MinIndx
获取向量中的最小值及其索引。
函数接口声明如下:
- 整型数的操作:
HmppResult HMPPS_MinIndx_16s(const int16_t *src, int32_t len, int16_t *min, int32_t *indx);
HmppResult HMPPS_MinIndx_32s(const int32_t *src, int32_t len, int32_t *min, int32_t *indx);
- 浮点数的操作:
HmppResult HMPPS_MinIndx_32f(const float *src, int32_t len, float *min, int32_t *indx);
HmppResult HMPPS_MinIndx_64f(const double *src, int32_t len, double *min, int32_t *indx);
参数
参数名 |
描述 |
取值范围 |
输入/输出 |
---|---|---|---|
src |
源向量。 |
非空 |
输入 |
len |
向量长度。 |
(0,INT_MAX] |
输入 |
min |
向量元素最小值。 |
非空 |
输出 |
indx |
向量元素最小值的位置索引。 |
非空 |
输出 |
返回值
- 成功:返回HMPP_STS_NO_ERR。
- 失败:返回错误码。
错误码
错误码 |
描述 |
---|---|
HMPP_STS_NULL_PTR_ERR |
src、min、indx这几个入参中存在空指针。 |
HMPP_STS_SIZE_ERR |
len小于或等于0。 |
示例
#define BUFFER_SIZE_T 10 void MinIndxExample(void) { int16_t src[BUFFER_SIZE_T] = {3, 0, 2, -8, 3, 15, 26, -31, 1, 23}; int16_t min; int32_t minIndex; HmppResult result = HMPPS_MinIndx_16s(src, BUFFER_SIZE_T, &min, &minIndex); printf("result = %d\n", result); if (result != HMPP_STS_NO_ERR) { return; } printf("min = %d, index of min is %d\n", min, minIndex); }
运行结果:
result = 0 min = -31, index of min is 7
父主题: 基础与通用运算