8 T
vnl_det(T
const *row0, T
const *row1)
10 return row0[0]*row1[1] - row0[1]*row1[0];
14 T
vnl_det(T
const *row0, T
const *row1, T
const *row2)
17 + row0[0]*row1[1]*row2[2]
18 - row0[0]*row2[1]*row1[2]
19 - row1[0]*row0[1]*row2[2]
20 + row1[0]*row2[1]*row0[2]
21 + row2[0]*row0[1]*row1[2]
22 - row2[0]*row1[1]*row0[2];
26 T
vnl_det(T
const *row0, T
const *row1, T
const *row2, T
const *row3)
29 + row0[0]*row1[1]*row2[2]*row3[3]
30 - row0[0]*row1[1]*row3[2]*row2[3]
31 - row0[0]*row2[1]*row1[2]*row3[3]
32 + row0[0]*row2[1]*row3[2]*row1[3]
33 + row0[0]*row3[1]*row1[2]*row2[3]
34 - row0[0]*row3[1]*row2[2]*row1[3]
35 - row1[0]*row0[1]*row2[2]*row3[3]
36 + row1[0]*row0[1]*row3[2]*row2[3]
37 + row1[0]*row2[1]*row0[2]*row3[3]
38 - row1[0]*row2[1]*row3[2]*row0[3]
39 - row1[0]*row3[1]*row0[2]*row2[3]
40 + row1[0]*row3[1]*row2[2]*row0[3]
41 + row2[0]*row0[1]*row1[2]*row3[3]
42 - row2[0]*row0[1]*row3[2]*row1[3]
43 - row2[0]*row1[1]*row0[2]*row3[3]
44 + row2[0]*row1[1]*row3[2]*row0[3]
45 + row2[0]*row3[1]*row0[2]*row1[3]
46 - row2[0]*row3[1]*row1[2]*row0[3]
47 - row3[0]*row0[1]*row1[2]*row2[3]
48 + row3[0]*row0[1]*row2[2]*row1[3]
49 + row3[0]*row1[1]*row0[2]*row2[3]
50 - row3[0]*row1[1]*row2[2]*row0[3]
51 - row3[0]*row2[1]*row0[2]*row1[3]
52 + row3[0]*row2[1]*row1[2]*row0[3];
57 #define VNL_DET_INSTANTIATE(T) \ 58 template VNL_EXPORT T vnl_det(T const *, T const *); \ 59 template VNL_EXPORT T vnl_det(T const *, T const *, T const *); \ 60 template VNL_EXPORT T vnl_det(T const *, T const *, T const *, T const *) 62 #endif // vnl_det_hxx_ Direct evaluation of 2x2, 3x3 and 4x4 determinants.
T vnl_det(vnl_matrix_fixed< T, 1, 1 > const &m)
Determinant of small size matrices.