66 HighestEnergyLimit = 1000*
TeV;
101 CrossSecFactor = fac;
102 G4cout <<
"The cross section for AnnihiToMuPair is artificially "
103 <<
"increased by the CrossSecFactor=" << CrossSecFactor <<
G4endl;
114 static const G4double Sig0 =
pi*Rmuon*Rmuon/3.;
117 if (Epos < LowestEnergyLimit)
return CrossSection;
119 G4double xi = LowestEnergyLimit/Epos;
120 G4double SigmaEl = Sig0*xi*(1.+xi/2.)*sqrt(1.-xi);
121 CrossSection = SigmaEl*
Z;
137 G4double AtomicZ = (*theElementVector)[i]->GetZ();
138 SIGMA += NbOfAtomsPerVolume[i] *
160 if(CurrentSigma >
DBL_MIN) mfp = 1.0/(CurrentSigma*CrossSecFactor);
189 if (Epos < LowestEnergyLimit) {
195 G4double xi = LowestEnergyLimit/Epos;
210 G4double Ecm = sqrt(0.5*Mele*(Epos+Mele));
211 G4double Pcm = sqrt(Ecm*Ecm-Mmuon*Mmuon);
212 G4double beta = sqrt((Epos-Mele)/(Epos+Mele));
218 G4double EmuPlus = gamma*( Ecm+cost*beta*Pcm);
219 G4double EmuMinus = gamma*( Ecm-cost*beta*Pcm);
220 G4double PmuPlusZ = gamma*(beta*Ecm+cost* Pcm);
221 G4double PmuMinusZ = gamma*(beta*Ecm-cost* Pcm);
227 G4double PmuPlus = sqrt(Pt*Pt+PmuPlusZ *PmuPlusZ );
228 G4double PmuMinus = sqrt(Pt*Pt+PmuMinusZ*PmuMinusZ);
233 MuPlusDirection ( PmuPlusX/PmuPlus, PmuPlusY/PmuPlus, PmuPlusZ/PmuPlus );
235 MuMinusDirection(PmuMinusX/PmuMinus,PmuMinusY/PmuMinus,PmuMinusZ/PmuMinus);
239 MuPlusDirection.
rotateUz(PositronDirection);
240 MuMinusDirection.
rotateUz(PositronDirection);
264 G4String comments =
"e+e->mu+mu- annihilation, atomic e- at rest, SubType=.";
267 G4cout <<
" threshold at " << LowestEnergyLimit/
GeV <<
" GeV"
268 <<
" good description up to "
269 << HighestEnergyLimit/
TeV <<
" TeV for all Z." <<
G4endl;