Public Types | Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
corbo::NonUniformFullDiscretizationGridBase Class Referenceabstract

#include <non_uniform_full_discretization_grid_base.h>

Inheritance diagram for corbo::NonUniformFullDiscretizationGridBase:
Inheritance graph
[legend]

Public Types

enum  CostIntegrationRule { CostIntegrationRule::LeftSum, CostIntegrationRule::TrapezoidalRule }
 
using Ptr = std::shared_ptr< NonUniformFullDiscretizationGridBase >
 
using UPtr = std::unique_ptr< NonUniformFullDiscretizationGridBase >
 
- Public Types inherited from corbo::DiscretizationGridInterface
using Ptr = std::shared_ptr< DiscretizationGridInterface >
 
using UPtr = std::unique_ptr< DiscretizationGridInterface >
 
- Public Types inherited from corbo::VertexSetInterface
using Ptr = std::shared_ptr< VertexSetInterface >
 

Public Member Functions

void clear () override
 
std::vector< VertexInterface * > & getActiveVertices () override
 
double getDtRef () const
 
void getDts (std::vector< double > &dts) const
 
double getFinalTime () const override
 
bool getFirstControlInput (Eigen::VectorXd &u0) override
 
double getFirstDt () const override
 
double getInitialDt () const override
 
int getInitialN () const override
 
DiscretizationGridInterface::Ptr getInstance () const override=0
 Return a newly created shared instance of the implemented class. More...
 
int getN () const override
 
int getNRef () const
 
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) More...
 
void getVertices (std::vector< VertexInterface *> &vertices) override
 
bool hasConstantControls () const override
 
bool hasSingleDt () const override
 
bool isEmpty () const override
 
bool isTimeVariableGrid () const override
 
bool isUniformGrid () const override
 
bool isValid () const
 
 NonUniformFullDiscretizationGridBase ()=default
 
bool providesStateTrajectory () const override
 
void setCostIntegrationRule (CostIntegrationRule integration)
 
void setDtRef (double dt)
 
void setFiniteDifferencesCollocationMethod (FiniteDifferencesCollocationInterface::Ptr fd_eval)
 
void setInitialDt (double dt) override
 
void setN (int n, bool try_resample=true) override
 Return dimension of the control input dimension in the grid. More...
 
void setNRef (int n)
 
void setWarmStart (bool active)
 
void setXfFixed (const Eigen::Matrix< bool, -1, 1 > &xf_fixed)
 
GridUpdateResult update (const Eigen::VectorXd &x0, ReferenceTrajectoryInterface &xref, ReferenceTrajectoryInterface &uref, NlpFunctions &nlp_fun, OptimizationEdgeSet &edges, SystemDynamicsInterface::Ptr dynamics, bool new_run, const Time &t, ReferenceTrajectoryInterface *sref=nullptr, const Eigen::VectorXd *prev_u=nullptr, double prev_u_dt=0, ReferenceTrajectoryInterface *xinit=nullptr, ReferenceTrajectoryInterface *uinit=nullptr) override
 
virtual ~NonUniformFullDiscretizationGridBase ()=default
 
- Public Member Functions inherited from corbo::DiscretizationGridInterface
 DiscretizationGridInterface ()=default
 
 DiscretizationGridInterface (int state_dim, int control_dim)
 
virtual ~DiscretizationGridInterface ()=default
 Virtual destructor. More...
 
- Public Member Functions inherited from corbo::VertexSetInterface
void applyIncrementNonFixed (const Eigen::Ref< const Eigen::VectorXd > &increment)
 Active vertices related methods. More...
 
void applyIncrementNonFixed (int idx, double increment)
 
void backupParametersActiveVertices ()
 
void clearConnectedEdges ()
 
void computeVertexIndices ()
 Precompute vertex indices in the hyper-graph (e.g. for the Jacobian or Hessian structure) More...
 
void discardBackupParametersActiveVertices (bool all=false)
 
void getBounds (Eigen::Ref< Eigen::VectorXd > lb, Eigen::Ref< Eigen::VectorXd > ub)
 
double getLowerBound (int idx)
 
int getParameterDimension ()
 
