AlignableDTWheel

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

/** \class AlignableDTWheel
 *  The alignable muon DT wheel.
 *
 *  $Date: 2008/04/15 16:05:53 $
 *  $Revision: 1.10 $
 *  \author Andre Sznajder - UERJ(Brazil)
 */

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

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

#include <vector>

class GeomDet;

/// Concrete class for muon DT Wheel alignable.
///
/// Misalignment can be de-/reactivated (forwarded to components).
///

class AlignableDTWheel : public AlignableComposite {
public:
  AlignableDTWheel(const std::vector<AlignableDTStation*>& dtStations);

  // gets the global position as the average over all positions of the layers
  PositionType computePosition();
  // get the global orientation
  RotationType computeOrientation();  //see explanation for "theOrientation"
  // get the Surface
  AlignableSurface computeSurface();

  AlignableDTStation& station(int i);

  /// Printout muon DT wheel information (not recursive)
  friend std::ostream& operator<<(std::ostream&, const AlignableDTWheel&);

  /// Recursive printout of the muon DT wheel structure
  void dump(void) const override;

private:
  std::vector<AlignableDTStation*> theDTStations;
};

#endif