cacoshf, cacosh, cacoshl_C语言中文网

定义于头文件 <complex.h>

float complex       cacoshf( float complex z );

(1) (C99 起)

double complex      cacosh( double complex z );

(2) (C99 起)

long double complex cacoshl( long double complex z );

(3) (C99 起)

定义于头文件 <tgmath.h>

#define acosh( z )

(4) (C99 起)

1-3) 计算复数值 z 的复反双曲余弦,分支切割在沿实轴小于 1 的值上。

4) 泛型宏:若 z 拥有 long double complex 类型,则调用 cacoshl 。若 z 拥有 double complex 类型,则调用 cacosh 。若 z 拥有 float complex 类型,则调用 cacoshf 。若 z 为实数或整数,则宏调用对应的实函数( acoshfacoshacoshl )。若 z 为虚数,则宏调用对应的复数版本,而返回类型为复数。

参数

返回值

z 的复反双曲余弦,沿实轴在区间 [0; ∞) 中,而沿虚轴在区间 [−iπ; +iπ] 中。

错误处理及特殊值

报告的错误与 math_errhandling 一致。

若实现支持 IEEE 浮点算术,则

  • cacosh(conj(z)) == conj(cacosh(z))
  • z±0+0i ,则结果为 +0+iπ/2
  • z+x+∞i (对于任何有限 x ),则结果为 +∞+iπ/2
  • z+x+NaNi (对于任何非零有限 x ),结果为 NaN+NaNi 并可能引发 FE_INVALID
  • z0+NaNi ,则结果为 NaN±iπ/2 ,其中虚部符号未指定
  • z-∞+yi (对于任何有限正 y ),则结果为 +∞+iπ
  • z+∞+yi (对于任何有限正 y ),则结果为 +∞+0i
  • z-∞+∞i ,则结果为 +∞+3iπ/4
  • z±∞+NaNi ,则结果为 +∞+NaNi
  • zNaN+yi (对于任何有限 y ),则结果为 NaN+NaNi 并可能引发 FE_INVALID
  • zNaN+∞i ,则结果为 +∞+NaNi
  • zNaN+NaNi ,则结果为 NaN+NaNi

注意

尽管 C 标准命名此函数为“复弧双曲余弦”,双曲函数的反函数是面积函数。其参数为双曲扇形的面积,而非弧长。正确名称是“复反双曲余弦”,和更少见的“复面积双曲余弦”。

反双曲余弦是多值函数,在复平面上要求分支切割。约定将分支切割置于实轴的线段 (-∞,+1) 上。

复反双曲余弦主值的数学定义是 acosh z = ln(z + z+1 z-1)

对于任何 z , acosh(z) = acos(z) ,或在复平面上半部简单地为 i acos(z)

示例

输出:

cacosh(+0.5+0i) = 0.000000-1.047198i
cacosh(+0.5-0i) (the other side of the cut) = 0.500000-0.000000i
casinh(1+1i) = 1.061275+0.666239i
I*asin(1+1i) = -1.061275+0.666239i

引用

  • C11 standard (ISO/IEC 9899:2011):
  • 7.3.6.1 The cacosh functions (p: 192)
  • 7.25 Type-generic math <tgmath.h> (p: 373-375)
  • G.6.2.1 The cacosh functions (p: 539-540)
  • G.7 Type-generic math <tgmath.h> (p: 545)
  • C99 standard (ISO/IEC 9899:1999):
  • 7.3.6.1 The cacosh functions (p: 174)
  • 7.22 Type-generic math <tgmath.h> (p: 335-337)
  • G.6.2.1 The cacosh functions (p: 474-475)
  • G.7 Type-generic math <tgmath.h> (p: 480)

参阅