double getParameterValue (int idx)
 
void getParameterVector (Eigen::Ref< Eigen::VectorXd > x)
 
double getUpperBound (int idx)
 
bool isModified () const
 
void restoreBackupParametersActiveVertices (bool keep_backup)
 
void setBounds (const Eigen::Ref< const Eigen::VectorXd > &lb, const Eigen::Ref< const Eigen::VectorXd > &ub)
 
void setLowerBound (int idx, double lb)
 
void setModified (bool modified)
 
void setParameterValue (int idx, double x)
 
void setParameterVector (const Eigen::Ref< const Eigen::VectorXd > &x)
 
void setUpperBound (int idx, double ub)
 
 VertexSetInterface ()
 
virtual ~VertexSetInterface ()
 Virtual destructor. More...
 

Protected Member Functions

virtual bool adaptGrid (bool new_run, NlpFunctions &nlp_fun)
 
bool checkAndInitializeXfFixedFlags (int dim_x)
 
void computeActiveVertices () override
 
virtual void createEdges (NlpFunctions &nlp_fun, OptimizationEdgeSet &edges, SystemDynamicsInterface::Ptr dynamics)=0
 
int findNearestState (const Eigen::VectorXd &x0)
 
void initializeSequences (const Eigen::VectorXd &x0, const Eigen::VectorXd &xf, ReferenceTrajectoryInterface &uref, NlpFunctions &nlp_fun)
 
void initializeSequences (const Eigen::VectorXd &x0, const Eigen::VectorXd &xf, ReferenceTrajectoryInterface &xref, ReferenceTrajectoryInterface &uref, NlpFunctions &nlp_fun)
 
virtual bool isDtFixedIntended () const
 
virtual bool isGridAdaptActive () const
 
virtual bool isMovingHorizonWarmStartActive () const
 
void updateBounds (const NlpFunctions &nlp_fun)
 
void warmStartShifting (const Eigen::VectorXd &x0)
 
- Protected Member Functions inherited from corbo::DiscretizationGridInterface
void setLastControlRef (const Eigen::VectorXd &last_u_ref)
 
void setPreviousControl (const Eigen::VectorXd &prev_u, double prev_u_dt)
 
- Protected Member Functions inherited from corbo::VertexSetInterface
void setVertexIdx (VertexInterface &vertex, int idx)
 

Protected Attributes

std::vector< VertexInterface * > _active_vertices
 
CostIntegrationRule _cost_integration
 
double _dt_lb = 0
 
double _dt_ref = 0.1
 
std::vector< ScalarVertex_dt_seq
 
double _dt_ub = CORBO_INF_DBL
 
FiniteDifferencesCollocationInterface::Ptr _fd_eval = std::make_shared<CrankNicolsonDiffCollocation>()
 
bool _first_run = true
 
int _n_adapt = 0
 
int _n_ref = 11
 
std::vector< VectorVertex_u_seq
 
bool _warm_start = false
 
std::vector< VectorVertex_x_seq
 
PartiallyFixedVectorVertex _xf
 
Eigen::Matrix< bool, -1, 1 > _xf_fixed
 
- Protected Attributes inherited from corbo::DiscretizationGridInterface
VectorVertex _u_prev
 
ScalarVertex _u_prev_dt
 
VectorVertex _u_ref
 
- Protected Attributes inherited from corbo::VertexSetInterface
bool _modified = true
 

Additional Inherited Members

- Static Public Member Functions inherited from corbo::DiscretizationGridInterface
static Factory< DiscretizationGridInterface > & getFactory ()
 Get access to the accociated factory. More...
 

Detailed Description

Definition at line 39 of file non_uniform_full_discretization_grid_base.h.

Member Typedef Documentation

◆ Ptr

Definition at line 42 of file non_uniform_full_discretization_grid_base.h.

◆ UPtr

Definition at line 43 of file non_uniform_full_discretization_grid_base.h.

Member Enumeration Documentation

◆ CostIntegrationRule

Enumerator
LeftSum 
TrapezoidalRule 

Definition at line 45 of file non_uniform_full_discretization_grid_base.h.

Constructor & Destructor Documentation

