c语言m1,expm1 - [ C语言中文开发手册 ] - 在线原生手册 - php中文网

本文详细介绍了C语言中的expm1函数,该函数用于计算e的给定倍率减去1,特别适用于处理接近零的参数。文章通过示例展示了expm1函数的精度优势,并提供了其在财务计算和反双曲函数中的应用。此外,还讨论了错误处理和特殊值的处理情况,如零、无穷大和NaN。
摘要由CSDN通过智能技术生成

在头文件中定义float expm1f(float arg);(1)(自C99以来)

double expm1(double arg);(2)(自C99以来)

long double expm1l(long double arg);(3)(自C99以来)

在头文件中定义

#define expm1(arg)(4)(自C99以来)

1-3)计算提升到给定倍率参数的e(欧拉数,2.7182818)减去1.0。 如果arg接近零,则此函数比表达式std :: exp(arg)-1.0更准确。

4)类型 - 通用宏:如果arg的类型是long double,则调用expm1l。 否则,如果arg具有整数类型或类型double,则调用expm1。 否则,调用expm1f。

参数

arg-floating point value

返回值

如果没有错误发生 earg

则返回-1。

如果发生由溢出引起的范围错误,则返回+ HUGE_VAL,+ HUGE_VALF或+ HUGE_VALL。

如果由于下溢而发生范围错误,则返回正确的结果(舍入后)。

错误处理

按照math_errhandling中的指定报告错误。

如果实现支持IEEE浮点运算(IEC 60559),

如果参数为±0,则返回,未修改

如果参数是-∞,则返回-1

如果参数是+∞,则返回+∞

如果参数是NaN,则返回NaN

注意

函数expm1和log1p对于财务计算很有用,例如,在计算小的每日利率时:(1 + x)n

-1可以表示为expm1(n * log1p(x))。 这些功能还简化了写入准确的反双曲函数。

对于兼容IEEE的类型,如果709.8

#include #include #include #include #include #pragma STDC FENV_ACCESS ON

int main(void){    printf("expm1(1) = %f\n", expm1(1));    printf("Interest earned in 2 days on $100, compounded daily at 1%%\n"           " on a 30/360 calendar = %f\n",           100*expm1(2*log1p(0.01/360)));    printf("exp(1e-16)-1 = %g, but expm1(1e-16) = %g\n",           exp(1e-16)-1, expm1(1e-16));    // special values    printf("expm1(-0) = %f\n", expm1(-0.0));    printf("expm1(-Inf) = %f\n", expm1(-INFINITY));    //error handling

errno = 0; feclearexcept(FE_ALL_EXCEPT);    printf("expm1(710) = %f\n", expm1(710));    if(errno == ERANGE) perror("    errno == ERANGE");    if(fetestexcept(FE_OVERFLOW)) puts("    FE_OVERFLOW raised");}

可能的输出:

expm1(1) = 1.718282Interest earned in 2 days on $100, compounded daily at 1%

on a 30/360 calendar = 0.005556exp(1e-16)-1 = 0, but expm1(1e-16) = 1e-16expm1(-0) = -0.000000expm1(-Inf) = -1.000000expm1(710) = inf

errno == ERANGE: Result too large

FE_OVERFLOW raised

参考

C11标准(ISO / IEC 9899:2011):7.12.6.3 expm1函数(p:243)

7.25类型通用数学(p:373-375)

F.10.3.3 expm1函数(p:521)

C99标准(ISO / IEC 9899:1999):7.12.6.3 expm1函数(p:223-224)

7.22类型通用数学(p:335-337)

F.9.3.3 expm1函数(p:458)

扩展内容

Expexpfexpl(C99)(C99)计算e给定的倍率(ex)(函数)exp2exp2fexp2l(C99)(C99)(C99)计算2提高到给定的倍率(2x)(功能)

log1plog1pflog1pl(C99)(C99)(C99)计算1加上给定数(ln(1 + x))(函数)的自然(基e)对数,

| expm1的C ++文档 |

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值