16 #ifndef OPENKALMAN_EIGEN_SELFADJOINTVIEW_HPP 17 #define OPENKALMAN_EIGEN_SELFADJOINTVIEW_HPP 19 #include <type_traits> 26 template<
typename MatrixType,
unsigned int UpLo>
31 using Xpr = Eigen::SelfAdjointView<MatrixType, UpLo>;
32 using IndexType =
typename MatrixType::Index;
39 template<
typename Arg>
43 template<
typename Arg,
typename N>
50 template<
typename Arg>
53 return std::forward<Arg>(arg).nestedExpression();
57 template<
typename Arg>
58 static constexpr
auto get_constant(
const Arg& arg)
66 else return std::monostate{};
68 else return std::monostate{};
72 template<
typename Arg>
73 static constexpr
auto get_constant_diagonal(
const Arg& arg)
79 template<Applicability b>
80 static constexpr
bool one_dimensional = OpenKalman::one_dimensional<MatrixType, b>;
83 template<Applicability b>
84 static constexpr
bool is_square = square_shaped<MatrixType, b>;
87 template<TriangleType t>
88 static constexpr
bool is_triangular = diagonal_matrix<MatrixType>;
91 static constexpr
bool is_triangular_adapter =
false;
94 static constexpr
bool is_hermitian =
95 (not values::complex<typename Eigen::internal::traits<MatrixType>::Scalar>) or
111 #ifdef __cpp_concepts 112 template<Eigen3::eigen_SelfAdjo
intView M>
114 template<
typename M, std::enable_if_t<Eigen3::eigen_SelfAdjo
intView<M>,
int> = 0>
120 #endif //OPENKALMAN_EIGEN_SELFADJOINTVIEW_HPP constexpr auto count_indices(const T &t)
Get the number of indices available to address the components of an indexible object.
Definition: count_indices.hpp:33
A hermitian matrix wrapper.
Definition: HermitianAdapter.hpp:31
constexpr bool one_dimensional
Specifies that a type is one-dimensional in every index.
Definition: one_dimensional.hpp:83
Definition: indexible_object_traits.hpp:36
typename scalar_type_of< T >::type scalar_type_of_t
helper template for scalar_type_of.
Definition: scalar_type_of.hpp:54
constexpr bool complex
T is a values::value that reduces to std::complex or a custom complex type.
Definition: complex.hpp:46
Definition: eigen-comma-initializers.hpp:20
HermitianAdapterType
The type of a hermitian adapter, indicating which triangle of the nested matrix is used...
Definition: global-definitions.hpp:78
constexpr bool not_complex
T is a values::value in which either its type is not a values::complex or its imaginary component is ...
Definition: not_complex.hpp:47
HermitianAdapter(M &&) -> HermitianAdapter< std::conditional_t< hermitian_adapter< M >, nested_object_of_t< M >, M >, hermitian_adapter< M > ? hermitian_adapter_type_of_v< M > :HermitianAdapterType::lower >
Deduction guide for converting Eigen::SelfAdjointView to HermitianAdapter.
An upper-right triangular matrix.
The constant associated with T, assuming T is a constant_matrix.
Definition: constant_coefficient.hpp:36
The root namespace for OpenKalman.
Definition: basics.hpp:34
The constant associated with T, assuming T is a constant_diagonal_matrix.
Definition: constant_diagonal_coefficient.hpp:32
constexpr bool fixed
T is a values::value that is determinable at compile time.
Definition: fixed.hpp:60
decltype(auto) constexpr nested_object(Arg &&arg)
Retrieve a nested object of Arg, if it exists.
Definition: nested_object.hpp:34
A lower-left triangular matrix.
constexpr auto get_vector_space_descriptor(const T &t, const N &n)
Get the coordinates::pattern object for index N of indexible object T.
Definition: get_vector_space_descriptor.hpp:56