Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4ANuElNucleusNcModel Class Reference

#include <G4ANuElNucleusNcModel.hh>

+ Inheritance diagram for G4ANuElNucleusNcModel:

Public Member Functions

 G4ANuElNucleusNcModel (const G4String &name="ANuElNuclNcModel")
 
virtual ~G4ANuElNucleusNcModel ()
 
virtual void InitialiseModel ()
 
virtual G4bool IsApplicable (const G4HadProjectile &aTrack, G4Nucleus &targetNucleus)
 
virtual G4HadFinalStateApplyYourself (const G4HadProjectile &aTrack, G4Nucleus &targetNucleus)
 
void SampleLVkr (const G4HadProjectile &aTrack, G4Nucleus &targetNucleus)
 
G4double GetMinNuElEnergy ()
 
G4double ThresholdEnergy (G4double mI, G4double mF, G4double mP)
 
virtual void ModelDescription (std::ostream &) const
 
- Public Member Functions inherited from G4NeutrinoNucleusModel
 G4NeutrinoNucleusModel (const G4String &name="neutrino-nucleus")
 
virtual ~G4NeutrinoNucleusModel ()
 
G4double SampleXkr (G4double energy)
 
G4double GetXkr (G4int iEnergy, G4double prob)
 
G4double SampleQkr (G4double energy, G4double xx)
 
G4double GetQkr (G4int iE, G4int jX, G4double prob)
 
void ClusterDecay (G4LorentzVector &lvX, G4int qX)
 
void MesonDecay (G4LorentzVector &lvX, G4int qX)
 
void FinalBarion (G4LorentzVector &lvB, G4int qB, G4int pdgB)
 
void RecoilDeexcitation (G4Fragment &fragment)
 
void FinalMeson (G4LorentzVector &lvM, G4int qM, G4int pdgM)
 
void CoherentPion (G4LorentzVector &lvP, G4int pdgP, G4Nucleus &targetNucleus)
 
void SetCutEnergy (G4double ec)
 
G4double GetCutEnergy ()
 
G4double GetNuEnergy ()
 
G4double GetQtransfer ()
 
G4double GetQ2 ()
 
G4double GetXsample ()
 
G4int GetPDGencoding ()
 
G4bool GetCascade ()
 
G4bool GetString ()
 
G4double GetCosTheta ()
 
G4double GetEmu ()
 
G4double GetEx ()
 
G4double GetMuMass ()
 
G4double GetW2 ()
 
G4double GetM1 ()
 
G4double GetMr ()
 
G4double GetTr ()
 
G4double GetDp ()
 
G4bool GetfBreak ()
 
G4bool GetfCascade ()
 
G4bool GetfString ()
 
G4LorentzVector GetLVl ()
 
G4LorentzVector GetLVh ()
 
G4LorentzVector GetLVt ()
 
G4LorentzVector GetLVcpi ()
 
G4double GetMinNuMuEnergy ()
 
G4double ThresholdEnergy (G4double mI, G4double mF, G4double mP)
 
G4double GetQEratioA ()
 
void SetQEratioA (G4double qea)
 
G4double FinalMomentum (G4double mI, G4double mF, G4double mP, G4LorentzVector lvX)
 
G4double FermiMomentum (G4Nucleus &targetNucleus)
 
G4double NucleonMomentum (G4Nucleus &targetNucleus)
 
G4double GetEx (G4int A, G4bool fP)
 
G4double GgSampleNM (G4Nucleus &nucl)
 
G4int GetEnergyIndex (G4double energy)
 
G4double GetNuMuQeTotRat (G4int index, G4double energy)
 
G4int GetOnePionIndex (G4double energy)
 
G4double GetNuMuOnePionProb (G4int index, G4double energy)
 
G4double CalculateQEratioA (G4int Z, G4int A, G4double energy, G4int nepdg)
 
- Public Member Functions inherited from G4HadronicInteraction
 G4HadronicInteraction (const G4String &modelName="HadronicModel")
 
virtual ~G4HadronicInteraction ()
 
virtual G4double SampleInvariantT (const G4ParticleDefinition *p, G4double plab, G4int Z, G4int A)
 
G4double GetMinEnergy () const
 
G4double GetMinEnergy (const G4Material *aMaterial, const G4Element *anElement) const
 
