Geant4
9.6.p02
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
geant4_9_6_p02
examples
advanced
gammaray_telescope
include
GammaRayTelTrackerHit.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
//
27
// $Id$
28
// ------------------------------------------------------------
29
// GEANT 4 class header file
30
// CERN Geneva Switzerland
31
//
32
//
33
// ------------ GammaRayTelTrackerHit ------
34
// by R.Giannitrapani, F.Longo & G.Santin (13 nov 2000)
35
//
36
// ************************************************************
37
// This Class describe the hits on the Tracker
38
39
#ifndef GammaRayTelTrackerHit_h
40
#define GammaRayTelTrackerHit_h 1
41
42
#include "
G4VHit.hh
"
43
#include "G4THitsCollection.hh"
44
#include "
G4Allocator.hh
"
45
#include "
G4ThreeVector.hh
"
46
47
48
//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
49
50
class
GammaRayTelTrackerHit
:
public
G4VHit
51
{
52
public
:
53
54
GammaRayTelTrackerHit
();
55
~GammaRayTelTrackerHit
();
56
GammaRayTelTrackerHit
(
const
GammaRayTelTrackerHit
&);
57
const
GammaRayTelTrackerHit
&
operator=
(
const
GammaRayTelTrackerHit
&);
58
int
operator==
(
const
GammaRayTelTrackerHit
&)
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
G4double
EdepSil;
// Energy deposited on the silicon strip
69
G4ThreeVector
pos;
// Position of the hit
70
G4int
NStrip;
// Number of the strip
71
G4int
NSilPlane;
// Number of the plane
72
G4int
IsXPlane;
// Type of the plane (1 X, 0 Y)
73
74
public
:
75
76
inline
void
AddSil
(
G4double
de) {EdepSil += de;};
77
inline
void
SetNStrip
(
G4int
i) {NStrip = i;};
78
inline
void
SetNSilPlane
(
G4int
i) {NSilPlane = i;};
79
inline
void
SetPlaneType
(
G4int
i) {IsXPlane = i;};
80
inline
void
SetPos
(
G4ThreeVector
xyz){ pos = xyz; }
81
82
inline
G4double
GetEdepSil
() {
return
EdepSil; };
83
inline
G4int
GetNStrip
() {
return
NStrip; };
84
inline
G4int
GetNSilPlane
() {
return
NSilPlane; };
85
inline
G4int
GetPlaneType
() {
return
IsXPlane;};
86
inline
G4ThreeVector
GetPos
() {
return
pos; };
87
88
};
89
90
//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
91
92
typedef
G4THitsCollection<GammaRayTelTrackerHit>
GammaRayTelTrackerHitsCollection
;
93
94
extern
G4Allocator<GammaRayTelTrackerHit>
GammaRayTelTrackerHitAllocator
;
95
96
//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
97
98
inline
void
* GammaRayTelTrackerHit::operator
new
(size_t)
99
{
100
void
* aHit;
101
aHit = (
void
*) GammaRayTelTrackerHitAllocator.
MallocSingle
();
102
return
aHit;
103
}
104
105
//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
106
107
inline
void
GammaRayTelTrackerHit::operator
delete
(
void
* aHit)
108
{
109
GammaRayTelTrackerHitAllocator.
FreeSingle
((
GammaRayTelTrackerHit
*) aHit);
110
}
111
112
#endif
113
114
115
116
117
118
119
120
121
Generated on Sat May 25 2013 14:32:09 for Geant4 by
1.8.4