aligator  0.6.1
A primal-dual augmented Lagrangian-type solver for nonlinear trajectory optimization.
Loading...
Searching...
No Matches
aligator::gar::RiccatiSolverDense< _Scalar > Class Template Reference

A stagewise-dense Riccati solver. More...

#include </home/runner/work/aligator/aligator/gar/include/aligator/gar/dense-riccati.hpp>

Inheritance diagram for aligator::gar::RiccatiSolverDense< _Scalar >:
[legend]
Collaboration diagram for aligator::gar::RiccatiSolverDense< _Scalar >:
[legend]

Classes

struct  FactorData
 

Public Types

using Scalar = _Scalar
 
using Base = RiccatiSolverBase<Scalar>
 
using BlkMat44 = BlkMatrix<MatrixXs, 4, 4>
 
using BlkRowMat41 = BlkMatrix<RowMatrixXs, 4, 1>
 
using BlkVec4 = BlkMatrix<VectorXs, 4, 1>
 
using KnotType = LQRKnotTpl<Scalar>
 
- Public Types inherited from aligator::gar::RiccatiSolverBase< _Scalar >
using Scalar = _Scalar
 

Public Member Functions

 ALIGATOR_DYNAMIC_TYPEDEFS_WITH_ROW_TYPES (Scalar)
 
 RiccatiSolverDense (const LQRProblemTpl< Scalar > &problem)
 
bool backward (const Scalar mudyn, const Scalar mueq)
 
bool forward (std::vector< VectorXs > &xs, std::vector< VectorXs > &us, std::vector< VectorXs > &vs, std::vector< VectorXs > &lbdas, const std::optional< ConstVectorRef > &theta=std::nullopt) const
 
VectorRef getFeedforward (size_t i)
 
RowMatrixRef getFeedback (size_t i)
 
- Public Member Functions inherited from aligator::gar::RiccatiSolverBase< _Scalar >
 ALIGATOR_DYNAMIC_TYPEDEFS_WITH_ROW_TYPES (Scalar)
 
virtual void collapseFeedback ()
 
virtual ~RiccatiSolverBase ()=default
 

Static Public Member Functions

static FactorData init_factor (const LQRKnotTpl< Scalar > &knot)
 

Public Attributes

std::vector< FactorDatadatas
 
std::vector< MatrixXs > Pxx
 
std::vector< MatrixXs > Pxt
 
std::vector< MatrixXs > Ptt
 
std::vector< VectorXs > px
 
std::vector< VectorXs > pt
 
struct { 
 
   BlkMatrix< MatrixXs, 2, 2 >   mat 
 
   BlkMatrix< VectorXs, 2, 1 >   ff 
 
   BlkMatrix< MatrixXs, 2, 1 >   fth 
 
