Algorithm used to track points from one frame to the next. More...
| Data Structures | |
| struct | VPIOpticalFlowPyrLKParams | 
| Structure that defines the parameters for vpiSubmitOpticalFlowPyrLK.  More... | |
| Enumerations | |
| enum | VPIEpsilonType | 
| Defines the error measurement types.  More... | |
| Functions | |
| VPIStatus | vpiInitOpticalFlowPyrLKParams (uint64_t backends, VPIOpticalFlowPyrLKParams *params) | 
| Initializes VPIOpticalFlowPyrLKParams with default values.  More... | |
| VPIStatus | vpiCreateOpticalFlowPyrLK (uint64_t backends, int32_t width, int32_t height, VPIImageFormat fmt, int32_t levels, float scale, VPIPayload *payload) | 
| Creates payload for vpiSubmitOpticalFlowPyrLK.  More... | |
| VPIStatus | vpiSubmitOpticalFlowPyrLK (VPIStream stream, uint64_t backend, VPIPayload payload, VPIPyramid prevPyr, VPIPyramid curPyr, VPIArray prevPts, VPIArray curPts, VPIArray trackingStatus, const VPIOpticalFlowPyrLKParams *params) | 
| Runs Pyramidal LK Optical Flow on two frames.  More... | |
Algorithm used to track points from one frame to the next.
Refer to Pyramidal LK Optical Flow for more details and usage examples.
| struct VPIOpticalFlowPyrLKParams | 
Structure that defines the parameters for vpiSubmitOpticalFlowPyrLK.
Definition at line 92 of file OpticalFlowPyrLK.h.
 Collaboration diagram for VPIOpticalFlowPyrLKParams:
 Collaboration diagram for VPIOpticalFlowPyrLKParams:| Data Fields | ||
|---|---|---|
| uint32_t | useInitialFlow | Uses initial estimations stored in current frame keypoints array when this flag is not 0, otherwise previous frame keypoints are copied to current frame keypoints array and is considered the initial estimate. | 
| uint32_t | termination | Specifies the termination criteria. 
 | 
| VPIEpsilonType | epsilonType | Specifies the tracking error type. | 
| float | epsilon | Specifies minimum error threshold for terminating the algorithm. Only applicable if termination flags includes VPI_TERMINATION_CRITERIA_ITERATIONS. | 
| int32_t | numIterations | Specifies the maximum number of iterations. Only applicable if termination flags includes VPI_TERMINATION_CRITERIA_ITERATIONS. 
 | 
| int32_t | windowDimension | Specifies the size of the window on which to perform the algorithm. 
 | 
| enum VPIEpsilonType | 
#include <vpi/algo/OpticalFlowPyrLK.h>
Defines the error measurement types.
| Enumerator | |
|---|---|
| VPI_LK_ERROR_L1 | L1 distance between previous feature and a next feature. | 
Definition at line 83 of file OpticalFlowPyrLK.h.
| VPIStatus vpiInitOpticalFlowPyrLKParams | ( | uint64_t | backends, | 
| VPIOpticalFlowPyrLKParams * | params | ||
| ) | 
#include <vpi/algo/OpticalFlowPyrLK.h>
Initializes VPIOpticalFlowPyrLKParams with default values.
Returns the default Pyramidal LK Optical Flow parameters that are compatible with all the given backends.
Defaults:
| [in] | backends | Specifies the backend to get default values for. 
 | 
| [in] | params | Structure to be filled with default values. | 
| VPI_ERROR_INVALID_ARGUMENT | paramsis NULL. | 
| VPI_SUCCESS | Operation executed successfully. | 
| VPIStatus vpiCreateOpticalFlowPyrLK | ( | uint64_t | backends, | 
| int32_t | width, | ||
| int32_t | height, | ||
| VPIImageFormat | fmt, | ||
| int32_t | levels, | ||
| float | scale, | ||
| VPIPayload * | payload | ||
| ) | 
#include <vpi/algo/OpticalFlowPyrLK.h>
Creates payload for vpiSubmitOpticalFlowPyrLK.
| [in] | backends | VPI backends that are eligible to execute the algorithm. 
 | 
| [in] | fmt | Specifies the format for the pyramid. 
 | 
| [in] | width,height | Specifies the dimensions of the pyramid on the finest resolution. 
 | 
