File indexing completed on 2024-04-06 12:14:23
0001 #ifndef TrackingGeometry_h
0002 #define TrackingGeometry_h
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021 #include "DataFormats/DetId/interface/DetId.h"
0022 #include "Geometry/CommonTopologies/interface/GeomDet.h"
0023 #include <vector>
0024 #include <unordered_map>
0025
0026 class TrackingGeometry {
0027 public:
0028 using DetTypeContainer = std::vector<const GeomDetType*>;
0029 using DetContainer = std::vector<const GeomDet*>;
0030 using DetIdContainer = std::vector<DetId>;
0031 using mapIdToDetUnit = std::unordered_map<unsigned int, const GeomDet*>;
0032 using mapIdToDet = std::unordered_map<unsigned int, const GeomDet*>;
0033
0034
0035 virtual ~TrackingGeometry() {}
0036
0037
0038 virtual const DetTypeContainer& detTypes() const = 0;
0039
0040
0041 virtual const DetContainer& detUnits() const = 0;
0042
0043
0044 virtual const DetContainer& dets() const = 0;
0045
0046
0047 virtual const DetIdContainer& detUnitIds() const = 0;
0048
0049
0050 virtual const DetIdContainer& detIds() const = 0;
0051
0052
0053 virtual const GeomDet* idToDetUnit(DetId) const = 0;
0054
0055
0056
0057 virtual const GeomDet* idToDet(DetId) const = 0;
0058 };
0059
0060 #endif