31 #include <Eigen/Dense> 32 #include <Eigen/Eigenvalues> 46 Eigen::MatrixXcd T = A_schur.
matrixT();
47 const Eigen::MatrixXcd& U = A_schur.
matrixU();
50 Eigen::MatrixXcd F = U.adjoint() * Q * U;
52 const int n = A.rows();
53 Eigen::MatrixXcd Y(n, n);
57 Eigen::MatrixXcd T_adjoint = T.adjoint();
61 for (
int k = n - 1; k >= 0; --k)
63 Eigen::VectorXcd rhs = F.col(k) + Y * T_adjoint.col(k);
65 const std::complex<double> offset = T_adjoint(k, k);
66 T.diagonal().array() += offset;
72 Y.col(k) = T_svd.
solve(-rhs);
74 if (k > 0) T.diagonal().array() -= offset;
78 X = (U * Y * U.adjoint()).
real();
87 Eigen::VectorXcd eigvals_A = A.eigenvalues();
89 for (
int i = 0; i < eigvals_A.size(); ++i)
91 for (
int j = i; j < eigvals_A.size(); ++j)
static bool hasUniqueSolution(const Eigen::Ref< const Eigen::MatrixXd > &A)
Determine if the Lyapunov equation exhibits a unique solution.
bool have_equal_size(const Eigen::MatrixBase< DerivedA > &matrix1, const Eigen::MatrixBase< DerivedB > &matrix2)
Determine if two matrices exhibit equal sizes/dimensions.
static bool solve(const Eigen::Ref< const Eigen::MatrixXd > &A, const Eigen::Ref< const Eigen::MatrixXd > &Q, Eigen::MatrixXd &X)
Solve continuous-time Lyapunov equation.
bool approx_equal(double a, double b, double epsilon=1e-6)
Check if two doubles are appoximately equal.
bool is_square(const Eigen::MatrixBase< Derived > &matrix)
Determine if a given matrix is square.
ComputationInfo info() const
Reports whether previous computation was successful.
const Solve< JacobiSVD< _MatrixType, QRPreconditioner >, Rhs > solve(const MatrixBase< Rhs > &b) const
MatrixType A(a, *n, *n, *lda)
A matrix or vector expression mapping an existing expression.
const ComplexMatrixType & matrixU() const
Returns the unitary matrix in the Schur decomposition.
Two-sided Jacobi SVD decomposition of a rectangular matrix.
JacobiSVD & compute(const MatrixType &matrix, unsigned int computationOptions)
Method performing the decomposition of given matrix using custom options.
EIGEN_DEVICE_FUNC const ImagReturnType imag() const
Performs a complex Schur decomposition of a real or complex square matrix.
const ComplexMatrixType & matrixT() const
Returns the triangular matrix in the Schur decomposition.