RTFilterBase.h
Go to the documentation of this file.
1 /*
2  * This file is part of ArmarX.
3  *
4  * Copyright (C) 2011-2017, High Performance Humanoid Technologies (H2T), Karlsruhe Institute of Technology (KIT), all rights reserved.
5  *
6  * ArmarX is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 as
8  * published by the Free Software Foundation.
9  *
10  * ArmarX is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program. If not, see <http://www.gnu.org/licenses/>.
17  *
18  * @package ArmarX
19  * @author Mirko Waechter( mirko.waechter at kit dot edu)
20  * @date 2017
21  * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
22  * GNU General Public License
23  */
24 #ifndef RTFILTERBASE_H
25 #define RTFILTERBASE_H
26 
27 #include <boost/circular_buffer.hpp>
28 
29 #include <IceUtil/Time.h>
30 
31 namespace armarx::rtfilters
32 {
33  class RTFilterBase;
34  using RTFilterBasePtr = std::shared_ptr<RTFilterBase>;
35  /**
36  * @brief The RTFilterBase class is the base class for all real time capable filters.
37  * Real Time capable means here that no heap memory allocation is done and no mutexes are locked
38  * during the update() function. Also the runtime must be the same during each call (e.g. no random searches).
39  */
41  {
42  public:
43  RTFilterBase(size_t historySize);
44  RTFilterBase(const RTFilterBase& other) = default;
45  virtual ~RTFilterBase() {}
46  virtual void reset();
47  virtual double update(IceUtil::Time const& timestamp, double newValue);
48  double update(double deltaSec, double newValue);
49  virtual double calculate() = 0;
50  virtual RTFilterBasePtr clone() const = 0;
51  double getCurrentValue() const;
52 
53  protected:
54  boost::circular_buffer<std::pair<IceUtil::Time, double> > dataHistory;
55  double currentValue = 0.0;
56  };
57  using RTFilterBasePtr = std::shared_ptr<RTFilterBase>;
58 
59 }
60 #endif // RTFILTERBASE_H
armarx::rtfilters::RTFilterBase::calculate
virtual double calculate()=0
armarx::rtfilters::RTFilterBasePtr
std::shared_ptr< RTFilterBase > RTFilterBasePtr
Definition: RTFilterBase.h:34
armarx::rtfilters::RTFilterBase::update
virtual double update(IceUtil::Time const &timestamp, double newValue)
Definition: RTFilterBase.cpp:40
armarx::rtfilters
Definition: AverageFilter.cpp:26
armarx::rtfilters::RTFilterBase::RTFilterBase
RTFilterBase(size_t historySize)
Definition: RTFilterBase.cpp:29
armarx::rtfilters::RTFilterBase::~RTFilterBase
virtual ~RTFilterBase()
Definition: RTFilterBase.h:45
armarx::rtfilters::RTFilterBase::clone
virtual RTFilterBasePtr clone() const =0
armarx::rtfilters::RTFilterBase::dataHistory
boost::circular_buffer< std::pair< IceUtil::Time, double > > dataHistory
Definition: RTFilterBase.h:54
armarx::rtfilters::RTFilterBase
The RTFilterBase class is the base class for all real time capable filters.
Definition: RTFilterBase.h:40
armarx::armem::Time
armarx::core::time::DateTime Time
Definition: forward_declarations.h:13
armarx::rtfilters::RTFilterBase::getCurrentValue
double getCurrentValue() const
Definition: RTFilterBase.cpp:47
armarx::rtfilters::RTFilterBase::currentValue
double currentValue
Definition: RTFilterBase.h:55
armarx::rtfilters::RTFilterBase::reset
virtual void reset()
Definition: RTFilterBase.cpp:34