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
GammaRayTelDigi.hh
Go to the documentation of this file.
Or view
the newest version in sPHENIX GitHub for file GammaRayTelDigi.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
//
27
// ------------------------------------------------------------
28
// GEANT 4 class header file
29
// CERN Geneva Switzerland
30
//
31
//
32
// ------------ GammaRayTelDigi ------
33
// by F.Longo, R.Giannitrapani & G.Santin (24 oct 2001)
34
//
35
// ************************************************************
36
// This Class describe the digits
37
38
#ifndef GammaRayTelDigi_h
39
#define GammaRayTelDigi_h 1
40
41
#include "
G4VDigi.hh
"
42
#include "
G4TDigiCollection.hh
"
43
#include "
G4Allocator.hh
"
44
#include "
G4ThreeVector.hh
"
45
46
47
//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
48
49
class
GammaRayTelDigi
:
public
G4VDigi
50
{
51
52
public
:
53
54
GammaRayTelDigi
();
55
~GammaRayTelDigi
();
56
GammaRayTelDigi
(
const
GammaRayTelDigi
&);
57
const
GammaRayTelDigi
&
operator=
(
const
GammaRayTelDigi
&);
58
G4bool
operator==
(
const
GammaRayTelDigi
&)
const
;
59
60
inline
void
*
operator
new
(size_t);
61
inline
void
operator
delete
(
void
*);
62
63
void
Draw
();
64
void
Print
();
65
66
private
:
67
68
G4int
PlaneNumber
;
// (active detector)
69
G4int
PlaneType
;
// (0 or 1 for X or Y plane)
70
G4int
StripNumber
;
// strip number
71
G4int
DigiType
;
// (0 == TKR, 1 == CAL, 2 == ACD)
72
G4double
Energy
;
// only for CAL
73
74
public
:
75
76
inline
void
SetPlaneNumber
(
G4int
PlaneNum) {
PlaneNumber
= PlaneNum;};
77
inline
void
SetPlaneType
(
G4int
PlaneTyp) {
PlaneType
= PlaneTyp;};
78
inline
void
SetStripNumber
(
G4int
StripNum) {
StripNumber
= StripNum;};
79
inline
void
SetDigiType
(
G4int
DigiID) {
DigiType
= DigiID;};
80
inline
void
SetEnergy
(
G4double
Ene) {
Energy
= Ene;};
81
82
inline
G4int
GetPlaneNumber
() {
return
PlaneNumber
;};
83
inline
G4int
GetPlaneType
() {
return
PlaneType
;};
84
inline
G4int
GetStripNumber
() {
return
StripNumber
;};
85
inline
G4int
GetDigiType
() {
return
DigiType
;};
86
inline
G4double
GetEnergy
() {
return
Energy
;};
87
88
89
};
90
91
//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
92
93
typedef
G4TDigiCollection<GammaRayTelDigi>
GammaRayTelDigitsCollection
;
94
95
extern
G4ThreadLocal
G4Allocator<GammaRayTelDigi>
*
GammaRayTelDigiAllocator
;
96
97
//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
98
99
inline
void
* GammaRayTelDigi::operator
new
(size_t)
100
{
101
if
(!
GammaRayTelDigiAllocator
)
102
GammaRayTelDigiAllocator
=
new
G4Allocator<GammaRayTelDigi>
;
103
return
(
void
*)
GammaRayTelDigiAllocator
->MallocSingle();
104
}
105
106
//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
107
108
inline
void
GammaRayTelDigi::operator
delete
(
void
* aDigi)
109
{
110
GammaRayTelDigiAllocator
->FreeSingle((
GammaRayTelDigi
*) aDigi);
111
}
112
113
#endif
114
115
116
117
118
119
120
121
122
geant4
tree
geant4-10.6-release
examples
advanced
gammaray_telescope
include
GammaRayTelDigi.hh
Built by
Jin Huang
. updated:
Wed Jun 29 2022 17:24:58
using
1.8.2 with
ECCE GitHub integration