std::beta, std::betaf, std::betal
來自 cppreference.com
< cpp | experimental | 特殊函式
double beta( double x, double y ); float betaf( float x, float y ); |
(1) | |
Promoted beta( Arithmetic x, Arithmetic y ); |
(2) | |
2) 針對所有非 (1) 中涵蓋的算術型別引數組合的過載集或函式模板。如果任何引數具有整型,則將其轉換為 double。如果任何引數是 long double,則返回型別
Promoted
也為 long double,否則返回型別始終為 double。與所有特殊函式一樣,僅當實現將 __STDCPP_MATH_SPEC_FUNCS__
定義為至少 201003L 的值,並且使用者在包含任何標準庫標頭檔案之前定義了 __STDCPP_WANT_MATH_SPEC_FUNCS__
時,beta
才保證在 <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. "Beta Function." From MathWorld--A Wolfram Web Resource。