state_feedback.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 STATE_FEEDBACK_HPP
34 #define STATE_FEEDBACK_HPP
35 
36 #include <float.h>
37 #include <memory>
38 
40 
41 namespace tuw
42 {
50 template <typename InputObsStateType, typename InputDesStateType, typename OutputStateType, typename ParamType>
52 {
53  // special class member functions
54 public:
55  StateFeedback(std::shared_ptr<ParamType> _params) : params_(_params)
56  {
57  }
58 
59 public:
60  virtual ~StateFeedback() = default;
61 
62 public:
63  StateFeedback(const StateFeedback&) = default;
64 
65 public:
66  StateFeedback& operator=(const StateFeedback&) = default;
67 
68 public:
69  StateFeedback(StateFeedback&&) = default;
70 
71 public:
73 
74  // pure virtual functions
81 public:
82  virtual std::shared_ptr<OutputStateType>& compute(std::shared_ptr<InputObsStateType>& _xObs,
83  std::shared_ptr<InputDesStateType>& _xDes, const double& _t) = 0;
87 public:
88  virtual void reloadParam() = 0;
91 public:
92  std::shared_ptr<OutputStateType>& output()
93  {
94  return output_;
95  }
98 public:
99  std::shared_ptr<ParamType>& params()
100  {
101  return params_;
102  }
103 
104 protected:
105  std::shared_ptr<ParamType> params_;
106 protected:
107  std::shared_ptr<OutputStateType> output_;
108 };
109 }
110 
111 #endif // STATE_FEEDBACK_HPP
std::shared_ptr< ParamType > & params()
Access to the last parameters object pointer.
StateFeedback & operator=(const StateFeedback &)=default
std::shared_ptr< OutputStateType > output_
Last computet output state.
virtual std::shared_ptr< OutputStateType > & compute(std::shared_ptr< InputObsStateType > &_xObs, std::shared_ptr< InputDesStateType > &_xDes, const double &_t)=0
Computes the output state at the specified time instant given the observed state and the desired stat...
virtual ~StateFeedback()=default
Interface for a filter that outputs a desired state given an observed state and a desired state...
StateFeedback(std::shared_ptr< ParamType > _params)
std::shared_ptr< OutputStateType > & output()
Access to the last computed output state.
std::shared_ptr< ParamType > params_
Pointer to the class parameters object.
virtual void reloadParam()=0
Reloads class parameters. To be called when parameters that influence the class variables are changed...


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