void SetMinEnergy (G4double anEnergy)
 
void SetMinEnergy (G4double anEnergy, const G4Element *anElement)
 
void SetMinEnergy (G4double anEnergy, const G4Material *aMaterial)
 
G4double GetMaxEnergy () const
 
G4double GetMaxEnergy (const G4Material *aMaterial, const G4Element *anElement) const
 
void SetMaxEnergy (const G4double anEnergy)
 
void SetMaxEnergy (G4double anEnergy, const G4Element *anElement)
 
void SetMaxEnergy (G4double anEnergy, const G4Material *aMaterial)
 
G4int GetVerboseLevel () const
 
void SetVerboseLevel (G4int value)
 
const G4StringGetModelName () const
 
void DeActivateFor (const G4Material *aMaterial)
 
void ActivateFor (const G4Material *aMaterial)
 
void DeActivateFor (const G4Element *anElement)
 
void ActivateFor (const G4Element *anElement)
 
G4bool IsBlocked (const G4Material *aMaterial) const
 
G4bool IsBlocked (const G4Element *anElement) const
 
void SetRecoilEnergyThreshold (G4double val)
 
G4double GetRecoilEnergyThreshold () const
 
virtual const std::pair< G4double, G4doubleGetFatalEnergyCheckLevels () const
 
virtual std::pair< G4double, G4doubleGetEnergyMomentumCheckLevels () const
 
void SetEnergyMomentumCheckLevels (G4double relativeLevel, G4double absoluteLevel)
 
virtual void BuildPhysicsTable (const G4ParticleDefinition &)
 
 G4HadronicInteraction (const G4HadronicInteraction &right)=delete
 
const G4HadronicInteractionoperator= (const G4HadronicInteraction &right)=delete
 
G4bool operator== (const G4HadronicInteraction &right) const =delete
 
G4bool operator!= (const G4HadronicInteraction &right) const =delete
 

Additional Inherited Members

- Protected Member Functions inherited from G4HadronicInteraction
void SetModelName (const G4String &nam)
 
G4bool IsBlocked () const
 
void Block ()
 
- Protected Attributes inherited from G4NeutrinoNucleusModel
G4ParticleDefinitiontheMuonMinus
 
G4ParticleDefinitiontheMuonPlus
 
G4double fSin2tW
 
G4double fCutEnergy
 
G4int fNbin
 
G4int fIndex
 
G4int fEindex
 
G4int fXindex
 
G4int fQindex
 
G4int fOnePionIndex
 
G4int fPDGencoding
 
G4bool fCascade
 
G4bool fString
 
G4bool fProton
 
G4bool f2p2h
 
G4bool fBreak
 
G4double fNuEnergy
 
G4double fQ2
 
G4double fQtransfer
 
G4double fXsample
 
G4double fM1
 
G4double fM2
 
G4double fMt
 
G4double fMu
 
G4double fW2
 
G4double fMpi
 
G4double fW2pi
 
G4double fMinNuEnergy
 
G4double fDp
 
G4double fTr
 
G4double fEmu
 
G4double fEmuPi
 
G4double fEx
 
G4double fMr
 
G4double fCosTheta
 
G4double fCosThetaPi
 
G4double fQEratioA
 
G4LorentzVector fLVh
 
G4LorentzVector fLVl
 
G4LorentzVector fLVt
 
G4LorentzVector fLVcpi
 
G4GeneratorPrecompoundInterfacefPrecoInterface
 
G4PreCompoundModelfPreCompound
 
G4ExcitationHandlerfDeExcitation
 
G4NucleusfRecoil
 
G4int fSecID
 
- Protected Attributes inherited from G4HadronicInteraction
G4HadFinalState theParticleChange
 
G4int verboseLevel
 
G4double theMinEnergy
 
G4double theMaxEnergy
 
G4bool isBlocked
 
- Static Protected Attributes inherited from G4NeutrinoNucleusModel
static const G4int fResNumber = 6
 
static const G4double fResMass [6]
 
static const G4int fClustNumber = 4
 
static const G4double fMesMass [4] = {1260., 980., 770., 139.57}
 
static const G4int fMesPDG [4] = {20213, 9000211, 213, 211}
 
static const G4double fBarMass [4] = {1700., 1600., 1232., 939.57}
 
