moveit2
The MoveIt Motion Planning Framework for ROS 2.
constrained_sampler.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 
39 
40 #include <utility>
41 
43  constraint_samplers::ConstraintSamplerPtr cs)
44  : ob::StateSampler(pc->getOMPLStateSpace().get())
45  , planning_context_(pc)
46  , default_(space_->allocDefaultStateSampler())
47  , constraint_sampler_(std::move(cs))
48  , work_state_(pc->getCompleteInitialRobotState())
49  , constrained_success_(0)
50  , constrained_failure_(0)
51 {
52  inv_dim_ = space_->getDimension() > 0 ? 1.0 / (double)space_->getDimension() : 1.0;
53 }
54 
56 {
57  if (constrained_success_ == 0)
58  return 0.0;
59  else
60  return (double)constrained_success_ / (double)(constrained_success_ + constrained_failure_);
61 }
62 
63 bool ompl_interface::ConstrainedSampler::sampleC(ob::State* state)
64 {
65  if (constraint_sampler_->sample(work_state_, planning_context_->getCompleteInitialRobotState(),
66  planning_context_->getMaximumStateSamplingAttempts()))
67  {
68  planning_context_->getOMPLStateSpace()->copyToOMPLState(state, work_state_);
69  if (space_->satisfiesBounds(state))
70  {
71  ++constrained_success_;
72  return true;
73  }
74  }
75  ++constrained_failure_;
76  return false;
77 }
78 
80 {
81  if (!sampleC(state) && !sampleC(state) && !sampleC(state))
82  default_->sampleUniform(state);
83 }
84 
85 void ompl_interface::ConstrainedSampler::sampleUniformNear(ob::State* state, const ob::State* near,
86  const double distance)
87 {
88  if (sampleC(state) || sampleC(state) || sampleC(state))
89  {
90  double total_d = space_->distance(state, near);
91  if (total_d > distance)
92  {
93  double dist = pow(rng_.uniform01(), inv_dim_) * distance;
94  space_->interpolate(near, state, dist / total_d, state);
95  }
96  }
97  else
98  default_->sampleUniformNear(state, near, distance);
99 }
100 
101 void ompl_interface::ConstrainedSampler::sampleGaussian(ob::State* state, const ob::State* mean, const double stdDev)
102 {
103  if (sampleC(state) || sampleC(state) || sampleC(state))
104  {
105  double total_d = space_->distance(state, mean);
106  double distance = rng_.gaussian(0.0, stdDev);
107  if (total_d > distance)
108  {
109  double dist = pow(rng_.uniform01(), inv_dim_) * distance;
110  space_->interpolate(mean, state, dist / total_d, state);
111  }
112  }
113  else
114  default_->sampleGaussian(state, mean, stdDev);
115 }
void sampleUniformNear(ompl::base::State *state, const ompl::base::State *near, const double distance) override
Sample a state (uniformly) within a certain distance of another state.
void sampleUniform(ompl::base::State *state) override
Sample a state (uniformly)
void sampleGaussian(ompl::base::State *state, const ompl::base::State *mean, const double stdDev) override
Sample a state using the specified Gaussian.
ConstrainedSampler(const ModelBasedPlanningContext *pc, constraint_samplers::ConstraintSamplerPtr cs)
Default constructor.
double distance(const urdf::Pose &transform)
Definition: pr2_arm_ik.h:55