计算x的伽马值绝对值的自然对数,返回伽马值的符号,输入参数为实数。
C interface:
float gammaf_r(float x, int *signgam);
double gamma_r(double x, int *signgam);
参数名 |
类型 |
描述 |
输入/输出 |
---|---|---|---|
x |
在gammaf_r中,x是单精度浮点类型。 在gamma_r中,x是双精度浮点类型。 |
表示输入数据的浮点值。 |
输入 |
signgam |
在gammaf_r中,signgam是整数类型指针。 在gamma_r中,signgam是整数类型指针。 |
存储x的伽马值的符号 |
输出 |
C: "km.h"
// print result int sign=0; double res=0.0; res=gamma_r(0.0, &sign); printf("gamma_r(0.0, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(-0.0, &sign); printf("gamma_r(-0.0, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(0.25, &sign); printf("gamma_r(0.25, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(-0.25, &sign); printf("gamma_r(-0.25, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(0.5, &sign); printf("gamma_r(0.5, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(-0.5, &sign); printf("gamma_r(-0.5, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(1.0, &sign); printf("gamma_r(1.0, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(-1.0, &sign); printf("gamma_r(-1.0, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(2.0, &sign); printf("gamma_r(2.0, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(-2.0, &sign); printf("gamma_r(-2.0, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(INFINITY, &sign); printf("gamma_r(INFINITY, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(-INFINITY, &sign); printf("gamma_r(-INFINITY, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(NAN, &sign); printf("gamma_r(NAN, &sign) = %.15f, sign = %d\n", res, sign); res=gamma_r(-NAN, &sign); printf("gamma_r(-NAN, &sign) = %.15f, sign = %d\n", res, sign); /* * gamma_r(0.0, &sign) = inf, sign = 1 * gamma_r(-0.0, &sign) = inf, sign = -1 * gamma_r(0.25, &sign) = 1.288022524698077, sign = 1 * gamma_r(-0.25, &sign) = 1.589575312551186, sign = -1 * gamma_r(0.5, &sign) = 0.572364942924700, sign = 1 * gamma_r(-0.5, &sign) = 1.265512123484645, sign = -1 * gamma_r(1.0, &sign) = 0.000000000000000, sign = 1 * gamma_r(-1.0, &sign) = inf, sign = 1 * gamma_r(2.0, &sign) = 0.000000000000000, sign = 1 * gamma_r(-2.0, &sign) = inf, sign = 1 * gamma_r(INFINITY, &sign) = inf, sign = 1 * gamma_r(-INFINITY, &sign) = inf, sign = 1 * gamma_r(NAN, &sign) = nan, sign = 1 * gamma_r(-NAN, &sign) = -nan, sign = 1 * * */