AlignableGEMStation

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

/* \class AlignableGEMRing
 * \author Hyunyong Kim - TAMU
 */

#include "Alignment/CommonAlignment/interface/Utilities.h"
#include "Alignment/CommonAlignment/interface/AlignableComposite.h"
#include "Alignment/CommonAlignment/interface/AlignableSurface.h"

#include "Alignment/MuonAlignment/interface/AlignableGEMRing.h"

#include <vector>

class GeomDet;
class AlignableGEMRing;

class AlignableGEMStation : public AlignableComposite {
public:
  AlignableGEMStation(const std::vector<AlignableGEMRing*>& GEMRings);

  PositionType computePosition();

  RotationType computeOrientation();

  AlignableSurface computeSurface();

  AlignableGEMRing& ring(int i);

  friend std::ostream& operator<<(std::ostream&, const AlignableGEMStation&);

  void dump(void) const override;

private:
  std::vector<AlignableGEMRing*> theGEMRings;
};

#endif