From e70336bd7881be51c162f621a9819a05b397e388 Mon Sep 17 00:00:00 2001
From: Rupert Tombs <rt500@cam.ac.uk>
Date: Tue, 20 Aug 2019 15:37:50 +0100
Subject: [PATCH] Use CaloTriggerTowerCfg and LArDigitMaker to complete Trigger
 configuration.

Add LAr folder mappings.

Remove RNG

Resolve merge conflict
---
 .../python/LArDigitizationConfigNew.py        | 72 ++++++++++++++-----
 .../test/DigitizationConfigNew_test.py        |  4 +-
 2 files changed, 56 insertions(+), 20 deletions(-)

diff --git a/LArCalorimeter/LArDigitization/python/LArDigitizationConfigNew.py b/LArCalorimeter/LArDigitization/python/LArDigitizationConfigNew.py
index 48da45addad4..f298a64ef2ec 100644
--- a/LArCalorimeter/LArDigitization/python/LArDigitizationConfigNew.py
+++ b/LArCalorimeter/LArDigitization/python/LArDigitizationConfigNew.py
@@ -13,6 +13,11 @@ from LArDigitization.LArDigitizationConf import LArPileUpTool, LArDigitMaker
 from CommissionUtils.CommissionUtilsConf import CosmicTriggerTimeTool
 from SGComps.SGCompsConf import AddressRemappingSvc, ProxyProviderSvc
 from OutputStreamAthenaPool.OutputStreamConfig import OutputStreamCfg
+from LArCabling.LArCablingConfig import LArFebRodMappingCfg, LArCalibIdMappingCfg
+from CaloConditions.CaloConditionsConfig import CaloTriggerTowerCfg
+from LArL1Sim.LArL1SimConf import LArTTL1Maker
+from RngComps.RandomServices import RNG
+
 
 def useLArFloat(flags):
     """Return bool for simplified transient LArHit with float E,time"""
@@ -25,17 +30,6 @@ def useLArFloat(flags):
         return False
     return True
 
-def LArItemList():
-    """Return list of item names needed for LAr output"""
-    ItemList = [
-        "LArRawChannelContainer#*",
-        "LArDigitContainer#*",
-        "LArDigitContainer#*LArDigitContainer_MC",
-        "LArDigitContainer#LArDigitContainer_MC_Thinned",
-        "LArHitContainer#HGTDDigitContainer_MC",
-        "LArTTL1Container#*",
-    ]
-    return ItemList
 
 def LArRangeEMCfg(flags, name="LArRangeEM", **kwargs):
     """Return a PileUpXingFoldertool for ElectroMagnetic calorimeter"""
@@ -50,6 +44,7 @@ def LArRangeEMCfg(flags, name="LArRangeEM", **kwargs):
                                        "LArHitContainer#LArHitEMEC"])
     return PileUpXingFolder(name, **kwargs)
 
+
 def LArRangeHECCfg(flags, name="LArRangeHEC", **kwargs):
     """Return a PileUpXingFoldertool for Hadronic End-Cap"""
     # bunch crossing range in ns
@@ -61,6 +56,7 @@ def LArRangeHECCfg(flags, name="LArRangeHEC", **kwargs):
         kwargs.setdefault("ItemList", ["LArHitContainer#LArHitHEC"])
     return PileUpXingFolder(name, **kwargs)
 
+
 def LArRangeFCALCfg(flags, name="LArRangeFCAL", **kwargs):
     """Return a PileUpXingFoldertool for Forward Calorimeters"""
     # bunch crossing range in ns
@@ -72,8 +68,9 @@ def LArRangeFCALCfg(flags, name="LArRangeFCAL", **kwargs):
         kwargs.setdefault("ItemList", ["LArHitContainer#LArHitFCAL"])
     return PileUpXingFolder(name, **kwargs)
 
+
 def LArPileUpToolCfg(flags, name="LArPileUpTool", **kwargs):
-    """Return a ComponentAccumulator with configured LArPileUpTool"""
+    """Return ComponentAccumulator with configured LArPileUpTool"""
     acc = LArGMCfg(flags)
 
     #The LArPileupTool needs: Noise, fSampl, Pedestal,Shape ADC2MeV 
@@ -115,7 +112,7 @@ def LArPileUpToolCfg(flags, name="LArPileUpTool", **kwargs):
         kwargs.setdefault("UseTriggerTime", True)
         kwargs.setdefault("TriggerTimeToolName", CosmicTriggerTimeTool())
     # pileup configuration "algorithm" way
-    if not flags.Digitization.DoXingByXingPileUp :
+    if not flags.Digitization.DoXingByXingPileUp:
         if flags.Digitization.Pileup or flags.Detector.OverlayLAr:
             kwargs.setdefault("PileUp", True)
     kwargs.setdefault("useLArFloat", useLArFloat(flags))
@@ -127,19 +124,58 @@ def LArPileUpToolCfg(flags, name="LArPileUpTool", **kwargs):
             "LArHitContainer#LArHitFCAL->LArHitFloatContainer#LArHitFCAL"
         ]
         acc.addService(AddressRemappingSvc(TypeKeyOverwriteMaps=maps, ProxyDict="ActiveStoreSvc"))
