MRPT  2.0.4
RawlogGrabberApp.h
Go to the documentation of this file.
1 /* +------------------------------------------------------------------------+
2  | Mobile Robot Programming Toolkit (MRPT) |
3  | https://www.mrpt.org/ |
4  | |
5  | Copyright (c) 2005-2020, Individual contributors, see AUTHORS file |
6  | See: https://www.mrpt.org/Authors - All rights reserved. |
7  | Released under BSD License. See: https://www.mrpt.org/License |
8  +------------------------------------------------------------------------+ */
9 #pragma once
10 
14 #include <mrpt/obs/CSensoryFrame.h>
15 #include <mrpt/obs/obs_frwds.h>
17 #include <atomic>
18 #include <mutex>
19 
20 namespace mrpt::apps
21 {
22 /** RawlogGrabber application wrapper class.
23  *
24  * \note If the environment variable `MRPT_HWDRIVERS_VERBOSE=1` is defined
25  * before calling initialize(), verbosity level will be changed to LVL_DEBUG.
26  *
27  * \ingroup mrpt_apps_grp
28  */
30 {
31  public:
33 
34  /** @name Main API
35  * @{ */
36 
37  /** Initializes the application from CLI parameters. Refer to the manpage of
38  * rawlog-grabber. Throws on errors.
39  */
40  void initialize(int argc, const char** argv);
41 
42  inline void initialize(int argc, char** argv)
43  {
44  initialize(argc, const_cast<const char**>(argv));
45  }
46 
47  /** Runs with the current parameter set. Throws on errors. */
48  void run();
49 
50  bool isRunning() const
51  {
52  m_isRunningMtx.lock();
53  const auto r = m_isRunning;
54  m_isRunningMtx.unlock();
55  return r;
56  }
57 
58  /** @} */
59 
60  /** @name Parameters and options. See: initialize()
61  * @{ */
62  /** Acquire this mutex if changing parameters *while* the app is running */
63  std::mutex params_mtx;
64 
65  /** If >0, run() will return after this period (in seconds) */
66  double run_for_seconds = 0;
67 
68  /** If enabled (default), exceptions in sensor threads will be reported to
69  * std::cerr */
71 
72  /** Populated in initialize(). Can be replaced or manipulated by the user
73  * after that and before run() to change the parameters loaded from INI
74  * file. */
76 
77  /** @} */
78 
79  /** @name Outputs and result variables
80  * @{ */
81  /** Acquire this mutex if reading these output variables *while* the app is
82  * running */
83  std::mutex results_mtx;
84 
85  std::string rawlog_filename; //!< The generated .rawlog file
86  std::size_t rawlog_saved_objects = 0; //!< Counter of saved objects
87 
88  /** @} */
89 
90  void SensorThread(std::string sensor_label);
91 
92  private:
93  using TListObservations =
95 
96  void dump_verbose_info(
98  void dump_verbose_info(const mrpt::obs::CSensoryFrame& sf) const;
100  void dump_IMU_info(const mrpt::obs::CObservationIMU& o) const;
101 
102  void process_observations_for_sf(const TListObservations& list_obs);
104 
105  void runImpl();
106 
109 
110  std::atomic_bool allThreadsMustExit = false;
111  mutable std::mutex m_isRunningMtx;
112  bool m_isRunning = false;
113 
114  /** Directory where to save externally stored images, only for
115  * CCameraSensor's. */
117 
119 
121  double SF_max_time_span = 0.25; // Seconds
122 };
123 
124 } // namespace mrpt::apps
This class implements a config file-like interface over a memory-stored string list.
mrpt::serialization::CArchive * m_out_arch_ptr
std::mutex results_mtx
Acquire this mutex if reading these output variables while the app is running.
TListObservations m_global_list_obs
std::string m_rawlog_ext_imgs_dir
Directory where to save externally stored images, only for CCameraSensor&#39;s.
This class stores measurements from an Inertial Measurement Unit (IMU) (attitude estimation, raw gyroscope and accelerometer values), altimeters or magnetometers.
mrpt::hwdrivers::CGenericSensor::TListObservations TListObservations
bool show_sensor_thread_exceptions
If enabled (default), exceptions in sensor threads will be reported to std::cerr. ...
void dump_verbose_info(const mrpt::serialization::CSerializable::Ptr &o) const
void initialize(int argc, const char **argv)
Initializes the application from CLI parameters.
Versatile class for consistent logging and management of output messages.
std::string rawlog_filename
The generated .rawlog file.
void run()
Runs with the current parameter set.
Declares a class for storing a "sensory frame", a set of "observations" taken by the robot approximat...
Definition: CSensoryFrame.h:51
std::atomic_bool allThreadsMustExit
void SensorThread(std::string sensor_label)
void process_observations_for_nonsf(const TListObservations &list_obs)
double run_for_seconds
If >0, run() will return after this period (in seconds)
const char * argv[]
Virtual base class for "archives": classes abstracting I/O streams.
Definition: CArchive.h:54
std::multimap< mrpt::system::TTimeStamp, mrpt::serialization::CSerializable::Ptr > TListObservations
void process_observations_for_sf(const TListObservations &list_obs)
std::size_t rawlog_saved_objects
Counter of saved objects.
const int argc
std::mutex params_mtx
Acquire this mutex if changing parameters while the app is running.
void dump_GPS_mode_info(const mrpt::obs::CObservationGPS &o) const
This class stores messages from GNSS or GNSS+IMU devices, from consumer-grade inexpensive GPS receive...
mrpt::config::CConfigFileMemory params
Populated in initialize().
void dump_IMU_info(const mrpt::obs::CObservationIMU &o) const
RawlogGrabber application wrapper class.
void initialize(int argc, char **argv)
mrpt::obs::CSensoryFrame m_curSF



Page generated by Doxygen 1.8.14 for MRPT 2.0.4 Git: 33de1d0ad Sat Jun 20 11:02:42 2020 +0200 at sáb jun 20 17:35:17 CEST 2020