12 void sobelExtractor(
const Mat img,
const Rect roi, Mat& feat);
14 int main(
int argc,
char** argv ){
18 " Usage: tracker <video_name>\n"
20 " example_tracking_kcf Bolt/img/%04d.jpg\n"
21 " example_tracking_kcf faceocc2.webm\n"
32 param.
desc_pca = TrackerKCF::GRAY | TrackerKCF::CN;
48 std::string video = argv[1];
60 tracker->
init(frame,roi);
63 printf(
"Start the tracking process, press ESC to quit.\n");
69 if(frame.rows==0 || frame.cols==0)
73 tracker->
update(frame,roi);
88 void sobelExtractor(
const Mat img,
const Rect roi, Mat& feat){
95 if(roi.
x<0){region.
x=0;region.
width+=roi.
x;}
96 if(roi.
y<0){region.
y=0;region.
height+=roi.
y;}
103 patch=img(region).
clone();
108 int addTop,addBottom, addLeft, addRight;
109 addTop=region.
y-roi.
y;
111 addLeft=region.
x-roi.
x;
Scalar_< double > Scalar
Definition: types.hpp:597
void cvtColor(InputArray src, OutputArray dst, int code, int dstCn=0)
Converts an image from one color space to another.
aaaaaa|abcdefgh|hhhhhhh
Definition: base.hpp:253
_Tp x
Definition: types.hpp:403
int rows
the number of rows and columns or (-1, -1) when the matrix has more than 2 dimensions ...
Definition: mat.hpp:1885
Definition: types_c.h:121
void convertTo(OutputArray m, int rtype, double alpha=1, double beta=0) const
Converts an array to another data type with optional scaling.
void rectangle(InputOutputArray img, Point pt1, Point pt2, const Scalar &color, int thickness=1, int lineType=LINE_8, int shift=0)
Draws a simple, thick, or filled up-right rectangle.
#define CV_64F
Definition: cvdef.h:109
void imshow(const String &winname, InputArray mat)
Displays an image in the specified window.
Definition: affine.hpp:51
Class for video capturing from video files, image sequences or cameras. The class provides C++ API fo...
Definition: videoio.hpp:389
_Tp y
Definition: types.hpp:403
unsigned int desc_npca
non-compressed descriptors of TrackerKCF::MODE
Definition: tracker.hpp:1249
void Sobel(InputArray src, OutputArray dst, int ddepth, int dx, int dy, int ksize=3, double scale=1, double delta=0, int borderType=BORDER_DEFAULT)
Calculates the first, second, third, or mixed image derivatives using an extended Sobel operator...
void copyMakeBorder(InputArray src, OutputArray dst, int top, int bottom, int left, int right, int borderType, const Scalar &value=Scalar())
Forms a border around an image.
bool init(const Mat &image, const Rect2d &boundingBox)
Initialize the tracker with a know bounding box that surrounding the target.
_Tp height
Definition: types.hpp:403
unsigned int desc_pca
compressed descriptors of TrackerKCF::MODE
Definition: tracker.hpp:1248
int cols
Definition: mat.hpp:1885
Mat clone() const
Creates a full copy of the array and the underlying data.
bool compress_feature
activate the pca method to compress the features
Definition: tracker.hpp:1245
Template class for 2D rectangles.
Definition: types.hpp:374
Template class for smart pointers with shared ownership.
Definition: cvstd.hpp:283
Rect2d selectROI(Mat img, bool fromCenter=true)
void merge(const Mat *mv, size_t count, OutputArray dst)
Creates one multichannel array out of several single-channel ones.
virtual void setFeatureExtractor(void(*)(const Mat, const Rect, Mat &), bool pca_func=false)
_Tp width
Definition: types.hpp:403
int compressed_size
feature size after compression
Definition: tracker.hpp:1247
#define CV_32F
Definition: cvdef.h:108
bool update(const Mat &image, Rect2d &boundingBox)
Update the tracker, find the new most likely bounding box for the target.
Definition: tracker.hpp:1220
int waitKey(int delay=0)
Waits for a pressed key.
This part explains how to set custom parameters and use your own feature-extractor function for the CN tracker. If you need a more detailed information to use cv::Tracker, please refer to Introduction to OpenCV Tracker.
Set Custom Parameters
TrackerKCF::Params param;
param.
desc_pca = TrackerKCF::GRAY | TrackerKCF::CN;
param.desc_npca = 0;
param.compress_feature = true;
param.compressed_size = 2;
To set custom paramters, an object should be created. Each tracker algorithm has their own parameter format. So, in this case we should use parameter from cv::TrackerKCF since we are interested in modifying the parameter of this tracker algorithm.
There are several parameters that can be configured as explained in cv::TrackerKCF::Params. For this tutorial, we focussed on the feature extractor functions.
Several feature types can be used in cv::TrackerKCF. In this case, the grayscale value (1 dimension) and color-names features (10 dimension), will be merged as 11 dimension feature and then compressed into 2 dimension as specified in the code.
If you want to use another type of pre-defined feature-extractor function, you can check in cv::TrackerKCF::MODE. We will leave the non-compressed feature as 0 since we want to use a customized function.
Using a custom function
You can define your own feature-extractor function for the CN tracker. However, you need to take care about several things:
- The extracted feature should have the same size as the size of the given bounding box (width and height). For the number of channels you can check the limitation in cv::Mat.
- You can only use features that can be compared using Euclidean distance. Features like local binary pattern (LBP) may not be suitable since it should be compared using Hamming distance.
Since the size of the extracted feature should be in the same size with the given bounding box, we need to take care whenever the given bounding box is partially out of range. In this case, we can copy part of image contained in the bounding box as shown in the snippet below.
if(roi.
x<0){region.
x=0;region.
width+=roi.
x;}
if(roi.
y<0){region.
y=0;region.
height+=roi.
y;}
Whenever the copied image is smaller than the given bounding box, padding should be given to the sides where the bounding box is partially out of frame.
int addTop,addBottom, addLeft, addRight;
Defining the feature
In this tutorial, the extracted feature is reponse of the Sobel filter in x and y direction. Those Sobel filter responses are concatenated, resulting a feature with 2 channels.
Post processing
Make sure to convert the feature into cv::CV_64F data format and normalize its value with range -0.5 to 0.5