55def ActsFatrasSimToolCfg(flags, name="ISF_ActsFatrasSimTool", **kwargs):
56 """Return ISF_FatrasSimHitCreatorID configured with ComponentAccumulator"""
57 acc = ComponentAccumulator()
58 mlog = logging.getLogger(name)
59 mlog.info('Start configuration ISF_ActsFatraSimTool')
60
61 kwargs.setdefault("MaxSteps", 20000)
62
63 from ISF_FatrasServices.ISF_FatrasConfig import fatrasKinematicFilterCfg
64 kwargs.setdefault("ParticleFilter", acc.addPublicTool(acc.popToolsAndMerge(fatrasKinematicFilterCfg(flags))))
65 # added https://its.cern.ch/jira/browse/ATLASSIM-7245
66 from ISF_Services.ISF_ServicesConfig import TruthServiceCfg
67 kwargs.setdefault("TruthRecordService", acc.getPrimaryAndMerge(TruthServiceCfg(flags)))
68 from RngComps.RngCompsConfig import AthRNGSvcCfg
69 kwargs.setdefault("RNGService", acc.getPrimaryAndMerge(AthRNGSvcCfg(flags)))
70
71 # Ensure GeoIDSvc is configured
72 from ISF_Services.ISF_ServicesCoreConfig import ATLFAST_GeoIDSvcCfg
73 kwargs.setdefault("GeoIDSvc", acc.getPrimaryAndMerge(ATLFAST_GeoIDSvcCfg(flags)))
74
75 from ActsConfig.ActsGeometryConfig import ActsExtrapolationToolCfg
76 kwargs.setdefault("ExtrapolationTool", acc.popToolsAndMerge(ActsExtrapolationToolCfg(flags)))
77
78 tgSvc = acc.getService("ActsTrackingGeometrySvc")
79 tgSvc.OutputLevel = INFO
80 if flags.Detector.EnableITk:
81 tgSvc.printGeometry = False
82 tgSvc.UseBlueprint = True
83 tgSvc.BuildSubDetectors = ["Calo", "ITkPixel","ITkStrip","HGTD"]
84
85 kwargs.setdefault("ActsFatrasWriteHandler", acc.popToolsAndMerge(ActsFatrasWriteHandlerCfg(flags)))
86 writtenContainers =[]
87 if flags.Detector.EnablePixel:
88 if (flags.Sim.ISFRun and flags.Sim.ISF.HITSMergingRequired.get('ID', True)):
89 writtenContainers += [("SiHitCollection", "PixelHits_Fatras")]
90 if flags.Detector.EnableSCT:
91 if (flags.Sim.ISFRun and flags.Sim.ISF.HITSMergingRequired.get('ID', True)):
92 writtenContainers += [("SiHitCollection", "SCT_Hits_Fatras")]
93 if flags.Detector.EnableITkPixel:
94 if (flags.Sim.ISFRun and flags.Sim.ISF.HITSMergingRequired.get('ITk', True)):
95 writtenContainers += [("SiHitCollection", "ITkPixelHits_Fatras")]
96 if flags.Detector.EnableITkStrip:
97 if (flags.Sim.ISFRun and flags.Sim.ISF.HITSMergingRequired.get('ITk', True)):
98 writtenContainers += [("SiHitCollection", "ITkStripHits_Fatras")]
99 kwargs.setdefault("ExtraOutputs", writtenContainers)
100 acc.setPrivateTools(CompFactory.ISF.ActsFatrasSimTool(name, **kwargs))
101 return acc