This class exists as a union of constraint samplers. It contains a vector of constraint samplers, and will sample from each of them. More...
#include <union_constraint_sampler.h>
Public Member Functions | |
virtual bool | canService (const moveit_msgs::Constraints &constr) const |
No-op, as the union constraint sampler can act on anything. More... | |
virtual bool | configure (const moveit_msgs::Constraints &constr) |
No-op, as the union constraint sampler is for already configured samplers. More... | |
virtual const std::string & | getName () const |
Get the name of the constraint sampler, for debugging purposes should be in CamelCase format. More... | |
const std::vector< ConstraintSamplerPtr > & | getSamplers () const |
Gets the sorted internal list of constraint samplers. More... | |
virtual bool | project (robot_state::RobotState &state, unsigned int max_attempts) |
Project a sample given the constraints, updating the joint state group. This function allows the parameter max_attempts to be set. More... | |
virtual bool | sample (robot_state::RobotState &state, const robot_state::RobotState &reference_state, unsigned int max_attempts) |
Produces a sample from all configured samplers. More... | |
UnionConstraintSampler (const planning_scene::PlanningSceneConstPtr &scene, const std::string &group_name, const std::vector< ConstraintSamplerPtr > &samplers) | |
Constructor, which will re-order its internal list of samplers on construction. More... | |
Public Member Functions inherited from constraint_samplers::ConstraintSampler | |
ConstraintSampler (const planning_scene::PlanningSceneConstPtr &scene, const std::string &group_name) | |
Constructor. More... | |
const std::vector< std::string > & | getFrameDependency () const |
Return the names of the mobile frames whose pose is needed when sample() is called. More... | |
const std::string & | getGroupName () const |
Gets the group name set in the constructor. More... | |
const robot_state::GroupStateValidityCallbackFn & | getGroupStateValidityCallback () const |
Gets the callback used to determine state validity during sampling. The sampler will attempt to satisfy this constraint if possible, but there is no guarantee. More... | |
const robot_model::JointModelGroup * | getJointModelGroup () const |
Gets the joint model group. More... | |
const planning_scene::PlanningSceneConstPtr & | getPlanningScene () const |
Gets the planning scene. More... | |
bool | getVerbose () const |
Check if the sampler is set to verbose mode. More... | |
bool | isValid () const |
Returns whether or not the constraint sampler is valid or not. To be valid, the joint model group must be available in the kinematic model and configure() must have successfully been called. More... | |
bool | project (robot_state::RobotState &state) |
Project a sample given the constraints, updating the joint state group. The value DEFAULT_MAX_SAMPLING_ATTEMPTS will be passed in as the maximum number of attempts to make to project the sample. More... | |
bool | sample (robot_state::RobotState &state) |
Samples given the constraints, populating state. The value DEFAULT_MAX_SAMPLING_ATTEMPTS will be passed in as the maximum number of attempts to make to take a sample. More... | |
bool | sample (robot_state::RobotState &state, unsigned int max_attempts) |
Samples given the constraints, populating state. This function allows the parameter max_attempts to be set. More... | |
bool | sample (robot_state::RobotState &state, const robot_state::RobotState &reference_state) |
Samples given the constraints, populating state. The value DEFAULT_MAX_SAMPLING_ATTEMPTS will be passed in as the maximum number of attempts to make to take a sample. More... | |
void | setGroupStateValidityCallback (const robot_state::GroupStateValidityCallbackFn &callback) |
Sets the callback used to determine the state validity during sampling. The sampler will attempt to satisfy this constraint if possible, but there is no guarantee. More... | |
virtual void | setVerbose (bool verbose) |
Enable/disable verbose mode for sampler. More... | |
virtual | ~ConstraintSampler () |
Protected Attributes | |
std::vector< ConstraintSamplerPtr > | samplers_ |
Holder for sorted internal list of samplers. More... | |
Protected Attributes inherited from constraint_samplers::ConstraintSampler | |
std::vector< std::string > | frame_depends_ |
Holds the set of frames that must exist in the reference state to allow samples to be drawn. More... | |
robot_state::GroupStateValidityCallbackFn | group_state_validity_callback_ |
Holds the callback for state validity. More... | |
bool | is_valid_ |
Holds the value for validity. More... | |
const robot_model::JointModelGroup *const | jmg_ |
Holds the joint model group associated with this constraint. More... | |
planning_scene::PlanningSceneConstPtr | scene_ |
Holds the planning scene. More... | |
bool | verbose_ |
True if verbosity is on. More... | |
Additional Inherited Members | |
Static Public Attributes inherited from constraint_samplers::ConstraintSampler | |
static const unsigned int | DEFAULT_MAX_SAMPLING_ATTEMPTS = 2 |
The default value associated with a sampling request. By default if a valid sample cannot be produced in this many attempts, it returns with no sample. More... | |
Protected Member Functions inherited from constraint_samplers::ConstraintSampler | |
virtual void | clear () |
Clears all data from the constraint. More... | |
This class exists as a union of constraint samplers. It contains a vector of constraint samplers, and will sample from each of them.
When asked to sample it will call the samplers in a sorted order that samples more general groups - like a robot's whole body - before sampling more specific groups, such as a robot's arm. Member samplers can operate on all or part of a joint state group vector, with later samplers potentially overwriting previous samplers.
Definition at line 57 of file union_constraint_sampler.h.
constraint_samplers::UnionConstraintSampler::UnionConstraintSampler | ( | const planning_scene::PlanningSceneConstPtr & | scene, |
const std::string & | group_name, | ||
const std::vector< ConstraintSamplerPtr > & | samplers | ||
) |
Constructor, which will re-order its internal list of samplers on construction.
The samplers need not all refer to the same group, as long as all are part of the kinematic model. The sampler will sort the samplers based on a set of criteria - where A and B are two samplers being considered for swapping by a sort algorithm:
[in] | scene | The planning scene |
[in] | group_name | The group name is ignored, as each sampler already has a group name |
[in] | samplers | A vector of already configured samplers that will be applied for future samples |
Definition at line 107 of file union_constraint_sampler.cpp.
|
inlinevirtual |
No-op, as the union constraint sampler can act on anything.
[in] | constr | Constraint message |
Definition at line 132 of file union_constraint_sampler.h.
|
inlinevirtual |
No-op, as the union constraint sampler is for already configured samplers.
[in] | constr | Constraint message |
Implements constraint_samplers::ConstraintSampler.
Definition at line 120 of file union_constraint_sampler.h.
|
inlinevirtual |
Get the name of the constraint sampler, for debugging purposes should be in CamelCase format.
Implements constraint_samplers::ConstraintSampler.
Definition at line 162 of file union_constraint_sampler.h.
|
inline |
Gets the sorted internal list of constraint samplers.
Definition at line 107 of file union_constraint_sampler.h.
|
virtual |
Project a sample given the constraints, updating the joint state group. This function allows the parameter max_attempts to be set.
[out] | state | The state into which the values will be placed. Only values for the group are written. |
[in] | max_attempts | The maximum number of times to attempt to draw a sample. If no sample has been drawn in this number of attempts, false will be returned. |
Implements constraint_samplers::ConstraintSampler.
Definition at line 150 of file union_constraint_sampler.cpp.
|
virtual |
Produces a sample from all configured samplers.
This function will call each sampler in sorted order independently of the group associated with the sampler. The function will also operate independently of the joint state group passed in as an argument. If any sampler fails, the sample fails altogether.
[in] | state | State where the group sample is written to |
[in] | reference_state | Reference kinematic state that will be passed through to samplers |
[in] | max_attempts | Max attempts, which will be passed through to samplers |
Implements constraint_samplers::ConstraintSampler.
Definition at line 126 of file union_constraint_sampler.cpp.
|
protected |
Holder for sorted internal list of samplers.
Definition at line 169 of file union_constraint_sampler.h.