138 {
140
141 const G4int itry_max = 100;
142
143
146 G4cout <<
" InuclCollider -> particle on particle collision" <<
G4endl;
147
148 theElementaryParticleCollider->collide(bullet, target, globalOutput);
149 return;
150 }
151
155 }
156
159 G4cerr <<
" InuclCollider -> no collision possible " <<
G4endl;
160
162 return;
163 }
164
165
166 G4InuclNuclei* ntarget =
dynamic_cast<G4InuclNuclei*
>(
interCase.getTarget());
167 if (!ntarget) {
168 G4cerr <<
" InuclCollider -> ERROR target is not a nucleus " <<
G4endl;
169
171 return;
172 }
173
177
179 G4InuclElementaryParticle* pbullet =
180 dynamic_cast<G4InuclElementaryParticle*
>(
interCase.getBullet());
181
182 if (!pbullet) {
183 G4cerr <<
" InuclCollider -> ERROR bullet is not a hadron " <<
G4endl;
185 return;
186 }
187
189 G4cerr <<
" InuclCollider -> ERROR can not collide with "
192 return;
193 }
194
195 btype = pbullet->
type();
196 } else {
197 G4InuclNuclei* nbullet =
198 dynamic_cast<G4InuclNuclei*
>(
interCase.getBullet());
199 if (!nbullet) {
200 G4cerr <<
" InuclCollider -> ERROR bullet is not a nucleus " <<
G4endl;
202 return;
203 }
204
205 ab = nbullet->
getA();
206 zb = nbullet->
getZ();
207 }
208
209 G4LorentzConvertor convertToTargetRestFrame(bullet, ntarget);
210 G4double ekin = convertToTargetRestFrame.getKinEnergyInTheTRS();
211
213
216 G4cout <<
" InuclCollider -> inelastic interaction is impossible\n"
217 <<
" due to the coulomb barirer " <<
G4endl;
218
220 return;
221 }
222
223
224 convertToTargetRestFrame.toTheTargetRestFrame();
226 G4cout <<
" degenerated? " << convertToTargetRestFrame.trivial()
228 }
229
231 bmom.
setZ(convertToTargetRestFrame.getTRSMomentum());
232
233
234 G4InuclParticle* zbullet = 0;
236 zbullet = new G4InuclElementaryParticle(bmom, btype);
237 else
238 zbullet = new G4InuclNuclei(bmom, ab, zb);
239
241 while (itry < itry_max) {
242 itry++;
244
245 globalOutput.
reset();
246 output.reset();
247
248 theIntraNucleiCascader->collide(zbullet, target, output);
249
251
252 deexcite(output.getRecoilFragment(), output);
253 output.removeRecoilFragment();
254
255
256 if (std::getenv("G4CASCADE_CHECK_PHOTONUCLEAR"))
258
260 G4cout <<
" itry " << itry <<
" finished, moving to lab frame" <<
G4endl;
261
262
263 output.boostToLabFrame(convertToTargetRestFrame);
264
265 globalOutput.
add(output);
266
267
268
272 G4cout <<
" InuclCollider output after trials " << itry <<
G4endl;
273 delete zbullet;
274 return;
275 } else {
277 G4cerr <<
" InuclCollider setOnShell failed." <<
G4endl;
278 }
279 }
280
282 G4cout <<
" InuclCollider -> can not generate acceptable inter. after "
283 << itry_max <<
" attempts " <<
G4endl;
284 }
285
287
288 delete zbullet;
289 return;
290}
CLHEP::HepLorentzVector G4LorentzVector
G4GLOB_DLL std::ostream G4cerr
G4GLOB_DLL std::ostream G4cout
static const G4CascadeChannel * GetTable(G4int initialState)
virtual G4bool useEPCollider(G4InuclParticle *bullet, G4InuclParticle *target) const
G4InteractionCase interCase
virtual G4bool inelasticInteractionPossible(G4InuclParticle *bullet, G4InuclParticle *target, G4double ekin) const
void setOnShell(G4InuclParticle *bullet, G4InuclParticle *target)
G4bool acceptable() const
void add(const G4CollisionOutput &right)
void trivialise(G4InuclParticle *bullet, G4InuclParticle *target)
void deexcite(const G4Fragment &fragment, G4CollisionOutput &globalOutput)
G4bool photonuclearOkay(G4CollisionOutput &checkOutput) const
const G4ParticleDefinition * getDefinition() const
const G4String & GetParticleName() const