命名空间
变体
操作

cprojf, cproj, cprojl

来自 cppreference.cn
< c‎ | 数值‎ | 复数
定义在头文件 <complex.h>
float complex       cprojf( float complex z );
(1) (C99 起)
double complex      cproj( double complex z );
(2) (C99 起)
long double complex cprojl( long double complex z );
(3) (C99 起)
定义于头文件 <tgmath.h>
#define cproj( z )
(4) (C99 起)
1-3) 计算 z 在黎曼球面上的投影。
4) 泛型宏:如果 z 的类型是 long double complexlong double imaginarylong double,则调用 cprojl。如果 z 的类型是 float complexfloat imaginaryfloat,则调用 cprojf。如果 z 的类型是 double complexdouble imaginarydouble 或任何整数类型,则调用 cproj

对于大多数 zcproj(z)==z,但所有复无穷大,即使是一个分量为无穷大而另一个为 NaN 的数,都变为正实无穷大,INFINITY+0.0*IINFINITY-0.0*I。虚(零)分量的符号是 cimag(z) 的符号。

目录

[编辑] 参数

z - 复数参数

[编辑] 返回值

z 在黎曼球面上的投影。

此函数对所有可能的输入都完全指定,不受 math_errhandling 中描述的任何错误的影响。

[编辑] 注意

cproj 函数通过将所有无穷大映射到一个点(忽略虚零的符号),帮助对黎曼球面进行建模,并且应该在任何可能对其他无穷大给出错误结果的操作(尤其是比较操作)之前使用。

[编辑] 示例

#include <stdio.h>
#include <complex.h>
#include <math.h>
 
int main(void)
{
    double complex z1 = cproj(1 + 2*I);
    printf("cproj(1+2i) = %.1f%+.1fi\n", creal(z1),cimag(z1));
 
    double complex z2 = cproj(INFINITY+2.0*I);
    printf("cproj(Inf+2i) = %.1f%+.1fi\n", creal(z2),cimag(z2));
 
    double complex z3 = cproj(INFINITY-2.0*I);
    printf("cproj(Inf-2i) = %.1f%+.1fi\n", creal(z3),cimag(z3));
}

输出

cproj(1+2i) = 1.0+2.0i
cproj(Inf+2i) = inf+0.0i
cproj(Inf-2i) = inf-0.0i

[编辑] 参考

  • C11 标准 (ISO/IEC 9899:2011)
  • 7.3.9.5 cproj 函数 (p: 198)
  • 7.25 类型通用数学 <tgmath.h> (p: 373-375)
  • G.7 类型通用数学 <tgmath.h> (p: 545)
  • C99 标准 (ISO/IEC 9899:1999)
  • 7.3.9.4 cproj 函数 (p: 179)
  • 7.22 类型通用数学 <tgmath.h> (p: 335-337)
  • G.7 类型通用数学 <tgmath.h> (p: 480)

[编辑] 另请参阅

C++ 文档,关于 proj