edge_dynamic_obstacle.h
Go to the documentation of this file.
00001 /*********************************************************************
00002  *
00003  * Software License Agreement (BSD License)
00004  *
00005  *  Copyright (c) 2016,
00006  *  TU Dortmund - Institute of Control Theory and Systems Engineering.
00007  *  All rights reserved.
00008  *
00009  *  Redistribution and use in source and binary forms, with or without
00010  *  modification, are permitted provided that the following conditions
00011  *  are met:
00012  *
00013  *   * Redistributions of source code must retain the above copyright
00014  *     notice, this list of conditions and the following disclaimer.
00015  *   * Redistributions in binary form must reproduce the above
00016  *     copyright notice, this list of conditions and the following
00017  *     disclaimer in the documentation and/or other materials provided
00018  *     with the distribution.
00019  *   * Neither the name of the institute nor the names of its
00020  *     contributors may be used to endorse or promote products derived
00021  *     from this software without specific prior written permission.
00022  *
00023  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00024  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00025  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00026  *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00027  *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00028  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00029  *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00030  *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00031  *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00032  *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00033  *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00034  *  POSSIBILITY OF SUCH DAMAGE.
00035  * 
00036  * Notes:
00037  * The following class is derived from a class defined by the
00038  * g2o-framework. g2o is licensed under the terms of the BSD License.
00039  * Refer to the base class source for detailed licensing information.
00040  *
00041  * Author: Christoph Rösmann
00042  *********************************************************************/
00043 
00044 #ifndef EDGE_DYNAMICOBSTACLE_H
00045 #define EDGE_DYNAMICOBSTACLE_H
00046 
00047 #include <teb_local_planner/g2o_types/vertex_pose.h>
00048 #include <teb_local_planner/g2o_types/vertex_timediff.h>
00049 #include <teb_local_planner/g2o_types/penalties.h>
00050 #include <teb_local_planner/g2o_types/base_teb_edges.h>
00051 #include <teb_local_planner/obstacles.h>
00052 #include <teb_local_planner/teb_config.h>
00053 
00054 namespace teb_local_planner
00055 {
00056   
00070 class EdgeDynamicObstacle : public BaseTebBinaryEdge<1, const Obstacle*, VertexPose, VertexTimeDiff>
00071 {
00072 public:
00073   
00077   EdgeDynamicObstacle() : vert_idx_(0)
00078   {
00079   }
00080   
00085   EdgeDynamicObstacle(size_t vert_idx) : vert_idx_(vert_idx)
00086   {
00087   }
00088   
00092   void computeError()
00093   {
00094     ROS_ASSERT_MSG(cfg_, "You must call setTebConfig on EdgeDynamicObstacle()");
00095     const VertexPose* bandpt = static_cast<const VertexPose*>(_vertices[0]);
00096     const VertexTimeDiff* dt_vertex = static_cast<const VertexTimeDiff*>(_vertices[1]);
00097     
00098     // WARNING: vert_idx_*dt is just an approximation for the total time, since we don't have a uniform dt at the moment!
00099     Eigen::Vector2d pred_obst_point = _measurement->getCentroid() + double(vert_idx_)*dt_vertex->estimate()*_measurement->getCentroidVelocity();
00100     double dist = (pred_obst_point - bandpt->position()).norm();
00101     /*
00102     // get point in x-y-t
00103     Eigen::Vector3d point(bandpt->estimate().coeffRef(0), bandpt->estimate().coeffRef(1), _vert_idx*dt_vertex->estimate());
00104     
00105     // calc distance of that point to the obstacle trajectory in x-y-t predicted with a constant velocity
00106     Eigen::Vector3d robot_point;
00107     robot_point.head(2) = _measurement->getCentroid();
00108     robot_point.coeffRef(2) = 0;
00109     Eigen::Vector3d robot_vel;
00110     robot_vel.head(2) = _measurement->getCentroidVelocity();
00111     robot_vel.coeffRef(2) = 1;
00112     double dist = 0; //calcDistancePointToLine<Eigen::Vector3d>(point, robot_point, robot_vel);   
00113     */ 
00114     
00115     _error[0] = penaltyBoundFromBelow(dist, cfg_->obstacles.min_obstacle_dist, cfg_->optim.penalty_epsilon);
00116 
00117     ROS_ASSERT_MSG(std::isfinite(_error[0]), "EdgeDynamicObstacle::computeError() _error[0]=%f _error[1]=%f\n",_error[0],_error[1]);      
00118   }
00119   
00124   void setVertexIdx(size_t vert_idx)
00125   {
00126     vert_idx_ = vert_idx;
00127   }
00128   
00133   void setObstacle(const Obstacle* obstacle)
00134   {
00135     _measurement = obstacle;
00136   }
00137   
00138 
00139 protected:
00140   
00141   size_t vert_idx_; 
00142   
00143 public: 
00144   EIGEN_MAKE_ALIGNED_OPERATOR_NEW
00145 
00146 };
00147     
00148  
00149     
00150 
00151 } // end namespace
00152 
00153 #endif


teb_local_planner
Author(s): Christoph Rösmann
autogenerated on Sat Jun 8 2019 20:21:34