52 validity_service_ =
context_->moveit_cpp_->getNode()->create_service<moveit_msgs::srv::GetStateValidity>(
53 STATE_VALIDITY_SERVICE_NAME, [
this](
const std::shared_ptr<rmw_request_id_t>& request_header,
54 const std::shared_ptr<moveit_msgs::srv::GetStateValidity::Request>& req,
55 const std::shared_ptr<moveit_msgs::srv::GetStateValidity::Response>& res) {
56 return computeService(request_header, req, res);
60 bool MoveGroupStateValidationService::computeService(
61 const std::shared_ptr<rmw_request_id_t>& ,
62 const std::shared_ptr<moveit_msgs::srv::GetStateValidity::Request>& req,
63 const std::shared_ptr<moveit_msgs::srv::GetStateValidity::Response>& res)
76 creq.
max_contacts = ls->getWorld()->size() + ls->getRobotModel()->getLinkModelsWithCollisionGeometry().size();
82 ls->checkCollision(creq, cres, rs);
87 rclcpp::Time time_now =
context_->moveit_cpp_->getNode()->get_clock()->now();
90 for (collision_detection::CollisionResult::ContactMap::const_iterator it = cres.
contacts.begin();
94 res->contacts.resize(res->contacts.size() + 1);
96 res->contacts.back().header.frame_id = ls->getPlanningFrame();
97 res->contacts.back().header.stamp = time_now;
105 res->cost_sources.resize(res->cost_sources.size() + 1);
113 kset.add(req->constraints, ls->getTransforms());
114 std::vector<kinematic_constraints::ConstraintEvaluationResult> kres;
120 res->constraint_result.resize(kres.size());
121 for (std::size_t k = 0; k < kres.size(); ++k)
123 res->constraint_result[k].result = kres[k].
satisfied;
124 res->constraint_result[k].distance = kres[k].distance;
132 #include <pluginlib/class_list_macros.hpp>
PLUGINLIB_EXPORT_CLASS(cached_ik_kinematics_plugin::CachedIKKinematicsPlugin< kdl_kinematics_plugin::KDLKinematicsPlugin >, kinematics::KinematicsBase)
A class that contains many different constraints, and can check RobotState *versus the full set....
MoveGroupContextPtr context_
MoveGroupStateValidationService()
void initialize() override
Representation of a robot's state. This includes position, velocity, acceleration and effort.
This is a convenience class for obtaining access to an instance of a locked PlanningScene.
void contactToMsg(const Contact &contact, moveit_msgs::msg::ContactInformation &msg)
void costSourceToMsg(const CostSource &cost_source, moveit_msgs::msg::CostSource &msg)
bool isEmpty(const moveit_msgs::msg::PlanningScene &msg)
Check if a message includes any information about a planning scene, or whether it is empty.
bool robotStateMsgToRobotState(const Transforms &tf, const moveit_msgs::msg::RobotState &robot_state, RobotState &state, bool copy_attached_bodies=true)
Convert a robot state msg (with accompanying extra transforms) to a MoveIt robot state.
Representation of a collision checking request.
std::string group_name
The group name to check collisions for (optional; if empty, assume the complete robot)
std::size_t max_cost_sources
When costs are computed, this value defines how many of the top cost sources should be returned.
bool contacts
If true, compute contacts. Otherwise only a binary collision yes/no is reported.
bool cost
If true, a collision cost is computed.
std::size_t max_contacts
Overall maximum number of contacts to compute.
Representation of a collision checking result.
std::set< CostSource > cost_sources
These are the individual cost sources when costs are computed.
bool collision
True if collision was found, false otherwise.
std::size_t contact_count
Number of contacts returned.
When collision costs are computed, this structure contains information about the partial cost incurre...
Struct for containing the results of constraint evaluation.
bool satisfied
Whether or not the constraint or constraints were satisfied.