Visual Servoing Platform  version 3.6.1 under development (2024-04-20)
tutorial-pose-from-points-realsense-T265.cpp
1 
2 #include <visp3/core/vpConfig.h>
3 #ifdef VISP_HAVE_MODULE_SENSOR
4 #include <visp3/sensor/vpRealSense2.h>
5 #endif
6 #include <visp3/gui/vpDisplayGDI.h>
7 #include <visp3/gui/vpDisplayOpenCV.h>
8 #include <visp3/gui/vpDisplayX.h>
9 
10 #include "pose_helper.h"
11 
12 int main(int argc, char **argv)
13 {
14 #if (defined(VISP_HAVE_X11) || defined(VISP_HAVE_GDI) || defined(VISP_HAVE_OPENCV)) && \
15  defined(VISP_HAVE_REALSENSE2) && (RS2_API_VERSION > ((2 * 10000) + (31 * 100) + 0))
16  try {
17  double opt_square_width = 0.12;
18  int opt_camera_index = 1; // camera index: 1. Left, 2.Right
19 
20  for (int i = 0; i < argc; i++) {
21  if (std::string(argv[i]) == "--camera_index" && i + 1 < argc) {
22  opt_camera_index = atoi(argv[i + 1]);
23  }
24  else if (std::string(argv[i]) == "--square_width" && i + 1 < argc) {
25  opt_square_width = atoi(argv[i + 1]);
26  }
27  else if (std::string(argv[i]) == "--help" || std::string(argv[i]) == "-h") {
28  std::cout << "\nUsage: " << argv[0] << " [--camera_index <1.Left | 2.Right> (default: 1)]"
29  << " [--square_width <square width in meter (default: 0.12)] [--help] [-h]\n"
30  << "\nExample using right camera and square size 0.1:\n"
31  << " " << argv[0] << "--camera_index 2 --square_width 0.1\n"
32  << std::endl;
33  return EXIT_SUCCESS;
34  }
35  }
36 
38 
40  std::cout << "Use Realsense 2 grabber" << std::endl;
41  vpRealSense2 g;
42  rs2::config config;
43  config.enable_stream(RS2_STREAM_FISHEYE, 1);
44  config.enable_stream(RS2_STREAM_FISHEYE, 2);
45 
46  g.open(config);
47  if (opt_camera_index == 1) // Left camera
48  g.acquire(&I, nullptr, nullptr);
49  else
50  g.acquire(nullptr, &I, nullptr);
51 
52  std::cout << "Read camera parameters from Realsense device" << std::endl;
53  // Parameters of our camera
55  RS2_STREAM_FISHEYE, vpCameraParameters::ProjWithKannalaBrandtDistortion, opt_camera_index);
57 
58  std::cout << "Square width : " << opt_square_width << std::endl;
59  std::cout << cam << std::endl;
60 
61  // The pose container
63 
64  std::vector<vpDot2> dot(4);
65  std::vector<vpPoint> point; // 3D coordinates of the points
66  std::vector<vpImagePoint> ip; // 2D coordinates of the points in pixels
67  double L = opt_square_width / 2.;
68  point.push_back(vpPoint(-L, -L, 0));
69  point.push_back(vpPoint(L, -L, 0));
70  point.push_back(vpPoint(L, L, 0));
71  point.push_back(vpPoint(-L, L, 0));
72 
73 #if defined(VISP_HAVE_X11)
74  vpDisplayX d(I);
75 #elif defined(VISP_HAVE_GDI)
76  vpDisplayGDI d(I);
77 #elif defined(HAVE_OPENCV_HIGHGUI)
78  vpDisplayOpenCV d(I);
79 #endif
80 
81  bool quit = false;
82  bool apply_cv = false; // apply computer vision
83  bool init_cv = true; // initialize tracking and pose computation
84 
85  while (!quit) {
86  double t_begin = vpTime::measureTimeMs();
87 
88  if (opt_camera_index == 1)
89  g.acquire(&I, nullptr, nullptr);
90  else
91  g.acquire(nullptr, &I, nullptr);
92 
94  if (apply_cv) {
95  try {
96  ip = track(I, dot, init_cv);
97  computePose(point, ip, cam, init_cv, cMo);
98  vpDisplay::displayFrame(I, cMo, cam, opt_square_width, vpColor::none, 3);
99  if (init_cv)
100  init_cv = false; // turn off the computer vision initialisation specific stuff
101 
102  { // Display estimated pose in [m] and [deg]
103  vpPoseVector pose(cMo);
104  std::stringstream ss;
105  ss << "Translation: " << std::setprecision(5) << pose[0] << " " << pose[1] << " " << pose[2] << " [m]";
106  vpDisplay::displayText(I, 60, 20, ss.str(), vpColor::red);
107  ss.str(""); // erase ss
108  ss << "Rotation tu: " << std::setprecision(4) << vpMath::deg(pose[3]) << " " << vpMath::deg(pose[4]) << " "
109  << vpMath::deg(pose[5]) << " [deg]";
110  vpDisplay::displayText(I, 80, 20, ss.str(), vpColor::red);
111  }
112  }
113  catch (...) {
114  std::cout << "Computer vision failure." << std::endl;
115  apply_cv = false;
116  init_cv = true;
117  }
118  }
119  vpDisplay::displayText(I, 20, 20, "Right click: quit", vpColor::red);
120  if (apply_cv) {
121  vpDisplay::displayText(I, 40, 20, "Computer vision in progress...", vpColor::red);
122  }
123  else {
124  vpDisplay::displayText(I, 40, 20, "Left click : start", vpColor::red);
125  }
127  if (vpDisplay::getClick(I, button, false)) {
128  if (button == vpMouseButton::button3) {
129  quit = true;
130  }
131  else if (button == vpMouseButton::button1) {
132  apply_cv = true;
133  }
134  }
135  {
136  std::stringstream ss;
137  ss << "Time: " << vpTime::measureTimeMs() - t_begin << " ms";
138  vpDisplay::displayText(I, 20, I.getWidth() - 100, ss.str(), vpColor::red);
139  }
140  vpDisplay::flush(I);
141  }
142  }
143  catch (const vpException &e) {
144  std::cout << "Catch an exception: " << e.getMessage() << std::endl;
145  }
146 #elif !defined(VISP_HAVE_REALSENSE2)
147  (void)argc;
148  (void)argv;
149  std::cout << "You do not realsense2 SDK functionality enabled..." << std::endl;
150  std::cout << "Tip:" << std::endl;
151  std::cout << "- Install librealsense2, configure again ViSP using cmake and build again this example" << std::endl;
152  return EXIT_SUCCESS;
153 #elif !(defined(VISP_HAVE_X11) || defined(VISP_HAVE_GDI) || defined(VISP_HAVE_OPENCV))
154  (void)argc;
155  (void)argv;
156  std::cout << "Install a 3rd party dedicated to image display (X11, GDI, OpenCV), configure and build ViSP again to "
157  "use this example"
158  << std::endl;
159 #elif !(RS2_API_VERSION > ((2 * 10000) + (31 * 100) + 0))
160  (void)argc;
161  (void)argv;
162  std::cout << "Install librealsense version > 2.31.0" << std::endl;
163 #endif
164 }
Generic class defining intrinsic camera parameters.
@ ProjWithKannalaBrandtDistortion
Projection with Kannala-Brandt distortion model.
static const vpColor red
Definition: vpColor.h:211
static const vpColor none
Definition: vpColor.h:223
Display for windows using GDI (available on any windows 32 platform).
Definition: vpDisplayGDI.h:128
The vpDisplayOpenCV allows to display image using the OpenCV library. Thus to enable this class OpenC...
Use the X11 console to display images on unix-like OS. Thus to enable this class X11 should be instal...
Definition: vpDisplayX.h:128
static bool getClick(const vpImage< unsigned char > &I, bool blocking=true)
static void display(const vpImage< unsigned char > &I)
static void displayFrame(const vpImage< unsigned char > &I, const vpHomogeneousMatrix &cMo, const vpCameraParameters &cam, double size, const vpColor &color=vpColor::none, unsigned int thickness=1, const vpImagePoint &offset=vpImagePoint(0, 0), const std::string &frameName="", const vpColor &textColor=vpColor::black, const vpImagePoint &textOffset=vpImagePoint(15, 15))
static void flush(const vpImage< unsigned char > &I)
static void displayText(const vpImage< unsigned char > &I, const vpImagePoint &ip, const std::string &s, const vpColor &color)
error that can be emitted by ViSP classes.
Definition: vpException.h:59
const char * getMessage() const
Definition: vpException.cpp:64
Implementation of an homogeneous matrix and operations on such kind of matrices.
unsigned int getWidth() const
Definition: vpImage.h:245
static double deg(double rad)
Definition: vpMath.h:117
Class that defines a 3D point in the object frame and allows forward projection of a 3D point in the ...
Definition: vpPoint.h:77
Implementation of a pose vector and operations on poses.
Definition: vpPoseVector.h:189
vpCameraParameters getCameraParameters(const rs2_stream &stream, vpCameraParameters::vpCameraParametersProjType type=vpCameraParameters::perspectiveProjWithDistortion, int index=-1) const
void acquire(vpImage< unsigned char > &grey, double *ts=nullptr)
bool open(const rs2::config &cfg=rs2::config())
VISP_EXPORT double measureTimeMs()