Difference between revisions of "Function:GoodFeaturesToTrack"

From CUVI Wiki
Line 5: Line 5:
|style="font-size:150%;"|
|style="font-size:150%;"|
<syntaxhighlight lang="cpp">
<syntaxhighlight lang="cpp">
CuviStatus goodFeaturesToTrack(CuviImage* srcImage,
CuviStatus goodFeaturesToTrack(const CuviImage& src,
                               CuviROI roi,
                               const CuviRect& roi,
                               CuviPointValue2D** outputFeatures,
                               CuviPointValue2D<Cuvi32f,Cuvi32f>*& output,
                               Cuvi32s* maxFeatures,
                               Cuvi32s& maxFeatures,
                               CuviFeaturesCriteria criteria,
                               const CuviFeaturesCriteria criteria = CuviFeaturesCriteria(),
                               CuviStream* stream = NULL);
                               const CuviStream& stream = CuviStream());
</syntaxhighlight>
</syntaxhighlight>
|}
|}
Line 21: Line 21:
! Description
! Description
|-
|-
| srcImage
| src
| CuviImage*
| const CuviImage&
| Input 8 bit Gray Scale Image.
| Input 8 bit Gray Scale Image.
|-
|-
| roi
| roi
| CuviROI
| const CuviRect&
| Desired region of interest of input image. The function will return features from only that region of the image
| Desired region of interest of input image. The function will return features from only that region of the image
|-
|-
| outputFeatures
| output
| CuviPointValue2D**
| CuviPointValue2D<Cuvi32f,Cuvi32f>*&
| Output feature list that contains the coordinates & values of features/corners.
| Output feature list that contains the coordinates & values of features/corners.
|-
|-
| maxFeatures
| maxFeatures
| Cuvi32s*
| Cuvi32s&
| Desired number of features. If the total features detected in the image or ROI are less than maxFeatures its value is updated to that number
| Desired number of features. If the total features detected in the image or ROI are less than maxFeatures its value is updated to that number
|-
|-
| criteria
| criteria
| CuviFeaturesCriteria
| const CuviFeaturesCriteria
| A structure containing various parameters that affect feature selection behavior  
| A structure containing various parameters that affect feature selection behavior  
|-
|-
| stream
| stream
| CuviStream*
| const CuviStream&
| GPU stream ID for execution
| GPU stream ID for execution


Line 56: Line 56:
|-
|-
| 8uC1
| 8uC1
| CuviPointValue2D
| CuviPointValue2D<Cuvi32f,Cuvi32f>
|}
|}


Line 76: Line 76:


//Create an 8-bit Grays-scale CuviImage
//Create an 8-bit Grays-scale CuviImage
CuviImage *gpu_image = new CuviImage(size,img->depth,img->nChannels);
CuviImage gpu_image = cuvi::io::loadImage(path,CUVI_LOAD_IMAGE_GRAYSCALE);


//Populate the Image
CuviPointValue2D<Cuvi32f,Cuvi32f> *features;
gpu_image->upload(img->imageData,img->widthStep);
 
CuviPointValue2D *features;


//Desired number of features
//Desired number of features
Line 87: Line 84:


//Selecting complete image for the process
//Selecting complete image for the process
CuviROI roi = cuviROI(0,0,img->width,img->height);
CuviRect roi(0,0,img.width(),img.height());


//Setting Feature selection parameters
//Setting Feature selection parameters
CuviFeaturesCriteria criteria = cuviFeaturesCriteria(CUVI_FEATURES_HARRIS_PETER,0.006f,15,3,-2.0f);
CuviFeaturesCriteria criteria(CUVI_FEATURES_HARRIS_PETER,0.006f,15,3,-2.0f);


//Calling GoodFeaturesToTrack
//Calling GoodFeaturesToTrack
cuvi::computerVision::goodFeaturesToTrack(&gimg,roi,&features,&featureCount,criteria);
cuvi::computerVision::goodFeaturesToTrack(gimg,roi,features,featureCount,criteria);


</syntaxhighlight>
</syntaxhighlight>
|}
|}

Revision as of 20:03, 18 April 2013

Detecting interesting parts of an image is an important step in most computer vision applications. Itserves as the first low-level processing step in applications like image segmentation, object recognition, object tracking and motion estimation. CUVI offers feature detectors including KLT, Harris and Peter in a single function

Function

CuviStatus goodFeaturesToTrack(const CuviImage& src,
                               const CuviRect& roi,
                               CuviPointValue2D<Cuvi32f,Cuvi32f>*& output,
                               Cuvi32s& maxFeatures,
                               const CuviFeaturesCriteria criteria = CuviFeaturesCriteria(),
                               const CuviStream& stream = CuviStream());

Parameters

Name Type Description
src const CuviImage& Input 8 bit Gray Scale Image.
roi const CuviRect& Desired region of interest of input image. The function will return features from only that region of the image
output CuviPointValue2D<Cuvi32f,Cuvi32f>*& Output feature list that contains the coordinates & values of features/corners.
maxFeatures Cuvi32s& Desired number of features. If the total features detected in the image or ROI are less than maxFeatures its value is updated to that number
criteria const CuviFeaturesCriteria A structure containing various parameters that affect feature selection behavior
stream const CuviStream& GPU stream ID for execution


Image Type Support

Input Output
8uC1 CuviPointValue2D<Cuvi32f,Cuvi32f>


Samples

Error creating thumbnail: Unable to save thumbnail to destination
Input Image
Error creating thumbnail: Unable to save thumbnail to destination
Selected Features


Example

//Create an 8-bit Grays-scale CuviImage
CuviImage gpu_image = cuvi::io::loadImage(path,CUVI_LOAD_IMAGE_GRAYSCALE);

CuviPointValue2D<Cuvi32f,Cuvi32f> *features;

//Desired number of features
int featureCount = 100;

//Selecting complete image for the process
CuviRect roi(0,0,img.width(),img.height());

//Setting Feature selection parameters
CuviFeaturesCriteria criteria(CUVI_FEATURES_HARRIS_PETER,0.006f,15,3,-2.0f);

//Calling GoodFeaturesToTrack
cuvi::computerVision::goodFeaturesToTrack(gimg,roi,features,featureCount,criteria);