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

#include <G4ChipsHyperonInelasticXS.hh>

+ Inheritance diagram for G4ChipsHyperonInelasticXS:

Public Member Functions

 G4ChipsHyperonInelasticXS ()
 
 ~G4ChipsHyperonInelasticXS ()
 
virtual void CrossSectionDescription (std::ostream &) const
 
virtual G4bool IsIsoApplicable (const G4DynamicParticle *Pt, G4int Z, G4int A, const G4Element *elm, const G4Material *mat)
 
virtual G4double GetIsoCrossSection (const G4DynamicParticle *, G4int tgZ, G4int A, const G4Isotope *iso=0, const G4Element *elm=0, const G4Material *mat=0)
 
virtual G4double GetChipsCrossSection (G4double momentum, G4int Z, G4int N, G4int pdg)
 
- Public Member Functions inherited from G4VCrossSectionDataSet
 G4VCrossSectionDataSet (const G4String &nam="")
 
virtual ~G4VCrossSectionDataSet ()
 
virtual G4bool IsElementApplicable (const G4DynamicParticle *, G4int Z, const G4Material *mat=nullptr)
 
G4double GetCrossSection (const G4DynamicParticle *, const G4Element *, const G4Material *mat=nullptr)
 
G4double ComputeCrossSection (const G4DynamicParticle *, const G4Element *, const G4Material *mat=nullptr)
 
virtual G4double ComputeCrossSectionPerElement (G4double kinEnergy, G4double loge, const G4ParticleDefinition *, const G4Element *, const G4Material *mat=nullptr)
 
virtual G4double GetElementCrossSection (const G4DynamicParticle *, G4int Z, const G4Material *mat=nullptr)
 
virtual G4double ComputeIsoCrossSection (G4double kinEnergy, G4double loge, const G4ParticleDefinition *, G4int Z, G4int A, const G4Isotope *iso=nullptr, const G4Element *elm=nullptr, const G4Material *mat=nullptr)
 
virtual const G4IsotopeSelectIsotope (const G4Element *, G4double kinEnergy, G4double logE)
 
virtual void BuildPhysicsTable (const G4ParticleDefinition &)
 
virtual void DumpPhysicsTable (const G4ParticleDefinition &)
 
virtual void SetVerboseLevel (G4int value)
 
G4double GetMinKinEnergy () const
 
void SetMinKinEnergy (G4double value)
 
G4double GetMaxKinEnergy () const
 
void SetMaxKinEnergy (G4double value)
 
bool ForAllAtomsAndEnergies () const
 
void SetForAllAtomsAndEnergies (G4bool val)
 
const G4StringGetName () const
 
void SetName (const G4String &nam)
 
G4VCrossSectionDataSetoperator= (const G4VCrossSectionDataSet &right)=delete
 
 G4VCrossSectionDataSet (const G4VCrossSectionDataSet &)=delete
 

Static Public Member Functions

static const char * Default_Name ()
 

Additional Inherited Members

- Protected Attributes inherited from G4VCrossSectionDataSet
G4int verboseLevel {0}
 
G4String name
 

Detailed Description

Definition at line 45 of file G4ChipsHyperonInelasticXS.hh.

Constructor & Destructor Documentation

◆ G4ChipsHyperonInelasticXS()

G4ChipsHyperonInelasticXS::G4ChipsHyperonInelasticXS ( )

Definition at line 54 of file G4ChipsHyperonInelasticXS.cc.

55{
56 // Initialization of the
57 lastLEN=0; // Pointer to the lastArray of LowEn CS
58 lastHEN=0; // Pointer to the lastArray of HighEn CS
59 lastN=0; // The last N of calculated nucleus
60 lastZ=0; // The last Z of calculated nucleus
61 lastP=0.; // Last used in cross section Momentum
62 lastTH=0.; // Last threshold momentum
63 lastCS=0.; // Last value of the Cross Section
64 lastI=0; // The last position in the DAMDB
65 LEN = new std::vector<G4double*>;
66 HEN = new std::vector<G4double*>;
67}
G4VCrossSectionDataSet(const G4String &nam="")

◆ ~G4ChipsHyperonInelasticXS()

G4ChipsHyperonInelasticXS::~G4ChipsHyperonInelasticXS ( )

Definition at line 69 of file G4ChipsHyperonInelasticXS.cc.

70{
71 std::size_t lens=LEN->size();
72 for(std::size_t i=0; i<lens; ++i) delete[] (*LEN)[i];
73 delete LEN;
74
75 std::size_t hens=HEN->size();
76 for(std::size_t i=0; i<hens; ++i) delete[] (*HEN)[i];
77 delete HEN;
78}

Member Function Documentation

◆ CrossSectionDescription()

void G4ChipsHyperonInelasticXS::CrossSectionDescription ( std::ostream & outFile) const
virtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 80 of file G4ChipsHyperonInelasticXS.cc.

81{
82 outFile << "G4ChipsHyperonInelasticXS provides the inelastic cross\n"
83 << "section for hyperon nucleus scattering as a function of incident\n"
84 << "momentum. The cross section is calculated using M. Kossov's\n"
85 << "CHIPS parameterization of cross section data.\n";
86}

