model_based_joint_state_space.h
Go to the documentation of this file.
00001 /*********************************************************************
00002 * Software License Agreement (BSD License)
00003 *
00004 *  Copyright (c) 2012, 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 #ifndef MOVEIT_OMPL_INTERFACE_PARAMETERIZATION_MODEL_BASED_JOINT_STATE_SPACE_
00038 #define MOVEIT_OMPL_INTERFACE_PARAMETERIZATION_MODEL_BASED_JOINT_STATE_SPACE_
00039 
00040 #include <ompl/base/StateSpace.h>
00041 #include <moveit/robot_model/robot_model.h>
00042 #include <moveit/robot_state/robot_state.h>
00043 
00044 namespace ompl_interface
00045 {
00046 
00047 class ModelBasedJointStateSpace : public ompl::base::StateSpace
00048 {
00049 public:
00050 
00051   class StateType : public ompl::base::State
00052   {
00053   public:
00054     robot_state::JointState *joint_state;
00055   };
00056 
00057   ModelBasedJointStateSpace(const robot_model::JointModel *joint_model);
00058   ModelBasedJointStateSpace(const robot_model::JointModel *joint_model,
00059                             const robot_model::JointModel::Bounds &joint_bounds);
00060 
00061   virtual ~ModelBasedJointStateSpace();
00062 
00063   virtual ompl::base::State* allocState() const;
00064   virtual void freeState(ompl::base::State *state) const;
00065 
00066   virtual unsigned int getDimension() const;
00067   virtual double getMaximumExtent() const;
00068   virtual void enforceBounds(ompl::base::State *state) const;
00069   virtual bool satisfiesBounds(const ompl::base::State *state) const;
00070 
00071   virtual void copyState(ompl::base::State *destination, const ompl::base::State *source) const;
00072   virtual double distance(const ompl::base::State *state1, const ompl::base::State *state2) const;
00073   virtual bool equalStates(const ompl::base::State *state1, const ompl::base::State *state2) const;
00074   virtual void interpolate(const ompl::base::State *from, const ompl::base::State *to, const double t, ompl::base::State *state) const;
00075 
00076   virtual unsigned int getSerializationLength() const;
00077   virtual void serialize(void *serialization, const ompl::base::State *state) const;
00078   virtual void deserialize(ompl::base::State *state, const void *serialization) const;
00079   virtual double* getValueAddressAtIndex(ompl::base::State *state, const unsigned int index) const;
00080   virtual void printState(const ompl::base::State *state, std::ostream &out) const;
00081   virtual void printSettings(std::ostream &out) const;
00082 
00083   virtual ompl::base::StateSamplerPtr allocDefaultStateSampler() const;
00084 
00085   const robot_model::JointModel* getJointModel() const
00086   {
00087     return joint_model_;
00088   }
00089 
00090   const std::string& getJointName() const
00091   {
00092     return getJointModel()->getName();
00093   }
00094 
00096   void setPlanningVolume(double minX, double maxX, double minY, double maxY, double minZ, double maxZ);
00097 
00098   const robot_model::JointModel::Bounds& getJointBounds() const
00099   {
00100     return joint_bounds_;
00101   }
00102 
00103 protected:
00104 
00105   void propagateJointStateUpdate(ompl::base::State *state) const;
00106 
00107   const robot_model::JointModel *joint_model_;
00108   robot_model::JointModel::Bounds joint_bounds_;
00109 
00110 };
00111 
00112 }
00113 
00114 #endif


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