Visual Servoing Platform  version 3.3.0 under development (2020-02-17)
templateTracker.cpp
1 /****************************************************************************
2  *
3  * ViSP, open source Visual Servoing Platform software.
4  * Copyright (C) 2005 - 2019 by Inria. All rights reserved.
5  *
6  * This software is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  * See the file LICENSE.txt at the root directory of this source
11  * distribution for additional information about the GNU GPL.
12  *
13  * For using ViSP with software that can not be combined with the GNU
14  * GPL, please contact Inria about acquiring a ViSP Professional
15  * Edition License.
16  *
17  * See http://visp.inria.fr for more information.
18  *
19  * This software was developed at:
20  * Inria Rennes - Bretagne Atlantique
21  * Campus Universitaire de Beaulieu
22  * 35042 Rennes Cedex
23  * France
24  *
25  * If you have questions regarding the use of this file, please contact
26  * Inria at visp@inria.fr
27  *
28  * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
29  * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
30  *
31  * Description:
32  * Example of template tracking.
33  *
34  * Authors:
35  * Amaury Dame
36  * Aurelien Yol
37  * Fabien Spindler
38  *
39  *****************************************************************************/
40 
47 #include <iostream>
48 #include <visp3/core/vpConfig.h>
49 
50 #if defined(VISP_HAVE_MODULE_TT) && defined(VISP_HAVE_DISPLAY)
51 
52 #include <visp3/core/vpDebug.h>
53 #include <visp3/core/vpHomogeneousMatrix.h>
54 #include <visp3/core/vpIoTools.h>
55 #include <visp3/core/vpMath.h>
56 #include <visp3/gui/vpDisplayD3D.h>
57 #include <visp3/gui/vpDisplayGDI.h>
58 #include <visp3/gui/vpDisplayGTK.h>
59 #include <visp3/gui/vpDisplayOpenCV.h>
60 #include <visp3/gui/vpDisplayX.h>
61 #include <visp3/io/vpImageIo.h>
62 #include <visp3/io/vpParseArgv.h>
63 #include <visp3/io/vpVideoReader.h>
64 
65 #include <visp3/tt/vpTemplateTrackerSSD.h>
66 #include <visp3/tt/vpTemplateTrackerSSDESM.h>
67 #include <visp3/tt/vpTemplateTrackerSSDForwardAdditional.h>
68 #include <visp3/tt/vpTemplateTrackerSSDForwardCompositional.h>
69 #include <visp3/tt/vpTemplateTrackerSSDInverseCompositional.h>
70 #include <visp3/tt/vpTemplateTrackerZNCCForwardAdditional.h>
71 #include <visp3/tt/vpTemplateTrackerZNCCInverseCompositional.h>
72 
73 #include <visp3/tt/vpTemplateTrackerWarpAffine.h>
74 #include <visp3/tt/vpTemplateTrackerWarpHomography.h>
75 #include <visp3/tt/vpTemplateTrackerWarpHomographySL3.h>
76 #include <visp3/tt/vpTemplateTrackerWarpRT.h>
77 #include <visp3/tt/vpTemplateTrackerWarpSRT.h>
78 #include <visp3/tt/vpTemplateTrackerWarpTranslation.h>
79 
80 #ifdef VISP_HAVE_MODULE_TT_MI
81 #include <visp3/tt_mi/vpTemplateTrackerMIESM.h>
82 #include <visp3/tt_mi/vpTemplateTrackerMIForwardAdditional.h>
83 #include <visp3/tt_mi/vpTemplateTrackerMIForwardCompositional.h>
84 #include <visp3/tt_mi/vpTemplateTrackerMIInverseCompositional.h>
85 #endif
86 
87 #define GETOPTARGS "cdhi:l:Lprs:t:w:"
88 
89 #ifndef DOXYGEN_SHOULD_SKIP_THIS
90 typedef enum {
91  WARP_AFFINE,
92  WARP_HOMOGRAPHY,
93  WARP_HOMOGRAPHY_SL3,
94  WARP_SRT,
95  WARP_TRANSLATION,
96 #ifdef VISP_HAVE_MODULE_TT_MI
97  WARP_RT,
98 #endif
99  WARP_LAST
100 } WarpType;
101 
102 typedef enum {
103  TRACKER_SSD_ESM,
104  TRACKER_SSD_FORWARD_ADDITIONAL,
105  TRACKER_SSD_FORWARD_COMPOSITIONAL,
106  TRACKER_SSD_INVERSE_COMPOSITIONAL, // The most efficient
107  TRACKER_ZNCC_FORWARD_ADDITIONEL,
108  TRACKER_ZNCC_INVERSE_COMPOSITIONAL,
109 #ifdef VISP_HAVE_MODULE_TT_MI
110  TRACKER_MI_ESM,
111  TRACKER_MI_FORWARD_ADDITIONAL,
112  TRACKER_MI_FORWARD_COMPOSITIONAL,
113  TRACKER_MI_INVERSE_COMPOSITIONAL, // The most efficient
114 #endif
115  TRACKER_LAST
116 } TrackerType;
117 
118 #endif
119 
120 void usage(const char *name, const char *badparam, const WarpType &warp_type, TrackerType &tracker_type,
121  const long &last_frame, const double &residual_threhold)
122 {
123  fprintf(stdout, "\n\
124 Example of template tracking.\n\
125 \n\
126 SYNOPSIS\n\
127  %s [-i <test image path>] [-c] [-d] [-p] \n\
128  [-w <warp type>] [-t <tracker type>] \n\
129  [-l <last frame number>] [-r] [-L] [-h]\n", name);
130 
131  fprintf(stdout, "\n\
132 OPTIONS: Default\n\
133  -i <input image path> \n\
134  Set image input path.\n\
135  From this path read images \n\
136  \"cube/image%%04d.pgm\". These \n\
137  images come from ViSP-images-x.y.z.tar.gz available \n\
138  on the ViSP website.\n\
139  Setting the VISP_INPUT_IMAGE_PATH environment\n\
140  variable produces the same behaviour than using\n\
141  this option.\n\
142  \n\
143  -l <last frame number> %ld\n\
144  Last frame number to consider.\n\
145  \n\
146  -d \n\
147  Turn off the display.\n\
148  \n\
149  -c\n\
150  Disable the mouse click. Useful to automaze the \n\
151  execution of this program without humain intervention.\n\
152  \n", last_frame);
153 
154 #ifdef VISP_HAVE_MODULE_TT_MI
155  fprintf(stdout, "\n\
156  -w <warp type=[0,1,2,3,4,5]> %d\n\
157  Set the model used to warp the template. \n\
158  Authorized values are:\n\
159  %d : Affine\n\
160  %d : Homography\n\
161  %d : Homography in SL3\n\
162  %d : SRT (scale, rotation, translation)\n\
163  %d : Translation\n\
164  %d : RT (rotation, translation)\n\n", (int)warp_type, (int)WARP_AFFINE, (int)WARP_HOMOGRAPHY, (int)WARP_HOMOGRAPHY_SL3, (int)WARP_SRT,
165  (int)WARP_TRANSLATION, (int)WARP_RT);
166 #else
167  fprintf(stdout, "\n\
168  -w <warp type=[0,1,2,3,4]> %d\n\
169  Set the model used to warp the template. \n\
170  Authorized values are:\n\
171  %d : Affine\n\
172  %d : Homography\n\
173  %d : Homography in SL3\n\
174  %d : SRT (scale, rotation, translation)\n\
175  %d : Translation\n\n", (int)warp_type, (int)WARP_AFFINE, (int)WARP_HOMOGRAPHY, (int)WARP_HOMOGRAPHY_SL3, (int)WARP_SRT,
176  (int)WARP_TRANSLATION);
177 #endif
178 
179 #ifdef VISP_HAVE_MODULE_TT_MI
180  fprintf(stdout, "\n\
181  -t <tracker type=[0,1,2,3,4,5,6,7,8,9]> %d\n\
182  Set the tracker used to track the template. \n\
183  Authorized values are:\n\
184  %d : SSD ESM\n\
185  %d : SSD forward additional\n\
186  %d : SSD forward compositional\n\
187  %d : SSD inverse compositional\n\
188  %d : ZNCC forward additional\n\
189  %d : ZNCC inverse compositional\n\
190  %d : MI ESM\n\
191  %d : MI forward additional\n\
192  %d : MI forward compositional\n\
193  %d : MI inverse compositional\n", (int)tracker_type, (int)TRACKER_SSD_ESM, (int)TRACKER_SSD_FORWARD_ADDITIONAL,
194  (int)TRACKER_SSD_FORWARD_COMPOSITIONAL, (int)TRACKER_SSD_INVERSE_COMPOSITIONAL,
195  (int)TRACKER_ZNCC_FORWARD_ADDITIONEL, (int)TRACKER_ZNCC_INVERSE_COMPOSITIONAL, (int)TRACKER_MI_ESM,
196  (int)TRACKER_MI_FORWARD_ADDITIONAL, (int)TRACKER_MI_FORWARD_COMPOSITIONAL,
197  (int)TRACKER_MI_INVERSE_COMPOSITIONAL);
198 #else
199  fprintf(stdout, "\n\
200  -t <tracker type=[0,1,2,3,4,5]> %d\n\
201  Set the tracker used to track the template. \n\
202  Authorized values are:\n\
203  %d : SSD ESM\n\
204  %d : SSD forward additional\n\
205  %d : SSD forward compositional\n\
206  %d : SSD inverse compositional\n\
207  %d : ZNCC forward additional\n\
208  %d : ZNCC inverse compositional\n", (int)tracker_type, (int)TRACKER_SSD_ESM, (int)TRACKER_SSD_FORWARD_ADDITIONAL,
209  (int)TRACKER_SSD_FORWARD_COMPOSITIONAL, (int)TRACKER_SSD_INVERSE_COMPOSITIONAL,
210  (int)TRACKER_ZNCC_FORWARD_ADDITIONEL, (int)TRACKER_ZNCC_INVERSE_COMPOSITIONAL);
211 
212 #endif
213  fprintf(stdout, "\n\
214  -p\n\
215  Enable pyramidal tracking.\n\
216  \n\
217  -r\n\
218  Disable re-init at frame 10.\n\
219  \n\
220  -s <residual threshold> %g\n\
221  Threshold used to stop optimization when residual difference\n\
222  between two successive optimization iteration becomes lower\n\
223  that this parameter.\n\
224  \n\
225  -L \n\
226  Create log file.\n\
227  \n\
228  -h \n\
229  Print the help.\n\n", residual_threhold);
230 
231  if (badparam)
232  fprintf(stdout, "\nERROR: Bad parameter [%s]\n", badparam);
233 }
234 
235 bool getOptions(int argc, const char **argv, std::string &ipath, bool &click_allowed, bool &display, bool &pyramidal,
236  WarpType &warp_type, TrackerType &tracker_type, long &last_frame, bool &reinit, double &threshold_residual,
237  bool &log)
238 {
239  const char *optarg_;
240  int c;
241  while ((c = vpParseArgv::parse(argc, argv, GETOPTARGS, &optarg_)) > 1) {
242 
243  switch (c) {
244  case 'c':
245  click_allowed = false;
246  break;
247  case 'd':
248  display = false;
249  break;
250  case 'h':
251  usage(argv[0], NULL, warp_type, tracker_type, last_frame, threshold_residual);
252  return false;
253  break;
254  case 'i':
255  ipath = optarg_;
256  break;
257  case 'l':
258  last_frame = (long)atoi(optarg_);
259  break;
260  case 'L':
261  log = true;
262  break;
263  case 'p':
264  pyramidal = true;
265  break;
266  case 'r':
267  reinit = false;
268  break;
269  case 't':
270  tracker_type = (TrackerType)atoi(optarg_);
271  break;
272  case 'w':
273  warp_type = (WarpType)atoi(optarg_);
274  break;
275  case 's':
276  threshold_residual = std::atof(optarg_);
277  break;
278 
279  default:
280  usage(argv[0], optarg_, warp_type, tracker_type, last_frame, threshold_residual);
281  return false;
282  break;
283  }
284  }
285 
286  if (warp_type >= WARP_LAST) {
287  usage(argv[0], NULL, warp_type, tracker_type, last_frame, threshold_residual);
288  std::cerr << "ERROR: " << std::endl;
289  std::cerr << " Bad argument -w <warp type> with \"warp type\"=" << (int)warp_type << std::endl << std::endl;
290  return false;
291  }
292  if (tracker_type >= TRACKER_LAST) {
293  usage(argv[0], NULL, warp_type, tracker_type, last_frame, threshold_residual);
294  std::cerr << "ERROR: " << std::endl;
295  std::cerr << " Bad argument -t <tracker type> with \"tracker type\"=" << (int)tracker_type << std::endl
296  << std::endl;
297  return false;
298  }
299  if ((c == 1) || (c == -1)) {
300  // standalone param or error
301  usage(argv[0], NULL, warp_type, tracker_type, last_frame, threshold_residual);
302  std::cerr << "ERROR: " << std::endl;
303  std::cerr << " Bad argument " << optarg_ << std::endl << std::endl;
304  return false;
305  }
306 
307  return true;
308 }
309 
310 int main(int argc, const char **argv)
311 {
312  try {
313  std::string env_ipath;
314  std::string opt_ipath;
315  std::string ipath;
316  bool opt_click_allowed = true;
317  bool opt_display = true;
318  bool opt_pyramidal = false;
319  TrackerType opt_tracker_type = TRACKER_SSD_INVERSE_COMPOSITIONAL;
320  WarpType opt_warp_type = WARP_AFFINE;
321  long opt_last_frame = 30;
322  bool opt_reinit = true;
323  double opt_threshold_residual = 1e-4;
324  bool opt_log = false;
325  std::ofstream ofs;
326 
327  // Set the default output path
328 #if !defined(_WIN32) && (defined(__unix__) || defined(__unix) || (defined(__APPLE__) && defined(__MACH__))) // UNIX
329  std::string opath = "/tmp";
330 #elif defined(_WIN32)
331  std::string opath = "C:\\temp";
332 #endif
333 
334  // Get the user login name
335  std::string username;
336  vpIoTools::getUserName(username);
337 
338  // Get the visp-images-data package path or VISP_INPUT_IMAGE_PATH
339  // environment variable value
340  env_ipath = vpIoTools::getViSPImagesDataPath();
341 
342  // Set the default input path
343  if (!env_ipath.empty())
344  ipath = env_ipath;
345 
346  // Append to the output path string, the login name of the user
347  std::string odirname = vpIoTools::createFilePath(opath, username);
348  std::string logfilename = vpIoTools::createFilePath(odirname, "template-tracker.log");
349 
350  // Read the command line options
351  if (!getOptions(argc, argv, opt_ipath, opt_click_allowed, opt_display, opt_pyramidal, opt_warp_type,
352  opt_tracker_type, opt_last_frame, opt_reinit, opt_threshold_residual, opt_log)) {
353  return (-1);
354  }
355 
356  // Test if an input path is set
357  if (opt_ipath.empty() && env_ipath.empty()) {
358  usage(argv[0], NULL, opt_warp_type, opt_tracker_type, opt_last_frame, opt_threshold_residual);
359  std::cerr << std::endl << "ERROR:" << std::endl;
360  std::cerr << " Use -i <visp image path> option or set VISP_INPUT_IMAGE_PATH " << std::endl
361  << " environment variable to specify the location of the " << std::endl
362  << " image path where test images are located." << std::endl
363  << std::endl;
364 
365  return (-1);
366  }
367 
368  // Get the option values
369  if (!opt_ipath.empty())
370  ipath = vpIoTools::createFilePath(opt_ipath, "mire-2/image.%04d.pgm");
371  else
372  ipath = vpIoTools::createFilePath(env_ipath, "mire-2/image.%04d.pgm");
373 
374  if (opt_log) {
375  ofs.open( logfilename.c_str() );
376  }
377 
379  vpVideoReader reader;
380 
381  reader.setFileName(ipath.c_str());
382  reader.setFirstFrameIndex(1);
383  reader.setLastFrameIndex(opt_last_frame);
384  try {
385  reader.open(I);
386  } catch (...) {
387  std::cout << "Cannot open sequence: " << ipath << std::endl;
388  return -1;
389  }
390  reader.acquire(I);
391 
392  vpDisplay *display = NULL;
393  if (opt_display) {
394 // initialise a display
395 #if defined VISP_HAVE_X11
396  display = new vpDisplayX;
397 #elif defined VISP_HAVE_GDI
398  display = new vpDisplayGDI;
399 #elif defined VISP_HAVE_OPENCV
400  display = new vpDisplayOpenCV;
401 #elif defined VISP_HAVE_D3D9
402  display = new vpDisplayD3D;
403 #elif defined VISP_HAVE_GTK
404  display = new vpDisplayGTK;
405 #else
406  opt_display = false;
407 #endif
408 #if defined(VISP_HAVE_DISPLAY)
409  display->init(I, 100, 100, "Test tracking");
410 #endif
412  vpDisplay::flush(I);
413  }
414 
415  vpTemplateTrackerWarp *warp = NULL;
416  switch (opt_warp_type) {
417  case WARP_AFFINE:
418  warp = new vpTemplateTrackerWarpAffine;
419  break;
420  case WARP_HOMOGRAPHY:
422  break;
423  case WARP_HOMOGRAPHY_SL3:
425  break;
426  case WARP_SRT:
427  warp = new vpTemplateTrackerWarpSRT;
428  break;
429  case WARP_TRANSLATION:
431  break;
432 #ifdef VISP_HAVE_MODULE_TT_MI
433  case WARP_RT:
434  warp = new vpTemplateTrackerWarpRT;
435  break;
436 #endif
437  default:
438  return 0;
439  }
440 
441  vpTemplateTracker *tracker = NULL;
442  switch (opt_tracker_type) {
443  case TRACKER_SSD_ESM:
444  tracker = new vpTemplateTrackerSSDESM(warp);
445  break;
446  case TRACKER_SSD_FORWARD_ADDITIONAL:
447  tracker = new vpTemplateTrackerSSDForwardAdditional(warp);
448  break;
449  case TRACKER_SSD_FORWARD_COMPOSITIONAL:
450  tracker = new vpTemplateTrackerSSDForwardCompositional(warp);
451  break;
452  case TRACKER_SSD_INVERSE_COMPOSITIONAL:
453  tracker = new vpTemplateTrackerSSDInverseCompositional(warp);
454  break;
455  case TRACKER_ZNCC_FORWARD_ADDITIONEL:
456  tracker = new vpTemplateTrackerZNCCForwardAdditional(warp);
457  break;
458  case TRACKER_ZNCC_INVERSE_COMPOSITIONAL:
459  tracker = new vpTemplateTrackerZNCCInverseCompositional(warp);
460  break;
461 #ifdef VISP_HAVE_MODULE_TT_MI
462  case TRACKER_MI_ESM:
463  tracker = new vpTemplateTrackerMIESM(warp);
464  break;
465  case TRACKER_MI_FORWARD_ADDITIONAL:
466  tracker = new vpTemplateTrackerMIForwardAdditional(warp);
467  break;
468  case TRACKER_MI_FORWARD_COMPOSITIONAL:
469  tracker = new vpTemplateTrackerMIForwardCompositional(warp);
470  break;
471  case TRACKER_MI_INVERSE_COMPOSITIONAL:
472  tracker = new vpTemplateTrackerMIInverseCompositional(warp);
473  break;
474 #endif
475  default:
476  return 0;
477  }
478 
479  tracker->setSampling(2, 2);
480  tracker->setLambda(0.001);
481  tracker->setThresholdGradient(60.);
482  tracker->setIterationMax(800);
483  if (opt_pyramidal) {
484  tracker->setPyramidal(2, 1);
485  }
486  tracker->setThresholdResidualDifference(opt_threshold_residual);
487  bool delaunay = false;
488  if (opt_display && opt_click_allowed)
489  tracker->initClick(I, delaunay);
490  else {
491  std::vector<vpImagePoint> v_ip;
492  vpImagePoint ip;
493  ip.set_ij(166, 54);
494  v_ip.push_back(ip);
495  ip.set_ij(284, 55);
496  v_ip.push_back(ip);
497  ip.set_ij(259, 284);
498  v_ip.push_back(ip); // ends the first triangle
499  ip.set_ij(259, 284);
500  v_ip.push_back(ip); // start the second triangle
501  ip.set_ij(149, 240);
502  v_ip.push_back(ip);
503  ip.set_ij(167, 58);
504  v_ip.push_back(ip);
505 
506  tracker->initFromPoints(I, v_ip, false);
507  }
508 
509  double t_init = vpTime::measureTimeMs();
510  int niter = 0;
511 
512  while (!reader.end()) {
513  // Acquire a new image
514  reader.acquire(I);
515  std::cout << "Process image number " << reader.getFrameIndex() << std::endl;
516  // Display the image
518  // Track the template
519  tracker->track(I);
520  // Save log
521  if (opt_log) {
522  ofs << tracker->getNbIteration() << std::endl;
523  }
524 
525  // Simulate a re-init
526  if (opt_reinit && (reader.getFrameIndex() == 10)) {
527  std::cout << "re-init simulation" << std::endl;
528  if (opt_click_allowed)
530 
531  tracker->resetTracker();
532 
533  if (opt_display && opt_click_allowed) {
534  vpDisplay::displayText(I, 10, 10, "Re-init simulation", vpColor::red);
535  vpDisplay::flush(I);
536  tracker->initClick(I, delaunay);
537  } else {
538  std::vector<vpImagePoint> v_ip;
539  vpImagePoint ip;
540  ip.set_ij(146, 60);
541  v_ip.push_back(ip);
542  ip.set_ij(254, 74);
543  v_ip.push_back(ip);
544  ip.set_ij(228, 288);
545  v_ip.push_back(ip); // ends the first triangle
546  ip.set_ij(228, 288);
547  v_ip.push_back(ip); // start the second triangle
548  ip.set_ij(126, 242);
549  v_ip.push_back(ip);
550  ip.set_ij(146, 60);
551  v_ip.push_back(ip);
552 
553  tracker->initFromPoints(I, v_ip, false);
554  }
555  }
556 
557 // Display the template
558 #if 1
559  tracker->display(I, vpColor::red, 3);
560 #else
561  vpTemplateTrackerZone zoneWarped_, zoneRef_ = tracker->getZoneRef();
562  vpTemplateTrackerWarp *warp_ = tracker->getWarp();
563  vpColVector p_ = tracker->getp();
564  warp_->warpZone(zoneRef_, p_, zoneWarped_);
565  zoneWarped_.display(I, vpColor::red, 3);
566  zoneRef_.display(I, vpColor::green, 3);
567 #endif
568 
569  vpDisplay::flush(I);
570 
571  niter ++;
572  }
573  double t_end = vpTime::measureTimeMs();
574  std::cout << "Total time: " << t_end - t_init << " ms" << std::endl;
575  std::cout << "Total mean: " << (t_end - t_init)/niter << " ms" << std::endl;
576 
577  if (opt_log) {
578  std::cout << "Log are saved in: " << logfilename << std::endl;
579  ofs.close();
580  }
581 
582  if (opt_click_allowed) {
583  vpDisplay::displayText(I, 10, 10, "A click to exit...", vpColor::red);
584  vpDisplay::flush(I);
586  }
587  reader.close();
588  if (display)
589  delete display;
590 
591  delete warp;
592  delete tracker;
593 
594  return EXIT_SUCCESS;
595  } catch (const vpException &e) {
596  std::cout << "Catch an exception: " << e << std::endl;
597  return EXIT_FAILURE;
598  }
599 }
600 
601 #else
602 
603 int main()
604 {
605  std::cout << "visp_tt module or display not available." << std::endl;
606  return EXIT_SUCCESS;
607 }
608 
609 #endif
void display(const vpImage< unsigned char > &I, const vpColor &col=vpColor::green, unsigned int thickness=3)
void setSampling(int sample_i, int sample_j)
Class that defines generic functionnalities for display.
Definition: vpDisplay.h:171
static bool getClick(const vpImage< unsigned char > &I, bool blocking=true)
static std::string getViSPImagesDataPath()
Definition: vpIoTools.cpp:1292
unsigned int getNbIteration() const
Display for windows using GDI (available on any windows 32 platform).
Definition: vpDisplayGDI.h:128
static void displayText(const vpImage< unsigned char > &I, const vpImagePoint &ip, const std::string &s, const vpColor &color)
Use the X11 console to display images on unix-like OS. Thus to enable this class X11 should be instal...
Definition: vpDisplayX.h:150
Class that enables to manipulate easily a video file or a sequence of images. As it inherits from the...
error that can be emited by ViSP classes.
Definition: vpException.h:71
void setIterationMax(const unsigned int &n)
static const vpColor green
Definition: vpColor.h:182
static void flush(const vpImage< unsigned char > &I)
VISP_EXPORT double measureTimeMs()
Definition: vpTime.cpp:126
static bool parse(int *argcPtr, const char **argv, vpArgvInfo *argTable, int flags)
Definition: vpParseArgv.cpp:69
static const vpColor red
Definition: vpColor.h:179
vpColVector getp() const
void open(vpImage< vpRGBa > &I)
void display(const vpImage< unsigned char > &I, const vpColor &col=vpColor::green, unsigned int thickness=3)
Display for windows using Direct3D 3rd party. Thus to enable this class Direct3D should be installed...
Definition: vpDisplayD3D.h:106
static std::string createFilePath(const std::string &parent, const std::string &child)
Definition: vpIoTools.cpp:1537
static void display(const vpImage< unsigned char > &I)
The vpDisplayOpenCV allows to display image using the OpenCV library. Thus to enable this class OpenC...
vpTemplateTrackerWarp * getWarp() const
void initClick(const vpImage< unsigned char > &I, bool delaunay=false)
static std::string getUserName()
Definition: vpIoTools.cpp:318
The vpDisplayGTK allows to display image using the GTK 3rd party library. Thus to enable this class G...
Definition: vpDisplayGTK.h:137
void acquire(vpImage< vpRGBa > &I)
void initFromPoints(const vpImage< unsigned char > &I, const std::vector< vpImagePoint > &v_ip, bool delaunay=false)
void warpZone(const vpTemplateTrackerZone &in, const vpColVector &p, vpTemplateTrackerZone &out)
long getFrameIndex() const
void set_ij(double ii, double jj)
Definition: vpImagePoint.h:189
void setLastFrameIndex(const long last_frame)
Implementation of column vector and the associated operations.
Definition: vpColVector.h:130
void setLambda(double l)
void track(const vpImage< unsigned char > &I)
void setFileName(const std::string &filename)
void setFirstFrameIndex(const long first_frame)
Class that defines a 2D point in an image. This class is useful for image processing and stores only ...
Definition: vpImagePoint.h:88
void setThresholdResidualDifference(double threshold)
vpTemplateTrackerZone getZoneRef() const
void setPyramidal(unsigned int nlevels=2, unsigned int level_to_stop=1)
void setThresholdGradient(double threshold)