file frontends/FeynHiggs_2_12_0.cpp
[No description available]
Functions
Name | |
---|---|
if(scan_level ) | |
if(slhaea. find"SPINFO" ==slhaea.end()) | |
std::vector< std::string > | k3(1 , “3” ) |
std::vector< std::string > | k4(1 , “4” ) |
if(spinfo.find(k3) ! =spinfo.end() | |
FHSetSMPara(error , invAlfa , AlfasMZ , GF , ME , MU , MD , MM , MC , MS , ML , MB , MW , MZ , CKMlambda , CKMA , CKMrhobar , CKMetabar ) | |
if(MA0<= 0.) | |
FHSetPara(error , scalefactor , MT , TB , MA0 , MHp , M3SL , M3SE , M3SQ , M3SU , M3SD , M2SL , M2SE , M2SQ , M2SU , M2SD , M1SL , M1SE , M1SQ , M1SU , M1SD , MUE , Atau , At , Ab , Amu , Ac , As , Ae , Au , Ad , M_1 , M_2 , M_3 , Qtau , Qt , Qb ) |
Attributes
Name | |
---|---|
BE_INI_FUNCTION | |
bool | scan_level |
const Spectrum & | fullspectrum |
const SMInputs & | sminputs |
const SubSpectrum & | spec |
SLHAea::Coll | slhaea |
SLHAea::Block | spinfo |
fh_real | invAlfa |
fh_real | AlfasMZ |
fh_real | GF |
fh_real | ME |
fh_real | MU |
fh_real | MD |
fh_real | MM |
fh_real | MC |
fh_real | MS |
fh_real | ML |
fh_real | MB |
fh_real | MW |
fh_real | MZ |
fh_real | CKMlambda |
fh_real | CKMA |
fh_real | CKMrhobar |
fh_real | CKMetabar |
error | |
fh_real | MT |
fh_real | TB |
fh_real | MA0 |
fh_real | MHp |
fh_real | M1SL |
fh_real | M2SL |
fh_real | M3SL |
fh_real | M1SE |
fh_real | M2SE |
fh_real | M3SE |
fh_real | M1SQ |
fh_real | M2SQ |
fh_real | M3SQ |
fh_real | M1SU |
fh_real | M2SU |
fh_real | M3SU |
fh_real | M1SD |
fh_real | M2SD |
fh_real | M3SD |
fh_complex | Af |
Af | re |
Af | im |
fh_complex | At |
fh_complex | Ac |
fh_complex | Au |
fh_complex | Ab |
fh_complex | As |
fh_complex | Ad |
fh_complex | Atau |
fh_complex | Amu |
fh_complex | Ae |
fh_complex | MUE |
fh_complex | M_1 |
fh_complex | M_2 |
fh_complex | M_3 |
double | SCALE |
fh_real | Qtau |
fh_real | Qt |
fh_real | Qb |
fh_real | scalefactor |
Functions Documentation
function if
if(
scan_level
)
function if
if(
slhaea. find"SPINFO" ==slhaea.end()
)
function k3
std::vector< std::string > k3(
1 ,
"3"
)
function k4
std::vector< std::string > k4(
1 ,
"4"
)
function if
if(
spinfo.find(k3) ! =spinfo.end()||spinfo.find(k4) !=spinfo.end()
)
function FHSetSMPara
FHSetSMPara(
error ,
invAlfa ,
AlfasMZ ,
GF ,
ME ,
MU ,
MD ,
MM ,
MC ,
MS ,
ML ,
MB ,
MW ,
MZ ,
CKMlambda ,
CKMA ,
CKMrhobar ,
CKMetabar
)
function if
if(
MA0<= 0.
)
function FHSetPara
FHSetPara(
error ,
scalefactor ,
MT ,
TB ,
MA0 ,
MHp ,
M3SL ,
M3SE ,
M3SQ ,
M3SU ,
M3SD ,
M2SL ,
M2SE ,
M2SQ ,
M2SU ,
M2SD ,
M1SL ,
M1SE ,
M1SQ ,
M1SU ,
M1SD ,
MUE ,
Atau ,
At ,
Ab ,
Amu ,
Ac ,
As ,
Ae ,
Au ,
Ad ,
M_1 ,
M_2 ,
M_3 ,
Qtau ,
Qt ,
Qb
)
Attributes Documentation
variable BE_INI_FUNCTION
BE_INI_FUNCTION {
int error = 1;
variable scan_level
static bool scan_level = true;
variable fullspectrum
const Spectrum & fullspectrum = *Dep::unimproved_MSSM_spectrum;
variable sminputs
const SMInputs & sminputs = fullspectrum.get_SMInputs();
variable spec
const SubSpectrum & spec = fullspectrum.get_HE();
variable slhaea
SLHAea::Coll slhaea = fullspectrum.getSLHAea(2);
variable spinfo
SLHAea::Block spinfo = slhaea.at("SPINFO");
variable invAlfa
fh_real invAlfa = sminputs.alphainv;
variable AlfasMZ
fh_real AlfasMZ = sminputs.alphaS;
variable GF
fh_real GF = sminputs.GF;
variable ME
fh_real ME = sminputs.mE;
variable MU
fh_real MU = sminputs.mU;
variable MD
fh_real MD = sminputs.mD;
variable MM
fh_real MM = sminputs.mMu;
variable MC
fh_real MC = sminputs.mCmC;
variable MS
fh_real MS = sminputs.mS;
variable ML
fh_real ML = sminputs.mTau;
variable MB
fh_real MB = sminputs.mBmB;
variable MW
fh_real MW = fullspectrum.get(Par::Pole_Mass,"W+");
variable MZ
fh_real MZ = sminputs.mZ;
variable CKMlambda
fh_real CKMlambda = sminputs.CKM.lambda;
variable CKMA
fh_real CKMA = sminputs.CKM.A;
variable CKMrhobar
fh_real CKMrhobar = sminputs.CKM.rhobar;
variable CKMetabar
fh_real CKMetabar = sminputs.CKM.etabar;
variable error
error = 1;
variable MT
fh_real MT = fullspectrum.get(Par::Pole_Mass,"t");
variable TB
fh_real TB = SLHAea::to<double>( slhaea.at("MINPAR").at(3).at(1) );
variable MA0
fh_real MA0 = fullspectrum.get(Par::Pole_Mass,"A0");
variable MHp
fh_real MHp = -1.;
variable M1SL
fh_real M1SL = SLHAea::to<double>( slhaea.at("MSOFT").at(31).at(1) );
variable M2SL
fh_real M2SL = SLHAea::to<double>( slhaea.at("MSOFT").at(32).at(1) );
variable M3SL
fh_real M3SL = SLHAea::to<double>( slhaea.at("MSOFT").at(33).at(1) );
variable M1SE
fh_real M1SE = SLHAea::to<double>( slhaea.at("MSOFT").at(34).at(1) );
variable M2SE
fh_real M2SE = SLHAea::to<double>( slhaea.at("MSOFT").at(35).at(1) );
variable M3SE
fh_real M3SE = SLHAea::to<double>( slhaea.at("MSOFT").at(36).at(1) );
variable M1SQ
fh_real M1SQ = SLHAea::to<double>( slhaea.at("MSOFT").at(41).at(1) );
variable M2SQ
fh_real M2SQ = SLHAea::to<double>( slhaea.at("MSOFT").at(42).at(1) );
variable M3SQ
fh_real M3SQ = SLHAea::to<double>( slhaea.at("MSOFT").at(43).at(1) );
variable M1SU
fh_real M1SU = SLHAea::to<double>( slhaea.at("MSOFT").at(44).at(1) );
variable M2SU
fh_real M2SU = SLHAea::to<double>( slhaea.at("MSOFT").at(45).at(1) );
variable M3SU
fh_real M3SU = SLHAea::to<double>( slhaea.at("MSOFT").at(46).at(1) );
variable M1SD
fh_real M1SD = SLHAea::to<double>( slhaea.at("MSOFT").at(47).at(1) );
variable M2SD
fh_real M2SD = SLHAea::to<double>( slhaea.at("MSOFT").at(48).at(1) );
variable M3SD
fh_real M3SD = SLHAea::to<double>( slhaea.at("MSOFT").at(49).at(1) );
variable Af
fh_complex Af;
variable re
Af re = 0.;
variable im
Af im = 0.;
variable At
fh_complex At = Af;
variable Ac
fh_complex Ac = Af;
variable Au
fh_complex Au = Af;
variable Ab
fh_complex Ab = Af;
variable As
fh_complex As = Af;
variable Ad
fh_complex Ad = Af;
variable Atau
fh_complex Atau = Af;
variable Amu
fh_complex Amu = Af;
variable Ae
fh_complex Ae = Af;
variable MUE
fh_complex MUE;
variable M_1
fh_complex M_1;
variable M_2
fh_complex M_2;
variable M_3
fh_complex M_3;
variable SCALE
double SCALE = spec.GetScale();
variable Qtau
fh_real Qtau = SCALE;
variable Qt
fh_real Qt = SCALE;
variable Qb
fh_real Qb = SCALE;
variable scalefactor
fh_real scalefactor = 1.;
Source code
// GAMBIT: Global and Modular BSM Inference Tool
// *********************************************
/// \file FeynHiggs.cpp
///
/// Frontend source for the FeynHiggs backend.
///
/// Actual implementation of FeynHiggs ini function.
///
/// *********************************************
///
/// Authors (add name and date if you modify):
///
/// \author Christopher S. Rogan
/// (crogan@cern.ch)
/// \date 2015 Sept
///
/// \author Pat Scott
/// (p.scott@imperial.ac.uk)
/// \date 2016 Aug
///
/// *********************************************
#include "gambit/Backends/frontend_macros.hpp"
#include "gambit/Backends/frontends/FeynHiggs_2_12_0.hpp"
//#define FEYNHIGGS_DEBUG
BE_INI_FUNCTION
{
int error = 1;
// Scan-level initialisation
static bool scan_level = true;
if(scan_level)
{
// initialize FeynHiggs flags
int mssmpart = 4; // scope of calculation (4 -> full MSSM, recommended)
int fieldren = 0; // one-loop field-renormalization constants (0 -> DRbar, strongly recommended))
int tanbren = 0; // one-loop one-loop tanBeta counter-term (0 -> DRbar, strongly recommended))
int higgsmix = 2; // mixing in Higgs sector (3 -> full 3 x 3 in neutral sector) -> HB says 2
int p2approx = 4; // 1-loop approximation (4 -> none, UHiggs eval. at p^2=0, recommended) -> HB says 0
int looplevel = 2; // higher-order corrections? (2 -> various 2-loop contrib., recommended)
int loglevel = 3; // resum logs? (1 -> NLL, large MSUSY; 2 -> NLL, large MCha,MNeu,MGlu,MSUSY 3 -> NNLL, large MCha,MNeu,MGlu,MSUSY) -> FH recommend 1 or 2, but anything except 0 is buggy in this version.
int runningMT = 1; // top mass for 1/2-loop corr. (1 -> m_t^{run}, recommended)
int botResum = 1; // O(tan^n Beta) corr. ressummed? (1 -> yes, recommended)
int tlCplxApprox = 0; // determines how 2-loop corr. are treated with complex param (0 for rMSSM, > 0 for cMSSM)
#ifdef FEYNHIGGS_DEBUG
cout << "****** calling FHSetFlags ******" << endl;
#endif
FHSetFlags(error, mssmpart, fieldren, tanbren, higgsmix,
p2approx, looplevel, loglevel, runningMT, botResum,
tlCplxApprox);
}
scan_level = false;
// retrieve MSSM_spectrum dependency
const Spectrum& fullspectrum = *Dep::unimproved_MSSM_spectrum;
const SMInputs& sminputs = fullspectrum.get_SMInputs();
const SubSpectrum& spec = fullspectrum.get_HE();
SLHAea::Coll slhaea = fullspectrum.getSLHAea(2);
if (slhaea.find("SPINFO") == slhaea.end())
{
cout << slhaea << endl;
backend_error().raise(LOCAL_INFO, "SPINFO block missing from SLHAea object.");
}
SLHAea::Block spinfo = slhaea.at("SPINFO");
std::vector<std::string> k3(1, "3");
std::vector<std::string> k4(1, "4");
if(spinfo.find(k3) != spinfo.end() || spinfo.find(k4) != spinfo.end())
{
backend_error().raise(LOCAL_INFO, "Entry 3 or 4 missing in SPINFO block.");
}
//
// SM input parameters: -1 gives default value
//
fh_real invAlfa = sminputs.alphainv; // 1/alpha_{QED}
fh_real AlfasMZ = sminputs.alphaS; // alpha_s @ MZ
fh_real GF = sminputs.GF; // Fermi constant
fh_real ME = sminputs.mE; // electron mass
fh_real MU = sminputs.mU; // up quark mass @ 2 GeV
fh_real MD = sminputs.mD; // down quark mass @ 2 GeV
fh_real MM = sminputs.mMu; // muon mass
fh_real MC = sminputs.mCmC; // charm mass at m_c
fh_real MS = sminputs.mS; // stange mass @ 2 GeV
fh_real ML = sminputs.mTau; // tau mass
fh_real MB = sminputs.mBmB; // bottom mass at m_b
fh_real MW = fullspectrum.get(Par::Pole_Mass,"W+"); // W boson mass
fh_real MZ = sminputs.mZ; // Z boson mass
// CKM input parameters in Wolfenstein parameterization
fh_real CKMlambda = sminputs.CKM.lambda;
fh_real CKMA = sminputs.CKM.A;
fh_real CKMrhobar = sminputs.CKM.rhobar;
fh_real CKMetabar = sminputs.CKM.etabar;
#ifdef FEYNHIGGS_DEBUG
cout << "****** calling FHSetSMPara ******" << endl;
#endif
error = 1;
FHSetSMPara(error, invAlfa, AlfasMZ, GF,
ME, MU, MD, MM, MC, MS, ML, MB,
MW, MZ,
CKMlambda, CKMA, CKMrhobar, CKMetabar);
fh_real MT = fullspectrum.get(Par::Pole_Mass,"t"); // top quark mass
fh_real TB = SLHAea::to<double>( slhaea.at("MINPAR").at(3).at(1) ); // tan Beta
fh_real MA0 = fullspectrum.get(Par::Pole_Mass,"A0"); // masses of CP-odd and
fh_real MHp = -1.; // charged Higgs (only one should be given)
if(MA0 <= 0.){
MA0 = -1.;
MHp = fullspectrum.get(Par::Pole_Mass,"H+");
}
// cout << "** Top Mass: " << MT << endl;
// cout << "** Tan beta: " << TB << endl;
// cout << "** MA0: " << MA0 << endl;
// cout << "** MHp: " << MHp << endl;
// soft-SUSY breaking parameters for g=1,2,3 generation sfermions
// slepton doublet
fh_real M1SL = SLHAea::to<double>( slhaea.at("MSOFT").at(31).at(1) );
fh_real M2SL = SLHAea::to<double>( slhaea.at("MSOFT").at(32).at(1) );
fh_real M3SL = SLHAea::to<double>( slhaea.at("MSOFT").at(33).at(1) );
// slepton singlet
fh_real M1SE = SLHAea::to<double>( slhaea.at("MSOFT").at(34).at(1) );
fh_real M2SE = SLHAea::to<double>( slhaea.at("MSOFT").at(35).at(1) );
fh_real M3SE = SLHAea::to<double>( slhaea.at("MSOFT").at(36).at(1) );
// squark doublet
fh_real M1SQ = SLHAea::to<double>( slhaea.at("MSOFT").at(41).at(1) );
fh_real M2SQ = SLHAea::to<double>( slhaea.at("MSOFT").at(42).at(1) );
fh_real M3SQ = SLHAea::to<double>( slhaea.at("MSOFT").at(43).at(1) );
// up-type squark singlet
fh_real M1SU = SLHAea::to<double>( slhaea.at("MSOFT").at(44).at(1) );
fh_real M2SU = SLHAea::to<double>( slhaea.at("MSOFT").at(45).at(1) );
fh_real M3SU = SLHAea::to<double>( slhaea.at("MSOFT").at(46).at(1) );
// down-type squark singlet
fh_real M1SD = SLHAea::to<double>( slhaea.at("MSOFT").at(47).at(1) );
fh_real M2SD = SLHAea::to<double>( slhaea.at("MSOFT").at(48).at(1) );
fh_real M3SD = SLHAea::to<double>( slhaea.at("MSOFT").at(49).at(1) );
// cout << "** soft-SUSY breaking parameters for g=1,2,3 sfermions:" << endl;
// cout << " ** M1SL = " << M1SL << endl;
// cout << " ** M2SL = " << M2SL << endl;
// cout << " ** M3SL = " << M3SL << endl << endl;
// cout << " ** M1SE = " << M1SE << endl;
// cout << " ** M2SE = " << M2SE << endl;
// cout << " ** M3SE = " << M3SE << endl << endl;
// cout << " ** M1SQ = " << M1SQ << endl;
// cout << " ** M2SQ = " << M2SQ << endl;
// cout << " ** M3SQ = " << M3SQ << endl << endl;
// cout << " ** M1SU = " << M1SU << endl;
// cout << " ** M2SU = " << M2SU << endl;
// cout << " ** M3SU = " << M3SU << endl << endl;
// cout << " ** M1SD = " << M1SD << endl;
// cout << " ** M2SD = " << M2SD << endl;
// cout << " ** M3SD = " << M3SD << endl << endl;
// soft-SUSY breaking parameters
fh_complex Af;
Af.re = 0.;
Af.im = 0.;
fh_complex At = Af, Ac = Af, Au = Af;
fh_complex Ab = Af, As = Af, Ad = Af;
fh_complex Atau = Af, Amu = Af, Ae = Af;
Au.re = SLHAea::to<double>(slhaea.at("TU").at(1,1).at(2))/SLHAea::to<double>(slhaea.at("YU").at(1,1).at(2));
Ac.re = SLHAea::to<double>(slhaea.at("TU").at(2,2).at(2))/SLHAea::to<double>(slhaea.at("YU").at(2,2).at(2));
At.re = SLHAea::to<double>(slhaea.at("TU").at(3,3).at(2))/SLHAea::to<double>(slhaea.at("YU").at(3,3).at(2));
Ad.re = SLHAea::to<double>(slhaea.at("TD").at(1,1).at(2))/SLHAea::to<double>(slhaea.at("YD").at(1,1).at(2));
As.re = SLHAea::to<double>(slhaea.at("TD").at(2,2).at(2))/SLHAea::to<double>(slhaea.at("YD").at(2,2).at(2));
Ab.re = SLHAea::to<double>(slhaea.at("TD").at(3,3).at(2))/SLHAea::to<double>(slhaea.at("YD").at(3,3).at(2));
Ae.re = SLHAea::to<double>(slhaea.at("TE").at(1,1).at(2))/SLHAea::to<double>(slhaea.at("YE").at(1,1).at(2));
Amu.re = SLHAea::to<double>(slhaea.at("TE").at(2,2).at(2))/SLHAea::to<double>(slhaea.at("YE").at(2,2).at(2));
Atau.re = SLHAea::to<double>(slhaea.at("TE").at(3,3).at(2))/SLHAea::to<double>(slhaea.at("YE").at(3,3).at(2));
// cout << "** Au =" << endl;
// cout << Au.re << " " << Ac.re << " " << At.re << endl;
// cout << "** Ad =" << endl;
// cout << Ad.re << " " << As.re << " " << Ab.re << endl;
// cout << "** Ae =" << endl;
// cout << Ae.re << " " << Amu.re << " " << Atau.re << endl;
fh_complex MUE; // Higgs mixing parameter mu
MUE.re = spec.get(Par::mass1,"Mu");
MUE.im = 0;
// cout << "** MU = " << MUE.re << endl;
// gaugino mass parameters. M_1 == 0 => GUT relation is used
fh_complex M_1, M_2, M_3;
M_1.re = spec.get(Par::mass1,"M1");
M_1.im = 0;
M_2.re = spec.get(Par::mass1,"M2");
M_2.im = 0;
M_3.re = spec.get(Par::mass1,"M3");
M_3.im = 0;
// cout << "** M1 = " << M_1.re << endl;
// cout << "** M2 = " << M_2.re << endl;
// cout << "** M3 = " << M_3.re << endl;
// the scales at which the sfermion input parameters M3S are given
// 0 indicates on-shell parameters
double SCALE = spec.GetScale();
// cout << "** SCALE = " << SCALE << endl;
fh_real Qtau = SCALE;
fh_real Qt = SCALE;
fh_real Qb = SCALE;
// the renormalization scale is Mtop times the 'scalefactor'
fh_real scalefactor = 1.;
#ifdef FEYNHIGGS_DEBUG
cout << "****** calling FHSetPara ******" << endl;
#endif
error = 1;
FHSetPara(error, scalefactor, MT, TB, MA0, MHp,
M3SL, M3SE, M3SQ, M3SU, M3SD,
M2SL, M2SE, M2SQ, M2SU, M2SD,
M1SL, M1SE, M1SQ, M1SU, M1SD,
MUE,
Atau, At, Ab,
Amu, Ac, As,
Ae, Au, Ad,
M_1, M_2, M_3,
Qtau, Qt, Qb);
//
// Set NMFV parameters
//
/*
fh_ccomplex deltaQLL12, deltaQLL23, deltaQLL13;
fh_ccomplex deltaULR12, deltaULR23, deltaULR13;
fh_ccomplex deltaURL12, deltaURL23, deltaURL13;
fh_ccomplex deltaURR12, deltaURR23, deltaURR13;
fh_ccomplex deltaDLR12, deltaDLR23, deltaDLR13;
fh_ccomplex deltaDRL12, deltaDRL23, deltaDRL13;
fh_ccomplex deltaDRR12, deltaDRR23, deltaDRR13;
FHSetNMFV(error,
deltaQLL12, deltaQLL23, deltaQLL13,
deltaULR12, deltaULR23, deltaULR13,
deltaURL12, deltaURL23, deltaURL13,
deltaURR12, deltaURR23, deltaURR13,
deltaDLR12, deltaDLR23, deltaDLR13,
deltaDRL12, deltaDRL23, deltaDRL13,
deltaDRR12, deltaDRR23, deltaDRR13);
*/
//
// Set LFV parameters
//
/*
fh_ccomplex deltaLLL12, deltaLLL23, deltaLLL13;
fh_ccomplex deltaELR12, deltaELR23, deltaELR13;
fh_ccomplex deltaERL12, deltaERL23, deltaERL13;
fh_ccomplex deltaERR12, deltaERR23, deltaERR13;
FHSetLFV(error,
deltaLLL12, deltaLLL23, deltaLLL13,
deltaELR12, deltaELR23, deltaELR13,
deltaERL12, deltaERL23, deltaERL13,
deltaERR12, deltaERR23, deltaERR13);
*/
}
END_BE_INI_FUNCTION
Updated on 2024-07-18 at 13:53:36 +0000