Geant4.10
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Member Functions
RE05SteppingVerbose Class Reference

#include <RE05SteppingVerbose.hh>

Inheritance diagram for RE05SteppingVerbose:
G4SteppingVerbose G4VSteppingVerbose

Public Member Functions

 RE05SteppingVerbose ()
 
 ~RE05SteppingVerbose ()
 
void StepInfo ()
 
void TrackingStarted ()
 
- Public Member Functions inherited from G4SteppingVerbose
 G4SteppingVerbose ()
 
 ~G4SteppingVerbose ()
 
void NewStep ()
 
void AtRestDoItInvoked ()
 
void AlongStepDoItAllDone ()
 
void PostStepDoItAllDone ()
 
void AlongStepDoItOneByOne ()
 
void PostStepDoItOneByOne ()
 
void StepInfo ()
 
void TrackingStarted ()
 
void DPSLStarted ()
 
void DPSLUserLimit ()
 
void DPSLPostStep ()
 
void DPSLAlongStep ()
 
void VerboseTrack ()
 
void VerboseParticleChange ()
 
void ShowStep () const
 
- Public Member Functions inherited from G4VSteppingVerbose
virtual ~G4VSteppingVerbose ()
 
void CopyState ()
 
void SetManager (G4SteppingManager *const)
 

Additional Inherited Members

- Static Public Member Functions inherited from G4VSteppingVerbose
static void SetInstance (G4VSteppingVerbose *Instance)
 
static G4VSteppingVerboseGetInstance ()
 
static G4int GetSilent ()
 
static void SetSilent (G4int fSilent)
 
static G4int GetSilentStepInfo ()
 
static void SetSilentStepInfo (G4int fSilent)
 
- Protected Types inherited from G4VSteppingVerbose
typedef std::vector< G4intG4SelectedAtRestDoItVector
 
typedef std::vector< G4intG4SelectedAlongStepDoItVector
 
typedef std::vector< G4intG4SelectedPostStepDoItVector
 
- Protected Member Functions inherited from G4VSteppingVerbose
 G4VSteppingVerbose ()
 
- Protected Attributes inherited from G4VSteppingVerbose
G4SteppingManagerfManager
 
G4UserSteppingActionfUserSteppingAction
 
G4double PhysicalStep
 
G4double GeometricalStep
 
G4double CorrectedStep
 
G4bool PreStepPointIsGeom
 
G4bool FirstStep
 
G4StepStatus fStepStatus
 
G4double TempInitVelocity
 
G4double TempVelocity
 
G4double Mass
 
G4double sumEnergyChange
 
G4VParticleChangefParticleChange
 
G4TrackfTrack
 
G4TrackVectorfSecondary
 
G4StepfStep
 
G4StepPointfPreStepPoint
 
G4StepPointfPostStepPoint
 
G4VPhysicalVolumefCurrentVolume
 
G4VSensitiveDetectorfSensitive
 
G4VProcessfCurrentProcess
 
G4ProcessVectorfAtRestDoItVector
 
G4ProcessVectorfAlongStepDoItVector
 
G4ProcessVectorfPostStepDoItVector
 
G4ProcessVectorfAtRestGetPhysIntVector
 
G4ProcessVectorfAlongStepGetPhysIntVector
 
G4ProcessVectorfPostStepGetPhysIntVector
 
size_t MAXofAtRestLoops
 
size_t MAXofAlongStepLoops
 
size_t MAXofPostStepLoops
 
G4double currentMinimumStep
 
G4double numberOfInteractionLengthLeft
 
size_t fAtRestDoItProcTriggered
 
size_t fAlongStepDoItProcTriggered
 
size_t fPostStepDoItProcTriggered
 
G4int fN2ndariesAtRestDoIt
 
G4int fN2ndariesAlongStepDoIt
 
G4int fN2ndariesPostStepDoIt
 
G4NavigatorfNavigator
 
G4int verboseLevel
 
G4SelectedAtRestDoItVectorfSelectedAtRestDoItVector
 
G4SelectedAlongStepDoItVectorfSelectedAlongStepDoItVector
 
G4SelectedPostStepDoItVectorfSelectedPostStepDoItVector
 
G4double fPreviousStepSize
 
G4TouchableHandle fTouchableHandle
 
G4SteppingControl StepControlFlag
 
G4double physIntLength
 
G4ForceCondition fCondition
 
G4GPILSelection fGPILSelection
 
- Static Protected Attributes inherited from G4VSteppingVerbose
static G4ThreadLocal
G4VSteppingVerbose
fInstance = 0
 
static G4ThreadLocal G4int Silent = 0
 
static G4ThreadLocal G4int SilentStepInfo = 0
 

Detailed Description

This class manages the verbose outputs in G4SteppingManager. It inherits from G4SteppingVerbose. It shows how to extract informations during the tracking of a particle.

Definition at line 48 of file RE05SteppingVerbose.hh.

Constructor & Destructor Documentation

