00001 /********************************************************************* 00002 * Software License Agreement (BSD License) 00003 * 00004 * Copyright (c) 2013, PAL Robotics, S.L. 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 PAL Robotics 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 /* 00036 * Author: Enrique Fernández 00037 */ 00038 00039 #include <algorithm> 00040 00041 #include <jackal_diff_drive_controller/speed_limiter.h> 00042 00043 template<typename T> 00044 T clamp(T x, T min, T max) 00045 { 00046 return std::min(std::max(min, x), max); 00047 } 00048 00049 namespace diff_drive_controller 00050 { 00051 00052 SpeedLimiter::SpeedLimiter( 00053 bool has_velocity_limits, 00054 bool has_acceleration_limits, 00055 double min_velocity, 00056 double max_velocity, 00057 double min_acceleration, 00058 double max_acceleration 00059 ) 00060 : has_velocity_limits(has_velocity_limits), 00061 has_acceleration_limits(has_acceleration_limits), 00062 min_velocity(min_velocity), 00063 max_velocity(max_velocity), 00064 min_acceleration(min_acceleration), 00065 max_acceleration(max_acceleration) 00066 { 00067 } 00068 00069 void SpeedLimiter::limit(double& v, double v0, double dt) 00070 { 00071 limit_velocity(v); 00072 limit_acceleration(v, v0, dt); 00073 } 00074 00075 void SpeedLimiter::limit_velocity(double& v) 00076 { 00077 if (has_velocity_limits) 00078 { 00079 v = clamp(v, min_velocity, max_velocity); 00080 } 00081 } 00082 00083 void SpeedLimiter::limit_acceleration(double& v, double v0, double dt) 00084 { 00085 if (has_acceleration_limits) 00086 { 00087 double dv = v - v0; 00088 00089 const double dv_min = min_acceleration * dt; 00090 const double dv_max = max_acceleration * dt; 00091 00092 dv = clamp(dv, dv_min, dv_max); 00093 00094 v = v0 + dv; 00095 } 00096 } 00097 00098 } // namespace diff_drive_controller