约束说明
昇腾310 AI处理器上,该功能为预留功能,暂不支持。
昇腾910 AI处理器上,该功能为预留功能,暂不支持。
图片分辨率约束
- 输入图片分辨率:10*6~8192*8192。在调用接口实现VPC功能时,各接口对分辨率的要求可能不同,请参见VPC图像处理接口下各接口的说明。 
- 输出图片分辨率:10*6~4096*4096。
图片格式、宽高对齐、内存约束
VPC在处理图片时,需调用acl.himpi.dvpp_malloc接口申请Device上的输入、输出内存,调用acl.himpi.dvpp_free接口释放输入、输出内存,这部分内存的生命周期由用户自行管理。
 
 
     在调用接口实现VPC功能时:
- 图片格式的定义请参见hi_pixel_format,宽stride、高stride等概念请参见基本概念。
- 宽stride最小32、最大16384(16384=4096*4,宽是4096的argb格式的图像,1个像素占用4个字节,一行像素就占用4096*4,即宽stride);高stride最小6、最大16384。
- 各接口对图片格式的要求可能不同,请参见VPC图像处理接口下各接口的说明。
| 输入图片格式 | 输入图片宽、高对齐要求 | 输入图片宽stride、高stride、内存大小要求 | 
|---|---|---|
| YUV400 8bit | 无对齐要求 | 宽stride为宽16对齐后的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride | 
| YUV420SP NV12 8bit | 宽2对齐 高2对齐 | 宽stride为宽16对齐后的值;高stride为高2对齐后的值。 内存大小(单位Byte)= 宽stride * 高stride * 3/2 | 
| YUV420SP NV21 8bit | ||
| YUV422SP 8bit | 宽2对齐 高无对齐要求 | 宽stride为宽16对齐后的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride * 2 | 
| YVU422SP 8bit | ||
| YUV444SP 8bit | 无对齐要求 | 宽stride为宽16对齐后的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride * 3 | 
| YVU444SP 8bit | ||
| YUV422Packed YUYV 8bit | 宽2对齐 高无对齐要求 | 宽stride为宽16对齐后、再乘以2的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride | 
| YUV422Packed UYVY 8bit | ||
| YUV422Packed YVYU 8bit | ||
| YUV422Packed VYUY 8bit | ||
| YUV444Packed 8bit | 无对齐要求 | 宽stride为宽16对齐后、再乘以3的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride | 
| RGB888 | ||
| BGR888 | ||
| ARGB8888 | 无对齐要求 | 宽stride为宽16对齐后、再乘以4的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride | 
| ABGR8888 | ||
| RGBA8888 | ||
| BGRA8888 | ||
| YUV440SP 8bit | 宽无对齐要求 高2对齐 | 宽stride为宽16对齐后的值;高stride为高2对齐后的值。 内存大小(单位Byte)= 宽stride * 高stride * 2 | 
| YVU440SP 8bit | 
| 输出图片格式 | 输出图片宽、高对齐要求 | 输出图片宽stride、高stride、内存大小要求 | 
|---|---|---|
| YUV400 8bit | 无对齐要求 | 宽stride为宽16对齐后的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride | 
| YUV420SP NV12 8bit | 宽2对齐 高2对齐 | 宽stride为宽16对齐后的值;高stride为高2对齐后的值。 内存大小(单位Byte)= 宽stride * 高stride * 3/2 | 
| YUV420SP NV21 8bit | ||
| YUV422SP 8bit | 宽2对齐 高无对齐要求 | 宽stride为宽16对齐后的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride * 2 | 
| YVU422SP 8bit | ||
| YUV444Packed 8bit | 无对齐要求 | 宽stride为宽16对齐后、再乘以3的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride | 
| RGB888 | ||
| BGR888 | ||
| ARGB8888 | 无对齐要求 | 宽stride为宽16对齐后、再乘以4的值;高stride无对齐要求,与高相同即可。 内存大小(单位Byte)= 宽stride * 高stride | 
| ABGR8888 | ||
| RGBA8888 | ||
| BGRA8888 | 
抠图、贴图约束
- 抠图区域不超出输入图片区域。
- 贴图区域不超出输出图片区域,最大贴图个数256个。贴图区域相对输出图片的左偏移16对齐。贴图时可直接放置在输出图片的最左侧,即相对输出图片的左偏移为0,0也满足16对齐的要求。 
- 输出图片的贴图宽度建议16对齐,如果不是16对齐,会多写一段无效数据使其16对齐,如图4、图5所示,贴图区域旁边的绿色框就表示无效数据。
- 抠图、贴图区域的奇数、偶数限制为:输出图片格式为YUV420SP,贴图区域奇数、偶数限制为:左偏移和上偏移为偶数、右偏移和下偏移为奇数。 输出图片格式为YUV422SP,贴图区域奇数、偶数限制为:左偏移为偶数、右偏移为奇数。 其它格式,贴图区域没有偏移奇偶数的限制。 
- 缩放场景下,贴图/抠图的宽高缩放比例范围:[1/1024, 512]。等比例缩放场景下,由于贴图左偏移16对齐的限制,如果直接调用acl.himpi.vpc_crop_resize_paste接口实现缩放功能,贴图的位置可能不在输出图片的正中心位置,此时可通过抠图、缩放、填充几个功能配合使用(调用acl.himpi.vpc_crop_resize_make_border或acl.himpi.vpc_batch_crop_resize_make_border接口),实现等比例缩放。 
填充约束
针对以下输出图片格式,在实现填充功能(调用acl.himpi.vpc_copy_make_border接口)时,需注意:
- 对于YUV420SP输出格式,上下左右填充的尺寸建议为偶数。
- 对于YUV422SP输出格式,左右填充的尺寸建议为偶数。
存在这个填充约束,是由于VPC在处理图片时,会根据输入或输出图片格式,将输入图片格式转换为YUV444或RGB用于内部处理,YUV444或RGB没有宽高奇偶数的限制,但当输出图片格式为YUV420SP或YUV422SP格式时,由于该格式本身的数据排布导致宽高存在奇偶数限制,为防止图片边缘存在异常数据,需注意以上填充约束。
精度相关约束
VPC功能中,贴图区域的宽有16对齐的约束,贴图有效区域的宽不满足16对齐时,贴图区域中会存在一些补边的无效数据,为保证推理精度,贴图有效区域的宽不满足16对齐时,在贴图前用户可先将贴图有效区域缩放成16*2对齐,或在推理前借助AIPP抠出有效区域,去除无效数据。