Visual Servoing Platform version 3.7.0
Loading...
Searching...
No Matches
vpTemplateTrackerMIBSpline.h
1/*
2 * ViSP, open source Visual Servoing Platform software.
3 * Copyright (C) 2005 - 2025 by Inria. All rights reserved.
4 *
5 * This software is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 * See the file LICENSE.txt at the root directory of this source
10 * distribution for additional information about the GNU GPL.
11 *
12 * For using ViSP with software that can not be combined with the GNU
13 * GPL, please contact Inria about acquiring a ViSP Professional
14 * Edition License.
15 *
16 * See https://visp.inria.fr for more information.
17 *
18 * This software was developed at:
19 * Inria Rennes - Bretagne Atlantique
20 * Campus Universitaire de Beaulieu
21 * 35042 Rennes Cedex
22 * France
23 *
24 * If you have questions regarding the use of this file, please contact
25 * Inria at visp@inria.fr
26 *
27 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
28 * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
29 *
30 * Description:
31 * Template tracker.
32 *
33 * Authors:
34 * Amaury Dame
35 * Aurelien Yol
36 */
41
42#ifndef vpTemplateTrackerMIBSpline_hh
43#define vpTemplateTrackerMIBSpline_hh
44
45#include <visp3/core/vpConfig.h>
46
47#include <visp3/core/vpImage.h>
48#include <visp3/core/vpMath.h>
49#include <visp3/tt/vpTemplateTrackerBSpline.h>
50#include <visp3/tt/vpTemplateTrackerHeader.h>
51
52#include <visp3/tt_mi/vpTemplateTrackerMI.h>
53
54#ifndef DOXYGEN_SHOULD_SKIP_THIS
67 class VISP_EXPORT vpTemplateTrackerMIBSpline
68{
69public:
70 static void PutPVBsplineD(double *Prt, int cr, double er, int ct, double et, int Nc, double val, const int &degre);
71 static void PutPVBsplineD3(double *Prt, int cr, double er, int ct, double et, int Nc, double val);
72 static void PutPVBsplineD4(double *Prt, int cr, double er, int ct, double et, int Nc, double val);
73
74 static void PutTotPVBspline(double *Prt, int cr, double &er, int ct, double &et, int Nc, double *val,
75 unsigned int &NbParam, int &degree);
76 static void PutTotPVBspline(double *Prt, double *dPrt, double *d2Prt, int cr, double &er, int ct, double &et, int Ncb,
77 double *val, unsigned int &NbParam, int &degree);
78 static void PutTotPVBspline3(double *Prt, int cr, double &er, int ct, double &et, int Nc, double *val,
79 unsigned int &NbParam);
80 static void PutTotPVBspline3(double *Prt, double *dPrt, double *d2Prt, int cr, double &er, int ct, double &et,
81 int Ncb, double *val, unsigned int &NbParam);
82 static void PutTotPVBspline4(double *Prt, int cr, double er, int ct, double et, int Nc, double *val,
83 unsigned int &NbParam);
84 static void PutTotPVBspline4(double *Prt, double *dPrt, double *d2Prt, int cr, double er, int ct, double et, int Ncb,
85 double *val, unsigned int &NbParam);
86
87 // AY Optimisation
88 static void PutTotPVBspline3(double *Prt, double &er, double *et, unsigned int NbParam);
89 static void PutTotPVBspline4(double *Prt, double &er, double *et, unsigned int NbParam);
90 //
91
92 static void PutTotPVBsplineNoSecond(double *Prt, int &cr, double &er, int &ct, double &et, int &Nc, double *val,
93 unsigned int &NbParam, int &degree);
94 static void PutTotPVBsplineNoSecond(double *Prt, double *dPrt, int &cr, double &er, int &ct, double &et, int &Ncb,
95 double *val, unsigned int &NbParam, int &degree);
96 static void PutTotPVBspline3NoSecond(double *Prt, int &cr, double &er, int &ct, double &et, int &Nc, double *val,
97 unsigned int &NbParam);
98 static void PutTotPVBspline3NoSecond(double *Prt, double *dPrt, int &cr, double &er, int &ct, double &et, int &Ncb,
99 double *val, unsigned int &NbParam);
100 static void PutTotPVBspline4NoSecond(double *Prt, int &cr, double &er, int &ct, double &et, int &Nc, double *val,
101 unsigned int &NbParam);
102 static void PutTotPVBspline4NoSecond(double *Prt, double *dPrt, int &cr, double &er, int &ct, double &et, int &Ncb,
103 double *val, unsigned int &NbParam);
104
105 static void PutTotPVBsplinePrtTout(double *Prt, int &cr, double &er, int &ct, double &et, int &Nc,
106 unsigned int &NbParam, int &degree);
107 static void PutTotPVBspline3PrtTout(double *Prt, int &cr, double &er, int &ct, double &et, int &Nc,
108 unsigned int &NbParam);
109 static void PutTotPVBspline4PrtTout(double *Prt, int &cr, double &er, int &ct, double &et, int &Nc,
110 unsigned int &NbParam);
111
112 static void PutTotPVBsplinePrt(double *Prt, int &cr, double &er, int &ct, double &et, int &Ncb, unsigned int &NbParam,
113 int &degree);
114 static void PutTotPVBspline3Prt(double *Prt, int &cr, double &er, int &ct, double &et, int &Ncb);
115 static void PutTotPVBspline4Prt(double *Prt, int &cr, double &er, int &ct, double &et, int &Ncb);
116
117 static double Bspline3(double diff);
118 static double Bspline4i(double diff, int &interv);
119
120 static double dBspline3(double diff);
121 static double dBspline4(double diff);
122
123 static double d2Bspline3(double diff);
124 static double d2Bspline4(double diff);
125
126 static void computeProbabilities(double *Prt, int &cr, double &er, int &ct, double &et, int &Nc, double *dW,
127 unsigned int &NbParam, int &bspline,
128 vpTemplateTrackerMI::vpHessienApproximationType &approx, bool use_hessien_des);
129};
130END_VISP_NAMESPACE
131#endif
132#endif