下载
中文
注册

acldvppVpcBatchCropAndPasteAsync

函数功能

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

约束说明

版本

约束

Atlas 200/300/500 推理产品

Atlas 训练系列产品

  • 关于输入图片分辨率、图片格式:
    • 输入图片分辨率在[10*6, 4096*4096]范围内时,支持图片格式、宽高对齐、内存约束处说明的输入图片格式。
    • 输入图片的宽在(4096, 8192]或高在(4096, 8192]范围内时,支持格式如下:
      支持acldvppPixelFormat枚举值中的如下枚举项:
      PIXEL_FORMAT_YUV_SEMIPLANAR_420 = 1,       // YUV420SP NV12 8bit   
      PIXEL_FORMAT_YVU_SEMIPLANAR_420 = 2,       // YUV420SP NV21 8bit 
  • 关于输出图片分辨率、图片格式请参见图片格式、宽高对齐、内存约束
  • 关于各图片格式的宽高对齐、内存大小约束,请参见图片格式、宽高对齐、内存约束
  • 当pasteArea的宽高与cropArea的宽高不一致时会对图片做一次缩放操作,默认缩放算法为“自研的高阶滤波算法”。

Atlas 推理系列产品

  • 关于输入图片分辨率、图片格式:
    • 输入图片分辨率在[10*6, 4096*4096]范围内时,支持图片格式、宽高对齐、内存约束处说明的输入图片格式。
    • 输入图片的宽在(4096, 8192]或高在(4096, 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
  • 关于输出图片分辨率、图片格式请参见图片格式、宽高对齐、内存约束
  • 关于各图片格式的宽高对齐、内存大小约束,请参见图片格式、宽高对齐、内存约束
  • 当pasteArea的宽高与cropArea的宽高不一致时会对图片做一次缩放操作,默认缩放算法为“业界通用的Bilinear算法”。

Atlas A2训练系列产品/Atlas 800I A2推理产品

Atlas 200/500 A2推理产品

  • 关于图片分辨率、图片格式、宽高对齐、内存等总体约束,请参见图片格式、宽高对齐、内存约束
  • 当pasteArea的宽高与cropArea的宽高不一致时会对图片做一次缩放操作,默认缩放算法为“业界通用的Bilinear算法”。
  • 由于YUV格式图像下采样约束,当输出图片格式为YUV420SP或YUV422SP格式时,贴图的顶部偏移、左侧偏移建议为偶数。

函数原型

aclError acldvppVpcBatchCropAndPasteAsync(acldvppChannelDesc *channelDesc,

acldvppBatchPicDesc *srcBatchPicDescs,

uint32_t *roiNums,

uint32_t size,

acldvppBatchPicDesc *dstBatchPicDescs,

acldvppRoiConfig *cropAreas[],

acldvppRoiConfig *pasteAreas[],

aclrtStream stream)

参数说明

参数名

输入/输出

说明

channelDesc

输入

通道描述信息的指针。

与调用acldvppCreateChannel接口创建通道时指定的channelDesc保持一致。

srcBatchPicDescs

输入

指定批量输入图片描述信息的指针。

roiNums

输入

每个输入图片抠图数量的指针,当前最大抠图数量为256。

roiNums为数组,数组总和小于等于256,与dstBatchPicDescs结构体中的batchSize值保持一致。

roiNums[0]+...+roiNums[size-1] <= 256

size

输入

表示roiNums数组中的元素个数,个数小于等于256。

dstBatchPicDescs

输入&输出

批量输出图片描述信息的指针。

dstBatchPicDescs参数作为输入时,需要用户调用如下接口:

cropAreas

输入

抠图区域位置的指针数组。

  • 调用acldvppCreateRoiConfig接口创建区域位置数据。
  • cropAreas、pasteAreas数组中的元素个数与dstBatchPicDescs结构体中的batchSize值相等。

pasteAreas

输入

贴图区域位置的指针数组。

  • 调用acldvppCreateRoiConfig接口创建区域位置数据。
  • 贴图区域左偏移需要16对齐。
  • cropAreas、pasteAreas数组中的元素个数与dstBatchPicDescs参数中的batchSize值相等。

stream

输入

指定Stream。

返回值说明

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

参考资源

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