RadiusControl.h
Go to the documentation of this file.
00001 /*********************************************************************
00002  * Software License Agreement (BSD License)
00003  *
00004  *  Copyright (c) 2015-2018, Dataspeed 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 Dataspeed Inc. 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 #ifndef RADIUSCONTROL_H
00036 #define RADIUSCONTROL_H
00037 
00038 #include <math.h>
00039 
00040 namespace dbw_mkz_twist_controller {
00041 
00042 class RadiusControl {
00043 public:
00044   RadiusControl() : wheelbase_(1.0), steering_ratio_(1.0), angle_max_(INFINITY) {}
00045   RadiusControl(double wheelbase, double steering_ratio, double steering_wheel_angle_max = INFINITY) :
00046     wheelbase_(wheelbase), steering_ratio_(steering_ratio), angle_max_(fabs(steering_wheel_angle_max)) {}
00047   void setWheelBase(double val) { wheelbase_ = val; }
00048   void setSteeringRatio(double val) { steering_ratio_ = val; }
00049   void setSteeringWheelAngleMax(double val) { angle_max_ = fabs(val); }
00050   double getSteeringWheelAngle(double radius) {
00051     double angle = isnan(radius) ? 0.0 : atan(wheelbase_ / radius) * steering_ratio_;
00052     if (angle > angle_max_) {
00053       return angle_max_;
00054     } else if (angle < -angle_max_) {
00055       return -angle_max_;
00056     }
00057     return angle;
00058   }
00059 private:
00060   double wheelbase_;
00061   double steering_ratio_;
00062   double angle_max_;
00063 };
00064 
00065 }
00066 
00067 #endif // RADIUSCONTROL_H
00068 


dbw_mkz_twist_controller
Author(s): Micho Radovnikovich , Kevin Hallenbeck
autogenerated on Thu Jul 4 2019 20:08:22