v?atan2
计算src1/src2的反正切值,src1和src2以及结果均为向量。
接口定义
C interface:
void vsatan2(const int len, const float* src1, const float* src2, float* dst);
void vdatan2(const int len, const double* src1, const double* src2, double* dst);
Fortran interface:
CALL VSATAN2(LEN, SRC1, SRC2, DST);
CALL VDATAN2(LEN, SRC1, SRC2, DST);
参数
参数名 |
类型 |
描述 |
输入/输出 |
|---|---|---|---|
len |
整型数 |
表示输入向量的元素个数。 len≤0时会提示len无效并返回。 |
输入 |
src1 |
|
输入向量src1,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输入 |
src2 |
|
输入向量src2,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输入 |
dst |
|
输出向量dst,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输出 |
输出结果
- 每个运算值atan2(y, x)返回的是原点至点(x, y)的方位角,即与x轴的夹角。返回值的单位为弧度,取值范围为(-π, +π]。
- 输入y为±0,x为负或-0,则返回±π。
- 输入y为±0,x为正或+0,则返回±0。
- 输入y为±∞,x为有限,则返回±π/2。
- 输入y为±∞,x为-∞,则返回±3π/4。
- 输入y为±∞,x为+∞,则返回±π/4。
- 输入x为±0,y为负,则返回-π/2。
- 输入x为±0,y为正,则返回+π/2。
- 输入x是-∞,y是有限且正的,则返回+π。
- 输入x为-∞,y为有限负,则返回-π。
- 输入x为+∞,且y为有限且为正,则返回+0。
- 输入x为+∞,且y为有限且为负,则返回-0。
- 输入x为nan,或y为nan,则返回nan。
依赖
C: "kvml.h"
Fortran: "kvml.f03"
示例
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;
}
vsatan2(len, src1, src2, dst);
/**
* Output dst:
* 0.0 0.463647603988647 -0.785398185253143 nan
*
*/
Fortran interface:
INTEGER :: LEN = 4
REAL(4) SRC1(4)
REAL(4) SRC2(4)
REAL(4) DST(4)
DATA SRC1 /1.2, 2.5, -2.4, 3.6/
DATA SRC2 /8.6, -2.5, -12.4, 32.6/
CALL VSATAN2(LEN, SRC1, SRC2, DST)
!
! OUTPUT DST:
! 0.138639733, 2.35619450, -2.95040822, 0.109983824
!
父主题: 函数定义