Documentation of MARTY
A Modern ARtificial Theoretical phYsicist
SU_N_algebra.h
Go to the documentation of this file.
1 // This file is part of MARTY.
2 //
3 // MARTY is free software: you can redistribute it and/or modify
4 // it under the terms of the GNU General Public License as published by
5 // the Free Software Foundation, either version 3 of the License, or
6 // (at your option) any later version.
7 //
8 // MARTY is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 // GNU General Public License for more details.
12 //
13 // You should have received a copy of the GNU General Public License
14 // along with MARTY. If not, see <https://www.gnu.org/licenses/>.
15 
23 #ifndef SU_N_ALGEBRA_H_INCLUDED
24 #define SU_N_ALGEBRA_H_INCLUDED
25 
26 #include <csl.h>
27 
28 namespace pauli {
29 
30 inline
31 csl::Expr sigma1 = csl::matrix_s({{CSL_0, CSL_1},
32  {CSL_1, CSL_0}});
33 
34 inline
35 csl::Expr sigma2 = csl::matrix_s({{CSL_0, -CSL_I},
36  {CSL_I, CSL_0}});
37 
38 inline
39 csl::Expr sigma3 = csl::matrix_s({{CSL_1, CSL_0},
40  {CSL_0, -CSL_1}});
41 
42 inline
43 csl::Expr f = csl::highdtensor_s({{{CSL_0, CSL_0, CSL_0},
44  {CSL_0, CSL_0, CSL_1},
45  {CSL_0, -CSL_1, CSL_0}},
46 
47  {{CSL_0, CSL_0, -CSL_1},
48  {CSL_0, CSL_0, CSL_0},
49  {CSL_1, CSL_0, CSL_0}},
50 
51  {{CSL_0, CSL_1, CSL_0},
52  {-CSL_1, CSL_0, CSL_0},
53  {CSL_0, CSL_0, CSL_0}}});
54 
55 }
56 
57 namespace gell_mann {
58 
59 inline
60 csl::Expr lambda1 = csl::matrix_s({{CSL_0, CSL_1, CSL_0},
61  {CSL_1, CSL_0, CSL_0},
62  {CSL_0, CSL_0, CSL_0}});
63 
64 inline
65 csl::Expr lambda2 = csl::matrix_s({{CSL_0, -CSL_I, CSL_0},
66  {CSL_I, CSL_0, CSL_0},
67  {CSL_0, CSL_0, CSL_0}});
68 
69 inline
70 csl::Expr lambda3 = csl::matrix_s({{CSL_1, CSL_0, CSL_0},
71  {CSL_0, -CSL_1, CSL_0},
72  {CSL_0, CSL_0, CSL_0}});
73 
74 inline
75 csl::Expr lambda4 = csl::matrix_s({{CSL_0, CSL_0, CSL_1},
76  {CSL_0, CSL_0, CSL_0},
77  {CSL_1, CSL_0, CSL_0}});
78 
79 inline
80 csl::Expr lambda5 = csl::matrix_s({{CSL_0, CSL_0, -CSL_I},
81  {CSL_0, CSL_0, CSL_0},
82  {CSL_I, CSL_0, CSL_0}});
83 
84 inline
85 csl::Expr lambda6 = csl::matrix_s({{CSL_0, CSL_0, CSL_0},
86  {CSL_0, CSL_0, CSL_1},
87  {CSL_0, CSL_1, CSL_0}});
88 
89 inline
90 csl::Expr lambda7 = csl::matrix_s({{CSL_0, CSL_0, CSL_0},
91  {CSL_0, CSL_0, -CSL_I},
92  {CSL_0, CSL_I, CSL_0}});
93 
94 inline
95 csl::Expr lambda8 = 1/csl::sqrt_s(csl::int_s(3))
96  * csl::matrix_s({{CSL_1, CSL_0, CSL_0},
97  {CSL_0, CSL_1, CSL_0},
98  {CSL_0, CSL_0, -CSL_2}});
99 
100 csl::Expr generate_f_ABC();
101 
102 csl::Expr generate_d_ABC();
103 
104 
105 inline
106 csl::Expr f = generate_f_ABC();
107 
108 inline
109 csl::Expr d3 = generate_d_ABC();
110 
111 }
112 
113 #endif
Definition: SU_N_algebra.h:57
Definition: SU_N_algebra.h:28