10 #ifndef EIGEN_DETERMINANT_H 11 #define EIGEN_DETERMINANT_H 14 #include "./InternalHeaderCheck.h" 20 template <
typename Derived>
21 EIGEN_DEVICE_FUNC
inline const typename Derived::Scalar bruteforce_det3_helper(
const MatrixBase<Derived>& matrix,
int a,
23 return matrix.coeff(0, a) * (matrix.coeff(1, b) * matrix.coeff(2, c) - matrix.coeff(1, c) * matrix.coeff(2, b));
26 template <
typename Derived,
int DeterminantType = Derived::RowsAtCompileTime>
27 struct determinant_impl {
28 static inline typename traits<Derived>::Scalar run(
const Derived& m) {
29 if (Derived::ColsAtCompileTime ==
Dynamic && m.rows() == 0)
return typename traits<Derived>::Scalar(1);
30 return m.partialPivLu().determinant();
34 template <
typename Derived>
35 struct determinant_impl<Derived, 1> {
36 static inline EIGEN_DEVICE_FUNC
typename traits<Derived>::Scalar run(
const Derived& m) {
return m.coeff(0, 0); }
39 template <
typename Derived>
40 struct determinant_impl<Derived, 2> {
41 static inline EIGEN_DEVICE_FUNC
typename traits<Derived>::Scalar run(
const Derived& m) {
42 return m.coeff(0, 0) * m.coeff(1, 1) - m.coeff(1, 0) * m.coeff(0, 1);
46 template <
typename Derived>
47 struct determinant_impl<Derived, 3> {
48 static inline EIGEN_DEVICE_FUNC
typename traits<Derived>::Scalar run(
const Derived& m) {
49 return bruteforce_det3_helper(m, 0, 1, 2) - bruteforce_det3_helper(m, 1, 0, 2) + bruteforce_det3_helper(m, 2, 0, 1);
53 template <
typename Derived>
54 struct determinant_impl<Derived, 4> {
55 typedef typename traits<Derived>::Scalar Scalar;
56 static EIGEN_DEVICE_FUNC Scalar run(
const Derived& m) {
57 Scalar d2_01 = det2(m, 0, 1);
58 Scalar d2_02 = det2(m, 0, 2);
59 Scalar d2_03 = det2(m, 0, 3);
60 Scalar d2_12 = det2(m, 1, 2);
61 Scalar d2_13 = det2(m, 1, 3);
62 Scalar d2_23 = det2(m, 2, 3);
63 Scalar d3_0 = det3(m, 1, d2_23, 2, d2_13, 3, d2_12);
64 Scalar d3_1 = det3(m, 0, d2_23, 2, d2_03, 3, d2_02);
65 Scalar d3_2 = det3(m, 0, d2_13, 1, d2_03, 3, d2_01);
66 Scalar d3_3 = det3(m, 0, d2_12, 1, d2_02, 2, d2_01);
67 return internal::pmadd(static_cast<Scalar>(-m(0, 3)), d3_0, static_cast<Scalar>(m(1, 3) * d3_1)) +
68 internal::pmadd(static_cast<Scalar>(-m(2, 3)), d3_2, static_cast<Scalar>(m(3, 3) * d3_3));
72 static EIGEN_DEVICE_FUNC Scalar det2(
const Derived& m,
Index i0,
Index i1) {
73 return m(i0, 0) * m(i1, 1) - m(i1, 0) * m(i0, 1);
76 static EIGEN_DEVICE_FUNC Scalar det3(
const Derived& m,
Index i0,
const Scalar& d0,
Index i1,
const Scalar& d1,
77 Index i2,
const Scalar& d2) {
78 return internal::pmadd(m(i0, 2), d0,
79 internal::pmadd(static_cast<Scalar>(-m(i1, 2)), d1, static_cast<Scalar>(m(i2, 2) * d2)));
89 template <
typename Derived>
91 eigen_assert(rows() == cols());
92 typedef typename internal::nested_eval<Derived, Base::RowsAtCompileTime>::type Nested;
93 return internal::determinant_impl<internal::remove_all_t<Nested>>::run(derived());
98 #endif // EIGEN_DETERMINANT_H Namespace containing all symbols from the Eigen library.
Definition: B01_Experimental.dox:1
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:82
const int Dynamic
Definition: Constants.h:25
Scalar determinant() const
Definition: Determinant.h:90