static const G4int fBarPDG [4] = {12224, 32224, 2224, 2212}
 
static const G4double fNuMuResQ [50][50]
 
static const G4double fNuMuEnergy [50]
 
static const G4double fNuMuQeTotRat [50]
 
static const G4double fOnePionEnergy [58]
 
static const G4double fOnePionProb [58]
 
static const G4double fNuMuEnergyLogVector [50]
 
static G4double fNuMuXarrayKR [50][51] = {{1.0}}
 
static G4double fNuMuXdistrKR [50][50] = {{1.0}}
 
static G4double fNuMuQarrayKR [50][51][51] = {{{1.0}}}
 
static G4double fNuMuQdistrKR [50][51][50] = {{{1.0}}}
 
static const G4double fQEnergy [50]
 
static const G4double fANeMuQEratio [50]
 
static const G4double fNeMuQEratio [50]
 

Detailed Description

Definition at line 60 of file G4ANuElNucleusNcModel.hh.

Constructor & Destructor Documentation

◆ G4ANuElNucleusNcModel()

G4ANuElNucleusNcModel::G4ANuElNucleusNcModel ( const G4String & name = "ANuElNuclNcModel")

Definition at line 68 of file G4ANuElNucleusNcModel.cc.

70{
71 SetMinEnergy( 0.0*GeV );
72 SetMaxEnergy( 100.*TeV );
73 SetMinEnergy(1.e-6*eV);
74
75 theNuE = G4NeutrinoE::NeutrinoE();
76
77 fMnumu = 0.;
78 fData = fMaster = false;
80
81}
void SetMinEnergy(G4double anEnergy)
void SetMaxEnergy(const G4double anEnergy)
static G4NeutrinoE * NeutrinoE()
G4NeutrinoNucleusModel(const G4String &name="neutrino-nucleus")

◆ ~G4ANuElNucleusNcModel()

G4ANuElNucleusNcModel::~G4ANuElNucleusNcModel ( )
virtual

Definition at line 84 of file G4ANuElNucleusNcModel.cc.

85{}

Member Function Documentation

◆ ApplyYourself()

G4HadFinalState * G4ANuElNucleusNcModel::ApplyYourself ( const G4HadProjectile & aTrack,
G4Nucleus & targetNucleus )
virtual

Implements G4NeutrinoNucleusModel.

Definition at line 220 of file G4ANuElNucleusNcModel.cc.

