41 from GoodRunsLists.GoodRunsListsDictionary
import getGoodRunsLists
42 all_grls = getGoodRunsLists()
43 all_grl_flattened = [grl
for grls
in all_grls.values()
for grl
in grls]
45 acc = ComponentAccumulator()
47 if isinstance(grls, str):
48 raise TypeError(
"grls must be an iterable of GRLs, e.g. [%s]" % grls)
52 if grl.endswith(
".xml"):
53 if grl
not in all_grl_flattened:
54 logger.warning(
"GRL '%s' is not in the reccomended GRLs, using it as is.", grl)
55 resolved_grls.append(grl)
58 resolved_grls.extend(all_grls[grl])
60 raise ValueError(f
"GRL name '{grl}' not found in the available GRLs. Available GRL names: %s" % all_grls.keys())
62 tool = CompFactory.GoodRunsListSelectionTool(name=
"GoodRunsListSelectionTool",
63 GoodRunsListVec=resolved_grls,
66 acc.setPrivateTools(tool)
85 acc = ComponentAccumulator()
87 kwargs.setdefault(
"FileKey",
"PhysVal")
88 kwargs.setdefault(
"Environment",
"altprod")
89 kwargs.setdefault(
"ManualDataTypeSetup",
True)
90 kwargs.setdefault(
"DataType",
"monteCarlo")
91 kwargs.setdefault(
"ManualRunLBSetup",
True)
92 kwargs.setdefault(
"Run", 1)
93 kwargs.setdefault(
"LumiBlock", 1)
95 if flags.PhysVal.doExample:
97 if flags.PhysVal.doInDet:
98 from InDetPhysValMonitoring.InDetPhysValMonitoringConfig
import InDetPhysValMonitoringToolCfg
99 tools.append(acc.popToolsAndMerge(InDetPhysValMonitoringToolCfg(flags)))
100 if flags.PhysVal.doInDetLargeD0:
101 from InDetPhysValMonitoring.InDetPhysValMonitoringConfig
import InDetLargeD0PhysValMonitoringToolCfg
102 tools.append(acc.popToolsAndMerge(InDetLargeD0PhysValMonitoringToolCfg(flags)))
103 if flags.PhysVal.doBtag:
104 from JetTagDQA.JetTagDQAConfig
import PhysValBTagCfg
105 tools.append(acc.popToolsAndMerge(PhysValBTagCfg(flags)))
106 if flags.PhysVal.doMET:
107 from MissingEtDQA.MissingEtDQAConfig
import PhysValMETCfg
108 tools.append(acc.popToolsAndMerge(PhysValMETCfg(flags)))
109 if flags.PhysVal.doEgamma:
110 from EgammaPhysValMonitoring.EgammaPhysValMonitoringConfig
import EgammaPhysValMonitoringToolCfg
111 tools.append(acc.popToolsAndMerge(EgammaPhysValMonitoringToolCfg(flags, useOQQuality=flags.PhysVal.applyAllDataCleaning)))
112 if flags.PhysVal.doTau:
113 from TauDQA.TauDQAConfig
import PhysValTauCfg
114 tools.append(acc.popToolsAndMerge(PhysValTauCfg(flags, tauContainer=
"TauJets")))
115 if flags.Tau.TauMuonRM_isAvailable:
116 tools.append(acc.popToolsAndMerge(PhysValTauCfg(flags, tauContainer=
"TauJets_MuonRM")))
117 if flags.Tau.TauEleRM_isAvailable:
118 tools.append(acc.popToolsAndMerge(PhysValTauCfg(flags, tauContainer=
"TauJets_EleRM")))
119 if flags.PhysVal.doDiTau:
120 from DiTauDQA.DiTauDQAConfig
import PhysValDiTauCfg
121 tools.append(acc.popToolsAndMerge(PhysValDiTauCfg(flags)))
122 if flags.PhysVal.doJet:
123 from JetValidation.JetValidationConfig
import PhysValJetCfg
124 tools.append(acc.popToolsAndMerge(PhysValJetCfg(flags)))
125 if flags.PhysVal.doTopoCluster:
126 from PFODQA.ClusterDQAConfig
import PhysValClusterCfg
127 tools += acc.popToolsAndMerge(PhysValClusterCfg(flags))
128 if flags.PhysVal.doZee:
129 from ZeeValidation.ZeeValidationMonToolConfig
import PhysValZeeCfg
130 tools.append(acc.popToolsAndMerge(PhysValZeeCfg(flags)))
131 if flags.PhysVal.doPFlow:
132 from PFODQA.PFPhysValConfig
import PhysValPFOCfg
133 tools += acc.popToolsAndMerge(PhysValPFOCfg(flags))
134 if flags.PhysVal.doMuon:
135 from MuonPhysValMonitoring.MuonPhysValConfig
import PhysValMuonCfg
136 tools.append(acc.popToolsAndMerge(PhysValMuonCfg(flags)))
137 if flags.PhysVal.doLRTMuon:
138 from MuonPhysValMonitoring.MuonPhysValConfig
import PhysValLRTMuonCfg
139 tools.append(acc.popToolsAndMerge(PhysValLRTMuonCfg(flags)))
140 if flags.PhysVal.IDPVM.doActs:
141 from ActsConfig.ActsAnalysisConfig
import PhysValActsCfg
142 tools.append(acc.popToolsAndMerge(PhysValActsCfg(flags)))
143 if flags.PhysVal.doLLPSecVtx:
144 from InDetSecVertexValidation.InDetSecVertexValidationConfig
import PhysValSecVtxCfg
145 tools.append(acc.popToolsAndMerge(PhysValSecVtxCfg(flags)))
147 kwargs.setdefault(
"AthenaMonTools", tools)
150 acc.addSequence(seqAND(
"PhysValSequence"))
152 if flags.PhysVal.applyAllDataCleaning
or flags.PhysVal.applyGRL:
153 if (flags.Input.isMC):
154 raise ValueError(
"applyGRL (or applyAllDataCleaning) is not supported for MC data, please disable it.")
156 sequenceName=
"PhysValSequence")
157 if flags.PhysVal.applyAllDataCleaning
or flags.PhysVal.applyEventStatusSelection:
158 if (flags.Input.isMC):
159 raise ValueError(
"applyEventStatusSelection (or applyAllDataCleaning) is not supported for MC data, please disable it.")
160 acc.addEventAlgo(CompFactory.CP.EventStatusSelectionAlg(
"EventStatusSelectionAlg", FilterKey=
"EventErrorState",
161 FilterDescription=
"selecting events without any error state set"), sequenceName=
"PhysValSequence")
164 acc.addEventAlgo(CompFactory.AthenaMonManager(
165 name, **kwargs), sequenceName=
"PhysValSequence")
166 acc.addService(CompFactory.THistSvc(
167 Output=[f
"PhysVal DATAFILE='{flags.PhysVal.OutputFileName}' OPT='RECREATE'"]))