CMS 3D CMS Logo

PetrukhinModel.cc
Go to the documentation of this file.
1 // PetrukhinModel.cc Class:
3 //
4 // Improvements: Function of Muom Brem using nuclear screening correction
5 // Description: Muon bremsstrahlung using the Petrukhin's model in FASTSIM
6 // Authors: Sandro Fonseca de Souza and Andre Sznajder (UERJ/Brazil)
7 // Date: 23-Nov-2010
9 
10 #include <fstream>
11 #include "TF1.h"
13 #include <cmath>
14 using namespace std;
15 
16 //=====================================================================
17 
19 //Function of Muom Brem using nuclear-electron screening correction from G4 style
20 //
21 
22 double PetrukhinFunc(double *x, double *p) {
23  //Function independent variable
24  double nu = x[0]; //fraction of muon's energy transferred to the photon
25 
26  // Parameters
27  double E = p[0]; //Muon Energy (in GeV)
28  double A = p[1]; // Atomic weight
29  double Z = p[2]; // Atomic number
30 
31  /*
32 
34 //Function of Muom Brem using nuclear screening correction
35 //Ref: http://pdg.lbl.gov/2008/AtomicNuclearProperties/adndt.pdf
36 
37  //Physical constants
38  double B = 182.7;
39  double ee = sqrt(2.7181) ; // sqrt(e)
40  double ZZ= pow( Z,-1./3.); // Z^-1/3
42  double emass = 0.0005109990615; // electron mass (GeV/c^2)
43  double mumass = 0.105658367;//mu mass (GeV/c^2)
44 
45  double re = 2.817940285e-13;// Classical electron radius (Units: cm)
46  double alpha = 1./137.03599976; // fine structure constant
47  double Dn = 1.54* (pow(A,0.27));
48  double constant = pow((2.0 * Z * emass/mumass * re ),2.0);
50 
51  double delta = (mumass * mumass * nu) /(2.* E * (1.- nu));
52 
53  double Delta_n = TMath::Log(Dn / (1.+ delta *( Dn * ee -2.)/ mumass)); //nuclear screening correction
54 
55  double Phi = TMath::Log((B * mumass * ZZ / emass)/ (1.+ delta * ee * B * ZZ / emass)) - Delta_n;//phi(delta)
56 
57  //Diff. Cross Section for Muon Brem from a screened nuclear (Equation 16: REF: LBNL-44742)
58  double f = alpha * constant *(4./3.-4./3.*nu + nu*nu)*Phi/nu;
59 */
60 
62  // Function for Muon Brem Xsec from G4
64  //Physical constants
65  double B = 183.;
66  double Bl = 1429.;
67  double ee = 1.64872; // sqrt(e)
68  double Z13 = pow(Z, -1. / 3.); // Z^-1/3
69  double Z23 = pow(Z, -2. / 3.); // Z^-2/3
70 
71  //Original values of paper
72  double emass = 0.0005109990615; // electron mass (GeV/c^2)
73  double mumass = 0.105658367; // muon mass (GeV/c^2)
74  // double re = 2.817940285e-13; // Classical electron radius (Units: cm)
75  double alpha = 0.00729735; // 1./137.03599976; // fine structure constant
76  double constant = 1.85736e-30; // pow( ( emass / mumass * re ) , 2.0);
77 
78  double Dn = 1.54 * (pow(A, 0.27));
79  double Dnl = pow(Dn, (1. - 1. / Z));
80 
81  double delta = (mumass * mumass * nu) / (2. * E * (1. - nu));
82 
83  double Phi_n = TMath::Log(B * Z13 * (mumass + delta * (Dnl * ee - 2)) / (Dnl * (emass + delta * ee * B * Z13)));
84 
85  double Phi_e =
86  TMath::Log((Bl * Z23 * mumass) / (1. + delta * mumass / (emass * emass * ee)) / (emass + delta * ee * Bl * Z23));
87 
88  //Diff. Cross Section for Muon Brem from G4 ( without NA/A factor )
89  double f = 16. / 3. * alpha * constant * Z * (Z * Phi_n + Phi_e) * (1. / nu) * (1. - nu + 0.75 * nu * nu);
90 
91  return f;
92 }
f
double f[11][100]
Definition: MuScleFitUtils.cc:78
AlCaHLTBitMon_ParallelJobs.p
p
Definition: AlCaHLTBitMon_ParallelJobs.py:153
alpha
float alpha
Definition: AMPTWrapper.h:105
DDAxes::x
PetrukhinModel.h
PetrukhinFunc
double PetrukhinFunc(double *x, double *p)
Definition: PetrukhinModel.cc:22
dumpMFGeometry_cfg.delta
delta
Definition: dumpMFGeometry_cfg.py:25
TtFullHadDaughter::B
static const std::string B
Definition: TtFullHadronicEvent.h:9
std
Definition: JetResolutionObject.h:76
funct::pow
Power< A, B >::type pow(const A &a, const B &b)
Definition: Power.h:29
BeamSpotPI::Z
Definition: BeamSpotPayloadInspectorHelper.h:33
A