ATLAS Offline Software
Loading...
Searching...
No Matches
MuonCablingConfig.py
Go to the documentation of this file.
1# Copyright (C) 2002-2024 CERN for the benefit of the ATLAS collaboration
2
3from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
4from AthenaConfiguration.ComponentFactory import CompFactory
5
6def NRPCCablingConfigCfg(flags, name = "MuonNRPC_CablingAlg", **kwargs):
7 result = ComponentAccumulator()
8
9
10 kwargs.setdefault("JSONFile", "")
11 if len(kwargs["JSONFile"]) == 0:
12 from IOVDbSvc.IOVDbSvcConfig import addFolders
13 dbName = 'RPC_OFL' if flags.Input.isMC else 'RPC'
14 cablingFolder = "/RPC/NCABLING/JSON" if flags.Input.isMC else "/RPC/Onl/NCABLING/JSON"
15 cablingTag = "RpcNcablingJson-RUN3-09"
16 from AthenaConfiguration.Enums import LHCPeriod
17 if flags.Muon.usePhaseIIGeoSetup:
18 if flags.GeoModel.Run <= LHCPeriod.Run3:
19 if flags.Input.isMC:
20 cablingTag = "RpcNcablingJson-RUN3-FantasyCabling-5"
21 else:
22 cablingTag = "RpcNcablingJson-RUN3-FantasyHybridCabling-1"
23 elif flags.Input.isMC: #Run4 MC
24 cablingTag = "RpcNcablingJson-RUN4-FantasyCabling-8"
25 result.merge(addFolders(flags, [cablingFolder], detDb=dbName, className='CondAttrListCollection', tag=cablingTag))
26 kwargs.setdefault("MapFolders", cablingFolder)
27
28
29 NRPCCablingAlg = CompFactory.Muon.NRpcCablingAlg(name, **kwargs)
30
31 result.addCondAlgo( NRPCCablingAlg, primary= True)
32 return result
33
34
36 acc = ComponentAccumulator()
37 if not flags.Detector.GeometryRPC: return acc
38 if flags.Muon.enableNRPC:
39 acc.merge(NRPCCablingConfigCfg(flags))
40 acc.merge(RPCLegacyCablingConfigCfg(flags))
41 return acc
42
44 acc = ComponentAccumulator()
45 dbName = 'RPC_OFL' if flags.Input.isMC else 'RPC'
46 dbRepo="MuonRPC_Cabling/ATLAS.data"
47 rpcCabMap="/RPC/CABLING/MAP_SCHEMA"
48 rpcCabMapCorr="/RPC/CABLING/MAP_SCHEMA_CORR"
49 rpcTrigEta="/RPC/TRIGGER/CM_THR_ETA"
50 rpcTrigPhi="/RPC/TRIGGER/CM_THR_PHI"
51
52 from IOVDbSvc.IOVDbSvcConfig import addFolders
53 acc.merge(addFolders(flags, [rpcCabMap,rpcCabMapCorr], dbName, className='CondAttrListCollection' ))
54
55 acc.merge(addFolders(flags, [rpcTrigEta,rpcTrigPhi], dbName, className='CondAttrListCollection'))
56
57 RpcCablingCondAlg=CompFactory.RpcCablingCondAlg
58 RpcCablingAlg = RpcCablingCondAlg("RpcCablingCondAlg",DatabaseRepository=dbRepo)
59 acc.addCondAlgo( RpcCablingAlg )
60
61 return acc
62
63
64def TGCCablingConfigCfg(flags, name="TgcCablingCondAlg", **kwargs):
65 acc = ComponentAccumulator()
66 if not flags.Detector.GeometryTGC: return acc
67
68 kwargs.setdefault("databaseASDtoPPdiff", 'ASD2PP_diff_12_OFL.db' if flags.Input.isMC else 'ASD2PP_diff_12_ONL.db')
69 the_alg = CompFactory.Muon.TgcCablingCondAlg(name, **kwargs)
70 acc.addCondAlgo(the_alg, primary = True)
71 return acc
72
73# This should be checked by experts since I just wrote it based on
74# athena/MuonSpectrometer/MuonCnv/MuonCnvExample/python/MuonCablingConfig.py
75def MDTCablingConfigCfg(flags, name = "MuonMDT_CablingAlg", **kwargs):
76 acc = ComponentAccumulator()
77 if not flags.Detector.GeometryMDT: return acc
78 from AthenaConfiguration.Enums import LHCPeriod
79
80 kwargs.setdefault("UseJSONFormat", flags.Muon.usePhaseIIGeoSetup and \
81 flags.GeoModel.Run >= LHCPeriod.Run4)
82
83 kwargs.setdefault("MezzanineJSON", "")
84 kwargs.setdefault("CablingJSON", "")
85
86 kwargs.setdefault("isRun3", flags.GeoModel.Run >= LHCPeriod.Run3 )
87 from IOVDbSvc.IOVDbSvcConfig import addFolders
88 if len(kwargs["MezzanineJSON"]) == 0 and len(kwargs["CablingJSON"]) == 0:
89 if flags.Input.isMC is True:
90 dbTagMezz = None
91 dbTagSchema = None
92 if flags.Muon.usePhaseIIGeoSetup and \
93 flags.GeoModel.Run >= LHCPeriod.Run4:
94 dbTagMezz = "MDTMezMapSchemaJSON_RUN4BestKnowledge_v1"
95 dbTagSchema = "MDTCablingMapSchemaJSON_RUN4BestKnowledge_v1"
96 elif flags.GeoModel.Run >= LHCPeriod.Run4:
97 dbTagSchema = "MDTOflCablingMapSchema_RUN124_MC15_02"
98 dbTagMezz = "MDTOflCablingMezzanineSchema_RUN124_MC15_02"
99 if kwargs["UseJSONFormat"]:
100 kwargs.setdefault("MapFolders", "/MDT/CABLING/MAP_SCHEMA_JSON")
101 kwargs.setdefault("MezzanineFolders", "/MDT/CABLING/MEZZANINE_SCHEMA_JSON")
102 else:
103 kwargs.setdefault("MapFolders", "/MDT/Ofl/CABLING/MAP_SCHEMA")
104 kwargs.setdefault("MezzanineFolders", "/MDT/Ofl/CABLING/MEZZANINE_SCHEMA")
105 acc.merge( addFolders( flags, [kwargs["MapFolders"]], 'MDT_OFL',
106 className="CondAttrListCollection", tag = dbTagSchema))
107 acc.merge( addFolders( flags, [kwargs["MezzanineFolders"]], 'MDT_OFL',
108 className="CondAttrListCollection", tag = dbTagMezz) )
109 else:
110 if kwargs["UseJSONFormat"]:
111 kwargs.setdefault("MapFolders", "/MDT/CABLING/MAP_SCHEMA_JSON")
112 kwargs.setdefault("MezzanineFolders", "/MDT/CABLING/MEZZANINE_SCHEMA_JSON")
113 else:
114 kwargs.setdefault("MapFolders", "/MDT/CABLING/MAP_SCHEMA")
115 kwargs.setdefault("MezzanineFolders", "/MDT/CABLING/MEZZANINE_SCHEMA")
116 acc.merge( addFolders( flags, [kwargs["MapFolders"], kwargs["MezzanineFolders"]], 'MDT',
117 className="CondAttrListCollection") )
118
119
120 MDTCablingAlg = CompFactory.MuonMDT_CablingAlg(name, **kwargs)
121 acc.addCondAlgo( MDTCablingAlg, primary = True )
122
123 return acc
124
125def MdtTwinTubeMapCondAlgCfg(flags, name="MdtTwinTubeCondAlg", **kwargs):
126 result = ComponentAccumulator()
127 if not flags.Detector.GeometryMDT: return result
128 kwargs.setdefault("JSONFile","")
129 if(not kwargs["JSONFile"]):
130 kwargs.setdefault("FolderName","/MDT/TWINMAPPING")
131 from IOVDbSvc.IOVDbSvcConfig import addFolders
132 result.merge(addFolders(flags,[kwargs["FolderName"]], ("MDT_OFL" if flags.Input.isMC else "MDT"),className="CondAttrListCollection", tag="MDTTwinMapping_compactFormat_Run123"))
133 else:
134 kwargs["FolderName"] = ""
135
136 the_alg = CompFactory.Muon.TwinTubeMappingCondAlg(name, **kwargs)
137 result.addCondAlgo(the_alg, primary = True)
138 return result
139
140# This should be checked by experts
142 acc = ComponentAccumulator()
143 if not flags.Detector.GeometryCSC: return acc
144 CSCcablingSvc=CompFactory.CSCcablingSvc
145 cscCablingSvc = CSCcablingSvc()
146
147 acc.addService( cscCablingSvc, primary=True )
148
149 return acc
150
151def MmCablingCfg(flags, name = "MuonMm_CablingAlg", **kwargs):
152 result = ComponentAccumulator()
153
154 if flags.Input.isMC or (not flags.Detector.GeometryMM):
155 return result
156
157 from IOVDbSvc.IOVDbSvcConfig import addFolders
158 cablingFolder = ["/MDT/MM/CABLING" if not flags.Common.isOnline else "/MDT/Onl/MM/CABLING"]
159 kwargs.setdefault("CablingFolder",cablingFolder)
160 result.merge(addFolders(flags, kwargs["CablingFolder"], detDb=("MDT_OFL" if not flags.Common.isOnline else "MDT_ONL"), className="CondAttrListCollection"))
161
162 the_alg = CompFactory.MuonNSW_CablingAlg(name, **kwargs)
163 result.addCondAlgo(the_alg, primary = True)
164 return result
165
166def sTgcCablingCfg(flags, name = "MuonsTgc_CablingAlg", **kwargs):
167 result = ComponentAccumulator()
168
169 if flags.Input.isMC or (not flags.Detector.GeometrysTGC):
170 return result
171
172 from IOVDbSvc.IOVDbSvcConfig import addFolders
173 cablingFolder = ["/TGC/NSW/CABLING" if not flags.Common.isOnline else "/TGC/Onl/NSW/CABLING"]
174 kwargs.setdefault("CablingFolder",cablingFolder)
175 kwargs.setdefault("WriteKey",'stgcCablingMap')
176 result.merge(addFolders(flags, kwargs["CablingFolder"], detDb=("TGC_OFL" if not flags.Common.isOnline else "TGC_ONL"), className="CondAttrListCollection"))
177
178 the_alg = CompFactory.MuonNSW_CablingAlg(name, **kwargs)
179 result.addCondAlgo(the_alg, primary = True)
180 return result
181
182
183
184#All the cabling configs together (convenience function)
186 acc = ComponentAccumulator()
187 acc.merge( RPCCablingConfigCfg(flags) )
188 acc.merge( TGCCablingConfigCfg(flags) )
189
190 acc.merge( MDTCablingConfigCfg(flags) )
191
192 acc.merge( CSCCablingConfigCfg(flags) )
193
194 acc.merge(MmCablingCfg(flags))
195 acc.merge(sTgcCablingCfg(flags))
196
197 return acc
198
199if __name__ == '__main__':
200 from AthenaConfiguration.AllConfigFlags import initConfigFlags
201 from AthenaConfiguration.TestDefaults import defaultTestFiles, defaultGeometryTags
202 flags = initConfigFlags()
203 flags.Input.Files = defaultTestFiles.RAW_RUN2
204 flags.GeoModel.AtlasVersion = defaultGeometryTags.RUN2
205 flags.lock()
206
207 acc = ComponentAccumulator()
208
209 result = MuonCablingConfigCfg(flags)
210 acc.merge( result )
211
212 f=open('MuonCabling.pkl','wb')
213 acc.store(f)
214 f.close()
if(pathvar)
sTgcCablingCfg(flags, name="MuonsTgc_CablingAlg", **kwargs)
MDTCablingConfigCfg(flags, name="MuonMDT_CablingAlg", **kwargs)
NRPCCablingConfigCfg(flags, name="MuonNRPC_CablingAlg", **kwargs)
TGCCablingConfigCfg(flags, name="TgcCablingCondAlg", **kwargs)
MdtTwinTubeMapCondAlgCfg(flags, name="MdtTwinTubeCondAlg", **kwargs)
MmCablingCfg(flags, name="MuonMm_CablingAlg", **kwargs)