std::beta, std::betaf, std::betal
来自 cppreference.com
< cpp | experimental | 特殊函数
double beta( double x, double y ); float betaf( float x, float y ); |
(1) | |
提升 beta( Arithmetic x, Arithmetic y ); |
(2) | |
2) 一组重载或一个函数模板,用于所有未被 (1) 涵盖的算术类型参数组合。如果任何参数具有 整型,它将被强制转换为 double。如果任何参数是 long double,则返回类型
Promoted
也是 long double,否则返回类型始终为 double。与所有特殊函数一样,beta
仅当实现将 __STDCPP_MATH_SPEC_FUNCS__
定义为至少为 201003L 的值,并且用户在包含任何标准库头文件之前定义 __STDCPP_WANT_MATH_SPEC_FUNCS__
时,才保证在 <cmath>
中可用。
内容 |
[编辑] 参数
x, y | - | 浮点型或整型值 |
[编辑] 返回值
如果未发生任何错误,则返回 x 和 y 的贝塔函数值,即 ∫10tx-1
(1 - t)(y-1)
dt,或等效地,
Γ(x)Γ(y) |
Γ(x + y) |
[编辑] 错误处理
错误可能按 math_errhandling 中指定的进行报告。
- 如果任何参数为 NaN,则返回 NaN 且不报告域错误。
- 该函数仅在 x 和 y 都大于零时才需要定义,并且在其他情况下允许报告域错误。
[编辑] 备注
不支持 TR 29124 但支持 TR 19768 的实现,在头文件 tr1/cmath
和命名空间 std::tr1
中提供此函数。
此函数的实现也可以在 boost.math 中获得。
beta(x, y) 等于 beta(y, x)。
当 x 和 y 是正整数时,beta(x, y) 等于(x - 1)!(y - 1)! |
(x + y - 1)! |
⎜
⎝n
k⎞
⎟
⎠=
1 |
(n + 1)Β(n - k + 1, k + 1) |
[编辑] 示例
(在 gcc 6.0 中按所示工作)
运行此代码
#define __STDCPP_WANT_MATH_SPEC_FUNCS__ 1 #include <cmath> #include <iomanip> #include <iostream> #include <string> double binom(int n, int k) { return 1 / ((n + 1) * std::beta(n - k + 1, k + 1)); } int main() { std::cout << "Pascal's triangle:\n"; for (int n = 1; n < 10; ++n) { std::cout << std::string(20 - n * 2, ' '); for (int k = 1; k < n; ++k) std::cout << std::setw(3) << binom(n, k) << ' '; std::cout << '\n'; } }
输出
Pascal's triangle: 2 3 3 4 6 4 5 10 10 5 6 15 20 15 6 7 21 35 35 21 7 8 28 56 70 56 28 8 9 36 84 126 126 84 36 9
[编辑] 另请参阅
(C++11)(C++11)(C++11) |
伽马函数 (函数) |
[编辑] 外部链接
Weisstein, Eric W. "贝塔函数." 来自 MathWorld--Wolfram Web 资源。