222{
223 theParticleChange.Clear();
224 fProton = f2p2h = fBreak = false;
225 const G4HadProjectile* aParticle = &aTrack;
226 G4double energy = aParticle->GetTotalEnergy();
227
228 G4String pName = aParticle->GetDefinition()->GetParticleName();
229
230 if( energy < fMinNuEnergy )
231 {
232 theParticleChange.SetEnergyChange(energy);
233 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit());
234 return &theParticleChange;
235 }
236 SampleLVkr( aTrack, targetNucleus);
237
238 if( fBreak == true || fEmu < fMnumu ) // ~5*10^-6
239 {
240 // G4cout<<"ni, ";
241 theParticleChange.SetEnergyChange(energy);
242 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit());
243 return &theParticleChange;
244 }
245
246 // LVs of initial state
247
248 G4LorentzVector lvp1 = aParticle->Get4Momentum();
249 G4LorentzVector lvt1( 0., 0., 0., fM1 );
251
252 // 1-pi by fQtransfer && nu-energy
253 G4LorentzVector lvpip1( 0., 0., 0., mPip );
254 G4LorentzVector lvsum, lv2, lvX;
255 G4ThreeVector eP;
256 G4double cost(1.), sint(0.), phi(0.), muMom(0.), massX2(0.);
257 G4DynamicParticle* aLept = nullptr; // lepton lv
258
259 G4int Z = targetNucleus.GetZ_asInt();
260 G4int A = targetNucleus.GetA_asInt();
261 G4double mTarg = targetNucleus.AtomicMass(A,Z);
262 G4int pdgP(0), qB(0);
263 // G4double mSum = G4ParticleTable::GetParticleTable()->FindParticle(2212)->GetPDGMass() + mPip;
264
265 G4int iPi = GetOnePionIndex(energy);
266 G4double p1pi = GetNuMuOnePionProb( iPi, energy);
267
268 if( p1pi > G4UniformRand() && fCosTheta > 0.9 ) // && fQtransfer < 0.95*GeV ) // mu- & coherent pion + nucleus
269 {
270 // lvsum = lvp1 + lvpip1;
271 lvsum = lvp1 + lvt1;
272 // cost = fCosThetaPi;
273 cost = fCosTheta;
274 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
275 phi = G4UniformRand()*CLHEP::twopi;
276 eP = G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
277
278 // muMom = sqrt(fEmuPi*fEmuPi-fMnumu*fMnumu);
279 muMom = sqrt(fEmu*fEmu-fMnumu*fMnumu);
280
281 eP *= muMom;
282
283 // lv2 = G4LorentzVector( eP, fEmuPi );
284 lv2 = G4LorentzVector( eP, fEmu );
285 lv2 = fLVl;
286
287 lvX = lvsum - lv2;
288 lvX = fLVh;
289 massX2 = lvX.m2();
290 G4double massX = lvX.m();
291 G4double massR = fLVt.m();
292
293 // if ( massX2 <= 0. ) // vmg: very rarely ~ (1-4)e-6 due to big Q2/x, to be improved
294 if ( massX2 <= fM1*fM1 ) // 9-3-20 vmg: very rarely ~ (1-4)e-6 due to big Q2/x, to be improved
295 if ( lvX.e() <= fM1 ) // 9-3-20 vmg: very rarely ~ (1-4)e-6 due to big Q2/x, to be improved
296 {
297 theParticleChange.SetEnergyChange(energy);
298 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit());
299 return &theParticleChange;
300 }
301 fW2 = massX2;
302
303 if( pName == "anti_nu_e" ) aLept = new G4DynamicParticle( theNuE, lv2 );
304 // else if( pName == "anti_nu_mu") aLept = new G4DynamicParticle( theANuMu, lv2 );
305 else
306 {
307 theParticleChange.SetEnergyChange(energy);
308 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit());
309 return &theParticleChange;
310 }
311
312 pdgP = 111;
313
314 G4double eCut; // = fMpi + 0.5*(fMpi*fMpi - massX2)/mTarg; // massX -> fMpi
315
316 if( A > 1 )
317 {
318 eCut = (fMpi + mTarg)*(fMpi + mTarg) - (massX + massR)*(massX + massR);
319 eCut /= 2.*massR;
320 eCut += massX;
321 }
322 else eCut = fM1 + fMpi;
323
324 if ( lvX.e() > eCut ) // && sqrt( GetW2() ) < 1.4*GeV ) //
325 {
326 CoherentPion( lvX, pdgP, targetNucleus);
327 }
328 else
329 {
330 theParticleChange.SetEnergyChange(energy);
331 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit());
332 return &theParticleChange;
333 }
334 theParticleChange.AddSecondary( aLept, fSecID );
335
336 return &theParticleChange;
337 }
338 else // lepton part in lab
339 {
340 lvsum = lvp1 + lvt1;
341 cost = fCosTheta;
342 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
343 phi = G4UniformRand()*CLHEP::twopi;
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
350 lv2 = G4LorentzVector( eP, fEmu );
351
352 lvX = lvsum - lv2;
353
354 massX2 = lvX.m2();
355
356 if ( massX2 <= 0. ) // vmg: very rarely ~ (1-4)e-6 due to big Q2/x, to be improved
357 {
358 theParticleChange.SetEnergyChange(energy);
359 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit());
360 return &theParticleChange;
361 }
362 fW2 = massX2;
363
364 aLept = new G4DynamicParticle( theNuE, lv2 );
365
366 theParticleChange.AddSecondary( aLept, fSecID );
367 }
368
369 // hadron part
370
371 fRecoil = nullptr;
372 fCascade = false;
373 fString = false;
374
375 if( A == 1 )
376 {
377 qB = 1;
378
379 // if( G4UniformRand() > 0.1 ) // > 0.9999 ) // > 0.0001 ) //
380 {
381 ClusterDecay( lvX, qB );
382 }
383 return &theParticleChange;
384 }
385 G4Nucleus recoil;
386 G4double ratio = G4double(Z)/G4double(A);
387
388 if( ratio > G4UniformRand() ) // proton is excited
389 {
390 fProton = true;
391 recoil = G4Nucleus(A-1,Z-1);
392 fRecoil = &recoil;
395 }
396 else // excited neutron
397 {
398 fProton = false;
399 recoil = G4Nucleus(A-1,Z);
400 fRecoil = &recoil;
403 }
404 // G4int index = GetEnergyIndex(energy);
405 G4int nepdg = aParticle->GetDefinition()->GetPDGEncoding();
406
407 G4double qeTotRat; // = GetNuMuQeTotRat(index, energy);
408 qeTotRat = CalculateQEratioA( Z, A, energy, nepdg);
409
410 G4ThreeVector dX = (lvX.vect()).unit();
411 G4double eX = lvX.e(); // excited nucleon
412 G4double mX = sqrt(massX2);
413
414 if( qeTotRat > G4UniformRand() || mX <= fMt ) // || eX <= 1232.*MeV) // QE
415 {
416 fString = false;
417
418 G4double rM;
419 if( fProton )
420 {
421 fPDGencoding = 2212;
422 fMr = proton_mass_c2;
423 recoil = G4Nucleus(A-1,Z-1);
424 fRecoil = &recoil;
425 rM = recoil.AtomicMass(A-1,Z-1);
426 }
427 else
428 {
429 fPDGencoding = 2112;
431 FindParticle(fPDGencoding)->GetPDGMass(); // 939.5654133*MeV;
432 recoil = G4Nucleus(A-1,Z);
433 fRecoil = &recoil;
434 rM = recoil.AtomicMass(A-1,Z);
435 }
436 G4double eTh = fMr+0.5*(fMr*fMr-mX*mX)/rM;
437
438 if(eX <= eTh) // vmg, very rarely out of kinematics
439 {
440 theParticleChange.SetEnergyChange(energy);
441 theParticleChange.SetMomentumChange(aTrack.Get4Momentum().vect().unit());
442 return &theParticleChange;
443 }
444 FinalBarion( lvX, 0, fPDGencoding ); // p(n)+deexcited recoil
445 }
446 else // if ( eX < 9500000.*GeV ) // < 25.*GeV) // < 95.*GeV ) // < 2.5*GeV ) //cluster decay
447 {
448 if ( fProton && pName == "anti_nu_e" ) qB = 1;
449 else if( !fProton && pName == "anti_nu_e" ) qB = 0;
450
451 ClusterDecay( lvX, qB );
452 }
453 return &theParticleChange;
454}
CLHEP::HepLorentzVector G4LorentzVector
CLHEP::Hep3Vector G4ThreeVector
double G4double
Definition G4Types.hh:83
int G4int
Definition G4Types.hh:85
const G4double A[17]
#define G4UniformRand()
Definition Randomize.hh:52
Hep3Vector unit() const
Hep3Vector vect() const
void SampleLVkr(const G4HadProjectile &aTrack, G4Nucleus &targetNucleus)
const G4ParticleDefinition * GetDefinition() const
const G4LorentzVector & Get4Momentum() const
G4double GetTotalEnergy() const
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)
G4int GetA_asInt() const
Definition G4Nucleus.hh:99
G4int GetZ_asInt() const
Definition G4Nucleus.hh:105
G4double AtomicMass(const G4double A, const G4double Z, const G4int numberOfLambdas=0) const
Definition G4Nucleus.cc:369
const G4String & GetParticleName() const
G4ParticleDefinition * FindParticle(G4int PDGEncoding)
static G4ParticleTable * GetParticleTable()
G4double energy(const ThreeVector &p, const G4double m)

