Simulates the kinematics of a differential-driven planar mobile robot/vehicle, including odometry errors and dynamics limitations.
Definition at line 22 of file CVehicleSimul_DiffDriven.h.
#include <mrpt/kinematics/CVehicleSimul_DiffDriven.h>

| Public Types | |
| typedef CVehicleVelCmd_DiffDriven | kinematic_cmd_t | 
| Public Member Functions | |
| CVehicleSimul_DiffDriven () | |
| virtual | ~CVehicleSimul_DiffDriven () | 
| void | setDelayModelParams (double TAU_delay_sec=1.8, double CMD_delay_sec=0.) | 
| Change the model of delays used for the orders sent to the robot.  More... | |
| void | setV (double v) | 
| void | setW (double w) | 
| double | getV () | 
| double | getW () | 
| void | movementCommand (double lin_vel, double ang_vel) | 
| Used to command the robot a desired movement:  More... | |
| void | sendVelCmd (const CVehicleVelCmd &cmd_vel) MRPT_OVERRIDE | 
| Sends a velocity command to the robot.  More... | |
| CVehicleVelCmdPtr | getVelCmdType () const MRPT_OVERRIDE | 
| Gets an empty velocity command object that can be queried to find out the number of velcmd components,...  More... | |
| Kinematic simulation and control interface | |
| void | simulateOneTimeStep (const double dt) | 
| Runs the simulator during "dt" seconds.  More... | |
| const mrpt::math::TPose2D & | getCurrentGTPose () const | 
| Returns the instantaneous, ground truth pose in world coordinates.  More... | |
| void | setCurrentGTPose (const mrpt::math::TPose2D &pose) | 
| Brute-force move robot to target coordinates ("teleport")  More... | |
| const mrpt::math::TPose2D & | getCurrentOdometricPose () const | 
| Returns the current pose according to (noisy) odometry.  More... | |
| template<typename T > | |
| void | setCurrentOdometricPose (const T &pose) | 
| Brute-force overwrite robot odometry.  More... | |
| const mrpt::math::TTwist2D & | getCurrentGTVel () const | 
| Returns the instantaneous, ground truth velocity vector (vx,vy,omega) in world coordinates.  More... | |
| mrpt::math::TTwist2D | getCurrentGTVelLocal () const | 
| Returns the instantaneous, ground truth velocity vector (vx,vy,omega) in the robot local frame.  More... | |
| const mrpt::math::TTwist2D & | getCurrentOdometricVel () const | 
| Returns the instantaneous, odometric velocity vector (vx,vy,omega) in world coordinates.  More... | |
| mrpt::math::TTwist2D | getCurrentOdometricVelLocal () const | 
| Returns the instantaneous, odometric velocity vector (vx,vy,omega) in the robot local frame.  More... | |
| double | getTime () const | 
| Get the current simulation time.  More... | |
| void | setOdometryErrors (bool enabled, double Ax_err_bias=1e-3, double Ax_err_std=10e-3, double Ay_err_bias=1e-3, double Ay_err_std=10e-3, double Aphi_err_bias=mrpt::utils::DEG2RAD(1e-3), double Aphi_err_std=mrpt::utils::DEG2RAD(10e-3)) | 
| Enable/Disable odometry errors.  More... | |
| void | resetStatus () | 
| void | resetTime () | 
| Reset all simulator variables to 0 (except the simulation time).  More... | |
| Protected Attributes | |
| double | m_firmware_control_period | 
| The period at which the low-level controller updates velocities (Default: 0.5 ms)  More... | |
| bool | m_use_odo_error | 
| Whether to corrupt odometry with noise.  More... | |
| double | m_Ax_err_bias | 
| double | m_Ax_err_std | 
| double | m_Ay_err_bias | 
| double | m_Ay_err_std | 
| double | m_Aphi_err_bias | 
| double | m_Aphi_err_std | 
| State vector | |
| double | m_time | 
| simulation running time  More... | |
| mrpt::math::TPose2D | m_GT_pose | 
| ground truth pose in world coordinates.  More... | |
| mrpt::math::TTwist2D | m_GT_vel | 
| Velocity in (x,y,omega)  More... | |
| mrpt::math::TTwist2D | m_odometric_vel | 
| Velocity in (x,y,omega)  More... | |
| mrpt::math::TPose2D | m_odometry | 
| Private Member Functions | |
| void | internal_simulControlStep (const double dt) MRPT_OVERRIDE | 
| void | internal_clear () MRPT_OVERRIDE | 
| Resets all pending cmds.  More... | |
| Private Attributes | |
| double | m_v | 
| double | m_w | 
| lin & angular velocity in the robot local frame.  More... | |
| double | Command_Time | 
| Dynamic limitations of the robot.  More... | |
| double | Command_v | 
| double | Command_w | 
| double | Command_v0 | 
| double | Command_w0 | 
| double | cTAU | 
| The time-constants for the first order low-pass filter for the velocities changes.  More... | |
| double | cDELAY | 
| The delay constant for the velocities changes.  More... | |
Definition at line 25 of file CVehicleSimul_DiffDriven.h.
| CVehicleSimul_DiffDriven::CVehicleSimul_DiffDriven | ( | ) | 
Definition at line 17 of file CVehicleSimul_DiffDriven.cpp.
References mrpt::kinematics::CVehicleSimulVirtualBase::resetStatus(), and mrpt::kinematics::CVehicleSimulVirtualBase::resetTime().
| 
 | virtual | 
