Geant4 11.4.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4ParticleHPElementData.cc
Go to the documentation of this file.
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26// particle_hp -- source file
27// J.P. Wellisch, Nov-1996
28// A prototype of the low energy neutron transport model.
29//
30// T.Koi 02-08-06 Modified Harmonise to resolve x-section trouble at high-end.
31//
32// P. Arce, June-2014 Conversion neutron_hp to particle_hp
33// V. Ivanchenko July-2023 converted back capture
34//
36
38{
39 precision = 0.02;
40 theFissionData = new G4ParticleHPVector;
41 theCaptureData = new G4ParticleHPVector;
42 theElasticData = new G4ParticleHPVector;
43 theInelasticData = new G4ParticleHPVector;
44 theIsotopeWiseData = nullptr;
45 theBuffer = nullptr;
46}
47
49{
50 delete theFissionData;
51 delete theCaptureData;
52 delete theElasticData;
53 delete theInelasticData;
54 delete[] theIsotopeWiseData;
55}
56
58 G4ParticleDefinition* projectile,
59 const char* dataDirVariable)
60{
61 auto nIso = (G4int)theElement->GetNumberOfIsotopes();
62 auto Z = theElement->GetZasInt();
63 const std::size_t dsize = nIso > 0 ? nIso : 1;
64 theIsotopeWiseData = new G4ParticleHPIsoData[dsize];
65
66 for (G4int i1 = 0; i1 < nIso; ++i1) {
67 G4int A = theElement->GetIsotope(i1)->GetN();
68 G4int M = theElement->GetIsotope(i1)->Getm();
69 G4double frac = theElement->GetRelativeAbundanceVector()[i1] / CLHEP::perCent;
70 UpdateData(A, Z, M, i1, frac, projectile, dataDirVariable);
71 }
72}
73
75 G4double abundance,
76 G4ParticleDefinition* projectile,
77 const char* dataDirVariable)
78{
79 // Reads in the Data, using G4ParticleHPIsoData[], and its Init
80 theIsotopeWiseData[index].Init(A, Z, M, abundance, projectile, dataDirVariable);
81
82 theBuffer = theIsotopeWiseData[index].MakeElasticData();
83 Harmonise(theElasticData, theBuffer);
84 delete theBuffer;
85
86 theBuffer = theIsotopeWiseData[index].MakeInelasticData();
87 Harmonise(theInelasticData, theBuffer);
88 delete theBuffer;
89
90 theBuffer = theIsotopeWiseData[index].MakeCaptureData();
91 Harmonise(theCaptureData, theBuffer);
92 delete theBuffer;
93
94 theBuffer = theIsotopeWiseData[index].MakeFissionData();
95 Harmonise(theFissionData, theBuffer);
96 delete theBuffer;
97}
98
100{
101 if (theNew == nullptr) {
102 return;
103 }
104 G4int s_tmp = 0, n = 0, m_tmp = 0;
105 auto theMerge = new G4ParticleHPVector(theStore->GetVectorLength());
106 while (theStore->GetEnergy(s_tmp) < theNew->GetEnergy(0)
107 && s_tmp < theStore->GetVectorLength()) // Loop checking, 11.05.2015, T. Koi
108 {
109 theMerge->SetData(m_tmp++, theStore->GetEnergy(s_tmp), theStore->GetXsec(s_tmp));
110 ++s_tmp;
111 }
112 G4ParticleHPVector* active = theStore;
113 G4ParticleHPVector* passive = theNew;
115 G4int a = s_tmp, p = n, t;
116 while (a < active->GetVectorLength()
117 && p < passive->GetVectorLength()) // Loop checking, 11.05.2015, T. Koi
118 {
119 if (active->GetEnergy(a) <= passive->GetEnergy(p)) {
120 theMerge->SetData(m_tmp, active->GetEnergy(a), active->GetXsec(a));
121 G4double x = theMerge->GetEnergy(m_tmp);
122 G4double y = std::max(0., passive->GetXsec(x));
123 theMerge->SetData(m_tmp, x, theMerge->GetXsec(m_tmp) + y);
124 ++m_tmp;
125 ++a;
126 }
127 else {
128 tmp = active;
129 t = a;
130 active = passive;
131 a = p;
132 passive = tmp;
133 p = t;
134 }
135 }
136 while (a != active->GetVectorLength()) // Loop checking, 11.05.2015, T. Koi
137 {
138 theMerge->SetData(m_tmp++, active->GetEnergy(a), active->GetXsec(a));
139 ++a;
140 }
141 while (p != passive->GetVectorLength()) // Loop checking, 11.05.2015, T. Koi
142 {
143 G4double x = passive->GetEnergy(p);
144 G4double y = std::max(0., active->GetXsec(x));
145 theMerge->SetData(m_tmp++, x, passive->GetXsec(p) + y);
146 ++p;
147 }
148 delete theStore;
149 theStore = theMerge;
150}
151
154 G4ParticleDefinition* projectile,
156 char* dataDirVariable)
157{
158 Init(theElement, projectile, dataDirVariable);
159 return GetData(theSet);
160}
161
164 G4ParticleDefinition* projectile,
166 char* dataDirVariable)
167{
168 Init(theElement, projectile, dataDirVariable);
169 return GetData(theSet);
170}
171
174 G4ParticleDefinition* projectile,
176 char* dataDirVariable)
177{
178 Init(theElement, projectile, dataDirVariable);
179 return GetData(theSet);
180}
183 G4ParticleDefinition* projectile,
185 char* dataDirVariable)
186{
187 Init(theElement, projectile, dataDirVariable);
188 return GetData(theSet);
189}
#define M(row, col)
double G4double
Definition G4Types.hh:83
int G4int
Definition G4Types.hh:85
const G4double A[17]
G4double * GetRelativeAbundanceVector() const
Definition G4Element.hh:149
std::size_t GetNumberOfIsotopes() const
Definition G4Element.hh:143
const G4Isotope * GetIsotope(G4int iso) const
Definition G4Element.hh:151
G4int GetZasInt() const
Definition G4Element.hh:120
G4int Getm() const
Definition G4Isotope.hh:89
G4int GetN() const
Definition G4Isotope.hh:83
G4ParticleHPVector * GetData(G4ParticleHPFissionData *)
void UpdateData(G4int A, G4int Z, G4int index, G4double abundance, G4ParticleDefinition *projectile, const char *dataDirVariable)
G4ParticleHPVector * MakePhysicsVector(G4Element *theElement, G4ParticleDefinition *projectile, G4ParticleHPFissionData *theSet, char *dataDirVariable)
void Harmonise(G4ParticleHPVector *&theStore, G4ParticleHPVector *theNew)
void Init(G4Element *theElement, G4ParticleDefinition *projectile, const char *dataDirVariable)
G4bool Init(G4int A, G4int Z, G4double abun, const G4String &dirName, const G4String &aFSType)
G4double GetXsec(G4int i)
G4double GetEnergy(G4int i) const
G4int GetVectorLength() const