中文
注册
我要评分
文档获取效率
文档正确性
内容完整性
文档易理解
在线提单
论坛求助

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

  • 在vsatan2中,src1是单精度浮点类型。
  • 在vdatan2中,src1是双精度浮点类型。

输入向量src1,向量长度为len。

若为空指针,会提示空指针错误并返回。

输入

src2

  • 在vsatan2中,src2是单精度浮点类型。
  • 在vdatan2中,src2是双精度浮点类型。

输入向量src2,向量长度为len。

若为空指针,会提示空指针错误并返回。

输入

dst

  • 在vsatan2中,dst是单精度浮点类型。
  • 在vdatan2中,dst是双精度浮点类型。

输出向量dst,向量长度为len。

若为空指针,会提示空指针错误并返回。

输出

输出结果

  1. 每个运算值atan2(y, x) 返回的是原点至点 (x, y) 的方位角,即与x轴的夹角。返回值的单位为弧度,取值范围为(-π, +π]。
  2. 输入y为±0,x为负或-0,则返回±π。
  3. 输入y为±0,x为正或+0,则返回±0。
  4. 输入y为±∞,x为有限,则返回±π/2。
  5. 输入y为±∞,x为-∞,则返回±3π/4。
  6. 输入y为±∞,x为+∞,则返回±π/4。
  7. 输入x为±0,y为负,则返回-π/2。
  8. 输入x为±0,y为正,则返回+π/2。
  9. 输入x是-∞,y是有限且正的,则返回+π。
  10. 输入x为-∞, y为有限负,则返回-π。
  11. 输入x为+∞,且y为有限且为正,则返回+0。
  12. 输入x为+∞,且y为有限且为负,则返回-0。
  13. 输入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 
    !