FWRecoGeometryESProducer

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
#ifndef GEOMETRY_FWRECO_GEOMETRY_ES_PRODUCER_H
#define GEOMETRY_FWRECO_GEOMETRY_ES_PRODUCER_H

#include <memory>

#include "FWCore/Framework/interface/ESProducer.h"
#include "FWCore/Utilities/interface/ESGetToken.h"
#include "DataFormats/GeometryVector/interface/GlobalPoint.h"

namespace edm {
  class ParameterSet;
}

class CaloGeometry;
class CaloGeometryRecord;
class GlobalTrackingGeometry;
class GlobalTrackingGeometryRecord;
class TrackerGeometry;
class IdealGeometryRecord;
class MTDGeometry;
class MTDDigiGeometryRecord;
class FWRecoGeometry;
class FWRecoGeometryRecord;
class GeomDet;

class FWRecoGeometryESProducer : public edm::ESProducer {
public:
  FWRecoGeometryESProducer(const edm::ParameterSet&);
  ~FWRecoGeometryESProducer(void) override;

  std::unique_ptr<FWRecoGeometry> produce(const FWRecoGeometryRecord&);

  FWRecoGeometryESProducer(const FWRecoGeometryESProducer&) = delete;
  const FWRecoGeometryESProducer& operator=(const FWRecoGeometryESProducer&) = delete;

private:
  void addCSCGeometry(FWRecoGeometry&);
  void addDTGeometry(FWRecoGeometry&);
  void addRPCGeometry(FWRecoGeometry&);
  void addGEMGeometry(FWRecoGeometry&);
  void addME0Geometry(FWRecoGeometry&);
  void addPixelBarrelGeometry(FWRecoGeometry&);
  void addPixelForwardGeometry(FWRecoGeometry&);
  void addTIBGeometry(FWRecoGeometry&);
  void addTOBGeometry(FWRecoGeometry&);
  void addTIDGeometry(FWRecoGeometry&);
  void addTECGeometry(FWRecoGeometry&);
  void addCaloGeometry(FWRecoGeometry&);

  void addMTDGeometry(FWRecoGeometry&);

  void ADD_PIXEL_TOPOLOGY(unsigned int rawid, const GeomDet* detUnit, FWRecoGeometry&);

  void ADD_MTD_TOPOLOGY(unsigned int rawid, const GeomDet* detUnit, FWRecoGeometry&);

  unsigned int insert_id(unsigned int id, FWRecoGeometry&);
  void fillPoints(unsigned int id,
                  std::vector<GlobalPoint>::const_iterator begin,
                  std::vector<GlobalPoint>::const_iterator end,
                  FWRecoGeometry&);
  void fillShapeAndPlacement(unsigned int id, const GeomDet* det, FWRecoGeometry&);
  void writeTrackerParametersXML(FWRecoGeometry&);

  edm::ESGetToken<GlobalTrackingGeometry, GlobalTrackingGeometryRecord> m_trackingGeomToken;
  edm::ESGetToken<MTDGeometry, MTDDigiGeometryRecord> m_mtdGeomToken;
  edm::ESGetToken<CaloGeometry, CaloGeometryRecord> m_caloGeomToken;
  const GlobalTrackingGeometry* m_trackingGeom = nullptr;
  const MTDGeometry* m_mtdGeom = nullptr;
  const CaloGeometry* m_caloGeom = nullptr;
  const TrackerGeometry* m_trackerGeom = nullptr;

  unsigned int m_current;
  bool m_tracker;
  bool m_muon;
  bool m_gem;
  bool m_calo;
  bool m_timing;
};

#endif  // GEOMETRY_FWRECO_GEOMETRY_ES_PRODUCER_H