File indexing completed on 2023-10-25 09:50:13
0001 #include "Geometry/TrackerNumberingBuilder/plugins/CmsTrackerPetalBuilder.h"
0002 #include "DetectorDescription/Core/interface/DDFilteredView.h"
0003 #include "DetectorDescription/DDCMS/interface/DDFilteredView.h"
0004 #include "Geometry/TrackerNumberingBuilder/interface/GeometricDet.h"
0005 #include "Geometry/TrackerNumberingBuilder/plugins/ExtractStringFromDDD.h"
0006 #include "Geometry/TrackerNumberingBuilder/plugins/CmsTrackerRingBuilder.h"
0007 #include "DataFormats/DetId/interface/DetId.h"
0008 #include "FWCore/MessageLogger/interface/MessageLogger.h"
0009 #include <vector>
0010
0011 template <class FilteredView>
0012 void CmsTrackerPetalBuilder<FilteredView>::buildComponent(FilteredView& fv, GeometricDet* g, const std::string& s) {
0013 GeometricDet* det = new GeometricDet(&fv,
0014 CmsTrackerLevelBuilder<FilteredView>::theCmsTrackerStringToEnum.type(
0015 ExtractStringFromDDD<FilteredView>::getString(s, &fv)));
0016 CmsTrackerRingBuilder<FilteredView> theCmsTrackerRingBuilder;
0017 theCmsTrackerRingBuilder.build(fv, det, s);
0018 g->addComponent(det);
0019 }
0020
0021 template <class FilteredView>
0022 void CmsTrackerPetalBuilder<FilteredView>::sortNS(FilteredView& fv, GeometricDet* det) {
0023 GeometricDet::ConstGeometricDetContainer& comp = det->components();
0024
0025 if (comp.front()->type() == GeometricDet::ring)
0026 std::sort(comp.begin(), comp.end(), CmsTrackerLevelBuilderHelper::isLessRModule);
0027 else
0028 edm::LogError("CmsTrackerPetalBuilder")
0029 << "ERROR - wrong SubDet to sort..... " << det->components().front()->type();
0030
0031
0032
0033
0034
0035 uint32_t startring = 8 - comp.size();
0036
0037 for (uint32_t i = 0; i < comp.size(); i++) {
0038 det->component(i)->setGeographicalID(startring + i);
0039 }
0040 }
0041
0042 template class CmsTrackerPetalBuilder<DDFilteredView>;
0043 template class CmsTrackerPetalBuilder<cms::DDFilteredView>;