243{
248
249 const G4HadProjectile* aParticle = &aTrack;
251
253
255 {
259 }
260
262
264 {
265
269 }
270
271
272
276
277
281 G4double cost(1.), sint(0.), phi(0.), muMom(0.), massX2(0.), massX(0.), massR(0.), eCut(0.);
282 G4DynamicParticle* aLept = nullptr;
283
287 G4int pdgP(0), qB(0);
288
289
292
294 {
295
296 lvsum = lvp1 + lvt1;
297
299 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
301 eP =
G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
302
303
304 muMom = sqrt(
fEmu*
fEmu-fMtau*fMtau);
305
306 eP *= muMom;
307
308
309
311
312
317
318 if ( massX2 <= 0. )
319 {
324 }
326
327 if( pName == "anti_nu_tau" ) aLept = new G4DynamicParticle( theTauPlus, lv2 );
328
329 else
330 {
334 }
335 if( pName == "anti_nu_tau" ) pdgP = 211;
336
337
338
340 {
341 eCut = (
fMpi + mTarg)*(
fMpi + mTarg) - (massX + massR)*(massX + massR);
342 eCut /= 2.*massR;
343 eCut += massX;
344 }
346
347 if ( lvX.
e() > eCut )
348 {
350 }
351 else
352 {
357 }
359
361 }
362 else
363 {
364 lvsum = lvp1 + lvt1;
366 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
368 eP =
G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
369
370 muMom = sqrt(
fEmu*
fEmu-fMtau*fMtau);
371
372 eP *= muMom;
373
376 lvX = lvsum - lv2;
379
380 if ( massX2 <= 0. )
381 {
386 }
388
389 if( pName == "anti_nu_tau" ) aLept = new G4DynamicParticle( theTauPlus, lv2 );
390
391 else
392 {
396 }
398 }
399
400
401
403
405 {
406 if( pName == "anti_nu_tau" ) qB = 2;
407
408
409
410 {
412 }
414 }
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430 G4Nucleus recoil;
432
434 {
436 recoil = G4Nucleus(
A-1,Z-1);
439
440 if( pName == "anti_nu_tau" )
441 {
444 }
445 else
446 {
447
448
449 }
450 }
451 else
452 {
454 recoil = G4Nucleus(
A-1,Z);
457
458 if( pName == "anti_nu_tau" )
459 {
462 }
463 else
464 {
465
466
467 }
468 }
469
471
474
478
479
480
482 {
484
486 {
488 fMr = proton_mass_c2;
489 recoil = G4Nucleus(
A-1,Z-1);
492 }
493 else
494 {
498 recoil = G4Nucleus(
A-1,Z);
501 }
502
504
505 if( eX <= eTh )
506 {
511 }
512
514 }
515 else
516 {
517 if (
fProton && pName ==
"anti_nu_tau" ) qB = 2;
518
519 else if( !
fProton && pName ==
"anti_nu_tau" ) qB = 1;
520
521
522
524 }
526}
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)
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)