Geant4
10.03.p01
Main Page
Related Pages
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Pages
G4ParticlesWorkspace.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
// Description:
27
// Manage the per-thread state of solids - those which
28
// have a per-thread state and dependent classes (if any)
29
// In particular it
30
// - owns the arrays that implement 'split' classes
31
// - classes/objects which are owned by the split classes.
32
// Background: the classes/objects affected are
33
// - 'split' classes part of its state is per-thread,
34
// - per-thread objects, in particular those which are owned
35
// by the split classes.
36
// Goal: Take ownership and control of per-thread state of
37
// classes to work with multi-threading.
38
// Offshoot of G4GeometryWorkspace, to deal with Particles.
39
//
40
// Designed / created by John Apostolakis
41
// Interface design - review with Andrea Dotti.
42
//
43
// First version: 4th Oct 2013
44
// Created due to dependency issue with G4GeometryWorkspace
45
// Working version:
46
47
#ifndef G4PARTICLESWORKSPACE_HH
48
#define G4PARTICLESWORKSPACE_HH
49
50
#include "
G4ParticleDefinition.hh
"
51
52
#include "
G4TWorkspacePool.hh
"
53
54
class
G4ParticlesWorkspace
55
{
56
public
:
57
58
typedef
G4TWorkspacePool<G4ParticlesWorkspace>
pool_type
;
59
G4ParticlesWorkspace
(
G4bool
verbose=
false
);
60
~G4ParticlesWorkspace
();
61
62
void
UseWorkspace
();
//Take ownership
63
void
ReleaseWorkspace
();
//Release ownership
64
void
DestroyWorkspace
();
//Release ownership and destroy
65
66
void
InitialiseWorkspace
();
67
// To be called at start of each run (especially 2nd and further runs)
68
69
void
SetVerbose
(
G4bool
v) { fVerbose=v; }
70
G4bool
GetVerbose
() {
return
fVerbose; }
71
72
static
pool_type
*
GetPool
();
73
74
protected
:
// Implementation methods
75
76
void
InitialiseParticles
();
77
78
private
:
79
80
// Helper pointer - can be per instance or shared
81
G4PDefManager
*fpPDefSIM;
82
83
// Per Instance variables
84
// NOTE: the ownership of the Data Arrays is IN this object
85
86
// Store SubInstanceManager object pointers (SIM pointers)
87
G4PDefData
*fpPDefOffset;
88
G4bool
fVerbose;
89
};
90
91
#endif //G4PARTICLESWORKSPACE_HH
G4ParticlesWorkspace::GetPool
static pool_type * GetPool()
Definition:
G4ParticlesWorkspace.cc:34
G4ParticlesWorkspace::UseWorkspace
void UseWorkspace()
Definition:
G4ParticlesWorkspace.cc:54
G4ParticlesWorkspace::G4ParticlesWorkspace
G4ParticlesWorkspace(G4bool verbose=false)
Definition:
G4ParticlesWorkspace.cc:36
G4bool
bool G4bool
Definition:
G4Types.hh:79
G4ParticlesWorkspace::InitialiseWorkspace
void InitialiseWorkspace()
Definition:
G4ParticlesWorkspace.cc:77
G4ParticleDefinition.hh
G4ParticlesWorkspace::DestroyWorkspace
void DestroyWorkspace()
Definition:
G4ParticlesWorkspace.cc:96
G4TWorkspacePool
Definition:
G4TWorkspacePool.hh:48
G4ParticlesWorkspace::SetVerbose
void SetVerbose(G4bool v)
Definition:
G4ParticlesWorkspace.hh:69
G4ParticlesWorkspace::pool_type
G4TWorkspacePool< G4ParticlesWorkspace > pool_type
Definition:
G4ParticlesWorkspace.hh:58
G4PDefManager
Definition:
G4PDefManager.hh:87
G4ParticlesWorkspace::InitialiseParticles
void InitialiseParticles()
Definition:
G4ParticlesWorkspace.cc:72
G4ParticlesWorkspace
Definition:
G4ParticlesWorkspace.hh:54
G4PDefData
Definition:
G4PDefManager.hh:55
G4TWorkspacePool.hh
G4ParticlesWorkspace::ReleaseWorkspace
void ReleaseWorkspace()
Definition:
G4ParticlesWorkspace.cc:67
G4ParticlesWorkspace::GetVerbose
G4bool GetVerbose()
Definition:
G4ParticlesWorkspace.hh:70
G4ParticlesWorkspace::~G4ParticlesWorkspace
~G4ParticlesWorkspace()
Definition:
G4ParticlesWorkspace.cc:49
geant4.10.03.p01
source
particles
management
include
G4ParticlesWorkspace.hh
Generated on Thu Mar 16 2017 22:37:57 for Geant4 by
1.8.5