◆ GetMinNuElEnergy()

G4double G4ANuElNucleusNcModel::GetMinNuElEnergy ( )
inline

Definition at line 81 of file G4ANuElNucleusNcModel.hh.

81{ return fMnumu + 0.5*fMnumu*fMnumu/fM1 + 0.05*CLHEP::keV; }; // kinematics + accuracy for sqrts

Referenced by IsApplicable().

◆ InitialiseModel()

void G4ANuElNucleusNcModel::InitialiseModel ( )
virtual

Reimplemented from G4HadronicInteraction.

Definition at line 101 of file G4ANuElNucleusNcModel.cc.

102{
103 G4String pName = "anti_nu_e";
104
105 G4int nSize(0), i(0), j(0), k(0);
106
107 if(!fData)
108 {
109#ifdef G4MULTITHREADED
110 G4MUTEXLOCK(&numuNucleusModel);
111 if(!fData)
112 {
113#endif
114 fMaster = true;
115#ifdef G4MULTITHREADED
116 }
117 G4MUTEXUNLOCK(&numuNucleusModel);
118#endif
119 }
120
121 if(fMaster)
122 {
123 const char* path = G4FindDataDir("G4PARTICLEXSDATA");
124 std::ostringstream ost1, ost2, ost3, ost4;
125 ost1 << path << "/" << "neutrino" << "/" << pName << "/xarraynckr";
126
127 std::ifstream filein1( ost1.str().c_str() );
128
129 // filein.open("$PARTICLEXSDATA/");
130
131 filein1>>nSize;
132
133 for( k = 0; k < fNbin; ++k )
134 {
135 for( i = 0; i <= fNbin; ++i )
136 {
137 filein1 >> fNuMuXarrayKR[k][i];
138 // G4cout<< fNuMuXarrayKR[k][i] << " ";
139 }
140 }
141 // G4cout<<G4endl<<G4endl;
142
143 ost2 << path << "/" << "neutrino" << "/" << pName << "/xdistrnckr";
144 std::ifstream filein2( ost2.str().c_str() );
145
146 filein2>>nSize;
147
148 for( k = 0; k < fNbin; ++k )
149 {
150 for( i = 0; i < fNbin; ++i )
151 {
152 filein2 >> fNuMuXdistrKR[k][i];
153 // G4cout<< fNuMuXdistrKR[k][i] << " ";
154 }
155 }
156 // G4cout<<G4endl<<G4endl;
157
158 ost3 << path << "/" << "neutrino" << "/" << pName << "/q2arraynckr";
159 std::ifstream filein3( ost3.str().c_str() );
160
161 filein3>>nSize;
162
163 for( k = 0; k < fNbin; ++k )
164 {
165 for( i = 0; i <= fNbin; ++i )
166 {
167 for( j = 0; j <= fNbin; ++j )
168 {
169 filein3 >> fNuMuQarrayKR[k][i][j];
170 // G4cout<< fNuMuQarrayKR[k][i][j] << " ";
171 }
172 }
173 }
174 // G4cout<<G4endl<<G4endl;
175
176 ost4 << path << "/" << "neutrino" << "/" << pName << "/q2distrnckr";
177 std::ifstream filein4( ost4.str().c_str() );
178
179 filein4>>nSize;
180
181 for( k = 0; k < fNbin; ++k )
182 {
183 for( i = 0; i <= fNbin; ++i )
184 {
185 for( j = 0; j < fNbin; ++j )
186 {
187 filein4 >> fNuMuQdistrKR[k][i][j];
188 // G4cout<< fNuMuQdistrKR[k][i][j] << " ";
189 }
190 }
191 }
192 fData = true;
193 }
194}
const char * G4FindDataDir(const char *)
#define G4MUTEXLOCK(mutex)
#define G4MUTEXUNLOCK(mutex)
static G4double fNuMuQarrayKR[50][51][51]
static G4double fNuMuXarrayKR[50][51]
static G4double fNuMuXdistrKR[50][50]
static G4double fNuMuQdistrKR[50][51][50]

