85{
88
89 G4int A = theNucleus.GetA_asInt();
90 G4int Z = theNucleus.GetZ_asInt();
91
93
94
97
101
102
103
104
106
108
109 if(
M - mass <= lowestEnergyLimit) {
111 }
112
114 G4cout <<
"G4NeutronRadCapture::DoIt: Eini(MeV)="
117 <<
" Z= " << Z <<
" A= " <<
A <<
G4endl;
118 }
121 lv2.boost(bst);
122 G4HadSecondary* news =
127 delete news;
128
129 const G4ParticleDefinition* theDef = 0;
130
131 lab4mom -= lv2;
134 else if (Z == 2 &&
A == 3) {theDef =
G4He3::He3();}
136 else { theDef = theTableOfIons->GetIon(Z,
A,0.0,
noFloat,0); }
137
139 G4cout <<
"Gamma 4-mom: " << lv2 <<
" "
141 }
142 if(theDef) {
143 news = new G4HadSecondary(new G4DynamicParticle(theDef, lab4mom));
147 delete news;
148 }
149
150
151 } else {
152
153
155 G4double etot = std::max(mass, lab4mom.e());
156 G4double ptot = std::sqrt((etot - mass)*(etot + mass));
158 lab4mom.
set(v.
x()*ptot,v.
y()*ptot,v.
z()*ptot,etot);
159 }
160
161 G4Fragment* aFragment =
new G4Fragment(
A, Z, lab4mom);
162
164 G4cout <<
"G4NeutronRadCapture::ApplyYourself initial G4Fragmet:"
167 }
168
169
170
171
174 fv->push_back(aFragment);
175 std::size_t
n = fv->size();
176
178 G4cout <<
"G4NeutronRadCapture: " <<
n <<
" final particles" <<
G4endl;
179 }
180 for(std::size_t i=0; i<
n; ++i) {
181
182 G4Fragment* f = (*fv)[i];
184
187
188 const G4ParticleDefinition* theDef;
192 else if (Z == 2 &&
A == 3) {theDef =
G4He3::He3();}
194 else {
196 if(eexc <= minExcitation) { eexc = 0.0; }
197 theDef = theTableOfIons->GetIon(Z,
A, eexc,
noFloat, 0);
198
199
200
201
202
203 }
207 << " Ekin(MeV)= " << etot/MeV
210 }
211 G4HadSecondary* news = new G4HadSecondary(
212 new G4DynamicParticle(theDef,
214 ekin));
216 if(timeF < 0.0) { timeF = 0.0; }
220 delete news;
221 delete f;
222 }
223 delete fv;
224 }
225
227}
std::vector< G4Fragment * > G4FragmentVector
CLHEP::HepLorentzVector G4LorentzVector
G4ThreeVector G4RandomDirection()
CLHEP::Hep3Vector G4ThreeVector
G4GLOB_DLL std::ostream G4cout
void set(double x, double y, double z)
static G4Deuteron * Deuteron()
G4double GetExcitationEnergy() const
const G4LorentzVector & GetMomentum() const
G4double GetCreationTime() const
const G4ParticleDefinition * GetParticleDefinition() const
G4double GetKineticEnergy() const
const G4LorentzVector & Get4Momentum() const
G4double GetGlobalTime() const
void SetTime(G4double aT)
void SetCreatorModelID(G4int id)
G4HadFinalState theParticleChange
static G4double GetNuclearMass(const G4double A, const G4double Z)
G4double GetPDGMass() const
const G4String & GetParticleName() const
static G4Triton * Triton()