Definition at line 24 of file CVehicleSimul_DiffDriven.cpp.
| 
 | inlineinherited | 
Returns the instantaneous, ground truth pose in world coordinates.
Definition at line 42 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::nav::CRobot2NavInterfaceForSimulator_Holo::getCurrentPoseAndSpeeds(), mrpt::nav::CRobot2NavInterfaceForSimulator_DiffDriven::getCurrentPoseAndSpeeds(), mrpt::utils::CRobotSimulator::getPHI(), mrpt::utils::CRobotSimulator::getRealPose(), mrpt::utils::CRobotSimulator::getX(), mrpt::utils::CRobotSimulator::getY(), and run_rnav_test().
| 
 | inlineinherited | 
Returns the instantaneous, ground truth velocity vector (vx,vy,omega) in world coordinates.
Definition at line 54 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::nav::CRobot2NavInterfaceForSimulator_Holo::getCurrentPoseAndSpeeds(), and mrpt::nav::CRobot2NavInterfaceForSimulator_DiffDriven::getCurrentPoseAndSpeeds().
| 
 | inherited | 
Returns the instantaneous, ground truth velocity vector (vx,vy,omega) in the robot local frame.
Definition at line 88 of file CVehicleSimulVirtualBase.cpp.
References mrpt::kinematics::CVehicleSimulVirtualBase::m_GT_pose, mrpt::kinematics::CVehicleSimulVirtualBase::m_GT_vel, mrpt::math::TPose2D::phi, and mrpt::math::TTwist2D::rotate().
| 
 | inlineinherited | 
Returns the current pose according to (noisy) odometry.
Definition at line 48 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::nav::CRobot2NavInterfaceForSimulator_Holo::getCurrentPoseAndSpeeds(), mrpt::nav::CRobot2NavInterfaceForSimulator_DiffDriven::getCurrentPoseAndSpeeds(), and mrpt::utils::CRobotSimulator::getOdometry().
| 
 | inlineinherited | 
Returns the instantaneous, odometric velocity vector (vx,vy,omega) in world coordinates.
Definition at line 59 of file CVehicleSimulVirtualBase.h.
| 
 | inherited | 
