名前空間
変種
操作

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 );
longdouble comp_ellint_2(longdouble k );
float       comp_ellint_2f(float k );

longdouble comp_ellint_2l(longdouble 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]
close