Geant4 11.2.2
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4SmartTrackStack.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// G4SmartTrackStack class implementation
27//
28// Author: S.Kamperis - 4 October 2012
29// --------------------------------------------------------------------
30
31#include "G4SmartTrackStack.hh"
32#include "G4VTrajectory.hh"
33#include "G4Track.hh"
34
36{
37 // Print to stderr so that we can split stats output from normal
38 // output of Geant4 which is typically being printed to stdout
39 for (G4int i=0; i<nTurn; ++i)
40 {
41 G4cerr << stacks[i]->GetNTrack() << " ";
42 G4cerr << stacks[i]->getTotalEnergy() << " ";
43 }
44 G4cerr << G4endl;
45}
46
48{
49 for(G4int i=0; i<nTurn; ++i)
50 {
51 stacks[i] = new G4TrackStack(5000);
52 energies[i] = 0.;
53 }
54}
55
57{
58 for (auto* sp : stacks)
59 {
60 delete sp;
61 }
62}
63
65{
66 for (auto* sp : stacks)
67 {
68 sp->TransferTo(aStack);
69 }
70 nTracks = 0;
71}
72
74{
75 G4StackedTrack aStackedTrack;
76
77 if (nTracks != 0)
78 {
79 while (true)
80 {
81 if (stacks[fTurn]->GetNTrack() != 0u)
82 {
83 aStackedTrack = stacks[fTurn]->PopFromStack();
84 energies[fTurn] -= aStackedTrack.GetTrack()->GetDynamicParticle()->GetTotalEnergy();
85 --nTracks;
86 break;
87 }
88
89 fTurn = (fTurn+1) % nTurn;
90 }
91 }
92
93 return aStackedTrack;
94}
95
96enum
97{
99};
100
102{
103
104 G4int iDest = 0;
105 if (aStackedTrack.GetTrack()->GetParentID() != 0)
106 {
107 G4int code = aStackedTrack.GetTrack()->GetDynamicParticle()->GetPDGcode();
108 if (code == electronCode)
109 iDest = 2;
110 else if (code == gammaCode)
111 iDest = 3;
112 else if (code == positronCode)
113 iDest = 4;
114 else if (code == neutronCode)
115 iDest = 1;
116 }
117 else
118 {
119 // We have a primary track, which should go first.
120 fTurn = 0; // reseting the turn
121 }
122 stacks[iDest]->PushToStack(aStackedTrack);
123 energies[iDest] += aStackedTrack.GetTrack()->GetDynamicParticle()->GetTotalEnergy();
124 ++nTracks;
125
126 G4long dy1 = stacks[iDest]->GetNTrack() - stacks[iDest]->GetSafetyValue1();
127 G4long dy2 = stacks[fTurn]->GetNTrack() - stacks[fTurn]->GetSafetyValue2();
128
129 if (dy1 > 0 || dy1 > dy2 ||
130 (iDest == 2 &&
131 stacks[iDest]->GetNTrack() < 50 && energies[iDest] < energies[fTurn]))
132 {
133 fTurn = iDest;
134 }
135
136 if (nTracks > maxNTracks) maxNTracks = nTracks;
137}
138
140{
141 for (G4int i = 0; i < nTurn; ++i)
142 {
143 stacks[i]->clear();
144 energies[i] = 0.0;
145 fTurn = 0;
146 }
147 nTracks = 0;
148}
149
151{
152 for (G4int i = 0; i < nTurn; ++i)
153 {
154 stacks[i]->clearAndDestroy();
155 energies[i] = 0.0;
156 fTurn = 0;
157 }
158 nTracks = 0;
159}
@ electronCode
@ neutronCode
@ gammaCode
@ positronCode
long G4long
Definition G4Types.hh:87
int G4int
Definition G4Types.hh:85
G4GLOB_DLL std::ostream G4cerr
#define G4endl
Definition G4ios.hh:67
G4double GetTotalEnergy() const
G4int GetPDGcode() const
void TransferTo(G4TrackStack *aStack)
void PushToStack(const G4StackedTrack &aStackedTrack)
G4int GetNTrack() const
G4StackedTrack PopFromStack()
G4Track * GetTrack() const
const G4DynamicParticle * GetDynamicParticle() const
G4int GetParentID() const