v?arg
矢量计算输入复数的幅角,即虚部与实部比值的反正切值。
接口定义
C interface:
void vcarg(const int len, const float complex* src, float* dst);
void vzarg(const int len, const double complex* src, double* dst);
参数
参数名 |
类型 |
描述 |
输入/输出 |
---|---|---|---|
len |
整型数 |
表示输入向量的元素个数。 len≤0时会提示len无效并返回。 |
输入 |
src |
|
输入向量src,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输入 |
dst |
|
输出dst,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输出 |
输出结果
- 每一个运算值返回输入复数的幅角,计算公式为 arg(x + yi) = arctan(y/x)。
- 其他特殊值参考如下表格。
RE(z) i * IM(z) |
-∞ |
-X |
-0 |
+0 |
+X |
+∞ |
NAN |
---|---|---|---|---|---|---|---|
+i * ∞ |
+∞+i*∞ |
+π/2 |
+π/2 |
+π/2 |
+π/2 |
+π/4 |
NAN |
+i * Y |
+π |
+π/2 |
+π/2 |
+0 |
NAN |
||
+i * 0 |
+π |
+π |
+π |
+0 |
+0 |
+0 |
NAN |
-i * 0 |
-π |
-π |
-π |
-0 |
-0 |
-0 |
NAN |
-i * Y |
-π |
-π/2 |
-π/2 |
-0 |
NAN |
||
-i * ∞ |
-3*π/4 |
-π/2 |
-π/2 |
-π/2 |
-π/2 |
-π/4 |
NAN |
+i * NAN |
NAN |
NAN |
NAN |
NAN |
NAN |
NAN |
NAN |
依赖
C: "kvml.h"
示例
C interface:
#define N 4 const complex float src[N] = { __builtin_complex(-8.0f, 25.0f), __builtin_complex(+INFINITY, -2.1f), __builtin_complex(2.6f, 25.0f), __builtin_complex(-0.0f, +0.1f) }; float dst[N] = {0}; vcarg(N, src, dst); printFArr("output:", N, dst); /** * input: (-8.000,25.000) ( inf,-2.100) (2.600,25.000) (-0.000,0.100) * output: 1.880 -0.000 1.467 1.571 */
父主题: 函数定义