oscillation.h
Go to the documentation of this file.
00001 /*
00002  * Software License Agreement (BSD License)
00003  *
00004  *  Copyright (c) 2017, Locus Robotics
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 copyright holder 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 HOLDER 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 #ifndef DWB_CRITICS_OSCILLATION_H_
00036 #define DWB_CRITICS_OSCILLATION_H_
00037 
00038 #include <dwb_local_planner/trajectory_critic.h>
00039 #include <vector>
00040 #include <string>
00041 
00042 namespace dwb_critics
00043 {
00044 
00079 class OscillationCritic: public dwb_local_planner::TrajectoryCritic
00080 {
00081 public:
00082   void onInit() override;
00083   bool prepare(const geometry_msgs::Pose2D& pose, const nav_2d_msgs::Twist2D& vel,
00084                const geometry_msgs::Pose2D& goal, const nav_2d_msgs::Path2D& global_plan) override;
00085   double scoreTrajectory(const dwb_msgs::Trajectory2D& traj) override;
00086   void reset() override;
00087   void debrief(const nav_2d_msgs::Twist2D& cmd_vel) override;
00088 
00089 protected:
00094   class CommandTrend
00095   {
00096   public:
00097     CommandTrend();
00098     void reset();
00099 
00105     bool update(double velocity);
00106 
00112     bool isOscillating(double velocity);
00113 
00118     bool hasSignFlipped();
00119 
00120   protected:
00121     // Simple Enum for Tracking
00122     enum class Sign { ZERO, POSITIVE, NEGATIVE };
00123 
00124     Sign sign_;
00125     bool positive_only_, negative_only_;
00126   };
00127 
00133   bool setOscillationFlags(const nav_2d_msgs::Twist2D& cmd_vel);
00134 
00138   bool resetAvailable();
00139 
00140   CommandTrend x_trend_, y_trend_, theta_trend_;
00141   double oscillation_reset_dist_, oscillation_reset_angle_, x_only_threshold_;
00142   double oscillation_reset_time_;
00143 
00144   // Cached square parameter
00145   double oscillation_reset_dist_sq_;
00146 
00147   // Saved positions
00148   geometry_msgs::Pose2D pose_, prev_stationary_pose_;
00149   // Saved timestamp
00150   ros::Time prev_reset_time_;
00151 };
00152 
00153 }  // namespace dwb_critics
00154 #endif  // DWB_CRITICS_OSCILLATION_H_


dwb_critics
Author(s): David V. Lu!!
autogenerated on Wed Jun 26 2019 20:09:47