Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4VSteppingVerbose.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// G4VSteppingVerbose class implementation
27//
28// Contact:
29// Questions and comments to this code should be sent to
30// Katsuya Amako (e-mail: [email protected])
31// Takashi Sasaki (e-mail: [email protected])
32// --------------------------------------------------------------------
33
34#include "G4VSteppingVerbose.hh"
35
37#include "G4SteppingManager.hh"
38#include "G4Track.hh"
39
44
45//////////////////////////////////////////////////
47//////////////////////////////////////////////////
48{
49 if (fInstance != nullptr) {
50 G4Exception("G4VSteppingVerbose::G4VSteppingVerbose()", "Tracking0014", FatalException,
51 "Only one SteppingVerbose class can be instantiated.");
52 }
53 fInstance = this;
54 if (fMasterInstance == nullptr) fMasterInstance = this;
55}
56
57//////////////////////////////////////////////////
59//////////////////////////////////////////////////
60{
61 fInstance = nullptr;
62}
63
64//////////////////////////////////////////////////////////////////
66//////////////////////////////////////////////////////////////////
67{
68 G4Exception("G4VSteppingVerbose::Clone", "TRKING000", FatalException,
69 "Base class method must not be invoked.");
70 return nullptr;
71}
72//////////////////////////////////////////////////////////////////
74//////////////////////////////////////////////////////////////////
75{
76 fManager = fMan;
77}
78
79//////////////////////////////////////////////////
81//////////////////////////////////////////////////
82{
83 fUserSteppingAction = fManager->GetUserAction();
84
85 PhysicalStep = fManager->GetPhysicalStep();
86 GeometricalStep = fManager->GetGeometricalStep();
87 CorrectedStep = fManager->GetCorrectedStep();
88 PreStepPointIsGeom = fManager->GetPreStepPointIsGeom();
89 FirstStep = fManager->GetFirstStep();
90 fStepStatus = fManager->GetfStepStatus();
91
92 TempInitVelocity = fManager->GetTempInitVelocity();
93 TempVelocity = fManager->GetTempVelocity();
94 Mass = fManager->GetMass();
95
96 sumEnergyChange = fManager->GetsumEnergyChange();
97
98 fParticleChange = fManager->GetfParticleChange();
99 fTrack = fManager->GetfTrack();
100 fSecondary = fManager->GetfSecondary();
101 fStep = fManager->GetfStep();
102 fPreStepPoint = fManager->GetfPreStepPoint();
103 fPostStepPoint = fManager->GetfPostStepPoint();
104
105 fCurrentVolume = fManager->GetfCurrentVolume();
106 fSensitive = fManager->GetfSensitive();
107 fCurrentProcess = fManager->GetfCurrentProcess();
108
109 fAtRestDoItVector = fManager->GetfAtRestDoItVector();
110 fAlongStepDoItVector = fManager->GetfAlongStepDoItVector();
111 fPostStepDoItVector = fManager->GetfPostStepDoItVector();
112
113 fAtRestGetPhysIntVector = fManager->GetfAtRestGetPhysIntVector();
114 fAlongStepGetPhysIntVector = fManager->GetfAlongStepGetPhysIntVector();
115 fPostStepGetPhysIntVector = fManager->GetfPostStepGetPhysIntVector();
116
117 MAXofAtRestLoops = fManager->GetMAXofAtRestLoops();
118 MAXofAlongStepLoops = fManager->GetMAXofAlongStepLoops();
119 MAXofPostStepLoops = fManager->GetMAXofPostStepLoops();
120
121 fAtRestDoItProcTriggered = fManager->GetfAtRestDoItProcTriggered();
122 fAlongStepDoItProcTriggered = fManager->GetfAlongStepDoItProcTriggered();
123 fPostStepDoItProcTriggered = fManager->GetfPostStepDoItProcTriggered();
124
125 fN2ndariesAtRestDoIt = fManager->GetfN2ndariesAtRestDoIt();
126 fN2ndariesAlongStepDoIt = fManager->GetfN2ndariesAlongStepDoIt();
127 fN2ndariesPostStepDoIt = fManager->GetfN2ndariesPostStepDoIt();
128
129 fNavigator = fManager->GetfNavigator();
130
131 verboseLevel = fManager->GetverboseLevel();
132
133 fSelectedAtRestDoItVector = fManager->GetfSelectedAtRestDoItVector();
134 fSelectedAlongStepDoItVector = fManager->GetfSelectedAlongStepDoItVector();
135 fSelectedPostStepDoItVector = fManager->GetfSelectedPostStepDoItVector();
136
137 fPreviousStepSize = fManager->GetfPreviousStepSize();
138
139 fTouchableHandle = fManager->GetTouchableHandle();
140
141 StepControlFlag = fManager->GetStepControlFlag();
142
143 physIntLength = fManager->GetphysIntLength();
144 fCondition = fManager->GetfCondition();
145 fGPILSelection = fManager->GetfGPILSelection();
146}
147
149
151
153
155
156void G4VSteppingVerbose::SetSilent(G4int fSilent) { Silent = fSilent; }
157
159
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
int G4int
Definition G4Types.hh:85
static G4int GetSilentStepInfo()
static G4VSteppingVerbose * GetInstance()
static G4ThreadLocal G4VSteppingVerbose * fInstance
static void SetSilentStepInfo(G4int fSilent)
G4ProcessVector * fPostStepGetPhysIntVector
G4UserSteppingAction * fUserSteppingAction
G4ForceCondition fCondition
G4ProcessVector * fAlongStepGetPhysIntVector
G4TouchableHandle fTouchableHandle
virtual G4VSteppingVerbose * Clone()
G4GPILSelection fGPILSelection
std::size_t fAlongStepDoItProcTriggered
G4VParticleChange * fParticleChange
G4SteppingControl StepControlFlag
static void SetInstance(G4VSteppingVerbose *Instance)
G4VPhysicalVolume * fCurrentVolume
G4SelectedPostStepDoItVector * fSelectedPostStepDoItVector
static G4VSteppingVerbose * fMasterInstance
G4ProcessVector * fAtRestDoItVector
G4SelectedAtRestDoItVector * fSelectedAtRestDoItVector
G4ProcessVector * fAtRestGetPhysIntVector
G4SelectedAlongStepDoItVector * fSelectedAlongStepDoItVector
static void SetSilent(G4int fSilent)
std::size_t fAtRestDoItProcTriggered
G4VSensitiveDetector * fSensitive
G4ProcessVector * fPostStepDoItVector
G4ProcessVector * fAlongStepDoItVector
std::size_t fPostStepDoItProcTriggered
static G4TRACKING_DLL G4ThreadLocal G4int SilentStepInfo
G4SteppingManager * fManager
static G4TRACKING_DLL G4ThreadLocal G4int Silent
static G4VSteppingVerbose * GetMasterInstance()
virtual void SetManager(G4SteppingManager *const)
G4TrackVector * fSecondary
#define G4ThreadLocal
Definition tls.hh:77