Returns the instantaneous, odometric velocity vector (vx,vy,omega) in the robot local frame.
Definition at line 95 of file CVehicleSimulVirtualBase.cpp.
References mrpt::kinematics::CVehicleSimulVirtualBase::m_odometric_vel, mrpt::kinematics::CVehicleSimulVirtualBase::m_odometry, mrpt::math::TPose2D::phi, and mrpt::math::TTwist2D::rotate().
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | inlineinherited | 
Get the current simulation time.
Definition at line 65 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::nav::CRobot2NavInterfaceForSimulator_Holo::getNavigationTime(), mrpt::nav::CRobot2NavInterfaceForSimulator_DiffDriven::getNavigationTime(), mrpt::utils::CRobotSimulator::getT(), mrpt::nav::CRobot2NavInterfaceForSimulator_Holo::resetNavigationTimer(), and mrpt::nav::CRobot2NavInterfaceForSimulator_DiffDriven::resetNavigationTimer().
| 
 | inline | 
Definition at line 39 of file CVehicleSimul_DiffDriven.h.
| 
 | inlinevirtual | 
Gets an empty velocity command object that can be queried to find out the number of velcmd components,...
Implements mrpt::kinematics::CVehicleSimulVirtualBase.
Definition at line 53 of file CVehicleSimul_DiffDriven.h.
| 
 | inline | 
Definition at line 40 of file CVehicleSimul_DiffDriven.h.
| 
 | privatevirtual | 
Resets all pending cmds.
Implements mrpt::kinematics::CVehicleSimulVirtualBase.
Definition at line 28 of file CVehicleSimul_DiffDriven.cpp.
References Command_Time, Command_v, Command_w, m_v, and m_w.
| 
 | privatevirtual | 
Implements mrpt::kinematics::CVehicleSimulVirtualBase.
Definition at line 36 of file CVehicleSimul_DiffDriven.cpp.
References cDELAY, Command_Time, Command_v, Command_v0, Command_w, Command_w0, cTAU, mrpt::kinematics::CVehicleSimulVirtualBase::m_odometric_vel, mrpt::kinematics::CVehicleSimulVirtualBase::m_odometry, mrpt::kinematics::CVehicleSimulVirtualBase::m_time, m_v, m_w, mrpt::math::TTwist2D::omega, mrpt::math::TPose2D::phi, mrpt::math::TTwist2D::vx, and mrpt::math::TTwist2D::vy.
| void CVehicleSimul_DiffDriven::movementCommand | ( | double | lin_vel, | 
| double | ang_vel | ||
| ) | 
Used to command the robot a desired movement:
| lin_vel | Linar velocity (m/s) | 
| ang_vel | Angular velocity (rad/s) | 
Definition at line 67 of file CVehicleSimul_DiffDriven.cpp.
References Command_Time, Command_v, Command_v0, Command_w, Command_w0, mrpt::kinematics::CVehicleSimulVirtualBase::m_time, m_v, and m_w.
| 
 | inherited | 
Definition at line 74 of file CVehicleSimulVirtualBase.cpp.
References mrpt::kinematics::CVehicleSimulVirtualBase::internal_clear(), mrpt::kinematics::CVehicleSimulVirtualBase::m_GT_pose, mrpt::kinematics::CVehicleSimulVirtualBase::m_GT_vel, mrpt::kinematics::CVehicleSimulVirtualBase::m_odometric_vel, and mrpt::kinematics::CVehicleSimulVirtualBase::m_odometry.
Referenced by CVehicleSimul_DiffDriven(), and mrpt::kinematics::CVehicleSimul_Holo::CVehicleSimul_Holo().
| 
 | inherited | 
Reset all simulator variables to 0 (except the simulation time).
Definition at line 83 of file CVehicleSimulVirtualBase.cpp.
References mrpt::kinematics::CVehicleSimulVirtualBase::m_time.
Referenced by CVehicleSimul_DiffDriven(), and mrpt::kinematics::CVehicleSimul_Holo::CVehicleSimul_Holo().
| 
 | inlinevirtual | 
