72 resA13 = lastA = muu = freeU = a0 = a1 = delta0 = delta1 = 0.0;
73 pcoeff = fGamma*
pEvapMass*CLHEP::millibarn
74 /((CLHEP::pi*CLHEP::hbarc)*(CLHEP::pi*CLHEP::hbarc));
76 if (1 ==
theZ && 1 ==
theA) { index = 1; }
77 else if (1 ==
theZ && 2 ==
theA) { index = 2; }
78 else if (1 ==
theZ && 3 ==
theA) { index = 3; }
79 else if (2 ==
theZ && 3 ==
theA) { index = 4; }
80 else if (2 ==
theZ && 4 ==
theA) { index = 5; }
137 G4double SystemEntropy = 2.0*std::sqrt(a0*freeU);
138 const G4double RN2 = 2.25*CLHEP::fermi*CLHEP::fermi
139 /(CLHEP::twopi*CLHEP::hbar_Planck*hbar_Planck);
149 G4double Term1 = Beta*a1 - 1.5 + maxea;
150 G4double Term2 = (2.0*Beta*a1-3.0)*std::sqrt(maxea) + 2*maxea;
152 G4double ExpTerm1 = (SystemEntropy <= explim) ?
G4Exp(-SystemEntropy) : 0.0;
154 G4double ExpTerm2 = 2.*std::sqrt(maxea) - SystemEntropy;
155 ExpTerm2 = std::min(ExpTerm2, explim);
156 ExpTerm2 =
G4Exp(ExpTerm2);
158 pProbability = GlobalFactor*(Term1*ExpTerm1 + Term2*ExpTerm2);
181 if (excRes < 0.0) {
return 0.0; }
183 K1 = std::max(K1, 0.0);
185 if (xs <= 0.0) {
return 0.0; }
188 G4double E0 = std::max(freeU - delta0, 0.0);
189 G4double E1 = std::max(excRes - delta1, 0.0);
190 G4double prob = pcoeff*
G4Exp(2.0*(std::sqrt(a1*E1) - std::sqrt(a0*E0)))*K1*xs;
198 if (
OPTxs > 1 && 0 < index &&
resA != lastA) {
203 recentXS = fXSection->GetElementCrossSection(K,
resZ)/CLHEP::millibarn;
205 }
else if (
OPTxs == 2) {
208 }
else if (
OPTxs == 3) {
G4double G4Exp(G4double initial_x)
Exponential Function double precision.
static G4double ComputeCrossSection(G4double K, G4double cb, G4double resA13, G4double amu1, G4int idx, G4int Z, G4int resA)
static G4Deuteron * Deuteron()
G4double CrossSection(G4double K, G4double CB)
G4EvaporationProbability(G4int anA, G4int aZ, G4double aGamma)
~G4EvaporationProbability() override
G4double ComputeProbability(G4double K, G4double CB) override
virtual G4double CalcAlphaParam(const G4Fragment &fragment)
virtual G4double TotalProbability(const G4Fragment &fragment, G4double minKinEnergy, G4double maxKinEnergy, G4double CB, G4double exEnergy)
virtual G4double CalcBetaParam(const G4Fragment &fragment)
static G4double ComputePowerParameter(G4int resA, G4int idx)
static G4double ComputeCrossSection(G4double K, G4double cb, G4double resA13, G4double amu1, G4int idx, G4int Z, G4int A, G4int resA)
static G4Neutron * Neutron()
static G4Proton * Proton()
static G4Triton * Triton()
G4VEmissionProbability(G4int Z, G4int A)
void ResetIntegrator(size_t nbin, G4double de, G4double eps)
G4double IntegrateProbability(G4double elow, G4double ehigh, G4double CB)
G4NuclearLevelData * pNuclearLevelData