Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/examples/advanced/HGCal_testbeam/include/PrimaryGeneratorAction.hh

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

  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 #ifndef PRIMARYGENERATORACTION_HH
 27 #define PRIMARYGENERATORACTION_HH
 28 
 29 #include "G4String.hh"
 30 #include "G4VUserPrimaryGeneratorAction.hh"
 31 #include "CLHEP/Units/SystemOfUnits.h"
 32 
 33 class G4ParticleGun;
 34 class G4Event;
 35 class G4Box;
 36 class PrimaryGeneratorMessenger;
 37 
 38 #ifdef WITHROOT
 39 #include <RtypesCore.h>
 40 class TFile;
 41 class TTreeReader;
 42 template <typename T> class TTreeReaderValue;
 43 #endif
 44 
 45 /**
 46  * @brief Primary generator
 47  *
 48  * Primary generator action.
 49  *
 50  * By default particle gun is used. It can be controlled with standard UI
 51  * commands (/gun/) and with additional ones introduced by the messenger.
 52  * "/HGCalTestbeam/generator/momentumSpread <VALUE>" to change constant
 53  * particle energy to Gaussian distribution with sigma expressed in units of the
 54  * initial energy (e.g. value 0.05 means sigma of 0.05 * E).
 55  * By default it equals to 0 and constant energy value is used.
 56  * "/HGCalTestbeam/generator/beamSpread <none/Gaussian/flat>" to define type of
 57  * beam position spread. By default none is used.
 58  * "/HGCalTestbeam/generator/beamSpreadX <SIZE>" to define size of beam spread
 59  * along x axis. It is sigma of a Gaussian distribution, or half-width of a
 60  * flat distribution.
 61  * "/HGCalTestbeam/generator/beamSpreadY <SIZE>" to define size of beam spread
 62  * along y axis. It is sigma of a Gaussian distribution, or half-width of a
 63  * flat distribution.
 64  * "/HGCalTestbeam/generator/fBeamZ0 <POSITION>" to define beam position along z
 65  * axis. By default edge of the world volume is used.
 66  *
 67  * If installation was done with ROOT package (CMake was able to locate it),
 68  * an additional option of input read from the ROOT file is enabled.
 69  * It can be activated with "/HGCalTestbeam/generator/fReadInputFile true".
 70  * "/HGCalTestbeam/generator/fPathInputFile <FILE>" sets the path to the input
 71  * file.
 72  * "/HGCalTestbeam/generator/startFromEvent <N>" allows to start simulation from
 73  * Nth event.
 74  * Please note that in current implementation input from file needs to be
 75  * executed in a non-multithreaded mode (or with 1 thread).
 76  *
 77  */
 78 
 79 class PrimaryGeneratorAction : public G4VUserPrimaryGeneratorAction {
 80 public:
 81   PrimaryGeneratorAction();
 82   virtual ~PrimaryGeneratorAction();
 83 
 84   virtual void GeneratePrimaries(G4Event *);
 85 
 86   const G4ParticleGun *GetParticleGun() const { return fParticleGun; }
 87 
 88 #ifdef WITHROOT
 89   /// Open input file with list of particles
 90   void OpenInput();
 91 
 92   /// Set flag indicating that particles should be read from file
 93   inline void SetIfUseInputFiles(G4bool aUseInputFiles) {
 94     fReadInputFile = aUseInputFiles;
 95   };
 96   /// Set the flag indicating that particles should be read from file
 97   inline G4bool GetIfUseInputFiles() { return fReadInputFile; }
 98   /// Set the path to the input file
 99   inline void SetInputFiles(G4String aInputFiles) {
100     fPathInputFile = aInputFiles;
101   };
102   /// Get the path to the input file
103   inline G4String GetInputFiles() const { return fPathInputFile; }
104   /// Set ID of the first event to be read for the simulation
105   inline void SetStartFromEvent(G4int aStartFromEvent) {
106     fStartFromEvent = aStartFromEvent;
107   };
108   /// Get ID of the first event to be read for the simulation
109   inline G4int GetStartFromEvent() const { return fStartFromEvent; }
110 #endif
111   /// Set sigma of the Gaussian distribution for the momentum spread
112   /// @param[in] aMomentumSpread sigma of Gaussian distribution expressed in
113   /// units of initial energy (e.g. 0.05 means sigma = 0.05 * E)
114   inline void SetMomentumSpread(G4double aMomentumSpread) {
115     fMomentumGaussianSpread = aMomentumSpread;
116   };
117   /// Get sigma of the Gaussian distribution for the momentum spread
118   inline G4double GetMomentumSpread() const { return fMomentumGaussianSpread; }
119   /// Set type of beam position spread
120   /// @param[in] aType Type of beam position spread: "none", "Gaussian" or
121   /// "flat". By default "none" is used.
122   inline void SetBeamSpreadType(G4String aType) {
123     if (aType == "none")
124       fBeamType = eNone;
125     if (aType == "Gaussian")
126       fBeamType = eGaussian;
127     if (aType == "flat")
128       fBeamType = eFlat;
129   }
130   /// Get type of beam position spread
131   inline G4String GetBeamSpreadType() const {
132     switch (fBeamType) {
133     case eNone:
134       return "none";
135       break;
136     case eGaussian:
137       return "Gaussian";
138       break;
139     case eFlat:
140       return "flat";
141       break;
142     }
143     return "";
144   }
145   /// Set size of beam position spread along X axis
146   /// @param[in] aBeamSpreadX Size of beam position spread. Sigma for Gaussian
147   /// distribution or half-width of flat distribution.
148   inline void SetBeamSpreadX(G4double aBeamSpreadX) {
149     fSigmaBeamX = aBeamSpreadX;
150   }
151   /// Get size of beam position spread along X axis
152   inline G4double GetBeamSpreadX() const { return fSigmaBeamX; }
153   /// Set size of beam position spread along Y axis
154   /// @param[in] aBeamSpreadY Size of beam position spread. Sigma for Gaussian
155   /// distribution or half-width of flat distribution.
156   inline void SetBeamSpreadY(G4double aBeamSpreadY) {
157     fSigmaBeamY = aBeamSpreadY;
158   }
159   /// Get size of beam position spread along Y axis
160   inline G4double GetBeamSpreadY() const { return fSigmaBeamY; }
161   /// Set initial beam position along Z axis
162   /// By default edge of world volume is used
163   inline void SetBeamZ0(G4double aBeamZ0) { fBeamZ0 = aBeamZ0; }
164   /// Get initial beam position along Z axis
165   inline G4double GetBeamZ0() const { return fBeamZ0; }
166 
167 private:
168   /// Pointer to the particle gun
169   G4ParticleGun *fParticleGun;
170   /// Pointer to the world volume for initial beam position
171   G4Box *fEnvelopeBox;
172   /// Pointer to the messenger with custom UI commands
173   PrimaryGeneratorMessenger *fMessenger;
174   /// enum describing the beam position spread in transverse plane
175   enum eBeamType { eNone, eGaussian, eFlat };
176   /// Type of beam position spread in transverse dimension
177   eBeamType fBeamType = eBeamType::eNone;
178   /// Size of beam position spread along X axis
179   /// Sigma for Gaussian, and half-width for flat distribution
180   G4double fSigmaBeamX = 0;
181   /// Size of beam position spread along Y axis
182   /// Sigma for Gaussian, and half-width for flat distribution
183   G4double fSigmaBeamY = 0;
184   /// Initial beam position along Z axis
185   G4double fBeamZ0 = -999 * CLHEP::m;
186   /// Sigma of Gaussian momentum spread
187   G4double fMomentumGaussianSpread = 0;
188 
189 #ifdef WITHROOT
190   /// Flag indicating if primaries should be read from file instead of using
191   /// the particle gun
192   G4bool fReadInputFile = false;
193   /// Path to the input file
194   G4String fPathInputFile = "";
195   /// ID of the first event in the file to be used in this simulation
196   G4int fStartFromEvent = 0;
197   /// Counter of event
198   G4int fEventCounter = -1;
199   /// Pointer to the input file
200   TFile *fInputFile = nullptr;
201   /// Pointer to the tree containing particles
202   TTreeReader *fHgcalReader = nullptr;
203   /// Reader of event ID
204   TTreeReaderValue<Float_t> *fHgcalEventId;
205   /// Reader of particle PDG
206   TTreeReaderValue<Float_t> *fHgcalPdgId;
207   /// Reader of particle X position (in mm)
208   TTreeReaderValue<Float_t> *fHgcalPosX;
209   /// Reader of particle Y position (in mm)
210   TTreeReaderValue<Float_t> *fHgcalPosY;
211   /// Reader of particle Z position (in mm)
212   // TTreeReaderValue<Float_t> *fHgcalPosZ;
213   /// Reader of particle X momentum (in MeV)
214   TTreeReaderValue<Float_t> *fHgcalMomX;
215   /// Reader of particle Y momentum (in MeV)
216   TTreeReaderValue<Float_t> *fHgcalMomY;
217   /// Reader of particle Z momentum (in MeV)
218   TTreeReaderValue<Float_t> *fHgcalMomZ;
219 #endif
220 };
221 
222 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
223 
224 #endif
225