add_iterative_spline_parameterization.cpp
Go to the documentation of this file.
1 /*********************************************************************
2  * Software License Agreement (BSD License)
3  *
4  * Copyright (c) 2012, Willow Garage, Inc.
5  * Copyright (c) 2017, Ken Anderson
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * * Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above
15  * copyright notice, this list of conditions and the following
16  * disclaimer in the documentation and/or other materials provided
17  * with the distribution.
18  * * Neither the name of Willow Garage nor the names of its
19  * contributors may be used to endorse or promote products derived
20  * from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33  * POSSIBILITY OF SUCH DAMAGE.
34  *********************************************************************/
35 
36 /* Author: Ken Anderson, based off add_time_parameterization.cpp by Ioan Sucan */
37 
41 #include <ros/console.h>
42 
44 {
46 {
47 public:
49  {
50  }
51 
52  void initialize(const ros::NodeHandle& /*nh*/) override
53  {
54  }
55 
56  std::string getDescription() const override
57  {
58  return "Add Time Parameterization";
59  }
60 
61  bool adaptAndPlan(const PlannerFn& planner, const planning_scene::PlanningSceneConstPtr& planning_scene,
63  std::vector<std::size_t>& added_path_index) const override
64  {
65  bool result = planner(planning_scene, req, res);
66  if (result && res.trajectory_)
67  {
68  ROS_DEBUG("Running '%s'", getDescription().c_str());
69  std::size_t trajectory_size_before = res.trajectory_->getWayPointCount();
70  if (!time_param_.computeTimeStamps(*res.trajectory_, req.max_velocity_scaling_factor,
71  req.max_acceleration_scaling_factor))
72  {
73  ROS_ERROR("Time parametrization for the solution path failed.");
74  result = false;
75  }
76 
77  // IterativeSplineParameterization add waypoints after the first and before the last.
78  if (trajectory_size_before + 2 == res.trajectory_->getWayPointCount())
79  {
80  added_path_index.push_back(1);
81  added_path_index.push_back(res.trajectory_->getWayPointCount() - 2);
82  }
83  }
84 
85  return result;
86  }
87 
88 private:
90 };
91 } // namespace default_planner_request_adapters
92 
planning_interface::MotionPlanResponse
planning_request_adapter.h
default_planner_request_adapters::AddIterativeSplineParameterization::getDescription
std::string getDescription() const override
Definition: add_iterative_spline_parameterization.cpp:122
ROS_DEBUG
#define ROS_DEBUG(...)
default_planner_request_adapters::AddIterativeSplineParameterization::time_param_
trajectory_processing::IterativeSplineParameterization time_param_
Definition: add_iterative_spline_parameterization.cpp:155
planning_request_adapter::PlanningRequestAdapter
default_planner_request_adapters::AddIterativeSplineParameterization::AddIterativeSplineParameterization
AddIterativeSplineParameterization()
Definition: add_iterative_spline_parameterization.cpp:114
default_planner_request_adapters::AddIterativeSplineParameterization
Definition: add_iterative_spline_parameterization.cpp:78
console.h
planning_interface::MotionPlanResponse::trajectory_
robot_trajectory::RobotTrajectoryPtr trajectory_
ROS_ERROR
#define ROS_ERROR(...)
class_loader.hpp
planning_interface::MotionPlanRequest
moveit_msgs::MotionPlanRequest MotionPlanRequest
iterative_spline_parameterization.h
trajectory_processing::IterativeSplineParameterization::computeTimeStamps
bool computeTimeStamps(robot_trajectory::RobotTrajectory &trajectory, const double max_velocity_scaling_factor=1.0, const double max_acceleration_scaling_factor=1.0) const override
default_planner_request_adapters
Definition: add_iterative_spline_parameterization.cpp:43
planning_request_adapter::PlanningRequestAdapter::PlannerFn
boost::function< bool(const planning_scene::PlanningSceneConstPtr &, const planning_interface::MotionPlanRequest &, planning_interface::MotionPlanResponse &)> PlannerFn
default_planner_request_adapters::AddIterativeSplineParameterization::adaptAndPlan
bool adaptAndPlan(const PlannerFn &planner, const planning_scene::PlanningSceneConstPtr &planning_scene, const planning_interface::MotionPlanRequest &req, planning_interface::MotionPlanResponse &res, std::vector< std::size_t > &added_path_index) const override
Definition: add_iterative_spline_parameterization.cpp:127
CLASS_LOADER_REGISTER_CLASS
CLASS_LOADER_REGISTER_CLASS(default_planner_request_adapters::AddIterativeSplineParameterization, planning_request_adapter::PlanningRequestAdapter)
default_planner_request_adapters::AddIterativeSplineParameterization::initialize
void initialize(const ros::NodeHandle &) override
Definition: add_iterative_spline_parameterization.cpp:118
planning_scene
trajectory_processing::IterativeSplineParameterization
ros::NodeHandle


planning
Author(s): Ioan Sucan , Sachin Chitta
autogenerated on Sat Jan 18 2025 03:36:46