Namespaces
Variants

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

From cppreference.net
double comp_ellint_2 ( double arg ) ;

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

long double comp_ellint_2l ( long double arg ) ;
(1)
double comp_ellint_2 ( IntegralType arg ) ;
(2)
1) 第二種完全楕円積分を計算します。 complete elliptic integral of the second kind arg に対する値を求めます。
2) 任意の 整数型 の引数を受け入れるオーバーロードのセットまたは関数テンプレート。引数を double にキャストした後の (1) と等価です。

すべての特殊関数と同様に、 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リソース

関連項目

第二種(不完全)楕円積分
(関数)