◆ Default_Name()

static const char * G4ChipsHyperonInelasticXS::Default_Name ( )
inlinestatic

Definition at line 54 of file G4ChipsHyperonInelasticXS.hh.

54{return "ChipsHyperonInelasticXS";}

Referenced by G4ChipsComponentXS::G4ChipsComponentXS(), and G4ChipsHyperonInelasticXS().

◆ GetChipsCrossSection()

G4double G4ChipsHyperonInelasticXS::GetChipsCrossSection ( G4double momentum,
G4int Z,
G4int N,
G4int pdg )
virtual

!The slave functions must provide cross-sections in millibarns (mb) !! (not in IU)

Definition at line 109 of file G4ChipsHyperonInelasticXS.cc.

110{
111
112 G4bool in=false; // By default the isotope must be found in the AMDB
113 if(tgN!=lastN || tgZ!=lastZ) // The nucleus was not the last used isotope
114 {
115 in = false; // By default the isotope haven't be found in AMDB
116 lastP = 0.; // New momentum history (nothing to compare with)
117 lastN = tgN; // The last N of the calculated nucleus
118 lastZ = tgZ; // The last Z of the calculated nucleus
119 lastI = (G4int)colN.size(); // Size of the Associative Memory DB in the heap
120 j = 0; // A#0f records found in DB for this projectile
121
122 if(lastI) for(G4int i=0; i<lastI; ++i) // AMDB exists, try to find the (Z,N) isotope
123 {
124 if(colN[i]==tgN && colZ[i]==tgZ) // Try the record "i" in the AMDB
125 {
126 lastI=i; // Remember the index for future fast/last use
127 lastTH =colTH[i]; // The last THreshold (A-dependent)
128
129 if(pMom<=lastTH)
130 {
131 return 0.; // Energy is below the Threshold value
132 }
133 lastP =colP [i]; // Last Momentum (A-dependent)
134 lastCS =colCS[i]; // Last CrossSect (A-dependent)
135 in = true; // This is the case when the isotop is found in DB
136 // Momentum pMom is in IU ! @@ Units
137 lastCS=CalculateCrossSection(-1,j,PDG,lastZ,lastN,pMom); // read & update
138
139 if(lastCS<=0. && pMom>lastTH) // Correct the threshold (@@ No intermediate Zeros)
140 {
141 lastCS=0.;
142 lastTH=pMom;
143 }
144 break; // Go out of the LOOP
145 }
146 j++; // Increment a#0f records found in DB
147 }
148 if(!in) // This isotope has not been calculated previously
149 {
150 //!!The slave functions must provide cross-sections in millibarns (mb) !! (not in IU)
151 lastCS=CalculateCrossSection(0,j,PDG,lastZ,lastN,pMom); //calculate & create
152
153 lastTH = 0; //ThresholdEnergy(tgZ, tgN); // The Threshold Energy which is now the last
154 colN.push_back(tgN);
155 colZ.push_back(tgZ);
156 colP.push_back(pMom);
157 colTH.push_back(lastTH);
158 colCS.push_back(lastCS);
159 //} // M.K. Presence of H1 with high threshold breaks the syncronization
160 return lastCS*millibarn;
161 } // End of creation of the new set of parameters
162 else
163 {
164 colP[lastI]=pMom;
165 colCS[lastI]=lastCS;
166 }
167 } // End of parameters udate
168 else if(pMom<=lastTH)
169 {
170 return 0.; // Momentum is below the Threshold Value -> CS=0
171 }
172 else // It is the last used -> use the current tables
173 {
174 lastCS=CalculateCrossSection(1,j,PDG,lastZ,lastN,pMom); // Only read and UpdateDB
175 lastP=pMom;
176 }
177 return lastCS*millibarn;
178}
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85

Referenced by GetIsoCrossSection().

◆ GetIsoCrossSection()

G4double G4ChipsHyperonInelasticXS::GetIsoCrossSection ( const G4DynamicParticle * Pt,
G4int tgZ,
G4int A,
const G4Isotope * iso = 0,
const G4Element * elm = 0,
const G4Material * mat = 0 )
virtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 97 of file G4ChipsHyperonInelasticXS.cc.

101{
102 G4double pMom=Pt->GetTotalMomentum();
103 G4int tgN = A - tgZ;
104 G4int pdg = Pt->GetDefinition()->GetPDGEncoding();
105
106 return GetChipsCrossSection(pMom, tgZ, tgN, pdg);
107}
double G4double
Definition G4Types.hh:83
const G4double A[17]
virtual G4double GetChipsCrossSection(G4double momentum, G4int Z, G4int N, G4int pdg)
G4ParticleDefinition * GetDefinition() const
G4double GetTotalMomentum() const

◆ IsIsoApplicable()

G4bool G4ChipsHyperonInelasticXS::IsIsoApplicable ( const G4DynamicParticle * Pt,
G4int Z,
G4int A,
const G4Element * elm,
const G4Material * mat )
virtual

Reimplemented from G4VCrossSectionDataSet.

Definition at line 88 of file G4ChipsHyperonInelasticXS.cc.

91{
92 return true;
93}

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