time-to-botec/js/node_modules/@stdlib/math/base/special/ellipk/README.md

137 lines
3.3 KiB
Markdown
Raw Permalink Normal View History

<!--
@license Apache-2.0
Copyright (c) 2019 The Stdlib Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
# ellipk
> Compute the [complete elliptic integral of the first kind][elliptic-integral].
<section class="intro">
The [complete elliptic integral of the first kind][elliptic-integral] is defined as
<!-- <equation class="equation" label="eq:complete_elliptic_integral_first_kind" align="center" raw="K(m)=\int_0^\tfrac{\pi}{2} \frac{d\theta}{\sqrt{1-m \sin^2\theta}}" alt="Complete elliptic integral of the first kind"> -->
<div class="equation" align="center" data-raw-text="K(m)=\int_0^\tfrac{\pi}{2} \frac{d\theta}{\sqrt{1-m \sin^2\theta}}" data-equation="eq:complete_elliptic_integral_first_kind">
<img src="https://cdn.jsdelivr.net/gh/stdlib-js/stdlib@fa2cf1d471224644251a972f9424f30bde62c2c3/lib/node_modules/@stdlib/math/base/special/ellipk/docs/img/equation_complete_elliptic_integral_first_kind.svg" alt="Complete elliptic integral of the first kind">
<br>
</div>
<!-- </equation> -->
where the parameter `m` is related to the modulus `k` by `m = k^2`.
</section>
<!-- /.intro -->
<section class="usage">
## Usage
```javascript
var ellipk = require( '@stdlib/math/base/special/ellipk' );
```
#### ellipk( m )
Computes the [complete elliptic integral of the first kind][elliptic-integral].
```javascript
var v = ellipk( 0.5 );
// returns ~1.854
v = ellipk( -1.0 );
// returns ~1.311
v = ellipk( 2.0 );
// returns NaN
v = ellipk( Infinity );
// returns NaN
v = ellipk( -Infinity );
// returns NaN
v = ellipk( NaN );
// returns NaN
```
</section>
<!-- /.usage -->
<section class="notes">
## Notes
- This function is valid for `-∞ < m <= 1`.
</section>
<!-- /.notes -->
<section class="examples">
## Examples
<!-- eslint no-undef: "error" -->
```javascript
var randu = require( '@stdlib/random/base/randu' );
var ellipk = require( '@stdlib/math/base/special/ellipk' );
var m;
var i;
for ( i = 0; i < 100; i++ ) {
m = -1.0 + ( randu() * 2.0 );
console.log( 'ellipk(%d) = %d', m, ellipk( m ) );
}
```
</section>
<!-- /.examples -->
* * *
<section class="references">
## References
- Fukushima, Toshio. 2009. "Fast computation of complete elliptic integrals and Jacobian elliptic functions." _Celestial Mechanics and Dynamical Astronomy_ 105 (4): 305. doi:[10.1007/s10569-009-9228-z][@fukushima:2009a].
- Fukushima, Toshio. 2015. "Precise and fast computation of complete elliptic integrals by piecewise minimax rational function approximation." _Journal of Computational and Applied Mathematics_ 282 (July): 7176. doi:[10.1016/j.cam.2014.12.038][@fukushima:2015a].
</section>
<!-- /.references -->
<section class="links">
[elliptic-integral]: https://en.wikipedia.org/wiki/Elliptic_integral
[@fukushima:2009a]: https://doi.org/10.1007/s10569-009-9228-z
[@fukushima:2015a]: https://doi.org/10.1016/j.cam.2014.12.038
</section>
<!-- /.links -->