MaxAbs
Obtains the maximum absolute value in a vector.
The function interface declaration is as follows:
- Operations on integers:
HmppResult HMPPS_MaxAbs_16s(const int16_t *src, int32_t len, int16_t *maxAbs);
HmppResult HMPPS_MaxAbs_32s(const int32_t *src, int32_t len, int32_t *maxAbs);
- Operations on floating-point numbers:
HmppResult HMPPS_MaxAbs_32f(const float *src, int32_t len, float *maxAbs);
HmppResult HMPPS_MaxAbs_64f(const double *src, int32_t len, double *maxAbs);
Parameters
Parameter |
Description |
Value Range |
Input/Output |
|---|---|---|---|
src |
Pointer to the source vector |
The value cannot be NULL. |
Input |
len |
Vector length |
(0, INT_MAX] |
Input |
maxAbs |
Pointer to the maximum absolute value |
The value cannot be NULL. |
Output |
Return Value
- Success: HMPP_STS_NO_ERR
- Failure: An error code is returned.
Error Codes
Error Code |
Description |
|---|---|
HMPP_STS_NULL_PTR_ERR |
The value of src or maxAbs is NULL. |
HMPP_STS_SIZE_ERR |
The value of len is less than or equal to 0. |
Example
#define BUFFER_SIZE_T 10
void MaxAbsExample(void)
{
int16_t src[BUFFER_SIZE_T] = {3, 0, 2, -8, 3, 15, 26, -31, 1, 23};
int16_t maxAbs;
HmppResult result = HMPPS_MaxAbs_16s(src, BUFFER_SIZE_T, &maxAbs);
printf("result = %d ", result);
if (result != HMPP_STS_NO_ERR) {
return;
}
printf("maxAbs = %d\n", maxAbs);
}
Output:
result = 0 maxAbs = 31