CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Private Member Functions | Private Attributes
TrackerG4SimHitNumberingScheme Class Reference

#include <TrackerG4SimHitNumberingScheme.h>

Public Types

using DirectMapType = std::map< Nav_Story, unsigned int >
 
using Nav_Story = std::vector< std::pair< int, std::string > >
 

Public Member Functions

unsigned int g4ToNumberingScheme (const G4VTouchable *)
 
 TrackerG4SimHitNumberingScheme (const GeometricDet &)
 

Private Member Functions

void buildAll ()
 
void dumpG4VPV (const G4VTouchable *)
 
void touchToNavStory (const G4VTouchable *, Nav_Story &)
 

Private Attributes

bool alreadySet_
 
DirectMapType directMap_
 
const GeometricDetgeomDet_
 

Detailed Description

Definition at line 12 of file TrackerG4SimHitNumberingScheme.h.

Member Typedef Documentation

Definition at line 16 of file TrackerG4SimHitNumberingScheme.h.

using TrackerG4SimHitNumberingScheme::Nav_Story = std::vector<std::pair<int, std::string> >

Definition at line 15 of file TrackerG4SimHitNumberingScheme.h.

Constructor & Destructor Documentation

TrackerG4SimHitNumberingScheme::TrackerG4SimHitNumberingScheme ( const GeometricDet det)
explicit

Member Function Documentation

void TrackerG4SimHitNumberingScheme::buildAll ( )
private

Definition at line 17 of file TrackerG4SimHitNumberingScheme.cc.

References alreadySet_, GeometricDet::deepComponents(), directMap_, Exception, geomDet_, compare::hist, LogDebug, OrderedSet::t, and touchToNavStory().

Referenced by g4ToNumberingScheme().

17  {
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::LogInfo("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::LogInfo("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 }
#define LogDebug(id)
std::vector< std::pair< int, std::string > > Nav_Story
ConstGeometricDetContainer deepComponents() const
void touchToNavStory(const G4VTouchable *, Nav_Story &)
void TrackerG4SimHitNumberingScheme::dumpG4VPV ( const G4VTouchable *  v)
private

Definition at line 96 of file TrackerG4SimHitNumberingScheme.cc.

References dqmdumpme::k, jets_cff::levels, and LogDebug.

Referenced by g4ToNumberingScheme().

96  {
97  int levels = v->GetHistoryDepth();
98 
99  LogDebug("TrackerSimDebugNumbering") << " NAME : " << v->GetVolume()->GetLogicalVolume()->GetName();
100  for (int k = 0; k <= levels; k++) {
101  LogDebug("TrackerSimInfoNumbering") << " Hist: " << v->GetVolume(k)->GetLogicalVolume()->GetName() << " Copy "
102  << v->GetVolume(k)->GetCopyNo();
103  }
104 }
#define LogDebug(id)
unsigned int TrackerG4SimHitNumberingScheme::g4ToNumberingScheme ( const G4VTouchable *  v)

Definition at line 81 of file TrackerG4SimHitNumberingScheme.cc.

References alreadySet_, buildAll(), directMap_, dumpG4VPV(), LogDebug, and touchToNavStory().

Referenced by TkAccumulatingSensitiveDetector::setDetUnitId().

81  {
82  if (alreadySet_ == false) {
83  buildAll();
84  }
86  touchToNavStory(v, st);
87 
88 #ifdef DEBUG
89  dumpG4VPV(v);
90  LogDebug("TrackerSimDebugNumbering") << " Returning: " << directMap_[st];
91 #endif
92 
93  return directMap_[st];
94 }
#define LogDebug(id)
std::vector< std::pair< int, std::string > > Nav_Story
void touchToNavStory(const G4VTouchable *, Nav_Story &)
void TrackerG4SimHitNumberingScheme::touchToNavStory ( const G4VTouchable *  v,
TrackerG4SimHitNumberingScheme::Nav_Story st 
)
private

Definition at line 56 of file TrackerG4SimHitNumberingScheme.cc.

References findQualityFiles::jj, dqmdumpme::k, jets_cff::levels, and LogDebug.

Referenced by buildAll(), and g4ToNumberingScheme().

57  {
58 #ifdef 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 (v->GetVolume(k)->GetLogicalVolume()->GetName() != "TOBInactive") {
66  st.emplace_back(
67  std::pair<int, std::string>(v->GetVolume(k)->GetCopyNo(), v->GetVolume(k)->GetLogicalVolume()->GetName()));
68 #ifdef DEBUG
69  debugint.emplace_back(v->GetVolume(k)->GetCopyNo());
70  debugstring.emplace_back(v->GetVolume(k)->GetLogicalVolume()->GetName());
71 #endif
72  }
73  }
74 #ifdef DEBUG
75  LogDebug("TrackerSimDebugNumbering") << " G4 TrackerG4SimHitNumberingScheme " << debugint;
76  for (u_int32_t jj = 0; jj < debugstring.size(); jj++)
77  LogDebug("TrackerSimDebugNumbering") << " " << debugstring[jj];
78 #endif
79 }
#define LogDebug(id)

Member Data Documentation

bool TrackerG4SimHitNumberingScheme::alreadySet_
private

Definition at line 29 of file TrackerG4SimHitNumberingScheme.h.

Referenced by buildAll(), and g4ToNumberingScheme().

DirectMapType TrackerG4SimHitNumberingScheme::directMap_
private

Definition at line 28 of file TrackerG4SimHitNumberingScheme.h.

Referenced by buildAll(), and g4ToNumberingScheme().

const GeometricDet* TrackerG4SimHitNumberingScheme::geomDet_
private

Definition at line 30 of file TrackerG4SimHitNumberingScheme.h.

Referenced by buildAll().