133def EGammaCookieCutClusterToolCfg(flags, name = 'EGCookieCutTool', **kwargs):
134 acc = ComponentAccumulator()
135
136 from LArGeoAlgsNV.LArGMConfig import LArGMCfg
137 acc.merge(LArGMCfg(flags))
138 from TileGeoModel.TileGMConfig import TileGMCfg
139 acc.merge(TileGMCfg(flags))
140
141 clusterKey = kwargs.setdefault("ClusterContainerName", "ForwardElectronCookieCutClusters")
142 kwargs.setdefault("ClusterContainerLinksName", clusterKey + "_links")
143
144 if kwargs["ClusterContainerLinksName"] != (clusterKey + "_links"):
145 raise AttributeError("ClusterContainerLinksName ({}) is not syncrhonised with ClusterContainerName ({})".format(kwargs["ClusterContainerLinksName"], clusterKey))
146 kwargs.setdefault('StoreCookedMoments', False)
147 kwargs.setdefault('StoreInputMoments', False)
148 kwargs.setdefault("SGKey_electrons", flags.Egamma.Keys.Output.ForwardElectrons)
149 momentNames = [
150 "CENTER_X", "CENTER_Y", "CENTER_Z",
151 "SECOND_LAMBDA", "LATERAL", "LONGITUDINAL", "ENG_FRAC_MAX",
152 "SECOND_R", "CENTER_LAMBDA", "SECOND_ENG_DENS", "SIGNIFICANCE" ]
153 import ROOT
154 moments = [
155 ROOT.xAOD.CaloCluster.CENTER_X, ROOT.xAOD.CaloCluster.CENTER_Y, ROOT.xAOD.CaloCluster.CENTER_Z,
156 ROOT.xAOD.CaloCluster.SECOND_LAMBDA, ROOT.xAOD.CaloCluster.LATERAL, ROOT.xAOD.CaloCluster.LONGITUDINAL, ROOT.xAOD.CaloCluster.ENG_FRAC_MAX,
157 ROOT.xAOD.CaloCluster.SECOND_R, ROOT.xAOD.CaloCluster.CENTER_LAMBDA, ROOT.xAOD.CaloCluster.SECOND_ENG_DENS, ROOT.xAOD.CaloCluster.SIGNIFICANCE ]
158 kwargs.setdefault("MomentNames", momentNames)
159 kwargs.setdefault("Moments", moments)
160 cookedMoments = [ "cookiecut" + moment for moment in momentNames] if kwargs['StoreCookedMoments'] else []
161 originalMoments = [ "original" + moment for moment in momentNames] if kwargs['StoreInputMoments'] else []
162 electronDecorations = [i for sublist in zip(cookedMoments, originalMoments) for i in sublist]
163 electronDecorations += ["cookiecutClusterLink"]
164 kwargs.setdefault("SGKey_electrons_decorations", electronDecorations)
165
166 from CaloTools.CaloNoiseCondAlgConfig import CaloNoiseCondAlgCfg
167 acc.merge(CaloNoiseCondAlgCfg(flags,"totalNoise"))
168 from CaloRec.CaloTopoClusterConfig import getTopoMoments
169 momentsMaker = acc.popToolsAndMerge(getTopoMoments(flags))
170 kwargs.setdefault("ClusterMomentMaker",[momentsMaker])
171
172 acc.setPrivateTools(
173 CompFactory.DerivationFramework.EGammaCookieCutClusterTool(
174 name, **kwargs))
175 return acc