Program Listing for File state_observer.hpp

Return to documentation for file (include/state_observers/state_observer.hpp)

// Copyright 2024 National Council of Research of Italy (CNR) - Intelligent Robotics Lab
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef STATE_OBSERVERS__STATE_OBSERVER_HPP_
#define STATE_OBSERVERS__STATE_OBSERVER_HPP_

#include <Eigen/Dense>
#include <state_observers_param/state_observer_param.hpp>

namespace state_observer
{

class StateObserver
{
public:
  StateObserver(
    const Eigen::MatrixXd & A, const Eigen::MatrixXd & B,
    const Eigen::MatrixXd & C, const Eigen::MatrixXd & D,
    const Eigen::VectorXd & initial_state);

  StateObserver(
    const Eigen::MatrixXd & A, const Eigen::MatrixXd & B,
    const Eigen::MatrixXd & C,
    const Eigen::VectorXd & initial_state);

  StateObserver(
    const Eigen::MatrixXd & A, const Eigen::MatrixXd & B,
    const Eigen::MatrixXd & C);

  StateObserver() {}

  ~StateObserver() {}

  virtual void set_parameters(const StateObserverParam::SharedPtr state_observer_params) {}
  // TODO(@samu) Pure virtual and mandatory in inheritance

  void initialize(const Eigen::VectorXd & initial_state);

  virtual Eigen::VectorXd open_loop_update();

  virtual Eigen::MatrixXd update(const Eigen::VectorXd & measurement) = 0;

  virtual Eigen::MatrixXd update(
    const Eigen::VectorXd & measurement,
    const Eigen::VectorXd & input) = 0;

  inline Eigen::VectorXd get_state() const {return x_;}

  inline Eigen::VectorXd get_output() const {return C_ * x_;}

  inline bool is_initialized() const {return initialized_;}

  virtual Eigen::VectorXd get_state_variance() {throw std::runtime_error("Not implemented.");}
  void set_state_transition_matrix(const Eigen::MatrixXd & A);

  inline Eigen::MatrixXd get_A() const {return A_;}
  inline Eigen::MatrixXd get_B() const {return B_;}
  inline Eigen::MatrixXd get_C() const {return C_;}
  inline Eigen::MatrixXd get_D() const {return D_;}
  inline Eigen::VectorXd get_initial_state() const {return x_;}

protected:
  Eigen::MatrixXd A_, B_, C_, D_;
  Eigen::VectorXd x_, y_;
  bool initialized_ = false;

  void dimensions_check(
    const Eigen::MatrixXd & A, const Eigen::MatrixXd & B,
    const Eigen::MatrixXd & C, const Eigen::MatrixXd & D,
    const Eigen::VectorXd & initial_state
  );
};

}  // namespace state_observer

#endif  // STATE_OBSERVERS__STATE_OBSERVER_HPP_