cprojf, cproj, cprojl
来自 cppreference.com
定义于头文件 <complex.h> |
||
(1) | (自 C99 起) | |
(2) | (自 C99 起) | |
(3) | (自 C99 起) | |
定义于头文件 <tgmath.h> |
||
#define cproj( z ) |
(4) | (自 C99 起) |
1-3) 计算
z
在黎曼球面上的投影。4) 类型通用宏: 如果
z
的类型为 long double complex, long double imaginary, 或 long double, 则调用 cprojl
。如果 z
的类型为 float complex, float imaginary, 或 float, 则调用 cprojf
。如果 z
的类型为 double complex, double imaginary, double, 或任何整数类型,则调用 cproj
。对于大多数 z
,cproj(z)==z,但所有复数无穷大,即使是其中一个分量为无穷大而另一个为 NaN 的数字,也会变为正实数无穷大,INFINITY+0.0*I 或 INFINITY-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 The cproj functions (p: 198)
- 7.25 Type-generic math <tgmath.h> (p: 373-375)
- G.7 Type-generic math <tgmath.h> (p: 545)
- C99 标准 (ISO/IEC 9899:1999)
- 7.3.9.4 The cproj functions (p: 179)
- 7.22 Type-generic math <tgmath.h> (p: 335-337)
- G.7 Type-generic math <tgmath.h> (p: 480)
[编辑] 参见
C++ 文档 for proj
|