std:: comp_ellint_2, std:: comp_ellint_2f, std:: comp_ellint_2l
|
double
comp_ellint_2
(
double
arg
)
;
double
comp_ellint_2
(
float
arg
)
;
|
(1) | |
|
double
comp_ellint_2
(
IntegralType arg
)
;
|
(2) | |
すべての特殊関数と同様に、
comp_ellint_2
は、
__STDCPP_MATH_SPEC_FUNCS__
が実装によって少なくとも201003L以上の値として定義されており、かつユーザーが標準ライブラリのヘッダーをインクルードする前に
__STDCPP_WANT_MATH_SPEC_FUNCS__
を定義している場合にのみ、
<cmath>
で利用可能であることが保証されています。
目次 |
パラメータ
| arg | - | 浮動小数点型または整数型の値 |
戻り値
エラーが発生しない場合、第二種完全楕円積分の値、すなわち arg に対する ellint_2(arg, π/2) が返されます。
エラーハンドリング
エラーは math_errhandling で指定される通りに報告される場合があります。
- 引数がNaNの場合、NaNが返され、定義域エラーは報告されません。
- |arg| > 1 の場合、定義域エラーが発生する可能性があります。
注記
TR 29124をサポートせず、TR 19768をサポートする実装では、この関数はヘッダー
tr1/cmath
および名前空間
std::tr1
で提供されます。
この関数の実装は boost.math でも利用可能です。
例
(gcc 6.0で示された通り動作します)
#define __STDCPP_WANT_MATH_SPEC_FUNCS__ 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(0.5) = " << std::comp_ellint_2(0.5) << '\n' << "E(0.5, π/2) = " << std::ellint_2(0.5, hpi) << '\n'; }
出力:
E(0) = 1.5708 π/2 = 1.5708 E(0.5) = 1.46746 E(0.5, π/2) = 1.46746
外部リンク
Weisstein, Eric W. "第二種完全楕円積分" MathWorldより -- Wolfram Webリソース
関連項目
|
第二種(不完全)楕円積分
(関数) |