242{
247
248 const G4HadProjectile* aParticle = &aTrack;
250
252
254 {
258 }
259
261
263 {
264
268 }
269
270
271
275
276
280 G4double cost(1.), sint(0.), phi(0.), muMom(0.), massX2(0.), massX(0.), massR(0.), eCut(0.);
281 G4DynamicParticle* aLept = nullptr;
282
286 G4int pdgP(0), qB(0);
287
288
291
293 {
294
295 lvsum = lvp1 + lvt1;
296
298 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
300 eP =
G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
301
302
304
305 eP *= muMom;
306
307
308
310
311
316
317 if ( massX2 <= 0. )
318 {
323 }
325
326 if( pName == "anti_nu_e" ) aLept = new G4DynamicParticle( thePositron, lv2 );
327 else
328 {
332 }
333 if( pName == "anti_nu_e" ) pdgP = 211;
334
335
336
338 {
339 eCut = (
fMpi + mTarg)*(
fMpi + mTarg) - (massX + massR)*(massX + massR);
340 eCut /= 2.*massR;
341 eCut += massX;
342 }
344
345 if ( lvX.
e() > eCut )
346 {
348 }
349 else
350 {
355 }
357
359 }
360 else
361 {
362 lvsum = lvp1 + lvt1;
364 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
366 eP =
G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
367
369
370 eP *= muMom;
371
374 lvX = lvsum - lv2;
377
378 if ( massX2 <= 0. )
379 {
384 }
386
387 if( pName == "anti_nu_e" ) aLept = new G4DynamicParticle( thePositron, lv2 );
388 else
389 {
393 }
395 }
396
397
398
400
402 {
403 if( pName == "anti_nu_e" ) qB = 2;
404
405
406
407 {
409 }
411 }
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427 G4Nucleus recoil;
429
431 {
433 recoil = G4Nucleus(
A-1,Z-1);
435 if( pName == "anti_nu_e" )
436 {
439 }
440 else
441 {
442
443
444 }
445 }
446 else
447 {
449 recoil = G4Nucleus(
A-1,Z);
451 if( pName == "anti_nu_e" )
452 {
455 }
456 else
457 {
458
459
460 }
461 }
462
464
467
471
472
473
475 {
477
480 {
482 fMr = proton_mass_c2;
483 recoil = G4Nucleus(
A-1,Z-1);
486 }
487 else
488 {
492 recoil = G4Nucleus(
A-1,Z);
495 }
496
498
499 if( eX <= eTh )
500 {
505 }
506
508 }
509 else
510 {
511 if (
fProton && pName ==
"anti_nu_e" ) qB = 2;
512 else if( !
fProton && pName ==
"anti_nu_e" ) qB = 1;
513
515 }
517}
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)