Functions
VXLIB_warpPerspectiveNearest_i8u_c32f_o8u

Functions

VXLIB_STATUS VXLIB_warpPerspectiveNearest_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[9], int16_t srcOffsetX, int16_t srcOffsetY, int16_t dstOffsetX, int16_t dstOffsetY)
 
VXLIB_STATUS VXLIB_warpPerspectiveNearest_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[9], int16_t srcOffsetX, int16_t srcOffsetY, int16_t dstOffsetX, int16_t dstOffsetY)
 

Detailed Description

Function Documentation

◆ VXLIB_warpPerspectiveNearest_i8u_c32f_o8u()

VXLIB_STATUS VXLIB_warpPerspectiveNearest_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[9],
int16_t  srcOffsetX,
int16_t  srcOffsetY,
int16_t  dstOffsetX,
int16_t  dstOffsetY 
)

Performs perspective warp transformation from input image (8-bit) to output image (8-bit) using the nearest neighbor interpolation. No border handling in done in this function, so it is expected that appropriate padding is done to the input buffer.

Method:
The perspective warp kernel is computed by using the following equation:
 x0 = (x * warpMatrix[0] + y * warpMatrix[3] + warpMatrix[6]) / z0;
 y0 = (x * warpMatrix[1] + y * warpMatrix[4] + warpMatrix[7]) / z0;
 z0 =  x * warpMatrix[2] + y * warpMatrix[5] + warpMatrix[8];

 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 perspective coefficients (F32)
[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.
  • Be sure to allocate padding around the border (or fetch enough pad pixels from the input for interior edges when breaking into blocks), for the warp, or else the function may fetch from an out-of-bounds memory location. For each dimension, the required fetch amount depends on the warpMatrix coefficients.
  • If padding has been applied to the start of the input image, then the src pointer should point to the start of the image including the padding, and the srcOffsetX and srcOffsetY will be negative numbers (e.g. If 2 rows and 2 columns of padding have been added, then srcOffsetX and srcOffsetY will both be -2).
Performance Considerations:
  • For best performance, the following parameter settings are recommended:
    • Set dst width values to a multiple of 4

◆ VXLIB_warpPerspectiveNearest_i8u_c32f_o8u_checkParams()

VXLIB_STATUS VXLIB_warpPerspectiveNearest_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[9],
int16_t  srcOffsetX,
int16_t  srcOffsetY,
int16_t  dstOffsetX,
int16_t  dstOffsetY 
)
Description:
Checks the parameters for programming errors for the VXLIB_warpPerspectiveNearest_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 perspective coefficients (F32)
[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 2023, Texas Instruments Incorporated