Loading...
Searching...
No Matches
TSPhysicsList.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/// \file parallel/ThreadsafeScorers/src/TSPhysicsList.cc
27/// \brief Implementation of the TSPhysicsList class
28//
29//
30//
31//
32/// This is a very, very extensive physics list and step-limiters are applied
33/// to many particles. The reasoning behind this is because we wan't to put
34/// as much pressure on the atomics as possible and produce as much
35/// round-off error as possible. See descriptions in README and
36/// TSDetectorConstruction for more details.
37//
38//
39//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
40//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
41
42#include "TSPhysicsList.hh"
43
44#include "G4RunManager.hh"
45#include "G4ParticleDefinition.hh"
46#include "G4ProcessManager.hh"
47#include "G4ParticleTypes.hh"
48
49// Hadrons
50#include "G4BaryonConstructor.hh"
51#include "G4IonConstructor.hh"
52#include "G4MesonConstructor.hh"
53
54// Bosons
55#include "G4BosonConstructor.hh"
56
57// Leptons
58#include "G4LeptonConstructor.hh"
59
60// Other Particles
61#include "G4ShortLivedConstructor.hh"
62
63// Process options
64#include "G4LossTableManager.hh"
65
66// Physics List Helper
67#include "G4PhysicsListHelper.hh"
68
69#include "G4StepLimiter.hh"
70
71// Constructors
72#include "G4EmStandardPhysics_option3.hh"
73#include "G4EmStandardPhysics_option4.hh"
74#include "G4RadioactiveDecayPhysics.hh"
75#include "G4HadronPhysicsQGSP_BERT.hh"
76#include "G4HadronPhysicsQGSP_BERT_HP.hh"
77#include "G4HadronElasticPhysics.hh"
78#include "G4HadronElasticPhysicsHP.hh"
79#include "G4IonElasticPhysics.hh"
80#include "G4IonBinaryCascadePhysics.hh"
81#include "G4DecayPhysics.hh"
82
83#include <set>
84
85//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
86
88{
89 defaultCutValue = 1. * CLHEP::mm;
90
92 fConstructors.push_back(new G4DecayPhysics);
98}
99
100//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
101
103{
104 for(auto ite : fConstructors)
105 delete ite;
106}
107
108//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
109
111{
112 for(auto c : fConstructors)
113 {
114 c->ConstructParticle();
115 }
116}
117
118//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
119
121{
122 // Transportation
123 //
124 AddTransportation();
125
126 for(auto c : fConstructors)
127 {
128 c->ConstructProcess();
129 }
130
131 std::set<G4String> step_limit_particles;
132 // standard particles
133 step_limit_particles.insert("e-");
134 step_limit_particles.insert("e+");
135 step_limit_particles.insert("alpha");
136 step_limit_particles.insert("He3");
137 step_limit_particles.insert("GenericIon");
138 step_limit_particles.insert("proton");
139 step_limit_particles.insert("neutron");
140 // more ~exotic particles
141 step_limit_particles.insert("pi+");
142 step_limit_particles.insert("pi-");
143 step_limit_particles.insert("mu+");
144 step_limit_particles.insert("mu-");
145
146 auto particleIterator = GetParticleIterator();
147 particleIterator->reset();
148
149 G4PhysicsListHelper* ph = G4PhysicsListHelper::GetPhysicsListHelper();
150
151 while((*particleIterator)())
152 {
153 G4ParticleDefinition* particle = particleIterator->value();
154 G4String pname = particle->GetParticleName();
155
156 if(step_limit_particles.find(pname) != step_limit_particles.end() ||
157 particle->GetPDGCharge())
158 {
159 ph->RegisterProcess(new G4StepLimiter, particle);
160 }
161 }
162}
163
164//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
Definition of the TSPhysicsList class.
PhysicsSet_t fConstructors
virtual ~TSPhysicsList()
TSPhysicsList()
This is a very, very extensive physics list and step-limiters are applied to many particles.
void ConstructParticle() override
void ConstructProcess() override

Applications | User Support | Publications | Collaboration