Sends a velocity command to the robot.
The number of components and their meaning depends on the vehicle-kinematics derived class
Implements mrpt::kinematics::CVehicleSimulVirtualBase.
Definition at line 48 of file CVehicleSimul_DiffDriven.h.
References mrpt::kinematics::CVehicleVelCmd_DiffDriven::ang_vel, ASSERTMSG_, and mrpt::kinematics::CVehicleVelCmd_DiffDriven::lin_vel.
Referenced by mrpt::nav::CRobot2NavInterfaceForSimulator_DiffDriven::changeSpeeds(), and mrpt::nav::CRobot2NavInterfaceForSimulator_DiffDriven::stop().
| 
 | inherited | 
Brute-force move robot to target coordinates ("teleport")
Definition at line 27 of file CVehicleSimulVirtualBase.cpp.
References mrpt::kinematics::CVehicleSimulVirtualBase::m_GT_pose.
Referenced by mrpt::utils::CRobotSimulator::setRealPose().
| 
 | inlineinherited | 
Brute-force overwrite robot odometry.
Definition at line 51 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::utils::CRobotSimulator::resetOdometry(), and mrpt::utils::CRobotSimulator::setOdometry().
| 
 | inline | 
Change the model of delays used for the orders sent to the robot.
Definition at line 31 of file CVehicleSimul_DiffDriven.h.
Referenced by mrpt::utils::CRobotSimulator::CRobotSimulator().
| 
 | inlineinherited | 
Enable/Disable odometry errors.
Errors in odometry are 1 sigma Gaussian values per second
Definition at line 74 of file CVehicleSimulVirtualBase.h.
| 
 | inline | 
Definition at line 36 of file CVehicleSimul_DiffDriven.h.
| 
 | inline | 
Definition at line 37 of file CVehicleSimul_DiffDriven.h.
| 
 | inherited | 
Runs the simulator during "dt" seconds.
It will be split into periods of "m_firmware_control_period".
Definition at line 32 of file CVehicleSimulVirtualBase.cpp.
References mrpt::random::CRandomGenerator::drawGaussian1D_normalized(), mrpt::kinematics::CVehicleSimulVirtualBase::getCurrentOdometricVelLocal(), mrpt::kinematics::CVehicleSimulVirtualBase::internal_simulControlStep(), mrpt::kinematics::CVehicleSimulVirtualBase::m_Aphi_err_bias, mrpt::kinematics::CVehicleSimulVirtualBase::m_Aphi_err_std, mrpt::kinematics::CVehicleSimulVirtualBase::m_Ax_err_bias, mrpt::kinematics::CVehicleSimulVirtualBase::m_Ax_err_std, mrpt::kinematics::CVehicleSimulVirtualBase::m_Ay_err_bias, mrpt::kinematics::CVehicleSimulVirtualBase::m_Ay_err_std, mrpt::kinematics::CVehicleSimulVirtualBase::m_firmware_control_period, mrpt::kinematics::CVehicleSimulVirtualBase::m_GT_pose, mrpt::kinematics::CVehicleSimulVirtualBase::m_GT_vel, mrpt::kinematics::CVehicleSimulVirtualBase::m_odometric_vel, mrpt::kinematics::CVehicleSimulVirtualBase::m_odometry, mrpt::kinematics::CVehicleSimulVirtualBase::m_time, mrpt::kinematics::CVehicleSimulVirtualBase::m_use_odo_error, mrpt::math::TTwist2D::omega, mrpt::math::TPose2D::phi, mrpt::random::randomGenerator, mrpt::math::TTwist2D::rotate(), mrpt::math::TTwist2D::vx, mrpt::math::TTwist2D::vy, mrpt::math::wrapToPiInPlace(), and mrpt::math::TPose2D::x.
Referenced by run_rnav_test(), and mrpt::utils::CRobotSimulator::simulateInterval().
| 
 | private | 
The delay constant for the velocities changes.
Definition at line 71 of file CVehicleSimul_DiffDriven.h.
Referenced by internal_simulControlStep().
| 
 | private | 