-        acc.addService(ProxyProviderSvc(ProviderNames=["AddressRemappingSvc"]))    
+        acc.addService(ProxyProviderSvc(ProviderNames=["AddressRemappingSvc"]))
     acc.setPrivateTools(LArPileUpTool(name, **kwargs))
     return acc
 
-def LArDigitMakerCfg(flags, name="LArDigitMaker", **kwargs):
-    """Return a ComponentAccumulator with configured LArDigitMaker algorithm"""
+
+def LArDigitMakerBasicCfg(flags, name="LArDigitMaker", **kwargs):
+    """Return ComponentAccumulator with configured LArDigitMaker algorithm"""
     acc = ComponentAccumulator()
     if "LArPileUpTool" not in kwargs:
         tool = acc.popToolsAndMerge(LArPileUpToolCfg(flags))
         kwargs["LArPileUpTool"] = tool
-
     
     acc.addEventAlgo(LArDigitMaker(name, **kwargs))
-    acc.merge(OutputStreamCfg(flags, "RDO", LArItemList()))
+    return acc
+
+
+def LArDigitMakerCfg(flags, name="LArDigitMaker", **kwargs):
+    """Return ComponentAccumulator with configured LArDigitMaker algorithm and Output"""
+    acc = LArDigitMakerBasicCfg(flags, name, **kwargs)
+    LArItemList = [
+        "LArRawChannelContainer#*",
+        "LArDigitContainer#*",
+        "LArDigitContainer#*LArDigitContainer_MC",
+        "LArDigitContainer#LArDigitContainer_MC_Thinned",
+        "LArHitContainer#HGTDDigitContainer_MC",
+    ]
+    acc.merge(OutputStreamCfg(flags, "RDO", LArItemList))
+    return acc
+
+
+def LArTriggerDigitizationBasicCfg(flags, **kwargs):
+    """Return ComponentAccumulator for LAr Trigger Tower"""
+    acc = LArDigitMakerBasicCfg(flags)
+    acc.merge(LArFebRodMappingCfg(flags))
+    acc.merge(LArCalibIdMappingCfg(flags))
+    acc.merge(CaloTriggerTowerCfg(flags))
+    # trigger tower algo
+    kwargs.setdefault("NoiseOnOff", flags.Digitization.DoCaloNoise)
+    if not flags.Digitization.DoXingByXingPileUp:
+        if flags.Digitization.Pileup or flags.Detector.OverlayLAr:
+            kwargs.setdefault("PileUp", True)
+    if flags.Digitization.PileUpPremixing:
+        kwargs.setdefault("EmTTL1ContainerName", flags.Overlay.BkgPrefix + "LArTTL1EM")
+        kwargs.setdefault("HadTTL1ContainerName", flags.Overlay.BkgPrefix + "LArTTL1HAD")
+    acc.addEventAlgo(LArTTL1Maker(**kwargs))
+    return acc
+
+
+def LArTriggerDigitizationCfg(flags, **kwargs):
+    """Return ComponentAccumulator for LAr Trigger Tower and Output"""
+    acc = LArTriggerDigitizationBasicCfg(flags)
+    acc.merge(LArDigitMakerCfg(flags))
+    acc.merge(OutputStreamCfg(flags, "RDO", ["LArTTL1Container#*"]))
     return acc
 
diff --git a/Simulation/Digitization/test/DigitizationConfigNew_test.py b/Simulation/Digitization/test/DigitizationConfigNew_test.py
index ae590b0adf69..c11b960e8ed4 100755
--- a/Simulation/Digitization/test/DigitizationConfigNew_test.py
+++ b/Simulation/Digitization/test/DigitizationConfigNew_test.py
@@ -19,7 +19,7 @@ from MDT_Digitization.MDT_DigitizationConfigNew import MDT_DigitizerCfg
 from TGC_Digitization.TGC_DigitizationConfigNew import TGC_DigitizerCfg
 from RPC_Digitization.RPC_DigitizationConfigNew import RPC_DigitizerCfg
 from CSC_Digitization.CSC_DigitizationConfigNew import CSC_DigitBuilderCfg
-from LArDigitization.LArDigitizationConfigNew import LArDigitMakerCfg
+from LArDigitization.LArDigitizationConfigNew import LArTriggerDigitizationCfg
 from TileSimAlgs.TileDigitizationConfig import TileDigitizationCfg, TileTriggerDigitizationCfg
 
 # Set up logging and new style config
@@ -44,7 +44,7 @@ acc.merge(MDT_DigitizerCfg(ConfigFlags))
 acc.merge(TGC_DigitizerCfg(ConfigFlags))
 acc.merge(RPC_DigitizerCfg(ConfigFlags))
 acc.merge(CSC_DigitBuilderCfg(ConfigFlags))
-acc.merge(LArDigitMakerCfg(ConfigFlags))
+acc.merge(LArTriggerDigitizationCfg(ConfigFlags))
 acc.merge(TileDigitizationCfg(ConfigFlags))
 acc.merge(TileTriggerDigitizationCfg(ConfigFlags))
 # Dump config
-- 
GitLab