dither.h
Go to the documentation of this file.
00001 /*********************************************************************
00002  * Software License Agreement (BSD License)
00003  *
00004  *  Copyright (c) 2009, 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 
00037 #ifndef CONTROL_TOOLBOX__DITHER_H
00038 #define CONTROL_TOOLBOX__DITHER_H
00039 
00040 #include <cstdlib>
00041 #include <ctime>
00042 #include <math.h>
00043 #include <ros/ros.h>
00044 
00045 namespace control_toolbox {
00046 
00047 /***************************************************/
00057 class Dither
00058 {
00059 public:
00060 
00061   Dither();
00062 
00066   ~Dither();
00067 
00072   double update();
00073 
00074    /*
00075    *\brief Dither gets an amplitude, must be >0 to initialize
00076    *
00077    *\param amplitude Amplitude of white noise output
00078    *\param seed Random seed for white noise
00079    */
00080   bool init(const double &amplitude, const double &seed)
00081   {
00082     if (amplitude < 0.0)
00083     {
00084       ROS_ERROR("Dither amplitude not set properly. Amplitude must be >0.");
00085       return false;
00086     }
00087     
00088     amplitude_ = amplitude;
00089 
00090     // Somewhat mimics the old code.  A given seed gives a
00091     // reproducible sequence of random numbers, and that's what
00092     // matters.
00093     unsigned long s = (unsigned long)seed;
00094     seed_[0] = (s) ^ 45213;
00095     seed_[1] = (s >> 16) ^ 39204;
00096     seed_[2] = (s >> 32) ^ 5598;
00097     
00098     return true;
00099   }
00100 
00101 
00102 private:
00103   double amplitude_;   
00104   double saved_value_;
00105   bool has_saved_value_;
00106   double s_;
00107   double x_;
00108   unsigned short seed_[3];
00109 };
00110 }
00111 
00112 #endif


control_toolbox
Author(s): Melonee Wise, Sachin Chitta, John Hsu
autogenerated on Sat Jun 8 2019 20:43:37