91 const std::string& logFileDirectory =
92 std::string(
"./reactivenav.logs"));
139 std::vector<CParameterizedTrajectoryGenerator::Ptr>
PTGs;
172 const size_t ptg_idx, std::vector<double>& out_TPObstacles,
175 const bool eval_clearance)
override;
void setHeight(size_t level, double h)
bool checkCollisionWithLatestObstacles(const mrpt::math::TPose2D &relative_robot_pose) const override
Checks whether the robot shape, when placed at the given pose (relative to the current pose)...
TCandidateMovementPTG holonomicmov
void resize(size_t num_levels)
std::vector< CParameterizedTrajectoryGenerator::Ptr > PTGs
mrpt::maps::CSimplePointsMap m_WS_Obstacles_unsorted
The unsorted set of obstacles from the sensors.
A 3D robot shape stored as a "sliced" stack of 2D polygons, used for CReactiveNavigationSystem3D Depe...
void STEP1_InitPTGs() override
void saveConfigFile(mrpt::config::CConfigFileBase &c) const override
Saves all current options to a config file.
void loggingGetWSObstaclesAndShape(CLogFileRecord &out_log) override
Generates a pointcloud of obstacles, and the robot shape, to be saved in the logging record for the c...
double getHeight(size_t level) const
A set of PTGs of the same type, one per "height level".
TRobotShape m_robotShape
The robot 3D shape model.
const CParameterizedTrajectoryGenerator * getPTG(size_t i) const override
Gets the i'th PTG.
size_t getPTG_count() const override
Returns the number of different PTGs that have been setup.
const mrpt::math::CPolygon & polygon(size_t level) const
void enableLogFile(bool enable)
Enables/disables saving log files.
A wrapper of a TPolygon2D class, implementing CSerializable.
A cloud of points in 2D or 3D, which can be built from a sequence of laser scans. ...
Clearance information for one particular PTG and one set of obstacles.
A class for storing, saving and loading a reactive navigation log record for the CReactiveNavigationS...
void setRadius(size_t level, double r)
CParameterizedTrajectoryGenerator * getPTG(size_t i) override
Gets the i'th PTG.
#define ASSERT_(f)
Defines an assertion mechanism.
mrpt::Clock::time_point TTimeStamp
A system independent time type, it holds the the number of 100-nanosecond intervals since January 1...
This is the base class for any user-defined PTG.
This class allows loading and storing values and vectors of different types from a configuration text...
double getRadius(size_t level) const
std::vector< double > radius
void loadConfigFile(const mrpt::config::CConfigFileBase &c) override
Loads all params from a file.
std::vector< TPTGmultilevel > m_ptgmultilevel
The set of PTG-transformations to be used: indices are [ptg_index][height_index]. ...
Base class for reactive navigator systems based on TP-Space, with an arbitrary holonomic reactive met...
const std::vector< double > & getHeights() const
See base class CAbstractPTGBasedReactive for a description and instructions of use.
std::vector< mrpt::math::CPolygon > polygons
bool implementSenseObstacles(mrpt::system::TTimeStamp &obs_timestamp) override
Return false on any fatal error.
std::vector< mrpt::maps::CSimplePointsMap > m_WS_Obstacles_inlevels
One point cloud per 2.5D robot-shape-slice, coordinates relative to the robot local frame...
std::vector< double > heights
void changeRobotShape(TRobotShape robotShape)
Change the robot shape, which is taken into account for collision grid building.
~CReactiveNavigationSystem3D() override
Destructor.
mrpt::math::TPoint2D TP_Target
mrpt::math::CPolygon & polygon(size_t level)
void STEP3_WSpaceToTPSpace(const size_t ptg_idx, std::vector< double > &out_TPObstacles, mrpt::nav::ClearanceDiagram &out_clearance, const mrpt::math::TPose2D &rel_pose_PTG_origin_wrt_sense, const bool eval_clearance) override
Transform the obstacle into TP-Obstacles in TP-Spaces.
The pure virtual interface between a real or simulated robot and any CAbstractNavigator-derived class...
CReactiveNavigationSystem3D(CRobot2NavInterface &react_iterf_impl, bool enableConsoleOutput=true, bool enableLogFile=false, const std::string &logFileDirectory=std::string("./reactivenav.logs"))
See docs in ctor of base class.
Stores a candidate movement in TP-Space-based navigation.