222{
225 const G4HadProjectile* aParticle = &aTrack;
227
229
231 {
235 }
237
239 {
240
244 }
245
246
247
251
252
256 G4double cost(1.), sint(0.), phi(0.), muMom(0.), massX2(0.);
257 G4DynamicParticle* aLept = nullptr;
258
262 G4int pdgP(0), qB(0);
263
264
267
269 {
270
271 lvsum = lvp1 + lvt1;
272
274 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
276 eP =
G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
277
278
279 muMom = sqrt(
fEmu*
fEmu-fMnumu*fMnumu);
280
281 eP *= muMom;
282
283
286
287 lvX = lvsum - lv2;
292
293
295 if ( lvX.
e() <=
fM1 )
296 {
300 }
302
303 if( pName == "nu_tau" ) aLept = new G4DynamicParticle( theNuTau, lv2 );
304 else if( pName == "anti_nu_tau") aLept = new G4DynamicParticle( theANuTau, lv2 );
305 else
306 {
310 }
311
312 pdgP = 111;
313
315
317 {
318 eCut = (
fMpi + mTarg)*(
fMpi + mTarg) - (massX + massR)*(massX + massR);
319 eCut /= 2.*massR;
320 eCut += massX;
321 }
323
324 if ( lvX.
e() > eCut )
325 {
327 }
328 else
329 {
333 }
335
337 }
338 else
339 {
340 lvsum = lvp1 + lvt1;
342 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
344 eP =
G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
345
346 muMom = sqrt(
fEmu*
fEmu-fMnumu*fMnumu);
347
348 eP *= muMom;
349
351
352 lvX = lvsum - lv2;
353
355
356 if ( massX2 <= 0. )
357 {
361 }
363
364 aLept = new G4DynamicParticle( theANuTau, lv2 );
365
367 }
368
369
370
374
376 {
377 qB = 1;
378
379
380 {
382 }
384 }
385 G4Nucleus recoil;
387
389 {
391 recoil = G4Nucleus(
A-1,Z-1);
394
397 }
398 else
399 {
401 recoil = G4Nucleus(
A-1,Z);
404
407 }
408
410
413
417
419 {
421
423 {
425 fMr = proton_mass_c2;
426 recoil = G4Nucleus(
A-1,Z-1);
429 }
430 else
431 {
435 recoil = G4Nucleus(
A-1,Z);
438 }
440
441 if(eX <= eTh)
442 {
446 }
448 }
449 else
450 {
451 if (
fProton && pName ==
"nu_tau" ) qB = 1;
452 else if( !
fProton && pName ==
"nu_tau" ) qB = 0;
453
455 }
457}
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)