Loading...
Searching...
No Matches
Par04EventAction.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#ifndef PAR04EVENTACTION_HH
27#define PAR04EVENTACTION_HH
28
29#include <G4Types.hh> // for G4int, G4double
30#include <vector> // for vector
31#include "G4Timer.hh" // for G4Timer
32#include "G4UserEventAction.hh" // for G4UserEventAction
33class G4Event;
36
37/**
38 * @brief Event action class for hits' analysis.
39 *
40 * Analysis of single-particle events and developed showers in the detector.
41 * At the end of the event basic variables are calculated and saved in the
42 * histograms.
43 * Additionally ntuple with cell energies and IDs (in cylindrical coordinates) is stored.
44 *
45 */
46
48{
49 public:
52
53 /// Timer is started
54 virtual void BeginOfEventAction(const G4Event* aEvent) final;
55 /// Hits collection is retrieved, analysed, and histograms are filled.
56 virtual void EndOfEventAction(const G4Event* aEvent) final;
57 inline std::vector<G4double>& GetCalEdep() { return fCalEdep; }
58 inline std::vector<G4int>& GetCalRho() { return fCalRho; }
59 inline std::vector<G4int>& GetCalPhi() { return fCalPhi; }
60 inline std::vector<G4int>& GetCalZ() { return fCalZ; }
61 inline std::vector<G4double>& GetPhysicalCalEdep() { return fCalPhysicalEdep; }
62 inline std::vector<G4int>& GetPhysicalCalLayer() { return fCalPhysicalLayer; }
63 inline std::vector<G4int>& GetPhysicalCalSlice() { return fCalPhysicalSlice; }
64 inline std::vector<G4int>& GetPhysicalCalRow() { return fCalPhysicalRow; }
65 void StartTimer();
66 void StopTimer();
67 private:
68 /// ID of a hit collection to analyse
69 G4int fHitCollectionID = -1;
72 /// Timer measurement from Geant4
74 /// Pointer to detector construction to retrieve (once) the detector
75 /// dimensions and size of readout
78 /// Size of cell along Z axis
79 G4double fCellSizeZ = 0;
80 /// Size of cell along radius of cylinder
81 G4double fCellSizeRho = 0;
82 /// Size of cell in azimuthal angle
83 G4double fCellSizePhi = 0;
84 /// Number of readout cells along radius
85 G4int fCellNbRho = 0;
86 /// Number of readout cells in azimuthal angle
87 G4int fCellNbPhi = 0;
88 /// Number of readout cells along z axis
89 G4int fCellNbZ = 0;
90 /// Number of physical readout layers
92 /// Number of physical readout slices
94 /// Number of physical readout rows
95 G4int fPhysicalNbRows = 0;
96 /// Cell energy deposits to be stored in ntuple
97 std::vector<G4double> fCalEdep;
98 /// Cell ID of radius to be stored in ntuple
99 std::vector<G4int> fCalRho;
100 /// Cell ID of azimuthal angle to be stored in ntuple
101 std::vector<G4int> fCalPhi;
102 /// Cell ID of z axis to be stored in ntuple
103 std::vector<G4int> fCalZ;
104 /// Physical cell energy deposits to be stored in ntuple
105 std::vector<G4double> fCalPhysicalEdep;
106 /// Physical layer ID to be stored in ntuple
107 std::vector<G4int> fCalPhysicalLayer;
108 /// Physical slice ID to be stored in ntuple
109 std::vector<G4int> fCalPhysicalSlice;
110 /// Physical row ID to be stored in ntuple
111 std::vector<G4int> fCalPhysicalRow;
112};
113
114#endif /* PAR04EVENTACTION_HH */
Event action class for hits' analysis.
std::vector< G4int > fCalZ
Cell ID of z axis to be stored in ntuple.
G4double fCellSizePhi
Size of cell in azimuthal angle.
virtual void BeginOfEventAction(const G4Event *aEvent) final
Timer is started.
G4int fHitCollectionID
ID of a hit collection to analyse.
std::vector< G4int > fCalPhi
Cell ID of azimuthal angle to be stored in ntuple.
G4int fCellNbRho
Number of readout cells along radius.
std::vector< G4int > fCalPhysicalRow
Physical row ID to be stored in ntuple.
std::vector< G4int > & GetPhysicalCalSlice()
std::vector< G4int > & GetCalZ()
std::vector< G4int > & GetCalPhi()
virtual ~Par04EventAction()
G4int fCellNbZ
Number of readout cells along z axis.
G4int fPhysicalNbRows
Number of physical readout rows.
std::vector< G4double > fCalPhysicalEdep
Physical cell energy deposits to be stored in ntuple.
G4double fCellSizeRho
Size of cell along radius of cylinder.
Par04DetectorConstruction * fDetector
Pointer to detector construction to retrieve (once) the detector dimensions and size of readout.
G4int fPhysicalNbLayers
Number of physical readout layers.
G4double fCellSizeZ
Size of cell along Z axis.
std::vector< G4int > & GetCalRho()
std::vector< G4int > fCalRho
Cell ID of radius to be stored in ntuple.
G4Timer fTimer
Timer measurement from Geant4.
std::vector< G4double > & GetCalEdep()
G4int fPhysicalNbSlices
Number of physical readout slices.
std::vector< G4double > fCalEdep
Cell energy deposits to be stored in ntuple.
std::vector< G4int > fCalPhysicalLayer
Physical layer ID to be stored in ntuple.
virtual void EndOfEventAction(const G4Event *aEvent) final
Hits collection is retrieved, analysed, and histograms are filled.
std::vector< G4int > & GetPhysicalCalRow()
std::vector< G4double > & GetPhysicalCalEdep()
std::vector< G4int > & GetPhysicalCalLayer()
std::vector< G4int > fCalPhysicalSlice
Physical slice ID to be stored in ntuple.
G4int fCellNbPhi
Number of readout cells in azimuthal angle.
Par04ParallelFullWorld * fParallel

Applications | User Support | Publications | Collaboration