Parasol Planning Library (PPL)
Data Structures
GroupPRM Class Reference

#include <GroupPRM.h>

Inheritance diagram for GroupPRM:
Inheritance graph
[legend]
Collaboration diagram for GroupPRM:
Collaboration graph
[legend]

Data Structures

struct  SamplerSetting
 Settings for a specific sampler. More...
 

Public Types

Motion Planning Types
typedef MPBaseObject::GroupCfgType GroupCfgType
 
typedef MPBaseObject::GroupRoadmapType GroupRoadmapType
 
typedef GroupRoadmapType::VID VID
 
- Public Types inherited from GroupStrategyMethod
typedef MPBaseObject::GroupCfgType GroupCfgType
 
typedef MPBaseObject::GroupRoadmapType GroupRoadmapType
 
typedef GroupRoadmapType::VID VID
 
typedef SamplerMethod::BoundaryMap BoundaryMap
 
- Public Types inherited from MPStrategyMethod
typedef size_t VID
 
- Public Types inherited from MPBaseObject
typedef DefaultWeight< CfgWeightType
 
typedef GenericStateGraph< Cfg, WeightTypeRoadmapType
 
typedef GroupCfg< RoadmapTypeGroupCfgType
 
typedef GroupLocalPlan< RoadmapTypeGroupWeightType
 
typedef GroupRoadmap< GroupCfgType, GroupWeightTypeGroupRoadmapType
 

Public Member Functions

Construction
 GroupPRM ()
 
 GroupPRM (XMLNode &_node)
 
virtual ~GroupPRM ()=default
 
MPBaseObject Overrides
virtual void Print (std::ostream &_os) const override
 
virtual void Initialize () override
 
- Public Member Functions inherited from GroupStrategyMethod
 GroupStrategyMethod ()=default
 
 GroupStrategyMethod (XMLNode &_node)
 
virtual ~GroupStrategyMethod ()=default
 
- Public Member Functions inherited from MPStrategyMethod
 MPStrategyMethod ()=default
 
 MPStrategyMethod (XMLNode &_node)
 
virtual ~MPStrategyMethod ()
 
void operator() ()
 Execute the strategy by calling Initialize, Run, and Finalize. More...
 
void EnableOutputFiles (const bool _enable=true)
 
virtual void Initialize ()
 
- Public Member Functions inherited from MPBaseObject
 MPBaseObject (const std::string &_label="", const std::string &_name="", bool _debug=false)
 
 MPBaseObject (XMLNode &_node)
 
virtual ~MPBaseObject ()
 
const std::string & GetName () const
 Get the class name for this object. More...
 
const std::string & GetLabel () const
 Get the unique label for this object. More...
 
std::string GetNameAndLabel () const
 Get the unique string identifier for this object "m_name::m_label". More...
 
void SetLabel (const std::string &)
 Set the unique label for this object. More...
 
void SetMPLibrary (MPLibrary *) noexcept
 Set the owning MPLibrary. More...
 
MPLibraryGetMPLibrary () const noexcept
 Get the owning MPLibrary. More...
 
bool IsRunning () const noexcept
 Check the library's running flag. More...
 
MPProblemGetMPProblem () const noexcept
 Get the library's current MPProblem. More...
 
EnvironmentGetEnvironment () const noexcept
 Get the current environment. More...
 
MPTaskGetTask () const noexcept
 Get the current task. More...
 
GroupTaskGetGroupTask () const noexcept
 Get the current group task. More...
 
MPSolutionTypeGetMPSolution () const noexcept
 
RoadmapTypeGetRoadmap (Robot *const _r=nullptr) const noexcept
 Get the current free-space roadmap. More...
 
GroupRoadmapTypeGetGroupRoadmap (RobotGroup *const _g=nullptr) const noexcept
 Get the current free-space group roadmap. More...
 
RoadmapTypeGetBlockRoadmap (Robot *const _r=nullptr) const noexcept
 Get the current obstacle-space roadmap. More...
 
PathGetPath (Robot *const _r=nullptr) const noexcept
 
GroupPathGetGroupPath (RobotGroup *const _g=nullptr) const noexcept
 Get the current best group path. More...
 
StatClassGetStatClass () const noexcept
 Get the current StatClass. More...
 
