v?atan2pi
计算src1/src2的反正切值除以π的值,src1和src2以及结果均为向量。
接口定义
C interface:
void vsatan2pi(const int len, const float* src1, const float* src2, float* dst);
void vdatan2pi(const int len, const double* src1, const double* src2, double* dst);
参数
参数名 |
类型 |
描述 |
输入/输出 |
---|---|---|---|
len |
整型数 |
表示输入向量的元素个数。 len≤0时会提示len无效并返回。 |
输入 |
src1 |
|
输入向量src1,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输入 |
src2 |
|
输入向量src2,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输入 |
dst |
|
输出向量dst,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输出 |
输出结果
- 计算每个运算值的反正切值除以π的值,取值范围为(-1, +1]。
- 其他特殊值参考如下说明。
输入值1(src1)
输入值2(src2)
输出值(dst)
±0
-0
±1
±0
+0
±0
±∞
有限值
±1/2
±∞
-∞
±3/4
±∞
+∞
±1/4
<0
±0
-1/2
>0
±0
-1/2
有限正值
-inf
+1
有限负值
-inf
-1
有限正值
+inf
+0
有限负值
+inf
-0
nan
any
nan
any
nan
nan
依赖
C: "kvml.h"
示例
C interface:
int i, len = 4; float src1[len] = {0.0f, 1.0f, -inf, inf}; float src2[len] = {0.0f, 2.0f, inf, nan}; float* dst = (float*)malloc(sizeof(float) * len); if (dst == NULL) { printf("Malloc Failed!\n"); return 0; } vsatan2pi(len, src1, src2, dst); /** * Output dst: * 0.0 0.14758362 -0.25 nan * */
父主题: 函数定义