Referenced by G4ANuElNucleusNcModel().

◆ IsApplicable()

G4bool G4ANuElNucleusNcModel::IsApplicable ( const G4HadProjectile & aTrack,
G4Nucleus & targetNucleus )
virtual

Reimplemented from G4NeutrinoNucleusModel.

Definition at line 198 of file G4ANuElNucleusNcModel.cc.

200{
201 G4bool result = false;
202 G4String pName = aPart.GetDefinition()->GetParticleName();
203 G4double energy = aPart.GetTotalEnergy();
205
206 if( pName == "anti_nu_e"
207 &&
208 energy > fMinNuEnergy )
209 {
210 result = true;
211 }
212
213 return result;
214}
bool G4bool
Definition G4Types.hh:86

◆ ModelDescription()

void G4ANuElNucleusNcModel::ModelDescription ( std::ostream & outFile) const
virtual

Reimplemented from G4NeutrinoNucleusModel.

Definition at line 88 of file G4ANuElNucleusNcModel.cc.

89{
90
91 outFile << "G4ANuElNucleusNcModel is a neutrino-nucleus (neutral current) scattering\n"
92 << "model which uses the standard model \n"
93 << "transfer parameterization. The model is fully relativistic\n";
94
95}

◆ SampleLVkr()

void G4ANuElNucleusNcModel::SampleLVkr ( const G4HadProjectile & aTrack,
G4Nucleus & targetNucleus )

