函数:dvpp_vpc_batch_crop_and_paste_async

C函数原型

aclError acldvppVpcBatchCropAndPasteAsync(acldvppChannelDesc *channelDesc, acldvppBatchPicDesc *srcBatchPicDesc, uint32_t *roiNums, uint32_t size, acldvppBatchPicDesc *dstBatchPicDesc, acldvppRoiConfig *cropAreas[], acldvppRoiConfig *pasteAreas[], aclrtStream stream)

Python函数

dst_batch_pic_descs, ret = acl.media.dvpp_vpc_batch_crop_and_paste_async(dvpp_channel_desc, src_batch_pic_descs, roi_nums_list,dst_batch_pic_descs, crop_area_list,paste_area_list,stream)

函数功能

按指定区域从一张或多张输入图片中抠出一个或多个子图,再将抠的子图贴到目标图片的指定位置,作为输出图片。异步接口。

当paste_area的宽高与crop_area的宽高不一致时会对图片做一次缩放操作。

Atlas 200/500 A2推理产品,默认缩放算法为“业界通用的Bilinear算法”。

输入说明

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

src_batch_pic_descs:int,指定批量输入图片描述信息。

roi_nums_list: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值相等。

paste_area_list:list,贴图区域位置。

  • 调用acl.media.dvpp_create_roi_config接口创建区域位置数据。
  • 贴图区域左偏移需要16对齐。
  • crop_area、paste_area中元素个数与dst_batch_pic_descs中的batch_size值相等。

stream:int,指定Stream。

返回值说明

dst_batch_pic_descs:int,批量输出图片描述信息。

ret:int,错误码。

  • 返回0表示任务下发成功。
  • 返回非0表示任务下发失败。

参考资源

接口调用示例,参见抠图贴图(一图多框)示例代码

约束说明

昇腾AI处理器

约束

Atlas 200/500 A2推理产品