4#include <visp3/core/vpConfig.h>
17#if defined(VISP_HAVE_DISPLAY) && defined(VISP_HAVE_PUGIXML) && \
18 (defined(VISP_HAVE_V4L2) || defined(VISP_HAVE_DC1394) || defined(VISP_HAVE_CMU1394) || \
19 defined(VISP_HAVE_FLYCAPTURE) || defined(VISP_HAVE_REALSENSE2)) || defined(VISP_HAVE_OPENCV) && \
20 (((VISP_HAVE_OPENCV_VERSION < 0x030000) && defined(HAVE_OPENCV_HIGHGUI)) || \
21 ((VISP_HAVE_OPENCV_VERSION >= 0x030000) && defined(HAVE_OPENCV_VIDEOIO)))
23#ifdef VISP_HAVE_MODULE_SENSOR
24#include <visp3/sensor/vp1394CMUGrabber.h>
25#include <visp3/sensor/vp1394TwoGrabber.h>
26#include <visp3/sensor/vpFlyCaptureGrabber.h>
27#include <visp3/sensor/vpRealSense2.h>
28#include <visp3/sensor/vpV4l2Grabber.h>
30#include <visp3/core/vpXmlParserCamera.h>
31#include <visp3/gui/vpDisplayFactory.h>
33#if defined(VISP_HAVE_OPENCV) && (VISP_HAVE_OPENCV_VERSION < 0x030000) && defined(HAVE_OPENCV_HIGHGUI)
34#include <opencv2/highgui/highgui.hpp>
35#elif defined(VISP_HAVE_OPENCV) && (VISP_HAVE_OPENCV_VERSION >= 0x030000) && defined(HAVE_OPENCV_VIDEOIO)
36#include <opencv2/videoio/videoio.hpp>
39#include "pose_helper.h"
41void usage(
const char **argv,
int error)
43 std::cout <<
"Synopsis" << std::endl
45 <<
" [--camera-device <id>]"
46#if defined(VISP_HAVE_PUGIXML)
47 <<
" [--intrinsic <xmlfile>]"
48 <<
" [--camera-name <name>]"
50 <<
" [--square-width <width>]"
51 <<
" [--help, -h]" << std::endl
53 std::cout <<
"Description" << std::endl
54 <<
" Compute the pose of a square from its 4 corners." << std::endl
56 <<
" --camera-device <id>" << std::endl
57 <<
" Camera device id." << std::endl
58 <<
" Default: 0" << std::endl
60#if defined(VISP_HAVE_PUGIXML)
61 <<
" --intrinsic <xmlfile>" << std::endl
62 <<
" Camera intrinsic parameters file in xml format." << std::endl
63 <<
" Default: empty" << std::endl
65 <<
" --camera-name <name>" << std::endl
66 <<
" Camera name in the intrinsic parameters file in xml format." << std::endl
67 <<
" Default: empty" << std::endl
70 <<
" --square-width <width>" << std::endl
71 <<
" Square width in meter." << std::endl
72 <<
" Default: 0.12" << std::endl
74 <<
" --help, -h" << std::endl
75 <<
" Print this helper message." << std::endl
79 <<
"Example using default camera parameters and square size:\n"
80 <<
" " << argv[0] <<
"\n"
82 <<
"Example fully tuned for a 0.1m x 0.1m square:\n"
83 <<
" " << argv[0] <<
" --intrinsic camera.xml --camera-name Camera --square-width 0.1\n"
87 std::cout <<
"Error" << std::endl
89 <<
"Unsupported parameter " << argv[
error] << std::endl;
93int main(
int argc,
const char **argv)
95#ifdef ENABLE_VISP_NAMESPACE
98#if (VISP_CXX_STANDARD >= VISP_CXX_STANDARD_11)
99 std::shared_ptr<vpDisplay> display;
104 std::string opt_intrinsic_file;
105 std::string opt_camera_name;
106 double opt_square_width = 0.12;
109 for (
int i = 1;
i < argc;
i++) {
110 if (std::string(argv[i]) ==
"--camera-device" && i + 1 < argc) {
111 opt_device = atoi(argv[++i]);
113 else if (std::string(argv[i]) ==
"--intrinsic" && i + 1 < argc) {
114 opt_intrinsic_file = std::string(argv[++i]);
116 else if (std::string(argv[i]) ==
"--camera-name" && i + 1 < argc) {
117 opt_camera_name = std::string(argv[++i]);
119 else if (std::string(argv[i]) ==
"--square-width" && i + 1 < argc) {
120 opt_device = atoi(argv[++i]);
122 else if (std::string(argv[i]) ==
"--help" || std::string(argv[i]) ==
"-h") {
136#if defined(VISP_HAVE_V4L2)
138 std::ostringstream device;
139 device <<
"/dev/video" << opt_device;
140 std::cout <<
"Use Video 4 Linux grabber on device " << device.str() << std::endl;
144 cam.initPersProjWithoutDistortion(840, 840, I.getWidth() / 2, I.getHeight() / 2);
145#elif defined(VISP_HAVE_DC1394)
147 std::cout <<
"Use DC1394 grabber" << std::endl;
150 cam.initPersProjWithoutDistortion(840, 840, I.getWidth() / 2, I.getHeight() / 2);
151#elif defined(VISP_HAVE_CMU1394)
153 std::cout <<
"Use CMU1394 grabber" << std::endl;
156 cam.initPersProjWithoutDistortion(840, 840, I.getWidth() / 2, I.getHeight() / 2);
157#elif defined(VISP_HAVE_FLYCAPTURE)
159 std::cout <<
"Use FlyCapture grabber" << std::endl;
162 cam.initPersProjWithoutDistortion(840, 840, I.getWidth() / 2, I.getHeight() / 2);
163#elif defined(VISP_HAVE_REALSENSE2)
165 std::cout <<
"Use Realsense 2 grabber" << std::endl;
168 config.disable_stream(RS2_STREAM_DEPTH);
169 config.disable_stream(RS2_STREAM_INFRARED);
170 config.enable_stream(RS2_STREAM_COLOR, 640, 480, RS2_FORMAT_RGBA8, 30);
174 std::cout <<
"Read camera parameters from Realsense device" << std::endl;
176#elif ((VISP_HAVE_OPENCV_VERSION < 0x030000) && defined(HAVE_OPENCV_HIGHGUI))|| ((VISP_HAVE_OPENCV_VERSION >= 0x030000) && defined(HAVE_OPENCV_VIDEOIO))
177 std::cout <<
"Use OpenCV grabber on device " << opt_device << std::endl;
178 cv::VideoCapture g(opt_device);
180 std::cout <<
"Failed to open the camera" << std::endl;
186 cam.initPersProjWithoutDistortion(840, 840, I.getWidth() / 2, I.getHeight() / 2);
190#if defined(VISP_HAVE_PUGIXML)
193 if (!opt_intrinsic_file.empty() && !opt_camera_name.empty()) {
194 std::cout <<
"Intrinsic file: " << opt_intrinsic_file << std::endl;
195 std::cout <<
"Camera name : " << opt_camera_name << std::endl;
198 std::cout <<
"Succeed to read camera parameters from xml file" << std::endl;
201 std::cout <<
"Unable to read camera parameters from xml file" << std::endl;
206 std::cout <<
"Square width : " << opt_square_width << std::endl;
207 std::cout <<
cam << std::endl;
212 std::vector<vpDot2> dot(4);
213 std::vector<vpPoint> point;
214 std::vector<vpImagePoint> ip;
215 double L = opt_square_width / 2.;
216 point.push_back(
vpPoint(-L, -L, 0));
217 point.push_back(
vpPoint(L, -L, 0));
218 point.push_back(
vpPoint(L, L, 0));
219 point.push_back(
vpPoint(-L, L, 0));
221#if (VISP_CXX_STANDARD >= VISP_CXX_STANDARD_11)
228 bool apply_cv =
false;
234#if defined(VISP_HAVE_V4L2) || defined(VISP_HAVE_DC1394) || defined(VISP_HAVE_CMU1394) || \
235 defined(VISP_HAVE_FLYCAPTURE) || defined(VISP_HAVE_REALSENSE2)
237#elif ((VISP_HAVE_OPENCV_VERSION < 0x030000) && defined(HAVE_OPENCV_HIGHGUI))|| ((VISP_HAVE_OPENCV_VERSION >= 0x030000) && defined(HAVE_OPENCV_VIDEOIO))
244 ip = track(I, dot, init_cv);
245 computePose(point, ip, cam, init_cv, cMo);
252 std::stringstream ss;
253 ss <<
"Translation: " << std::setprecision(5) << pose[0] <<
" " << pose[1] <<
" " << pose[2] <<
" [m]";
256 ss <<
"Rotation tu: " << std::setprecision(4) <<
vpMath::deg(pose[3]) <<
" " <<
vpMath::deg(pose[4]) <<
" "
262 std::cout <<
"Computer vision failure." << std::endl;
284 std::stringstream ss;
292 std::cout <<
"Catch an exception: " <<
e.getMessage() << std::endl;
294#if (VISP_CXX_STANDARD < VISP_CXX_STANDARD_11)
295 if (display !=
nullptr) {
305 std::cout <<
"There are missing 3rd parties to run this tutorial" << std::endl;
Firewire cameras video capture based on CMU 1394 Digital Camera SDK.
void open(vpImage< unsigned char > &I)
Class for firewire ieee1394 video devices using libdc1394-2.x api.
void open(vpImage< unsigned char > &I)
Generic class defining intrinsic camera parameters.
@ perspectiveProjWithDistortion
Perspective projection with distortion model.
@ perspectiveProjWithoutDistortion
Perspective projection without distortion model.
static const vpColor none
Class that defines generic functionalities for display.
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.
void open(vpImage< unsigned char > &I)
Implementation of an homogeneous matrix and operations on such kind of matrices.
static void convert(const vpImage< unsigned char > &src, vpImage< vpRGBa > &dest)
Definition of the vpImage class member functions.
static double deg(double rad)
Class that defines a 3D point in the object frame and allows forward projection of a 3D point in the ...
Implementation of a pose vector and operations on poses.
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())
Class that is a wrapper over the Video4Linux2 (V4L2) driver.
void open(vpImage< unsigned char > &I)
void setScale(unsigned scale=vpV4l2Grabber::DEFAULT_SCALE)
void setDevice(const std::string &devname)
XML parser to load and save intrinsic camera parameters.
std::shared_ptr< vpDisplay > createDisplay()
Return a smart pointer vpDisplay specialization if a GUI library is available or nullptr otherwise.
vpDisplay * allocateDisplay()
Return a newly allocated vpDisplay specialization if a GUI library is available or nullptr otherwise.
VISP_EXPORT double measureTimeMs()