名前空間
変種
操作

std::comp_ellint_2, std::comp_ellint_2f, std::comp_ellint_2l

提供: cppreference.com
 
 
 
 
ヘッダ <cmath> で定義
double      comp_ellint_2( double k);

float       comp_ellint_2( float k );
long double comp_ellint_2( long double k );
float       comp_ellint_2f( float k );

long double comp_ellint_2l( long double k );
(1) (C++17以上)
double      comp_ellint_2( 整数型 k );
(2) (C++17以上)
1) k第二種完全楕円積分を計算します。
2) 任意の整数型の引数を取るオーバーロード集合または関数テンプレート。 引数を double にキャストした後は (1) と同等です。

目次

[編集] 引数

k - 楕円の母数または離心率 (浮動小数点型または整数型の値)

[編集] 戻り値

エラーが発生しなければ、 k の第二種完全楕円積分、すなわち ellint_2(k,π/2) の値が返されます。

[編集] エラー処理

エラーは math_errhandling で規定されている通りに報告されます。

  • 引数が NaN の場合は、 NaN が返されます。 定義域エラーは報告されません。
  • |k|>1 の場合、定義域エラーが発生するかもしれません。

[編集] ノート

C++17 をサポートしないけれども ISO 29124:2010 をサポートする処理系は、 __STDCPP_MATH_SPEC_FUNCS__ が処理系によって少なくとも 201003L の値に定義されており、ユーザがいかなる標準ライブラリのヘッダもインクルードする前に __STDCPP_WANT_MATH_SPEC_FUNCS__ を定義する場合、この関数を提供します。

ISO 29124:2010 をサポートしなけれども TR 19768:2007 (TR1) をサポートする処理系は、ヘッダ <tr1/cmath> および名前空間 std::tr1 で、この関数を提供します。

この関数の実装は boost.math でも利用可能です。

離心率 k および長半径 a を持つ楕円の外周は 4aE(k) と等しくなります。 ただし Estd::comp_ellint_2 です。 離心率が 0 と等しいとき、楕円は半径 a の円に縮退し、その外周は 2πa と等しく、そのため E(0) = π/2 です。 離心率が 1 と等しいとき、楕円は長さ 2a の直線に縮退し、その外周は 4a であり、そのため E(1) = 1 です。

[編集]

#include <cmath>
#include <iostream>
int main()
{
    double hpi = std::acos(-1)/2;
    std::cout << "E(0) = " << std::comp_ellint_2(0) << '\n'
              << "π/2 = " << hpi << '\n'
              << "E(1) = " << std::comp_ellint_2(1) << '\n'
              << "E(1, π/2) = " << std::ellint_2(1, hpi) << '\n';
}

出力:

E(0) = 1.5708
π/2 = 1.5708
E(1) = 1
E(1, π/2) = 1

[編集] 外部リンク

Weisstein, Eric W. "Complete Elliptic Integral of the Second Kind." From MathWorld--A Wolfram Web Resource.

[編集] 関連項目

(C++17)(C++17)(C++17)
第二種 (不完全) 楕円積分
(関数) [edit]