Convert

该类接口可将图像像素值从一种数据类型转换为另一种数据类型。

函数接口声明如下:

参数

参数名

描述

取值范围

输入/输出

src

指向源向量的指针。

非空

输入

srcStep

源图像中连续行起点之间的距离(以字节为单位)。

(0, INT_MAX]

输入

dst

指向目的向量的指针。

非空

输出

srcDst

指向源图像感兴趣区域的指针。

非空

输入/输出

dstStep

目标图像中连续行的起点之间的距离(以字节为单位)。

(0, INT_MAX]

输入

srcDstStep

源图像中连续行的起点之间的距离(以字节为单位)。

非负整数

输入

roiSize

源和目标图像感兴趣区域的大小(以像素为单位)。

roiSize.width∈(0, INT_MAX],roiSize.height∈(0, INT_MAX]

输入

scale

比例因子。

[INT_MIN, INT_MAX]

输入

roundMode

HMPP_RND_ZERO:指定将浮点值截断为零。

0

输入

HMPP_RND_NEAR:指定当小数部分等于0.5时,浮点值四舍五入为最接近的偶数整数;否则,浮点值四舍五入为最接近的整数。

1

输入

HMPP_RND_FINANCIAL:指定当小数部分小于0.5时,浮点值向下舍入为最接近的整数;如果小数部分等于或大于0.5,则向上舍入为最接近的整数。

2

输入

返回值

错误码

错误码

描述

HMPP_STS_NULL_PTR_ERR

src、dst这两个入参中存在空指针。

HMPP_STS_SIZE_ERR

roiSize的字段为零或负值。

HMPP_STS_STEP_ERR

srcStep、dstStep中存在零或负值。

HMPP_STS_NOT_EVEN_STEP_ERR

srcStep、dstStep不能被src、dst所属数据类型的字节长度整除的错误条件。

HMPP_STS_NOT_SUPPORTED_MODE_ERR

输入模式为不支持的舍入模式。

HMPP_STS_ROI_ERR

roiSize.width > 步长。

示例

#define SRC_BUFFER_SIZE_T 28
#define DST_BUFFER_SIZE_T 28

int ConvertExample(){
    int32_t i;
    HmppiSize roi = {5,4};
    float dst[DST_BUFFER_SIZE_T] = {0.0f};
    uint8_t src[SRC_BUFFER_SIZE_T] = { 1, 2, 4, 8, 16, 8, 4, 
                                       1, 2, 4, 8, 16, 8, 4, 
                                       1, 2, 4, 8, 16, 8, 4, 
                                       1, 2, 4, 8, 16, 8, 4,};
    int32_t srcStep = 7 * sizeof(uint8_t);
    int32_t dstStep = 7 * sizeof(float);
    HmppResult result = HMPPI_Convert_8u32f_C1R(src, srcStep, dst, dstStep, roi);
    printf("result = %d \ndst =", result);
    for (i = 0; i < DST_BUFFER_SIZE_T; i++) {
        printf(" %f  ", dst[i]);
    }
    return 0;
}

运行结果:

result = 0
dst = 1.000000  2.000000  4.000000  8.000000  16.000000  0.000000  0.000000  1.000000  2.000000  4.000000  8.000000  16.000000  0.000000  0.000000 1.000000  2.000000  4.000000  8.000000  16.000000  0.000000  0.000000 1.000000  2.000000  4.000000  8.000000  16.000000  0.000000  0.000000