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
|