C++官网参考链接:https://cplusplus.com/reference/cmath/log1p/
函数
<cmath> <ctgmath>
log1p
C99
double log1p(double x);
float log1pf(float x);
long double log1pl(long double x);
C++11
double log1p(double x);
float log1p(float x);
long double log1p(long double x);
double log1p (T x); // additional overloads for integral types
计算对数加1
返回1+x的和的自然对数。
对于小的x绝对大小值,log1p可能比log(1+x)更准确。
C99
头文件<tgmath.h>提供了该函数的泛型类型的宏版本。
C++11
在此头文件(<cmath>)中为整型(integral types)提供了额外的重载:这些重载在计算之前有效地将x转换为double类型(定义T为任何整型(integral types))。
形参
计算其对数的值。
如果参数小于-1,则发生定义域错误。
返回值
1+x的和的自然对数。
如果x小于-1,则会导致定义域错误。
如果x是-1,它可能会导致极点错误(取决于库实现)。
如果发生定义域错误:
—math_errhandling具有MATH_ERRNO集合:全局变量errno设置为EDOM。
—math_errhandling具有MATH_ERREXCEPT集合:将引发FE_INVALID。
如果发生极点错误:
—math_errhandling具有MATH_ERRNO集合:全局变量errno设置为ERANGE。
—math_errhandling具有MATH_ERREXCEPT集合:引发FE_DIVBYZERO。
用例
/* log1p example */
#include <stdio.h> /* printf */
#include <math.h> /* log1p */
int main ()
{
double param, result;
param = 1.0;
result = log1p (param);
printf ("log1p (%f) = %f.\n", param, result );
return 0;
}
输出: