56 theProbability(aprob),
62 evapMass2 = evapMass*evapMass;
68 delete theCoulombBarrier;
73 theProbability->Initialise();
79 theProbability->ResetProbability();
86 if(resA < theA || resA < resZ || resZ < 0 || (resA == theA && resZ < theZ)
87 || ((resA > 1) && (resA == resZ || resZ == 0)))
92 mass = fragMass + exEnergy;
94 if (mass <= evapMass + resMass) {
return 0.0; }
96 ekinmax = 0.5*((mass-resMass)*(mass+resMass) + evapMass2)/mass - evapMass;
101 bCoulomb = theCoulombBarrier->GetCoulombBarrier(resA, resZ, 0.0);
104 elim = (0 <
OPTxs) ? bCoulomb*0.5 : bCoulomb;
114 G4double resM = mass - evapMass - elim;
115 if (resM < resMass) {
return 0.0; }
116 G4double ekinmin = 0.5*((mass-resM)*(mass+resM) + evapMass2)/mass - evapMass;
123 if(ekinmax <= ekinmin) {
return 0.0; }
125 theProbability->SetDecayKinematics(resZ, resA, resMass, mass);
126 G4double prob = theProbability->TotalProbability(*fragment, ekinmin,
137 if(resA > 4 && theProbability->GetProbability() > 0.0) {
138 ekin = theProbability->SampleEnergy();
140 ekin = std::max(ekin, 0.0);
158 return (p > 0.0) ? theProbability->RecentXS() : 0.0;
165 if (prob <= 0.0) {
return 0.0; }
167 bCoulomb = (theZ > 0) ? theCoulombBarrier->GetCoulombBarrier(resA, resZ, 0.0) : 0.0;
168 G4double p = theProbability->ComputeProbability(kinEnergy, bCoulomb);
CLHEP::HepLorentzVector G4LorentzVector
G4ThreeVector G4RandomDirection()
Hep3Vector boostVector() const
HepLorentzVector & boost(double, double, double)
G4EvaporationChannel(G4int A, G4int Z, G4EvaporationProbability *)
G4double ComputeInverseXSection(G4Fragment *, G4double kinEnergy) override
G4double GetEmissionProbability(G4Fragment *fragment) override
~G4EvaporationChannel() override
G4Fragment * EmittedFragment(G4Fragment *theNucleus) override
void Initialise() override
G4double ComputeProbability(G4Fragment *, G4double kinEnergy) override
G4double GetGroundStateMass() const
G4double GetExcitationEnergy() const
const G4LorentzVector & GetMomentum() const
void SetCreatorModelID(G4int value)
void SetZAandMomentum(const G4LorentzVector &, G4int Z, G4int A, G4int nLambdas=0)
static G4NuclearLevelData * GetInstance()
static G4double GetNuclearMass(const G4double A, const G4double Z)
static G4int GetModelID(const G4int modelIndex)
virtual void Initialise()
G4VEvaporationChannel(const G4String &aName="")