92{
93 G4double result = 0., cofL, cofR, cofL2, cofR2, cofLR;
94
97
98 if( pName == "nu_e")
99 {
102 }
103 else if( pName == "anti_nu_e")
104 {
107 }
108 else if( pName == "nu_mu")
109 {
112 }
113 else if( pName == "anti_nu_mu")
114 {
117 }
118 else if( pName == "nu_tau")
119 {
122 }
123 else if( pName == "anti_nu_tau")
124 {
127 }
128 else
129 {
130 return result;
131 }
132
133
134 cofL2 = cofL*cofL;
135 cofR2 = cofR*cofR;
136 cofLR = cofL*cofR;
137
139 {
146
147 result = (cofL2+cofR2)*(tM-tC);
148 result -= (cofR2+cofLR*0.5*electron_mass_c2/
energy)*(tM2-tC2)/
energy;
149 result += cofR2*(tM3-tC3)/energy/energy/3.;
150 }
151 else
152 {
156
157 result = (cofL2+cofR2)*rtM*energy;
158 result -= (cofR2*
energy+cofLR*0.5*electron_mass_c2)*rtM2;
159 result += cofR2*rtM3*
energy/3.;
160 }
161
162
163
164
171
174
175 if( energy > 50.*GeV )
176 {
177 result *= bb;
178 result /= 1.+ aa*totS/mz/mz;
179
180 if( pName == "anti_nu_e")
181 {
182 result *= 1. + dd*gw*gw*totS/( (totS-mw*mw)*(totS-mw*mw)+gw*gw*mw*mw );
183 }
184 }
185
187
188 result *= ZZ;
189
191
192 return result;
193}
G4ParticleDefinition * GetDefinition() const
G4double GetTotalEnergy() const
const G4String & GetParticleName() const
G4double energy(const ThreeVector &p, const G4double m)