116 else if (Z == 2 && A == 3) theDef =
G4He3::He3();
117 else if (Z == 2 && A == 4) theDef =
theAlpha;
136 fTmax = 4.0*ptot*ptot;
151 XsCoulomb=XsCoulomb*0.38938e+6;
158 G4double CoulombProb = XsCoulomb/(XsCoulomb+XsElastHad);
170 G4double par1 = 2.*(1.+Am)/(1.+ctet1);
174 G4double cosThetaCMS = (par1*ctet1- Ksi*(1.+2.*Am))/(par1-Ksi);
178 G4double PtProjCMS = ptot*std::sqrt(1.0 - cosThetaCMS*cosThetaCMS);
179 G4double PtX= PtProjCMS * std::cos(phi);
180 G4double PtY= PtProjCMS * std::sin(phi);
183 Fproj.
setE(std::sqrt(PtX*PtX+PtY*PtY+PtZ*PtZ+Mproj*Mproj));
184 T = -(Pproj-Fproj).mag2();
202 if((A>=12.) && (A<27) )
fRa=
fRa*0.85;
203 if((A>=27.) && (A<48) )
fRa=
fRa*0.90;
204 if((A>=48.) && (A<65) )
fRa=
fRa*0.95;
218 { rho = 1.3347-10.342*Plab/1000.+22.277*Plab/1000.*Plab/1000.-
219 13.634*Plab/1000.*Plab/1000.*Plab/1000. ;}
220 if((Plab < 5500.)&&(Plab >= 610.) )
222 if((Plab >= 5500.)&&(Plab < 12300.) )
225 { rho = 0.135-2.26/(std::sqrt(S)) ;}
227 Ref2 = 0.35 + 0.9/std::sqrt(std::sqrt(S-4.*0.88))+0.04*
G4Log(S) ;
228 ceff2 = 0.375 - 2./S + 0.44/(
sqr(S-4.)+1.5) ;
245 { Ref2 =
fRa*
fRa +2.48*0.01*sig_pbarp*
fRa - 2.23e-6*sig_pbarp*sig_pbarp*
fRa*
fRa;
246 ceff2 = 0.16+3.3e-4*sig_pbarp+0.35*
G4Exp(-0.03*sig_pbarp);
249 { Ref2 =
fRa*
fRa -0.46 +0.03*sig_pbarp - 2.98e-6*sig_pbarp*sig_pbarp;
250 ceff2= 0.078 + 6.657e-4*sig_pbarp + 0.3359*
G4Exp(-0.03*sig_pbarp);
253 { Ref2 =
fRa*
fRa - 1.36 + 0.025 * sig_pbarp - 3.69e-7 * sig_pbarp*sig_pbarp;
254 ceff2 = 0.149 + 7.091e-04*sig_pbarp + 0.3743*
G4Exp(-0.03*sig_pbarp);
257 { Ref2 =
fRa*
fRa - 1.36 + 0.025 * sig_pbarp - 3.69e-7 * sig_pbarp*sig_pbarp;
258 ceff2 = 0.149 + 7.091e-04*sig_pbarp + 0.3743*
G4Exp(-0.03*sig_pbarp);
262 Ref2 =
fRa*
fRa - 0.28 + 0.019 * sig_pbarp + 2.06e-6 * sig_pbarp*sig_pbarp;
263 ceff2 = 0.297 + 7.853e-04*sig_pbarp + 0.2899*
G4Exp(-0.03*sig_pbarp);
270 Ref2 = XstotalHad/10./2./
pi ;
273 ceff2 = 0.38 + 2.0e-4 *sig_pbarp + 0.5 *
G4Exp(-0.03*sig_pbarp);
277 ceff2 = 0.297 + 7.853e-04*sig_pbarp + 0.2899*
G4Exp(-0.03*sig_pbarp);
281 ceff2 = 0.65 + 3.0e-4*sig_pbarp + 0.55 *
G4Exp(-0.03*sig_pbarp);
285 ceff2 = 0.57 + 2.5e-4*sig_pbarp + 0.65 *
G4Exp(-0.02*sig_pbarp);
289 ceff2 = 0.40 + 3.5e-4 *sig_pbarp + 0.45 *
G4Exp(-0.02*sig_pbarp);
296 Ref2 = XstotalHad/10./2./
pi ;
299 ceff2 = 0.26 + 2.2e-4*sig_pbarp + 0.33*
G4Exp(-0.03*sig_pbarp);
303 ceff2 = 0.149 + 7.091e-04*sig_pbarp + 0.3743*
G4Exp(-0.03*sig_pbarp);
307 ceff2 = 0.57 + 2.5e-4*sig_pbarp + 0.65 *
G4Exp(-0.02*sig_pbarp);
311 ceff2 = 0.39 + 2.7e-4*sig_pbarp + 0.7 *
G4Exp(-0.02*sig_pbarp);
315 ceff2 = 0.24 + 3.5e-4*sig_pbarp + 0.75 *
G4Exp(-0.03*sig_pbarp);
323 Ref2 = XstotalHad/10./2./
pi ;
326 ceff2 = 0.22 + 2.0e-4*sig_pbarp + 0.2 *
G4Exp(-0.03*sig_pbarp);
330 ceff2= 0.078 + 6.657e-4*sig_pbarp + 0.3359*
G4Exp(-0.03*sig_pbarp);
334 ceff2 = 0.40 + 3.5e-4 *sig_pbarp + 0.45 *
G4Exp(-0.02*sig_pbarp);
338 ceff2 = 0.24 + 3.5e-4*sig_pbarp + 0.75 *
G4Exp(-0.03*sig_pbarp);
342 ceff2 = 0.17 + 3.5e-4*sig_pbarp + 0.45 *
G4Exp(-0.03*sig_pbarp);
346 fRef=std::sqrt(Ref2);
347 fceff = std::sqrt(ceff2);
353 const G4int maxNumberOfLoops = 10000;
354 G4int loopCounter = 0;
365 ++loopCounter < maxNumberOfLoops );
366 if ( loopCounter >= maxNumberOfLoops ) {
394 if(!(T < 0.0 || T >= 0.0))
398 G4cout <<
"G4DiffuseElastic:WARNING: A = " << A
399 <<
" mom(GeV)= " << plab/
GeV
400 <<
" S-wave will be sampled"
410 if(cosTet > 1.0 ) cosTet= 1.;
411 if(cosTet < -1.0 ) cosTet=-1.;
430 if(!(T < 0.0 || T >= 0.0))
434 G4cout <<
"G4DiffuseElastic:WARNING: A = " << A
435 <<
" mom(GeV)= " << plab/
GeV
436 <<
" S-wave will be sampled"
453 else if( cost <= -1.0)
460 sint = std::sqrt((1.0-cost)*(1.0+cost));
484 if( std::fabs(x) < 0.01 )
504 fBeta = a/std::sqrt(1+a*a);
540 G4double modvalue, value2, fact1, fact2, arg, shift, bessel;
542 modvalue = std::fabs(value);
546 value2 = value*
value;
548 fact1 = 57568490574.0 + value2*(-13362590354.0
549 + value2*( 651619640.7
550 + value2*(-11214424.18
551 + value2*( 77392.33017
552 + value2*(-184.9052456 ) ) ) ) );
554 fact2 = 57568490411.0 + value2*( 1029532985.0
555 + value2*( 9494680.718
556 + value2*(59272.64853
557 + value2*(267.8532712
558 + value2*1.0 ) ) ) );
560 bessel = fact1/fact2;
568 shift = modvalue-0.785398164;
570 fact1 = 1.0 + value2*(-0.1098628627e-2
571 + value2*(0.2734510407e-4
572 + value2*(-0.2073370639e-5
573 + value2*0.2093887211e-6 ) ) );
574 fact2 = -0.1562499995e-1 + value2*(0.1430488765e-3
575 + value2*(-0.6911147651e-5
576 + value2*(0.7621095161e-6
577 - value2*0.934945152e-7 ) ) );
579 bessel = std::sqrt(0.636619772/modvalue)*(std::cos(shift)*fact1 - arg*std::sin(shift)*fact2);
591 G4double modvalue, value2, fact1, fact2, arg, shift, bessel;
593 modvalue = std::fabs(value);
595 if ( modvalue < 8.0 )
597 value2 = value*
value;
598 fact1 = value*(72362614232.0 + value2*(-7895059235.0
599 + value2*( 242396853.1
600 + value2*(-2972611.439
601 + value2*( 15704.48260
602 + value2*(-30.16036606 ) ) ) ) ) );
604 fact2 = 144725228442.0 + value2*(2300535178.0
605 + value2*(18583304.74
606 + value2*(99447.43394
607 + value2*(376.9991397
608 + value2*1.0 ) ) ) );
609 bessel = fact1/fact2;
616 shift = modvalue - 2.356194491;
618 fact1 = 1.0 + value2*( 0.183105e-2
619 + value2*(-0.3516396496e-4
620 + value2*(0.2457520174e-5
621 + value2*(-0.240337019e-6 ) ) ) );
623 fact2 = 0.04687499995 + value2*(-0.2002690873e-3
624 + value2*( 0.8449199096e-5
625 + value2*(-0.88228987e-6
626 + value2*0.105787412e-6 ) ) );
628 bessel = std::sqrt( 0.636619772/modvalue)*(std::cos(shift)*fact1 - arg*std::sin(shift)*fact2);
629 if (value < 0.0) bessel = -bessel;
640 if( std::fabs(x) < 0.01 )
644 result = (2.- x2 + x2*x2/6.)/4.;
663 if(cteta1 < -1.) cteta1 = -1.0;