AlignableCSCRing

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

/** \class AlignableCSCRing 
 *  The alignable muon CSC ring.
 *
 *  $Date: 2008/04/15 16:05:53 $
 *  $Revision: 1.3 $
 *  \author Jim Pivarski - Texas A&M University
 */

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

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

#include <vector>

class GeomDet;
class AlignableCSCChamber;

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

class AlignableCSCRing : public AlignableComposite {
public:
  AlignableCSCRing(const std::vector<AlignableCSCChamber*>& cscChambers);

  // 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();

  AlignableCSCChamber& chamber(int i);

  //virtual void twist(float);

  /// Printout muon CSC Ring information (not recursive)
  friend std::ostream& operator<<(std::ostream&, const AlignableCSCRing&);

  /// Recursive printout of the muon CSC Ring structure
  void dump(void) const override;

private:
  std::vector<AlignableCSCChamber*> theCSCChambers;
};

#endif