Geant4 10.7.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4VUserPhysicsList.hh
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//
27//
28//
29// ------------------------------------------------------------
30// GEANT 4 class header file
31// Class Description:
32// This class is an abstract class for
33// constructing particles and processes.
34// User must implement following three virtual methods
35// in his/her own concrete class derived from this class.
36// G4VUserPhysicsList::ConstructParticle()
37// Construct particles
38// G4VUserPhysicsList::ConstructProcess()
39// Construct procesess and register them to particles
40//
41// -------------------------------------------
42// History
43// first version 09 Jan. 1998 by H.Kurashige
44// modified 24 Jan. 1998 by H.Kurashige
45// rename DumpCutValues/DumpCutValuesTable
46// change SetCuts method
47// add SetCutsWithDefault method
48// modified 06 June 1998 by H.Kurashige
49// add AddProcessManager
50// add BuildPhysicsTable
51// modified 29 June 1998 by H.Kurashige
52// add AddProcessManager
53// modified 05 Dec. 1998 by H.Kurashige
54// add ConstructAllParticles()
55// modified 14, Apr 1999 by H.Kurashige
56// change BuildPhysicsTable as public
57// removed ConstructAllParticles() and related methods
58// changed SetCuts method argument
59// modified 08, Nov 2000 by H.Kurashige
60// added Retrieve/StorePhysicsTable and related methods
61// modified 08, Mar 2001 by H.Kurashige
62// added binary mode for Retrieve/StorePhysicsTable
63// added RetrieveCutValues and related
64// added Set/ResetStoredInAscii() to switch on ascii mode
65// for Retrieve/StorePhysicsTable
66// modified for CUTS per REGION 10, Oct 2002 by H.Kurashige
67// removed following methods
68// void ReCalcCutValue()
69// void SetCutValueForOthers()
70// void SetCutValueForOtherThan()
71// void ReCalcCutValueForOthers()
72// virtual G4bool StoreMaterialInfo()
73// virtual G4bool StoreCutValues()
74// virtual G4bool RetrieveCutValues()
75// virtual G4bool CheckForRetrievePhysicsTable()
76// virtual G4bool CheckMaterialInfo()
77// added void BuildPhysicsTable()
78// Added PhysicsListHelper 29 Apr. 2011 H.Kurashige
79// Added default impelmentation of SetCuts 10 June 2011 H.Kurashige
80// SetCuts is not 'pure virtual' any more
81// Trasnformations for multi-threading 26 Mar. 2013 A. Dotti
82// Added destructions 21 Apr 2017 A. Dotti
83// ------------------------------------------------------------
84#ifndef G4VUserPhysicsList_h
85#define G4VUserPhysicsList_h 1
86
87#include "G4ios.hh"
88#include "globals.hh"
89#include "rundefs.hh"
90#include "tls.hh"
91
93#include "G4ParticleTable.hh"
95#include "G4VUPLSplitter.hh"
96
97#include "G4Threading.hh"
98
101class G4VProcess;
102
104{
105 // Encapsulate the fields of class G4VUserPhysicsList
106 // that are per-thread.
107 public:
108 void initialize();
114};
115// The type G4VUPLManager is introduced to encapsulate the methods used by
116// both the master thread and worker threads to allocate memory space for
117// the fields encapsulated by the class G4VUPLData. When each thread
118// changes the value for these fields, it refers to them using a macro
119// definition defined below. For every G4VUserPhysicsList instance,
120// there is a corresponding G4VUPLData instance. All G4VUPLData instances
121// are organized by the class G4VUPLManager as an array.
122// The field "int g4vuplInstanceID" is added to the class G4VUserPhysicsList.
123// The value of this field in each G4VUserPhysicsList instance is the
124// subscript of the corresponding G44VUPLData instance.
125// In order to use the class G44VUPLManager, we add a static member in the class
126// G4VUserPhysicsList as follows: "static G4VUPLManager subInstanceManager".
127// Both the master thread and worker threads change the length of the array
128// for G44VUPLData instances mutually along with G4VUserPhysicsList
129// instances are created. For each worker thread, it dynamically creates ions.
130// Consider any thread A, if there is any other thread which creates an ion.
131// This ion is shared by the thread A. So the thread A leaves an empty space
132// in the array of G4PDefData instances for the ion.
133//
134// Important Note: you may wonder why we are introducing this mechanism
135// since there is only one PL for each application.
136// This is true, in the sense that only one PL is allowed
137// to be associated to a G4RunManager, however user can
138// instantiate as many PLs are needed and at run-time select one
139// of the PLs to be used we thus need this mechanism to
140// guarantee that the system works without problems in case of
141// this (unusual) case. This may be reviewed in the future
144
145// This macros change the references to fields that are now encapsulated
146// in the class G4VUPLData.
147//
148// Note1: the use of this-> this is needed to avoid compilation errors
149// when using templated class with T=G4VUserPhysicsList. Don't know why.
150// Note2: the name of the first #define is different, because otherwise
151// we need to change its use in all classes that inherits from
152// this base class (all examples). However one should note comment
153// on JIRA task: http://jira-geant4.kek.jp/browse/DEV-27
154//#define theParticleIterator
155//((this->subInstanceManager.offset[this->g4vuplInstanceID])._theParticleIterator)
156
158{
159 public:
161 virtual ~G4VUserPhysicsList();
162
163 // copy constructor and assignment operator
166
167 public: // with description
168 // Each particle type will be instantiated
169 // This method is invoked by the RunManger
170 virtual void ConstructParticle() = 0;
171
172 // By calling the "Construct" method,
173 // process manager and processes are created.
174 void Construct();
175
176 // Each physics process will be instantiated and
177 // registered to the process manager of each particle type
178 // This method is invoked in Construct method
179 virtual void ConstructProcess() = 0;
180
181 protected: // with description
182 // User must invoke this method in his ConstructProcess()
183 // implementation in order to insures particle transportation.
184 void AddTransportation();
185
186 // Register a process to the particle type
187 // according to the ordering parameter table
188 // 'true' is returned if the process is registerd successfully
190
191 public:
192 void UseCoupledTransportation(G4bool vl = true);
193
194 /////////////////////////////////////////////////////////////////
195 public: // with description
196 // "SetCuts" method sets a cut value for all particle types
197 // in the particle table
198 virtual void SetCuts();
199
200 public: // with description
201 // set/get the default cut value
202 // Calling SetDefaultCutValue causes re-calcuration of cut values
203 // and physics tables just before the next event loop
204 void SetDefaultCutValue(G4double newCutValue);
206
207 /////////////////////////////////////////////////////////////////////
208 public: // with description
209 // Invoke BuildPhysicsTable for all processes for all particles
210 // In case of "Retrieve" flag is ON, PhysicsTable will be
211 // retrieved from files
212 void BuildPhysicsTable();
213
214 // do PreparePhysicsTable for specified particle type
216
217 // do BuildPhysicsTable for specified particle type
219
220 // Store PhysicsTable together with both material and cut value
221 // information in files under the specified directory.
222 // (return true if files are successfully created)
223 G4bool StorePhysicsTable(const G4String& directory = ".");
224
225 // Return true if "Retrieve" flag is ON.
226 // (i.e. PhysicsTable will be retrieved from files)
228 G4bool IsStoredInAscii() const;
229
230 // Get directory path for physics table files.
231 const G4String& GetPhysicsTableDirectory() const;
232
233 // Set "Retrieve" flag
234 // Directory path can be set together.
235 // Null string (default) means directory is not changed
236 // from the current value
237 void SetPhysicsTableRetrieved(const G4String& directory = "");
238 void SetStoredInAscii();
239
240 // Reset "Retrieve" flag
242 void ResetStoredInAscii();
243
244 ///////////////////////////////////////////////////////////////////////
245 public: // with description
246 // Print out the List of registered particles types
247 void DumpList() const;
248
249 public: // with description
250 // Request to print out information of cut values
251 // Printing will be performed when all tables are made
252 void DumpCutValuesTable(G4int flag = 1);
253
254 // The following method actually trigger the print-out requested
255 // by the above method. This method must be invoked by RunManager
256 // at the proper moment.
258
259 public: // with description
260 void SetVerboseLevel(G4int value);
261 G4int GetVerboseLevel() const;
262 // set/get controle flag for output message
263 // 0: Silent
264 // 1: Warning message
265 // 2: More
266
267 ///////////////////////////////////////////////////////////////////////////
268 public: // with description
269 // "SetCutsWithDefault" method invokes default SetCuts method
270 // Note: Cut values will not be overwriten with this method
271 // Using default SetCuts method is recommended
272 // (i.e You do not need to implement SetCuts method)
273 void SetCutsWithDefault();
274
275 // Following are utility methods for SetCuts
276
277 // SetCutValue sets a cut value for a particle type for the default region
278 void SetCutValue(G4double aCut, const G4String& pname);
279
280 // GetCutValue sets a cut value for a particle type for the default region
281 G4double GetCutValue(const G4String& pname) const;
282
283 // SetCutValue sets a cut value for a particle type for a region
284 void SetCutValue(G4double aCut, const G4String& pname, const G4String& rname);
285
286 // Invoke SetCuts for specified particle for a region
287 // If the pointer to the region is NULL, the default region is used
288 // In case of "Retrieve" flag is ON,
289 // Cut values will be retrieved from files
291 G4Region* region = 0);
292 void SetParticleCuts(G4double cut, const G4String& particleName,
293 G4Region* region = 0);
294
295 // Invoke SetCuts for all particles in a region
296 void SetCutsForRegion(G4double aCut, const G4String& rname);
297
298 // Following are utility methods are obsolete
299 void ResetCuts();
300
301 ///////////////////////////////////////////////////////////////////
302 public:
303 // Get/SetApplyCuts gets/sets the flag for ApplyCuts
304 void SetApplyCuts(G4bool value, const G4String& name);
305 G4bool GetApplyCuts(const G4String& name) const;
306
307 ///////////////////////////////////////////////////////////////////////////////
308 protected:
309 // do BuildPhysicsTable for make the integral schema
311
312 protected:
313 // Retrieve PhysicsTable from files for proccess belongng the particle.
314 // Normal BuildPhysics procedure of processes will be invoked,
315 // if it fails (in case of Process's RetrievePhysicsTable returns false)
317 const G4String& directory,
318 G4bool ascii = false);
319
320 /////////////////////////////////////////////////////////////////
321 protected:
322 // adds new ProcessManager to all particles in the Particle Table
323 // this routine is used in Construct()
325
326 public: // with description
327 // remove and delete ProcessManagers for all particles in tha Particle Table
328 // this routine is invoked from RunManager
330
331 public: // with description
332 // add process manager for particles created on-the-fly
333 void AddProcessManager(G4ParticleDefinition* newParticle,
334 G4ProcessManager* newManager = 0);
335
336 /////////////////////////////////////////////////////////////////
337 public:
338 // check consistencies of list of particles
339
340 void CheckParticleList();
341
343
344 ////////////////////////////////////////////////////////////////////////
345 protected:
346 // the particle table has the complete List of existing particle types
348 // G4ParticleTable::G4PTblDicIterator* theParticleIterator; //AND
349
350 protected:
351 // pointer to G4UserPhysicsListMessenger
352 // G4UserPhysicsListMessenger* theMessenger;
353
354 protected:
356
357 protected:
358 // this is the default cut value for all particles
361
362 protected:
363 // pointer to ProductionCutsTable
365
366 // flag to determine physics table will be build from file or not
369
372
373 // directory name for physics table files
375
376 // flag for displaying the range cuts & energy thresholds
377 // G4int fDisplayThreshold;
378
379 // flag for Physics Table has been built
380 // G4bool fIsPhysicsTableBuilt;
381
382 // flag for CheckParticleList
384
385 // PhysicsListHelper
386 // G4PhysicsListHelper* thePLHelper;
387
388 private:
389 enum
390 {
391 FixedStringLengthForStore = 32
392 };
393
394 // Changes for MT
395 protected:
399
400 public:
401 inline G4int GetInstanceID() const;
402 static const G4VUPLManager& GetSubInstanceManager();
403 // Used by Worker threads on the shared instance of
404 // PL to initialize workers. Derived class re-implementing this method
405 // must also call this base class method
406 virtual void InitializeWorker();
407 // Destroy thread-local data. Note that derived classes
408 // implementing this method should still call this base class one
409 virtual void TerminateWorker();
410};
411
413{
414#ifdef G4VERBOSE
415 if(verboseLevel > 1)
416 G4cout << "G4VUserPhysicsList::Construct()" << G4endl;
417#endif
418
420
421#ifdef G4VERBOSE
422 if(verboseLevel > 1)
423 G4cout << "Construct processes " << G4endl;
424#endif
426}
427
429{
430 return defaultCutValue;
431}
432
434{
435 return verboseLevel;
436}
437
439{
441}
442
444{
445 return fStoredInAscii;
446}
447
449{
451}
452
454
456{
457 fRetrievePhysicsTable = false;
458 fIsRestoredCutValues = false;
460}
461
463
465{
467}
468
470{
471 return g4vuplInstanceID;
472}
473
475{
476 return subInstanceManager;
477}
478#endif
double G4double
Definition: G4Types.hh:83
bool G4bool
Definition: G4Types.hh:86
int G4int
Definition: G4Types.hh:85
G4VUPLManager G4VUserPhysicsListSubInstanceManager
G4VUPLSplitter< G4VUPLData > G4VUPLManager
#define G4endl
Definition: G4ios.hh:57
G4GLOB_DLL std::ostream G4cout
G4bool _fIsPhysicsTableBuilt
G4ParticleTable::G4PTblDicIterator * _theParticleIterator
G4PhysicsListHelper * _thePLHelper
G4UserPhysicsListMessenger * _theMessenger
G4double GetCutValue(const G4String &pname) const
void SetDefaultCutValue(G4double newCutValue)
void SetPhysicsTableRetrieved(const G4String &directory="")
virtual void ConstructProcess()=0
G4VUserPhysicsList & operator=(const G4VUserPhysicsList &)
void PreparePhysicsTable(G4ParticleDefinition *)
virtual void TerminateWorker()
void SetCutValue(G4double aCut, const G4String &pname)
G4bool RegisterProcess(G4VProcess *process, G4ParticleDefinition *particle)
void UseCoupledTransportation(G4bool vl=true)
G4bool IsStoredInAscii() const
void SetCutsForRegion(G4double aCut, const G4String &rname)
G4ProductionCutsTable * fCutsTable
virtual void ConstructParticle()=0
G4bool StorePhysicsTable(const G4String &directory=".")
G4ParticleTable::G4PTblDicIterator * GetParticleIterator() const
G4ParticleTable * theParticleTable
void SetVerboseLevel(G4int value)
G4int GetVerboseLevel() const
void SetApplyCuts(G4bool value, const G4String &name)
const G4String & GetPhysicsTableDirectory() const
G4bool IsPhysicsTableRetrieved() const
void SetParticleCuts(G4double cut, G4ParticleDefinition *particle, G4Region *region=0)
virtual void RetrievePhysicsTable(G4ParticleDefinition *, const G4String &directory, G4bool ascii=false)
void ResetCuts()
obsolete methods
G4bool fIsCheckedForRetrievePhysicsTable
void DumpCutValuesTable(G4int flag=1)
G4bool GetApplyCuts(const G4String &name) const
static G4RUN_DLL G4VUPLManager subInstanceManager
void AddProcessManager(G4ParticleDefinition *newParticle, G4ProcessManager *newManager=0)
void BuildIntegralPhysicsTable(G4VProcess *, G4ParticleDefinition *)
G4int GetInstanceID() const
virtual void InitializeWorker()
G4double GetDefaultCutValue() const
static const G4VUPLManager & GetSubInstanceManager()
#define G4RUN_DLL
Definition: rundefs.hh:47