Dynamic limitations of the robot.
Approximation to non-infinity motor forces: A first order low-pass filter, using: Command_Time: Time "t" when the last order was received. Command_v, Command_w: The user-desired velocities. Command_v0, Command_w0: Actual robot velocities at the moment of user request.
Definition at line 66 of file CVehicleSimul_DiffDriven.h.
Referenced by internal_clear(), internal_simulControlStep(), and movementCommand().
| 
 | private | 
Definition at line 66 of file CVehicleSimul_DiffDriven.h.
Referenced by internal_clear(), internal_simulControlStep(), and movementCommand().
| 
 | private | 
Definition at line 66 of file CVehicleSimul_DiffDriven.h.
Referenced by internal_simulControlStep(), and movementCommand().
| 
 | private | 
Definition at line 66 of file CVehicleSimul_DiffDriven.h.
Referenced by internal_clear(), internal_simulControlStep(), and movementCommand().
| 
 | private | 
Definition at line 66 of file CVehicleSimul_DiffDriven.h.
Referenced by internal_simulControlStep(), and movementCommand().
| 
 | private | 
The time-constants for the first order low-pass filter for the velocities changes.
Definition at line 70 of file CVehicleSimul_DiffDriven.h.
Referenced by internal_simulControlStep().
| 
 | protectedinherited | 
Definition at line 112 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
Definition at line 112 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
Definition at line 110 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
Definition at line 110 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
Definition at line 111 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
Definition at line 111 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
The period at which the low-level controller updates velocities (Default: 0.5 ms)
Definition at line 107 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
ground truth pose in world coordinates.
Definition at line 102 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::getCurrentGTVelLocal(), mrpt::kinematics::CVehicleSimulVirtualBase::resetStatus(), mrpt::kinematics::CVehicleSimulVirtualBase::setCurrentGTPose(), and mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
Velocity in (x,y,omega)
Definition at line 103 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::getCurrentGTVelLocal(), mrpt::kinematics::CVehicleSimulVirtualBase::resetStatus(), and mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
Velocity in (x,y,omega)
Definition at line 104 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::getCurrentOdometricVelLocal(), mrpt::kinematics::CVehicleSimul_Holo::internal_simulControlStep(), internal_simulControlStep(), mrpt::kinematics::CVehicleSimulVirtualBase::resetStatus(), mrpt::kinematics::CVehicleSimul_Holo::sendVelRampCmd(), and mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
Definition at line 105 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::getCurrentOdometricVelLocal(), mrpt::kinematics::CVehicleSimul_Holo::internal_simulControlStep(), internal_simulControlStep(), mrpt::kinematics::CVehicleSimulVirtualBase::resetStatus(), and mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
simulation running time
Definition at line 101 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimul_Holo::internal_simulControlStep(), internal_simulControlStep(), movementCommand(), mrpt::kinematics::CVehicleSimulVirtualBase::resetTime(), mrpt::kinematics::CVehicleSimul_Holo::sendVelRampCmd(), and mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | protectedinherited | 
Whether to corrupt odometry with noise.
Definition at line 109 of file CVehicleSimulVirtualBase.h.
Referenced by mrpt::kinematics::CVehicleSimulVirtualBase::simulateOneTimeStep().
| 
 | private | 
Definition at line 58 of file CVehicleSimul_DiffDriven.h.
Referenced by internal_clear(), internal_simulControlStep(), and movementCommand().
| 
 | private | 
lin & angular velocity in the robot local frame.
Definition at line 58 of file CVehicleSimul_DiffDriven.h.
Referenced by internal_clear(), internal_simulControlStep(), and movementCommand().
| Page generated by Doxygen 1.8.14 for MRPT 1.5.9 Git: 690a4699f Wed Apr 15 19:29:53 2020 +0200 at miƩ abr 15 19:30:12 CEST 2020 |