full_discretization_grid_move_blocking_base.h
Go to the documentation of this file.
1 /*********************************************************************
2  *
3  * Software License Agreement
4  *
5  * Copyright (c) 2020,
6  * TU Dortmund - Institute of Control Theory and Systems Engineering.
7  * All rights reserved.
8  *
9  * This program is free software: you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation, either version 3 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program. If not, see <https://www.gnu.org/licenses/>.
21  *
22  * Authors: Maximilian Krämer, Christoph Rösmann
23  *********************************************************************/
24 
25 #ifndef SRC_OPTIMAL_CONTROL_INCLUDE_CORBO_OPTIMAL_CONTROL_STRUCTURED_OCP_DISCRETIZATION_GRIDS_FULL_DISCRETIZATION_GRID_MOVE_BLOCKING_BASE_H_
26 #define SRC_OPTIMAL_CONTROL_INCLUDE_CORBO_OPTIMAL_CONTROL_STRUCTURED_OCP_DISCRETIZATION_GRIDS_FULL_DISCRETIZATION_GRID_MOVE_BLOCKING_BASE_H_
27 
29 
30 namespace corbo {
31 
32 class FullDiscretizationGridMoveBlockingBase : public FullDiscretizationGridBase
33 {
34  public:
35  using Ptr = std::shared_ptr<FullDiscretizationGridMoveBlockingBase>;
36  using UPtr = std::unique_ptr<FullDiscretizationGridMoveBlockingBase>;
37 
39  virtual ~FullDiscretizationGridMoveBlockingBase() = default;
40 
42  DiscretizationGridInterface::Ptr getInstance() const override = 0;
43 
44  void getStateAndControlTimeSeries(TimeSeries::Ptr x_sequence, TimeSeries::Ptr u_sequence, double t_max = CORBO_INF_DBL) const override;
45 
46  bool isValid() const override;
47 
50 
51  void setWarmStartShiftU(bool shift_u) { _warm_start_shift_u = shift_u; }
52 
53 #ifdef MESSAGE_SUPPORT
54  void fromMessage(const messages::DiscretizationGrid& message, std::stringstream* issues) override {}
55  void toMessage(messages::DiscretizationGrid& message) const override {}
56 #endif
57 
58  protected:
59  Eigen::VectorXi _blocking_vector;
60  bool _warm_start_shift_u = false;
61 
62  void initializeSequences(const Eigen::VectorXd& x0, const Eigen::VectorXd& xf, ReferenceTrajectoryInterface& uref,
63  NlpFunctions& nlp_fun) override;
64  void initializeSequences(const Eigen::VectorXd& x0, const Eigen::VectorXd& xf, ReferenceTrajectoryInterface& xref,
65  ReferenceTrajectoryInterface& uref, NlpFunctions& nlp_fun) override;
66 
67  void warmStartShifting(const Eigen::VectorXd& x0) override;
68 
69  void resampleTrajectory(int n_new) override;
70 
71  void createEdges(NlpFunctions& nlp_fun, OptimizationEdgeSet& edges, SystemDynamicsInterface::Ptr dynamics) override = 0;
72 
73  void computeActiveVertices() override;
74 };
75 
76 } // namespace corbo
77 
78 #endif // SRC_OPTIMAL_CONTROL_INCLUDE_CORBO_OPTIMAL_CONTROL_STRUCTURED_OCP_DISCRETIZATION_GRIDS_FULL_DISCRETIZATION_GRID_MOVE_BLOCKING_BASE_H_
corbo::FullDiscretizationGridMoveBlockingBase::UPtr
std::unique_ptr< FullDiscretizationGridMoveBlockingBase > UPtr
Definition: full_discretization_grid_move_blocking_base.h:80
full_discretization_grid_base.h
corbo::FullDiscretizationGridMoveBlockingBase::_warm_start_shift_u
bool _warm_start_shift_u
Definition: full_discretization_grid_move_blocking_base.h:104
corbo
Definition: communication/include/corbo-communication/utilities.h:37
corbo::CORBO_INF_DBL
constexpr const double CORBO_INF_DBL
Representation for infinity (double version)
Definition: core/include/corbo-core/types.h:75
corbo::FullDiscretizationGridMoveBlockingBase::getInstance
DiscretizationGridInterface::Ptr getInstance() const override=0
Return a newly created shared instance of the implemented class.
corbo::FullDiscretizationGridMoveBlockingBase::resampleTrajectory
void resampleTrajectory(int n_new) override
Definition: full_discretization_grid_move_blocking_base.cpp:298
corbo::DiscretizationGridInterface::Ptr
std::shared_ptr< DiscretizationGridInterface > Ptr
Definition: discretization_grid_interface.h:107
B
MatrixType B(b, *n, *nrhs, *ldb)
corbo::FullDiscretizationGridMoveBlockingBase::FullDiscretizationGridMoveBlockingBase
FullDiscretizationGridMoveBlockingBase()=default
corbo::FullDiscretizationGridMoveBlockingBase::setBlockingMatrix
void setBlockingMatrix(const Eigen::Ref< const Eigen::VectorXi > &B)
Definition: full_discretization_grid_move_blocking_base.h:93
corbo::FullDiscretizationGridMoveBlockingBase::createEdges
void createEdges(NlpFunctions &nlp_fun, OptimizationEdgeSet &edges, SystemDynamicsInterface::Ptr dynamics) override=0
corbo::FullDiscretizationGridMoveBlockingBase::setWarmStartShiftU
void setWarmStartShiftU(bool shift_u)
Definition: full_discretization_grid_move_blocking_base.h:95
corbo::FullDiscretizationGridMoveBlockingBase::getStateAndControlTimeSeries
void getStateAndControlTimeSeries(TimeSeries::Ptr x_sequence, TimeSeries::Ptr u_sequence, double t_max=CORBO_INF_DBL) const override
Return state and control trajectory as time series object (shared instance)
Definition: full_discretization_grid_move_blocking_base.cpp:51
corbo::SystemDynamicsInterface::Ptr
std::shared_ptr< SystemDynamicsInterface > Ptr
Definition: system_dynamics_interface.h:91
corbo::FullDiscretizationGridMoveBlockingBase::_blocking_vector
Eigen::VectorXi _blocking_vector
Definition: full_discretization_grid_move_blocking_base.h:103
corbo::FullDiscretizationGridMoveBlockingBase::~FullDiscretizationGridMoveBlockingBase
virtual ~FullDiscretizationGridMoveBlockingBase()=default
Eigen::Ref
A matrix or vector expression mapping an existing expression.
Definition: Ref.h:192
corbo::FullDiscretizationGridMoveBlockingBase::computeActiveVertices
void computeActiveVertices() override
Definition: full_discretization_grid_move_blocking_base.cpp:300
corbo::FullDiscretizationGridMoveBlockingBase::initializeSequences
void initializeSequences(const Eigen::VectorXd &x0, const Eigen::VectorXd &xf, ReferenceTrajectoryInterface &uref, NlpFunctions &nlp_fun) override
Definition: full_discretization_grid_move_blocking_base.cpp:99
corbo::FullDiscretizationGridMoveBlockingBase::getBlockingMatrix
void getBlockingMatrix(Eigen::Ref< Eigen::VectorXi > B)
Definition: full_discretization_grid_move_blocking_base.h:92
corbo::TimeSeries::Ptr
std::shared_ptr< TimeSeries > Ptr
Definition: time_series.h:108
corbo::FullDiscretizationGridMoveBlockingBase::Ptr
std::shared_ptr< FullDiscretizationGridMoveBlockingBase > Ptr
Definition: full_discretization_grid_move_blocking_base.h:79
corbo::FullDiscretizationGridMoveBlockingBase::warmStartShifting
void warmStartShifting(const Eigen::VectorXd &x0) override
Definition: full_discretization_grid_move_blocking_base.cpp:209
corbo::FullDiscretizationGridMoveBlockingBase::isValid
bool isValid() const override
Definition: full_discretization_grid_move_blocking_base.cpp:93


control_box_rst
Author(s): Christoph Rösmann
autogenerated on Wed Mar 2 2022 00:05:45