   Eigen::BunchKaufman< MatrixXs >   ldl 
 
kkt0 
 
VectorXs thGrad
 
MatrixXs thHess
 

Protected Member Functions

void initialize ()
 

Protected Attributes

const LQRProblemTpl< Scalar > * problem_
 

Detailed Description

template<typename _Scalar>
class aligator::gar::RiccatiSolverDense< _Scalar >

A stagewise-dense Riccati solver.

Definition at line 14 of file dense-riccati.hpp.

Member Typedef Documentation

◆ Scalar

template<typename _Scalar >
using aligator::gar::RiccatiSolverDense< _Scalar >::Scalar = _Scalar

Definition at line 16 of file dense-riccati.hpp.

◆ Base

template<typename _Scalar >
using aligator::gar::RiccatiSolverDense< _Scalar >::Base = RiccatiSolverBase<Scalar>

Definition at line 18 of file dense-riccati.hpp.

◆ BlkMat44

template<typename _Scalar >
using aligator::gar::RiccatiSolverDense< _Scalar >::BlkMat44 = BlkMatrix<MatrixXs, 4, 4>

Definition at line 19 of file dense-riccati.hpp.

◆ BlkRowMat41

template<typename _Scalar >
using aligator::gar::RiccatiSolverDense< _Scalar >::BlkRowMat41 = BlkMatrix<RowMatrixXs, 4, 1>

Definition at line 20 of file dense-riccati.hpp.

◆ BlkVec4

template<typename _Scalar >
using aligator::gar::RiccatiSolverDense< _Scalar >::BlkVec4 = BlkMatrix<VectorXs, 4, 1>

Definition at line 21 of file dense-riccati.hpp.

◆ KnotType

template<typename _Scalar >
using aligator::gar::RiccatiSolverDense< _Scalar >::KnotType = LQRKnotTpl<Scalar>

Definition at line 22 of file dense-riccati.hpp.

Constructor & Destructor Documentation

◆ RiccatiSolverDense()

template<typename _Scalar >
aligator::gar::RiccatiSolverDense< _Scalar >::RiccatiSolverDense ( const LQRProblemTpl< Scalar > & problem)
explicit

Member Function Documentation

◆ ALIGATOR_DYNAMIC_TYPEDEFS_WITH_ROW_TYPES()

template<typename _Scalar >
aligator::gar::RiccatiSolverDense< _Scalar >::ALIGATOR_DYNAMIC_TYPEDEFS_WITH_ROW_TYPES ( Scalar )

◆ init_factor()

template<typename _Scalar >
static FactorData aligator::gar::RiccatiSolverDense< _Scalar >::init_factor ( const LQRKnotTpl< Scalar > & knot)
inlinestatic

Definition at line 32 of file dense-riccati.hpp.

◆ backward()

template<typename _Scalar >
bool aligator::gar::RiccatiSolverDense< _Scalar >::backward ( const Scalar mudyn,
const Scalar mueq )
virtual

◆ forward()

template<typename _Scalar >
bool aligator::gar::RiccatiSolverDense< _Scalar >::forward ( std::vector< VectorXs > & xs,
std::vector< VectorXs > & us,
std::vector< VectorXs > & vs,
std::vector< VectorXs > & lbdas,
const std::optional< ConstVectorRef > & theta = std::nullopt ) const
virtual

◆ getFeedforward()

template<typename _Scalar >
VectorRef aligator::gar::RiccatiSolverDense< _Scalar >::getFeedforward ( size_t i)
inlinevirtual

Implements aligator::gar::RiccatiSolverBase< _Scalar >.

Definition at line 65 of file dense-riccati.hpp.

◆ getFeedback()

template<typename _Scalar >
RowMatrixRef aligator::gar::RiccatiSolverDense< _Scalar >::getFeedback ( size_t i)
inlinevirtual

Implements aligator::gar::RiccatiSolverBase< _Scalar >.

Definition at line 66 of file dense-riccati.hpp.

◆ initialize()

template<typename _Scalar >
void aligator::gar::RiccatiSolverDense< _Scalar >::initialize ( )
protected

Member Data Documentation

◆ datas

template<typename _Scalar >
std::vector<FactorData> aligator::gar::RiccatiSolverDense< _Scalar >::datas

Definition at line 42 of file dense-riccati.hpp.

◆ Pxx

template<typename _Scalar >
std::vector<MatrixXs> aligator::gar::RiccatiSolverDense< _Scalar >::Pxx

Definition at line 43 of file dense-riccati.hpp.

◆ Pxt

template<typename _Scalar >
std::vector<MatrixXs> aligator::gar::RiccatiSolverDense< _Scalar >::Pxt

Definition at line 44 of file dense-riccati.hpp.

◆ Ptt

template<typename _Scalar >
std::vector<MatrixXs> aligator::gar::RiccatiSolverDense< _Scalar >::Ptt

Definition at line 45 of file dense-riccati.hpp.

◆ px

template<typename _Scalar >
std::vector<VectorXs> aligator::gar::RiccatiSolverDense< _Scalar >::px

Definition at line 46 of file dense-riccati.hpp.

◆ pt

template<typename _Scalar >
std::vector<VectorXs> aligator::gar::RiccatiSolverDense< _Scalar >::pt

Definition at line 47 of file dense-riccati.hpp.

◆ mat

template<typename _Scalar >
BlkMatrix<MatrixXs, 2, 2> aligator::gar::RiccatiSolverDense< _Scalar >::mat

Definition at line 49 of file dense-riccati.hpp.

◆ ff

template<typename _Scalar >
BlkMatrix<VectorXs, 2, 1> aligator::gar::RiccatiSolverDense< _Scalar >::ff

Definition at line 50 of file dense-riccati.hpp.

◆ fth

template<typename _Scalar >
BlkMatrix<MatrixXs, 2, 1> aligator::gar::RiccatiSolverDense< _Scalar >::fth

Definition at line 51 of file dense-riccati.hpp.

◆ ldl

template<typename _Scalar >
Eigen::BunchKaufman<MatrixXs> aligator::gar::RiccatiSolverDense< _Scalar >::ldl

Definition at line 52 of file dense-riccati.hpp.

◆ [struct]

struct { ... } aligator::gar::RiccatiSolverDense< _Scalar >::kkt0

◆ thGrad

template<typename _Scalar >
VectorXs aligator::gar::RiccatiSolverDense< _Scalar >::thGrad

Definition at line 54 of file dense-riccati.hpp.

◆ thHess

template<typename _Scalar >
MatrixXs aligator::gar::RiccatiSolverDense< _Scalar >::thHess

Definition at line 55 of file dense-riccati.hpp.

◆ problem_

template<typename _Scalar >
const LQRProblemTpl<Scalar>* aligator::gar::RiccatiSolverDense< _Scalar >::problem_
protected

Definition at line 70 of file dense-riccati.hpp.


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