获取向量中的最小值及其索引。
函数接口声明如下:
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_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