◆ NonUniformFullDiscretizationGridBase()

corbo::NonUniformFullDiscretizationGridBase::NonUniformFullDiscretizationGridBase ( )
default

◆ ~NonUniformFullDiscretizationGridBase()

virtual corbo::NonUniformFullDiscretizationGridBase::~NonUniformFullDiscretizationGridBase ( )
virtualdefault

Member Function Documentation

◆ adaptGrid()

virtual bool corbo::NonUniformFullDiscretizationGridBase::adaptGrid ( bool  new_run,
NlpFunctions nlp_fun 
)
inlineprotectedvirtual

◆ checkAndInitializeXfFixedFlags()

bool corbo::NonUniformFullDiscretizationGridBase::checkAndInitializeXfFixedFlags ( int  dim_x)
protected

◆ clear()

void corbo::NonUniformFullDiscretizationGridBase::clear ( )
overridevirtual

◆ computeActiveVertices()

void corbo::NonUniformFullDiscretizationGridBase::computeActiveVertices ( )
overrideprotectedvirtual

◆ createEdges()

virtual void corbo::NonUniformFullDiscretizationGridBase::createEdges ( NlpFunctions nlp_fun,
OptimizationEdgeSet edges,
SystemDynamicsInterface::Ptr  dynamics 
)
protectedpure virtual

◆ findNearestState()

int corbo::NonUniformFullDiscretizationGridBase::findNearestState ( const Eigen::VectorXd &  x0)
protected

◆ getActiveVertices()

std::vector<VertexInterface*>& corbo::NonUniformFullDiscretizationGridBase::getActiveVertices ( )
inlineoverridevirtual

◆ getDtRef()

double corbo::NonUniformFullDiscretizationGridBase::getDtRef ( ) const
inline

Definition at line 89 of file non_uniform_full_discretization_grid_base.h.

◆ getDts()

void corbo::NonUniformFullDiscretizationGridBase::getDts ( std::vector< double > &  dts) const

◆ getFinalTime()

double corbo::NonUniformFullDiscretizationGridBase::getFinalTime ( ) const
overridevirtual

◆ getFirstControlInput()

bool corbo::NonUniformFullDiscretizationGridBase::getFirstControlInput ( Eigen::VectorXd &  u0)
overridevirtual

◆ getFirstDt()

double corbo::NonUniformFullDiscretizationGridBase::getFirstDt ( ) const
inlineoverridevirtual

◆ getInitialDt()

double corbo::NonUniformFullDiscretizationGridBase::getInitialDt ( ) const
inlineoverridevirtual

◆ getInitialN()

int corbo::NonUniformFullDiscretizationGridBase::getInitialN ( ) const
inlineoverridevirtual

◆ getInstance()

DiscretizationGridInterface::Ptr corbo::NonUniformFullDiscretizationGridBase::getInstance ( ) const
overridepure virtual

Return a newly created shared instance of the implemented class.

Implements corbo::DiscretizationGridInterface.

Implemented in corbo::NonUniformFiniteDifferencesVariableGrid.

◆ getN()

int corbo::NonUniformFullDiscretizationGridBase::getN ( ) const
inlineoverridevirtual

◆ getNRef()

int corbo::NonUniformFullDiscretizationGridBase::getNRef ( ) const
inline

Definition at line 85 of file non_uniform_full_discretization_grid_base.h.

◆ getStateAndControlTimeSeries()

void corbo::NonUniformFullDiscretizationGridBase::getStateAndControlTimeSeries ( TimeSeries::Ptr  x_sequence,
TimeSeries::Ptr  u_sequence,
double  t_max = CORBO_INF_DBL 
) const
overridevirtual

Return state and control trajectory as time series object (shared instance)

Implements corbo::DiscretizationGridInterface.

Definition at line 469 of file non_uniform_full_discretization_grid_base.cpp.

◆ getVertices()

void corbo::NonUniformFullDiscretizationGridBase::getVertices ( std::vector< VertexInterface *> &  vertices)
overridevirtual

◆ hasConstantControls()

bool corbo::NonUniformFullDiscretizationGridBase::hasConstantControls ( ) const
inlineoverridevirtual

