61 if (myOwnFissionBarrier)
delete theFissionBarrierPtr;
62 if (myOwnFissionProbability)
delete theFissionProbabilityPtr;
63 if (myOwnLevelDensity)
delete theLevelDensityPtr;
71 if (
OPTxs == 1) { fFactor = 0.5; }
80 fissionProbability = 0.0;
82 if (
A >= 65 && Z > 16) {
84 pairingCorrection->GetFissionPairingCorrection(
A, Z);
87 fissionBarrier = theFissionBarrierPtr->FissionBarrier(
A, Z, exEnergy);
88 maxKineticEnergy = exEnergy - fissionBarrier;
90 theFissionProbabilityPtr->EmissionProbability(*fragment,
94 return fissionProbability*fFactor;
107 G4double pcorr = pairingCorrection->GetFissionPairingCorrection(
A,Z);
108 if (U <= pcorr) {
return Fragment1; }
117 theParam.DefineParameters(
A, Z, U-pcorr, fissionBarrier);
129 G4double FragmentsExcitationEnergy = 0.0;
130 G4double FragmentsKineticEnergy = 0.0;
136 A1 = FissionAtomicNumber(
A);
137 Z1 = FissionCharge(
A, Z, A1);
143 if (A2 < 1 || Z2 < 0 || Z2 > A2) {
144 FragmentsExcitationEnergy = -1.0;
153 FragmentsExcitationEnergy = -1.0;
157 FragmentsKineticEnergy = FissionKineticEnergy(
A , Z,
168 FragmentsExcitationEnergy =
169 Tmax - FragmentsKineticEnergy + pcorr;
172 }
while (FragmentsExcitationEnergy < 0.0 && ++Trials < 100);
174 if (FragmentsExcitationEnergy <= 0.0) {
176 "G4CompetitiveFission::BreakItUp: Excitation energy for fragments < 0.0!");
180 M1 += FragmentsExcitationEnergy * A1/
static_cast<G4double>(
A);
182 M2 += FragmentsExcitationEnergy * A2/
static_cast<G4double>(
A);
186 G4double etot1 = ((
M - M2)*(
M + M2) + M1*M1)/(2*
M);
193 Fragment1 =
new G4Fragment( A1, Z1, FourMomentum1);
195 theNucleusMomentum -= FourMomentum1;
203G4CompetitiveFission::FissionAtomicNumber(
G4int A)
219 if (w > 1000.0 ) {
C2 = C2S; }
220 else if (w < 0.001) {
C2 = C2A; }
221 else {
C2 = std::max(C2A,C2S); }
234 G4double Mass2 = MassDistribution(Am1,
A);
236 G4double Mass4 = MassDistribution(Am2,
A);
240 if (Mass2 > MassMax) { MassMax = Mass2; }
241 if (Mass3 > MassMax) { MassMax = Mass3; }
242 if (Mass4 > MassMax) { MassMax = Mass4; }
243 if (Mass5 > MassMax) { MassMax = Mass5; }
250 Pm = MassDistribution(xm,
A);
263 G4double y0 = (x-theParam.GetAs())/theParam.GetSigmaS();
266 G4double y1 = (x - theParam.GetA1())/theParam.GetSigma1();
267 G4double y2 = (x - theParam.GetA2())/theParam.GetSigma2();
268 G4double z1 = (x -
A + theParam.GetA1())/theParam.GetSigma1();
269 G4double z2 = (x -
A + theParam.GetA2())/theParam.GetSigma2();
270 G4double Xasym = LocalExp(y1) + LocalExp(y2)
271 + 0.5*(LocalExp(z1) + LocalExp(z2));
275 if (w > 1000) { res = Xsym; }
276 else if (w < 0.001) { res = Xasym; }
277 else { res = w*Xsym+Xasym; }
286 if (Af >= 134.0) { DeltaZ = -0.45; }
287 else if (Af <= (
A-134.0)) { DeltaZ = 0.45; }
288 else { DeltaZ = -0.45*(Af-
A*0.5)/(134.0-
A*0.5); }
294 theZ = G4RandGauss::shoot(Zmean,sigma);
296 }
while (theZ < 1.0 || theZ > (Z-1.0) || theZ > Af);
302G4CompetitiveFission::FissionKineticEnergy(
G4int A,
G4int Z,
309 G4int AfMax = std::max(Af1,Af2);
313 if (theParam.GetW() <= 1000) {
314 G4double x1 = (AfMax-theParam.GetA1())/theParam.GetSigma1();
315 G4double x2 = (AfMax-theParam.GetA2())/theParam.GetSigma2();
316 Pas = 0.5*LocalExp(x1) + LocalExp(x2);
320 if (theParam.GetW() >= 0.001) {
321 G4double xs = (AfMax-theParam.GetAs())/theParam.GetSigmaS();
322 Ps = theParam.GetW()*LocalExp(xs);
324 G4double Psy = (Pas + Ps > 0.0) ? Ps/(Pas+Ps) : 0.5;
327 G4double PPas = theParam.GetSigma1() + 2.0 * theParam.GetSigma2();
328 G4double PPsy = theParam.GetW() * theParam.GetSigmaS();
329 G4double Xas = (PPas + PPsy > 0.0) ? PPas/(PPas+PPsy) : 0.5;
340 G4double A11 = theParam.GetA1()-0.7979*theParam.GetSigma1();
341 G4double A12 = theParam.GetA1()+0.7979*theParam.GetSigma1();
342 G4double A21 = theParam.GetA2()-0.7979*theParam.GetSigma2();
343 G4double A22 = theParam.GetA2()+0.7979*theParam.GetSigma2();
345 G4double ScaleFactor = 0.5*theParam.GetSigma1()*
346 (AsymmetricRatio(
A,
A11)+AsymmetricRatio(
A,
A12))+
347 theParam.GetSigma2()*(AsymmetricRatio(
A,
A21)+AsymmetricRatio(
A,
A22));
349 TaverageAfMax = (Eaverage + 12.5 * Xsy) * (PPas/ScaleFactor) *
353 G4double As0 = theParam.GetAs() + 0.7979*theParam.GetSigmaS();
355 TaverageAfMax = (Eaverage - 12.5*CLHEP::MeV*Xas)
356 *SymmetricRatio(
A,
G4double(AfMax))/SymmetricRatio(
A, As0);
357 ESigma = 8.0*CLHEP::MeV;
366 if (++i > 100)
return Eaverage;
368 }
while (KineticEnergy < Eaverage-3.72*ESigma ||
369 KineticEnergy > Eaverage+3.72*ESigma ||
370 KineticEnergy > Tmax);
377 if (myOwnFissionBarrier)
delete theFissionBarrierPtr;
378 theFissionBarrierPtr = aBarrier;
379 myOwnFissionBarrier =
false;
385 if (myOwnFissionProbability)
delete theFissionProbabilityPtr;
386 theFissionProbabilityPtr = aFissionProb;
387 myOwnFissionProbability =
false;
393 if (myOwnLevelDensity)
delete theLevelDensityPtr;
394 theLevelDensityPtr = aLevelDensity;
395 myOwnLevelDensity =
false;
CLHEP::HepLorentzVector G4LorentzVector
G4ThreeVector G4ParticleMomentum
G4ThreeVector G4RandomDirection()
Hep3Vector boostVector() const
HepLorentzVector & boost(double, double, double)
void SetEmissionStrategy(G4VEmissionProbability *aFissionProb)
void SetLevelDensityParameter(G4VLevelDensityParameter *aLevelDensity)
G4double GetEmissionProbability(G4Fragment *theNucleus) override
void SetFissionBarrier(G4VFissionBarrier *aBarrier)
G4Fragment * EmittedFragment(G4Fragment *theNucleus) override
~G4CompetitiveFission() override
void Initialise() override
G4double GetAs(void) const
G4double GetW(void) const
G4double GetSigmaS(void) const
G4double GetSigma2(void) const
G4double GetGroundStateMass() const
void SetZandA_asInt(G4int Znew, G4int Anew, G4int Lnew=0)
G4double GetExcitationEnergy() const
const G4LorentzVector & GetMomentum() const
void SetCreatorModelID(G4int value)
void SetMomentum(const G4LorentzVector &value)
G4PairingCorrection * GetPairingCorrection()
static G4NuclearLevelData * GetInstance()
static G4double GetNuclearMass(const G4double A, const G4double Z)
static G4int GetModelID(const G4int modelIndex)
static G4Pow * GetInstance()
G4double Z13(G4int Z) const
virtual void Initialise()
G4VEvaporationChannel(const G4String &aName="")