| [in] | levels | Number of levels of the pyramid to be used. | 
| [in] | scale | Scale of the pyramid to be used. | 
| [out] | payload | Pointer to the payload variable that receives the created handle. | 
| VPI_IMAGE_FORMAT_INVALID | fmtis not supported. | 
| VPI_ERROR_INVALID_ARGUMENT | payloadis NULL. | 
| VPI_ERROR_INVALID_ARGUMENT | widthorheightoutside valid range. | 
| VPI_ERROR_INVALID_ARGUMENT | fmtis not supported. | 
| VPI_ERROR_INVALID_ARGUMENT | backendsrefers to an invalid backend. | 
| VPI_ERROR_NOT_IMPLEMENTED | Pyramidal LK Optical Flow algorithm is not supported by given backend. | 
| VPI_ERROR_INVALID_CONTEXT | Current context is destroyed. | 
| VPI_ERROR_OUT_OF_MEMORY | Cannot allocate required resources. | 
| VPI_ERROR_INVALID_OPERATION | Backend isn't enabled in current context. | 
| VPI_SUCCESS | Operation executed successfully. | 
| VPIStatus vpiSubmitOpticalFlowPyrLK | ( | VPIStream | stream, | 
| uint64_t | backend, | ||
| VPIPayload | payload, | ||
| VPIPyramid | prevPyr, | ||
| VPIPyramid | curPyr, | ||
| VPIArray | prevPts, | ||
| VPIArray | curPts, | ||
| VPIArray | trackingStatus, | ||
| const VPIOpticalFlowPyrLKParams * | params | ||
| ) | 
#include <vpi/algo/OpticalFlowPyrLK.h>
Runs Pyramidal LK Optical Flow on two frames.
Outputs estimated feature points and tracking status.
| [in] | stream | The stream where the operation will be queued in. 
 | 
| [in] | backend | Backend that will execute the algorithm. 
 | 
| [in] | payload | Payload created with vpiCreateOpticalFlowPyrLK. | 
| [in] | prevPyr | Previous frame, represented as a gaussian pyramid. 
 | 
| [in] | curPyr | Current frame, represented as a gaussian pyramid. 
 | 
| [in] | prevPts | Array of keypoints in the prevPyrhigh resolution pyramid.
 | 
| [in,out] | curPts | Array of keypoints in first level of curPyr. It is used as starting search point in curPyr if useInitialFlow inparamsis not 0.
 | 
| [in,out] | trackingStatus | Status array for tracking status for each input in prevPts. If element is 0, the corresponding keypoint is being tracked, otherwide, tracking is lost. 
 | 
| [in] | params | Parameters for the LK tracker. If NULL, it uses default parameters are returned by vpiInitOpticalFlowPyrLKParams. | 
| VPI_ERROR_INVALID_ARGUMENT | streamis NULL. | 
| VPI_ERROR_INVALID_ARGUMENT | prevPyr,curPyr,prevPts,curPtsortrackingStatusare NULL. | 
| VPI_ERROR_INVALID_ARGUMENT | payloadis not generated using vpiCreateKLTFeatureTracker. | 
| VPI_ERROR_INVALID_ARGUMENT | prevPyrandcurPyrshould have same number of levels, size, scale and format. | 
| VPI_ERROR_INVALID_ARGUMENT | prevPyrandcurPyrformat should match with format specified in thepayloadcreation. | 
| VPI_ERROR_INVALID_ARGUMENT | Invalid termination criteria provided in params. | 
| VPI_ERROR_INVALID_ARGUMENT | Number of iterations in paramsoutside valid range. | 
| VPI_ERROR_INVALID_ARGUMENT | Tracking window dimension in paramsis invalid. | 
| VPI_ERROR_INVALID_ARGUMENT | prevPtsorcurPtshave unsupported array type. | 
| VPI_ERROR_INVALID_ARGUMENT | prevPtsorcurPts'ssize outside valid range. | 
| VPI_ERROR_INVALID_ARGUMENT | prevPtsortrackingStatus'scapacity outside valid range. | 
| VPI_ERROR_INVALID_ARGUMENT | trackingStatushas unsupported array type. | 
| VPI_ERROR_INVALID_PAYLOAD_TYPE | payloadis invalid. | 
| VPI_ERROR_INVALID_OPERATION | The needed backends aren't enabled in stream,prevPyr,curPyr,prevPts,curPtsortrackingStatus. | 
| VPI_SUCCESS | Operation executed successfully. |