62 if(de > 0.0) { elimit = de; }
63 if(eps > 0.0) { accuracy = eps; }
87 const G4double edeltamin = 0.1*CLHEP::MeV;
88 const G4double edeltamax = 2*CLHEP::MeV;
89 G4double edelta = std::min(std::min(elimit, edeltamax), edeltamin);
90 G4double xbin = (emax - emin)/edelta + 1.0;
95 edelta = (emax - emin)/ibin;
102 G4cout <<
"### G4VEmissionProbability::IntegrateProbability: "
103 <<
"probmax=" << probmax <<
" Emin=" << emin
104 <<
" Emax=" << emax <<
" QB=" << cb <<
" nbin=" << nbin
107 fE1 = fE2 = fP2 = 0.0;
110 for(
G4int i=0; i<nbin; ++i) {
118 G4cout <<
" " << i <<
". E= " << x <<
" prob= " << y
119 <<
" Edel= " << edelta <<
G4endl;
123 }
else if(0.0 == fE1 && 2*y < probmax) {
127 G4double del = (y + problast)*edelta*0.5;
135 0.7*edelta > edeltamin) {
137 }
else if(del < 0.1*
pProbability && 1.5*edelta < edeltamax) {
141 if(fE1 > emin && fE1 < emax) {
142 fE2 = std::max(0.5*(fE1 + emax), emax - edelta);
148 << probmax <<
" emin=" << emin <<
" emax=" << emax
149 <<
" E1=" << fE1 <<
" E2=" << fE2 <<
G4endl;
168 if(fE1 > 0.0 && fP2 > 0.0 && fP2 < 0.5*probmax) {
169 a0 =
G4Log(probmax/fP2)/(fE2 - fE1);
174 a1 = (x > alim) ? 1.0 -
G4Exp(-x) : x*(1.0 - 0.5*x);
182 G4cout <<
"### G4VEmissionProbability::SampleEnergy: "
183 <<
" Emin= " << emin <<
" Emax= " << emax
184 <<
"/n E1=" << fE1 <<
" p1=" << p1
185 <<
" probmax=" << probmax <<
" P2=" << fP2 <<
G4endl;
189 const G4int nmax = 1000;
198 }
else if (q <= p1) {
200 ekin = del*q/p1 + emin;
202 ekin = fE1 -
G4Log(1.0 - (q - p1)*a1/p2)/
a0;
206 gmax = probmax*((x > alim) ?
G4Exp(-x) : 1.0 - x*(1.0 - 0.5*x));
212 <<
". prob= " << gg <<
" probmax= " << probmax
213 <<
" Ekin= " << ekin <<
G4endl;
215 if((gg > gmax || n > nmax) &&
pVerbose > 1) {
216 G4cout <<
"### G4VEmissionProbability::SampleEnergy for Z= " <<
theZ
217 <<
" A= " <<
theA <<
" Eex(MeV)=" << fExc <<
" p1=" << p1
218 <<
"\n Warning n= " << n
219 <<
" prob/gmax=" << gg/gmax
220 <<
" prob=" << gg <<
" gmax=" << gmax <<
" probmax=" << probmax
221 <<
"\n Ekin= " << ekin <<
" Emin= " << emin
222 <<
" Emax= " << emax <<
G4endl;
224 }
while(gmax*rndm->
flat() > gg && n < nmax);
225 G4double enew = FindRecoilExcitation(ekin);
227 G4cout <<
"### SampleEnergy: Efinal= "
228 << enew <<
" E=" << ekin <<
" Eexc=" << fExcRes <<
G4endl;
245 G4cout <<
"### FindRecoilExcitation for resZ= "
247 <<
" evaporated Z= " <<
theZ <<
" A= " <<
theA
248 <<
" Ekin= " << e <<
" Eexc= " << fExcRes <<
G4endl;
254 return std::max(0.5*(m02 + m12 - m22)/
pMass - mass, 0.0);
256 if(!fFD) {
return e; }
260 if(
nullptr == lManager) {
return e; }
263 if(fExcRes > lManager->MaxLevelEnergy() +
pTolerance) {
return e; }
266 std::size_t idx = lManager->NearestLevelIndex(fExcRes);
267 auto level = lManager->GetLevel(idx);
270 if (level->GetTimeGamma() == 0.0) {
return e; }
273 G4double elevel = lManager->LevelEnergy(idx);
282 return std::max(0.5*(m02 + m12 - mr2)/
pMass - mass, 0.0);
G4double G4Exp(G4double initial_x)
Exponential Function double precision.
G4double G4Log(G4double x)
G4GLOB_DLL std::ostream G4cout
G4bool GetDiscreteExcitationFlag() const
G4int GetDeexModelType() const
G4double GetNuclearLevelWidth() const
G4double GetMinExcitation() const
static G4NuclearLevelData * GetInstance()
static G4double GetNuclearMass(const G4double A, const G4double Z)
static G4Pow * GetInstance()
G4VEmissionProbability(G4int Z, G4int A)
virtual void Initialise()
void ResetIntegrator(size_t nbin, G4double de, G4double eps)
G4double IntegrateProbability(G4double elow, G4double ehigh, G4double CB)
virtual G4double ComputeProbability(G4double anEnergy, G4double CB)
virtual G4double EmissionProbability(const G4Fragment &fragment, G4double anEnergy)
G4NuclearLevelData * pNuclearLevelData