CMS 3D CMS Logo

MuonAlignmentInputDB.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: MuonAlignment
4 // Class : MuonAlignmentInputDB
5 //
6 // Implementation:
7 // <Notes on implementation>
8 //
9 // Original Author: Jim Pivarski
10 // Created: Thu Mar 6 17:30:46 CST 2008
11 // $Id: MuonAlignmentInputDB.cc,v 1.4 2009/10/07 20:46:39 pivarski Exp $
12 //
13 
14 // system include files
16 
17 // user include files
29 //
30 // constants, enums and typedefs
31 //
32 
33 //
34 // static data member definitions
35 //
36 
37 //
38 // constructors and destructor
39 //
41  : m_dtLabel(""), m_cscLabel(""), m_gemLabel(""), idealGeometryLabel("idealForInputDB"), m_getAPEs(false) {}
42 
45  : m_dtLabel(dtLabel),
46  m_cscLabel(cscLabel),
47  m_gemLabel(gemLabel),
48  idealGeometryLabel(idealLabel),
49  m_getAPEs(getAPEs) {}
50 
51 // MuonAlignmentInputDB::MuonAlignmentInputDB(const MuonAlignmentInputDB& rhs)
52 // {
53 // // do actual copying here;
54 // }
55 
57 
58 //
59 // assignment operators
60 //
61 // const MuonAlignmentInputDB& MuonAlignmentInputDB::operator=(const MuonAlignmentInputDB& rhs)
62 // {
63 // //An exception safe implementation is
64 // MuonAlignmentInputDB temp(rhs);
65 // swap(rhs);
66 //
67 // return *this;
68 // }
69 
70 //
71 // member functions
72 //
73 
75  edm::ESHandle<DTGeometry> dtGeometry;
76  edm::ESHandle<CSCGeometry> cscGeometry;
78  iSetup.get<MuonGeometryRecord>().get(idealGeometryLabel, dtGeometry);
79  iSetup.get<MuonGeometryRecord>().get(idealGeometryLabel, cscGeometry);
81 
82  edm::ESHandle<Alignments> dtAlignments;
83  edm::ESHandle<AlignmentErrorsExtended> dtAlignmentErrorsExtended;
84  edm::ESHandle<Alignments> cscAlignments;
85  edm::ESHandle<AlignmentErrorsExtended> cscAlignmentErrorsExtended;
86  edm::ESHandle<Alignments> gemAlignments;
87  edm::ESHandle<AlignmentErrorsExtended> gemAlignmentErrorsExtended;
88  edm::ESHandle<Alignments> globalPositionRcd;
89 
90  iSetup.get<DTAlignmentRcd>().get(m_dtLabel, dtAlignments);
91  iSetup.get<CSCAlignmentRcd>().get(m_cscLabel, cscAlignments);
92  iSetup.get<GEMAlignmentRcd>().get(m_gemLabel, gemAlignments);
93  iSetup.get<GlobalPositionRcd>().get(globalPositionRcd);
94 
95  if (m_getAPEs) {
96  iSetup.get<DTAlignmentErrorExtendedRcd>().get(m_dtLabel, dtAlignmentErrorsExtended);
97  iSetup.get<CSCAlignmentErrorExtendedRcd>().get(m_cscLabel, cscAlignmentErrorsExtended);
98  iSetup.get<GEMAlignmentErrorExtendedRcd>().get(m_gemLabel, gemAlignmentErrorsExtended);
99 
100  GeometryAligner aligner;
101  aligner.applyAlignments<DTGeometry>(&(*dtGeometry),
102  &(*dtAlignments),
103  &(*dtAlignmentErrorsExtended),
104  align::DetectorGlobalPosition(*globalPositionRcd, DetId(DetId::Muon)));
105  aligner.applyAlignments<CSCGeometry>(&(*cscGeometry),
106  &(*cscAlignments),
107  &(*cscAlignmentErrorsExtended),
108  align::DetectorGlobalPosition(*globalPositionRcd, DetId(DetId::Muon)));
109  aligner.applyAlignments<GEMGeometry>(&(*gemGeometry),
110  &(*gemAlignments),
111  &(*gemAlignmentErrorsExtended),
112  align::DetectorGlobalPosition(*globalPositionRcd, DetId(DetId::Muon)));
113 
114  } else {
115  AlignmentErrorsExtended dtAlignmentErrorsExtended2, cscAlignmentErrorsExtended2, gemAlignmentErrorsExtended2;
116 
117  for (std::vector<AlignTransform>::const_iterator i = dtAlignments->m_align.begin();
118  i != dtAlignments->m_align.end();
119  ++i) {
120  CLHEP::HepSymMatrix empty_matrix(3, 0);
121  AlignTransformErrorExtended empty_error(empty_matrix, i->rawId());
122  dtAlignmentErrorsExtended2.m_alignError.push_back(empty_error);
123  }
124  for (std::vector<AlignTransform>::const_iterator i = cscAlignments->m_align.begin();
125  i != cscAlignments->m_align.end();
126  ++i) {
127  CLHEP::HepSymMatrix empty_matrix(3, 0);
128  AlignTransformErrorExtended empty_error(empty_matrix, i->rawId());
129  cscAlignmentErrorsExtended2.m_alignError.push_back(empty_error);
130  }
131  for (std::vector<AlignTransform>::const_iterator i = gemAlignments->m_align.begin();
132  i != gemAlignments->m_align.end();
133  ++i) {
134  CLHEP::HepSymMatrix empty_matrix(3, 0);
135  AlignTransformErrorExtended empty_error(empty_matrix, i->rawId());
136  gemAlignmentErrorsExtended2.m_alignError.push_back(empty_error);
137  }
138 
139  GeometryAligner aligner;
140  aligner.applyAlignments<DTGeometry>(&(*dtGeometry),
141  &(*dtAlignments),
142  &(dtAlignmentErrorsExtended2),
143  align::DetectorGlobalPosition(*globalPositionRcd, DetId(DetId::Muon)));
144  aligner.applyAlignments<CSCGeometry>(&(*cscGeometry),
145  &(*cscAlignments),
146  &(cscAlignmentErrorsExtended2),
147  align::DetectorGlobalPosition(*globalPositionRcd, DetId(DetId::Muon)));
148  aligner.applyAlignments<GEMGeometry>(&(*gemGeometry),
149  &(*gemAlignments),
150  &(gemAlignmentErrorsExtended2),
151  align::DetectorGlobalPosition(*globalPositionRcd, DetId(DetId::Muon)));
152  }
153 
154  return new AlignableMuon(&(*dtGeometry), &(*cscGeometry), &(*gemGeometry));
155 }
156 
157 //
158 // const member functions
159 //
160 
161 //
162 // static member functions
163 //
DTGeometry
Definition: DTGeometry.h:28
MuonAlignmentInputDB::m_cscLabel
std::string m_cscLabel
Definition: MuonAlignmentInputDB.h:51
GEMAlignmentErrorExtendedRcd
Definition: GEMAlignmentErrorExtendedRcd.h:6
mps_fire.i
i
Definition: mps_fire.py:428
MuonAlignmentInputDB.h
funct::false
false
Definition: Factorize.h:29
MuonAlignmentInputDB::m_getAPEs
bool m_getAPEs
Definition: MuonAlignmentInputDB.h:52
ESHandle.h
GEMAlignmentErrorExtendedRcd.h
DTAlignmentErrorExtendedRcd.h
DetectorGlobalPosition.h
convertSQLitetoXML_cfg.cscLabel
cscLabel
Definition: convertSQLitetoXML_cfg.py:68
GEMAlignmentRcd
Definition: GEMAlignmentRcd.h:6
GeometryAligner::applyAlignments
void applyAlignments(const C *geometry, const Alignments *alignments, const AlignmentErrorsExtended *alignmentErrors, const AlignTransform &globalCoordinates)
Definition: GeometryAligner.h:52
GlobalPositionRcd
Definition: GlobalPositionRcd.h:6
MuonAlignmentInputDB::m_gemLabel
std::string m_gemLabel
Definition: MuonAlignmentInputDB.h:51
MuonAlignmentInputDB::~MuonAlignmentInputDB
~MuonAlignmentInputDB() override
Definition: MuonAlignmentInputDB.cc:56
CSCGeometry
Definition: CSCGeometry.h:24
align::AlignableMuon
Definition: StructureType.h:90
DetId
Definition: DetId.h:17
GEMAlignmentRcd.h
MuonAlignmentInputDB::idealGeometryLabel
std::string idealGeometryLabel
Definition: MuonAlignmentInputDB.h:51
edm::EventSetup::get
T get() const
Definition: EventSetup.h:87
convertSQLitetoXML_cfg.getAPEs
getAPEs
Definition: convertSQLitetoXML_cfg.py:71
DTAlignmentRcd
Definition: DTAlignmentRcd.h:6
convertSQLitetoXML_cfg.dtLabel
dtLabel
Definition: convertSQLitetoXML_cfg.py:67
CSCAlignmentErrorExtendedRcd.h
MuonAlignmentInputDB::MuonAlignmentInputDB
MuonAlignmentInputDB()
Definition: MuonAlignmentInputDB.cc:40
edm::ESHandle< DTGeometry >
DTAlignmentErrorExtendedRcd
Definition: DTAlignmentErrorExtendedRcd.h:6
CSCAlignmentErrorExtendedRcd
Definition: CSCAlignmentErrorExtendedRcd.h:6
align::DetectorGlobalPosition
const AlignTransform & DetectorGlobalPosition(const Alignments &allGlobals, const DetId &id)
Definition: DetectorGlobalPosition.cc:10
MuonAlignmentInputDB::newAlignableMuon
AlignableMuon * newAlignableMuon(const edm::EventSetup &iSetup) const override
Definition: MuonAlignmentInputDB.cc:74
AlignableMuon
Constructor of the full muon geometry.
Definition: AlignableMuon.h:38
DTAlignmentRcd.h
edm::EventSetup
Definition: EventSetup.h:58
get
#define get
AlignmentErrorsExtended
Definition: AlignmentErrorsExtended.h:10
AlCaHLTBitMon_QueryRunRegistry.string
string string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
GEMGeometry.h
GeometryAligner.h
MuonAlignmentInputDB::m_dtLabel
std::string m_dtLabel
Definition: MuonAlignmentInputDB.h:51
AlignTransformErrorExtended
Definition: AlignTransformErrorExtended.h:13
gemGeometry_cff.gemGeometry
gemGeometry
Definition: gemGeometry_cff.py:5
Alignments::m_align
std::vector< AlignTransform > m_align
Definition: Alignments.h:19
AlignmentErrorsExtended::m_alignError
std::vector< AlignTransformErrorExtended > m_alignError
Definition: AlignmentErrorsExtended.h:19
GEMGeometry
Definition: GEMGeometry.h:24
DetId::Muon
Definition: DetId.h:26
MuonGeometryRecord.h
MuonGeometryRecord
Definition: MuonGeometryRecord.h:34
CSCAlignmentRcd
Definition: CSCAlignmentRcd.h:6
GeometryAligner
Class to update a given geometry with a set of alignments.
Definition: GeometryAligner.h:33
CSCAlignmentRcd.h