TotemGeometry

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
/****************************************************************************
*
* This is a part of TOTEM offline software.
* Author:
*   Laurent Forthomme
*
****************************************************************************/

#ifndef Geometry_ForwardGeometry_TotemGeometry_h
#define Geometry_ForwardGeometry_TotemGeometry_h

#include "Geometry/ForwardGeometry/interface/TotemT2Tile.h"
#include "Geometry/VeryForwardGeometryBuilder/interface/DetGeomDesc.h"

#include "DataFormats/CTPPSDetId/interface/TotemT2DetId.h"

class TotemGeometry {
public:
  TotemGeometry(const DetGeomDesc*);

  bool addT2Plane(const TotemT2DetId&, const DetGeomDesc*&);
  bool addT2Tile(const TotemT2DetId&, const DetGeomDesc*&);

  const DetGeomDesc* plane(const TotemT2DetId&) const;
  const TotemT2Tile& tile(const TotemT2DetId&) const;

private:
  void browse(const DetGeomDesc*, bool in_t2);
  void browseT2(const DetGeomDesc*&);

  std::map<TotemT2DetId, const DetGeomDesc*> nt2_planes_;
  std::map<TotemT2DetId, TotemT2Tile> nt2_tiles_;
};

#endif