Definition at line 465 of file G4ANuElNucleusNcModel.cc.

466{
467 fBreak = false;
468 G4int A = targetNucleus.GetA_asInt(), iTer(0), iTerMax(100);
469 G4int Z = targetNucleus.GetZ_asInt();
470 G4double e3(0.), pMu2(0.), pX2(0.), nMom(0.), rM(0.), hM(0.), tM = targetNucleus.AtomicMass(A,Z);
471 G4double cost(1.), sint(0.), phi(0.), muMom(0.);
472 G4ThreeVector eP, bst;
473 const G4HadProjectile* aParticle = &aTrack;
474 G4LorentzVector lvp1 = aParticle->Get4Momentum();
475 nMom = NucleonMomentum( targetNucleus );
476
477 if( A == 1 || nMom == 0. ) // hydrogen, no Fermi motion ???
478 {
479 fNuEnergy = aParticle->GetTotalEnergy();
480 iTer = 0;
481
482 do
483 {
487
488 if( fXsample > 0. )
489 {
490 fW2 = fM1*fM1 - fQ2 + fQ2/fXsample; // sample excited hadron mass
492 }
493 else
494 {
495 fW2 = fM1*fM1;
496 fEmu = fNuEnergy;
497 }
498 e3 = fNuEnergy + fM1 - fEmu;
499
500 // if( e3 < sqrt(fW2) ) G4cout<<"energyX = "<<e3/GeV<<", fW = "<<sqrt(fW2)/GeV<<G4endl; // vmg ~10^-5 for NC
501
502 pMu2 = fEmu*fEmu - fMnumu*fMnumu;
503 pX2 = e3*e3 - fW2;
504
505 fCosTheta = fNuEnergy*fNuEnergy + pMu2 - pX2;
506 fCosTheta /= 2.*fNuEnergy*sqrt(pMu2);
507 iTer++;
508 }
509 while( ( abs(fCosTheta) > 1. || fEmu < fMnumu ) && iTer < iTerMax );
510
511 if( iTer >= iTerMax ) { fBreak = true; return; }
512
513 if( abs(fCosTheta) > 1.) // vmg: due to big Q2/x values. To be improved ...
514 {
515 G4cout<<"H2: fCosTheta = "<<fCosTheta<<", fEmu = "<<fEmu<<G4endl;
516 // fCosTheta = -1. + 2.*G4UniformRand();
517 if(fCosTheta < -1.) fCosTheta = -1.;
518 if(fCosTheta > 1.) fCosTheta = 1.;
519 }
520 // LVs
521
522 G4LorentzVector lvt1 = G4LorentzVector( 0., 0., 0., fM1 );
523 G4LorentzVector lvsum = lvp1 + lvt1;
524
525 cost = fCosTheta;
526 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
527 phi = G4UniformRand()*CLHEP::twopi;
528 eP = G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
529 muMom = sqrt(fEmu*fEmu-fMnumu*fMnumu);
530 eP *= muMom;
531 fLVl = G4LorentzVector( eP, fEmu );
532
533 fLVh = lvsum - fLVl;
534 fLVt = G4LorentzVector( 0., 0., 0., 0. ); // no recoil
535 }
536 else // Fermi motion, Q2 in nucleon rest frame
537 {
538 G4ThreeVector nMomDir = nMom*G4RandomDirection();
539
540 if( !f2p2h ) // 1p1h
541 {
542 G4Nucleus recoil(A-1,Z);
543 rM = sqrt( recoil.AtomicMass(A-1,Z)*recoil.AtomicMass(A-1,Z) + nMom*nMom );
544 hM = tM - rM;
545
546 fLVt = G4LorentzVector( nMomDir, sqrt( rM*rM+nMom*nMom ) );
547 fLVh = G4LorentzVector(-nMomDir, sqrt( hM*hM+nMom*nMom ) );
548 }
549 else // 2p2h
550 {
551 G4Nucleus recoil(A-2,Z-1);
552 rM = recoil.AtomicMass(A-2,Z-1)+sqrt(nMom*nMom+fM1*fM1);
553 hM = tM - rM;
554
555 fLVt = G4LorentzVector( nMomDir, sqrt( rM*rM+nMom*nMom ) );
556 fLVh = G4LorentzVector(-nMomDir, sqrt( hM*hM+nMom*nMom ) );
557 }
558 // G4cout<<hM<<", ";
559 // bst = fLVh.boostVector(); // 9-3-20
560
561 // lvp1.boost(-bst); // 9-3-20 -> nucleon rest system, where Q2 transfer is ???
562
563 fNuEnergy = lvp1.e();
564 iTer = 0;
565
566 do
567 {
571
572 if( fXsample > 0. )
573 {
574 fW2 = fM1*fM1 - fQ2 + fQ2/fXsample; // sample excited hadron mass
576 }
577 else
578 {
579 fW2 = fM1*fM1;
580 fEmu = fNuEnergy;
581 }
582
583 // if(fEmu < 0.) G4cout<<"fEmu = "<<fEmu<<" hM = "<<hM<<G4endl;
584
585 e3 = fNuEnergy + fM1 - fEmu;
586
587 // if( e3 < sqrt(fW2) ) G4cout<<"energyX = "<<e3/GeV<<", fW = "<<sqrt(fW2)/GeV<<G4endl;
588
589 pMu2 = fEmu*fEmu - fMnumu*fMnumu;
590 pX2 = e3*e3 - fW2;
591
592 fCosTheta = fNuEnergy*fNuEnergy + pMu2 - pX2;
593 fCosTheta /= 2.*fNuEnergy*sqrt(pMu2);
594 iTer++;
595 }
596 while( ( abs(fCosTheta) > 1. || fEmu < fMnumu ) && iTer < iTerMax );
597
598 if( iTer >= iTerMax ) { fBreak = true; return; }
599
600 if( abs(fCosTheta) > 1.) // vmg: due to big Q2/x values. To be improved ...
601 {
602 G4cout<<"FM: fCosTheta = "<<fCosTheta<<", fEmu = "<<fEmu<<G4endl;
603 // fCosTheta = -1. + 2.*G4UniformRand();
604 if(fCosTheta < -1.) fCosTheta = -1.;
605 if(fCosTheta > 1.) fCosTheta = 1.;
606 }
607 // LVs
608 G4LorentzVector lvt1 = G4LorentzVector( 0., 0., 0., fM1 );
609 G4LorentzVector lvsum = lvp1 + lvt1;
610
611 cost = fCosTheta;
612 sint = std::sqrt( (1.0 - cost)*(1.0 + cost) );
613 phi = G4UniformRand()*CLHEP::twopi;
614 eP = G4ThreeVector( sint*std::cos(phi), sint*std::sin(phi), cost );
615 muMom = sqrt(fEmu*fEmu-fMnumu*fMnumu);
616 eP *= muMom;
617 fLVl = G4LorentzVector( eP, fEmu );
618 fLVh = lvsum - fLVl;
619 // back to lab system
620 // fLVl.boost(bst); // 9-3-20
621 // fLVh.boost(bst); // 9-3-20
622 }
623 //G4cout<<iTer<<", "<<fBreak<<"; ";
624}
G4ThreeVector G4RandomDirection()
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
G4double NucleonMomentum(G4Nucleus &targetNucleus)
G4double SampleXkr(G4double energy)
G4double SampleQkr(G4double energy, G4double xx)

Referenced by ApplyYourself().

◆ ThresholdEnergy()

G4double G4ANuElNucleusNcModel::ThresholdEnergy ( G4double mI,
G4double mF,
G4double mP )
inline

Definition at line 83 of file G4ANuElNucleusNcModel.hh.

84 {
85 G4double w = std::sqrt(fW2);
86 return w + 0.5*( (mP+mF)*(mP+mF)-(w+mI)*(w+mI) )/mI;
87 };

The documentation for this class was generated from the following files: