Belle II Software  release-08-01-10
SensitiveDetector.cc
1 /**************************************************************************
2  * basf2 (Belle II Analysis Software Framework) *
3  * Author: The Belle II Collaboration *
4  * *
5  * See git log for contributors and copyright holders. *
6  * This file is licensed under LGPL-3.0, see LICENSE.md. *
7  **************************************************************************/
8 
9 #include <beast/pindiode/simulation/SensitiveDetector.h>
10 #include <beast/pindiode/dataobjects/PindiodeSimHit.h>
11 
12 #include <framework/datastore/StoreArray.h>
13 #include <framework/datastore/RelationArray.h>
14 
15 #include <G4Track.hh>
16 #include <G4Step.hh>
17 
18 namespace Belle2 {
24  namespace pindiode {
25 
27  Simulation::SensitiveDetectorBase("PindiodeSensitiveDetector", Const::invalidDetector)
28  {
29  m_hitNum = 0;
30  m_EvnetNumber = 0;
31  m_oldEvnetNumber = 0;
32  m_trackID = 0;
33  m_startTime = 0;
34  m_endTime = 0;
35  m_WightedTime = 0;
36  m_startEnergy = 0;
37  m_energyDeposit = 0;
38  m_trackLength = 0;
39  iECLCell = 0;
40  TimeIndex = 0;
41  local_pos = 0;
42  T_ave = 0;
43  firstcall = 0;
44  m_phiID = 0;
45  m_thetaID = 0;
46  m_cellID = 0;
47 
48  //Make sure all collections are registered
49  StoreArray<MCParticle> mcParticles;
51  RelationArray relMCSimHit(mcParticles, simHits);
52 
53  //Register all collections we want to modify and require those we want to use
54  mcParticles.registerInDataStore();
55  simHits.registerInDataStore();
56  relMCSimHit.registerInDataStore();
57 
58  //Register the Relation so that the TrackIDs get replaced by the actual
59  //MCParticle indices after simulating the events. This is needed as
60  //secondary particles might not be stored so everything relating to those
61  //particles will be attributed to the last saved mother particle
62  registerMCParticleRelation(relMCSimHit);
63  }
64 
66  {
67 
68  }
69 
70  bool SensitiveDetector::step(G4Step* step, G4TouchableHistory*)
71  {
72  const G4StepPoint& preStep = *step->GetPreStepPoint();
73  const G4StepPoint& postStep = *step->GetPostStepPoint();
74 
75  G4Track& track = *step->GetTrack();
76  if (m_trackID != track.GetTrackID()) {
77  //TrackID changed, store track informations
78  m_trackID = track.GetTrackID();
79  //Get momentum
80  m_momentum = preStep.GetMomentum() ;
81  //Get energy
82  m_startEnergy = preStep.GetKineticEnergy() ;
83  //Reset energy deposit;
84  m_energyDeposit = 0;
85  //Reset Wighted Time;
86  m_WightedTime = 0;
87  //Reset m_WightedPos;
88  m_WightedPos.SetXYZ(0, 0, 0);
89 
90  }
91  //Update energy deposit
92  m_energyDeposit += step->GetTotalEnergyDeposit() ;
93 
94  m_startTime = preStep.GetGlobalTime();
95  m_endTime = postStep.GetGlobalTime();
96  m_WightedTime += (m_startTime + m_endTime) / 2 * (step->GetTotalEnergyDeposit());
97 
98  m_startPos = preStep.GetPosition();
99  m_endPos = postStep.GetPosition();
100  TVector3 position((m_startPos.getX() + m_endPos.getX()) / 2 / CLHEP::cm, (m_startPos.getY() + m_endPos.getY()) / 2 / CLHEP::cm,
101  (m_startPos.getZ() + m_endPos.getZ()) / 2 / CLHEP::cm);
102  m_WightedPos += position * (step->GetTotalEnergyDeposit());
103 
104  //Save Hit if track leaves volume or is killed
105  if (track.GetNextVolume() != track.GetVolume() || track.GetTrackStatus() >= fStopAndKill) {
106  int pdgCode = track.GetDefinition()->GetPDGEncoding();
107 
108  //const G4VPhysicalVolume& v = * track.GetVolume();
109  //G4ThreeVector posCell = v.GetTranslation();
110  // Get layer ID
111 
112  //if (v.GetName().find("Crystal") != std::string::npos) {
113  //CsiGeometryPar* eclp = CsiGeometryPar::Instance();
114  m_cellID = step->GetTrack()->GetVolume()->GetCopyNo();
115 
116  double dTotalEnergy = 1 / m_energyDeposit; //avoid the error no match for 'operator/'
117  if (m_energyDeposit > 0.) {
119  m_energyDeposit, m_momentum, m_WightedPos * dTotalEnergy);
120  //}
121  }
122 
123  //Reset TrackID
124  m_trackID = 0;
125  }
126 
127  return true;
128  }
129  /*
130  //Get Track information
131  const G4Track& track = *step->GetTrack();
132  const int trackID = track.GetTrackID();
133  const double depEnergy = step->GetTotalEnergyDeposit() * CLHEP::MeV;
134  const double nielEnergy = step->GetNonIonizingEnergyDeposit() * CLHEP::MeV;
135  const G4ThreeVector G4tkPos = step->GetTrack()->GetPosition();
136  float tkPos[3];
137  tkPos[0] = G4tkPos.x() * CLHEP::cm;
138  tkPos[1] = G4tkPos.y() * CLHEP::cm;
139  tkPos[2] = G4tkPos.z() * CLHEP::cm;
140  const G4ThreeVector G4tkMom = step->GetTrack()->GetMomentum();
141  float tkMom[3];
142  tkMom[0] = G4tkMom.x() * CLHEP::MeV;
143  tkMom[1] = G4tkMom.y() * CLHEP::MeV;
144  tkMom[2] = G4tkMom.z() * CLHEP::MeV;
145  const G4ThreeVector G4tkMomDir = step->GetTrack()->GetMomentumDirection();
146  float tkMomDir[3];
147  tkMomDir[0] = G4tkMomDir.x() * CLHEP::MeV;
148  tkMomDir[1] = G4tkMomDir.y() * CLHEP::MeV;
149  tkMomDir[2] = G4tkMomDir.z() * CLHEP::MeV;
150  const int tkPDG = step->GetTrack()->GetDefinition()->GetPDGEncoding();
151  const double tkKEnergy = step->GetTrack()->GetKineticEnergy();
152  const int detNb = step->GetTrack()->GetVolume()->GetCopyNo();
153  const double GlTime = step->GetPreStepPoint()->GetGlobalTime();
154  //Ignore everything below 1eV
155  if (depEnergy < CLHEP::eV) return false;
156 
157  //Get the datastore arrays
158  StoreArray<MCParticle> mcParticles;
159  StoreArray<PindiodeSimHit> simHits;
160  RelationArray relMCSimHit(mcParticles, simHits);
161 
162  StoreArray<PindiodeSimHit> PindiodeHits;
163  if (!PindiodeHits.isValid()) PindiodeHits.create();
164  PindiodeSimHit* hit = PindiodeHits.appendNew(
165  depEnergy,
166  nielEnergy,
167  tkPDG,
168  tkKEnergy,
169  detNb,
170  GlTime,
171  tkPos,
172  tkMom,
173  tkMomDir
174  );
175 
176  //Add Relation between SimHit and MCParticle with a weight of 1. Since
177  //the MCParticle index is not yet defined we use the trackID from Geant4
178  relMCSimHit.add(trackID, hit->getArrayIndex(), 1.0);
179 
180  return true;
181  }
182  */
183 
185  const G4int cellId,
186  const G4int trackID,
187  const G4int pid,
188  const G4double tof,
189  const G4double edep,
190  G4ThreeVector mom,
191  TVector3 posAve)
192  {
193 
194  //Get the datastore arraus
195  StoreArray<MCParticle> mcParticles;
197  RelationArray relMPindiodemHit(mcParticles, simHits);
198 
199  StoreArray<PindiodeSimHit> PindiodeHits;
200  RelationArray pindiodeSimHitRel(mcParticles, PindiodeHits);
201  TVector3 momentum(mom.getX() / CLHEP::GeV, mom.getY() / CLHEP::GeV, mom.getZ() / CLHEP::GeV);
202  PindiodeHits.appendNew(cellId, trackID, pid, tof / CLHEP::ns, edep / CLHEP::GeV, momentum, posAve);
203  int simhitNumber = PindiodeHits.getEntries() - 1;
204  B2DEBUG(150, "HitNumber: " << simhitNumber);
205  pindiodeSimHitRel.add(trackID, simhitNumber);
206  return (simhitNumber);
207  }//saveSimHit
208 
209 
210  } //pindiode namespace
212 } //Belle2 namespace
This class provides a set of constants for the framework.
Definition: Const.h:34
Low-level class to create/modify relations between StoreArrays.
Definition: RelationArray.h:62
void add(index_type from, index_type to, weight_type weight=1.0)
Add a new element to the relation.
static void registerMCParticleRelation(const std::string &name, RelationArray::EConsolidationAction ignoreAction=RelationArray::c_negativeWeight)
Register an relation involving MCParticles.
bool registerInDataStore(DataStore::EStoreFlags storeFlags=DataStore::c_WriteOut)
Register the object/array in the DataStore.
T * appendNew()
Construct a new T object at the end of the array.
Definition: StoreArray.h:246
int getEntries() const
Get the number of objects in the array.
Definition: StoreArray.h:216
int m_thetaID
The current phi ID in an event.
double m_energyDeposit
particle energy at the entrance in volume
int m_EvnetNumber
The current number of created hits in an event.
int TimeIndex
Hit Energy of StoreArray.
int m_trackID
The current number of created hits in an event.
TVector3 m_WightedPos
Position of poststep.
int m_hitNum
members of SensitiveDetector
int firstcall
flight time to diode sensor
double T_ave
position alongthe vector of crystal axis
double local_pos
vector of crystal axis
G4ThreeVector m_momentum
Wighted step Position.
int m_cellID
The current theta ID in an event.
double m_startTime
momentum of track
int iECLCell
length of the track in the volume
double m_trackLength
energy deposited in volume
int m_oldEvnetNumber
The current number of created hits in an event.
G4ThreeVector m_endPos
Position of prestep.
bool step(G4Step *step, G4TouchableHistory *) override
Step processing method.
int saveSimHit(const G4int cellId, const G4int trackID, const G4int pid, const G4double tof, const G4double edep, G4ThreeVector mom, TVector3 WightedPos)
Save PindiodeSimHit into datastore.
Abstract base class for different kinds of events.