◆ hasSingleDt()

bool corbo::NonUniformFullDiscretizationGridBase::hasSingleDt ( ) const
inlineoverridevirtual

◆ initializeSequences() [1/2]

void corbo::NonUniformFullDiscretizationGridBase::initializeSequences ( const Eigen::VectorXd &  x0,
const Eigen::VectorXd &  xf,
ReferenceTrajectoryInterface uref,
NlpFunctions nlp_fun 
)
protected

◆ initializeSequences() [2/2]

void corbo::NonUniformFullDiscretizationGridBase::initializeSequences ( const Eigen::VectorXd &  x0,
const Eigen::VectorXd &  xf,
ReferenceTrajectoryInterface xref,
ReferenceTrajectoryInterface uref,
NlpFunctions nlp_fun 
)
protected

◆ isDtFixedIntended()

virtual bool corbo::NonUniformFullDiscretizationGridBase::isDtFixedIntended ( ) const
inlineprotectedvirtual

◆ isEmpty()

bool corbo::NonUniformFullDiscretizationGridBase::isEmpty ( ) const
inlineoverridevirtual

◆ isGridAdaptActive()

virtual bool corbo::NonUniformFullDiscretizationGridBase::isGridAdaptActive ( ) const
inlineprotectedvirtual

◆ isMovingHorizonWarmStartActive()

virtual bool corbo::NonUniformFullDiscretizationGridBase::isMovingHorizonWarmStartActive ( ) const
inlineprotectedvirtual

◆ isTimeVariableGrid()

bool corbo::NonUniformFullDiscretizationGridBase::isTimeVariableGrid ( ) const
inlineoverridevirtual

◆ isUniformGrid()

bool corbo::NonUniformFullDiscretizationGridBase::isUniformGrid ( ) const
inlineoverridevirtual

◆ isValid()

bool corbo::NonUniformFullDiscretizationGridBase::isValid ( ) const
inline

Definition at line 74 of file non_uniform_full_discretization_grid_base.h.

◆ providesStateTrajectory()

bool corbo::NonUniformFullDiscretizationGridBase::providesStateTrajectory ( ) const
inlineoverridevirtual

◆ setCostIntegrationRule()

void corbo::NonUniformFullDiscretizationGridBase::setCostIntegrationRule ( CostIntegrationRule  integration)
inline

Definition at line 95 of file non_uniform_full_discretization_grid_base.h.

◆ setDtRef()

void corbo::NonUniformFullDiscretizationGridBase::setDtRef ( double  dt)
inline

Definition at line 88 of file non_uniform_full_discretization_grid_base.h.

◆ setFiniteDifferencesCollocationMethod()

void corbo::NonUniformFullDiscretizationGridBase::setFiniteDifferencesCollocationMethod ( FiniteDifferencesCollocationInterface::Ptr  fd_eval)
inline

Definition at line 94 of file non_uniform_full_discretization_grid_base.h.

◆ setInitialDt()

void corbo::NonUniformFullDiscretizationGridBase::setInitialDt ( double  dt)
inlineoverridevirtual

◆ setN()

void corbo::NonUniformFullDiscretizationGridBase::setN ( int  n,
bool  try_resample = true 
)
inlineoverridevirtual

Return dimension of the control input dimension in the grid.

Implements corbo::DiscretizationGridInterface.

Definition at line 76 of file non_uniform_full_discretization_grid_base.h.

◆ setNRef()

void corbo::NonUniformFullDiscretizationGridBase::setNRef ( int  n)

◆ setWarmStart()

void corbo::NonUniformFullDiscretizationGridBase::setWarmStart ( bool  active)
inline

Definition at line 90 of file non_uniform_full_discretization_grid_base.h.

◆ setXfFixed()

void corbo::NonUniformFullDiscretizationGridBase::setXfFixed ( const Eigen::Matrix< bool, -1, 1 > &  xf_fixed)
inline

Definition at line 97 of file non_uniform_full_discretization_grid_base.h.

◆ update()

