Functions
VXLIB_warpAffineNearest_bc_i8u_c32f_o8u

Functions

VXLIB_STATUS VXLIB_warpAffineNearest_bc_i8u_c32f_o8u (const uint8_t src[restrict], const VXLIB_bufParams2D_t *src_addr, uint8_t dst[restrict], const VXLIB_bufParams2D_t *dst_addr, const VXLIB_F32 warpMatrix[6], uint8_t border_constant_value, int16_t srcOffsetX, int16_t srcOffsetY, int16_t dstOffsetX, int16_t dstOffsetY)
 
VXLIB_STATUS VXLIB_warpAffineNearest_bc_i8u_c32f_o8u_checkParams (const uint8_t src[restrict], const VXLIB_bufParams2D_t *src_addr, uint8_t dst[restrict], const VXLIB_bufParams2D_t *dst_addr, const VXLIB_F32 warpMatrix[6], uint8_t border_constant_value, int16_t srcOffsetX, int16_t srcOffsetY, int16_t dstOffsetX, int16_t dstOffsetY)
 

Detailed Description

Function Documentation

◆ VXLIB_warpAffineNearest_bc_i8u_c32f_o8u()

VXLIB_STATUS VXLIB_warpAffineNearest_bc_i8u_c32f_o8u ( const uint8_t  src[restrict],
const VXLIB_bufParams2D_t *  src_addr,
uint8_t  dst[restrict],
const VXLIB_bufParams2D_t *  dst_addr,
const VXLIB_F32  warpMatrix[6],
uint8_t  border_constant_value,
int16_t  srcOffsetX,
int16_t  srcOffsetY,
int16_t  dstOffsetX,
int16_t  dstOffsetY 
)

Performs affine warp transformation from input image (8-bit) to output image (8-bit) using the nearest neighbor interpolation. If the input pixel mapping is out of bounds from the input image, then the border_constant_value is placed in the output cooresponding to the out of bounds input.

Method:
The affine warp kernel is computed by using the following equation:
 x0 = x * warpMatrix[0] + y * warpMatrix[2] + warpMatrix[4];
 y0 = x * warpMatrix[1] + y * warpMatrix[3] + warpMatrix[5];

 dst(x,y) = NearestNeighbor(src(x0, y0))
Parameters
[in]src[]Pointer to array containing first input image (UQ8.0)
[in]src_addr[]Pointer to structure containing dimensional information of src
[out]dst[]Pointer to array containing output image (UQ8.0)
[in]dst_addr[]Pointer to structure containing dimensional information of dst
[in]warpMatrix[]Pointer to array containing the affine coefficients (F32)
[in]border_constant_valueParameter indicating out of bounds value (UQ8.0)
[in]srcOffsetXParameter indicating x offset of src pointer relative to start of valid data in broader image (SQ15.0)
[in]srcOffsetYParameter indicating y offset of src pointer relative to start of valid data in broader image (SQ15.0)
[in]dstOffsetXParameter indicating x offset of dst pointer relative to start of output valid data in broader image (SQ15.0)
[in]dstOffsetYParameter indicating y offset of dst pointer relative to start of output valid data in broader image (SQ15.0)
Assumptions:
  • I/O buffer pointers are assumed to be not aliased.
  • If a user wants to divide processing of the image into smaller blocks, then it can use the dstOffsetX and dstOffsetY to indicate the starting coordinate of the output block relative to the start of the full output image, and srcOffsetX and srcOffsetY to indicate the starting coordinate of the input block relative to the start of the full input image.
  • When breaking input image processing into blocks, be sure to fetch enough overlap pixels from the input for interior edges for the warp, or else the function may put a false border within the block edge of of the output image.
Performance Considerations:
  • For best performance, the following parameter settings are recommended:
    • Set all width values to a multiple of 4

◆ VXLIB_warpAffineNearest_bc_i8u_c32f_o8u_checkParams()

VXLIB_STATUS VXLIB_warpAffineNearest_bc_i8u_c32f_o8u_checkParams ( const uint8_t  src[restrict],
const VXLIB_bufParams2D_t *  src_addr,
uint8_t  dst[restrict],
const VXLIB_bufParams2D_t *  dst_addr,
const VXLIB_F32  warpMatrix[6],
uint8_t  border_constant_value,
int16_t  srcOffsetX,
int16_t  srcOffsetY,
int16_t  dstOffsetX,
int16_t  dstOffsetY 
)
Description:
Checks the parameters for programming errors for the VXLIB_warpAffineNearest_bc_i8u_c32f_o8u function.
Method:
The following checks are made:
  • There shall be no NULL pointers
  • The strides of each image shall be equal to or greater than the x dimension
Parameters
[in]src[]Pointer to array containing first input image (UQ8.0)
[in]src_addr[]Pointer to structure containing dimensional information of src
[out]dst[]Pointer to array containing output image (UQ8.0)
[in]dst_addr[]Pointer to structure containing dimensional information of dst
[in]warpMatrix[]Pointer to array containing the affine coefficients (F32)
[in]border_constant_valueParameter indicating out of bounds value (UQ8.0)
[in]srcOffsetXParameter indicating x offset of src pointer relative to start of valid data in broader image (SQ15.0)
[in]srcOffsetYParameter indicating y offset of src pointer relative to start of valid data in broader image (SQ15.0)
[in]dstOffsetXParameter indicating x offset of dst pointer relative to start of output valid data in broader image (SQ15.0)
[in]dstOffsetYParameter indicating y offset of dst pointer relative to start of output valid data in broader image (SQ15.0)

Copyright 2024, Texas Instruments Incorporated