GM2Calc 2.3.0
Loading...
Searching...
No Matches
MSSMNoFV_onshell_mass_eigenstates.hpp
Go to the documentation of this file.
1// ====================================================================
2// This file is part of GM2Calc.
3//
4// GM2Calc is free software: you can redistribute it and/or modify
5// it under the terms of the GNU General Public License as published
6// by the Free Software Foundation, either version 3 of the License,
7// or (at your option) any later version.
8//
9// GM2Calc is distributed in the hope that it will be useful, but
10// WITHOUT ANY WARRANTY; without even the implied warranty of
11// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12// General Public License for more details.
13//
14// You should have received a copy of the GNU General Public License
15// along with GM2Calc. If not, see
16// <http://www.gnu.org/licenses/>.
17// ====================================================================
18
19/**
20 * @file MSSMNoFV_onshell_mass_eigenstates.hpp
21 *
22 * @brief contains class for MSSMNoFV with routines needed to solve EWSB
23 * and determine the pole masses and mixings
24 *
25 * This file was generated at Wed 22 Jul 2015 18:14:31 with FlexibleSUSY
26 * 1.2.1 (git commit: v1.2.1-49-gfc4c300) and SARAH 4.5.8 .
27 */
28
29#ifndef GM2_MSSMNoFV_ONSHELL_MASS_EIGENSTATES_HPP
30#define GM2_MSSMNoFV_ONSHELL_MASS_EIGENSTATES_HPP
31
35
36#include <iosfwd>
37
38#include <Eigen/Core>
39
40namespace gm2calc {
41
42/**
43 * @class MSSMNoFV_onshell_mass_eigenstates
44 * @brief model class with routines determine masses, mixings and EWSB
45 */
47public:
49
50 void print(std::ostream&) const override;
51
54 void do_force_output(bool);
55 bool do_force_output() const;
64 int solve_ewsb();
65
66 double get_MVG() const { return MVG; }
67 double get_MGlu() const { return MGlu; }
68 double get_MVP() const { return MVP; }
69 double get_MVZ() const { return MVZ; }
70 double get_MFd() const { return MFd; }
71 double get_MFs() const { return MFs; }
72 double get_MFb() const { return MFb; }
73 double get_MFu() const { return MFu; }
74 double get_MFc() const { return MFc; }
75 double get_MFt() const { return MFt; }
76 double get_MFve() const { return MFve; }
77 double get_MFvm() const { return MFvm; }
78 double get_MFvt() const { return MFvt; }
79 double get_MFe() const { return MFe; }
80 double get_MFm() const { return MFm; }
81 double get_MFtau() const { return MFtau; }
82 double get_MSveL() const { return MSveL; }
83 double get_MSvmL() const { return MSvmL; }
84 double get_MSvtL() const { return MSvtL; }
85 const Eigen::Array<double,2,1>& get_MSd() const { return MSd; }
86 double get_MSd(int i) const { return MSd(i); }
87 const Eigen::Array<double,2,1>& get_MSu() const { return MSu; }
88 double get_MSu(int i) const { return MSu(i); }
89 const Eigen::Array<double,2,1>& get_MSe() const { return MSe; }
90 double get_MSe(int i) const { return MSe(i); }
91 const Eigen::Array<double,2,1>& get_MSm() const { return MSm; }
92 double get_MSm(int i) const { return MSm(i); }
93 const Eigen::Array<double,2,1>& get_MStau() const { return MStau; }
94 double get_MStau(int i) const { return MStau(i); }
95 const Eigen::Array<double,2,1>& get_MSs() const { return MSs; }
96 double get_MSs(int i) const { return MSs(i); }
97 const Eigen::Array<double,2,1>& get_MSc() const { return MSc; }
98 double get_MSc(int i) const { return MSc(i); }
99 const Eigen::Array<double,2,1>& get_MSb() const { return MSb; }
100 double get_MSb(int i) const { return MSb(i); }
101 const Eigen::Array<double,2,1>& get_MSt() const { return MSt; }
102 double get_MSt(int i) const { return MSt(i); }
103 const Eigen::Array<double,2,1>& get_Mhh() const { return Mhh; }
104 double get_Mhh(int i) const { return Mhh(i); }
105 const Eigen::Array<double,2,1>& get_MAh() const { return MAh; }
106 double get_MAh(int i) const { return MAh(i); }
107 const Eigen::Array<double,2,1>& get_MHpm() const { return MHpm; }
108 double get_MHpm(int i) const { return MHpm(i); }
109 const Eigen::Array<double,4,1>& get_MChi() const { return MChi; }
110 double get_MChi(int i) const { return MChi(i); }
111 const Eigen::Array<double,2,1>& get_MCha() const { return MCha; }
112 double get_MCha(int i) const { return MCha(i); }
113 double get_MVWm() const { return MVWm; }
114
115
116 Eigen::Array<double,1,1> get_MChargedHiggs() const;
117 Eigen::Array<double,1,1> get_MPseudoscalarHiggs() const;
118
119 const Eigen::Matrix<double,2,2>& get_ZD() const { return ZD; }
120 double get_ZD(int i, int k) const { return ZD(i,k); }
121 const Eigen::Matrix<double,2,2>& get_ZU() const { return ZU; }
122 double get_ZU(int i, int k) const { return ZU(i,k); }
123 const Eigen::Matrix<double,2,2>& get_ZE() const { return ZE; }
124 double get_ZE(int i, int k) const { return ZE(i,k); }
125 const Eigen::Matrix<double,2,2>& get_ZM() const { return ZM; }
126 double get_ZM(int i, int k) const { return ZM(i,k); }
127 const Eigen::Matrix<double,2,2>& get_ZTau() const { return ZTau; }
128 double get_ZTau(int i, int k) const { return ZTau(i,k); }
129 const Eigen::Matrix<double,2,2>& get_ZS() const { return ZS; }
130 double get_ZS(int i, int k) const { return ZS(i,k); }
131 const Eigen::Matrix<double,2,2>& get_ZC() const { return ZC; }
132 double get_ZC(int i, int k) const { return ZC(i,k); }
133 const Eigen::Matrix<double,2,2>& get_ZB() const { return ZB; }
134 double get_ZB(int i, int k) const { return ZB(i,k); }
135 const Eigen::Matrix<double,2,2>& get_ZT() const { return ZT; }
136 double get_ZT(int i, int k) const { return ZT(i,k); }
137 const Eigen::Matrix<double,2,2>& get_ZH() const { return ZH; }
138 double get_ZH(int i, int k) const { return ZH(i,k); }
139 const Eigen::Matrix<double,2,2>& get_ZA() const { return ZA; }
140 double get_ZA(int i, int k) const { return ZA(i,k); }
141 const Eigen::Matrix<double,2,2>& get_ZP() const { return ZP; }
142 double get_ZP(int i, int k) const { return ZP(i,k); }
143 const Eigen::Matrix<std::complex<double>,4,4>& get_ZN() const { return ZN; }
144 const std::complex<double>& get_ZN(int i, int k) const { return ZN(i,k); }
145 const Eigen::Matrix<std::complex<double>,2,2>& get_UM() const { return UM; }
146 const std::complex<double>& get_UM(int i, int k) const { return UM(i,k); }
147 const Eigen::Matrix<std::complex<double>,2,2>& get_UP() const { return UP; }
148 const std::complex<double>& get_UP(int i, int k) const { return UP(i,k); }
149
150 void set_PhaseGlu(std::complex<double> PhaseGlu_) { PhaseGlu = PhaseGlu_; }
151 std::complex<double> get_PhaseGlu() const { return PhaseGlu; }
152
153 double get_mass_matrix_VG() const;
154 void calculate_MVG();
155 double get_mass_matrix_Glu() const;
156 void calculate_MGlu();
157 double get_mass_matrix_VP() const;
158 void calculate_MVP();
159 double get_mass_matrix_VZ() const;
160 void calculate_MVZ();
161 double get_mass_matrix_Fd() const;
162 void calculate_MFd();
163 double get_mass_matrix_Fs() const;
164 void calculate_MFs();
165 double get_mass_matrix_Fb() const;
166 void calculate_MFb();
167 double get_mass_matrix_Fu() const;
168 void calculate_MFu();
169 double get_mass_matrix_Fc() const;
170 void calculate_MFc();
171 double get_mass_matrix_Ft() const;
172 void calculate_MFt();
173 double get_mass_matrix_Fve() const;
174 void calculate_MFve();
175 double get_mass_matrix_Fvm() const;
176 void calculate_MFvm();
177 double get_mass_matrix_Fvt() const;
178 void calculate_MFvt();
179 double get_mass_matrix_Fe() const;
180 void calculate_MFe();
181 double get_mass_matrix_Fm() const;
182 void calculate_MFm();
183 double get_mass_matrix_Ftau() const;
184 void calculate_MFtau();
185 double get_mass_matrix_SveL() const;
186 void calculate_MSveL();
187 double get_mass_matrix_SvmL() const;
188 void calculate_MSvmL();
189 double get_mass_matrix_SvtL() const;
190 void calculate_MSvtL();
191 Eigen::Matrix<double,2,2> get_mass_matrix_Sd() const;
192 void calculate_MSd();
193 Eigen::Matrix<double,2,2> get_mass_matrix_Su() const;
194 void calculate_MSu();
195 Eigen::Matrix<double,2,2> get_mass_matrix_Se() const;
196 void calculate_MSe();
197 Eigen::Matrix<double,2,2> get_mass_matrix_Sm() const;
198 void calculate_MSm();
199 Eigen::Matrix<double,2,2> get_mass_matrix_Stau() const;
200 void calculate_MStau();
201 Eigen::Matrix<double,2,2> get_mass_matrix_Ss() const;
202 void calculate_MSs();
203 Eigen::Matrix<double,2,2> get_mass_matrix_Sc() const;
204 void calculate_MSc();
205 Eigen::Matrix<double,2,2> get_mass_matrix_Sb() const;
206 void calculate_MSb();
207 Eigen::Matrix<double,2,2> get_mass_matrix_St() const;
208 void calculate_MSt();
209 Eigen::Matrix<double,2,2> get_mass_matrix_hh() const;
210 void calculate_Mhh();
211 Eigen::Matrix<double,2,2> get_mass_matrix_Ah() const;
212 void calculate_MAh();
213 Eigen::Matrix<double,2,2> get_mass_matrix_Hpm() const;
214 void calculate_MHpm();
215 Eigen::Matrix<double,4,4> get_mass_matrix_Chi() const;
216 void calculate_MChi();
217 Eigen::Matrix<double,2,2> get_mass_matrix_Cha() const;
218 void calculate_MCha();
219 double get_mass_matrix_VWm() const;
220 void calculate_MVWm();
221
222 double get_ewsb_eq_hh_1() const;
223 double get_ewsb_eq_hh_2() const;
224
225 double ThetaW() const;
226 double v() const;
227
228
229private:
230 bool force_output{false}; ///< switch to force output of pole masses
231 MSSMNoFV_onshell_physical physical; ///< contains the pole masses and mixings
232 MSSMNoFV_onshell_problems problems; ///< problems
233
234 int solve_ewsb_tree_level_via_soft_higgs_masses();
235
236 // DR-bar masses
237 double MVG{0.0};
238 double MGlu{0.0};
239 double MVP{0.0};
240 double MVZ{0.0};
241 double MVWm{0.0};
242 double MFd{0.0};
243 double MFs{0.0};
244 double MFb{0.0};
245 double MFu{0.0};
246 double MFc{0.0};
247 double MFt{0.0};
248 double MFve{0.0};
249 double MFvm{0.0};
250 double MFvt{0.0};
251 double MFe{0.0};
252 double MFm{0.0};
253 double MFtau{0.0};
254 double MSveL{0.0};
255 double MSvmL{0.0};
256 double MSvtL{0.0};
257 Eigen::Array<double,2,1> MSd{Eigen::Array<double,2,1>::Zero()};
258 Eigen::Array<double,2,1> MSu{Eigen::Array<double,2,1>::Zero()};
259 Eigen::Array<double,2,1> MSe{Eigen::Array<double,2,1>::Zero()};
260 Eigen::Array<double,2,1> MSm{Eigen::Array<double,2,1>::Zero()};
261 Eigen::Array<double,2,1> MStau{Eigen::Array<double,2,1>::Zero()};
262 Eigen::Array<double,2,1> MSs{Eigen::Array<double,2,1>::Zero()};
263 Eigen::Array<double,2,1> MSc{Eigen::Array<double,2,1>::Zero()};
264 Eigen::Array<double,2,1> MSb{Eigen::Array<double,2,1>::Zero()};
265 Eigen::Array<double,2,1> MSt{Eigen::Array<double,2,1>::Zero()};
266 Eigen::Array<double,2,1> Mhh{Eigen::Array<double,2,1>::Zero()};
267 Eigen::Array<double,2,1> MAh{Eigen::Array<double,2,1>::Zero()};
268 Eigen::Array<double,2,1> MHpm{Eigen::Array<double,2,1>::Zero()};
269 Eigen::Array<double,4,1> MChi{Eigen::Array<double,4,1>::Zero()};
270 Eigen::Array<double,2,1> MCha{Eigen::Array<double,2,1>::Zero()};
271
272 // DR-bar mixing matrices
273 Eigen::Matrix<double,2,2> ZD{Eigen::Matrix<double,2,2>::Zero()};
274 Eigen::Matrix<double,2,2> ZU{Eigen::Matrix<double,2,2>::Zero()};
275 Eigen::Matrix<double,2,2> ZE{Eigen::Matrix<double,2,2>::Zero()};
276 Eigen::Matrix<double,2,2> ZM{Eigen::Matrix<double,2,2>::Zero()};
277 Eigen::Matrix<double,2,2> ZTau{Eigen::Matrix<double,2,2>::Zero()};
278 Eigen::Matrix<double,2,2> ZS{Eigen::Matrix<double,2,2>::Zero()};
279 Eigen::Matrix<double,2,2> ZC{Eigen::Matrix<double,2,2>::Zero()};
280 Eigen::Matrix<double,2,2> ZB{Eigen::Matrix<double,2,2>::Zero()};
281 Eigen::Matrix<double,2,2> ZT{Eigen::Matrix<double,2,2>::Zero()};
282 Eigen::Matrix<double,2,2> ZH{Eigen::Matrix<double,2,2>::Zero()};
283 Eigen::Matrix<double,2,2> ZA{Eigen::Matrix<double,2,2>::Zero()};
284 Eigen::Matrix<double,2,2> ZP{Eigen::Matrix<double,2,2>::Zero()};
285 Eigen::Matrix<std::complex<double>,4,4> ZN{Eigen::Matrix<std::complex<double>,4,4>::Zero()};
286 Eigen::Matrix<std::complex<double>,2,2> UM{Eigen::Matrix<std::complex<double>,2,2>::Zero()};
287 Eigen::Matrix<std::complex<double>,2,2> UP{Eigen::Matrix<std::complex<double>,2,2>::Zero()};
288
289 // phases
290 std::complex<double> PhaseGlu{1.0, 0.0};
291};
292
293std::ostream& operator<<(std::ostream&, const MSSMNoFV_onshell_mass_eigenstates&);
294
295} // namespace gm2calc
296
297#endif
model class with routines determine masses, mixings and EWSB
const Eigen::Array< double, 2, 1 > & get_MStau() const
const Eigen::Array< double, 2, 1 > & get_MSu() const
const Eigen::Matrix< double, 2, 2 > & get_ZU() const
const Eigen::Matrix< double, 2, 2 > & get_ZTau() const
const Eigen::Matrix< std::complex< double >, 4, 4 > & get_ZN() const
const Eigen::Matrix< double, 2, 2 > & get_ZA() const
const Eigen::Matrix< std::complex< double >, 2, 2 > & get_UM() const
const Eigen::Array< double, 2, 1 > & get_MSe() const
void calculate_DRbar_masses()
routine which finds the DRbar mass eigenstates and mixings.
const Eigen::Array< double, 2, 1 > & get_MAh() const
const Eigen::Matrix< double, 2, 2 > & get_ZC() const
const Eigen::Array< double, 4, 1 > & get_MChi() const
virtual ~MSSMNoFV_onshell_mass_eigenstates()=default
const Eigen::Array< double, 2, 1 > & get_MSs() const
void reorder_DRbar_masses()
reorders DRbar masses so that golstones are placed at the index specified in the model files definiti...
const MSSMNoFV_onshell_physical & get_physical() const
const Eigen::Array< double, 2, 1 > & get_MHpm() const
const Eigen::Matrix< double, 2, 2 > & get_ZP() const
const Eigen::Matrix< double, 2, 2 > & get_ZT() const
void reorder_pole_masses()
reorders pole masses so that golstones are placed at the index specified in the model files definitio...
const Eigen::Matrix< std::complex< double >, 2, 2 > & get_UP() const
const Eigen::Array< double, 2, 1 > & get_MSb() const
const Eigen::Matrix< double, 2, 2 > & get_ZS() const
const Eigen::Matrix< double, 2, 2 > & get_ZH() const
const std::complex< double > & get_UP(int i, int k) const
const std::complex< double > & get_UM(int i, int k) const
const Eigen::Array< double, 2, 1 > & get_MSd() const
const Eigen::Array< double, 2, 1 > & get_MCha() const
const Eigen::Matrix< double, 2, 2 > & get_ZB() const
const Eigen::Matrix< double, 2, 2 > & get_ZE() const
const Eigen::Array< double, 2, 1 > & get_MSt() const
const std::complex< double > & get_ZN(int i, int k) const
const Eigen::Array< double, 2, 1 > & get_MSm() const
const Eigen::Matrix< double, 2, 2 > & get_ZM() const
const MSSMNoFV_onshell_problems & get_problems() const
const Eigen::Array< double, 2, 1 > & get_Mhh() const
const Eigen::Array< double, 2, 1 > & get_MSc() const
const Eigen::Matrix< double, 2, 2 > & get_ZD() const
contains problem and warning flags
contains soft-breaking parameters of the MSSMNoFV model
std::ostream & operator<<(std::ostream &os, const MSSMNoFV_onshell &model)
streaming operator
MSSMNoFV pole masses and corresponding mixings.