RE05SteppingVerbose::RE05SteppingVerbose ( )

Definition at line 42 of file RE05SteppingVerbose.cc.

43 {}
RE05SteppingVerbose::~RE05SteppingVerbose ( )

Definition at line 47 of file RE05SteppingVerbose.cc.

48 {}

Member Function Documentation

void RE05SteppingVerbose::StepInfo ( )
virtual

Implements G4VSteppingVerbose.

Definition at line 52 of file RE05SteppingVerbose.cc.

References G4VSteppingVerbose::CopyState(), G4VSteppingVerbose::fN2ndariesAlongStepDoIt, G4VSteppingVerbose::fN2ndariesAtRestDoIt, G4VSteppingVerbose::fN2ndariesPostStepDoIt, G4VSteppingVerbose::fSecondary, G4VSteppingVerbose::fStep, G4VSteppingVerbose::fTrack, G4BestUnit, G4cout, G4endl, G4Track::GetCurrentStepNumber(), G4Track::GetKineticEnergy(), G4VPhysicalVolume::GetName(), G4Track::GetNextVolume(), G4Track::GetPosition(), G4Step::GetPostStepPoint(), G4StepPoint::GetProcessDefinedStep(), G4VProcess::GetProcessName(), G4Step::GetStepLength(), G4Step::GetTotalEnergyDeposit(), G4Track::GetTrackLength(), G4Track::GetVolume(), G4VSteppingVerbose::verboseLevel, G4SteppingVerbose::VerboseTrack(), test::x, CLHEP::Hep3Vector::x(), CLHEP::Hep3Vector::y(), z, and CLHEP::Hep3Vector::z().

53 {
54  CopyState();
55 
56  G4int prec = G4cout.precision(3);
57 
58  if( verboseLevel >= 1 ){
59  if( verboseLevel >= 4 ) VerboseTrack();
60  if( verboseLevel >= 3 ){
61  G4cout << G4endl;
62  G4cout << std::setw( 5) << "#Step#" << " "
63  << std::setw( 6) << "X" << " "
64  << std::setw( 6) << "Y" << " "
65  << std::setw( 6) << "Z" << " "
66  << std::setw( 9) << "KineE" << " "
67  << std::setw( 9) << "dEStep" << " "
68  << std::setw(10) << "StepLeng"
69  << std::setw(10) << "TrakLeng"
70  << std::setw(10) << "Volume" << " "
71  << std::setw(10) << "Process" << G4endl;
72  }
73 
74  G4cout << std::setw(5) << fTrack->GetCurrentStepNumber() << " "
75  << std::setw(6) << G4BestUnit(fTrack->GetPosition().x(),"Length")
76  << std::setw(6) << G4BestUnit(fTrack->GetPosition().y(),"Length")
77  << std::setw(6) << G4BestUnit(fTrack->GetPosition().z(),"Length")
78  << std::setw(6) << G4BestUnit(fTrack->GetKineticEnergy(),"Energy")
79  << std::setw(6) << G4BestUnit(fStep->GetTotalEnergyDeposit(),"Energy")
80  << std::setw(6) << G4BestUnit(fStep->GetStepLength(),"Length")
81  << std::setw(6) << G4BestUnit(fTrack->GetTrackLength(),"Length")
82  << " ";
83 
84  // if( fStepStatus != fWorldBoundary){
85  if( fTrack->GetNextVolume() != 0 ) {
86  G4cout << std::setw(10) << fTrack->GetVolume()->GetName();
87  } else {
88  G4cout << std::setw(10) << "OutOfWorld";
89  }
90 
92  G4cout << " "
93  << std::setw(10) << fStep->GetPostStepPoint()->GetProcessDefinedStep()
94  ->GetProcessName();
95  } else {
96  G4cout << " UserLimit";
97  }
98 
99  G4cout << G4endl;
100 
101  if( verboseLevel == 2 ){
102  G4int tN2ndariesTot = fN2ndariesAtRestDoIt +
105  if(tN2ndariesTot>0){
106  G4cout << " :----- List of 2ndaries - "
107  << "#SpawnInStep=" << std::setw(3) << tN2ndariesTot
108  << "(Rest=" << std::setw(2) << fN2ndariesAtRestDoIt
109  << ",Along=" << std::setw(2) << fN2ndariesAlongStepDoIt
110  << ",Post=" << std::setw(2) << fN2ndariesPostStepDoIt
111  << "), "
112  << "#SpawnTotal=" << std::setw(3) << (*fSecondary).size()
113  << " ---------------"
114  << G4endl;
115 
116  for(size_t lp1=(*fSecondary).size()-tN2ndariesTot;
117  lp1<(*fSecondary).size(); lp1++){
118  G4cout << " : "
119  << std::setw(6)
120  << G4BestUnit((*fSecondary)[lp1]->GetPosition().x(),"Length")
121  << std::setw(6)
122  << G4BestUnit((*fSecondary)[lp1]->GetPosition().y(),"Length")
123  << std::setw(6)
124  << G4BestUnit((*fSecondary)[lp1]->GetPosition().z(),"Length")
125  << std::setw(6)
126  << G4BestUnit((*fSecondary)[lp1]->GetKineticEnergy(),"Energy")
127  << std::setw(10)
128  << (*fSecondary)[lp1]->GetDefinition()->GetParticleName();
129  G4cout << G4endl;
130  }
131 
132  G4cout << " :-----------------------------"
133  << "----------------------------------"
134  << "-- EndOf2ndaries Info ---------------"
135  << G4endl;
136  }
137  }
138 
139  }
140  G4cout.precision(prec);
141 }
G4double GetStepLength() const
double x() const
G4double z
Definition: TRTMaterials.hh:39
const G4ThreeVector & GetPosition() const
#define G4BestUnit(a, b)
#define G4_USE_G4BESTUNIT_FOR_VERBOSE 1
int G4int
Definition: G4Types.hh:78
double z() const
G4VPhysicalVolume * GetNextVolume() const
G4double GetKineticEnergy() const
G4GLOB_DLL std::ostream G4cout
G4int GetCurrentStepNumber() const
G4TrackVector * fSecondary
const G4String & GetName() const
const G4String & GetProcessName() const
Definition: G4VProcess.hh:408
G4double GetTotalEnergyDeposit() const
G4double GetTrackLength() const
const G4VProcess * GetProcessDefinedStep() const
G4StepPoint * GetPostStepPoint() const
double y() const
G4VPhysicalVolume * GetVolume() const
#define G4endl
Definition: G4ios.hh:61
void RE05SteppingVerbose::TrackingStarted ( )
virtual

