45 #ifndef G4ElasticHadrNucleusHE_h
46 #define G4ElasticHadrNucleusHE_h 1
58 static const G4int NHADRONS = 26;
59 static const G4int ONQ0 = 5;
60 static const G4int ONQ2 = 100;
61 static const G4int NENERGY = 30;
62 static const G4int NQTABLE = NENERGY*ONQ2;
81 void DefineNucleusParameters(
G4double A);
172 G4int HadronCode[NHADRONS];
173 G4int HadronType[NHADRONS];
174 G4int HadronType1[NHADRONS];
207 G4double HadrTot, HadrSlope, HadrReIm, TotP,
208 DDSect2, DDSect3, ConstU, FmaxT;
211 G4double BoundaryP[7], BoundaryTL[7], BoundaryTG[7];
215 G4double Slope1, Slope2, Coeff1, Coeff2, MaxTR;
241 return c1+(p-p1)*(c2-c1)/(p2-p1);
253 for(i=1; i<
n; i++)
if(hLabMomentum <= EnP[i])
break;
255 if(i == n) i = n - 1;
257 Coeff0 =
LineInterpol(EnP[i], EnP[i-1], C0P[i], C0P[i-1], hLabMomentum);
258 Coeff1 =
LineInterpol(EnP[i], EnP[i-1], C1P[i], C1P[i-1], hLabMomentum);
259 Slope0 =
LineInterpol(EnP[i], EnP[i-1], B0P[i], B0P[i-1], hLabMomentum);
260 Slope1 =
LineInterpol(EnP[i], EnP[i-1], B1P[i], B1P[i-1], hLabMomentum);
271 if ( numN >= numM && numN <= 240)
return SetBinom[numN][numM];
280 return GetFt(Q2)/FmaxT;