MRPT
2.0.1
|
CRobot2NavInterface implemented for a simulator object based on mrpt::kinematics::CVehicleSimul_DiffDriven Only senseObstacles()
remains virtual for the user to implement it.
Definition at line 111 of file CRobot2NavInterfaceForSimulator.h.
#include <mrpt/nav/reactive/CRobot2NavInterfaceForSimulator.h>
Public Member Functions | |
CRobot2NavInterfaceForSimulator_DiffDriven (mrpt::kinematics::CVehicleSimul_DiffDriven &simul) | |
bool | getCurrentPoseAndSpeeds (mrpt::math::TPose2D &curPose, mrpt::math::TTwist2D &curVel, mrpt::system::TTimeStamp ×tamp, mrpt::math::TPose2D &curOdometry, std::string &frame_id) override |
Get the current pose and velocity of the robot. More... | |
bool | changeSpeeds (const mrpt::kinematics::CVehicleVelCmd &vel_cmd) override |
Sends a velocity command to the robot. More... | |
bool | stop (bool isEmergencyStop) override |
Stop the robot right now. More... | |
mrpt::kinematics::CVehicleVelCmd::Ptr | getStopCmd () override |
Gets the emergency stop command for the current robot. More... | |
mrpt::kinematics::CVehicleVelCmd::Ptr | getEmergencyStopCmd () override |
Gets the emergency stop command for the current robot. More... | |
double | getNavigationTime () override |
See CRobot2NavInterface::getNavigationTime(). More... | |
void | resetNavigationTimer () override |
See CRobot2NavInterface::resetNavigationTimer() More... | |
virtual bool | changeSpeedsNOP () |
Just like changeSpeeds(), but will be called when the last velocity command is still the preferred solution, so there is no need to change that past command. More... | |
virtual mrpt::kinematics::CVehicleVelCmd::Ptr | getAlignCmd (const double relative_heading_radians) |
Gets a motion command to make the robot to align with a given relative heading, without translating. More... | |
virtual bool | startWatchdog (float T_ms) |
Start the watchdog timer of the robot platform, if any, for maximum expected delay between consecutive calls to changeSpeeds(). More... | |
virtual bool | stopWatchdog () |
Stop the watchdog timer. More... | |
virtual bool | senseObstacles (mrpt::maps::CSimplePointsMap &obstacles, mrpt::system::TTimeStamp ×tamp)=0 |
Return the current set of obstacle points, as seen from the local coordinate frame of the robot. More... | |
Navigation event callbacks | |
virtual void | sendNavigationStartEvent () |
Callback: Start of navigation command. More... | |
virtual void | sendNavigationEndEvent () |
Callback: End of navigation command (reach of single goal, or final waypoint of waypoint list) More... | |
virtual void | sendWaypointReachedEvent (int waypoint_index, bool reached_nSkipped) |
Callback: Reached an intermediary waypoint in waypoint list navigation. More... | |
virtual void | sendNewWaypointTargetEvent (int waypoint_index) |
Callback: Heading towards a new intermediary/final waypoint in waypoint list navigation. More... | |
virtual void | sendNavigationEndDueToErrorEvent () |
Callback: Error asking sensory data from robot or sending motor commands. More... | |
virtual void | sendWaySeemsBlockedEvent () |
Callback: No progression made towards target for a predefined period of time. More... | |
virtual void | sendApparentCollisionEvent () |
Callback: Apparent collision event (i.e. More... | |
virtual void | sendCannotGetCloserToBlockedTargetEvent () |
Callback: Target seems to be blocked by an obstacle. More... | |
Static Public Member Functions | |
static std::array< mrpt::system::TConsoleColor, NUMBER_OF_VERBOSITY_LEVELS > & | logging_levels_to_colors () |
Map from VerbosityLevels to their corresponding mrpt::system::TConsoleColor. More... | |
static std::array< std::string, NUMBER_OF_VERBOSITY_LEVELS > & | logging_levels_to_names () |
Map from VerbosityLevels to their corresponding names. More... | |
Protected Attributes | |
VerbosityLevel | m_min_verbosity_level {LVL_INFO} |
Provided messages with VerbosityLevel smaller than this value shall be ignored. More... | |
Private Attributes | |
mrpt::kinematics::CVehicleSimul_DiffDriven & | m_simul |
double | m_simul_time_start |
for getNavigationTime More... | |
Logging methods | |
void | logStr (const VerbosityLevel level, std::string_view msg_str) const |
Main method to add the specified message string to the logger. More... | |
void | logFmt (const VerbosityLevel level, const char *fmt,...) const MRPT_printf_format_check(3 |
Alternative logging method, which mimics the printf behavior. More... | |
void void | logCond (const VerbosityLevel level, bool cond, const std::string &msg_str) const |
Log the given message only if the condition is satisfied. More... | |
void | setLoggerName (const std::string &name) |
Set the name of the COutputLogger instance. More... | |
std::string | getLoggerName () const |
Return the name of the COutputLogger instance. More... | |
void | setMinLoggingLevel (const VerbosityLevel level) |
Set the minimum logging level for which the incoming logs are going to be taken into account. More... | |
void | setVerbosityLevel (const VerbosityLevel level) |
alias of setMinLoggingLevel() More... | |
VerbosityLevel | getMinLoggingLevel () const |
bool | isLoggingLevelVisible (VerbosityLevel level) const |
void | getLogAsString (std::string &log_contents) const |
Fill the provided string with the contents of the logger's history in std::string representation. More... | |
std::string | getLogAsString () const |
Get the history of COutputLogger instance in a string representation. More... | |
void | writeLogToFile (const std::string *fname_in=nullptr) const |
Write the contents of the COutputLogger instance to an external file. More... | |
void | dumpLogToConsole () const |
Dump the current contents of the COutputLogger instance in the terminal window. More... | |
std::string | getLoggerLastMsg () const |
Return the last Tmsg instance registered in the logger history. More... | |
void | getLoggerLastMsg (std::string &msg_str) const |
Fill inputtted string with the contents of the last message in history. More... | |
void | loggerReset () |
Reset the contents of the logger instance. More... | |
void | logRegisterCallback (output_logger_callback_t userFunc) |
bool | logDeregisterCallback (output_logger_callback_t userFunc) |
bool | logging_enable_console_output {true} |
[Default=true] Set it to false in case you don't want the logged messages to be dumped to the output automatically. More... | |
bool | logging_enable_keep_record {false} |
[Default=false] Enables storing all messages into an internal list. More... | |
|
inline |
Definition at line 119 of file CRobot2NavInterfaceForSimulator.h.
|
inlineoverridevirtual |
Sends a velocity command to the robot.
The number components in each command depends on children classes of mrpt::kinematics::CVehicleVelCmd. One robot may accept one or more different CVehicleVelCmd classes. This method resets the watchdog timer (that may be or may be not implemented in a particular robotic platform) started with startWatchdog()
Implements mrpt::nav::CRobot2NavInterface.
Definition at line 137 of file CRobot2NavInterfaceForSimulator.h.
References m_simul, and mrpt::kinematics::CVehicleSimul_DiffDriven::sendVelCmd().
|
virtualinherited |
Just like changeSpeeds(), but will be called when the last velocity command is still the preferred solution, so there is no need to change that past command.
The unique effect of this callback would be resetting the watchdog timer.
Definition at line 21 of file CRobot2NavInterface.cpp.
References MRPT_LOG_THROTTLE_INFO.
Referenced by mrpt::nav::CAbstractNavigator::changeSpeedsNOP().
|
inherited |
Dump the current contents of the COutputLogger instance in the terminal window.
Definition at line 190 of file COutputLogger.cpp.
|
virtualinherited |
Gets a motion command to make the robot to align with a given relative heading, without translating.
Only for circular robots that can rotate in place; otherwise, return an empty smart pointer to indicate that the operation is not possible (this is what the default implementation does).
Reimplemented in mrpt::nav::CRobot2NavInterfaceForSimulator_Holo.
Definition at line 30 of file CRobot2NavInterface.cpp.
Referenced by mrpt::nav::CWaypointsNavigator::waypoints_navigationStep().
|
inlineoverridevirtual |
Get the current pose and velocity of the robot.
The implementation should not take too much time to return, so if it might take more than ~10ms to ask the robot for the instantaneous data, it may be good enough to return the latest values from a cache which is updated in a parallel thread.
Implements mrpt::nav::CRobot2NavInterface.
Definition at line 125 of file CRobot2NavInterfaceForSimulator.h.
References mrpt::kinematics::CVehicleSimulVirtualBase::getCurrentGTPose(), mrpt::kinematics::CVehicleSimulVirtualBase::getCurrentGTVel(), mrpt::kinematics::CVehicleSimulVirtualBase::getCurrentOdometricPose(), m_simul, and mrpt::system::now().
|
inlineoverridevirtual |
Gets the emergency stop command for the current robot.
Implements mrpt::nav::CRobot2NavInterface.
Definition at line 158 of file CRobot2NavInterfaceForSimulator.h.
References getStopCmd().
|
inherited |
Fill the provided string with the contents of the logger's history in std::string representation.
Definition at line 154 of file COutputLogger.cpp.
|
inherited |
Get the history of COutputLogger instance in a string representation.
Definition at line 159 of file COutputLogger.cpp.
Referenced by mrpt::graphslam::deciders::CICPCriteriaNRD< GRAPH_T >::getDescriptiveReport().
|
inherited |
Return the last Tmsg instance registered in the logger history.
Definition at line 195 of file COutputLogger.cpp.
References mrpt::system::COutputLogger::TMsg::getAsString().
|
inherited |
Fill inputtted string with the contents of the last message in history.
Definition at line 201 of file COutputLogger.cpp.
|
inherited |
Return the name of the COutputLogger instance.
Definition at line 143 of file COutputLogger.cpp.
|
inlineinherited |
Definition at line 201 of file system/COutputLogger.h.
References mrpt::system::COutputLogger::m_min_verbosity_level.
Referenced by mrpt::apps::RawlogGrabberApp::dump_verbose_info(), mrpt::maps::CRandomFieldGridMap2D::isEnabledVerbose(), mrpt::slam::CMetricMapBuilderRBPF::processActionObservation(), mrpt::apps::CGridMapAlignerApp::run(), mrpt::apps::RBPF_SLAM_App_Base::run(), and mrpt::apps::ICP_SLAM_App_Base::run().
|
inlineoverridevirtual |
See CRobot2NavInterface::getNavigationTime().
In this class, simulation time is returned instead of wall-clock time.
Reimplemented from mrpt::nav::CRobot2NavInterface.
Definition at line 165 of file CRobot2NavInterfaceForSimulator.h.
References mrpt::kinematics::CVehicleSimulVirtualBase::getTime(), m_simul, and m_simul_time_start.
|
inlineoverridevirtual |
Gets the emergency stop command for the current robot.
Implements mrpt::nav::CRobot2NavInterface.
Definition at line 151 of file CRobot2NavInterfaceForSimulator.h.
Referenced by getEmergencyStopCmd().
|
inlineinherited |
Definition at line 202 of file system/COutputLogger.h.
References mrpt::system::COutputLogger::m_min_verbosity_level.
Referenced by mrpt::slam::CMetricMapBuilderRBPF::processActionObservation(), and mrpt::system::COutputLoggerStreamWrapper::~COutputLoggerStreamWrapper().
|
inherited |
Log the given message only if the condition is satisfied.
Definition at line 131 of file COutputLogger.cpp.
|
inherited |
Definition at line 291 of file COutputLogger.cpp.
References getAddress(), and mrpt::system::COutputLogger::m_listCallbacks.
|
inherited |
Alternative logging method, which mimics the printf behavior.
Handy for not having to first use mrpt::format to pass a std::string message to logStr
Definition at line 91 of file COutputLogger.cpp.
Referenced by mrpt::hmtslam::CHMTSLAM::areaAbstraction(), mrpt::graphslam::deciders::CICPCriteriaNRD< GRAPH_T >::CICPCriteriaNRD(), mrpt::hmtslam::CTopLCDetector_GridMatching::computeTopologicalObservationModel(), CGraphSlamHandler< GRAPH_T >::execute(), mrpt::math::CLevenbergMarquardtTempl< VECTORTYPE, USERPARAM >::execute(), CGraphSlamHandler< GRAPH_T >::initOutputDir(), CGraphSlamHandler< GRAPH_T >::initVisualization(), mrpt::nav::CNavigatorManualSequence::navigationStep(), mrpt::nav::CAbstractNavigator::performNavigationStepNavigating(), CGraphSlamHandler< GRAPH_T >::readConfigFname(), CGraphSlamHandler< GRAPH_T >::saveResults(), CGraphSlamHandler< GRAPH_T >::setResultsDirName(), mrpt::nav::CReactiveNavigationSystem::STEP1_InitPTGs(), mrpt::hmtslam::CHMTSLAM::thread_3D_viewer(), mrpt::hmtslam::CHMTSLAM::thread_LSLAM(), mrpt::hmtslam::CHMTSLAM::thread_TBI(), and CGraphSlamHandler< GRAPH_T >::~CGraphSlamHandler().
|
inherited |
Reset the contents of the logger instance.
Called upon construction.
Definition at line 206 of file COutputLogger.cpp.
References mrpt::system::LVL_INFO.
|
staticinherited |
Map from VerbosityLevels to their corresponding mrpt::system::TConsoleColor.
Handy for coloring the input based on the verbosity of the message
Definition at line 47 of file COutputLogger.cpp.
References logging_levels_to_colors.
Referenced by mrpt::system::COutputLogger::TMsg::dumpToConsole().
|
staticinherited |
Map from VerbosityLevels to their corresponding names.
Handy for printing the current message VerbosityLevel along with the actual content
Definition at line 60 of file COutputLogger.cpp.
References logging_levels_to_names.
Referenced by mrpt::system::COutputLogger::TMsg::getAsString().
|
inherited |
Definition at line 278 of file COutputLogger.cpp.
References mrpt::system::COutputLogger::m_listCallbacks.
|
inherited |
Main method to add the specified message string to the logger.
Definition at line 72 of file COutputLogger.cpp.
References mrpt::system::COutputLogger::TMsg::body, mrpt::system::COutputLogger::TMsg::dumpToConsole(), mrpt::system::COutputLogger::TMsg::level, mrpt::system::COutputLogger::TMsg::name, and mrpt::system::COutputLogger::TMsg::timestamp.
Referenced by mrpt::slam::PF_implementation< mrpt::math::TPose3D, CMonteCarloLocalization3D, mrpt::bayes::particle_storage_mode::VALUE >::PF_SLAM_implementation_pfAuxiliaryPFStandardAndOptimal(), mrpt::nav::CReactiveNavigationSystem::STEP1_InitPTGs(), mrpt::system::COutputLoggerStreamWrapper::~COutputLoggerStreamWrapper(), and mrpt::system::CTimeLoggerSaveAtDtor::~CTimeLoggerSaveAtDtor().
|
inlineoverridevirtual |
See CRobot2NavInterface::resetNavigationTimer()
Reimplemented from mrpt::nav::CRobot2NavInterface.
Definition at line 170 of file CRobot2NavInterfaceForSimulator.h.
References mrpt::kinematics::CVehicleSimulVirtualBase::getTime(), m_simul, and m_simul_time_start.
|
virtualinherited |
Callback: Apparent collision event (i.e.
there is at least one obstacle point inside the robot shape)
Definition at line 102 of file CRobot2NavInterface.cpp.
References MRPT_LOG_THROTTLE_INFO.
Referenced by mrpt::nav::CAbstractPTGBasedReactive::performNavigationStep().
|
virtualinherited |
Callback: Target seems to be blocked by an obstacle.
Definition at line 110 of file CRobot2NavInterface.cpp.
References MRPT_LOG_THROTTLE_INFO.
|
virtualinherited |
Callback: Error asking sensory data from robot or sending motor commands.
Definition at line 86 of file CRobot2NavInterface.cpp.
References MRPT_LOG_THROTTLE_INFO.
Referenced by mrpt::nav::CAbstractNavigator::navigationStep().
|
virtualinherited |
Callback: End of navigation command (reach of single goal, or final waypoint of waypoint list)
Definition at line 63 of file CRobot2NavInterface.cpp.
References MRPT_LOG_INFO.
Referenced by mrpt::nav::CAbstractNavigator::performNavigationStepNavigating().
|
virtualinherited |
Callback: Start of navigation command.
Definition at line 56 of file CRobot2NavInterface.cpp.
References MRPT_LOG_INFO.
Referenced by mrpt::nav::CAbstractNavigator::performNavigationStepNavigating().
|
virtualinherited |
Callback: Heading towards a new intermediary/final waypoint in waypoint list navigation.
Definition at line 79 of file CRobot2NavInterface.cpp.
References MRPT_LOG_INFO_STREAM.
Referenced by mrpt::nav::CWaypointsNavigator::waypoints_navigationStep().
|
virtualinherited |
Callback: Reached an intermediary waypoint in waypoint list navigation.
reached_nSkipped will be true
if the waypoint was physically reached; false
if it was actually "skipped".
Definition at line 70 of file CRobot2NavInterface.cpp.
References MRPT_LOG_INFO_STREAM.
Referenced by mrpt::nav::CWaypointsNavigator::waypoints_navigationStep().
|
virtualinherited |
Callback: No progression made towards target for a predefined period of time.
Definition at line 94 of file CRobot2NavInterface.cpp.
References MRPT_LOG_THROTTLE_INFO.
Referenced by mrpt::nav::CAbstractNavigator::performNavigationStepNavigating().
|
pure virtualinherited |
Return the current set of obstacle points, as seen from the local coordinate frame of the robot.
[out] | obstacles | A representation of obstacles in robot-centric coordinates. |
[out] | timestamp | The timestamp for the read obstacles. Use mrpt::system::now() unless you have something more accurate. |
Referenced by mrpt::nav::CReactiveNavigationSystem::implementSenseObstacles(), and mrpt::nav::CReactiveNavigationSystem3D::implementSenseObstacles().
|
inherited |
Set the name of the COutputLogger instance.
Definition at line 138 of file COutputLogger.cpp.
Referenced by mrpt::slam::CMetricMapBuilderICP::CMetricMapBuilderICP(), mrpt::slam::CMetricMapBuilderRBPF::CMetricMapBuilderRBPF(), mrpt::slam::CMonteCarloLocalization2D::CMonteCarloLocalization2D(), mrpt::slam::CMonteCarloLocalization3D::CMonteCarloLocalization3D(), mrpt::apps::ICP_SLAM_App_Base::ICP_SLAM_App_Base(), mrpt::apps::ICP_SLAM_App_Live::ICP_SLAM_App_Live(), mrpt::apps::ICP_SLAM_App_Rawlog::ICP_SLAM_App_Rawlog(), mrpt::graphslam::CWindowManager::initCWindowManager(), mrpt::apps::MonteCarloLocalization_Base::MonteCarloLocalization_Base(), mrpt::apps::RBPF_SLAM_App_Base::RBPF_SLAM_App_Base(), and mrpt::apps::RBPF_SLAM_App_Rawlog::RBPF_SLAM_App_Rawlog().
|
inherited |
Set the minimum logging level for which the incoming logs are going to be taken into account.
String messages with specified VerbosityLevel smaller than the min, will not be outputted to the screen and neither will a record of them be stored in by the COutputLogger instance
Definition at line 144 of file COutputLogger.cpp.
Referenced by mrpt::maps::CRandomFieldGridMap2D::enableVerbose(), mrpt::math::CLevenbergMarquardtTempl< VECTORTYPE, USERPARAM >::execute(), generic_kf_slam_test(), generic_pf_test(), generic_rbpf_slam_test(), mrpt::apps::RawlogGrabberApp::initialize(), mrpt::hwdrivers::CHokuyoURG::initialize(), mrpt::graphslam::deciders::CICPCriteriaNRD< GRAPH_T >::loadParams(), mrpt::apps::CGridMapAlignerApp::run(), mrpt::apps::RBPF_SLAM_App_Base::run(), and mrpt::apps::ICP_SLAM_App_Base::run().
|
inherited |
alias of setMinLoggingLevel()
Definition at line 149 of file COutputLogger.cpp.
Referenced by mrpt::nav::CAbstractNavigator::CAbstractNavigator(), mrpt::slam::CMetricMapBuilderRBPF::CMetricMapBuilderRBPF(), mrpt::comms::CServerTCPSocket::CServerTCPSocket(), mrpt::slam::CMetricMapBuilderRBPF::processActionObservation(), mrpt::math::ransac_detect_2D_lines(), and mrpt::apps::ICP_SLAM_App_Base::run().
|
virtualinherited |
Start the watchdog timer of the robot platform, if any, for maximum expected delay between consecutive calls to changeSpeeds().
T_ms | Period, in ms. |
Definition at line 37 of file CRobot2NavInterface.cpp.
References MRPT_LOG_INFO_FMT.
Referenced by mrpt::nav::CAbstractNavigator::internal_onStartNewNavigation().
|
inlineoverridevirtual |
Stop the robot right now.
[in] | isEmergencyStop | true if stop is due to some unexpected error. false if "stop" happens as part of a normal operation (e.g. target reached). |
Implements mrpt::nav::CRobot2NavInterface.
Definition at line 143 of file CRobot2NavInterfaceForSimulator.h.
References m_simul, mrpt::kinematics::CVehicleSimul_DiffDriven::sendVelCmd(), and mrpt::kinematics::CVehicleVelCmd_DiffDriven::setToStop().
|
virtualinherited |
Stop the watchdog timer.
Definition at line 47 of file CRobot2NavInterface.cpp.
References MRPT_LOG_INFO.
Referenced by mrpt::nav::CAbstractNavigator::navigationStep().
|
inherited |
Write the contents of the COutputLogger instance to an external file.
Upon call to this method, COutputLogger dumps the contents of all the logged commands so far to the specified external file. By default the filename is set to ${LOGGERNAME}.log except if the fname parameter is provided
Definition at line 165 of file COutputLogger.cpp.
References ASSERTMSG_, and mrpt::format().
|
inherited |
[Default=true] Set it to false in case you don't want the logged messages to be dumped to the output automatically.
Definition at line 240 of file system/COutputLogger.h.
|
inherited |
[Default=false] Enables storing all messages into an internal list.
Definition at line 243 of file system/COutputLogger.h.
|
protectedinherited |
Provided messages with VerbosityLevel smaller than this value shall be ignored.
Definition at line 253 of file system/COutputLogger.h.
Referenced by mrpt::system::COutputLogger::getMinLoggingLevel(), and mrpt::system::COutputLogger::isLoggingLevelVisible().
|
private |
Definition at line 114 of file CRobot2NavInterfaceForSimulator.h.
Referenced by changeSpeeds(), getCurrentPoseAndSpeeds(), getNavigationTime(), resetNavigationTimer(), and stop().
|
private |
for getNavigationTime
Definition at line 116 of file CRobot2NavInterfaceForSimulator.h.
Referenced by getNavigationTime(), and resetNavigationTimer().
Page generated by Doxygen 1.8.14 for MRPT 2.0.1 Git: 0fef1a6d7 Fri Apr 3 23:00:21 2020 +0200 at vie abr 3 23:20:28 CEST 2020 |