Eigen  3.4.90 (git rev 5a9f66fb35d03a4da9ef8976e67a61b30aa16dcf)
 
Loading...
Searching...
No Matches
Determinant.h
1// This file is part of Eigen, a lightweight C++ template library
2// for linear algebra.
3//
4// Copyright (C) 2008 Benoit Jacob <[email protected]>
5//
6// This Source Code Form is subject to the terms of the Mozilla
7// Public License v. 2.0. If a copy of the MPL was not distributed
8// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
9
10#ifndef EIGEN_DETERMINANT_H
11#define EIGEN_DETERMINANT_H
12
13// IWYU pragma: private
14#include "./InternalHeaderCheck.h"
15
16namespace Eigen {
17
18namespace internal {
19
20template <typename Derived>
21EIGEN_DEVICE_FUNC inline const typename Derived::Scalar bruteforce_det3_helper(const MatrixBase<Derived>& matrix, int a,
22 int b, int c) {
23 return matrix.coeff(0, a) * (matrix.coeff(1, b) * matrix.coeff(2, c) - matrix.coeff(1, c) * matrix.coeff(2, b));
24}
25
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();
31 }
32};
33
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); }
37};
38
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);
43 }
44};
45
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);
50 }
51};
52
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));
69 }
70
71 protected:
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);
74 }
75
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)));
80 }
81};
82
83} // end namespace internal
84
89template <typename Derived>
90EIGEN_DEVICE_FUNC inline typename internal::traits<Derived>::Scalar MatrixBase<Derived>::determinant() const {
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());
94}
95
96} // end namespace Eigen
97
98#endif // EIGEN_DETERMINANT_H
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