constrained_goal_sampler.cpp
Go to the documentation of this file.
00001 /*********************************************************************
00002 * Software License Agreement (BSD License)
00003 *
00004 *  Copyright (c) 2011, Willow Garage, Inc.
00005 *  All rights reserved.
00006 *
00007 *  Redistribution and use in source and binary forms, with or without
00008 *  modification, are permitted provided that the following conditions
00009 *  are met:
00010 *
00011 *   * Redistributions of source code must retain the above copyright
00012 *     notice, this list of conditions and the following disclaimer.
00013 *   * Redistributions in binary form must reproduce the above
00014 *     copyright notice, this list of conditions and the following
00015 *     disclaimer in the documentation and/or other materials provided
00016 *     with the distribution.
00017 *   * Neither the name of the Willow Garage nor the names of its
00018 *     contributors may be used to endorse or promote products derived
00019 *     from this software without specific prior written permission.
00020 *
00021 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00022 *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00023 *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00024 *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00025 *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00026 *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00027 *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00028 *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00029 *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00030 *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00031 *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00032 *  POSSIBILITY OF SUCH DAMAGE.
00033 *********************************************************************/
00034 
00035 /* Author: Ioan Sucan */
00036 
00037 #include <moveit/ompl_interface/detail/constrained_goal_sampler.h>
00038 #include <moveit/ompl_interface/model_based_planning_context.h>
00039 #include <moveit/ompl_interface/detail/state_validity_checker.h>
00040 #include <moveit/profiler/profiler.h>
00041 
00042 ompl_interface::ConstrainedGoalSampler::ConstrainedGoalSampler(const ModelBasedPlanningContext *pc,
00043                                                                const kinematic_constraints::KinematicConstraintSetPtr &ks,
00044                                                                const constraint_samplers::ConstraintSamplerPtr &cs) :
00045   ob::GoalLazySamples(pc->getOMPLSimpleSetup().getSpaceInformation(), boost::bind(&ConstrainedGoalSampler::sampleUsingConstraintSampler, this, _1, _2), false),
00046   planning_context_(pc),
00047   kinematic_constraint_set_(ks),
00048   constraint_sampler_(cs),
00049   work_state_(pc->getCompleteInitialRobotState()),
00050   work_joint_group_state_(work_state_.getJointStateGroup(planning_context_->getGroupName())),
00051   invalid_sampled_constraints_(0),
00052   warned_invalid_samples_(false),
00053   verbose_display_(0)
00054 {
00055   if (!constraint_sampler_)
00056     default_sampler_ = si_->allocStateSampler();
00057   logDebug("Constructed a ConstrainedGoalSampler instance at address %p", this);
00058   startSampling();
00059 }
00060 
00061 bool ompl_interface::ConstrainedGoalSampler::sampleUsingConstraintSampler(const ob::GoalLazySamples *gls, ob::State *newGoal)
00062 {
00063   //  moveit::Profiler::ScopedBlock sblock("ConstrainedGoalSampler::sampleUsingConstraintSampler");
00064 
00065   unsigned int max_attempts = planning_context_->getMaximumGoalSamplingAttempts();
00066   unsigned int attempts_so_far = gls->samplingAttemptsCount();
00067 
00068   // terminate after too many attempts
00069   if (attempts_so_far >= max_attempts)
00070     return false;
00071 
00072   // terminate after a maximum number of samples
00073   if (gls->getStateCount() >= planning_context_->getMaximumGoalSamples())
00074     return false;
00075 
00076   // terminate the sampling thread when a solution has been found
00077   if (planning_context_->getOMPLSimpleSetup().getProblemDefinition()->hasSolution())
00078     return false;
00079 
00080   unsigned int max_attempts_div2 = max_attempts/2;
00081   for (unsigned int a = gls->samplingAttemptsCount() ; a < max_attempts && gls->isSampling() ; ++a)
00082   {
00083     bool verbose = false;
00084     if (gls->getStateCount() == 0 && a >= max_attempts_div2)
00085       if (verbose_display_ < 1)
00086       {
00087     verbose = true;
00088     verbose_display_++;
00089       }
00090 
00091     if (constraint_sampler_)
00092     {
00093       if (constraint_sampler_->project(work_joint_group_state_, planning_context_->getCompleteInitialRobotState(), planning_context_->getMaximumStateSamplingAttempts()))
00094       {
00095         if (kinematic_constraint_set_->decide(work_state_, verbose).satisfied)
00096         {
00097           planning_context_->getOMPLStateSpace()->copyToOMPLState(newGoal, work_joint_group_state_);
00098           if (static_cast<const StateValidityChecker*>(si_->getStateValidityChecker().get())->isValid(newGoal, verbose))
00099             return true;
00100         }
00101     else
00102     {
00103       invalid_sampled_constraints_++;
00104       if (!warned_invalid_samples_ && invalid_sampled_constraints_ >= (attempts_so_far * 8) / 10)
00105       {
00106         warned_invalid_samples_ = true;
00107         logWarn("More than 80%% of the sampled goal states fail to satisfy the constraints imposed on the goal sampler. Is the constrained sampler working correctly?");
00108       }
00109     }
00110       }
00111     }
00112     else
00113     {
00114       default_sampler_->sampleUniform(newGoal);
00115       if (static_cast<const StateValidityChecker*>(si_->getStateValidityChecker().get())->isValid(newGoal, verbose))
00116       {
00117         planning_context_->getOMPLStateSpace()->copyToRobotState(work_joint_group_state_, newGoal);
00118         if (kinematic_constraint_set_->decide(work_state_, verbose).satisfied)
00119           return true;
00120       }
00121     }
00122   }
00123   return false;
00124 }


ompl
Author(s): Ioan Sucan
autogenerated on Mon Oct 6 2014 11:12:03