Rocstar  1.0
Rocstar multiphysics simulation application
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
determinant.h
Go to the documentation of this file.
1 // ======================================================================
2 //
3 // Copyright (c) 1999 The CGAL Consortium
4 
5 // This software and related documentation is part of the Computational
6 // Geometry Algorithms Library (CGAL).
7 // This software and documentation is provided "as-is" and without warranty
8 // of any kind. In no event shall the CGAL Consortium be liable for any
9 // damage of any kind.
10 //
11 // Every use of CGAL requires a license.
12 //
13 // Academic research and teaching license
14 // - For academic research and teaching purposes, permission to use and copy
15 // the software and its documentation is hereby granted free of charge,
16 // provided that it is not a component of a commercial product, and this
17 // notice appears in all copies of the software and related documentation.
18 //
19 // Commercial licenses
20 // - A commercial license is available through Algorithmic Solutions, who also
21 // markets LEDA (http://www.algorithmic-solutions.de).
22 // - Commercial users may apply for an evaluation license by writing to
23 // Algorithmic Solutions (contact@algorithmic-solutions.com).
24 //
25 // The CGAL Consortium consists of Utrecht University (The Netherlands),
26 // ETH Zurich (Switzerland), Free University of Berlin (Germany),
27 // INRIA Sophia-Antipolis (France), Martin-Luther-University Halle-Wittenberg
28 // (Germany), Max-Planck-Institute Saarbrucken (Germany), RISC Linz (Austria),
29 // and Tel-Aviv University (Israel).
30 //
31 // ----------------------------------------------------------------------
32 //
33 // release : CGAL-2.2
34 // release_date : 2000, September 30
35 //
36 // source : determinant.fw
37 // file : include/CGAL/determinant.h
38 // package : Kernel_basic (3.14)
39 // revision : 3.14
40 // revision_date : 15 Sep 2000
41 // author(s) : Sylvain Pion
42 // Stefan Schirra
43 //
44 // coordinator : MPI, Saarbruecken (<Stefan.Schirra>)
45 // email : contact@cgal.org
46 // www : http://www.cgal.org
47 //
48 // ======================================================================
49 
50 
51 #ifndef CGAL_DETERMINANT_H
52 #define CGAL_DETERMINANT_H
53 
55 
56 template <class FT>
57 inline
58 FT
60  const FT& a00, const FT& a01,
61  const FT& a10, const FT& a11)
62 {
63 // First compute the det2x2
64  const FT m01 = a00*a11 - a10*a01;
65  return m01;
66 }
67 
68 template <class FT>
70 FT
72  const FT& a00, const FT& a01, const FT& a02,
73  const FT& a10, const FT& a11, const FT& a12,
74  const FT& a20, const FT& a21, const FT& a22)
75 {
76 // First compute the det2x2
77  const FT m01 = a00*a11 - a10*a01;
78  const FT m02 = a00*a21 - a20*a01;
79  const FT m12 = a10*a21 - a20*a11;
80 // Now compute the minors of rank 3
81  const FT m012 = m01*a22 - m02*a12 + m12*a02;
82  return m012;
83 }
84 
85 template <class FT>
87 FT
89  const FT& a00, const FT& a01, const FT& a02, const FT& a03,
90  const FT& a10, const FT& a11, const FT& a12, const FT& a13,
91  const FT& a20, const FT& a21, const FT& a22, const FT& a23,
92  const FT& a30, const FT& a31, const FT& a32, const FT& a33)
93 {
94 // First compute the det2x2
95  const FT m01 = a10*a01 - a00*a11;
96  const FT m02 = a20*a01 - a00*a21;
97  const FT m03 = a30*a01 - a00*a31;
98  const FT m12 = a20*a11 - a10*a21;
99  const FT m13 = a30*a11 - a10*a31;
100  const FT m23 = a30*a21 - a20*a31;
101 // Now compute the minors of rank 3
102  const FT m012 = m12*a02 - m02*a12 + m01*a22;
103  const FT m013 = m13*a02 - m03*a12 + m01*a32;
104  const FT m023 = m23*a02 - m03*a22 + m02*a32;
105  const FT m123 = m23*a12 - m13*a22 + m12*a32;
106 // Now compute the minors of rank 4
107  const FT m0123 = m123*a03 - m023*a13 + m013*a23 - m012*a33;
108  return m0123;
109 }
110 
111 template <class FT>
113 FT
115  const FT& a00, const FT& a01, const FT& a02, const FT& a03, const FT& a04,
116  const FT& a10, const FT& a11, const FT& a12, const FT& a13, const FT& a14,
117  const FT& a20, const FT& a21, const FT& a22, const FT& a23, const FT& a24,
118  const FT& a30, const FT& a31, const FT& a32, const FT& a33, const FT& a34,
119  const FT& a40, const FT& a41, const FT& a42, const FT& a43, const FT& a44)
120 {
121 // First compute the det2x2
122  const FT m01 = a10*a01 - a00*a11;
123  const FT m02 = a20*a01 - a00*a21;
124  const FT m03 = a30*a01 - a00*a31;
125  const FT m04 = a40*a01 - a00*a41;
126  const FT m12 = a20*a11 - a10*a21;
127  const FT m13 = a30*a11 - a10*a31;
128  const FT m14 = a40*a11 - a10*a41;
129  const FT m23 = a30*a21 - a20*a31;
130  const FT m24 = a40*a21 - a20*a41;
131  const FT m34 = a40*a31 - a30*a41;
132 // Now compute the minors of rank 3
133  const FT m012 = m12*a02 - m02*a12 + m01*a22;
134  const FT m013 = m13*a02 - m03*a12 + m01*a32;
135  const FT m014 = m14*a02 - m04*a12 + m01*a42;
136  const FT m023 = m23*a02 - m03*a22 + m02*a32;
137  const FT m024 = m24*a02 - m04*a22 + m02*a42;
138  const FT m034 = m34*a02 - m04*a32 + m03*a42;
139  const FT m123 = m23*a12 - m13*a22 + m12*a32;
140  const FT m124 = m24*a12 - m14*a22 + m12*a42;
141  const FT m134 = m34*a12 - m14*a32 + m13*a42;
142  const FT m234 = m34*a22 - m24*a32 + m23*a42;
143 // Now compute the minors of rank 4
144  const FT m0123 = m123*a03 - m023*a13 + m013*a23 - m012*a33;
145  const FT m0124 = m124*a03 - m024*a13 + m014*a23 - m012*a43;
146  const FT m0134 = m134*a03 - m034*a13 + m014*a33 - m013*a43;
147  const FT m0234 = m234*a03 - m034*a23 + m024*a33 - m023*a43;
148  const FT m1234 = m234*a13 - m134*a23 + m124*a33 - m123*a43;
149 // Now compute the minors of rank 5
150  const FT m01234 = m1234*a04 - m0234*a14 + m0134*a24 - m0124*a34 + m0123*a44;
151  return m01234;
152 }
153 
154 template <class FT>
155 FT
157  const FT& a00, const FT& a01, const FT& a02, const FT& a03, const FT& a04, const FT& a05,
158  const FT& a10, const FT& a11, const FT& a12, const FT& a13, const FT& a14, const FT& a15,
159  const FT& a20, const FT& a21, const FT& a22, const FT& a23, const FT& a24, const FT& a25,
160  const FT& a30, const FT& a31, const FT& a32, const FT& a33, const FT& a34, const FT& a35,
161  const FT& a40, const FT& a41, const FT& a42, const FT& a43, const FT& a44, const FT& a45,
162  const FT& a50, const FT& a51, const FT& a52, const FT& a53, const FT& a54, const FT& a55)
163 {
164 // First compute the det2x2
165  const FT m01 = a00*a11 - a10*a01;
166  const FT m02 = a00*a21 - a20*a01;
167  const FT m03 = a00*a31 - a30*a01;
168  const FT m04 = a00*a41 - a40*a01;
169  const FT m05 = a00*a51 - a50*a01;
170  const FT m12 = a10*a21 - a20*a11;
171  const FT m13 = a10*a31 - a30*a11;
172  const FT m14 = a10*a41 - a40*a11;
173  const FT m15 = a10*a51 - a50*a11;
174  const FT m23 = a20*a31 - a30*a21;
175  const FT m24 = a20*a41 - a40*a21;
176  const FT m25 = a20*a51 - a50*a21;
177  const FT m34 = a30*a41 - a40*a31;
178  const FT m35 = a30*a51 - a50*a31;
179  const FT m45 = a40*a51 - a50*a41;
180 // Now compute the minors of rank 3
181  const FT m012 = m01*a22 - m02*a12 + m12*a02;
182  const FT m013 = m01*a32 - m03*a12 + m13*a02;
183  const FT m014 = m01*a42 - m04*a12 + m14*a02;
184  const FT m015 = m01*a52 - m05*a12 + m15*a02;
185  const FT m023 = m02*a32 - m03*a22 + m23*a02;
186  const FT m024 = m02*a42 - m04*a22 + m24*a02;
187  const FT m025 = m02*a52 - m05*a22 + m25*a02;
188  const FT m034 = m03*a42 - m04*a32 + m34*a02;
189  const FT m035 = m03*a52 - m05*a32 + m35*a02;
190  const FT m045 = m04*a52 - m05*a42 + m45*a02;
191  const FT m123 = m12*a32 - m13*a22 + m23*a12;
192  const FT m124 = m12*a42 - m14*a22 + m24*a12;
193  const FT m125 = m12*a52 - m15*a22 + m25*a12;
194  const FT m134 = m13*a42 - m14*a32 + m34*a12;
195  const FT m135 = m13*a52 - m15*a32 + m35*a12;
196  const FT m145 = m14*a52 - m15*a42 + m45*a12;
197  const FT m234 = m23*a42 - m24*a32 + m34*a22;
198  const FT m235 = m23*a52 - m25*a32 + m35*a22;
199  const FT m245 = m24*a52 - m25*a42 + m45*a22;
200  const FT m345 = m34*a52 - m35*a42 + m45*a32;
201 // Now compute the minors of rank 4
202  const FT m0123 = m012*a33 - m013*a23 + m023*a13 - m123*a03;
203  const FT m0124 = m012*a43 - m014*a23 + m024*a13 - m124*a03;
204  const FT m0125 = m012*a53 - m015*a23 + m025*a13 - m125*a03;
205  const FT m0134 = m013*a43 - m014*a33 + m034*a13 - m134*a03;
206  const FT m0135 = m013*a53 - m015*a33 + m035*a13 - m135*a03;
207  const FT m0145 = m014*a53 - m015*a43 + m045*a13 - m145*a03;
208  const FT m0234 = m023*a43 - m024*a33 + m034*a23 - m234*a03;
209  const FT m0235 = m023*a53 - m025*a33 + m035*a23 - m235*a03;
210  const FT m0245 = m024*a53 - m025*a43 + m045*a23 - m245*a03;
211  const FT m0345 = m034*a53 - m035*a43 + m045*a33 - m345*a03;
212  const FT m1234 = m123*a43 - m124*a33 + m134*a23 - m234*a13;
213  const FT m1235 = m123*a53 - m125*a33 + m135*a23 - m235*a13;
214  const FT m1245 = m124*a53 - m125*a43 + m145*a23 - m245*a13;
215  const FT m1345 = m134*a53 - m135*a43 + m145*a33 - m345*a13;
216  const FT m2345 = m234*a53 - m235*a43 + m245*a33 - m345*a23;
217 // Now compute the minors of rank 5
218  const FT m01234 = m0123*a44 - m0124*a34 + m0134*a24 - m0234*a14 + m1234*a04;
219  const FT m01235 = m0123*a54 - m0125*a34 + m0135*a24 - m0235*a14 + m1235*a04;
220  const FT m01245 = m0124*a54 - m0125*a44 + m0145*a24 - m0245*a14 + m1245*a04;
221  const FT m01345 = m0134*a54 - m0135*a44 + m0145*a34 - m0345*a14 + m1345*a04;
222  const FT m02345 = m0234*a54 - m0235*a44 + m0245*a34 - m0345*a24 + m2345*a04;
223  const FT m12345 = m1234*a54 - m1235*a44 + m1245*a34 - m1345*a24 + m2345*a14;
224 // Now compute the minors of rank 6
225  const FT m012345 = m01234*a55 - m01235*a45 + m01245*a35 - m01345*a25 + m02345*a15 - m12345*a05;
226  return m012345;
227 }
228 
229 
231 
232 
233 #ifndef CGAL_PREDICATES_SIGN_OF_DETERMINANT_H
235 #endif // CGAL_PREDICATES_SIGN_OF_DETERMINANT_H
236 
237 #endif // CGAL_DETERMINANT_H
CGAL_BEGIN_NAMESPACE FT det2x2_by_formula(const FT &a00, const FT &a01, const FT &a10, const FT &a11)
Definition: determinant.h:59
CGAL_KERNEL_MEDIUM_INLINE FT det3x3_by_formula(const FT &a00, const FT &a01, const FT &a02, const FT &a10, const FT &a11, const FT &a12, const FT &a20, const FT &a21, const FT &a22)
Definition: determinant.h:71
CGAL_KERNEL_LARGE_INLINE FT det5x5_by_formula(const FT &a00, const FT &a01, const FT &a02, const FT &a03, const FT &a04, const FT &a10, const FT &a11, const FT &a12, const FT &a13, const FT &a14, const FT &a20, const FT &a21, const FT &a22, const FT &a23, const FT &a24, const FT &a30, const FT &a31, const FT &a32, const FT &a33, const FT &a34, const FT &a40, const FT &a41, const FT &a42, const FT &a43, const FT &a44)
Definition: determinant.h:114
FT det6x6_by_formula(const FT &a00, const FT &a01, const FT &a02, const FT &a03, const FT &a04, const FT &a05, const FT &a10, const FT &a11, const FT &a12, const FT &a13, const FT &a14, const FT &a15, const FT &a20, const FT &a21, const FT &a22, const FT &a23, const FT &a24, const FT &a25, const FT &a30, const FT &a31, const FT &a32, const FT &a33, const FT &a34, const FT &a35, const FT &a40, const FT &a41, const FT &a42, const FT &a43, const FT &a44, const FT &a45, const FT &a50, const FT &a51, const FT &a52, const FT &a53, const FT &a54, const FT &a55)
Definition: determinant.h:156
#define CGAL_KERNEL_MEDIUM_INLINE
Definition: kernel_basic.h:55
CGAL_KERNEL_LARGE_INLINE FT det4x4_by_formula(const FT &a00, const FT &a01, const FT &a02, const FT &a03, const FT &a10, const FT &a11, const FT &a12, const FT &a13, const FT &a20, const FT &a21, const FT &a22, const FT &a23, const FT &a30, const FT &a31, const FT &a32, const FT &a33)
Definition: determinant.h:88
#define CGAL_KERNEL_LARGE_INLINE
Definition: kernel_basic.h:56
#define CGAL_BEGIN_NAMESPACE
Definition: kdtree_d.h:86
#define CGAL_END_NAMESPACE
Definition: kdtree_d.h:87