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 
65 void 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 
94 void ompl_interface::ProjectionEvaluatorJointValue::project(const ompl::base::State* state,
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 }
model_based_planning_context.h
ompl_interface::ProjectionEvaluatorJointValue::ProjectionEvaluatorJointValue
ProjectionEvaluatorJointValue(const ModelBasedPlanningContext *pc, std::vector< unsigned int > variables)
Definition: projection_evaluators.cpp:77
ompl_interface::ModelBasedPlanningContext
Definition: model_based_planning_context.h:105
s
XmlRpcServer s
projection_evaluators.h
ompl_interface::ProjectionEvaluatorLinkPose::defaultCellSizes
void defaultCellSizes() override
Definition: projection_evaluators.cpp:57
ompl_interface::ModelBasedStateSpace::StateType
Definition: model_based_state_space.h:109
moveit::core::RobotState
model_based_state_space.h
ompl_interface::ProjectionEvaluatorJointValue::getDimension
unsigned int getDimension() const override
Definition: projection_evaluators.cpp:83
ompl_interface::ProjectionEvaluatorJointValue::project
void project(const ompl::base::State *state, OMPLProjection projection) const override
Definition: projection_evaluators.cpp:94
ompl_interface::ProjectionEvaluatorLinkPose::ProjectionEvaluatorLinkPose
ProjectionEvaluatorLinkPose(const ModelBasedPlanningContext *pc, const std::string &link)
Definition: projection_evaluators.cpp:43
ompl_interface::ProjectionEvaluatorLinkPose::project
void project(const ompl::base::State *state, OMPLProjection projection) const override
Definition: projection_evaluators.cpp:65
ompl_interface::ProjectionEvaluatorLinkPose::getDimension
unsigned int getDimension() const override
Definition: projection_evaluators.cpp:52
ompl_interface::ProjectionEvaluatorJointValue::defaultCellSizes
void defaultCellSizes() override
Definition: projection_evaluators.cpp:88
values
std::vector< double > values
std
OMPLProjection
ompl::base::EuclideanProjection & OMPLProjection
Definition: projection_evaluators.h:47


ompl
Author(s): Ioan Sucan
autogenerated on Tue Dec 24 2024 03:28:10