Visual Servoing Platform  version 3.6.1 under development (2024-11-15)
SickLDMRS-Acq.cpp
1 /****************************************************************************
2  *
3  * ViSP, open source Visual Servoing Platform software.
4  * Copyright (C) 2005 - 2023 by Inria. All rights reserved.
5  *
6  * This software is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  * See the file LICENSE.txt at the root directory of this source
11  * distribution for additional information about the GNU GPL.
12  *
13  * For using ViSP with software that can not be combined with the GNU
14  * GPL, please contact Inria about acquiring a ViSP Professional
15  * Edition License.
16  *
17  * See https://visp.inria.fr for more information.
18  *
19  * This software was developed at:
20  * Inria Rennes - Bretagne Atlantique
21  * Campus Universitaire de Beaulieu
22  * 35042 Rennes Cedex
23  * France
24  *
25  * If you have questions regarding the use of this file, please contact
26  * Inria at visp@inria.fr
27  *
28  * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
29  * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
30  *
31  * Description:
32  * Sick LD-MRS laser driver.
33  *
34 *****************************************************************************/
35 
46 #include <visp3/core/vpConfig.h>
47 #include <visp3/core/vpDebug.h>
48 #include <visp3/io/vpParseArgv.h>
49 #include <visp3/sensor/vpSickLDMRS.h>
50 
51 #if !defined(_WIN32) && (defined(__unix__) || defined(__unix) || (defined(__APPLE__) && defined(__MACH__)))
52 
53 int main()
54 {
55 #ifdef ENABLE_VISP_NAMESPACE
56  using namespace VISP_NAMESPACE_NAME;
57 #endif
58 
59  try {
60  vpSickLDMRS laser;
61  std::string ip = "131.254.12.119";
62 
63  laser.setIpAddress(ip);
64  laser.setup();
65  unsigned long int iter = 0;
66 
67  for (;;) {
68  double t1 = vpTime::measureTimeMs();
69  vpLaserScan laserscan[4];
70  if (laser.measure(laserscan) == false)
71  continue;
72 
73  iter++;
74  std::cout << "iter: " << iter << " time: " << vpTime::measureTimeMs() - t1 << " ms" << std::endl;
75  }
76  return EXIT_SUCCESS;
77  }
78  catch (const vpException &e) {
79  std::cout << "Catch an exception: " << e << std::endl;
80  return EXIT_FAILURE;
81  }
82 }
83 
84 #else // #ifdef UNIX
85 int main()
86 {
87  std::cout << "This example is only working on unix-like platforms \n"
88  << "since the Sick LD-MRS driver was not ported to Windows." << std::endl;
89 
90  return EXIT_SUCCESS;
91  }
92 #endif // #ifdef UNIX
error that can be emitted by ViSP classes.
Definition: vpException.h:60
Implements a laser scan data structure that contains especially the list of scanned points that have ...
Definition: vpLaserScan.h:65
VISP_EXPORT double measureTimeMs()