NVIDIA DeepStream SDK API Reference

4.0 Release

 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Groups
Image Transformation and Compositing API

Detailed Description

Defines the NvBufSurfTransform image transformation API, which sets and sets session parameters and transforms and composites images.

Data Structures

struct  NvBufSurfTransformRect
 Holds the coordinates of a rectangle. More...
 
struct  _NvBufSurfTransformConfigParams
 Holds configuration parameters for a transform/composite session. More...
 
struct  _NvBufSurfaceTransformParams
 Holds transform parameters for a transform call. More...
 
struct  _NvBufSurfTransformCompositeParams
 Holds composite parameters for a composite call. More...
 

NvBufSurfTransform types and functions.

This section describes types and functions of the NvBufSurfTransform application programming interface.

enum  NvBufSurfTransform_Compute {
  NvBufSurfTransformCompute_Default,
  NvBufSurfTransformCompute_GPU,
  NvBufSurfTransformCompute_VIC
}
 Specifies compute devices used by NvBufSurfTransform. More...
 
enum  NvBufSurfTransform_Flip {
  NvBufSurfTransform_None,
  NvBufSurfTransform_Rotate90,
  NvBufSurfTransform_Rotate180,
  NvBufSurfTransform_Rotate270,
  NvBufSurfTransform_FlipX,
  NvBufSurfTransform_FlipY,
  NvBufSurfTransform_Transpose,
  NvBufSurfTransform_InvTranspose
}
 Specifies video flip methods. More...
 
enum  NvBufSurfTransform_Inter {
  NvBufSurfTransformInter_Nearest = 0,
  NvBufSurfTransformInter_Bilinear,
  NvBufSurfTransformInter_Algo1,
  NvBufSurfTransformInter_Algo2,
  NvBufSurfTransformInter_Algo3,
  NvBufSurfTransformInter_Algo4,
  NvBufSurfTransformInter_Default
}
 Specifies video interpolation methods. More...
 
enum  NvBufSurfTransform_Error {
  NvBufSurfTransformError_ROI_Error = -4,
  NvBufSurfTransformError_Invalid_Params = -3,
  NvBufSurfTransformError_Execution_Error = -2,
  NvBufSurfTransformError_Unsupported = -1,
  NvBufSurfTransformError_Success = 0
}
 Specifies error codes returned by NvBufSurfTransform functions. More...
 
enum  NvBufSurfTransform_Transform_Flag {
  NVBUFSURF_TRANSFORM_CROP_SRC = 1,
  NVBUFSURF_TRANSFORM_CROP_DST = 1 << 1,
  NVBUFSURF_TRANSFORM_FILTER = 1 << 2,
  NVBUFSURF_TRANSFORM_FLIP = 1 << 3
}
 Specifies transform types. More...
 
enum  NvBufSurfTransform_Composite_Flag { NVBUFSURF_TRANSFORM_COMPOSITE = 1 }
 Specifies types of composition operations. More...
 
typedef struct
_NvBufSurfTransformConfigParams 
NvBufSurfTransformConfigParams
 Holds configuration parameters for a transform/composite session. More...
 
typedef struct
_NvBufSurfaceTransformParams 
NvBufSurfTransformParams
 Holds transform parameters for a transform call. More...
 
typedef struct
_NvBufSurfTransformCompositeParams 
NvBufSurfTransformCompositeParams
 Holds composite parameters for a composite call. More...
 
NvBufSurfTransform_Error NvBufSurfTransformSetSessionParams (NvBufSurfTransformConfigParams *config_params)
 Sets user-defined session parameters. More...
 
NvBufSurfTransform_Error NvBufSurfTransformGetSessionParams (NvBufSurfTransformConfigParams *config_params)
 Gets the session parameters used by NvBufSurfTransform(). More...
 
NvBufSurfTransform_Error NvBufSurfTransform (NvBufSurface *src, NvBufSurface *dst, NvBufSurfTransformParams *transform_params)
 Performs a transformation on batched input images. More...
 
NvBufSurfTransform_Error NvBufSurfTransformComposite (NvBufSurface *src, NvBufSurface *dst, NvBufSurfTransformCompositeParams *composite_params)
 Composites batched input images. More...
 

Typedef Documentation

Holds composite parameters for a composite call.

Holds configuration parameters for a transform/composite session.

Holds transform parameters for a transform call.

Enumeration Type Documentation

Specifies types of composition operations.

Enumerator
NVBUFSURF_TRANSFORM_COMPOSITE 

Specifies a flag to describe the requested compositing operation.

Definition at line 145 of file nvbufsurftransform.h.

Specifies compute devices used by NvBufSurfTransform.

Enumerator
NvBufSurfTransformCompute_Default 

Specifies VIC as a compute device for Jetson or dGPU for an x86_64 system.

NvBufSurfTransformCompute_GPU 

Specifies that the GPU is the compute device.

NvBufSurfTransformCompute_VIC 

Specifies that the VIC as a compute device.

Supported only for Jetson.

Definition at line 54 of file nvbufsurftransform.h.

Specifies error codes returned by NvBufSurfTransform functions.

