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 == "nu_e" ) aLept = new G4DynamicParticle( theElectron, lv2 );
327 else
328 {
332 }
333 if( pName == "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 == "nu_e" ) aLept = new G4DynamicParticle( theElectron, lv2 );
388 else
389 {
393 }
395 }
396
397
398
400
402 {
403 if( pName == "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);
436
437 if( pName == "nu_e" )
438 {
441 }
442 else
443 {
444
445
446 }
447 }
448 else
449 {
451 recoil = G4Nucleus(
A-1,Z);
454
455 if( pName == "nu_e" )
456 {
459 }
460 else
461 {
462
463
464 }
465 }
466
468
471
475
476
477
479 {
481
483 {
485 fMr = proton_mass_c2;
486 recoil = G4Nucleus(
A-1,Z-1);
489 }
490 else
491 {
495 recoil = G4Nucleus(
A-1,Z);
498 }
499
501
502 if( eX <= eTh )
503 {
508 }
509
511 }
512 else
513 {
514 if (
fProton && pName ==
"nu_e" ) qB = 2;
515 else if( !
fProton && pName ==
"nu_e" ) qB = 1;
516
518 }
520}
CLHEP::HepLorentzVector G4LorentzVector
CLHEP::Hep3Vector G4ThreeVector
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)
void SampleLVkr(const G4HadProjectile &aTrack, G4Nucleus &targetNucleus)
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)