2 #include <visp3/gui/vpPlot.h> 3 #include <visp3/robot/vpSimulatorCamera.h> 4 #include <visp3/visual_features/vpFeatureBuilder.h> 5 #include <visp3/vs/vpServo.h> 27 for (
unsigned int i = 0; i < 4; i++) {
41 #ifdef VISP_HAVE_DISPLAY 42 vpPlot plotter(2, 250 * 2, 500, 100, 200,
"Real time curves plotter");
43 plotter.setTitle(0,
"Visual features error");
44 plotter.setTitle(1,
"Camera velocities");
46 plotter.initGraph(0, 8);
47 plotter.initGraph(1, 6);
49 plotter.setLegend(0, 0,
"x1");
50 plotter.setLegend(0, 1,
"y1");
51 plotter.setLegend(0, 2,
"x2");
52 plotter.setLegend(0, 3,
"y2");
53 plotter.setLegend(0, 4,
"x3");
54 plotter.setLegend(0, 5,
"y3");
55 plotter.setLegend(0, 6,
"x4");
56 plotter.setLegend(0, 7,
"y4");
58 plotter.setLegend(1, 0,
"v_x");
59 plotter.setLegend(1, 1,
"v_y");
60 plotter.setLegend(1, 2,
"v_z");
61 plotter.setLegend(1, 3,
"w_x");
62 plotter.setLegend(1, 4,
"w_y");
63 plotter.setLegend(1, 5,
"w_z");
66 unsigned int iter = 0;
70 for (
unsigned int i = 0; i < 4; i++) {
77 #ifdef VISP_HAVE_DISPLAY 78 plotter.plot(0, iter, task.
getError());
79 plotter.plot(1, iter, v);
81 if ((task.
getError()).sumSquare() < 0.0001)
86 std::cout <<
"Convergence in " << iter <<
" iterations" << std::endl;
88 #ifdef VISP_HAVE_DISPLAY 89 plotter.saveData(0,
"error.dat");
90 plotter.saveData(1,
"vc.dat");
95 std::cout <<
"Catch an exception: " << e << std::endl;
Adaptive gain computation.
void setWorldCoordinates(double oX, double oY, double oZ)
static bool getClick(const vpImage< unsigned char > &I, bool blocking=true)
void setVelocity(const vpRobot::vpControlFrameType frame, const vpColVector &vel)
Implementation of an homogeneous matrix and operations on such kind of matrices.
Class that defines the simplest robot: a free flying camera.
void addFeature(vpBasicFeature &s, vpBasicFeature &s_star, unsigned int select=vpBasicFeature::FEATURE_ALL)
error that can be emited by ViSP classes.
void track(const vpHomogeneousMatrix &cMo)
Class that defines a 2D point visual feature which is composed by two parameters that are the cartes...
Class that defines a 3D point in the object frame and allows forward projection of a 3D point in the ...
virtual void setSamplingTime(const double &delta_t)
vpColVector getError() const
vpColVector computeControlLaw()
vpHomogeneousMatrix getPosition() const
void setInteractionMatrixType(const vpServoIteractionMatrixType &interactionMatrixType, const vpServoInversionType &interactionMatrixInversion=PSEUDO_INVERSE)
static double rad(double deg)
Implementation of column vector and the associated operations.
vpHomogeneousMatrix inverse() const
This class enables real time drawing of 2D or 3D graphics. An instance of the class open a window whi...
static void create(vpFeaturePoint &s, const vpCameraParameters &cam, const vpDot &d)
void setServo(const vpServoType &servo_type)