| 1 |
pamelats |
1.1 |
#include "PamG4RangeCutsPhysicsList.h" |
| 2 |
|
|
#include "PamG4RangeCutsPhysics.h" |
| 3 |
|
|
|
| 4 |
|
|
#include <TG4Globals.h> |
| 5 |
|
|
#include <TG4G3PhysicsManager.h> |
| 6 |
|
|
|
| 7 |
|
|
#include <G4ParticleDefinition.hh> |
| 8 |
|
|
#include <G4ProcessManager.hh> |
| 9 |
|
|
#include <G4ProcessTable.hh> |
| 10 |
|
|
|
| 11 |
|
|
|
| 12 |
|
|
PamG4RangeCutsPhysicsList* PamG4RangeCutsPhysicsList::fgInstance = 0; |
| 13 |
|
|
|
| 14 |
|
|
|
| 15 |
|
|
|
| 16 |
|
|
PamG4RangeCutsPhysicsList::PamG4RangeCutsPhysicsList() |
| 17 |
|
|
: G4VModularPhysicsList(), |
| 18 |
|
|
TG4Verbose("RangeCutsPhysicsList") |
| 19 |
|
|
{ |
| 20 |
|
|
/// Default constructor |
| 21 |
|
|
|
| 22 |
|
|
SetVerboseLevel(TG4VVerbose::VerboseLevel()); |
| 23 |
|
|
|
| 24 |
|
|
Configure(); |
| 25 |
|
|
} |
| 26 |
|
|
|
| 27 |
|
|
PamG4RangeCutsPhysicsList::~PamG4RangeCutsPhysicsList() |
| 28 |
|
|
{ |
| 29 |
|
|
/// Destructor |
| 30 |
|
|
fgInstance = 0; |
| 31 |
|
|
} |
| 32 |
|
|
|
| 33 |
|
|
|
| 34 |
|
|
void PamG4RangeCutsPhysicsList::Configure() |
| 35 |
|
|
{ |
| 36 |
|
|
/// Create the selected physics constructors |
| 37 |
|
|
/// and registeres them in the modular physics list. |
| 38 |
|
|
|
| 39 |
|
|
Int_t verboseLevel = TG4VVerbose::VerboseLevel(); |
| 40 |
|
|
|
| 41 |
|
|
RegisterPhysics(new PamG4RangeCutsPhysics(verboseLevel)); |
| 42 |
|
|
|
| 43 |
|
|
} |
| 44 |
|
|
|
| 45 |
|
|
|
| 46 |
|
|
void PamG4RangeCutsPhysicsList::ConstructProcess() |
| 47 |
|
|
{ |
| 48 |
|
|
/// Construct all processes. |
| 49 |
|
|
|
| 50 |
|
|
// lock physics manager |
| 51 |
|
|
TG4G3PhysicsManager* g3PhysicsManager = TG4G3PhysicsManager::Instance(); |
| 52 |
|
|
g3PhysicsManager->Lock(); |
| 53 |
|
|
|
| 54 |
|
|
// create processes for registered physics |
| 55 |
|
|
// To avoid call AddTransportation twice we do not call directly |
| 56 |
|
|
// G4VModularPhysicsList::ConstructProcess(); |
| 57 |
|
|
// but call registered processes ourselves: |
| 58 |
|
|
G4PhysConstVector::iterator itr; |
| 59 |
|
|
for (itr = physicsVector->begin(); itr!= physicsVector->end(); ++itr) { |
| 60 |
|
|
(*itr)->ConstructProcess(); |
| 61 |
|
|
} |
| 62 |
|
|
} |
| 63 |
|
|
|
| 64 |
|
|
G4int PamG4RangeCutsPhysicsList::VerboseLevel() const |
| 65 |
|
|
{ |
| 66 |
|
|
/// Return verbose level (via TG4VVerbose) |
| 67 |
|
|
|
| 68 |
|
|
return TG4VVerbose::VerboseLevel(); |
| 69 |
|
|
} |
| 70 |
|
|
|
| 71 |
|
|
void PamG4RangeCutsPhysicsList::VerboseLevel(G4int level) |
| 72 |
|
|
{ |
| 73 |
|
|
/// Set the specified level to both TG4Verbose and |
| 74 |
|
|
/// G4VModularPhysicsList. |
| 75 |
|
|
/// The verbose level is also propagated to registered physics contructors. |
| 76 |
|
|
|
| 77 |
|
|
TG4VVerbose::VerboseLevel(level); |
| 78 |
|
|
SetVerboseLevel(level); |
| 79 |
|
|
|
| 80 |
|
|
G4PhysConstVector::iterator it; |
| 81 |
|
|
for ( it = physicsVector->begin(); it != physicsVector->end(); ++it ) { |
| 82 |
|
|
TG4Verbose* verbose = dynamic_cast<TG4Verbose*>(*it); |
| 83 |
|
|
if ( verbose ) |
| 84 |
|
|
verbose->VerboseLevel(level); |
| 85 |
|
|
else |
| 86 |
|
|
(*it)->SetVerboseLevel(level); |
| 87 |
|
|
} |
| 88 |
|
|
} |
| 89 |
|
|
|
| 90 |
|
|
|
| 91 |
|
|
|