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
54
55
56
|
#ifndef Alignment_MuonAlignment_AlignableDTBarrel_H
#define Alignment_MuonAlignment_AlignableDTBarrel_H
/** \class AlignableDTBarrel
* The alignable muon DT barrel.
*
* $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/AlignableDTWheel.h"
#include <vector>
class GeomDet;
/// Concrete class for muon DT Barrel alignable.
///
/// Misalignment can be de-/reactivated (forwarded to components).
///
class AlignableDTBarrel : public AlignableComposite {
public:
AlignableDTBarrel(const std::vector<AlignableDTWheel*>& dtWheels);
// 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();
AlignableDTWheel& wheel(int i);
/// Printout muon Barrel information (not recursive)
friend std::ostream& operator<<(std::ostream&, const AlignableDTBarrel&);
/// Recursive printout of the muon Barrel structure
void dump(void) const override;
// Get alignments sorted by DetId
Alignments* alignments() const override;
// Get alignment errors sorted by DetId
AlignmentErrorsExtended* alignmentErrors() const override;
private:
std::vector<AlignableDTWheel*> theDTWheels;
};
#endif
|