49 #include <visp/vpBasicFeature.h>
50 #include <visp/vpFeatureLine.h>
53 #include <visp/vpException.h>
54 #include <visp/vpMatrixException.h>
55 #include <visp/vpFeatureException.h>
58 #include <visp/vpDebug.h>
61 #include <visp/vpMath.h>
66 #include <visp/vpCameraParameters.h>
69 #include <visp/vpColor.h>
70 #include <visp/vpImage.h>
74 #include <visp/vpFeatureDisplay.h>
109 A = B = C = D = 0.0 ;
133 for(
int i = 0; i < 2; i++)
flags[i] =
true;
149 const double C_,
const double D_)
218 if (
flags[i] ==
false)
222 vpTRACE(
"Warning !!! The interaction matrix is computed but rho was not set yet");
225 vpTRACE(
"Warning !!! The interaction matrix is computed but theta was not set yet");
228 vpTRACE(
"Warning !!! The interaction matrix is computed but A was not set yet");
231 vpTRACE(
"Warning !!! The interaction matrix is computed but B was not set yet");
234 vpTRACE(
"Warning !!! The interaction matrix is computed but C was not set yet");
237 vpTRACE(
"Warning !!! The interaction matrix is computed but D was not set yet");
240 vpTRACE(
"Problem during the reading of the variable flags");
247 double theta =
s[1] ;
250 double co = cos(theta);
251 double si = sin(theta);
255 vpERROR_TRACE(
"Incorrect plane coordinates D is null, D = %f",D) ;
258 "Incorrect plane coordinates D")) ;
261 double lambda_theta =( A*si - B*co) /D;
262 double lambda_rho = (C + rho*A*co + rho*B*si)/D;
269 Lrho[0][0]= co*lambda_rho;
270 Lrho[0][1]= si*lambda_rho;
271 Lrho[0][2]= -rho*lambda_rho;
272 Lrho[0][3]= si*(1.0 + rho*rho);
273 Lrho[0][4]= -co*(1.0 + rho*rho);
283 Ltheta[0][0] = co*lambda_theta;
284 Ltheta[0][1] = si*lambda_theta;
285 Ltheta[0][2] = -rho*lambda_theta;
286 Ltheta[0][3] = -rho*co;
287 Ltheta[0][4] = -rho*si;
336 const unsigned int select)
344 erho[0] =
s[0] - s_star[0] ;
354 double err =
s[1] - s_star[1] ;
355 while (err < -M_PI) err += 2*M_PI ;
356 while (err > M_PI) err -= 2*M_PI ;
366 std::cout <<std::endl << me << std::endl ;
372 std::cout <<std::endl << me << std::endl ;
406 std::cout <<
"Line:\t " << A <<
"X+" << B <<
"Y+" << C <<
"Z +" << D <<
"=0" <<std::endl ;;
408 std::cout <<
" \trho=" <<
s[0] ;
410 std::cout <<
" \ttheta=" << s[1] ;
411 std::cout <<std::endl ;
434 for(
int i = 0; i < 2; i++)
flags[i] =
true;
467 const double A_,
const double B_,
468 const double C_,
const double D_)
512 unsigned int thickness)
const
543 unsigned int thickness)
const
Definition of the vpMatrix class.
bool * flags
Ensure that all the parameters needed to compute the iteraction matrix are set.
void setABCD(const double A, const double B, const double C, const double D)
void resize(const unsigned int nrows, const unsigned int ncols, const bool nullify=true)
void print(const unsigned int select=FEATURE_ALL) const
Class to define colors available for display functionnalities.
unsigned int dim_s
Dimension of the visual feature.
error that can be emited by ViSP classes.
static unsigned int selectTheta()
class that defines what is a visual feature
void buildFrom(const double rho, const double theta)
void display(const vpCameraParameters &cam, const vpImage< unsigned char > &I, const vpColor &color=vpColor::green, unsigned int thickness=1) const
static unsigned int selectRho()
Error that can be emited by the vpBasicFeature class and its derivates.
Generic class defining intrinsic camera parameters.
Class that defines a 2D line visual feature which is composed by two parameters that are and ...
vpFeatureLine * duplicate() const
vpMatrix interaction(const unsigned int select=FEATURE_ALL)
void stackMatrices(const vpMatrix &A)
vpBasicFeatureDeallocatorType deallocate
Class that provides a data structure for the column vectors as well as a set of operations on these v...
static void displayLine(double rho, double theta, const vpCameraParameters &cam, const vpImage< unsigned char > &I, const vpColor &color=vpColor::green, unsigned int thickness=1)
error that can be emited by the vpMatrix class and its derivates
vpColVector error(const vpBasicFeature &s_star, const unsigned int select=FEATURE_ALL)
unsigned int nbParameters
Number of parameters needed to compute the interaction matrix.
vpColVector s
State of the visual feature.
void resize(const unsigned int i, const bool flagNullify=true)
void setRhoTheta(const double rho, const double theta)