78{
79 auto result = new G4ReactionProduct;
80 auto Z =
static_cast<G4int>(massCode / 1000);
81 auto A =
static_cast<G4int>(massCode - 1000 * Z);
82
83 if (massCode == 0) {
85 }
89 }
93 }
96 }
99 if (Z == 2) result->SetDefinition(
G4He3::He3());
100 }
103 if (Z != 2) throw G4HadronicException(__FILE__, __LINE__, "Unknown ion case 1");
104 }
105 else {
106 throw G4HadronicException(__FILE__, __LINE__,
107 "G4ParticleHPLabAngularEnergy: Unknown ion case 2");
108 }
109
110
113
114 for (i = 0; i < nEnergies; i++) {
115 it = i;
116 if (anEnergy < theEnergies[i]) break;
117 }
118
119 if (it == 0)
120
121 {
122
123
124
125 G4ParticleHPVector theThVec;
127 for (i = 0; i < nCosTh[it]; i++) {
128 theThVec.
SetX(i, theData[it][i].GetLabel());
129 theThVec.
SetY(i, theData[it][i].GetIntegral());
130 }
131 cosTh = theThVec.
Sample();
132
133
134
135
138 for (i = 1; i < nCosTh[it]; i++) {
139 i1 = i;
140 if (cosTh < theData[it][i].GetLabel()) break;
141 }
142
143 x = cosTh;
144 x1 = theData[it][i1 - 1].GetLabel();
145 x2 = theData[it][i1].GetLabel();
146 G4ParticleHPVector theBuff1a;
148 for (i = 0; i < theData[it][i1 - 1].GetVectorLength(); i++) {
149 E = theData[it][i1 - 1].GetX(i);
150 y1 = theData[it][i1 - 1].GetY(i);
151 y2 = theData[it][i1].GetY(E);
152 y = theInt.Interpolate(theSecondManager[it].GetScheme(i1), x, x1, x2, y1, y2);
154 }
155 G4ParticleHPVector theBuff2a;
157 for (i = 0; i < theData[it][i1].GetVectorLength(); i++) {
158 E = theData[it][i1].GetX(i);
159 y1 = theData[it][i1 - 1].GetY(E);
160 y2 = theData[it][i1].GetY(i);
161 y = theInt.Interpolate(theSecondManager[it].GetScheme(i1), x, x1, x2, y1, y2);
163 }
164 G4ParticleHPVector theStore;
165 theStore.
Merge(&theBuff1a, &theBuff2a);
166 secEnergy = theStore.
Sample();
167 currentMeanEnergy = theStore.
GetMeanX();
168
169 }
170 else
171 {
172 G4double x, x1, x2, y1, y2, y, tmp, E;
173
174 G4ParticleHPVector run1;
175 for (i = 0; i < nCosTh[it - 1]; i++) {
176 run1.
SetX(i, theData[it - 1][i].GetLabel());
177 run1.
SetY(i, theData[it - 1][i].GetIntegral());
178 }
179 G4ParticleHPVector run2;
180 for (i = 0; i < nCosTh[it]; i++) {
181 run2.
SetX(i, theData[it][i].GetLabel());
182 run2.
SetY(i, theData[it][i].GetIntegral());
183 }
184
185 x = anEnergy;
186 x1 = theEnergies[it - 1];
187 x2 = theEnergies[it];
188 G4ParticleHPVector thBuff1;
194 y = theInt.Interpolate(theManager.GetScheme(it), x, x1, x2, y1, y2);
196 }
197 G4ParticleHPVector thBuff2;
203 y = theInt.Interpolate(theManager.GetScheme(it), x, x1, x2, y1, y2);
205 }
206 G4ParticleHPVector theThVec;
207 theThVec.
Merge(&thBuff1, &thBuff2);
208 cosTh = theThVec.
Sample();
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
232
233
234 for (i = 1; i < nCosTh[it - 1]; i++) {
235 i1 = i;
236 if (cosTh < theData[it - 1][i].GetLabel()) break;
237 }
238
239 x = cosTh;
240 x1 = theData[it - 1][i1 - 1].GetLabel();
241 x2 = theData[it - 1][i1].GetLabel();
242 G4ParticleHPVector theBuff1a;
244 for (i = 0; i < theData[it - 1][i1 - 1].GetVectorLength(); i++) {
245 E = theData[it - 1][i1 - 1].GetX(i);
246 y1 = theData[it - 1][i1 - 1].GetY(i);
247 y2 = theData[it - 1][i1].GetY(E);
248 y = theInt.Interpolate(theSecondManager[it - 1].GetScheme(i1), x, x1, x2, y1, y2);
250 }
251 G4ParticleHPVector theBuff2a;
253 for (i = 0; i < theData[it - 1][i1].GetVectorLength(); i++) {
254 E = theData[it - 1][i1].GetX(i);
255 y1 = theData[it - 1][i1 - 1].GetY(E);
256 y2 = theData[it - 1][i1].GetY(i);
257 y = theInt.Interpolate(theSecondManager[it - 1].GetScheme(i1), x, x1, x2, y1, y2);
259 }
260 G4ParticleHPVector theStore1;
261 theStore1.
Merge(&theBuff1a, &theBuff2a);
262
263
264
265 for (i = 1; i < nCosTh[it]; i++) {
266 i2 = i;
267 if (cosTh < theData[it][i2].GetLabel()) break;
268 }
269 x1 = theData[it][i2 - 1].GetLabel();
270 x2 = theData[it][i2].GetLabel();
271 G4ParticleHPVector theBuff1b;
273 for (i = 0; i < theData[it][i2 - 1].GetVectorLength(); i++) {
274 E = theData[it][i2 - 1].GetX(i);
275 y1 = theData[it][i2 - 1].GetY(i);
276 y2 = theData[it][i2].GetY(E);
277 y = theInt.Interpolate(theSecondManager[it].GetScheme(i2), x, x1, x2, y1, y2);
279 }
280 G4ParticleHPVector theBuff2b;
282
283
284 for (i = 0; i < theData[it][i2].GetVectorLength(); i++) {
285
286
287
288 E = theData[it][i2].GetX(i);
289 y1 = theData[it][i2 - 1].GetY(E);
290 y2 = theData[it][i2].GetY(i);
291 y = theInt.Interpolate(theSecondManager[it].GetScheme(i2), x, x1, x2, y1, y2);
293 }
294 G4ParticleHPVector theStore2;
295 theStore2.
Merge(&theBuff1b, &theBuff2b);
296
297
298 x = anEnergy;
299 x1 = theEnergies[it - 1];
300 x2 = theEnergies[it];
301 G4ParticleHPVector theOne1;
304 E = theStore1.
GetX(i);
305 y1 = theStore1.
GetY(i);
306 y2 = theStore2.
GetY(E);
307 y = theInt.Interpolate(theManager.GetScheme(it), x, x1, x2, y1, y2);
309 }
310 G4ParticleHPVector theOne2;
313 E = theStore2.
GetX(i);
314 y1 = theStore1.
GetY(E);
315 y2 = theStore2.
GetY(i);
316 y = theInt.Interpolate(theManager.GetScheme(it), x, x1, x2, y1, y2);
318 }
319 G4ParticleHPVector theOne;
320 theOne.
Merge(&theOne1, &theOne2);
321
322 secEnergy = theOne.
Sample();
323 currentMeanEnergy = theOne.
GetMeanX();
324 }
325
326
327
328 result->SetKineticEnergy(secEnergy);
329
333 G4double mtot = result->GetTotalMomentum();
334 G4ThreeVector tempVector(mtot * sinth * std::cos(phi), mtot * sinth * std::sin(phi),
335 mtot * std::cos(theta));
336 result->SetMomentum(tempVector);
337
338 return result;
339}
CLHEP::Hep3Vector G4ThreeVector
static G4Deuteron * Deuteron()
static G4Electron * Electron()
static G4Neutron * Neutron()
void SetY(G4int i, G4double x)
void SetX(G4int i, G4double e)
void SetData(G4int i, G4double x, G4double y)
const G4InterpolationManager & GetInterpolationManager() const
void SetInterpolationManager(const G4InterpolationManager &aManager)
G4double GetY(G4double x)
G4double GetX(G4int i) const
void Merge(G4ParticleHPVector *active, G4ParticleHPVector *passive)
G4int GetVectorLength() const
static G4Positron * Positron()
static G4Proton * Proton()
static G4Triton * Triton()