moveit2
The MoveIt Motion Planning Framework for ROS 2.
Loading...
Searching...
No Matches
projection_evaluators.cpp
Go to the documentation of this file.
1/*********************************************************************
2 * Software License Agreement (BSD License)
3 *
4 * Copyright (c) 2011, 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
40
41#include <utility>
42
44 const std::string& link)
45 : ompl::base::ProjectionEvaluator(pc->getOMPLStateSpace())
46 , planning_context_(pc)
47 , link_(planning_context_->getJointModelGroup()->getLinkModel(link))
48 , tss_(planning_context_->getCompleteInitialRobotState())
49{
50}
51
53{
54 return 3;
55}
56
58{
59 cellSizes_.resize(3);
60 cellSizes_[0] = 0.1;
61 cellSizes_[1] = 0.1;
62 cellSizes_[2] = 0.1;
63}
64
65void ompl_interface::ProjectionEvaluatorLinkPose::project(const ompl::base::State* state,
66 OMPLProjection projection) const
67{
68 moveit::core::RobotState* s = tss_.getStateStorage();
69 planning_context_->getOMPLStateSpace()->copyToRobotState(*s, state);
70
71 const Eigen::Vector3d& o = s->getGlobalLinkTransform(link_).translation();
72 projection(0) = o.x();
73 projection(1) = o.y();
74 projection(2) = o.z();
75}
76
78 std::vector<unsigned int> variables)
79 : ompl::base::ProjectionEvaluator(pc->getOMPLStateSpace()), variables_(std::move(variables))
80{
81}
82
84{
85 return variables_.size();
86}
87
89{
90 cellSizes_.clear();
91 cellSizes_.resize(variables_.size(), 0.1);
92}
93
95 OMPLProjection projection) const
96{
97 for (std::size_t i = 0; i < variables_.size(); ++i)
98 projection(i) = state->as<ModelBasedStateSpace::StateType>()->values[variables_[i]];
99}
Representation of a robot's state. This includes position, velocity, acceleration and effort.
const Eigen::Isometry3d & getGlobalLinkTransform(const std::string &link_name)
Get the link transform w.r.t. the root link (model frame) of the RobotModel. This is typically the ro...
void project(const ompl::base::State *state, OMPLProjection projection) const override
ProjectionEvaluatorJointValue(const ModelBasedPlanningContext *pc, std::vector< unsigned int > variables)
ProjectionEvaluatorLinkPose(const ModelBasedPlanningContext *pc, const std::string &link)
void project(const ompl::base::State *state, OMPLProjection projection) const override
Eigen::Ref< Eigen::VectorXd > OMPLProjection