ECCE @ EIC Software
Reference for
ECCE @ EIC
simulation and reconstruction software on GitHub
Home page
Related Pages
Modules
Namespaces
Classes
Files
External Links
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
HadrontherapyEventAction.hh
Go to the documentation of this file.
Or view
the newest version in sPHENIX GitHub for file HadrontherapyEventAction.hh
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
// Hadrontherapy advanced example for Geant4
27
// See more at: https://twiki.cern.ch/twiki/bin/view/Geant4/AdvancedExamplesHadrontherapy
28
29
#ifndef HadrontherapyEventAction_h
30
#define HadrontherapyEventAction_h 1
31
32
#include "
G4UserEventAction.hh
"
33
#include "
globals.hh
"
34
35
class
HadrontherapyMatrix
;
36
class
HadrontherapyEventActionMessenger
;
37
38
class
HadrontherapyEventAction
:
public
G4UserEventAction
39
{
40
public
:
41
HadrontherapyEventAction
();
42
~HadrontherapyEventAction
();
43
44
public
:
45
void
BeginOfEventAction
(
const
G4Event
*);
46
void
EndOfEventAction
(
const
G4Event
*);
47
48
void
SetPrintModulo
(
G4int
val)
49
{
50
printModulo
= val;
51
};
52
53
void
SetDrawFlag
(
G4String
val)
54
{
55
drawFlag
= val;
56
};
57
58
private
:
59
G4String
drawFlag
;
//Visualisation flag
60
G4int
hitsCollectionID
;
61
//HadrontherapyMatrix *matrix;
62
G4int
printModulo
;
63
HadrontherapyEventActionMessenger
*
pointerEventMessenger
;
64
};
65
66
class
B4aEventAction
:
public
G4UserEventAction
67
{
68
public
:
69
B4aEventAction
();
70
virtual
~B4aEventAction
();
71
72
virtual
void
BeginOfEventAction
(
const
G4Event
* event);
73
virtual
void
EndOfEventAction
(
const
G4Event
* event);
74
75
void
AddAbs
(
G4double
de,
G4double
dl);
76
void
AddGap
(
G4double
de,
G4double
dl);
77
78
private
:
79
G4double
fEnergyAbs
;
80
G4double
fEnergyGap
;
81
G4double
fTrackLAbs
;
82
G4double
fTrackLGap
;
83
};
84
85
// inline functions
86
87
inline
void
B4aEventAction::AddAbs
(
G4double
de,
G4double
dl) {
88
fEnergyAbs
+= de;
89
fTrackLAbs
+= dl;
90
}
91
92
inline
void
B4aEventAction::AddGap
(
G4double
de,
G4double
dl) {
93
fEnergyGap
+= de;
94
fTrackLGap
+= dl;
95
}
96
97
98
#endif
99
100
101
geant4
tree
geant4-10.6-release
examples
advanced
hadrontherapy
include
HadrontherapyEventAction.hh
Built by
Jin Huang
. updated:
Wed Jun 29 2022 17:24:58
using
1.8.2 with
ECCE GitHub integration