Namespaces
Variants

catanhf, catanh, catanhl

From cppreference.net
定义于头文件 <complex.h>
float complex catanhf ( float complex z ) ;
(1) (C99 起)
double complex catanh ( double complex z ) ;
(2) (C99 起)
long double complex catanhl ( long double complex z ) ;
(3) (C99 起)
定义于头文件 <tgmath.h>
#define atanh( z )
(4) (C99 起)
1-3) 计算 z 的复反双曲正切,其在实轴上沿区间 [−1; +1] 之外存在分支切割。
4) 类型泛型宏:若 z 具有类型 long double complex ,则调用 catanhl ;若 z 具有类型 double complex ,则调用 catanh ;若 z 具有类型 float complex ,则调用 catanhf 。若 z 为实数或整数,则宏调用相应的实数函数( atanhf atanh atanhl )。若 z 为虚数,则宏调用 atan 的相应实数版本,实现公式 atanh(iy) = i atan(y) ,且返回类型为虚数。

目录

参数

z - 复参数

返回值

若无错误发生,则返回 z 的复反双曲正切值,其取值范围为沿实轴数学无界、沿虚轴位于区间 [−iπ/2; +iπ/2] 的半带域内。

错误处理与特殊值

错误报告方式与 math_errhandling 保持一致

如果实现支持 IEEE 浮点运算,

  • catanh ( conj ( z ) ) == conj ( catanh ( z ) )
  • catanh ( - z ) == - catanh ( z )
  • z +0+0i ,结果为 +0+0i
  • z +0+NaNi ,结果为 +0+NaNi
  • z +1+0i ,结果为 +∞+0i 并触发 FE_DIVBYZERO
  • z x+∞i (对于任意有限正数 x),结果为 +0+iπ/2
  • z x+NaNi (对于任意有限非零 x),结果为 NaN+NaNi 且可能触发 FE_INVALID
  • z +∞+yi (对于任意有限正数 y),结果为 +0+iπ/2
  • z +∞+∞i ,结果为 +0+iπ/2
  • z +∞+NaNi ,结果为 +0+NaNi
  • z NaN+yi (对于任意有限 y),结果为 NaN+NaNi 且可能触发 FE_INVALID
  • z NaN+∞i ,结果为 ±0+iπ/2 (实部符号未指定)
  • z NaN+NaNi ,结果为 NaN+NaNi

注释

尽管C标准将此函数命名为"复反双曲正切",但双曲函数的反函数实际上是面积函数。它们的参数是双曲扇形的面积,而非弧长。正确的名称应为"复反双曲正切",较少使用的名称为"复面积双曲正切"。

反双曲正切是一个多值函数,需要在复平面上设置分支切割。按照惯例,分支切割通常置于实轴的线段 (-∞,-1] [+1,+∞) 上。

The mathematical definition of the principal value of the inverse hyperbolic tangent is atanh z =
ln(1+z)-ln(z-1)
2
.


For any z, atanh(z) =
atan(iz)
i

示例

#include <stdio.h>
#include <complex.h>
int main(void)
{
    double complex z = catanh(2);
    printf("catanh(+2+0i) = %f%+fi\n", creal(z), cimag(z));
    double complex z2 = catanh(conj(2)); // 或在 C11 中使用 catanh(CMPLX(2, -0.0))
    printf("catanh(+2-0i) (分支切割的另一侧) = %f%+fi\n", creal(z2), cimag(z2));
    // 对于任意 z,atanh(z) = atan(iz)/i
    double complex z3 = catanh(1+2*I);
    printf("catanh(1+2i) = %f%+fi\n", creal(z3), cimag(z3));
    double complex z4 = catan((1+2*I)*I)/I;
    printf("catan(i * (1+2i))/i = %f%+fi\n", creal(z4), cimag(z4));
}

输出:

catanh(+2+0i) = 0.549306+1.570796i
catanh(+2-0i) (the other side of the cut) = 0.549306-1.570796i
catanh(1+2i) = 0.173287+1.178097i
catan(i * (1+2i))/i = 0.173287+1.178097i

参考文献

  • C11 标准 (ISO/IEC 9899:2011):
  • 7.3.6.3 catanh 函数 (p: 193)
  • 7.25 泛型数学 <tgmath.h> (p: 373-375)
  • G.6.2.3 catanh 函数 (p: 540-541)
  • G.7 泛型数学 <tgmath.h> (p: 545)
  • C99 标准 (ISO/IEC 9899:1999):
  • 7.3.6.3 catanh 函数 (p: 175)
  • 7.22 泛型数学 <tgmath.h> (p: 335-337)
  • G.6.2.3 catanh 函数 (p: 475-476)
  • G.7 泛型数学 <tgmath.h> (p: 480)

参考

(C99) (C99) (C99)
计算复反双曲正弦
(函数)
(C99) (C99) (C99)
计算复反双曲余弦
(函数)
(C99) (C99) (C99)
计算复双曲正切
(函数)
(C99) (C99) (C99)
计算反双曲正切 ( artanh(x) )
(函数)
C++ 文档 for atanh