v?copysign
符号拷贝函数,将src2中的符号位数据与src1中的非符号位数据结合,存储到dst,输入为向量。
接口定义
C interface:
void vscopysign(const int len, const float* src1, const float* src2, float* dst);
void vdcopysign(const int len, const double* src1, const double* src2, double* dst);
参数
参数名 |
类型 |
描述 |
输入/输出 |
---|---|---|---|
len |
整型数 |
表示输入向量的元素个数。 len≤0时会提示len无效并返回。 |
输入 |
src1 |
|
输入向量src1,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输入 |
src2 |
|
输入向量src2,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输入 |
dst |
|
输出dst,向量长度为len。 若为空指针,会提示空指针错误并返回。 |
输出 |
输出结果
- 每个运算值返回x2的符号位拷贝至x1得到的结果。
- 其他特殊值参考如下说明。
输入值(src1)
输入值(src2)的符号位
输出值(dst)
±inf
0
+inf
±inf
1
-inf
nan
0
nan
nan
1
-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.5f, 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; } vscopysign(len, src1, src2, dst); /** * Output dst: * 1.500000 0.000000 0.000000 -1.000000 -1.500000 inf -inf -nan */
父主题: 函数定义