Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4VITSteppingVerbose.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/*
27 * G4VITSteppingVerbose.cc
28 *
29 * Created on: Jun 22, 2015
30 * Author: mkaramit
31 */
32
35
36//______________________________________________________________________________
37
39{
40 fpStepProcessor = nullptr;
41 fpState = nullptr;
42 fpProcessGeneralInfo = nullptr;
43
44 PhysicalStep = -1;
46
47 fParticleChange = nullptr;
48 fTrack = nullptr;
49 fSecondary = nullptr;
50 fStep = nullptr;
51 fPreStepPoint = nullptr;
52 fPostStepPoint = nullptr;
53
54 fCurrentVolume = nullptr;
55 // fSensitive = fpStepProcessor->GetfSensitive();
56 fCurrentProcess = nullptr;
57
58 fAtRestDoItVector = nullptr;
59 fAlongStepDoItVector = nullptr;
60 fPostStepDoItVector = nullptr;
61
65
69
72
76
77 // fNavigator = fpStepProcessor->GetfNavigator();
78
79 fVerboseLevel = 0;
80 fpVerboseUI = new G4UIcmdWithAnInteger("/chem/tracking/verbose", this);
81
84
86
87 fTouchableHandle = nullptr;
88
89 // StepControlFlag = fpStepProcessor->GetStepControlFlag();
90
91 physIntLength = 0;
94
95}
96
97//______________________________________________________________________________
98
103
104//______________________________________________________________________________
105
107{
108
109 if(fpState != nullptr) *fpState = *(fpStepProcessor->GetProcessorState());
110 else
111 {
112 fpState = new G4ITStepProcessorState(*fpStepProcessor->GetProcessorState());
113 }
114
115 fpProcessGeneralInfo = fpStepProcessor->GetCurrentProcessInfo();
116
117 PhysicalStep = fpStepProcessor->GetPhysIntLength();
118 fStepStatus = fpState->fStepStatus;
119
120 fParticleChange = fpStepProcessor->GetParticleChange();
121 fTrack = fpStepProcessor->GetTrack();
122 fSecondary = fpStepProcessor->GetSecondaries();
123 fStep = fpStepProcessor->GetStep();
124 fPreStepPoint = fStep->GetPreStepPoint();
125 fPostStepPoint = fStep->GetPostStepPoint();
126
127 fCurrentVolume = fpStepProcessor->GetCurrentVolume();
128// fSensitive = fpStepProcessor->GetfSensitive();
129 fCurrentProcess = fpStepProcessor->GetCurrentProcess();
130
131 fAtRestDoItVector = fpProcessGeneralInfo->fpAtRestDoItVector;
132 fAlongStepDoItVector = fpProcessGeneralInfo->fpAlongStepDoItVector;
133 fPostStepDoItVector = fpProcessGeneralInfo->fpPostStepDoItVector;
134
135 fAtRestGetPhysIntVector = fpProcessGeneralInfo->fpAtRestGetPhysIntVector;
137 fpProcessGeneralInfo->fpAlongStepGetPhysIntVector;
138 fPostStepGetPhysIntVector = fpProcessGeneralInfo->fpPostStepGetPhysIntVector;
139
140 MAXofAtRestLoops = fpProcessGeneralInfo->MAXofAtRestLoops;
141 MAXofAlongStepLoops = fpProcessGeneralInfo->MAXofAlongStepLoops;
142 MAXofPostStepLoops = fpProcessGeneralInfo->MAXofPostStepLoops;
143
144 fAtRestDoItProcTriggered = fpStepProcessor->GetAtRestDoItProcTriggered();
145 fPostStepDoItProcTriggered = fpStepProcessor->GetPostStepDoItProcTriggered();
146
147 fN2ndariesAtRestDoIt = fpStepProcessor->GetN2ndariesAtRestDoIt();
148 fN2ndariesAlongStepDoIt = fpStepProcessor->GetN2ndariesAlongStepDoIt();
149 fN2ndariesPostStepDoIt = fpStepProcessor->GetN2ndariesPostStepDoIt();
150
151// fNavigator = fpStepProcessor->GetfNavigator();
152
153 fSelectedAtRestDoItVector = &(fpState->fSelectedAtRestDoItVector);
154 fSelectedPostStepDoItVector = &(fpState->fSelectedPostStepDoItVector);
155
156 fPreviousStepSize = fpState->fPreviousStepSize;
157
158 fTouchableHandle = fpState->fTouchableHandle;
159
160// StepControlFlag = fpStepProcessor->GetStepControlFlag();
161
162 physIntLength = fpStepProcessor->GetPhysIntLength();
163 fCondition = fpStepProcessor->GetCondition();
164 fGPILSelection = fpStepProcessor->GetGPILSelection();
165}
166
167//______________________________________________________________________________
168
170{
171 if(command == fpVerboseUI)
172 {
173 fVerboseLevel = fpVerboseUI->GetNewIntValue(newValue);
174 }
175}
176
177//______________________________________________________________________________
178
183
184//______________________________________________________________________________
185
187#ifdef G4VERBOSE
188 track
189#endif
190)
191{
192#ifdef G4VERBOSE
193 if(fVerboseLevel > 0)
194 {
195 TrackBanner(track, "G4ITTrackingManager::StartTracking : ");
196 }
197#endif
198
199}
200
201//______________________________________________________________________________
202
204#ifdef G4VERBOSE
205 track
206#endif
207)
208{
209#ifdef G4VERBOSE
210 if(fVerboseLevel > 0)
211 {
212 TrackBanner(track, "G4ITTrackingManager::EndTracking : ");
213 }
214#endif
215}
216
217//______________________________________________________________________________
218
220{
221 G4cout << G4endl;
222 G4cout << "*******************************************************"
223 << "**************************************************"
224 << G4endl;
225 if(!message.empty())
226 {
227 G4cout << message;
228 }
229 G4cout << " * G4Track Information: "
230 << " Particle : " << track->GetDefinition()->GetParticleName()
231 << ","
232 << " Track ID : " << track->GetTrackID()
233 << ","
234 << " Parent ID : " << track->GetParentID()
235 << G4endl;
236 G4cout << "*******************************************************"
237 << "**************************************************"
238 << G4endl;
239 G4cout << G4endl;
240}
@ InActivated
@ NotCandidateForSelection
@ fUndefined
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
const G4String & GetParticleName() const
G4int GetTrackID() const
G4ParticleDefinition * GetDefinition() const
G4int GetParentID() const
static G4String ConvertToString(G4bool boolVal)
G4ITStepProcessorState * fpState
const G4ITStepProcessor * fpStepProcessor
G4ProcessVector * fAtRestGetPhysIntVector
G4ProcessVector * fPostStepDoItVector
G4SelectedPostStepDoItVector * fSelectedPostStepDoItVector
G4String GetCurrentValue(G4UIcommand *command) override
G4UIcmdWithAnInteger * fpVerboseUI
G4ProcessVector * fPostStepGetPhysIntVector
G4ProcessVector * fAtRestDoItVector
G4TouchableHandle fTouchableHandle
virtual void TrackingEnded(G4Track *track)
const G4VPhysicalVolume * fCurrentVolume
const ProcessGeneralInfo * fpProcessGeneralInfo
G4ProcessVector * fAlongStepGetPhysIntVector
const G4VITProcess * fCurrentProcess
G4SelectedAtRestDoItVector * fSelectedAtRestDoItVector
const G4VParticleChange * fParticleChange
const G4TrackVector * fSecondary
void SetNewValue(G4UIcommand *command, G4String newValue) override
virtual void TrackingStarted(G4Track *track)
G4ProcessVector * fAlongStepDoItVector
void TrackBanner(G4Track *track, const G4String &message)