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
|
#ifndef Alignment_MuonAlignment_AlignableGEMRing_H
#define Alignment_MuonAlignment_AlignableGEMRing_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/AlignableGEMSuperChamber.h"
#include <vector>
class GeomDet;
class AlignableGEMRing : public AlignableComposite {
public:
AlignableGEMRing(const std::vector<AlignableGEMSuperChamber*>& GEMSuperChambers);
PositionType computePosition();
RotationType computeOrientation();
AlignableSurface computeSurface();
AlignableGEMSuperChamber& superChamber(int i);
friend std::ostream& operator<<(std::ostream&, const AlignableGEMRing&);
void dump(void) const override;
private:
std::vector<AlignableGEMSuperChamber*> theGEMSuperChambers;
};
#endif
|