GridUpdateResult corbo::NonUniformFullDiscretizationGridBase::update ( const Eigen::VectorXd &  x0,
ReferenceTrajectoryInterface xref,
ReferenceTrajectoryInterface uref,
NlpFunctions nlp_fun,
OptimizationEdgeSet edges,
SystemDynamicsInterface::Ptr  dynamics,
bool  new_run,
const Time t,
ReferenceTrajectoryInterface sref = nullptr,
const Eigen::VectorXd *  prev_u = nullptr,
double  prev_u_dt = 0,
ReferenceTrajectoryInterface xinit = nullptr,
ReferenceTrajectoryInterface uinit = nullptr 
)
overridevirtual

◆ updateBounds()

void corbo::NonUniformFullDiscretizationGridBase::updateBounds ( const NlpFunctions nlp_fun)
protected

◆ warmStartShifting()

void corbo::NonUniformFullDiscretizationGridBase::warmStartShifting ( const Eigen::VectorXd &  x0)
protected

Member Data Documentation

◆ _active_vertices

std::vector<VertexInterface*> corbo::NonUniformFullDiscretizationGridBase::_active_vertices
protected

Definition at line 141 of file non_uniform_full_discretization_grid_base.h.

◆ _cost_integration

CostIntegrationRule corbo::NonUniformFullDiscretizationGridBase::_cost_integration
protected

Definition at line 154 of file non_uniform_full_discretization_grid_base.h.

◆ _dt_lb

double corbo::NonUniformFullDiscretizationGridBase::_dt_lb = 0
protected

Definition at line 151 of file non_uniform_full_discretization_grid_base.h.

◆ _dt_ref

double corbo::NonUniformFullDiscretizationGridBase::_dt_ref = 0.1
protected

Definition at line 145 of file non_uniform_full_discretization_grid_base.h.

◆ _dt_seq

std::vector<ScalarVertex> corbo::NonUniformFullDiscretizationGridBase::_dt_seq
protected

Definition at line 139 of file non_uniform_full_discretization_grid_base.h.

◆ _dt_ub

double corbo::NonUniformFullDiscretizationGridBase::_dt_ub = CORBO_INF_DBL
protected

Definition at line 152 of file non_uniform_full_discretization_grid_base.h.

◆ _fd_eval

FiniteDifferencesCollocationInterface::Ptr corbo::NonUniformFullDiscretizationGridBase::_fd_eval = std::make_shared<CrankNicolsonDiffCollocation>()
protected

Definition at line 135 of file non_uniform_full_discretization_grid_base.h.

◆ _first_run

bool corbo::NonUniformFullDiscretizationGridBase::_first_run = true
protected

Definition at line 147 of file non_uniform_full_discretization_grid_base.h.

◆ _n_adapt

int corbo::NonUniformFullDiscretizationGridBase::_n_adapt = 0
protected

Definition at line 144 of file non_uniform_full_discretization_grid_base.h.

◆ _n_ref

int corbo::NonUniformFullDiscretizationGridBase::_n_ref = 11
protected

Definition at line 143 of file non_uniform_full_discretization_grid_base.h.

◆ _u_seq

std::vector<VectorVertex> corbo::NonUniformFullDiscretizationGridBase::_u_seq
protected

Definition at line 138 of file non_uniform_full_discretization_grid_base.h.

◆ _warm_start

bool corbo::NonUniformFullDiscretizationGridBase::_warm_start = false
protected

Definition at line 146 of file non_uniform_full_discretization_grid_base.h.

◆ _x_seq

std::vector<VectorVertex> corbo::NonUniformFullDiscretizationGridBase::_x_seq
protected

Definition at line 137 of file non_uniform_full_discretization_grid_base.h.

◆ _xf

PartiallyFixedVectorVertex corbo::NonUniformFullDiscretizationGridBase::_xf
protected

Definition at line 140 of file non_uniform_full_discretization_grid_base.h.

◆ _xf_fixed

Eigen::Matrix<bool, -1, 1> corbo::NonUniformFullDiscretizationGridBase::_xf_fixed
protected

Definition at line 150 of file non_uniform_full_discretization_grid_base.h.


The documentation for this class was generated from the following files:


control_box_rst
Author(s): Christoph Rösmann
autogenerated on Mon Feb 28 2022 22:08:03