CMS 3D CMS Logo

SiStripRegionConnectivity.cc
Go to the documentation of this file.
13 
14 using namespace sistrip;
15 
17 public:
19  ~SiStripRegionConnectivity() override;
20 
21  std::unique_ptr<SiStripRegionCabling> produceRegionCabling(const SiStripRegionCablingRcd&);
22 
23 private:
27 
29  uint32_t etadivisions_;
30  uint32_t phidivisions_;
31 
33  double etamax_;
34 };
35 
37  :
38 
39  etadivisions_(pset.getUntrackedParameter<unsigned int>("EtaDivisions", 10)),
40  phidivisions_(pset.getUntrackedParameter<unsigned int>("PhiDivisions", 10)),
41  etamax_(pset.getUntrackedParameter<double>("EtaMax", 2.4))
42 
43 {
45  .setConsumes(detcablingToken_)
46  .setConsumes(tkgeomToken_)
47  .setConsumes(tTopoToken_);
48 }
49 
51 
52 std::unique_ptr<SiStripRegionCabling> SiStripRegionConnectivity::produceRegionCabling(
53  const SiStripRegionCablingRcd& iRecord) {
54  const auto& detcabling = iRecord.get(detcablingToken_);
55  const auto& tkgeom = iRecord.get(tkgeomToken_);
56  const auto& tTopo = iRecord.get(tTopoToken_);
57 
58  //here build an object of type SiStripRegionCabling using the information from class SiStripDetCabling **PLUS** the geometry.
59 
60  //Construct region cabling object
61  auto RegionConnections = std::make_unique<SiStripRegionCabling>(etadivisions_, phidivisions_, etamax_);
62 
63  //Construct region cabling map
64  SiStripRegionCabling::Cabling regioncabling(
65  etadivisions_ * phidivisions_,
69 
70  //Loop det cabling
71  for (const auto& idet : detcabling.getDetCabling()) {
72  if (!idet.first || (idet.first == sistrip::invalid32_))
73  continue;
74 
75  // Check if geom det unit exists
76  auto geom_det = tkgeom.idToDetUnit(DetId(idet.first));
77  auto strip_det = dynamic_cast<StripGeomDetUnit const*>(geom_det);
78  if (!strip_det) {
79  continue;
80  }
81 
82  //Calculate region from geometry
83  double eta = tkgeom.idToDet(DetId(idet.first))->position().eta();
84  double phi = tkgeom.idToDet(DetId(idet.first))->position().phi().value();
85  uint32_t reg = RegionConnections->region(SiStripRegionCabling::Position(eta, phi));
86 
87  //Find subdet from det-id
88  uint32_t subdet = static_cast<uint32_t>(SiStripRegionCabling::subdetFromDetId(idet.first));
89 
90  //Find layer from det-id
91  uint32_t layer = tTopo.layer(idet.first);
92 
93  //@@ BELOW IS TEMP FIX TO HANDLE BUG IN DET CABLING
94  const std::vector<const FedChannelConnection*>& conns = idet.second;
95 
96  //Update region cabling map
97  regioncabling[reg][subdet][layer].push_back(SiStripRegionCabling::Element());
98  auto& elem = regioncabling[reg][subdet][layer].back();
99  elem.first = idet.first;
100  elem.second.resize(conns.size());
101  for (const auto& iconn : conns) {
102  if ((iconn != nullptr) && (iconn->apvPairNumber() < conns.size())) {
103  elem.second[iconn->apvPairNumber()] = *iconn;
104  }
105  }
106  }
107 
108  //Add map to region cabling object
109  RegionConnections->setRegionCabling(regioncabling);
110 
111  return RegionConnections;
112 }
113 
edm::ESGetToken< TrackerGeometry, TrackerDigiGeometryRecord > tkgeomToken_
auto setWhatProduced(T *iThis, const es::Label &iLabel={})
Definition: ESProducer.h:138
SiStripRegionConnectivity(const edm::ParameterSet &)
std::pair< uint32_t, std::vector< FedChannelConnection > > Element
static const uint32_t invalid32_
Definition: Constants.h:15
std::vector< Element > ElementCabling
sistrip classes
ProductT const & get(ESGetToken< ProductT, DepRecordT > const &iToken) const
static const SubDet subdetFromDetId(const uint32_t detid)
std::vector< RegionCabling > Cabling
edm::ESGetToken< SiStripDetCabling, SiStripDetCablingRcd > detcablingToken_
def elem(elemtype, innerHTML='', html_class='', kwargs)
Definition: HTMLExport.py:19
Definition: DetId.h:17
#define DEFINE_FWK_EVENTSETUP_MODULE(type)
Definition: ModuleFactory.h:60
std::pair< double, double > Position
edm::ESGetToken< TrackerTopology, TrackerTopologyRcd > tTopoToken_
std::vector< WedgeCabling > RegionCabling
std::unique_ptr< SiStripRegionCabling > produceRegionCabling(const SiStripRegionCablingRcd &)
std::vector< ElementCabling > WedgeCabling