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

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

  • 在vsatan中是单精度浮点类型。
  • 在vdatan中是双精度浮点类型。
  • 在vcatan中是复数单精度浮点类型。
  • 在vzatan中是复数双精度浮点类型。

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

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

输入

dst

  • 在vsatan中是单精度浮点类型。
  • 在vdatan中是双精度浮点类型。
  • 在vcatan中是复数单精度浮点类型。
  • 在vzatan中是复数双精度浮点类型。

输出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 
    !
搜索结果
找到“0”个结果

当前产品无相关内容

未找到相关内容,请尝试其他搜索词