下载
中文
注册

功能及约束说明

Atlas 200/300/500 推理产品上,不支持本章中的PNGD功能。

Atlas 训练系列产品上,不支持本章中的PNGD功能。

功能说明

PNGD(PNG Decoder)功能:实现PNG格式图片的解码。

PNGD在解码图片时,支持按源图片格式解码。源图片格式解码是指解码前后图片的编码格式保持一致,例如解码前输入图片格式为RGB,解码后输出图片格式为RGB888。

如果不清楚PNG源图片格式、但想使用源格式解码时,有以下两种方式:

  • 在调用PNGD解码接口时,直接将输出图片格式配置为HI_PIXEL_FORMAT_UNKNOWN,输出格式默认按源图片格式输出。此种方式,由于不知道输出图片格式,因此需要用户申请尽量大的内存,防止内存不够,无法存放输出图片。

    输入图片格式

    操作

    实际输出图片格式

    RGB/GRAY

    将输出图片格式设置为HI_PIXEL_FORMAT_UNKNOWN

    RGB888

    RGBA/AGRAY

    将输出图片格式设置为HI_PIXEL_FORMAT_UNKNOWN

    RGBA8888

  • 先调用hi_mpi_png_get_image_info接口根据传入的PNG源图片,获取按源图解码时的输出图片的宽、高、宽stride、高stride、解码输出内存大小、图片格式等信息后,再调用PNGD解码接口,使用通过hi_mpi_png_get_image_info接口获取的图片格式来设置输出图片格式。

图片分辨率约束

  • 输入图片分辨率:

    最大分辨率4096*4096,最小分辨率32*32。

  • 输出图片分辨率

    PNGD只对图片解码,不会改变图片分辨率,因此输出与输入的图片分辨率保持一致。

内存申请/释放接口说明

输入内存的大小就是指实际的输入图片所占用的大小,输出内存的大小参见表1中的计算公式。

版本

内存申请/释放接口

Atlas 推理系列产品

PNG图片解码时,调用hi_mpi_dvpp_malloc\hi_mpi_dvpp_free接口申请\释放Device上的输入、输出内存,这部分内存的生命周期由用户自行管理。

Atlas A2训练系列产品

Atlas 200/500 A2推理产品

PNG图片解码时,支持以下两种内存申请接口:

  • 调用aclrtMalloc\aclrtFree接口申请\释放Device上的输入、输出内存,这部分内存的生命周期由用户自行管理。
  • 调用hi_mpi_dvpp_malloc\hi_mpi_dvpp_free接口申请\释放Device上的输入、输出内存,这部分内存的生命周期由用户自行管理。

注意:调用hi_mpi_dvpp_malloc接口申请的内存为媒体数据处理的专用内存,但专用内存的地址空间有限,若关注内存规划或内存资源有限时,建议调用aclrtMalloc接口申请内存。

图片格式、宽高对齐、内存约束

若不确定输出格式、将输出图片格式设置为HI_PIXEL_FORMAT_UNKNOWN时:

  • 宽stride:

    如果输入图片是RGB或GRAY格式,则宽stride为输出图片的宽先向上128对齐后再乘以3的值;如果输入图片是RGBA或AGRAY格式,则宽stride为输出图片的宽先向上128对齐后再乘以4的值。

  • 高stride:为输出图片的高向上16对齐后的值。
表1 图片格式、宽高对齐、内存大小约束

输入图片格式

输出图片格式

输出图片宽、高对齐要求

输出图片宽stride、高stride、内存大小要求

RGB

RGB888

无对齐要求

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以3的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

GRAY

RGB888

RGBA

RGB888

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以3的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

RGBA8888 8bit

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以4的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

AGRAY

RGB888

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以3的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

RGBA8888 8bit

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以4的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

  • 输出图片格式的定义请参见hi_pixel_format,宽stride、高stride等概念请参见基本概念
  • 如果用户将宽stride、高stride设置为0,传入对应的接口,PNGD内部在处理时,会默认根据输出图片格式将宽stride向上128对齐、高stride向上16对齐。

其它约束

PNGD只支持对完整PNG图片进行解码,不支持将一张PNG图片分割成多个数据包后,由PNGD解码。