File indexing completed on 2024-04-06 12:14:22
0001 #ifndef GlobalTrackingGeometry_h
0002 #define GlobalTrackingGeometry_h
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016 #include "Geometry/CommonTopologies/interface/TrackingGeometry.h"
0017 #include <vector>
0018 #include <atomic>
0019
0020 class GlobalTrackingGeometry : public TrackingGeometry {
0021 public:
0022 GlobalTrackingGeometry(std::vector<const TrackingGeometry*>& geos);
0023
0024 ~GlobalTrackingGeometry() override;
0025
0026
0027 const DetTypeContainer& detTypes() const override;
0028
0029
0030 const DetContainer& detUnits() const override;
0031
0032
0033 const DetContainer& dets() const override;
0034
0035
0036 const DetIdContainer& detUnitIds() const override;
0037
0038
0039 const DetIdContainer& detIds() const override;
0040
0041
0042 const GeomDet* idToDetUnit(DetId) const override;
0043
0044
0045
0046 const GeomDet* idToDet(DetId) const override;
0047
0048
0049 const TrackingGeometry* slaveGeometry(DetId id) const;
0050
0051 private:
0052 std::vector<const TrackingGeometry*> theGeometries;
0053
0054
0055
0056
0057 mutable std::atomic<DetTypeContainer*> theDetTypes;
0058 mutable std::atomic<DetContainer*> theDetUnits;
0059 mutable std::atomic<DetContainer*> theDets;
0060 mutable std::atomic<DetIdContainer*> theDetUnitIds;
0061 mutable std::atomic<DetIdContainer*> theDetIds;
0062 };
0063
0064 #endif