IMU.cpp
Go to the documentation of this file.
1 /*+-------------------------------------------------------------------------+
2  | MultiVehicle simulator (libmvsim) |
3  | |
4  | Copyright (C) 2014-2023 Jose Luis Blanco Claraco |
5  | Copyright (C) 2017 Borys Tymchenko (Odessa Polytechnic University) |
6  | Distributed under 3-clause BSD License |
7  | See COPYING |
8  +-------------------------------------------------------------------------+ */
9 
10 #include <mrpt/core/lock_helper.h>
11 #include <mrpt/opengl/stock_objects.h>
12 #include <mrpt/version.h>
13 #include <mvsim/Sensors/IMU.h>
14 #include <mvsim/VehicleBase.h>
15 #include <mvsim/World.h>
16 
17 #include "xml_utils.h"
18 
19 #if defined(MVSIM_HAS_ZMQ) && defined(MVSIM_HAS_PROTOBUF)
20 #include <mvsim/mvsim-msgs/ObservationLidar2D.pb.h>
21 #endif
22 
23 using namespace mvsim;
24 using namespace rapidxml;
25 
27  : SensorBase(parent)
28 {
29  IMU::loadConfigFrom(root);
30 }
31 
33 
35 {
38 
39  TParameterDefinitions params;
40  params["pose"] = TParamEntry("%pose2d_ptr3d", &obs_model_.sensorPose);
41  params["pose_3d"] = TParamEntry("%pose3d", &obs_model_.sensorPose);
42  params["sensor_period"] = TParamEntry("%lf", &sensor_period_);
43  params["angular_velocity_std_noise"] =
45  params["linear_acceleration_std_noise"] =
47 
48  // Parse XML params:
50 
51  // Pass params to the template obj:
52  obs_model_.sensorLabel = name_;
53 }
54 
56  const mrpt::optional_ref<mrpt::opengl::COpenGLScene>& viz,
57  [[maybe_unused]] const mrpt::optional_ref<mrpt::opengl::COpenGLScene>&
58  physical,
59  [[maybe_unused]] bool childrenOnly)
60 {
61  // 1st time?
62  if (!gl_sensor_origin_ && viz)
63  {
64  gl_sensor_origin_ = mrpt::opengl::CSetOfObjects::Create();
65 #if MRPT_VERSION >= 0x270
66  gl_sensor_origin_->castShadows(false);
67 #endif
69  mrpt::opengl::stock_objects::CornerXYZSimple(0.15f);
70 
72 
73  gl_sensor_origin_->setVisibility(false);
74  viz->get().insert(gl_sensor_origin_);
76  }
77 
78  const mrpt::poses::CPose2D& p = vehicle_.getCPose2D();
79 
80  if (gl_sensor_origin_) gl_sensor_origin_->setPose(p);
81  if (glCustomVisual_) glCustomVisual_->setPose(p + obs_model_.sensorPose);
82 }
83 
84 void IMU::simul_pre_timestep([[maybe_unused]] const TSimulContext& context) {}
85 
86 // Simulate sensor AFTER timestep, with the updated vehicle dynamical state:
88 {
90 
92  {
93  internal_simulate_imu(context);
94  }
95 }
96 
98 {
99  using mrpt::obs::CObservationIMU;
100 
101  auto tle = mrpt::system::CTimeLoggerEntry(world_->getTimeLogger(), "IMU");
102 
103  auto outObs = CObservationIMU::Create(obs_model_);
104 
105  outObs->timestamp = world_->get_simul_timestamp();
106  outObs->sensorLabel = name_;
107 
108  // angular velocity:
109  mrpt::math::TVector3D w(0.0, 0.0, vehicle_.getTwist().omega);
110  rng_.drawGaussian1DVector(w, 0.0, angularVelocityStdNoise_);
111 
112  outObs->set(mrpt::obs::IMU_WX, w.x);
113  outObs->set(mrpt::obs::IMU_WY, w.y);
114  outObs->set(mrpt::obs::IMU_WZ, w.z);
115 
116  // linear acceleration:
117  const auto g = mrpt::math::TVector3D(.0, .0, -world_->get_gravity());
118 
119  mrpt::math::TVector3D linAccNoise(0, 0, 0);
120  rng_.drawGaussian1DVector(linAccNoise, 0.0, linearAccelerationStdNoise_);
121 
122  const mrpt::math::TVector3D linAccLocal =
123  vehicle_.getPose().inverseComposePoint(
125  linAccNoise;
126 
127  outObs->set(mrpt::obs::IMU_X_ACC, linAccLocal.x);
128  outObs->set(mrpt::obs::IMU_Y_ACC, linAccLocal.y);
129  outObs->set(mrpt::obs::IMU_Z_ACC, linAccLocal.z);
130 
131  // Save:
132  {
133  std::lock_guard<std::mutex> csl(last_obs_cs_);
134  last_obs_ = std::move(outObs);
135  }
136 
137  // publish as generic Protobuf (mrpt serialized) object:
139 }
140 
142 {
143  using namespace std::string_literals;
144 
146 
147 #if defined(MVSIM_HAS_ZMQ) && defined(MVSIM_HAS_PROTOBUF)
148  // Topic:
149  if (!publishTopic_.empty())
150  {
151  // c.advertiseTopic<mvsim_msgs::ObservationIMU>(publishTopic_ +
152  // "_scan"s);
153  }
154 #endif
155 }
mrpt::obs::CObservationIMU::Ptr last_obs_
Definition: IMU.h:59
virtual ~IMU()
Definition: IMU.cpp:32
IMU(Simulable &parent, const rapidxml::xml_node< char > *root)
Definition: IMU.cpp:26
std::string publishTopic_
Definition: SensorBase.h:89
std::map< std::string, TParamEntry > TParameterDefinitions
void parse_xmlnode_children_as_param(const rapidxml::xml_node< char > &xml_node, const TParameterDefinitions &params, const std::map< std::string, std::string > &variableNamesValues={}, const char *functionNameContext="", mrpt::system::COutputLogger *logger=nullptr)
Definition: xml_utils.cpp:224
f
mrpt::math::TPose3D getPose() const
Definition: Simulable.cpp:438
std::mutex last_obs_cs_
Definition: IMU.h:56
void registerOnServer(mvsim::Client &c) override
Definition: IMU.cpp:141
mrpt::math::TTwist2D getTwist() const
Definition: Simulable.cpp:448
bool should_simulate_sensor(const TSimulContext &context)
Definition: SensorBase.cpp:283
std::map< std::string, std::string > varValues_
Filled in by SensorBase::loadConfigFrom()
Definition: SensorBase.h:92
mrpt::opengl::CSetOfObjects::Ptr gl_sensor_origin_
Definition: IMU.h:61
mrpt::Clock::time_point get_simul_timestamp() const
Definition: World.h:118
mrpt::random::CRandomGenerator rng_
Definition: IMU.h:64
static void RegisterSensorOriginViz(const std::shared_ptr< mrpt::opengl::CSetOfObjects > &o)
Definition: SensorBase.cpp:76
std::shared_ptr< mrpt::opengl::CSetOfObjects > glCustomVisual_
Definition: VisualObject.h:75
Simulable & vehicle_
The vehicle this sensor is attached to.
Definition: SensorBase.h:74
mrpt::obs::CObservationIMU obs_model_
Definition: IMU.h:54
void registerOnServer(mvsim::Client &c) override
Definition: SensorBase.cpp:237
mrpt::poses::CPose2D getCPose2D() const
Alternative to getPose()
Definition: Simulable.cpp:125
void reportNewObservation(const std::shared_ptr< mrpt::obs::CObservation > &obs, const TSimulContext &context)
Definition: SensorBase.cpp:160
virtual void simul_pre_timestep(const TSimulContext &context) override
Definition: IMU.cpp:84
double angularVelocityStdNoise_
[rad/s]
Definition: IMU.h:49
std::string name_
Definition: Simulable.h:120
virtual void simul_post_timestep(const TSimulContext &context)
Definition: Simulable.cpp:59
double sensor_period_
Definition: SensorBase.h:80
virtual void loadConfigFrom(const rapidxml::xml_node< char > *root)
Definition: SensorBase.cpp:249
mrpt::system::CTimeLogger & getTimeLogger()
Definition: World.h:320
virtual void simul_post_timestep(const TSimulContext &context) override
Definition: IMU.cpp:87
void internal_simulate_imu(const TSimulContext &context)
Definition: IMU.cpp:97
virtual void loadConfigFrom(const rapidxml::xml_node< char > *root) override
Definition: IMU.cpp:34
mrpt::opengl::CSetOfObjects::Ptr gl_sensor_origin_corner_
Definition: IMU.h:61
double linearAccelerationStdNoise_
[m/s²]
Definition: IMU.h:50
void make_sure_we_have_a_name(const std::string &prefix)
Assign a sensible default name/sensor label if none is provided:
Definition: SensorBase.cpp:271
void internalGuiUpdate(const mrpt::optional_ref< mrpt::opengl::COpenGLScene > &viz, [[maybe_unused]] const mrpt::optional_ref< mrpt::opengl::COpenGLScene > &physical, [[maybe_unused]] bool childrenOnly) override
Definition: IMU.cpp:55
double get_gravity() const
Definition: World.h:136
mrpt::math::TVector3D getLinearAcceleration() const
Definition: Simulable.cpp:456


mvsim
Author(s):
autogenerated on Tue Jul 4 2023 03:08:21