59 const G4double G4InitXscPAI::fDelta = 0.005 ;
60 const G4int G4InitXscPAI::fPAIbin = 100 ;
61 const G4double G4InitXscPAI::fSolidDensity = 0.05*
g/
cm3 ;
71 : fPAIxscVector(nullptr),
72 fPAIdEdxVector(nullptr),
73 fPAIphotonVector(nullptr),
74 fPAIelectronVector(nullptr),
75 fChCosSqVector(nullptr),
76 fChWidthVector(nullptr)
89 for (i = 0; i < fIntervalNumber; i++)
93 for (i = 0; i < fIntervalNumber; i++)
97 for(j = 1; j < 5 ; j++)
104 fBetaGammaSq = fTmax = 0.0;
105 fIntervalTmax = fCurrentInterval = 0;
117 if(fPAIxscVector)
delete fPAIxscVector;
118 if(fPAIdEdxVector)
delete fPAIdEdxVector;
119 if(fPAIphotonVector)
delete fPAIphotonVector;
120 if(fPAIelectronVector)
delete fPAIelectronVector;
121 if(fChCosSqVector)
delete fChCosSqVector;
122 if(fChWidthVector)
delete fChWidthVector;
124 delete fMatSandiaMatrix;
136 for( i = 0 ; i < fIntervalNumber - 1 ; i++ )
138 energy1 = (*(*fMatSandiaMatrix)[i])[0];
139 energy2 = (*(*fMatSandiaMatrix)[i+1])[0];
141 if( energy2 - energy1 > 1.5*fDelta*(energy1 + energy2) )
continue ;
144 for(j = i; j < fIntervalNumber-1; j++)
146 for( k = 0; k < 5; k++ )
148 (*(*fMatSandiaMatrix)[j])[k] = (*(*fMatSandiaMatrix)[j+1])[k];
167 energy1 = (*(*fMatSandiaMatrix)[fIntervalNumber-1])[0];
168 energy2 = 2.*(*(*fMatSandiaMatrix)[fIntervalNumber-1])[0];
173 for( i = fIntervalNumber-2; i >= 0; i-- )
175 energy1 = (*(*fMatSandiaMatrix)[i])[0];
176 energy2 = (*(*fMatSandiaMatrix)[i+1])[0];
182 fNormalizationCof *= fElectronDensity;
184 fNormalizationCof /= cof;
188 for (i = 0; i < fIntervalNumber; i++)
190 for(j = 1; j < 5 ; j++)
192 (*(*fMatSandiaMatrix)[i])[j] *= fNormalizationCof;
236 G4double c1, c2, c3, a1, a2, a3, a4 ;
238 a1 = (*(*fMatSandiaMatrix)[k])[1];
239 a2 = (*(*fMatSandiaMatrix)[k])[2];
240 a3 = (*(*fMatSandiaMatrix)[k])[3];
241 a4 = (*(*fMatSandiaMatrix)[k])[4];
243 c1 = (x2 - x1)/x1/x2 ;
244 c2 = (x2 - x1)*(x2 + x1)/x1/x1/x2/x2 ;
245 c3 = (x2 - x1)*(x1*x1 + x1*x2 + x2*x2)/x1/x1/x1/x2/x2/x2 ;
248 return a1*log(x2/x1) + a2*c1 + a3*c2/2 + a4*c3/3 ;
261 for( i = 0; i <= fIntervalTmax; i++ )
263 if(i == fIntervalTmax)
265 energy1 = (*(*fMatSandiaMatrix)[i])[0];
270 if( omega <= (*(*fMatSandiaMatrix)[i+1])[0])
272 energy1 = (*(*fMatSandiaMatrix)[i])[0];
278 energy1 = (*(*fMatSandiaMatrix)[i])[0];
279 energy2 = (*(*fMatSandiaMatrix)[i+1])[0];
299 a1 = (*(*fMatSandiaMatrix)[k])[1];
300 a2 = (*(*fMatSandiaMatrix)[k])[2];
301 a3 = (*(*fMatSandiaMatrix)[k])[3];
302 a4 = (*(*fMatSandiaMatrix)[k])[4];
304 energy2 = energy1*energy1;
305 energy3 = energy2*energy1;
306 energy4 = energy3*energy1;
308 result = a1/energy1+a2/energy2+a3/energy3+a4/energy4 ;
309 result *=
hbarc/energy1 ;
331 result = eIm2 + eRe2;
346 G4double x0, x02, x03, x04, x05, x1, x2, a1,a2,a3,a4,xx1 ,xx2 , xx12,
347 c1, c2, c3, cof1, cof2, xln1, xln2, xln3,
result ;
352 for( i = 0; i < fIntervalNumber-1; i++)
354 x1 = (*(*fMatSandiaMatrix)[i])[0];
355 x2 = (*(*fMatSandiaMatrix)[i+1])[0] ;
357 a1 = (*(*fMatSandiaMatrix)[i])[1];
358 a2 = (*(*fMatSandiaMatrix)[i])[2];
359 a3 = (*(*fMatSandiaMatrix)[i])[3];
360 a4 = (*(*fMatSandiaMatrix)[i])[4];
362 if( std::abs(x0-x1) < 0.5*(x0+x1)*fDelta )
364 if(x0 >= x1) x0 = x1*(1+fDelta);
365 else x0 = x1*(1-fDelta);
367 if( std::abs(x0-x2) < 0.5*(x0+x2)*fDelta )
369 if(x0 >= x2) x0 = x2*(1+fDelta);
370 else x0 = x2*(1-fDelta);
376 if( xx12 < 0 ) xx12 = -xx12;
380 xln3 = log((x2 + x0)/(x1 + x0)) ;
387 c1 = (x2 - x1)/x1/x2 ;
388 c2 = (x2 - x1)*(x2 +x1)/x1/x1/x2/x2 ;
389 c3 = (x2 -x1)*(x1*x1 + x1*x2 + x2*x2)/x1/x1/x1/x2/x2/x2 ;
391 result -= (a1/x02 + a3/x04)*xln1 ;
392 result -= (a2/x02 + a4/x04)*c1 ;
393 result -= a3*c2/2/x02 ;
394 result -= a4*c3/3/x02 ;
396 cof1 = a1/x02 + a3/x04 ;
397 cof2 = a2/x03 + a4/x05 ;
399 result += 0.5*(cof1 +cof2)*xln2 ;
400 result += 0.5*(cof1 - cof2)*xln3 ;
416 G4int i = fCurrentInterval;
417 G4double betaGammaSq = fBetaGammaSq;
419 G4double be2,cof,x1,x2,x3,x4,x5,x6,x7,x8,
result ;
424 static const G4double betaBohr4 = betaBohr2*betaBohr2*4.0 ;
425 be2 = betaGammaSq/(1 + betaGammaSq) ;
431 if( betaGammaSq < 0.01 ) x2 = log(be2) ;
434 x2 = -log( (1/betaGammaSq - epsilonRe)*
435 (1/betaGammaSq - epsilonRe) +
436 epsilonIm*epsilonIm )/2 ;
438 if( epsilonIm == 0.0 || betaGammaSq < 0.01 )
444 x3 = -epsilonRe + 1/betaGammaSq ;
445 x5 = -1 - epsilonRe + be2*((1 +epsilonRe)*(1 + epsilonRe) +
446 epsilonIm*epsilonIm) ;
448 x7 = atan2(epsilonIm,x3) ;
453 x4 = ((x1 + x2)*epsilonIm + x6)/
hbarc ;
455 x8 = (1 + epsilonRe)*(1 + epsilonRe) +
458 result = (x4 + cof*integralTerm/omega/omega) ;
459 if(result < 1.0e-8) result = 1.0e-8 ;
460 result *= fine_structure_const/be2/
pi ;
463 result *= (1-exp(-be4/betaBohr4)) ;
464 if(fDensity >= fSolidDensity)
489 G4int i = fCurrentInterval;
490 G4double betaGammaSq = fBetaGammaSq;
494 G4double logarithm, x3, x5, argument, modul2, dNdxC ;
498 static const G4double cofBetaBohr = 4.0 ;
500 static const G4double betaBohr4 = betaBohr2*betaBohr2*cofBetaBohr ;
502 be2 = betaGammaSq/(1 + betaGammaSq) ;
505 if( betaGammaSq < 0.01 ) logarithm = log(1.0+betaGammaSq) ;
508 logarithm = -log( (1/betaGammaSq - epsilonRe)*
509 (1/betaGammaSq - epsilonRe) +
510 epsilonIm*epsilonIm )*0.5 ;
511 logarithm += log(1+1.0/betaGammaSq) ;
514 if( epsilonIm == 0.0 || betaGammaSq < 0.01 )
520 x3 = -epsilonRe + 1.0/betaGammaSq ;
521 x5 = -1.0 - epsilonRe +
522 be2*((1.0 +epsilonRe)*(1.0 + epsilonRe) +
523 epsilonIm*epsilonIm) ;
524 if( x3 == 0.0 ) argument = 0.5*
pi;
525 else argument = atan2(epsilonIm,x3) ;
528 dNdxC = ( logarithm*epsilonIm + argument )/
hbarc ;
530 if(dNdxC < 1.0e-8) dNdxC = 1.0e-8 ;
532 dNdxC *= fine_structure_const/be2/
pi ;
534 dNdxC *= (1-exp(-be4/betaBohr4)) ;
536 if(fDensity >= fSolidDensity)
538 modul2 = (1.0 + epsilonRe)*(1.0 + epsilonRe) +
553 G4int i = fCurrentInterval;
554 G4double betaGammaSq = fBetaGammaSq;
559 G4double cof, resonance, modul2, dNdxP ;
563 static const G4double cofBetaBohr = 4.0 ;
565 static const G4double betaBohr4 = betaBohr2*betaBohr2*cofBetaBohr ;
567 be2 = betaGammaSq/(1 + betaGammaSq) ;
571 resonance *= epsilonIm/
hbarc ;
574 dNdxP = ( resonance + cof*integralTerm/omega/omega ) ;
576 if( dNdxP < 1.0e-8 ) dNdxP = 1.0e-8 ;
578 dNdxP *= fine_structure_const/be2/
pi ;
579 dNdxP *= (1-exp(-be4/betaBohr4)) ;
581 if( fDensity >= fSolidDensity )
583 modul2 = (1 + epsilonRe)*(1 + epsilonRe) +
605 if(fPAIxscVector)
delete fPAIxscVector;
607 fPAIxscVector =
new G4PhysicsLogVector( (*(*fMatSandiaMatrix)[0])[0], fTmax, fPAIbin);
608 fPAIxscVector->
PutValue(fPAIbin-1,result);
610 for( i = fIntervalNumber - 1; i >= 0; i-- )
612 if( Tmax >= (*(*fMatSandiaMatrix)[i])[0] )
break;
620 for( k = fPAIbin - 2; k >= 0; k-- )
625 for( i = fIntervalTmax; i >= 0; i-- )
627 if( energy2 > (*(*fMatSandiaMatrix)[i])[0] )
break;
632 for( i = fIntervalTmax; i >= 0; i-- )
634 if( energy1 > (*(*fMatSandiaMatrix)[i])[0] )
break;
641 fCurrentInterval = i1;
648 for( i = i2; i >= i1; i-- )
650 fCurrentInterval = i;
652 if( i==i2 ) result += integral.
Legendre10(
this,
654 (*(*fMatSandiaMatrix)[i])[0] ,energy2);
656 else if( i == i1 ) result += integral.
Legendre10(
this,
658 (*(*fMatSandiaMatrix)[i+1])[0]);
662 (*(*fMatSandiaMatrix)[i])[0] ,(*(*fMatSandiaMatrix)[i+1])[0]);
686 if(fPAIdEdxVector)
delete fPAIdEdxVector;
688 fPAIdEdxVector =
new G4PhysicsLogVector( (*(*fMatSandiaMatrix)[0])[0], fTmax, fPAIbin);
689 fPAIdEdxVector->
PutValue(fPAIbin-1,result);
691 for( i = fIntervalNumber - 1; i >= 0; i-- )
693 if( Tmax >= (*(*fMatSandiaMatrix)[i])[0] )
break;
701 for( k = fPAIbin - 2; k >= 0; k-- )
706 for( i = fIntervalTmax; i >= 0; i-- )
708 if( energy2 > (*(*fMatSandiaMatrix)[i])[0] )
break;
713 for( i = fIntervalTmax; i >= 0; i-- )
715 if( energy1 > (*(*fMatSandiaMatrix)[i])[0] )
break;
722 fCurrentInterval = i1;
729 for( i = i2; i >= i1; i-- )
731 fCurrentInterval = i;
733 if( i==i2 ) result += integral.
Legendre10(
this,
735 (*(*fMatSandiaMatrix)[i])[0] ,energy2);
737 else if( i == i1 ) result += integral.
Legendre10(
this,
739 (*(*fMatSandiaMatrix)[i+1])[0]);
743 (*(*fMatSandiaMatrix)[i])[0] ,(*(*fMatSandiaMatrix)[i+1])[0]);
761 G4double energy1, energy2, beta2, module2, cos2, width,
result = 0.;
767 if(fPAIphotonVector)
delete fPAIphotonVector;
768 if(fChCosSqVector)
delete fChCosSqVector;
769 if(fChWidthVector)
delete fChWidthVector;
771 fPAIphotonVector =
new G4PhysicsLogVector( (*(*fMatSandiaMatrix)[0])[0], fTmax, fPAIbin);
772 fChCosSqVector =
new G4PhysicsLogVector( (*(*fMatSandiaMatrix)[0])[0], fTmax, fPAIbin);
773 fChWidthVector =
new G4PhysicsLogVector( (*(*fMatSandiaMatrix)[0])[0], fTmax, fPAIbin);
775 fPAIphotonVector->
PutValue(fPAIbin-1,result);
776 fChCosSqVector->
PutValue(fPAIbin-1,1.);
777 fChWidthVector->
PutValue(fPAIbin-1,1e-7);
779 for( i = fIntervalNumber - 1; i >= 0; i-- )
781 if( Tmax >= (*(*fMatSandiaMatrix)[i])[0] )
break;
789 for( k = fPAIbin - 2; k >= 0; k-- )
794 for( i = fIntervalTmax; i >= 0; i-- )
796 if( energy2 > (*(*fMatSandiaMatrix)[i])[0] )
break;
801 for( i = fIntervalTmax; i >= 0; i-- )
803 if( energy1 > (*(*fMatSandiaMatrix)[i])[0] )
break;
817 fCurrentInterval = i1;
820 fPAIphotonVector->
PutValue(k,result);
825 for( i = i2; i >= i1; i-- )
827 fCurrentInterval = i;
829 if( i==i2 ) result += integral.
Legendre10(
this,
831 (*(*fMatSandiaMatrix)[i])[0] ,energy2);
833 else if( i == i1 ) result += integral.
Legendre10(
this,
835 (*(*fMatSandiaMatrix)[i+1])[0]);
839 (*(*fMatSandiaMatrix)[i])[0] ,(*(*fMatSandiaMatrix)[i+1])[0]);
841 fPAIphotonVector->
PutValue(k,result);
862 if(fPAIelectronVector)
delete fPAIelectronVector;
864 fPAIelectronVector =
new G4PhysicsLogVector( (*(*fMatSandiaMatrix)[0])[0], fTmax, fPAIbin);
865 fPAIelectronVector->
PutValue(fPAIbin-1,result);
867 for( i = fIntervalNumber - 1; i >= 0; i-- )
869 if( Tmax >= (*(*fMatSandiaMatrix)[i])[0] )
break;
877 for( k = fPAIbin - 2; k >= 0; k-- )
882 for( i = fIntervalTmax; i >= 0; i-- )
884 if( energy2 > (*(*fMatSandiaMatrix)[i])[0] )
break;
889 for( i = fIntervalTmax; i >= 0; i-- )
891 if( energy1 > (*(*fMatSandiaMatrix)[i])[0] )
break;
898 fCurrentInterval = i1;
901 fPAIelectronVector->
PutValue(k,result);
905 for( i = i2; i >= i1; i-- )
907 fCurrentInterval = i;
909 if( i==i2 ) result += integral.
Legendre10(
this,
911 (*(*fMatSandiaMatrix)[i])[0] ,energy2);
913 else if( i == i1 ) result += integral.
Legendre10(
this,
915 (*(*fMatSandiaMatrix)[i+1])[0]);
919 (*(*fMatSandiaMatrix)[i])[0] ,(*(*fMatSandiaMatrix)[i+1])[0]);
921 fPAIelectronVector->
PutValue(k,result);
938 omega2 = omega*omega ;
939 omega3 = omega2*omega ;
940 omega4 = omega2*omega2 ;
942 for(i = 0; i < fIntervalNumber;i++)
944 if( omega < (*(*fMatSandiaMatrix)[i])[0] ) break ;
948 G4cout<<
"Warning: energy in G4InitXscPAI::GetPhotonLambda < I1"<<
G4endl;
952 a1 = (*(*fMatSandiaMatrix)[i])[1];
953 a2 = (*(*fMatSandiaMatrix)[i])[2];
954 a3 = (*(*fMatSandiaMatrix)[i])[3];
955 a4 = (*(*fMatSandiaMatrix)[i])[4];
957 lambda = 1./(a1/omega + a2/omega2 + a3/omega3 + a4/omega4);
G4double G4ParticleHPJENDLHEData::G4double result
G4double Legendre10(T &typeT, F f, G4double a, G4double b)
static constexpr double hbarc
G4double PAIdNdxCherenkov(G4double omega)
G4double GetDensity() const
G4int GetMaxInterval() const
G4double ModuleSqDielectricConst(G4int intervalNumber, G4double energy)
G4double ImPartDielectricConst(G4int intervalNumber, G4double energy)
void KillCloseIntervals()
G4double RePartDielectricConst(G4double energy)
G4double GetLowEdgeEnergy(size_t binNumber) const
static constexpr double g
G4double GetStepCerenkovLoss(G4double step)
static constexpr double electron_mass_c2
G4double DifPAIxSection(G4double omega)
void IntegralCherenkov(G4double bg2, G4double Tmax)
G4GLOB_DLL std::ostream G4cout
G4double GetStepEnergyLoss(G4double step)
G4double GetElectronDensity() const
void PutValue(size_t index, G4double theValue)
G4InitXscPAI(const G4MaterialCutsCouple *matCC)
void IntegralPAIxSection(G4double bg2, G4double Tmax)
static constexpr double cm3
G4double DifPAIdEdx(G4double omega)
void IntegralPlasmon(G4double bg2, G4double Tmax)
G4double GetSandiaMatTable(G4int, G4int) const
static constexpr double pi
void IntegralPAIdEdx(G4double bg2, G4double Tmax)
G4double RutherfordIntegral(G4int intervalNumber, G4double limitLow, G4double limitHigh)
G4double PAIdNdxPlasmon(G4double omega)
static constexpr double fine_structure_const
G4double IntegralTerm(G4double omega)
G4double GetPhotonLambda(G4double omega)
const G4Material * GetMaterial() const
G4double GetStepPlasmonLoss(G4double step)