LocalObstacleMapGetLocalObstacleMap () const noexcept
 Get the local obstacle map. More...
 

Protected Member Functions

MPStrategyMethod Overrides
virtual void Iterate () override
 Execute one iteration of the strategy. More...
 
Helpers
std::vector< VIDSample ()
 
void Connect (const std::vector< VID > &_vids)
 
- Protected Member Functions inherited from GroupStrategyMethod
virtual void Finalize () override
 Clean-up and output results. More...
 
virtual size_t GenerateStart (const std::string &_samplerLabel) override
 
virtual std::vector< size_t > GenerateGoals (const std::string &_samplerLabel) override
 
BoundaryMap GetStartBoundaryMap () const noexcept
 
std::vector< BoundaryMapGetGoalBoundaryMaps () const noexcept
 
- Protected Member Functions inherited from MPStrategyMethod
virtual void Run ()
 Call Iterate until EvaluateMap is true. More...
 
virtual bool EvaluateMap ()
 Check if we satisfied all map evaluators. More...
 
virtual void ClearRoadmap ()
 Pre-clear the roadmap(s) if requested. More...
 
- Protected Member Functions inherited from MPBaseObject
void SetName (const std::string &_s)
 
const std::string & GetBaseFilename () const
 

Protected Attributes

Internal State
std::vector< SamplerSettingm_samplers
 Sampler labels with number and attempts of sampler. More...
 
std::vector< std::string > m_connectorLabels
 Connector labels for node-to-node. More...
 
- Protected Attributes inherited from MPStrategyMethod
std::string m_querySampler
 Sampler for generating start/goal. More...
 
std::vector< std::string > m_meLabels
 The list of map evaluators to use. More...
 
size_t m_iterations {0}
 The number of executed iterations. More...
 
bool m_writeOutput {true}
 Write output at the end? More...
 
bool m_clearMap {false}
 Clear the roadmap(s) before run? More...
 
- Protected Attributes inherited from MPBaseObject
bool m_debug
 Print debug info? More...
 

Detailed Description

Basic PRM algorithm for multirobot teams using composite c-space.

Todo:
Create option for decoupled planning.

Member Typedef Documentation

◆ GroupCfgType

◆ GroupRoadmapType

◆ VID

Constructor & Destructor Documentation

◆ GroupPRM() [1/2]

GroupPRM::GroupPRM ( )

◆ GroupPRM() [2/2]

GroupPRM::GroupPRM ( XMLNode _node)

◆ ~GroupPRM()

virtual GroupPRM::~GroupPRM ( )
virtualdefault

Member Function Documentation

◆ Connect()

void GroupPRM::Connect ( const std::vector< VID > &  _vids)
protected

Connect nodes in the roadmap.

Parameters
_vidsA set of node VIDs to connect to the rest of the roadmap.
Todo:
Setup CC tracker for groups to fix this.

◆ Initialize()

void GroupPRM::Initialize ( )
overridevirtual

Initialize this object for the current MPProblem. This should reset any internal state of the algorithms so that they are ready for execution. It is also the place to initialize any state that depends on the current problem.

Warning
This member will be called for every compiled algorithm in the planning library - even those that will not be used. If an algorithm needs to do expenisve setup, then this method should only set a flag that tells it to do so on first use. The only exceptions are the MPStrategies, which will only have their initialize called on first use.

Reimplemented from MPBaseObject.

◆ Iterate()

void GroupPRM::Iterate ( )
overrideprotectedvirtual

Execute one iteration of the strategy.

Reimplemented from MPStrategyMethod.

◆ Print()

void GroupPRM::Print ( std::ostream &  _os) const
overridevirtual

Print internal state of this object.

Parameters
_osThe std::ostream to print to.

Reimplemented from MPStrategyMethod.

◆ Sample()

std::vector< size_t > GroupPRM::Sample ( )
protected

Sample and add configurations to the roadmap.

Returns
The generated VIDs for the successful samples.

Field Documentation

◆ m_connectorLabels

std::vector<std::string> GroupPRM::m_connectorLabels
protected

Connector labels for node-to-node.

◆ m_samplers

std::vector<SamplerSetting> GroupPRM::m_samplers
protected

Sampler labels with number and attempts of sampler.


The documentation for this class was generated from the following files: