integrator.hpp
Go to the documentation of this file.
1 /***************************************************************************
2  * Software License Agreement (BSD License) *
3  * Copyright (C) 2016 by Horatiu George Todoran <todorangrg@gmail.com> *
4  * *
5  * Redistribution and use in source and binary forms, with or without *
6  * modification, are permitted provided that the following conditions *
7  * are met: *
8  * *
9  * 1. Redistributions of source code must retain the above copyright *
10  * notice, this list of conditions and the following disclaimer. *
11  * 2. Redistributions in binary form must reproduce the above copyright *
12  * notice, this list of conditions and the following disclaimer in *
13  * the documentation and/or other materials provided with the *
14  * distribution. *
15  * 3. Neither the name of the copyright holder nor the names of its *
16  * contributors may be used to endorse or promote products derived *
17  * from this software without specific prior written permission. *
18  * *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT *
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS *
22  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE *
23  * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, *
24  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, *
25  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; *
26  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER *
27  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT *
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY *
29  * WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE *
30  * POSSIBILITY OF SUCH DAMAGE. *
31  ***************************************************************************/
32 
33 #ifndef INTEGRATOR_HPP
34 #define INTEGRATOR_HPP
35 
36 #include <float.h>
37 #include <memory>
38 
39 namespace tuw
40 {
45 {
46  // special class member functions
47 public:
48  Integrator() = default;
49 
50 public:
51  virtual ~Integrator() = default;
52 
53 public:
54  Integrator(const Integrator&) = default;
55 
56 public:
57  Integrator& operator=(const Integrator&) = default;
58 
59 public:
60  Integrator(Integrator&&) = default;
61 
62 public:
63  Integrator& operator=(Integrator&&) = default;
64 
68 public:
69  void reset(const double& _x0)
70  {
71  x_ = _x0;
72  comp_ = 0;
73  }
77 public:
78  const double& intOutput() const
79  {
80  return x_;
81  }
85 public:
86  void integrate(const double& _dx)
87  {
88  double y = _dx - comp_;
89  double t = x_ + y;
90  comp_ = (t - x_) - y;
91  x_ = t;
92  }
93 
94 private:
95  double x_;
96 private:
97  double comp_;
98 };
99 }
100 
101 #endif // STATE_FEEDBACK_HPP
void reset(const double &_x0)
resets the integrated value and compensation variable.
Definition: integrator.hpp:69
Integrator & operator=(const Integrator &)=default
double x_
Integrated value.
Definition: integrator.hpp:95
const double & intOutput() const
Returns the integrator value.
Definition: integrator.hpp:78
Integrator()=default
void integrate(const double &_dx)
Addds a new value to the integrated value.
Definition: integrator.hpp:86
double comp_
Summation compensation variable.
Definition: integrator.hpp:97
virtual ~Integrator()=default
Minimal class performing numerically stable integration (using the Kahan summation algorithm)...
Definition: integrator.hpp:44


tuw_control
Author(s): George Todoran
autogenerated on Mon Jun 10 2019 15:27:21