Visual Servoing Platform version 3.7.0
Loading...
Searching...
No Matches
vpTemplateTrackerWarp.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 vpTemplateTrackerWarp_hh
43#define vpTemplateTrackerWarp_hh
44
45#include <visp3/core/vpConfig.h>
46#include <visp3/core/vpDisplay.h>
47#include <visp3/core/vpTrackingException.h>
48#include <visp3/tt/vpTemplateTrackerHeader.h>
49#include <visp3/tt/vpTemplateTrackerTriangle.h>
50#include <visp3/tt/vpTemplateTrackerZone.h>
51
64class VISP_EXPORT vpTemplateTrackerWarp
65{
66protected:
67 double denom;
68 unsigned int nbParam;
69
70public:
79
80#ifndef DOXYGEN_SHOULD_SKIP_THIS
81 virtual void computeCoeff(const vpColVector &p) = 0;
82 virtual void computeDenom(vpColVector &vX, const vpColVector &ParamM) = 0;
83#endif
84
97 virtual void dWarp(const vpColVector &X1, const vpColVector &X2, const vpColVector &p, vpMatrix &dM) = 0;
98
108 virtual void dWarpCompo(const vpColVector &X1, const vpColVector &X2, const vpColVector &p, const double *dwdp0,
109 vpMatrix &dM) = 0;
110
119 virtual void getdW0(const int &v, const int &u, const double &dv, const double &du, double *dIdW) = 0;
120
132 virtual void getdWdp0(const int &v, const int &u, double *dIdW) = 0;
133
140 virtual void getParamInverse(const vpColVector &p, vpColVector &p_inv) const = 0;
141
148 virtual void getParamPyramidDown(const vpColVector &p, vpColVector &p_down) = 0;
149
156 virtual void getParamPyramidUp(const vpColVector &p, vpColVector &p_up) = 0;
157
163 virtual bool isESMcompatible() const = 0;
164
173 virtual void pRondp(const vpColVector &p1, const vpColVector &p2, vpColVector &p12) const = 0;
174
184 virtual void warpX(const int &v1, const int &u1, double &v2, double &u2, const vpColVector &p) = 0;
185
193 virtual void warpX(const vpColVector &X1, vpColVector &X2, const vpColVector &p) = 0;
194
202 virtual void warpXInv(const vpColVector &X1, vpColVector &X2, const vpColVector &p) = 0;
203
206#ifndef DOXYGEN_SHOULD_SKIP_THIS
207 void findWarp(const double *ut0, const double *vt0, const double *u, const double *v, int nb_pt, vpColVector &p);
208#endif
216
222 unsigned int getNbParam() const { return nbParam; }
223
229 void setNbParam(unsigned int nb) { nbParam = nb; }
230
241 void warp(const double *ut0, const double *vt0, int nb_pt, const vpColVector &p, double *u, double *v);
242
251 void warpTriangle(const vpTemplateTrackerTriangle &in, const vpColVector &p, vpTemplateTrackerTriangle &out);
252
262 void warpZone(const vpTemplateTrackerZone &in, const vpColVector &p, vpTemplateTrackerZone &out);
264};
265END_VISP_NAMESPACE
266#endif
Implementation of column vector and the associated operations.
Implementation of a matrix and operations on matrices.
Definition vpMatrix.h:175
virtual void dWarpCompo(const vpColVector &X1, const vpColVector &X2, const vpColVector &p, const double *dwdp0, vpMatrix &dM)=0
virtual bool isESMcompatible() const =0
virtual void warpX(const vpColVector &X1, vpColVector &X2, const vpColVector &p)=0
unsigned int nbParam
Number of parameters used to model warp transformation.
virtual void getParamPyramidUp(const vpColVector &p, vpColVector &p_up)=0
unsigned int getNbParam() const
virtual void getParamInverse(const vpColVector &p, vpColVector &p_inv) const =0
virtual void getdW0(const int &v, const int &u, const double &dv, const double &du, double *dIdW)=0
virtual void dWarp(const vpColVector &X1, const vpColVector &X2, const vpColVector &p, vpMatrix &dM)=0
virtual void getdWdp0(const int &v, const int &u, double *dIdW)=0
double getDistanceBetweenZoneAndWarpedZone(const vpTemplateTrackerZone &Z, const vpColVector &p)
virtual void warpX(const int &v1, const int &u1, double &v2, double &u2, const vpColVector &p)=0
void setNbParam(unsigned int nb)
virtual void warpXInv(const vpColVector &X1, vpColVector &X2, const vpColVector &p)=0
virtual void getParamPyramidDown(const vpColVector &p, vpColVector &p_down)=0
double denom
Internal value used by homography warp model.
virtual void pRondp(const vpColVector &p1, const vpColVector &p2, vpColVector &p12) const =0