Enumerator
NvBufSurfTransformError_ROI_Error 

Specifies an error in source or destination ROI.

NvBufSurfTransformError_Invalid_Params 

Specifies invalid input parameters.

NvBufSurfTransformError_Execution_Error 

Specifies a runtime execution error.

NvBufSurfTransformError_Unsupported 

Specifies an unsupported feature or format.

NvBufSurfTransformError_Success 

Specifies a successful operation.

Definition at line 114 of file nvbufsurftransform.h.

Specifies video flip methods.

Supported only for Jetson.

Enumerator
NvBufSurfTransform_None 

Specifies no video flip.

NvBufSurfTransform_Rotate90 

Specifies rotating 90 degrees clockwise.

NvBufSurfTransform_Rotate180 

Specifies rotating 180 degree clockwise.

NvBufSurfTransform_Rotate270 

Specifies rotating 270 degree clockwise.

NvBufSurfTransform_FlipX 

Specifies video flip with respect to the X-axis.

NvBufSurfTransform_FlipY 

Specifies video flip with respect to the Y-axis.

NvBufSurfTransform_Transpose 

Specifies video flip transpose.

NvBufSurfTransform_InvTranspose 

Specifies video flip inverse transpose.

Definition at line 69 of file nvbufsurftransform.h.

Specifies video interpolation methods.

Enumerator
NvBufSurfTransformInter_Nearest 

Specifies Nearest Interpolation Method interpolation.

NvBufSurfTransformInter_Bilinear 

Specifies Bilinear Interpolation Method interpolation.

NvBufSurfTransformInter_Algo1 

Specifies GPU-Cubic, VIC-5 Tap interpolation.

NvBufSurfTransformInter_Algo2 

Specifies GPU-Super, VIC-10 Tap interpolation.

NvBufSurfTransformInter_Algo3 

Specifies GPU-Lanzos, VIC-Smart interpolation.

NvBufSurfTransformInter_Algo4 

Specifies GPU-Ignored, VIC-Nicest interpolation.

NvBufSurfTransformInter_Default 

Specifies GPU-Nearest, VIC-Nearest interpolation.

Definition at line 93 of file nvbufsurftransform.h.

Specifies transform types.

Enumerator
NVBUFSURF_TRANSFORM_CROP_SRC 

Specifies a transform to crop the source rectangle.

NVBUFSURF_TRANSFORM_CROP_DST 

Specifies a transform to crop the destination rectangle.

NVBUFSURF_TRANSFORM_FILTER 

Specifies a transform to set the filter type.

NVBUFSURF_TRANSFORM_FLIP 

Specifies a transform to set the flip method.

Definition at line 131 of file nvbufsurftransform.h.

Function Documentation

NvBufSurfTransform_Error NvBufSurfTransform ( NvBufSurface src,
NvBufSurface dst,
NvBufSurfTransformParams transform_params 
)

Performs a transformation on batched input images.

If user-defined session parameters are to be used, call NvBufSurfTransformSetSessionParams() before calling this function.

Parameters
[in]srcA pointer to input batched buffers to be transformed.
[out]dstA pointer to a caller-allocated location where transformed output is to be stored.
When destination cropping is performed, memory outside
the crop location is not touched, and may contain stale information. The caller must perform a memset before calling this function if stale information must be eliminated.
Parameters
[in]transform_paramsA pointer to an NvBufSurfTransformParams structure which specifies the type of transform to be performed. They may include any combination of scaling, format conversion, and cropping for both source and destination. Flipping and rotation are supported on VIC.
Returns
An NvBufSurfTransform_Error value indicating success or failure.
NvBufSurfTransform_Error NvBufSurfTransformComposite ( NvBufSurface src,
NvBufSurface dst,
NvBufSurfTransformCompositeParams composite_params 
)

Composites batched input images.

The compositer scales and stitches batched buffers indicated by src into a single destination buffer, dst.

If user-defined session parameters are to be used, call NvBufSurfTransformSetSessionParams() before calling this function.

Parameters
[in]srcA pointer to input batched buffers to be transformed.
[out]dstA pointer a caller-allocated location (a single buffer) where composited output is to be stored.
[in]composite_paramsA pointer to an NvBufSurfTransformCompositeParams structure which specifies the compositing operation to be performed, e.g., the source and destination rectangles in src and dst.
Returns
An NvBufSurfTransform_Error value indicating success or failure.
NvBufSurfTransform_Error NvBufSurfTransformGetSessionParams ( NvBufSurfTransformConfigParams config_params)

Gets the session parameters used by NvBufSurfTransform().

Parameters
[out]config_paramsA pointer to a caller-allocated structure to be populated with the session parameters used.
Returns
An NvBufSurfTransform_Error value indicating success or failure.
NvBufSurfTransform_Error NvBufSurfTransformSetSessionParams ( NvBufSurfTransformConfigParams config_params)

Sets user-defined session parameters.

If user-defined session parameters are set, they override the NvBufSurfTransform() function's default session.

Parameters
[in]config_paramsA pointer to a structure that is populated with the session parameters to be used.
Returns
An NvBufSurfTransform_Error value indicating success or failure.