DTGeometryBuilderFromDD4hep

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
#ifndef DTGeometryBuilder_DTGeometryBuilderFromDD4hep_h
#define DTGeometryBuilder_DTGeometryBuilderFromDD4hep_h
// -*- C++ -*-
//
// Package:    Gemetry/DTGeometryBuilder
// Class:      DTGeometryBuilderFromDD4hep
//
/**\class DTGeometryBuilderFromDD4hep

 Description: DT Geometry builder from DD4hep

 Implementation:
     DT Geometry Builder iterates over a Detector Tree and
     retrvieves DT chambers, super layers, layers and wires.
*/
//
// Original Author:  Ianna Osborne
//         Created:  Wed, 16 Jan 2019 10:19:37 GMT
//         Modified by Sergio Lo Meo (sergio.lo.meo@cern.ch) Mon, 31 August 2020
//
//

#include "DataFormats/GeometrySurface/interface/ReferenceCounted.h"
#include "DataFormats/GeometrySurface/interface/Plane.h"
#include "DetectorDescription/DDCMS/interface/DDDetector.h"
#include "DetectorDescription/DDCMS/interface/DDFilteredView.h"
#include "Geometry/MuonNumbering/interface/DTNumberingScheme.h"

#include <DD4hep/SpecParRegistry.h>

namespace dd4hep {
  class Detector;
}

class DTGeometry;
class DTChamber;
class DTSuperLayer;
class DTLayer;
class MuonGeometryConstants;
class MuonGeometryNumbering;

class DTGeometryBuilderFromDD4hep {
public:
  DTGeometryBuilderFromDD4hep() {}

  void build(DTGeometry&, const cms::DDDetector*, const MuonGeometryConstants&, const dd4hep::SpecParRefs&);

private:
  void buildGeometry(cms::DDFilteredView&, DTGeometry&, const MuonGeometryConstants&) const;

  DTChamber* buildChamber(cms::DDFilteredView&, const MuonGeometryConstants&) const;

  DTSuperLayer* buildSuperLayer(cms::DDFilteredView&, DTChamber*, const MuonGeometryConstants&) const;

  DTLayer* buildLayer(cms::DDFilteredView&, DTSuperLayer*, const MuonGeometryConstants&) const;

  using RCPPlane = ReferenceCountingPointer<Plane>;

  RCPPlane plane(const cms::DDFilteredView&, Bounds* bounds) const;
};

#endif