昇腾社区首页
中文
注册

函数:dvpp_vpc_batch_crop_resize_make_border_async

产品支持情况

产品

是否支持

Atlas A3 训练系列产品/Atlas A3 推理系列产品

Atlas A2 训练系列产品/Atlas 800I A2 推理产品/A200I A2 Box 异构组件

Atlas 训练系列产品

x

Atlas 推理系列产品

Atlas 200I/500 A2 推理产品

Atlas 200/300/500 推理产品

x

功能说明

支持从一张或多张输入图片中抠出一张或多张子图,对每个子图进行缩放,扩边填充后输出至目标图像内存地址。异步接口。

函数原型

  • C函数原型
    1
    aclErroracldvppVpcBatchCropResizeMakeBorderAsync(acldvppChannelDesc *channelDesc, acldvppBatchPicDesc *srcBatchPicDescs, uint32_t *roiNums, uint32_t size, acldvppBatchPicDesc *dstBatchPicDescs,  acldvppRoiConfig *cropAreas[],  acldvppBorderConfig *borderCfgs[], acldvppResizeConfig *resizeConfig, aclrtStream stream)
    
  • python函数
    1
    ret = acl.media.dvpp_vpc_batch_crop_resize_make_border_async(dvpp_channel_desc, src_batch_pic_descs, roi_nums_list, dst_batch_pic_descs, crop_area_list, border_cfgs_list, resize_config, stream)
    

参数说明

参数名

说明

dvpp_channel_desc

int,指定通道描述信息的指针地址,与调用acl.media.dvpp_create_channel接口创建通道时指定的“dvpp_channel_desc”保持一致。

src_batch_pic_descs

int,指定批量输入图片描述信息的指针地址。

roi_nums_list

list,表示抠图的数量的列表,当前最大抠图数量为256。

“roi_nums_list”总和小于等于256,与“dst_batch_pic_descs”中的“batch_size”值保持一致。(roi_nums_list[0] + ... + roi_nums_list[size - 1] <= 256)

dst_batch_pic_descs

int,指定批量输出图片描述信息的指针地址。

crop_area_list

list,抠图区域位置列表。

  • 调用acl.media.dvpp_create_roi_config接口创建区域位置数据。
  • “crop_area”“paste_area”中元素个数与“dst_batch_pic_descs”中的“batch_size”值相等。

border_cfgs_list

list,扩边填充配置列表。

  • “border_cfgs”数组中的元素与“crop_areas”数组中的元素一一对应。
  • 扩边填充配置参数中的“border_type”参数值仅支持“BORDER_CONSTANT”“BORDER_REPLICATE”

resize_config

int,指定图片缩放配置数据的指针地址。

需提前调用acl.media.dvpp_create_resize_config接口创建图片缩放配置数据。

stream

int,指定Stream对象。

返回值说明

返回值

说明

ret

int,错误码,返回0表示成功,返回其它值表示失败。

约束说明

版本

约束

Atlas 推理系列产品

  • 关于输入图片分辨率、图片格式:
    • 输入图片分辨率在10 * 6 ~ 4096 * 4096(包括4096)范围内时,支持图片格式、宽高对齐、内存约束处说明的输入图片格式。
    • 输入图片的宽或高在4096 ~ 8192(包括8192)范围内时,支持格式如下:
      支持acldvppPixelFormat枚举值中的如下枚举项:
      PIXEL_FORMAT_YUV_400 = 0,               // YUV400 8bit
      PIXEL_FORMAT_YUV_SEMIPLANAR_420 = 1,    // YUV420SP NV12 8bit   
      PIXEL_FORMAT_YVU_SEMIPLANAR_420 = 2,    // YUV420SP NV21 8bit 
      PIXEL_FORMAT_YUV_SEMIPLANAR_422 = 3,    // YUV422SP 8bit
      PIXEL_FORMAT_YVU_SEMIPLANAR_422 = 4,    // YVU422SP 8bit
      PIXEL_FORMAT_YUV_SEMIPLANAR_444 = 5,    // YUV444SP 8bit
      PIXEL_FORMAT_YVU_SEMIPLANAR_444 = 6,    // YVU444SP 8bit
      PIXEL_FORMAT_YUYV_PACKED_422 = 7,       // YUV422Packed YUYV 8bit
      PIXEL_FORMAT_UYVY_PACKED_422 = 8,       // YUV422Packed UYVY 8bit
      PIXEL_FORMAT_YVYU_PACKED_422 = 9,       // YUV422Packed YVYU 8bit
      PIXEL_FORMAT_VYUY_PACKED_422 = 10,      // YUV422Packed VYUY 8bit
  • 关于输出图片分辨率、图片格式请参见图片格式、宽高对齐、内存约束
  • 关于各图片格式的宽高对齐、内存大小约束,请参见图片格式、宽高对齐、内存约束
  • 当输入、输出图片格式都为ARGB8888、ABGR8888、RGBA8888、BGRA8888格式时,在经过本接口缩放处理后,A分量值会变为0。
  • 使用本接口实现等比例缩放功能时,相关的描述及约束请参见抠图、贴图约束
  • 由于YUV格式图像下采样约束,当输出图片格式为YUV420SP或YUV422SP格式时,需注意:
    • 对于YUV420SP输出格式,上下左右填充的尺寸建议为偶数。
    • 对于YUV422SP输出格式,左右填充的尺寸建议为偶数。

Atlas A2 训练系列产品/Atlas 800I A2 推理产品/A200I A2 Box 异构组件

Atlas 200I/500 A2 推理产品

Atlas A3 训练系列产品/Atlas A3 推理系列产品

  • 关于图片分辨率、图片格式、宽高对齐、内存等总体约束,请参见图片格式、宽高对齐、内存约束
  • 当输入、输出图片格式都为ARGB8888、ABGR8888、RGBA8888、BGRA8888格式时,在经过本接口缩放处理后,A分量值会变为0。
  • 使用本接口实现等比例缩放功能时,相关的描述及约束请参见抠图、贴图约束
  • 由于YUV格式图像下采样约束,当输出图片格式为YUV420SP或YUV422SP格式时,需注意:
    • 对于YUV420SP输出格式,上下左右填充的尺寸建议为偶数。
    • 对于YUV422SP输出格式,左右填充的尺寸建议为偶数。