10#ifndef EIGEN_DETERMINANT_H
11#define EIGEN_DETERMINANT_H
14#include "./InternalHeaderCheck.h"
20template <
typename Derived>
21EIGEN_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));
26template <
typename Derived,
int DeterminantType = Derived::RowsAtCompileTime>
27struct 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();
34template <
typename Derived>
35struct determinant_impl<Derived, 1> {
36 static inline EIGEN_DEVICE_FUNC
typename traits<Derived>::Scalar run(
const Derived& m) {
return m.coeff(0, 0); }
39template <
typename Derived>
40struct 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);
46template <
typename Derived>
47struct 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);
53template <
typename Derived>
54struct 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)));
89template <
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());
Base class for all dense matrices, vectors, and expressions.
Definition MatrixBase.h:52
Namespace containing all symbols from the Eigen library.
Definition Core:137
const int Dynamic
Definition Constants.h:25