239{
244
245 const G4HadProjectile* aParticle = &aTrack;
247
249
251 {
255 }
256
258
260 {
261
265 }
266
267
268
272
273
277 G4double cost(1.), sint(0.), phi(0.), muMom(0.), massX2(0.), massX(0.), massR(0.), eCut(0.);
278 G4DynamicParticle* aLept = nullptr;
279
283 G4int pdgP(0), qB(0);
284
285
288
290 {
291
292 lvsum = lvp1 + lvt1;
293
295 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
297 eP =
G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
298
299
301
302 eP *= muMom;
303
304
305
307
308
313
314 if ( massX2 <= 0. )
315 {
320 }
322
323 if( pName ==
"anti_nu_mu") aLept =
new G4DynamicParticle(
theMuonPlus, lv2 );
324 else
325 {
329 }
330 if( pName == "anti_nu_mu" ) pdgP = -211;
331
332
333
335 {
336 eCut = (
fMpi + mTarg)*(
fMpi + mTarg) - (massX + massR)*(massX + massR);
337 eCut /= 2.*massR;
338 eCut += massX;
339 }
341
342 if ( lvX.
e() > eCut )
343 {
345 }
346 else
347 {
352 }
354
356 }
357 else
358 {
359 lvsum = lvp1 + lvt1;
361 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
363 eP =
G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
364
366
367 eP *= muMom;
368
371 lvX = lvsum - lv2;
374
375 if ( massX2 <= 0. )
376 {
381 }
383
384 if( pName ==
"anti_nu_mu") aLept =
new G4DynamicParticle(
theMuonPlus, lv2 );
385 else
386 {
390 }
392 }
393
394
395
397
399 {
400 if( pName == "anti_nu_mu" ) qB = 2;
401
402
403
404 {
406 }
408 }
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424 G4Nucleus recoil;
426
428 {
430 recoil = G4Nucleus(
A-1,Z-1);
432 if( pName == "anti_nu_mu" )
433 {
436 }
437 else
438 {
439
440
441 }
442 }
443 else
444 {
446 recoil = G4Nucleus(
A-1,Z);
448 if( pName == "anti_nu_mu" )
449 {
452 }
453 else
454 {
455
456
457 }
458 }
459
461
464
468
469
470
472 {
474
477 {
479 fMr = proton_mass_c2;
480 recoil = G4Nucleus(
A-1,Z-1);
483 }
484 else
485 {
489 recoil = G4Nucleus(
A-1,Z);
492 }
493
495
496 if( eX <= eTh )
497 {
502 }
503
505 }
506 else
507 {
508 if (
fProton && pName ==
"anti_nu_mu" ) qB = 0;
509 else if( !
fProton && pName ==
"anti_nu_mu" ) qB = -1;
510
512 }
514}
CLHEP::HepLorentzVector G4LorentzVector
CLHEP::Hep3Vector G4ThreeVector
void SampleLVkr(const G4HadProjectile &aTrack, G4Nucleus &targetNucleus)
const G4ParticleDefinition * GetDefinition() const
const G4LorentzVector & Get4Momentum() const
G4double GetTotalEnergy() const
G4HadFinalState theParticleChange
void CoherentPion(G4LorentzVector &lvP, G4int pdgP, G4Nucleus &targetNucleus)
G4int GetOnePionIndex(G4double energy)
G4double GetNuMuOnePionProb(G4int index, G4double energy)
G4double CalculateQEratioA(G4int Z, G4int A, G4double energy, G4int nepdg)
G4ParticleDefinition * theMuonPlus
void ClusterDecay(G4LorentzVector &lvX, G4int qX)
void FinalBarion(G4LorentzVector &lvB, G4int qB, G4int pdgB)
G4double AtomicMass(const G4double A, const G4double Z, const G4int numberOfLambdas=0) const
G4double GetPDGMass() const
G4int GetPDGEncoding() const
const G4String & GetParticleName() const
G4ParticleDefinition * FindParticle(G4int PDGEncoding)
static G4ParticleTable * GetParticleTable()
G4double energy(const ThreeVector &p, const G4double m)