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
|
#ifndef Alignment_MuonAlignment_AlignableGEMEndcap_H
#define Alignment_MuonAlignment_AlignableGEMEndcap_H
/* \class AlignableGEMEndcap
* \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/AlignableGEMStation.h"
#include <vector>
class GeomDet;
class AlignableGEMEndcap : public AlignableComposite {
public:
AlignableGEMEndcap(const std::vector<AlignableGEMStation*>& GEMStations);
PositionType computePosition();
RotationType computeOrientation();
AlignableSurface computeSurface();
AlignableGEMStation& station(int i);
friend std::ostream& operator<<(std::ostream&, const AlignableGEMEndcap&);
void dump(void) const override;
Alignments* alignments() const override;
AlignmentErrorsExtended* alignmentErrors() const override;
private:
std::vector<AlignableGEMStation*> theGEMStations;
};
#endif
|