BOSS 7.0.4
BESIII Offline Software System
Loading...
Searching...
No Matches
Simulation/BOOST/MucSim/MucSim-00-01-03/MucSim/BesMucHit.hh
Go to the documentation of this file.
1//---------------------------------------------------------------------------//
2// BOOST --- BESIII Object_Oriented Simulation Tool //
3//---------------------------------------------------------------------------//
4//Description: Hit in MUC
5//Author: Youzy Peking University mail: [email protected]
6//Created: Nov, 2003
7//Modified:
8//Comment:
9//---------------------------------------------------------------------------//
10
11//
12// $Id: BesMucHit.hh,v 1.3 2009/08/25 13:33:54 xieyg Exp $
13// GEANT4 tag $Name: MucSim-00-01-03 $
14
15#ifndef BesMucHit_h
16#define BesMucHit_h 1
17
18#include "G4VHit.hh"
19#include "G4THitsCollection.hh"
20#include "G4Allocator.hh"
21#include "G4ThreeVector.hh"
22#include "G4VPhysicalVolume.hh"
23#include "G4LogicalVolume.hh"
24//#include "BesDetectorConstruction.hh"
25
26class BesMucHit : public G4VHit
27{
28public:
30 BesMucHit(int prt, int seg, int lay, int str, int trId, int trIndex);
31 //BesMucHit(BesDetectorConstruction*);
35 int operator==(const BesMucHit&) const;
36
37 inline void* operator new(size_t);
38 inline void operator delete(void*);
39
40 void Draw();
41 void Print();
42
43public:
44
45 void SetTrackID(G4int track) { m_TrackID = track; };
46 void SetTrackIndex(G4int index) { m_TrackIndex = index;};
47 void SetPDGCode(G4int pdg) { m_PDGCode = pdg; };
48 void SetEdep(G4double de) { m_Edep = de; };
49 void SetEnergy(G4double energy) { m_Energy = energy; };
50 void SetTime(G4double t) { m_Time = t; };
51 void SetPos(G4ThreeVector xyz) { m_Pos = xyz; };
52 void SetPosLocal(G4ThreeVector xyzLocal) { m_PosLocal = xyzLocal; };
53 void SetDir(G4ThreeVector dir) { m_Dir = dir; };
54 void SetMomentum(G4ThreeVector momentum) { m_Momentum = momentum; };
55 void SetVolume(G4VPhysicalVolume* pv);
56 void SetPart(G4int part) { m_Part = part; };
57 void SetSeg(G4int seg) { m_Seg = seg; };
58 void SetGap(G4int gap) { m_Gap = gap; };
59 void SetStrip(G4int strip) { m_Strip = strip; };
60
61
62 G4int GetTrackID() { return m_TrackID; };
63 G4int GetTrackIndex() { return m_TrackIndex;};
64 G4int GetPDGCode() { return m_PDGCode; };
65 G4double GetEdep() { return m_Edep; };
66 G4double GetEnergy() { return m_Energy; };
67 G4double GetTime() { return m_Time; };
68 G4ThreeVector GetPos() { return m_Pos; };
69 G4ThreeVector GetPosLocal() { return m_PosLocal; };
70 G4ThreeVector GetDir() { return m_Dir; };
71 G4ThreeVector GetMomentum() { return m_Momentum; };
72 G4VPhysicalVolume* GetVolume() { return m_Volume; };
73 G4String GetVolumeName() { return m_VolumeName; };
74 G4int GetPart() { return m_Part; };
75 G4int GetSeg() { return m_Seg; };
76 G4int GetGap() { return m_Gap; };
77 G4int GetStrip() { return m_Strip; };
78 G4int GetPanel() { return m_Panel; };
79 G4int GetGasChamber() { return m_GasChamber; };
80
81private:
82
83 G4int m_TrackID; // g4 track id
84 G4int m_TrackIndex; // MC truth id
85 G4int m_PDGCode;
86 G4double m_Edep;
87 G4double m_Energy;
88 G4double m_Time;
89 G4ThreeVector m_Pos;
90 G4ThreeVector m_PosLocal;
91 G4ThreeVector m_Dir;
92 G4ThreeVector m_Momentum;
93 G4VPhysicalVolume* m_Volume;
94 G4String m_VolumeName;
95 G4int m_Part;
96 G4int m_Seg;
97 G4int m_Gap;
98 G4int m_Strip;
99 G4int m_Panel;
100 G4int m_GasChamber;
101 // BesDetectorConstruction* detector;
102};
103
104typedef G4THitsCollection<BesMucHit> BesMucHitsCollection;
105
106extern G4Allocator<BesMucHit> BesMucHitAllocator;
107
108inline void* BesMucHit::operator new(size_t)
109{
110 void *aHit;
111 aHit = (void *) BesMucHitAllocator.MallocSingle();
112 return aHit;
113}
114
115inline void BesMucHit::operator delete(void *aHit)
116{
117 BesMucHitAllocator.FreeSingle((BesMucHit*) aHit);
118}
119
120#endif
121
122
**********INTEGER nmxhep !maximum number of particles DOUBLE PRECISION vhep INTEGER jdahep COMMON hepevt $ !serial number $ !number of particles $ !status code $ !particle ident KF $ !parent particles $ !childreen particles $ !four momentum
************Class m_ypar INTEGER m_KeyWgt INTEGER m_KeyIHVP INTEGER m_KeyGPS INTEGER m_IsBeamPolarized INTEGER m_EvtGenInterface DOUBLE PRECISION m_Emin DOUBLE PRECISION m_sphot DOUBLE PRECISION m_Xenph DOUBLE PRECISION m_q2 DOUBLE PRECISION m_PolBeam2 DOUBLE PRECISION m_xErrPb *COMMON c_KK2f $ !CMS energy average $ !Spin Polarization vector first beam $ !Spin Polarization vector second beam $ !Beam energy spread[GeV] $ !minimum hadronization energy[GeV] $ !input READ never touch them !$ !debug facility $ !maximum weight $ !inverse alfaQED $ !minimum real photon energy
Definition: KK2f.h:50
#define prt(n)
G4Allocator< BesMucHit > BesMucHitAllocator
Definition: BesMucHit.cc:23
G4THitsCollection< BesMucHit > BesMucHitsCollection
BesMucHit(const BesMucHit &)
void SetVolume(G4VPhysicalVolume *pv)
BesMucHit(int prt, int seg, int lay, int str, int trId, int trIndex)
void Draw()
int operator==(const BesMucHit &) const
void Print()
const BesMucHit & operator=(const BesMucHit &)
int t()
Definition: t.c:1