aclmdlSetInputAIPP

Applicability

Product

Supported

Atlas A3 training products / Atlas A3 inference products

Atlas A2 training products / Atlas A2 inference products

Atlas 200I/500 A2 inference products

Atlas inference products

Atlas training products

Description

Sets the dynamic AIPP attributes for model inference based on the index of the dynamic AIPP input.

Dynamic AIPP provides the following functions and they are executed in the exact sequence: Cropping -> CSC -> Resizing (not supported currently) -> Mean subtraction/Normalization -> Padding.

Prototype

aclError aclmdlSetInputAIPP(uint32_t modelId, aclmdlDataset *dataset, size_t index, const aclmdlAIPP *aippParmsSet)

Parameters

Parameter

Input/Output

Description

modelId

Input

Model ID.

A successful aclmdlLoadFromFile, aclmdlLoadFromMem, aclmdlLoadFromFileWithMem, or aclmdlLoadFromMemWithMem call returns a model ID.

dataset

Input

Pointer to the input data for model inference.

Data of type aclmdlDataset describes the input data for model inference, while data of type describes the input buffer size and address.

index

Input

Input index of the dynamic AIPP input.

When the model has more than one dynamic AIPP input, you can call aclmdlGetAippType to obtain the specified input index.

To ensure forward compatibility, if there is only one dynamic AIPP input, you can call aclmdlGetInputIndexByName to obtain the input index. The input name is fixed to ACL_DYNAMIC_AIPP_NAME.

aippParmsSet

Input

Pointer to the dynamic AIPP parameter object.

Call aclmdlCreateAIPP in advance to create data of the aclmdlAIPP type.

Returns

0 on success; else, failure. For details, see aclError.

Restrictions

  • The image size after dynamic AIPP processing must be the same as that defined by the input shape required by the original model.
  • In batched inference scenarios, the image size after dynamic AIPP is calculated based on the configuration of each batch. After dynamic AIPP, the output image size must be consistent across batches. Table 1 describes the formulas for calculating the result image size.
  • After image cropping, resizing, or padding, the rules for verifying the image size after dynamic AIPP are shown in the table below. aippOutputW and aippOutputH indicate the width and height of the AIPP output image, respectively. Other parameters are the input parameters of the aclmdlSetAIPPSrcImageSize, aclmdlSetAIPPScfParams, aclmdlSetAIPPCropParams, and aclmdlSetAIPPPaddingParams APIs.
    Table 1 Formulas for calculating the image size after dynamic AIPP

    Cropping

    Resizing

    Padding

    Output Width and Height

    ×

    ×

    ×

    aippOutputW = srcImageSizeW, aippOutputH = srcImageSizeH

    ×

    ×

    aippOutputW = cropSizeW, aippOutputH = cropSizeH

    ×

    aippOutputW = scfOutputSizeW, aippOutputH = scfOutputSizeH

    ×

    aippOutputW = cropSizeW + paddingSizeLeft + paddingSizeRight, aippOutputH = cropSizeH + paddingSizeTop + paddingSizeBottom

    ×

    ×

    aippOutputW = srcImageSizeW + paddingSizeLeft + paddingSizeRight, aippOutputH = srcImageSizeH + paddingSizeTop + paddingSizeBottom

    ×

    aippOutputW = scfOutputSizeW + paddingSizeLeft + paddingSizeRight, aippOutputH = scfOutputSizeH + paddingSizeTop + paddingSizeBottom

    ×

    ×

    aippOutputW = scfOutputSizeW, aippOutputH = scfOutputSizeH

    aippOutputW = scfOutputSizeW + paddingSizeLeft + paddingSizeRight, aippOutputH = scfOutputSizeH + paddingSizeTop + paddingSizeBottom

See Also

For details about the API call sequence and example, see Dynamic AIPP Model Inference.