std:: comp_ellint_1, std:: comp_ellint_1f, std:: comp_ellint_1l
|
double
comp_ellint_1
(
double
arg
)
;
double
comp_ellint_1
(
float
arg
)
;
|
(1) | |
|
double
comp_ellint_1
(
IntegralType arg
)
;
|
(2) | |
与所有特殊函数一样,只有当实现将
__STDCPP_MATH_SPEC_FUNCS__
定义为至少 201003L 的值,并且用户在包含任何标准库头文件之前定义了
__STDCPP_WANT_MATH_SPEC_FUNCS__
时,才保证
comp_ellint_1
在
<cmath>
中可用。
目录 |
参数
| arg | - | 浮点或整数类型的值 |
返回值
若无错误发生,则返回第一类完全椭圆积分 arg 的值,即 ellint_1(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 << "K(0) = " << std::comp_ellint_1(0) << '\n' << "π/2 = " << hpi << '\n' << "K(0.5) = " << std::comp_ellint_1(0.5) << '\n' << "F(0.5, π/2) = " << std::ellint_1(0.5, hpi) << '\n'; }
输出:
K(0) = 1.5708 π/2 = 1.5708 K(0.5) = 1.68575 F(0.5, π/2) = 1.68575
外部链接
Weisstein, Eric W. "第一类完全椭圆积分" 摘自 MathWorld——Wolfram 网络资源。
另请参阅
|
(不完全)第一类椭圆积分
(函数) |