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

v?maxmag

矢量计算x和y中幅度更大的值,其中x、y为矢量数组。

接口定义

C interface:

void vsmaxmag(const int len, const float* src1, const float* src2, float* dst);

void vdmaxmag(const int len, const double* src1, const double* src2, double* dst);

参数

参数名

类型

描述

输入/输出

len

整型数

表示输入向量的元素个数。

len≤0时会提示len无效并返回。

输入

src1

  • 在vsmaxmag中是单精度浮点类型。
  • 在vdmaxmag中是双精度浮点类型。

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

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

输入

src2

  • 在vsmaxmag中是单精度浮点类型。
  • 在vdmaxmag中是双精度浮点类型。

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

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

输入

dst

  • 在vsmaxmag中是单精度浮点类型。
  • 在vdmaxmag中是双精度浮点类型。

输出dst,向量长度为len。

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

输出

输出结果

  • 每个运算值返回结果如下:

    如果|x| > |y|,返回x,否则返回y。

    如果|x| < |y|,返回y,否则返回x。

    否则返回fmax(x, y)。

  • 其他特殊值参考如下说明。

    输入值(src1)

    输入值(src2)

    输出值(dst)

    != nan

    nan

    x

    nan

    != nan

    y

    nan

    nan

    nan

依赖

C: "kvml.h"

示例

C interface:

    int i, len = 8; 
    float src1[8] = {-1.5f, -0.0f, 0.0f, 1.0f, 1.5f, -INFINITY, INFINITY, NAN};
    float src2[8] = {-1.1f, 0.0f, +0.0f, -1.0f, -1.5f, +INFINITY, -INFINITY, -NAN}; 
    float* dst = (float*)malloc(sizeof(float) * len); 
    if (dst == NULL) { 
        printf("Malloc Failed!\n"); 
        return 0;
    }
    vsmaxmag(len, src1, src2, dst);

    /** 
     *  Output dst: 
     *     -1.500000 0.000000 0.000000 1.000000 1.500000 inf inf nan
     */
搜索结果
找到“0”个结果

当前产品无相关内容

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