MTC
connect.h
1 /*********************************************************************
2  * Software License Agreement (BSD License)
3  *
4  * Copyright (c) 2017, Bielefeld University
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 Bielefeld University 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 /* Authors: Robert Haschke, Michael Goerner
36  Desc: Connect arbitrary states by motion planning
37 */
38 
39 #pragma once
40 
41 #include <moveit/task_constructor/stage.h>
42 #include <moveit/task_constructor/solvers/planner_interface.h>
43 
44 #include <moveit_msgs/Constraints.h>
45 
46 namespace moveit {
47 namespace core {
48 MOVEIT_CLASS_FORWARD(RobotState);
49 }
50 } // namespace moveit
51 
52 namespace moveit {
53 namespace task_constructor {
54 namespace stages {
55 
64 class Connect : public Connecting
65 {
66 protected:
67  bool compatible(const InterfaceState& from_state, const InterfaceState& to_state) const override;
68 
69 public:
70  enum MergeMode : uint8_t
71  {
72  SEQUENTIAL = 0,
73  WAYPOINTS = 1
74  };
75 
76  using GroupPlannerVector = std::vector<std::pair<std::string, solvers::PlannerInterfacePtr> >;
77  Connect(const std::string& name = "connect", const GroupPlannerVector& planners = {});
78 
79  void setMaxDistance(double max_distance) { setProperty("max_distance", max_distance); }
80  void setPathConstraints(moveit_msgs::Constraints path_constraints) {
81  setProperty("path_constraints", std::move(path_constraints));
82  }
83 
84  void reset() override;
85  void init(const moveit::core::RobotModelConstPtr& robot_model) override;
86  void compute(const InterfaceState& from, const InterfaceState& to) override;
87 
88 protected:
89  SolutionSequencePtr makeSequential(const std::vector<robot_trajectory::RobotTrajectoryConstPtr>& sub_trajectories,
90  const std::vector<planning_scene::PlanningSceneConstPtr>& intermediate_scenes,
91  const InterfaceState& from, const InterfaceState& to);
92  SubTrajectoryPtr merge(const std::vector<robot_trajectory::RobotTrajectoryConstPtr>& sub_trajectories,
93  const std::vector<planning_scene::PlanningSceneConstPtr>& intermediate_scenes,
94  const moveit::core::RobotState& state);
95 
96 protected:
97  GroupPlannerVector planner_;
98  moveit::core::JointModelGroupPtr merged_jmg_;
99  std::list<SubTrajectory> subsolutions_;
100  std::list<InterfaceState> states_;
101 };
102 } // namespace stages
103 } // namespace task_constructor
104 } // namespace moveit
void setProperty(const std::string &name, const boost::any &value)
Set a previously declared property to a new value.
Definition: stage.cpp:448
bool compatible(const InterfaceState &from_state, const InterfaceState &to_state) const override
compare consistency of planning scenes
Definition: connect.cpp:107
void init(const moveit::core::RobotModelConstPtr &robot_model) override
Definition: connect.cpp:74
void reset() override
reset stage, clearing all solutions, interfaces, inherited properties.
Definition: connect.cpp:67