moveit2
The MoveIt Motion Planning Framework for ROS 2.
plan_service_capability.cpp
Go to the documentation of this file.
1 /*********************************************************************
2  * Software License Agreement (BSD License)
3  *
4  * Copyright (c) 2012, Willow Garage, Inc.
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * * Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  * * Redistributions in binary form must reproduce the above
14  * copyright notice, this list of conditions and the following
15  * disclaimer in the documentation and/or other materials provided
16  * with the distribution.
17  * * Neither the name of Willow Garage nor the names of its
18  * contributors may be used to endorse or promote products derived
19  * from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  *********************************************************************/
34 
35 /* Author: Ioan Sucan */
36 
38 
42 #include <moveit/utils/logger.hpp>
43 
44 namespace move_group
45 {
46 
47 namespace
48 {
49 rclcpp::Logger getLogger()
50 {
51  return moveit::getLogger("MoveGroupPlanService");
52 }
53 } // namespace
54 
56 {
57 }
58 
60 {
61  plan_service_ = context_->moveit_cpp_->getNode()->create_service<moveit_msgs::srv::GetMotionPlan>(
62  PLANNER_SERVICE_NAME, [this](const std::shared_ptr<rmw_request_id_t>& request_header,
63  const std::shared_ptr<moveit_msgs::srv::GetMotionPlan::Request>& req,
64  const std::shared_ptr<moveit_msgs::srv::GetMotionPlan::Response>& res) {
65  return computePlanService(request_header, req, res);
66  });
67 }
68 
69 bool MoveGroupPlanService::computePlanService(const std::shared_ptr<rmw_request_id_t>& /* unused */,
70  const std::shared_ptr<moveit_msgs::srv::GetMotionPlan::Request>& req,
71  const std::shared_ptr<moveit_msgs::srv::GetMotionPlan::Response>& res)
72 {
73  RCLCPP_INFO(getLogger(), "Received new planning service request...");
74  // before we start planning, ensure that we have the latest robot state received...
75  if (static_cast<bool>(req->motion_plan_request.start_state.is_diff))
76  context_->planning_scene_monitor_->waitForCurrentRobotState(context_->moveit_cpp_->getNode()->get_clock()->now());
77  context_->planning_scene_monitor_->updateFrameTransforms();
78 
79  // Select planning_pipeline to handle request
80  const planning_pipeline::PlanningPipelinePtr planning_pipeline =
81  resolvePlanningPipeline(req->motion_plan_request.pipeline_id);
82  if (!planning_pipeline)
83  {
84  res->motion_plan_response.error_code.val = moveit_msgs::msg::MoveItErrorCodes::FAILURE;
85  return true;
86  }
87 
88  planning_scene_monitor::LockedPlanningSceneRO ps(context_->planning_scene_monitor_);
89  try
90  {
92  if (!planning_pipeline->generatePlan(ps, req->motion_plan_request, mp_res, context_->debug_))
93  {
94  RCLCPP_ERROR(getLogger(), "Generating a plan with planning pipeline failed.");
95  mp_res.error_code.val = moveit_msgs::msg::MoveItErrorCodes::FAILURE;
96  }
97  mp_res.getMessage(res->motion_plan_response);
98  }
99  catch (std::exception& ex)
100  {
101  RCLCPP_ERROR(getLogger(), "Planning pipeline threw an exception: %s", ex.what());
102  res->motion_plan_response.error_code.val = moveit_msgs::msg::MoveItErrorCodes::FAILURE;
103  }
104 
105  return true;
106 }
107 } // namespace move_group
108 
109 #include <pluginlib/class_list_macros.hpp>
110 
PLUGINLIB_EXPORT_CLASS(cached_ik_kinematics_plugin::CachedIKKinematicsPlugin< kdl_kinematics_plugin::KDLKinematicsPlugin >, kinematics::KinematicsBase)
planning_pipeline::PlanningPipelinePtr resolvePlanningPipeline(const std::string &pipeline_id) const
This is a convenience class for obtaining access to an instance of a locked PlanningScene.
rclcpp::Logger getLogger(const std::string &name)
Creates a namespaced logger.
Definition: logger.cpp:79
Response to a planning query.
moveit::core::MoveItErrorCode error_code
void getMessage(moveit_msgs::msg::MotionPlanResponse &msg) const
Construct a ROS message from struct data.