CMS 3D CMS Logo

TrackerG4SimHitNumberingScheme.cc
Go to the documentation of this file.
5 
6 #include "G4TransportationManager.hh"
7 #include "G4Navigator.hh"
8 #include "G4VTouchable.hh"
9 #include "G4TouchableHistory.hh"
10 #include "G4VSensitiveDetector.hh"
11 
12 //#define EDM_ML_DEBUG
13 
15  : alreadySet_(false), geomDet_(&det) {}
16 
18  if (alreadySet_)
19  return;
20  alreadySet_ = true;
21 
22  G4Navigator* theStdNavigator = G4TransportationManager::GetTransportationManager()->GetNavigatorForTracking();
23  G4Navigator theNavigator;
24  theNavigator.SetWorldVolume(theStdNavigator->GetWorldVolume());
25 
26  std::vector<const GeometricDet*> allSensitiveDets;
27  geomDet_->deepComponents(allSensitiveDets);
28  edm::LogVerbatim("TrackerSimInfoNumbering")
29  << " TouchableTo History: got " << allSensitiveDets.size() << " sensitive detectors from GeometricDet.";
30 
31  for (auto& theSD : allSensitiveDets) {
32  auto const& t = theSD->translation();
33  theNavigator.LocateGlobalPointAndSetup(G4ThreeVector(t.x(), t.y(), t.z()));
34  G4TouchableHistory* hist = theNavigator.CreateTouchableHistory();
36  touchToNavStory(hist, st);
37 
38  directMap_[st] = theSD->geographicalId();
39 
40  LogDebug("TrackerSimDebugNumbering") << " INSERTING LV " << hist->GetVolume()->GetLogicalVolume()->GetName()
41  << " SD: "
42  << hist->GetVolume()->GetLogicalVolume()->GetSensitiveDetector()->GetName()
43  << " Now size is " << directMap_.size();
44  delete hist;
45  }
46  edm::LogVerbatim("TrackerSimInfoNumbering")
47  << " TrackerG4SimHitNumberingScheme: mapped " << directMap_.size() << " detectors to Geant4.";
48 
49  if (directMap_.size() != allSensitiveDets.size()) {
50  edm::LogError("TrackerSimInfoNumbering") << " ERROR: GeomDet sensitive detectors do not match Geant4 ones.";
51  throw cms::Exception("TrackerG4SimHitNumberingScheme::buildAll")
52  << " cannot resolve structure of tracking sensitive detectors";
53  }
54 }
55 
58 #ifdef EDM_ML_DEBUG
59  std::vector<int> debugint;
60  std::vector<std::string> debugstring;
61 #endif
62  int levels = v->GetHistoryDepth();
63 
64  for (int k = 0; k <= levels; ++k) {
65  if (DD4hep2DDDName::noNameSpace(static_cast<std::string>(v->GetVolume(k)->GetLogicalVolume()->GetName())) !=
66  "TOBInactive") {
67  st.emplace_back(std::pair<int, std::string>(
68  v->GetVolume(k)->GetCopyNo(),
69  DD4hep2DDDName::noNameSpace(static_cast<std::string>(v->GetVolume(k)->GetLogicalVolume()->GetName()))));
70 #ifdef EDM_ML_DEBUG
71  debugint.emplace_back(v->GetVolume(k)->GetCopyNo());
72  debugstring.emplace_back(v->GetVolume(k)->GetLogicalVolume()->GetName());
73 #endif
74  }
75  }
76 #ifdef EDM_ML_DEBUG
77  edm::LogVerbatim("TrackerSimDebugNumbering") << " G4 TrackerG4SimHitNumberingScheme " << debugint.size();
78  for (u_int32_t jj = 0; jj < debugstring.size(); jj++)
79  edm::LogVerbatim("TrackerSimDebugNumbering") << " " << debugstring[jj];
80 #endif
81 }
82 
83 unsigned int TrackerG4SimHitNumberingScheme::g4ToNumberingScheme(const G4VTouchable* v) {
84  if (alreadySet_ == false) {
85  buildAll();
86  }
88  touchToNavStory(v, st);
89 
90 #ifdef EDM_ML_DEBUG
91  dumpG4VPV(v);
92  edm::LogVerbatim("TrackerSimDebugNumbering") << " Returning: " << directMap_[st];
93 #endif
94 
95  return directMap_[st];
96 }
97 
98 void TrackerG4SimHitNumberingScheme::dumpG4VPV(const G4VTouchable* v) {
99  int levels = v->GetHistoryDepth();
100 
101  edm::LogVerbatim("TrackerSimDebugNumbering") << " NAME : " << v->GetVolume()->GetLogicalVolume()->GetName();
102  for (int k = 0; k <= levels; k++) {
103  edm::LogVerbatim("TrackerSimInfoNumbering")
104  << " Hist: " << v->GetVolume(k)->GetLogicalVolume()->GetName() << " Copy " << v->GetVolume(k)->GetCopyNo();
105  }
106 }
Log< level::Info, true > LogVerbatim
Log< level::Error, false > LogError
unsigned int g4ToNumberingScheme(const G4VTouchable *)
std::vector< std::pair< int, std::string > > Nav_Story
ConstGeometricDetContainer deepComponents() const
std::string noNameSpace(const std::string &name)
void touchToNavStory(const G4VTouchable *, Nav_Story &)
#define LogDebug(id)