v?atan
计算输入的反正切值,输入为向量。
接口定义
C interface:
void vsatan(const int len, const float* src, float* dst);
void vdatan(const int len, const double* src, double* dst);
void vcatan(const int len, const float complex *src, float complex *dst);
void vzatan(const int len, const double complex *src, double complex *dst);
Fortran interface:
CALL VSATAN(LEN, SRC, DST);
CALL VDATAN(LEN, SRC, DST);
参数
参数名 |
类型 |
描述 |
输入/输出 |
---|---|---|---|
len |
整型数 |
表示输入向量的元素个数。 len≤0时会提示len无效并返回。 |
输入 |
src |
|
输入向量src,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输入 |
dst |
|
输出dst,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输出 |
输出结果
- 每个运算值返回输入x对应的反正切值y=arctan(x),y ∈(-π/2, +π/2)。
- 其他特殊值参考如下说明。
输入值(src)
输出值(dst)
+0
+0
-0
-0
±inf
±π/2
nan
nan
依赖
C: "kvml.h"
示例
C interface:
int i, len = 4; float src[len] = {0.0f, 2.0f, inf, nan}; float* dst = (float*)malloc(sizeof(float) * len); if (dst == NULL) { printf("Malloc Failed!\n"); return 0; } vsatan(len, src, dst); /** * Output dst: * 0.0 1.107148766517639 1.570796370506287 nan * */
Fortran interface:
INTEGER :: LEN = 4 REAL(4) SRC(4) REAL(4) DST(4) DATA SRC /1, 2, 3, 4/ CALL VSATAN(LEN, SRC, DST) ! ! OUTPUT DST: ! 0.785398185, 1.10714877, 1.24904573, 1.32581770 !
父主题: 函数定义