Implements G4VSteppingVerbose.

Definition at line 145 of file RE05SteppingVerbose.cc.

References G4VSteppingVerbose::CopyState(), G4VSteppingVerbose::fStep, G4VSteppingVerbose::fTrack, G4BestUnit, G4cout, G4endl, G4Track::GetCurrentStepNumber(), G4Track::GetKineticEnergy(), G4VPhysicalVolume::GetName(), G4Track::GetNextVolume(), G4Track::GetPosition(), G4Step::GetStepLength(), G4Step::GetTotalEnergyDeposit(), G4Track::GetTrackLength(), G4Track::GetVolume(), G4VSteppingVerbose::verboseLevel, CLHEP::Hep3Vector::x(), CLHEP::Hep3Vector::y(), and CLHEP::Hep3Vector::z().

146 {
147 
148  CopyState();
149 G4int prec = G4cout.precision(3);
150  if( verboseLevel > 0 ){
151 
152  G4cout << std::setw( 5) << "Step#" << " "
153  << std::setw( 6) << "X" << " "
154  << std::setw( 6) << "Y" << " "
155  << std::setw( 6) << "Z" << " "
156  << std::setw( 9) << "KineE" << " "
157  << std::setw( 9) << "dEStep" << " "
158  << std::setw(10) << "StepLeng"
159  << std::setw(10) << "TrakLeng"
160  << std::setw(10) << "Volume" << " "
161  << std::setw(10) << "Process" << G4endl;
162 
163  G4cout << std::setw(5) << fTrack->GetCurrentStepNumber() << " "
164  << std::setw(6) << G4BestUnit(fTrack->GetPosition().x(),"Length")
165  << std::setw(6) << G4BestUnit(fTrack->GetPosition().y(),"Length")
166  << std::setw(6) << G4BestUnit(fTrack->GetPosition().z(),"Length")
167  << std::setw(6) << G4BestUnit(fTrack->GetKineticEnergy(),"Energy")
168  << std::setw(6) << G4BestUnit(fStep->GetTotalEnergyDeposit(),"Energy")
169  << std::setw(6) << G4BestUnit(fStep->GetStepLength(),"Length")
170  << std::setw(6) << G4BestUnit(fTrack->GetTrackLength(),"Length")
171  << " ";
172 
173  if(fTrack->GetNextVolume()){
174  G4cout << std::setw(10) << fTrack->GetVolume()->GetName();
175  } else {
176  G4cout << std::setw(10) << "OutOfWorld";
177  }
178  G4cout << " initStep" << G4endl;
179  }
180  G4cout.precision(prec);
181 }
G4double GetStepLength() const
double x() const
const G4ThreeVector & GetPosition() const
#define G4BestUnit(a, b)
#define G4_USE_G4BESTUNIT_FOR_VERBOSE 1
int G4int
Definition: G4Types.hh:78
double z() const
G4VPhysicalVolume * GetNextVolume() const
G4double GetKineticEnergy() const
G4GLOB_DLL std::ostream G4cout
G4int GetCurrentStepNumber() const
const G4String & GetName() const
G4double GetTotalEnergyDeposit() const
G4double GetTrackLength() const
double y() const
G4VPhysicalVolume * GetVolume() const
#define G4endl
Definition: G4ios.hh:61

The documentation for this class was generated from the following files: