67 {
70 }
71
74
75
77 fissionStore.clear();
78
86
87 TETA = TETA / std::sinh(TETA);
88
90
94
100
101 TEM += DTEM;
102
105
107
108 for (
G4int i = 0; i < 50 && A1 > 30; i++) {
109 A1--;
113 Z1 =
G4lrint(getZopt(A1, A2,
Z, X3, X4, R12) - 1.);
117
118 potentialMinimization(VPOT, EDEF1, VCOUL, A1, A2, Z1, Z2, AL1, BET1, R12);
119
127
128 if(EZL > 0.0) {
129
130 G4double C1 = std::sqrt(getC2(A1, A2, X3, X4, R12) / TEM);
132
133 DZ = DZ > 0.0 ? DZ + 0.5 : -std::fabs(DZ - 0.5);
136
138 G4double EZ = (DMT1 + (DMT - DMT1) * TETA - VPOT + DEfin) / TEM;
139
140 if (EZ >= ALMA) ALMA = EZ;
141 G4double EK = VCOUL + DEfin + 0.5 * TEM;
143
144 if (EV > 0.0) fissionStore.addConfig(A1, Z1, EZ, EK, EV);
145 };
146 };
147
148 std::size_t store_size = fissionStore.size();
149 if (store_size == 0) return;
150
151 G4FissionConfiguration
config =
153
157
159
163 G4double pmod = std::sqrt(0.001 * EK * mass1 * mass2 / mass_in);
164
167
169 G4double EV = 1000.0 * (e_in - e_out) /
A;
170 if (EV <= 0.0) return;
171
174
175
178}
CLHEP::HepLorentzVector G4LorentzVector
G4GLOB_DLL std::ostream G4cout
void setVectM(const Hep3Vector &spatial, double mass)
void getTargetData(const G4Fragment &target)
const G4Fragment & makeFragment(G4LorentzVector mom, G4int A, G4int Z, G4double EX=0.)
void addRecoilFragment(const G4Fragment *aFragment)
G4double getNucleiMass() const
G4double bindingEnergy(G4int A, G4int Z)
G4double nucleiLevelDensity(G4int A)
G4LorentzVector generateWithRandomAngles(G4double p, G4double mass=0.)
G4double randomGauss(G4double sigma)
G4double G4cbrt(G4double x)
G4double bindingEnergyAsymptotic(G4int A, G4int Z)