Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2024-04-06 12:15:29

0001 #include "Geometry/TrackerNumberingBuilder/plugins/CmsTrackerSubStrctBuilder.h"
0002 #include "Geometry/TrackerNumberingBuilder/interface/GeometricDet.h"
0003 #include "Geometry/TrackerNumberingBuilder/plugins/ExtractStringFromDDD.h"
0004 #include "DataFormats/DetId/interface/DetId.h"
0005 #include "Geometry/TrackerNumberingBuilder/plugins/CmsTrackerLayerBuilder.h"
0006 #include "Geometry/TrackerNumberingBuilder/plugins/CmsTrackerOTLayerBuilder.h"
0007 #include "Geometry/TrackerNumberingBuilder/plugins/CmsTrackerWheelBuilder.h"
0008 #include "Geometry/TrackerNumberingBuilder/plugins/CmsTrackerDiskBuilder.h"
0009 #include "FWCore/MessageLogger/interface/MessageLogger.h"
0010 #include "DetectorDescription/Core/interface/DDFilteredView.h"
0011 #include "DetectorDescription/DDCMS/interface/DDFilteredView.h"
0012 #include <vector>
0013 
0014 #include <bitset>
0015 
0016 template <class FilteredView>
0017 void CmsTrackerSubStrctBuilder<FilteredView>::buildComponent(FilteredView& fv, GeometricDet* g, const std::string& s) {
0018   CmsTrackerLayerBuilder<FilteredView> theCmsTrackerLayerBuilder;
0019   CmsTrackerOTLayerBuilder<FilteredView> theCmsTrackerOTLayerBuilder;
0020   CmsTrackerWheelBuilder<FilteredView> theCmsTrackerWheelBuilder;
0021   CmsTrackerDiskBuilder<FilteredView> theCmsTrackerDiskBuilder;
0022 
0023   GeometricDet* subdet = new GeometricDet(&fv,
0024                                           CmsTrackerLevelBuilder<FilteredView>::theCmsTrackerStringToEnum.type(
0025                                               ExtractStringFromDDD<FilteredView>::getString(s, &fv)));
0026   switch (CmsTrackerLevelBuilder<FilteredView>::theCmsTrackerStringToEnum.type(
0027       ExtractStringFromDDD<FilteredView>::getString(s, &fv))) {
0028     case GeometricDet::layer:
0029       theCmsTrackerLayerBuilder.build(fv, subdet, s);
0030       break;
0031     case GeometricDet::OTPhase2Layer:
0032       theCmsTrackerOTLayerBuilder.build(fv, subdet, s);
0033       break;
0034     case GeometricDet::wheel:
0035       theCmsTrackerWheelBuilder.build(fv, subdet, s);
0036       break;
0037     case GeometricDet::disk:
0038       theCmsTrackerDiskBuilder.build(fv, subdet, s);
0039       break;
0040 
0041     default:
0042       edm::LogError("CmsTrackerSubStrctBuilder") << " ERROR - I was expecting a Layer ,Wheel or Disk... I got a "
0043                                                  << ExtractStringFromDDD<FilteredView>::getString(s, &fv);
0044   }
0045 
0046   g->addComponent(subdet);
0047 }
0048 
0049 template <class FilteredView>
0050 void CmsTrackerSubStrctBuilder<FilteredView>::sortNS(FilteredView& fv, GeometricDet* det) {
0051   GeometricDet::ConstGeometricDetContainer& comp = det->components();
0052 
0053   switch (comp.front()->type()) {
0054     case GeometricDet::layer:
0055       std::sort(comp.begin(), comp.end(), CmsTrackerLevelBuilderHelper::isLessR);
0056       break;
0057     case GeometricDet::OTPhase2Layer:
0058       std::sort(comp.begin(), comp.end(), CmsTrackerLevelBuilderHelper::isLessR);
0059       break;
0060     case GeometricDet::wheel:
0061       std::sort(comp.begin(), comp.end(), CmsTrackerLevelBuilderHelper::isLessModZ);
0062       break;
0063     case GeometricDet::disk:
0064       std::sort(comp.begin(), comp.end(), CmsTrackerLevelBuilderHelper::isLessModZ);
0065       break;
0066     default:
0067       edm::LogError("CmsTrackerSubStrctBuilder")
0068           << "ERROR - wrong SubDet to sort..... " << det->components().front()->type();
0069   }
0070 
0071   for (uint32_t i = 0; i < comp.size(); i++) {
0072     det->component(i)->setGeographicalID(i + 1);  // Every subdetector: Layer/Disk/Wheel Number
0073   }
0074 }
0075 
0076 template class CmsTrackerSubStrctBuilder<DDFilteredView>;
0077 template class CmsTrackerSubStrctBuilder<cms::DDFilteredView>;