std::comp_ellint_2, std::comp_ellint_2f, std::comp_ellint_2l
ヘッダ <cmath> で定義 | ||
double comp_ellint_2(double k); float comp_ellint_2(float k ); | (1) | (C++17以上) |
double comp_ellint_2( 整数型 k ); | (2) | (C++17以上) |
目次 |
[編集]引数
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) と等しくなります。 ただし E は std::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) | 第二種 (不完全) 楕円積分 (関数) |