Geant4 Cross Reference |
1 // 1 // 2 // ******************************************* 2 // ******************************************************************** 3 // * License and Disclaimer 3 // * License and Disclaimer * 4 // * 4 // * * 5 // * The Geant4 software is copyright of th 5 // * The Geant4 software is copyright of the Copyright Holders of * 6 // * the Geant4 Collaboration. It is provided 6 // * the Geant4 Collaboration. It is provided under the terms and * 7 // * conditions of the Geant4 Software License 7 // * conditions of the Geant4 Software License, included in the file * 8 // * LICENSE and available at http://cern.ch/ 8 // * LICENSE and available at http://cern.ch/geant4/license . These * 9 // * include a list of copyright holders. 9 // * include a list of copyright holders. * 10 // * 10 // * * 11 // * Neither the authors of this software syst 11 // * Neither the authors of this software system, nor their employing * 12 // * institutes,nor the agencies providing fin 12 // * institutes,nor the agencies providing financial support for this * 13 // * work make any representation or warran 13 // * work make any representation or warranty, express or implied, * 14 // * regarding this software system or assum 14 // * regarding this software system or assume any liability for its * 15 // * use. Please see the license in the file 15 // * use. Please see the license in the file LICENSE and URL above * 16 // * for the full disclaimer and the limitatio 16 // * for the full disclaimer and the limitation of liability. * 17 // * 17 // * * 18 // * This code implementation is the result 18 // * This code implementation is the result of the scientific and * 19 // * technical work of the GEANT4 collaboratio 19 // * technical work of the GEANT4 collaboration. * 20 // * By using, copying, modifying or distri 20 // * By using, copying, modifying or distributing the software (or * 21 // * any work based on the software) you ag 21 // * any work based on the software) you agree to acknowledge its * 22 // * use in resulting scientific publicati 22 // * use in resulting scientific publications, and indicate your * 23 // * acceptance of all terms of the Geant4 Sof 23 // * acceptance of all terms of the Geant4 Software license. * 24 // ******************************************* 24 // ******************************************************************** 25 // 25 // 26 // G4VUserPhysicsList 26 // G4VUserPhysicsList 27 // 27 // 28 // Class description: 28 // Class description: 29 // 29 // 30 // This class is an abstract class for constru 30 // This class is an abstract class for constructing particles and processes. 31 // User must implement the following two pure 31 // User must implement the following two pure virtual methods in the concrete 32 // class derived from this class: 32 // class derived from this class: 33 // - G4VUserPhysicsList::ConstructParticle() 33 // - G4VUserPhysicsList::ConstructParticle() 34 // Construct particles 34 // Construct particles 35 // - G4VUserPhysicsList::ConstructProcess() 35 // - G4VUserPhysicsList::ConstructProcess() 36 // Construct procesess and register them t 36 // Construct procesess and register them to particles. 37 37 38 // Original author: H.Kurashige (Kobe Universi 38 // Original author: H.Kurashige (Kobe University), 9 January 1998 39 // ------------------------------------------- 39 // -------------------------------------------------------------------- 40 #ifndef G4VUserPhysicsList_hh 40 #ifndef G4VUserPhysicsList_hh 41 #define G4VUserPhysicsList_hh 1 41 #define G4VUserPhysicsList_hh 1 42 42 43 #include "G4ParticleDefinition.hh" 43 #include "G4ParticleDefinition.hh" 44 #include "G4ParticleTable.hh" 44 #include "G4ParticleTable.hh" 45 #include "G4PhysicsModelCatalog.hh" 45 #include "G4PhysicsModelCatalog.hh" 46 #include "G4ProductionCutsTable.hh" 46 #include "G4ProductionCutsTable.hh" 47 #include "G4Threading.hh" 47 #include "G4Threading.hh" 48 #include "G4VUPLSplitter.hh" 48 #include "G4VUPLSplitter.hh" 49 #include "G4ios.hh" 49 #include "G4ios.hh" 50 #include "globals.hh" 50 #include "globals.hh" 51 51 52 #include "rundefs.hh" 52 #include "rundefs.hh" 53 #include "tls.hh" 53 #include "tls.hh" 54 54 55 class G4UserPhysicsListMessenger; 55 class G4UserPhysicsListMessenger; 56 class G4PhysicsListHelper; 56 class G4PhysicsListHelper; 57 class G4VProcess; 57 class G4VProcess; 58 58 59 // Encapsulate the fields of class G4VUserPhys 59 // Encapsulate the fields of class G4VUserPhysicsList that are per-thread. 60 class G4VUPLData 60 class G4VUPLData 61 { 61 { 62 public: 62 public: 63 void initialize(); 63 void initialize(); 64 64 65 G4ParticleTable::G4PTblDicIterator* _thePa 65 G4ParticleTable::G4PTblDicIterator* _theParticleIterator = nullptr; 66 G4UserPhysicsListMessenger* _theMessenger 66 G4UserPhysicsListMessenger* _theMessenger = nullptr; 67 G4PhysicsListHelper* _thePLHelper = nullpt 67 G4PhysicsListHelper* _thePLHelper = nullptr; 68 G4bool _fIsPhysicsTableBuilt = false; 68 G4bool _fIsPhysicsTableBuilt = false; 69 G4int _fDisplayThreshold = 0; 69 G4int _fDisplayThreshold = 0; 70 }; 70 }; 71 71 72 // The type G4VUPLManager is introduced to enc 72 // The type G4VUPLManager is introduced to encapsulate the methods used by 73 // both the master thread and worker threads t 73 // both the master thread and worker threads to allocate memory space for 74 // the fields encapsulated by the class G4VUPL 74 // the fields encapsulated by the class G4VUPLData. When each thread 75 // changes the value for these fields, it refe 75 // changes the value for these fields, it refers to them using a macro 76 // definition defined below. For every G4VUser 76 // definition defined below. For every G4VUserPhysicsList instance, 77 // there is a corresponding G4VUPLData instanc 77 // there is a corresponding G4VUPLData instance. All G4VUPLData instances 78 // are organized by the class G4VUPLManager as 78 // are organized by the class G4VUPLManager as an array. 79 // The field "int g4vuplInstanceID" is added t 79 // The field "int g4vuplInstanceID" is added to the class G4VUserPhysicsList. 80 // The value of this field in each G4VUserPhys 80 // The value of this field in each G4VUserPhysicsList instance is the 81 // subscript of the corresponding G44VUPLData 81 // subscript of the corresponding G44VUPLData instance. 82 // In order to use the class G44VUPLManager, w 82 // In order to use the class G44VUPLManager, we add a static member in the class 83 // G4VUserPhysicsList as follows: "static G4VU 83 // G4VUserPhysicsList as follows: "static G4VUPLManager subInstanceManager". 84 // Both the master thread and worker threads c 84 // Both the master thread and worker threads change the length of the array 85 // for G44VUPLData instances mutually along wi 85 // for G44VUPLData instances mutually along with G4VUserPhysicsList 86 // instances are created. For each worker thre 86 // instances are created. For each worker thread, it dynamically creates ions. 87 // Consider any thread A, if there is any othe 87 // Consider any thread A, if there is any other thread which creates an ion. 88 // This ion is shared by the thread A. So the 88 // This ion is shared by the thread A. So the thread A leaves an empty space 89 // in the array of G4PDefData instances for th 89 // in the array of G4PDefData instances for the ion. 90 // 90 // 91 // Important Note: you may wonder why we are i 91 // Important Note: you may wonder why we are introducing this mechanism 92 // since there is only one PL 92 // since there is only one PL for each application. 93 // This is true, in the sense 93 // This is true, in the sense that only one PL is allowed 94 // to be associated to a G4Run 94 // to be associated to a G4RunManager, however user can 95 // instantiate as many PLs are 95 // instantiate as many PLs are needed and at run-time select one 96 // of the PLs to be used we th 96 // of the PLs to be used we thus need this mechanism to 97 // guarantee that the system w 97 // guarantee that the system works without problems in case of 98 // this (unusual) case. This m 98 // this (unusual) case. This may be reviewed in the future 99 // 99 // 100 using G4VUPLManager = G4VUPLSplitter<G4VUPLDat 100 using G4VUPLManager = G4VUPLSplitter<G4VUPLData>; 101 using G4VUserPhysicsListSubInstanceManager = G 101 using G4VUserPhysicsListSubInstanceManager = G4VUPLManager; 102 102 103 class G4VUserPhysicsList 103 class G4VUserPhysicsList 104 { 104 { 105 public: 105 public: 106 G4VUserPhysicsList(); 106 G4VUserPhysicsList(); 107 virtual ~G4VUserPhysicsList(); 107 virtual ~G4VUserPhysicsList(); 108 G4VUserPhysicsList(const G4VUserPhysicsLis 108 G4VUserPhysicsList(const G4VUserPhysicsList&); 109 G4VUserPhysicsList& operator=(const G4VUse 109 G4VUserPhysicsList& operator=(const G4VUserPhysicsList&); 110 110 111 // Each particle type will be instantiated 111 // Each particle type will be instantiated. 112 // This method is invoked by the RunManger 112 // This method is invoked by the RunManger. 113 virtual void ConstructParticle() = 0; 113 virtual void ConstructParticle() = 0; 114 114 115 // By calling the "Construct" method, 115 // By calling the "Construct" method, 116 // process manager and processes are creat 116 // process manager and processes are created. 117 void Construct(); 117 void Construct(); 118 118 119 // Each physics process will be instantiat 119 // Each physics process will be instantiated and 120 // registered to the process manager of ea 120 // registered to the process manager of each particle type. 121 // Invoked in the Construct() method. 121 // Invoked in the Construct() method. 122 virtual void ConstructProcess() = 0; 122 virtual void ConstructProcess() = 0; 123 123 124 // Sets a cut value for all particle types 124 // Sets a cut value for all particle types in the particle table. 125 virtual void SetCuts(); 125 virtual void SetCuts(); 126 126 127 // Set/get the default cut value. Calling 127 // Set/get the default cut value. Calling SetDefaultCutValue() causes 128 // re-calcuration of cut values and physic 128 // re-calcuration of cut values and physics tables just before the 129 // next event loop. 129 // next event loop. 130 void SetDefaultCutValue(G4double newCutVal 130 void SetDefaultCutValue(G4double newCutValue); 131 G4double GetDefaultCutValue() const; 131 G4double GetDefaultCutValue() const; 132 132 133 // Invoke BuildPhysicsTable for all proces 133 // Invoke BuildPhysicsTable for all processes for all particles. 134 // In case of "Retrieve" flag is ON, Physi 134 // In case of "Retrieve" flag is ON, PhysicsTable will be 135 // retrieved from files. 135 // retrieved from files. 136 void BuildPhysicsTable(); 136 void BuildPhysicsTable(); 137 137 138 // Prepare the PhysicsTable for specified 138 // Prepare the PhysicsTable for specified particle type. 139 void PreparePhysicsTable(G4ParticleDefinit 139 void PreparePhysicsTable(G4ParticleDefinition*); 140 140 141 // Build the PhysicsTable for specified pa 141 // Build the PhysicsTable for specified particle type. 142 void BuildPhysicsTable(G4ParticleDefinitio 142 void BuildPhysicsTable(G4ParticleDefinition*); 143 143 144 // Store PhysicsTable together with both m 144 // Store PhysicsTable together with both material and cut value 145 // information in files under the specifie 145 // information in files under the specified directory. 146 // Returns "true" if files are successfull 146 // Returns "true" if files are successfully created. 147 G4bool StorePhysicsTable(const G4String& d 147 G4bool StorePhysicsTable(const G4String& directory = "."); 148 148 149 // Return true if "Retrieve" flag is ON. 149 // Return true if "Retrieve" flag is ON. 150 // (i.e. PhysicsTable will be retrieved fr 150 // (i.e. PhysicsTable will be retrieved from files). 151 G4bool IsPhysicsTableRetrieved() const; 151 G4bool IsPhysicsTableRetrieved() const; 152 G4bool IsStoredInAscii() const; 152 G4bool IsStoredInAscii() const; 153 153 154 // Get directory path for physics table fi 154 // Get directory path for physics table files. 155 const G4String& GetPhysicsTableDirectory() 155 const G4String& GetPhysicsTableDirectory() const; 156 156 157 // Set "Retrieve" flag. Directory path can 157 // Set "Retrieve" flag. Directory path can be set together. 158 // Null string (default) means directory i 158 // Null string (default) means directory is not changed 159 // from the current value. 159 // from the current value. 160 void SetPhysicsTableRetrieved(const G4Stri 160 void SetPhysicsTableRetrieved(const G4String& directory = ""); 161 void SetStoredInAscii(); 161 void SetStoredInAscii(); 162 162 163 // Reset "Retrieve" flag. 163 // Reset "Retrieve" flag. 164 void ResetPhysicsTableRetrieved(); 164 void ResetPhysicsTableRetrieved(); 165 void ResetStoredInAscii(); 165 void ResetStoredInAscii(); 166 166 167 // Print out the List of registered partic 167 // Print out the List of registered particles types. 168 void DumpList() const; 168 void DumpList() const; 169 169 170 // Request to print out information of cut 170 // Request to print out information of cut values. 171 // Printing will be performed when all tab 171 // Printing will be performed when all tables are made. 172 void DumpCutValuesTable(G4int flag = 1); 172 void DumpCutValuesTable(G4int flag = 1); 173 173 174 // Triggers the print-out requested by the 174 // Triggers the print-out requested by the above method. 175 // This method must be invoked by RunManag 175 // This method must be invoked by RunManager at the proper moment. 176 void DumpCutValuesTableIfRequested(); 176 void DumpCutValuesTableIfRequested(); 177 177 178 // Set/get control flag for output message 178 // Set/get control flag for output message 179 // 0: Silent 179 // 0: Silent 180 // 1: Warning message 180 // 1: Warning message 181 // 2: More 181 // 2: More 182 void SetVerboseLevel(G4int value); 182 void SetVerboseLevel(G4int value); 183 G4int GetVerboseLevel() const; 183 G4int GetVerboseLevel() const; 184 184 185 void UseCoupledTransportation(G4bool vl = 185 void UseCoupledTransportation(G4bool vl = true); 186 186 187 // Invokes default SetCuts() method. 187 // Invokes default SetCuts() method. 188 // Note: cut values will not be overwritte 188 // Note: cut values will not be overwritten. 189 // Use of default SetCuts() method is reco 189 // Use of default SetCuts() method is recommended. 190 void SetCutsWithDefault(); 190 void SetCutsWithDefault(); 191 191 192 // Sets a cut value for a particle type fo 192 // Sets a cut value for a particle type for the default region. 193 void SetCutValue(G4double aCut, const G4St 193 void SetCutValue(G4double aCut, const G4String& pname); 194 194 195 // Gets a cut value for a particle type fo 195 // Gets a cut value for a particle type for the default region. 196 G4double GetCutValue(const G4String& pname 196 G4double GetCutValue(const G4String& pname) const; 197 197 198 // Sets a cut value for a particle type fo 198 // Sets a cut value for a particle type for a region. 199 void SetCutValue(G4double aCut, const G4St 199 void SetCutValue(G4double aCut, const G4String& pname, const G4String& rname); 200 200 201 // Invoke SetCuts for specified particle f 201 // Invoke SetCuts for specified particle for a region. 202 // If the pointer to the region is NULL, t 202 // If the pointer to the region is NULL, the default region is used 203 // In case of "Retrieve" flag is ON, cut v 203 // In case of "Retrieve" flag is ON, cut values will be retrieved 204 // from files. 204 // from files. 205 void SetParticleCuts(G4double cut, G4Parti 205 void SetParticleCuts(G4double cut, G4ParticleDefinition* particle, G4Region* region = nullptr); 206 void SetParticleCuts(G4double cut, const G 206 void SetParticleCuts(G4double cut, const G4String& particleName, G4Region* region = nullptr); 207 207 208 // Invoke SetCuts() for all particles in a 208 // Invoke SetCuts() for all particles in a region. 209 void SetCutsForRegion(G4double aCut, const 209 void SetCutsForRegion(G4double aCut, const G4String& rname); 210 210 211 // Gets/sets the flag for ApplyCuts(). 211 // Gets/sets the flag for ApplyCuts(). 212 void SetApplyCuts(G4bool value, const G4St 212 void SetApplyCuts(G4bool value, const G4String& name); 213 G4bool GetApplyCuts(const G4String& name) 213 G4bool GetApplyCuts(const G4String& name) const; 214 214 215 // Remove and delete ProcessManagers for a 215 // Remove and delete ProcessManagers for all particles in the 216 // Particle Table. 216 // Particle Table. 217 void RemoveProcessManager(); 217 void RemoveProcessManager(); 218 218 219 // Remove and delete TrackingManagers for 219 // Remove and delete TrackingManagers for all particles in the 220 // Particle Table. 220 // Particle Table. 221 void RemoveTrackingManager(); 221 void RemoveTrackingManager(); 222 222 223 // Add process manager for particles creat 223 // Add process manager for particles created on-the-fly. 224 void AddProcessManager(G4ParticleDefinitio 224 void AddProcessManager(G4ParticleDefinition* newParticle, 225 G4ProcessManager* n 225 G4ProcessManager* newManager = nullptr); 226 226 227 // Check consistencies of list of particle 227 // Check consistencies of list of particles. 228 void CheckParticleList(); 228 void CheckParticleList(); 229 229 230 void DisableCheckParticleList(); 230 void DisableCheckParticleList(); 231 231 232 inline G4int GetInstanceID() const; 232 inline G4int GetInstanceID() const; 233 static const G4VUPLManager& GetSubInstance 233 static const G4VUPLManager& GetSubInstanceManager(); 234 234 235 // Used by Worker threads on the shared in 235 // Used by Worker threads on the shared instance of physics-list 236 // to initialise workers. Derived class re 236 // to initialise workers. Derived class re-implementing this method 237 // must also call this base class method. 237 // must also call this base class method. 238 virtual void InitializeWorker(); 238 virtual void InitializeWorker(); 239 239 240 // Destroy thread-local data. Note that de 240 // Destroy thread-local data. Note that derived classes 241 // implementing this method should still c 241 // implementing this method should still call this base class one. 242 virtual void TerminateWorker(); 242 virtual void TerminateWorker(); 243 243 244 protected: 244 protected: 245 // User must invoke this method in his Con 245 // User must invoke this method in his ConstructProcess() 246 // implementation in order to enable parti 246 // implementation in order to enable particle transportation. 247 void AddTransportation(); 247 void AddTransportation(); 248 248 249 // Register a process to the particle type 249 // Register a process to the particle type 250 // according to the ordering parameter tab 250 // according to the ordering parameter table. 251 // 'true' is returned if the process is re 251 // 'true' is returned if the process is registerd successfully. 252 G4bool RegisterProcess(G4VProcess* process 252 G4bool RegisterProcess(G4VProcess* process, G4ParticleDefinition* particle); 253 253 254 // Build PhysicsTable for making the integ 254 // Build PhysicsTable for making the integral schema. 255 void BuildIntegralPhysicsTable(G4VProcess* 255 void BuildIntegralPhysicsTable(G4VProcess*, G4ParticleDefinition*); 256 256 257 // Retrieve PhysicsTable from files for pr 257 // Retrieve PhysicsTable from files for process belonging to the particle. 258 // Normal BuildPhysics procedure of proces 258 // Normal BuildPhysics procedure of processes will be invoked, if it 259 // fails (in case of process's RetrievePhy 259 // fails (in case of process's RetrievePhysicsTable() returns false). 260 virtual void RetrievePhysicsTable(G4Partic 260 virtual void RetrievePhysicsTable(G4ParticleDefinition*, const G4String& directory, 261 G4bool a 261 G4bool ascii = false); 262 262 263 // Adds new ProcessManager to all particle 263 // Adds new ProcessManager to all particles in the Particle Table. 264 // This function is used in Construct(). 264 // This function is used in Construct(). 265 void InitializeProcessManager(); 265 void InitializeProcessManager(); 266 266 267 G4ParticleTable::G4PTblDicIterator* GetPar 267 G4ParticleTable::G4PTblDicIterator* GetParticleIterator() const; 268 268 269 protected: 269 protected: 270 // The particle table has the complete Lis 270 // The particle table has the complete List of existing particle types. 271 G4ParticleTable* theParticleTable = nullpt 271 G4ParticleTable* theParticleTable = nullptr; 272 272 273 G4int verboseLevel = 1; 273 G4int verboseLevel = 1; 274 274 275 // Default cut value for all particles 275 // Default cut value for all particles 276 G4double defaultCutValue = 1.0; 276 G4double defaultCutValue = 1.0; 277 G4bool isSetDefaultCutValue = false; 277 G4bool isSetDefaultCutValue = false; 278 278 279 // Pointer to ProductionCutsTable. 279 // Pointer to ProductionCutsTable. 280 G4ProductionCutsTable* fCutsTable = nullpt 280 G4ProductionCutsTable* fCutsTable = nullptr; 281 281 282 // Flag to determine if physics table will 282 // Flag to determine if physics table will be build from file or not. 283 G4bool fRetrievePhysicsTable = false; 283 G4bool fRetrievePhysicsTable = false; 284 G4bool fStoredInAscii = true; 284 G4bool fStoredInAscii = true; 285 285 286 G4bool fIsCheckedForRetrievePhysicsTable = 286 G4bool fIsCheckedForRetrievePhysicsTable = false; 287 G4bool fIsRestoredCutValues = false; 287 G4bool fIsRestoredCutValues = false; 288 288 289 // Directory name for physics table files. 289 // Directory name for physics table files. 290 G4String directoryPhysicsTable = "."; 290 G4String directoryPhysicsTable = "."; 291 291 292 // Flag for CheckParticleList(). 292 // Flag for CheckParticleList(). 293 G4bool fDisableCheckParticleList = false; 293 G4bool fDisableCheckParticleList = false; 294 294 295 // MT data 295 // MT data 296 G4int g4vuplInstanceID = 0; 296 G4int g4vuplInstanceID = 0; 297 G4RUN_DLL static G4VUPLManager subInstance 297 G4RUN_DLL static G4VUPLManager subInstanceManager; 298 }; 298 }; 299 299 300 // Inline methods implementations 300 // Inline methods implementations 301 301 302 inline void G4VUserPhysicsList::Construct() 302 inline void G4VUserPhysicsList::Construct() 303 { 303 { 304 #ifdef G4VERBOSE 304 #ifdef G4VERBOSE 305 if (verboseLevel > 1) G4cout << "G4VUserPhys 305 if (verboseLevel > 1) G4cout << "G4VUserPhysicsList::Construct()" << G4endl; 306 #endif 306 #endif 307 307 308 if (G4Threading::IsMasterThread()) G4Physics 308 if (G4Threading::IsMasterThread()) G4PhysicsModelCatalog::Initialize(); 309 309 310 InitializeProcessManager(); 310 InitializeProcessManager(); 311 311 312 #ifdef G4VERBOSE 312 #ifdef G4VERBOSE 313 if (verboseLevel > 1) G4cout << "Construct p 313 if (verboseLevel > 1) G4cout << "Construct processes " << G4endl; 314 #endif 314 #endif 315 ConstructProcess(); 315 ConstructProcess(); 316 } 316 } 317 317 318 inline G4double G4VUserPhysicsList::GetDefault 318 inline G4double G4VUserPhysicsList::GetDefaultCutValue() const 319 { 319 { 320 return defaultCutValue; 320 return defaultCutValue; 321 } 321 } 322 322 323 inline G4int G4VUserPhysicsList::GetVerboseLev 323 inline G4int G4VUserPhysicsList::GetVerboseLevel() const 324 { 324 { 325 return verboseLevel; 325 return verboseLevel; 326 } 326 } 327 327 328 inline G4bool G4VUserPhysicsList::IsPhysicsTab 328 inline G4bool G4VUserPhysicsList::IsPhysicsTableRetrieved() const 329 { 329 { 330 return fRetrievePhysicsTable; 330 return fRetrievePhysicsTable; 331 } 331 } 332 332 333 inline G4bool G4VUserPhysicsList::IsStoredInAs 333 inline G4bool G4VUserPhysicsList::IsStoredInAscii() const 334 { 334 { 335 return fStoredInAscii; 335 return fStoredInAscii; 336 } 336 } 337 337 338 inline const G4String& G4VUserPhysicsList::Get 338 inline const G4String& G4VUserPhysicsList::GetPhysicsTableDirectory() const 339 { 339 { 340 return directoryPhysicsTable; 340 return directoryPhysicsTable; 341 } 341 } 342 342 343 inline void G4VUserPhysicsList::SetStoredInAsc 343 inline void G4VUserPhysicsList::SetStoredInAscii() 344 { 344 { 345 fStoredInAscii = true; 345 fStoredInAscii = true; 346 } 346 } 347 347 348 inline void G4VUserPhysicsList::ResetPhysicsTa 348 inline void G4VUserPhysicsList::ResetPhysicsTableRetrieved() 349 { 349 { 350 fRetrievePhysicsTable = false; 350 fRetrievePhysicsTable = false; 351 fIsRestoredCutValues = false; 351 fIsRestoredCutValues = false; 352 fIsCheckedForRetrievePhysicsTable = false; 352 fIsCheckedForRetrievePhysicsTable = false; 353 } 353 } 354 354 355 inline void G4VUserPhysicsList::ResetStoredInA 355 inline void G4VUserPhysicsList::ResetStoredInAscii() 356 { 356 { 357 fStoredInAscii = false; 357 fStoredInAscii = false; 358 } 358 } 359 359 360 inline void G4VUserPhysicsList::DisableCheckPa 360 inline void G4VUserPhysicsList::DisableCheckParticleList() 361 { 361 { 362 fDisableCheckParticleList = true; 362 fDisableCheckParticleList = true; 363 } 363 } 364 364 365 inline G4int G4VUserPhysicsList::GetInstanceID 365 inline G4int G4VUserPhysicsList::GetInstanceID() const 366 { 366 { 367 return g4vuplInstanceID; 367 return g4vuplInstanceID; 368 } 368 } 369 369 370 inline const G4VUPLManager& G4VUserPhysicsList 370 inline const G4VUPLManager& G4VUserPhysicsList::GetSubInstanceManager() 371 { 371 { 372 return subInstanceManager; 372 return subInstanceManager; 373 } 373 } 374 374 375 #endif 375 #endif 376 376