DTGeometryBuilderFromDDD

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
#ifndef DTGeometryBuilder_DTGeometryBuilderFromDDD_h
#define DTGeometryBuilder_DTGeometryBuilderFromDDD_h

/** \class DTGeometryBuilderFromDDD
 *
 *  Build the DTGeometry from the DDD description.  
 *
 *  \author N. Amapane - CERN. 
 *  \author Port of: MuBarDDDGeomBuilder, MuBarDetBuilder (ORCA) by S. Lacaprara, M. Case
 */

#include "DataFormats/GeometrySurface/interface/Plane.h"
#include "DataFormats/GeometrySurface/interface/RectangularPlaneBounds.h"

#include <vector>

class DTGeometry;
class DDCompactView;
class DDFilteredView;
class DTChamber;
class DTSuperLayer;
class DTLayer;
class Bounds;
class MuonGeometryConstants;

namespace dtGeometryBuilder {
  // Helper function from DTGeometryBuilderFromCondDB.cc
  RectangularPlaneBounds* getRecPlaneBounds(const std::vector<double>::const_iterator& shapeStart);
}  // namespace dtGeometryBuilder

class DTGeometryBuilderFromDDD {
public:
  /// Constructor
  DTGeometryBuilderFromDDD();

  /// Destructor
  virtual ~DTGeometryBuilderFromDDD();

  // Operations
  void build(DTGeometry& theGeometry, const DDCompactView* cview, const MuonGeometryConstants& muonConstants);

private:
  /// create the chamber
  DTChamber* buildChamber(DDFilteredView& fv,
                          const std::string& type,
                          const MuonGeometryConstants& muonConstants) const;

  /// create the SL
  DTSuperLayer* buildSuperLayer(DDFilteredView& fv,
                                DTChamber* chamber,
                                const std::string& type,
                                const MuonGeometryConstants& muonConstants) const;

  /// create the layer
  DTLayer* buildLayer(DDFilteredView& fv,
                      DTSuperLayer* sl,
                      const std::string& type,
                      const MuonGeometryConstants& muonConstants) const;

  /// get parameter also for boolean solid.
  std::vector<double> extractParameters(DDFilteredView& fv) const;

  typedef ReferenceCountingPointer<Plane> RCPPlane;

  RCPPlane plane(const DDFilteredView& fv, Bounds* bounds) const;

  void buildGeometry(DTGeometry& theGeometry, DDFilteredView& fv, const MuonGeometryConstants& muonConstants) const;
};
#endif