BOSS 8.0.0
BESIII Offline Software System
Loading...
Searching...
No Matches
Simulation/BOOST/PhySim/include/PhySim/BesHadronPhysics.hh
Go to the documentation of this file.
1
2#ifndef BesHadronPhysics_h
3#define BesHadronPhysics_h 1
4
5#include "G4ios.hh"
6#include "globals.hh"
7#include <vector>
8
9#include "G4VPhysicsConstructor.hh"
10
11// #include "G4MultipleScattering.hh"
12#include "G4hIonisation.hh"
13
14#include "G4HadronCaptureProcess.hh"
15#include "G4HadronElasticProcess.hh"
16#include "G4HadronFissionProcess.hh"
17
18#include "G4AlphaInelasticProcess.hh"
19#include "G4AntiLambdaInelasticProcess.hh"
20#include "G4AntiNeutronInelasticProcess.hh"
21#include "G4AntiOmegaMinusInelasticProcess.hh"
22#include "G4AntiProtonInelasticProcess.hh"
23#include "G4AntiSigmaMinusInelasticProcess.hh"
24#include "G4AntiSigmaPlusInelasticProcess.hh"
25#include "G4AntiXiMinusInelasticProcess.hh"
26#include "G4AntiXiZeroInelasticProcess.hh"
27#include "G4DeuteronInelasticProcess.hh"
28#include "G4KaonMinusInelasticProcess.hh"
29#include "G4KaonPlusInelasticProcess.hh"
30#include "G4KaonZeroLInelasticProcess.hh"
31#include "G4KaonZeroSInelasticProcess.hh"
32#include "G4LambdaInelasticProcess.hh"
33#include "G4NeutronInelasticProcess.hh"
34#include "G4OmegaMinusInelasticProcess.hh"
35#include "G4PionMinusInelasticProcess.hh"
36#include "G4PionPlusInelasticProcess.hh"
37#include "G4ProtonInelasticProcess.hh"
38#include "G4SigmaMinusInelasticProcess.hh"
39#include "G4SigmaPlusInelasticProcess.hh"
40#include "G4TritonInelasticProcess.hh"
41#include "G4XiMinusInelasticProcess.hh"
42#include "G4XiZeroInelasticProcess.hh"
43
44// Low-energy Models
45// #include "G4LElastic.hh"
46// #include "G4LFission.hh"
47// #include "G4LCapture.hh"
48
49/*#include "G4LEPionPlusInelastic.hh"
50#include "G4LEAlphaInelastic.hh"
51#include "G4LEAntiLambdaInelastic.hh"
52#include "G4LEAntiNeutronInelastic.hh"
53#include "G4LEAntiOmegaMinusInelastic.hh"
54#include "G4LEAntiProtonInelastic.hh"
55#include "G4LEAntiSigmaMinusInelastic.hh"
56#include "G4LEAntiSigmaPlusInelastic.hh"
57#include "G4LEAntiXiMinusInelastic.hh"
58#include "G4LEAntiXiZeroInelastic.hh"
59#include "G4LEDeuteronInelastic.hh"
60#include "G4LEKaonMinusInelastic.hh"
61#include "G4LEKaonPlusInelastic.hh"
62#include "G4LEKaonZeroLInelastic.hh"
63#include "G4LEKaonZeroSInelastic.hh"
64#include "G4LELambdaInelastic.hh"
65#include "G4LENeutronInelastic.hh"
66#include "G4LEOmegaMinusInelastic.hh"
67#include "G4LEPionMinusInelastic.hh"
68#include "G4LEProtonInelastic.hh"
69#include "G4LESigmaMinusInelastic.hh"
70#include "G4LESigmaPlusInelastic.hh"
71#include "G4LETritonInelastic.hh"
72#include "G4LEXiMinusInelastic.hh"
73#include "G4LEXiZeroInelastic.hh"
74
75// High-energy Models
76
77#include "G4HEAntiLambdaInelastic.hh"
78#include "G4HEAntiNeutronInelastic.hh"
79#include "G4HEAntiOmegaMinusInelastic.hh"
80#include "G4HEAntiProtonInelastic.hh"
81#include "G4HEAntiSigmaMinusInelastic.hh"
82#include "G4HEAntiSigmaPlusInelastic.hh"
83#include "G4HEAntiXiMinusInelastic.hh"
84#include "G4HEAntiXiZeroInelastic.hh"
85#include "G4HEKaonMinusInelastic.hh"
86#include "G4HEKaonPlusInelastic.hh"
87#include "G4HEKaonZeroInelastic.hh"
88#include "G4HELambdaInelastic.hh"
89#include "G4HENeutronInelastic.hh"
90#include "G4HEOmegaMinusInelastic.hh"
91#include "G4HEPionMinusInelastic.hh"
92#include "G4HEPionPlusInelastic.hh"
93#include "G4HEProtonInelastic.hh"
94#include "G4HESigmaMinusInelastic.hh"
95#include "G4HESigmaPlusInelastic.hh"
96#include "G4HEXiMinusInelastic.hh"
97#include "G4HEXiZeroInelastic.hh"
98
99// Stopping processes
100#include "G4AntiNeutronAnnihilationAtRest.hh"
101#include "G4AntiProtonAnnihilationAtRest.hh"
102
103#ifdef TRIUMF_STOP_PIMINUS
104#include "G4PionMinusAbsorptionAtRest.hh"
105#else
106#include "G4PiMinusAbsorptionAtRest.hh"
107#endif
108#ifdef TRIUMF_STOP_KMINUS
109#include "G4KaonMinusAbsorption.hh"
110#else
111#include "G4KaonMinusAbsorptionAtRest.hh"
112#endif
113*/
114// quark gluon string model with chips afterburner.
115#include "G4ExcitationHandler.hh"
116#include "G4GeneratorPrecompoundInterface.hh"
117#include "G4PreCompoundModel.hh"
118#include "G4TheoFSGenerator.hh"
119/* AZ #include "G4QGSModel.hh"
120#include "G4ExcitedStringDecay.hh"
121#include "G4QGSMFragmentation.hh"
122#include "G4QGSParticipants.hh"
123*/
124class BesHadronPhysics : public G4VPhysicsConstructor {
125public:
126 BesHadronPhysics( const G4String& name = "hadron" );
128
129public:
130 // This method will be invoked in the Construct() method.
131 // each particle type will be instantiated
132 virtual void ConstructParticle();
133
134 // This method will be invoked in the Construct() method.
135 // each physics process will be instantiated and
136 // registered to the process manager of each particle type
137 virtual void ConstructProcess();
138
139protected:
140 /* // Elastic Process
141 G4HadronElasticProcess theElasticProcess;
142 G4LElastic* theElasticModel;
143
144 // Pi +
145 G4PionPlusInelasticProcess thePionPlusInelastic;
146 G4LEPionPlusInelastic* theLEPionPlusModel;
147 G4MultipleScattering thePionPlusMult;
148 G4hIonisation thePionPlusIonisation;
149
150 // Pi -
151 G4PionMinusInelasticProcess thePionMinusInelastic;
152 G4LEPionMinusInelastic* theLEPionMinusModel;
153 G4MultipleScattering thePionMinusMult;
154 G4hIonisation thePionMinusIonisation;
155 #ifdef TRIUMF_STOP_PIMINUS
156 G4PionMinusAbsorptionAtRest thePionMinusAbsorption;
157 #else
158 G4PiMinusAbsorptionAtRest thePionMinusAbsorption;
159 #endif
160 */
161 // pi+ and pi-
162
163 /* AZ G4TheoFSGenerator theTheoModel;
164 */
165 // G4ExcitationHandler theHandler;
166 // G4PreCompoundModel * thePreEquilib;
167 // G4GeneratorPrecompoundInterface theCascade;
168 /* AZ G4QGSModel< G4QGSParticipants >* theStringModel;
169 G4QGSMFragmentation theFragmentation;
170 G4ExcitedStringDecay * theStringDecay;
171 */
172 /*
173 // K +
174 G4KaonPlusInelasticProcess theKaonPlusInelastic;
175 G4LEKaonPlusInelastic* theLEKaonPlusModel;
176 G4HEKaonPlusInelastic* theHEKaonPlusModel;
177 G4MultipleScattering theKaonPlusMult;
178 G4hIonisation theKaonPlusIonisation;
179
180 // K -
181 G4KaonMinusInelasticProcess theKaonMinusInelastic;
182 G4LEKaonMinusInelastic* theLEKaonMinusModel;
183 G4HEKaonMinusInelastic* theHEKaonMinusModel;
184 G4MultipleScattering theKaonMinusMult;
185 G4hIonisation theKaonMinusIonisation;
186#ifdef TRIUMF_STOP_KMINUS
187 G4KaonMinusAbsorption theKaonMinusAbsorption;
188#else
189 G4PiMinusAbsorptionAtRest theKaonMinusAbsorption;
190#endif
191
192 // K0L
193 G4KaonZeroLInelasticProcess theKaonZeroLInelastic;
194 G4LEKaonZeroLInelastic* theLEKaonZeroLModel;
195 G4HEKaonZeroInelastic* theHEKaonZeroLModel;
196// K0Regeneration theK0LRegeneration;
197
198 // K0S
199 G4KaonZeroSInelasticProcess theKaonZeroSInelastic;
200 G4LEKaonZeroSInelastic* theLEKaonZeroSModel;
201 G4HEKaonZeroInelastic* theHEKaonZeroSModel;
202
203 // Proton
204 G4ProtonInelasticProcess theProtonInelastic;
205 G4LEProtonInelastic* theLEProtonModel;
206 G4HEProtonInelastic* theHEProtonModel;
207 G4MultipleScattering theProtonMult;
208 G4hIonisation theProtonIonisation;
209
210 // anti-proton
211 G4AntiProtonInelasticProcess theAntiProtonInelastic;
212 G4LEAntiProtonInelastic* theLEAntiProtonModel;
213 G4HEAntiProtonInelastic* theHEAntiProtonModel;
214 G4MultipleScattering theAntiProtonMult;
215 G4hIonisation theAntiProtonIonisation;
216 G4AntiProtonAnnihilationAtRest theAntiProtonAnnihilation;
217
218 // neutron
219 G4NeutronInelasticProcess theNeutronInelastic;
220 G4LENeutronInelastic* theLENeutronModel;
221 G4HENeutronInelastic* theHENeutronModel;
222 G4HadronFissionProcess theNeutronFission;
223 G4LFission* theNeutronFissionModel;
224 G4HadronCaptureProcess theNeutronCapture;
225 G4LCapture* theNeutronCaptureModel;
226
227
228 // anti-neutron
229 G4AntiNeutronInelasticProcess theAntiNeutronInelastic;
230 G4LEAntiNeutronInelastic* theLEAntiNeutronModel;
231 G4HEAntiNeutronInelastic* theHEAntiNeutronModel;
232 G4AntiNeutronAnnihilationAtRest theAntiNeutronAnnihilation;
233
234 // Lambda
235 G4LambdaInelasticProcess theLambdaInelastic;
236 G4LELambdaInelastic* theLELambdaModel;
237 G4HELambdaInelastic* theHELambdaModel;
238
239 // AntiLambda
240 G4AntiLambdaInelasticProcess theAntiLambdaInelastic;
241 G4LEAntiLambdaInelastic* theLEAntiLambdaModel;
242 G4HEAntiLambdaInelastic* theHEAntiLambdaModel;
243
244 // SigmaMinus
245 G4SigmaMinusInelasticProcess theSigmaMinusInelastic;
246 G4LESigmaMinusInelastic* theLESigmaMinusModel;
247 G4HESigmaMinusInelastic* theHESigmaMinusModel;
248 G4MultipleScattering theSigmaMinusMult;
249 G4hIonisation theSigmaMinusIonisation;
250
251 // AntiSigmaMinus
252 G4AntiSigmaMinusInelasticProcess theAntiSigmaMinusInelastic;
253 G4LEAntiSigmaMinusInelastic* theLEAntiSigmaMinusModel;
254 G4HEAntiSigmaMinusInelastic* theHEAntiSigmaMinusModel;
255 G4MultipleScattering theAntiSigmaMinusMult;
256 G4hIonisation theAntiSigmaMinusIonisation;
257
258 // SigmaPlus
259 G4SigmaPlusInelasticProcess theSigmaPlusInelastic;
260 G4LESigmaPlusInelastic* theLESigmaPlusModel;
261 G4HESigmaPlusInelastic* theHESigmaPlusModel;
262 G4MultipleScattering theSigmaPlusMult;
263 G4hIonisation theSigmaPlusIonisation;
264
265 // AntiSigmaPlus
266 G4AntiSigmaPlusInelasticProcess theAntiSigmaPlusInelastic;
267 G4LEAntiSigmaPlusInelastic* theLEAntiSigmaPlusModel;
268 G4HEAntiSigmaPlusInelastic* theHEAntiSigmaPlusModel;
269 G4MultipleScattering theAntiSigmaPlusMult;
270 G4hIonisation theAntiSigmaPlusIonisation;
271
272 // XiZero
273 G4XiZeroInelasticProcess theXiZeroInelastic;
274 G4LEXiZeroInelastic* theLEXiZeroModel;
275 G4HEXiZeroInelastic* theHEXiZeroModel;
276
277 // AntiXiZero
278 G4AntiXiZeroInelasticProcess theAntiXiZeroInelastic;
279 G4LEAntiXiZeroInelastic* theLEAntiXiZeroModel;
280 G4HEAntiXiZeroInelastic* theHEAntiXiZeroModel;
281
282 // XiMinus
283 G4XiMinusInelasticProcess theXiMinusInelastic;
284 G4LEXiMinusInelastic* theLEXiMinusModel;
285 G4HEXiMinusInelastic* theHEXiMinusModel;
286 G4MultipleScattering theXiMinusMult;
287 G4hIonisation theXiMinusIonisation;
288
289 // AntiXiMinus
290 G4AntiXiMinusInelasticProcess theAntiXiMinusInelastic;
291 G4LEAntiXiMinusInelastic* theLEAntiXiMinusModel;
292 G4HEAntiXiMinusInelastic* theHEAntiXiMinusModel;
293 G4MultipleScattering theAntiXiMinusMult;
294 G4hIonisation theAntiXiMinusIonisation;
295
296 // OmegaMinus
297 G4OmegaMinusInelasticProcess theOmegaMinusInelastic;
298 G4LEOmegaMinusInelastic* theLEOmegaMinusModel;
299 G4HEOmegaMinusInelastic* theHEOmegaMinusModel;
300 G4MultipleScattering theOmegaMinusMult;
301 G4hIonisation theOmegaMinusIonisation;
302
303 // AntiOmegaMinus
304 G4AntiOmegaMinusInelasticProcess theAntiOmegaMinusInelastic;
305 G4LEAntiOmegaMinusInelastic* theLEAntiOmegaMinusModel;
306 G4HEAntiOmegaMinusInelastic* theHEAntiOmegaMinusModel;
307 G4MultipleScattering theAntiOmegaMinusMult;
308 G4hIonisation theAntiOmegaMinusIonisation;
309
310 */
311};
312
313#endif
virtual void ConstructProcess()
virtual void ConstructParticle()
virtual ~BesHadronPhysics()
BesHadronPhysics(const G4String &name="hadron")