ATLAS Offline Software
PixelSensorGmxSD.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2023 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 //
6 // Pixel Sensitive Detector - specialisation for GeoModelXml
7 // The Hits are processed here. For every hit I get the position and
8 // an information on the sensor in which the interaction happened
9 //
10 
11 // Class header
12 #include "PixelSensorGmxSD.h"
13 
14 // Athena headers
15 #include "MCTruth/TrackHelper.h"
16 
17 // Geant4 headers
18 #include "G4ChargedGeantino.hh"
19 #include "G4Geantino.hh"
20 #include "G4SDManager.hh"
21 #include "G4Step.hh"
22 #include "G4ThreeVector.hh"
23 
24 // CLHEP headers
25 #include "CLHEP/Geometry/Transform3D.h"
26 #include "CLHEP/Units/SystemOfUnits.h"
27 
28 #include <GeoModelKernel/GeoFullPhysVol.h>
29 #include <GeoModelRead/ReadGeoModel.h>
30 
32 
33 // For make unique
34 #include <memory>
35 
36 
37 PixelSensorGmxSD::PixelSensorGmxSD(const std::string& name, const std::string& hitCollectionName,GeoModelIO::ReadGeoModel * sqlreader)
38  : G4VSensitiveDetector( name )
39  , m_HitColl( hitCollectionName )
40 {
41  m_sqlreader = sqlreader;
42 }
43 
44 // Initialize from G4 - necessary to new the write handle for now
45 void PixelSensorGmxSD::Initialize(G4HCofThisEvent *)
46 {
47  if (!m_HitColl.isValid()) m_HitColl = std::make_unique<SiHitCollection>();
48 }
49 
50 
51 G4bool PixelSensorGmxSD::ProcessHits(G4Step* aStep, G4TouchableHistory* /*ROhist*/)
52 {
53  if (verboseLevel>5) G4cout << "Process Hit" << G4endl;
54 
55  G4double edep = aStep->GetTotalEnergyDeposit();
56  edep *= CLHEP::MeV;
57  if(edep==0.) {
58  if(aStep->GetTrack()->GetDefinition() != G4Geantino::GeantinoDefinition() &&
59  aStep->GetTrack()->GetDefinition() != G4ChargedGeantino::ChargedGeantinoDefinition())
60  return false;
61  }
62 
63  //use the global time. i.e. the time from the beginning of the event
64  //
65  // Get the Touchable History:
66  //
67  const G4TouchableHistory *myTouch = dynamic_cast<const G4TouchableHistory*>(aStep->GetPreStepPoint()->GetTouchable());
68  if (not myTouch) {
69  G4cout << "PixelSensorGmxSD::ProcessHits bad dynamic_cast" << G4endl;
70  return false;
71  }
72  if(verboseLevel>5){
73  for (int i=0;i<myTouch->GetHistoryDepth();i++){
74  std::string detname=myTouch->GetVolume(i)->GetLogicalVolume()->GetName();
75  int copyno=myTouch->GetVolume(i)->GetCopyNo();
76  G4cout << "Volume " <<detname <<" Copy Nr. " << copyno << G4endl;
77  }
78  }
79  //
80  // Get the hit coordinates. Start and End Point
81  //
82  G4ThreeVector coord1 = aStep->GetPreStepPoint()->GetPosition();
83  G4ThreeVector coord2 = aStep->GetPostStepPoint()->GetPosition();
84 
85  // Calculate the local step begin and end position.
86  // From a G4 FAQ:
87  // http://geant4-hn.slac.stanford.edu:5090/HyperNews/public/get/geometry/17/1.html
88  //
89  const G4AffineTransform transformation = myTouch->GetHistory()->GetTopTransform();
90  G4ThreeVector localPosition1 = transformation.TransformPoint(coord1);
91  G4ThreeVector localPosition2 = transformation.TransformPoint(coord2);
92 
93  HepGeom::Point3D<double> lP1,lP2;
94  lP1[SiHit::xEta] = localPosition1[2]*CLHEP::mm;
95  lP1[SiHit::xPhi] = localPosition1[1]*CLHEP::mm;
96  lP1[SiHit::xDep] = localPosition1[0]*CLHEP::mm;
97 
98  lP2[SiHit::xEta] = localPosition2[2]*CLHEP::mm;
99  lP2[SiHit::xPhi] = localPosition2[1]*CLHEP::mm;
100  lP2[SiHit::xDep] = localPosition2[0]*CLHEP::mm;
101 
102  TrackHelper trHelp(aStep->GetTrack());
103 
104  if(m_sqlreader){
105  //if sqlite inputs, Identifier indices come from PhysVol Name
106  std::string physVolName = myTouch->GetVolume(0)->GetName();
107 
108  int hitIdOfWafer = SiHitIdHelper::GetHelper()->buildHitIdFromStringITk(0,physVolName);
109 
110 
111  m_HitColl->Emplace(lP1,
112  lP2,
113  edep,
114  aStep->GetPreStepPoint()->GetGlobalTime(),//use the global time. i.e. the time from the beginning of the event
115  trHelp.GenerateParticleLink(),
116  hitIdOfWafer);
117  return true;
118 
119  }
120  // if not from SQLite, we assume that the Identifier has already been written in as the copy number
121  // (it should have done if GeoModel building ran within Athena)
122 
123  int id = myTouch->GetVolume()->GetCopyNo();
124 
125  m_HitColl->Emplace(lP1,
126  lP2,
127  edep,
128  aStep->GetPreStepPoint()->GetGlobalTime(),
129  trHelp.GenerateParticleLink(),
130  id);
131  return true;
132 }
TrackHelper.h
python.SystemOfUnits.MeV
int MeV
Definition: SystemOfUnits.py:154
PixelSensorGmxSD::PixelSensorGmxSD
PixelSensorGmxSD(const std::string &name, const std::string &hitCollectionName, GeoModelIO::ReadGeoModel *sqlreader=nullptr)
Definition: PixelSensorGmxSD.cxx:37
SiHitIdHelper.h
TrackHelper
Definition: TrackHelper.h:14
SiHit::xDep
@ xDep
Definition: SiHit.h:162
lumiFormat.i
int i
Definition: lumiFormat.py:85
PixelSensorGmxSD::Initialize
virtual void Initialize(G4HCofThisEvent *) override final
Definition: PixelSensorGmxSD.cxx:45
PixelSensorGmxSD.h
SiHitIdHelper::buildHitIdFromStringITk
int buildHitIdFromStringITk(int part, const std::string &) const
Definition: SiHitIdHelper.cxx:131
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
SiHit::xEta
@ xEta
Definition: SiHit.h:162
python.SystemOfUnits.mm
int mm
Definition: SystemOfUnits.py:83
PixelSensorGmxSD::ProcessHits
virtual G4bool ProcessHits(G4Step *, G4TouchableHistory *) override final
Definition: PixelSensorGmxSD.cxx:51
SiHitIdHelper::GetHelper
static const SiHitIdHelper * GetHelper()
Definition: SiHitIdHelper.cxx:19
SiHit::xPhi
@ xPhi
Definition: SiHit.h:162
PixelSensorGmxSD::m_HitColl
SG::WriteHandle< SiHitCollection > m_HitColl
Definition: PixelSensorGmxSD.h:53
TrackHelper::GenerateParticleLink
HepMcParticleLink GenerateParticleLink()
Generates a creates new HepMcParticleLink object on the stack based on GetUniqueID(),...
Definition: TrackHelper.h:35
PixelSensorGmxSD::m_sqlreader
GeoModelIO::ReadGeoModel * m_sqlreader
Definition: PixelSensorGmxSD.h:54