From fe5afb026af176083e35668bffbe901b23cf24cf Mon Sep 17 00:00:00 2001
From: Joerg Stelzer <joerg.stelzer@cern.ch>
Date: Mon, 8 Feb 2021 19:52:37 +0100
Subject: [PATCH] Fix BSMonitoring (ATR-22194) and migrate to new L1Menu

---
 ...MonitoringJobOptions_forRecExCommission.py |  437 +++---
 .../TrigT1CTMonitoring/src/BSMonitoring.cxx   | 1244 ++++++++---------
 .../TrigT1CTMonitoring/src/BSMonitoring.h     |  146 +-
 .../TrigT1CTP/python/TrigT1CTPConfig.py       |    1 +
 .../TrigT1/TrigT1CTP/src/CTPSimulation.cxx    |   23 +-
 .../python/Lvl1SimulationConfig.py            |    1 +
 6 files changed, 922 insertions(+), 930 deletions(-)

diff --git a/Trigger/TrigT1/TrigT1CTMonitoring/share/TrigT1CTMonitoringJobOptions_forRecExCommission.py b/Trigger/TrigT1/TrigT1CTMonitoring/share/TrigT1CTMonitoringJobOptions_forRecExCommission.py
index cebacd448a39..54429f44839f 100644
--- a/Trigger/TrigT1/TrigT1CTMonitoring/share/TrigT1CTMonitoringJobOptions_forRecExCommission.py
+++ b/Trigger/TrigT1/TrigT1CTMonitoring/share/TrigT1CTMonitoringJobOptions_forRecExCommission.py
@@ -15,6 +15,9 @@
 ## get a handle to the ServiceManager
 #-----------COMMON CODE---------------------
 
+from AthenaCommon.Logging import logging
+ctpmonlog = logging.getLogger("CTPMonitoringSetup")
+
 from AthenaCommon.AppMgr import ServiceMgr as svcMgr
 from AthenaCommon.Constants import *
 
@@ -23,10 +26,10 @@ UsedFillStateCoolFolderName="/LHC/DCS/FILLSTATE"
 if LHCFillStateAvailable:
     UsedFillStateCoolFolderName="Unavailable"
 
+# add CTP and MUCTPI data to ByteStreamAddressProviderSvc
 if not hasattr( svcMgr, "ByteStreamAddressProviderSvc" ):
     from ByteStreamCnvSvcBase.ByteStreamCnvSvcBaseConf import ByteStreamAddressProviderSvc 
     svcMgr += ByteStreamAddressProviderSvc()
-
 svcMgr.ByteStreamAddressProviderSvc.TypeNames += [
     "MuCTPI_RDO/MUCTPI_RDO",
     "CTP_RDO/CTP_RDO",
@@ -46,234 +49,240 @@ from TrigT1CTMonitoring.TrigT1CTMonitoringConfig import *
 from AthenaCommon.AppMgr import ToolSvc as toolSvc
 from TrigT1CTMonitoring.TrigT1CTMonitoringConf import TrigT1CTMonitoring__BSMonitoring as BSMon
 
-#-----------ONLINE CODE---------------------
-if athenaCommonFlags.isOnline() and jp.ConcurrencyFlags.NumThreads() == 0:
-    #from TrigServices.TrigServicesConf import TrigMonTHistSvc
-    #THistSvc = TrigMonTHistSvc("THistSvc") 
-    #svcMgr += THistSvc 
-    doHist=True
-    InputDir = "."
-    OutputDir="."
-    FilePreFix = [ "MonTest"]
-    RootHistFileName = 'HistFile.root'
-    
-    ## add an AthenaMonManager algorithm to the list of algorithms to be ran
-    if not hasattr(topSequence,"PrimaryManager"):
-        from AthenaMonitoring.AthenaMonitoringConf import AthenaMonManager
-        topSequence += AthenaMonManager( "PrimaryManager" )
-    ## AthenaMonManager is the Algorithm that manages many classes inheriting
-    ## from ManagedMonitorToolBase
-    CTmonMan = topSequence.PrimaryManager
-
-    theApp.Dlls += [ "TrigT1CTMonitoring" ]
-    
-    CTmonMan.AthenaMonTools += [ "TrigT1CTMonitoring__BSMonitoring/BSMon" ]
-   
-    ## FILEKEY must match that given to THistSvc
-    CTmonMan.FileKey = "GLOBAL"
+if jp.ConcurrencyFlags.NumThreads() == 0: #no monitoring for multithreaded code yet
 
-    DetDescrVersion="ATLAS-DC3-05" # 11.0.42 files 
-    AllAlgs = False # if false, all algorithms are switched off by defaults 
+    #-----------ONLINE CODE---------------------
+    if athenaCommonFlags.isOnline():
+        ctpmonlog.info("Setting up CTP/MUCTPI BS monitoring for online")
+        #from TrigServices.TrigServicesConf import TrigMonTHistSvc
+        #THistSvc = TrigMonTHistSvc("THistSvc") 
+        #svcMgr += THistSvc 
+        doHist=True
+        InputDir = "."
+        OutputDir="."
+        FilePreFix = [ "MonTest"]
+        RootHistFileName = 'HistFile.root'
+        
+        ## add an AthenaMonManager algorithm to the list of algorithms to be ran
+        if not hasattr(topSequence,"PrimaryManager"):
+            from AthenaMonitoring.AthenaMonitoringConf import AthenaMonManager
+            topSequence += AthenaMonManager( "PrimaryManager" )
+        ## AthenaMonManager is the Algorithm that manages many classes inheriting
+        ## from ManagedMonitorToolBase
+        CTmonMan = topSequence.PrimaryManager
 
+        theApp.Dlls += [ "TrigT1CTMonitoring" ]
+        
+        CTmonMan.AthenaMonTools += [ "TrigT1CTMonitoring__BSMonitoring/BSMon" ]
 
-    from AthenaCommon.GlobalFlags import GlobalFlags
-    GlobalFlags.DataSource.set_data()
-    GlobalFlags.InputFormat.set_bytestream()
-    GlobalFlags.DetGeo.set_atlas()
-    
-    from AthenaCommon.DetFlags import DetFlags
-    
-    DetFlags.detdescr.all_setOn()
-    DetFlags.geometry.all_setOn()
-    DetFlags.ID_setOff()
-    DetFlags.Calo_setOff() 
-    DetFlags.Truth_setOff()
-    #switch on/off detectors
-   
-    DetFlags.Muon_setOn()
-    #DetFlags.Muon_setOff()
-   
-    DetFlags.LVL1_setOn()
-    DetFlags.pileup.all_setOff()
-    DetFlags.simulate.all_setOff()
-    DetFlags.digitize.all_setOff()
-    DetFlags.makeRIO.all_setOff()
-    DetFlags.writeBS.all_setOff()
-    DetFlags.readRDOBS.all_setOff()
-    DetFlags.readRIOBS.all_setOff()
-    DetFlags.readRIOPool.all_setOff()
-    DetFlags.writeRIOPool.all_setOff()
-    DetFlags.writeRDOPool.all_setOff()
-    DetFlags.readRDOBS.LVL1_setOn()
-    DetFlags.readRIOBS.LVL1_setOn()
-    DetFlags.Print()
-    GlobalFlags.Print()
-    
-    #--------------------------------------------------------------
-    # GeoModel stuff:
-    #--------------------------------------------------------------
-    include( "AtlasGeoModel/SetGeometryVersion.py" )
-    include( "AtlasGeoModel/GeoModelInit.py" )
-
-    #--------------------------------------------------------------
-    # 
-    #--------------------------------------------------------------
-    include( "AmdcAth/AmdcAth_jobOptions.py" )
-    include( "AtlasGeoModel/MuonGeoModel.py" )
-
-    # Cabling and geometry of muon detectors
-    from RPCgeometry.RPCgeometryConfig import RPCgeometryConfig
-    from RPCcabling.RPCcablingConfig import RPCcablingConfig
-    RPCcablingSvc = RPCcablingConfig()
-    RPCcablingSvc.ConfFileName = "LVL1conf.data"
-    RPCcablingSvc.CorrFileName = "LVL1corr.data"
-    
-    from MDTcabling.MDTcablingConfig import MDTcablingConfig
-    MDTcablingSvc = MDTcablingConfig()
-    MDTcablingSvc.RODfile    = "RODmap.data"
-    from TGCcabling.TGCcablingConfig import TGCcablingConfig
-    
-    # Needed to decode the RoI information
-    from TrigT1RPCRecRoiSvc.TrigT1RPCRecRoiConfig import RPCRecRoiConfig
-    from TrigT1TGCRecRoiSvc.TrigT1TGCRecRoiConfig import TGCRecRoiConfig
-
-    CTmonMan.Environment = "online" 
-    CTmonMan.ManualDataTypeSetup = False
-    CTmonMan.DataType            = "cosmics"
-    CTmonMan.ManualRunLBSetup    = False
-    CTmonMan.Run                 = 1
-    CTmonMan.LumiBlock           = 1
-    
-    #---------------------------------------------------------------
-    # LVL1 configuration
-    #---------------------------------------------------------------
-    log.info("will setup LVL1ConfigSvc and add instance to ServiceMgr")
-    from TrigConfigSvc.TrigConfigSvcConfig import LVL1ConfigSvc
-    LVL1ConfigSvc = LVL1ConfigSvc('LVL1ConfigSvc')
-    LVL1ConfigSvc.ConfigSource = "XML"
-    LVL1ConfigSvc.XMLFile = "L1MenuM5.xml"
-    LVL1ConfigSvc.CreateLegacyObjects = True
-    LVL1ConfigSvc.DumpTTVmap = False
-    #LVL1ConfigSvc.OutputLevel = VERBOSE
-    svcMgr += LVL1ConfigSvc
-    theApp.CreateSvc += [ "TrigConf::LVL1ConfigSvc/LVL1ConfigSvc" ]
-   
-    #    svcMgr.ToolSvc += BSMon( OutputLevel=INFO )
-    svcMgr.ToolSvc += BSMon( ProcessMuctpiData=True )
-    svcMgr.ToolSvc += BSMon( ProcessMuctpiDataRIO=True )
-    svcMgr.ToolSvc += BSMon( ProcessCTPData=True )
-    svcMgr.ToolSvc += BSMon( ProcessRoIBResult=True )
-    svcMgr.ToolSvc += BSMon( InclusiveTriggerThresholds=True )
-    svcMgr.ToolSvc += BSMon( FillStateCoolFolderName=UsedFillStateCoolFolderName)
-    #    RecMuCTPIByteStreamTool.OutputLevel = INFO #DEBUG
-    
-    printfunc (topSequence)
-    printfunc (svcMgr)
+        ## FILEKEY must match that given to THistSvc
+        CTmonMan.FileKey = "GLOBAL"
 
+        DetDescrVersion="ATLAS-DC3-05" # 11.0.42 files 
+        AllAlgs = False # if false, all algorithms are switched off by defaults 
 
-   
-#-----------OFFLINE CODE---------------------
-if not athenaCommonFlags.isOnline() and jp.ConcurrencyFlags.NumThreads() == 0:
 
-    from TriggerJobOpts.TriggerConfigGetter import TriggerConfigGetter
-    cfg = TriggerConfigGetter()
+        from AthenaCommon.GlobalFlags import GlobalFlags
+        GlobalFlags.DataSource.set_data()
+        GlobalFlags.InputFormat.set_bytestream()
+        GlobalFlags.DetGeo.set_atlas()
+        
+        from AthenaCommon.DetFlags import DetFlags
+        
+        DetFlags.detdescr.all_setOn()
+        DetFlags.geometry.all_setOn()
+        DetFlags.ID_setOff()
+        DetFlags.Calo_setOff() 
+        DetFlags.Truth_setOff()
+        #switch on/off detectors
 
-    ## add pre algorithms for rerunning CTP simulation
-    from PyUtils.MetaReaderPeeker import metadata
-    if 'IS_SIMULATION' not in metadata['eventTypes']:
-        #svcMgr.DSConfigSvc.readLVL1Thr=True
-        #svcMgr.DSConfigSvc.readLVL1BG=True
+        DetFlags.Muon_setOn()
+        #DetFlags.Muon_setOff()
+
+        DetFlags.LVL1_setOn()
+        DetFlags.pileup.all_setOff()
+        DetFlags.simulate.all_setOff()
+        DetFlags.digitize.all_setOff()
+        DetFlags.makeRIO.all_setOff()
+        DetFlags.writeBS.all_setOff()
+        DetFlags.readRDOBS.all_setOff()
+        DetFlags.readRIOBS.all_setOff()
+        DetFlags.readRIOPool.all_setOff()
+        DetFlags.writeRIOPool.all_setOff()
+        DetFlags.writeRDOPool.all_setOff()
+        DetFlags.readRDOBS.LVL1_setOn()
+        DetFlags.readRIOBS.LVL1_setOn()
+        DetFlags.Print()
+        GlobalFlags.Print()
+        
+        #--------------------------------------------------------------
+        # GeoModel stuff:
+        #--------------------------------------------------------------
+        include( "AtlasGeoModel/SetGeometryVersion.py" )
+        include( "AtlasGeoModel/GeoModelInit.py" )
+
+        #--------------------------------------------------------------
+        # 
+        #--------------------------------------------------------------
+        include( "AmdcAth/AmdcAth_jobOptions.py" )
+        include( "AtlasGeoModel/MuonGeoModel.py" )
+
+        # Cabling and geometry of muon detectors
+        from RPCgeometry.RPCgeometryConfig import RPCgeometryConfig
+        from RPCcabling.RPCcablingConfig import RPCcablingConfig
+        RPCcablingSvc = RPCcablingConfig()
+        RPCcablingSvc.ConfFileName = "LVL1conf.data"
+        RPCcablingSvc.CorrFileName = "LVL1corr.data"
+        
+        from MDTcabling.MDTcablingConfig import MDTcablingConfig
+        MDTcablingSvc = MDTcablingConfig()
+        MDTcablingSvc.RODfile    = "RODmap.data"
+        from TGCcabling.TGCcablingConfig import TGCcablingConfig
+        
+        # Needed to decode the RoI information
+        from TrigT1RPCRecRoiSvc.TrigT1RPCRecRoiConfig import RPCRecRoiConfig
+        from TrigT1TGCRecRoiSvc.TrigT1TGCRecRoiConfig import TGCRecRoiConfig
+
+        CTmonMan.Environment = "online" 
+        CTmonMan.ManualDataTypeSetup = False
+        CTmonMan.DataType            = "cosmics"
+        CTmonMan.ManualRunLBSetup    = False
+        CTmonMan.Run                 = 1
+        CTmonMan.LumiBlock           = 1
+        
+        #---------------------------------------------------------------
+        # LVL1 configuration
+        #---------------------------------------------------------------
+        ctpmonlog.info("will setup LVL1ConfigSvc and add instance to ServiceMgr")
+        from TrigConfigSvc.TrigConfigSvcConfig import LVL1ConfigSvc
+        LVL1ConfigSvc = LVL1ConfigSvc('LVL1ConfigSvc')
+        LVL1ConfigSvc.ConfigSource = "XML"
+        LVL1ConfigSvc.XMLFile = "L1MenuM5.xml"
+        LVL1ConfigSvc.CreateLegacyObjects = True
+        LVL1ConfigSvc.DumpTTVmap = False
+        svcMgr += LVL1ConfigSvc
+        theApp.CreateSvc += [ "TrigConf::LVL1ConfigSvc/LVL1ConfigSvc" ]
 
         from AthenaConfiguration.AllConfigFlags import ConfigFlags
-        if ConfigFlags.Trigger.enableL1Phase1:
-            from TrigT1MuctpiPhase1.TrigT1MuctpiPhase1Config import L1MuctpiPhase1_on_Data
-            topSequence += L1MuctpiPhase1_on_Data()
-        else:
-            from TrigT1Muctpi.TrigT1MuctpiConfig import L1Muctpi_on_Data
-            topSequence += L1Muctpi_on_Data()
-
-        from TrigT1CTMonitoring.TrigT1CTMonitoringConf import TrigT1CTMonitoring__DeriveSimulationInputs as DeriveSimulationInputs
-        topSequence += DeriveSimulationInputs(do_MuCTPI_input=True,
-                                              do_L1Calo_sim=False)
-
-        from TrigT1CTP.TrigT1CTPConfig import CTPSimulationOnData
-        topSequence += CTPSimulationOnData("CTPSimulation")
-
-        # configure simulation histogram output directory
-        from AthenaMonitoring.DQMonFlags import DQMonFlags
-        histbase = "/" + DQMonFlags.monManFileKey() + "/"
-        if DQMonFlags.monManRun():
-            from RecExConfig.AutoConfiguration import GetRunNumber
-            histbase += "run_%i/L1" % GetRunNumber()
-        else:
-            histbase += "L1Simulation"
-        try:
-            topSequence.CTPSimulation.HistPath = histbase
-        except AttributeError as ex:
-            printfunc (ex," ignore for now")
-            import traceback
-            traceback.print_exc()
-
-    ## add an AthenaMonManager algorithm to the list of algorithms to be run
-    monMan = AthenaMonManager( name="CTMonManager",
-                               FileKey             = DQMonFlags.monManFileKey(),
-                               Environment         = DQMonFlags.monManEnvironment(),
-                               ManualDataTypeSetup = DQMonFlags.monManManualDataTypeSetup(),
-                               DataType            = DQMonFlags.monManDataType() )
-    topSequence += monMan
-   
-    theApp.Dlls += [ "TrigT1CTMonitoring" ]
+        svcMgr.ToolSvc += BSMon( ProcessMuctpiData=True,
+                                ProcessMuctpiDataRIO=True,
+                                ProcessCTPData=True,
+                                ProcessRoIBResult=True,
+                                InclusiveTriggerThresholds=True,
+                                FillStateCoolFolderName=UsedFillStateCoolFolderName,
+                                UseNewConfig = ConfigFlags.Trigger.readLVL1FromJSON )
+        
+        printfunc (topSequence)
+        printfunc (svcMgr)
+
     
-    from PyUtils.MetaReaderPeeker import metadata
+    #-----------OFFLINE CODE---------------------
+    else:
+        from PyUtils.MetaReaderPeeker import metadata
+        isMC = 'IS_SIMULATION' in metadata['eventTypes']
+        ctpmonlog.info("Setting up CTP/MUCTPI BS monitoring for offline (MC=%s)", isMC)
+
+        from TriggerJobOpts.TriggerConfigGetter import TriggerConfigGetter
+        cfg = TriggerConfigGetter()
 
-    # check if global muons are on
-    if not rec.doMuon:
+        ## add pre algorithms for rerunning CTP simulation
         if 'IS_SIMULATION' not in metadata['eventTypes']:
-            CTBSMonTool = BSMon( ProcessCTPData = True,
-                                 ProcessRoIBResult = False,
-                                 InclusiveTriggerThresholds = False,
-                                 ProcessMuctpiData = False,
-                                 ProcessMuctpiDataRIO = False,
-                                 CompareRerun = True,
-                                 FillStateCoolFolderName=UsedFillStateCoolFolderName)
+            #svcMgr.DSConfigSvc.readLVL1Thr=True
+            #svcMgr.DSConfigSvc.readLVL1BG=True
+
+            from AthenaConfiguration.AllConfigFlags import ConfigFlags
+            if ConfigFlags.Trigger.enableL1Phase1:
+                from TrigT1MuctpiPhase1.TrigT1MuctpiPhase1Config import L1MuctpiPhase1_on_Data
+                topSequence += L1MuctpiPhase1_on_Data()
+            else:
+                from TrigT1Muctpi.TrigT1MuctpiConfig import L1Muctpi_on_Data
+                topSequence += L1Muctpi_on_Data()
+
+            from TrigT1CTMonitoring.TrigT1CTMonitoringConf import TrigT1CTMonitoring__DeriveSimulationInputs as DeriveSimulationInputs
+            topSequence += DeriveSimulationInputs(do_MuCTPI_input=True,
+                                                do_L1Calo_sim=False)
+
+            from TrigT1CTP.TrigT1CTPConfig import CTPSimulationOnData
+            topSequence += CTPSimulationOnData("CTPSimulation")
+
+            # configure simulation histogram output directory
+            from AthenaMonitoring.DQMonFlags import DQMonFlags
+            histbase = "/" + DQMonFlags.monManFileKey() + "/"
+            if DQMonFlags.monManRun():
+                from RecExConfig.AutoConfiguration import GetRunNumber
+                histbase += "run_%i/L1" % GetRunNumber()
+            else:
+                histbase += "L1Simulation"
+            try:
+                topSequence.CTPSimulation.HistPath = histbase
+            except AttributeError as ex:
+                printfunc (ex," ignore for now")
+                import traceback
+                traceback.print_exc()
+
+        ## add an AthenaMonManager algorithm to the list of algorithms to be run
+        monMan = AthenaMonManager( name="CTMonManager",
+                                FileKey             = DQMonFlags.monManFileKey(),
+                                Environment         = DQMonFlags.monManEnvironment(),
+                                ManualDataTypeSetup = DQMonFlags.monManManualDataTypeSetup(),
+                                DataType            = DQMonFlags.monManDataType() )
+        topSequence += monMan
+
+        theApp.Dlls += [ "TrigT1CTMonitoring" ]
+        
+        # check if global muons are on
+        if not rec.doMuon:
+            if 'IS_SIMULATION' not in metadata['eventTypes']:
+                CTBSMonTool = BSMon(ProcessRoIBResult = False,
+                                    InclusiveTriggerThresholds = False,
+                                    ProcessMuctpiData = False,
+                                    ProcessMuctpiDataRIO = False,
+                                    CompareRerun = True,
+                                    FillStateCoolFolderName=UsedFillStateCoolFolderName)
+            else:
+                CTBSMonTool = BSMon(ProcessRoIBResult = False,
+                                    InclusiveTriggerThresholds = False,
+                                    ProcessMuctpiData = False,
+                                    ProcessMuctpiDataRIO = False,
+                                    RunOnESD = True,
+                                    CompareRerun = False,
+                                    FillStateCoolFolderName=UsedFillStateCoolFolderName)
         else:
-            CTBSMonTool = BSMon( ProcessCTPData = True,
-                                 ProcessRoIBResult = False,
-                                 InclusiveTriggerThresholds = False,
-                                 ProcessMuctpiData = False,
-                                 ProcessMuctpiDataRIO = False,
-                                 RunOnESD = True,
-                                 CompareRerun = False,
-                                 FillStateCoolFolderName=UsedFillStateCoolFolderName)
-    else:
+            if 'IS_SIMULATION' not in metadata['eventTypes']:
+                CTBSMonTool = BSMon(ProcessRoIBResult = True,
+                                    ProcessMuctpiData = True,
+                                    ProcessMuctpiDataRIO = True,
+                                    CompareRerun = True)
+            else:
+                CTBSMonTool = BSMon(ProcessRoIBResult = True,
+                                    ProcessMuctpiData = True,
+                                    ProcessMuctpiDataRIO = False,
+                                    RunOnESD = True,
+                                    CompareRerun = False,
+                                    FillStateCoolFolderName=UsedFillStateCoolFolderName)
+            # Needed to decode the RoI information
+            from TrigT1RPCRecRoiSvc.TrigT1RPCRecRoiConfig import RPCRecRoiConfig
+            from TrigT1TGCRecRoiSvc.TrigT1TGCRecRoiConfig import TGCRecRoiConfig
+
+        from AthenaConfiguration.AllConfigFlags import ConfigFlags
+        CTBSMonTool.UseNewConfig = ConfigFlags.Trigger.readLVL1FromJSON
+
+
+        processByteStream = True
+
+
         if 'IS_SIMULATION' not in metadata['eventTypes']:
-            CTBSMonTool = BSMon( ProcessCTPData = True,
-                                 ProcessRoIBResult = True,
-                                 ProcessMuctpiData = True,
-                                 ProcessMuctpiDataRIO = True,
-                                 CompareRerun = True)
-        else:
-            CTBSMonTool = BSMon( ProcessCTPData = True,
-                                 ProcessRoIBResult = True,
-                                 ProcessMuctpiData = True,
-                                 ProcessMuctpiDataRIO = False,
-                                 RunOnESD = True,
-                                 CompareRerun = False,
-                                 FillStateCoolFolderName=UsedFillStateCoolFolderName)
-        # Needed to decode the RoI information
-        from TrigT1RPCRecRoiSvc.TrigT1RPCRecRoiConfig import RPCRecRoiConfig
-        from TrigT1TGCRecRoiSvc.TrigT1TGCRecRoiConfig import TGCRecRoiConfig
+            from IOVDbSvc.CondDB import conddb
+            conddb.addFolder('TRIGGER', '/TRIGGER/LUMI/LBLB') 
+            if LHCFillStateAvailable:
+                conddb.addFolder('DCS_OFL', "/LHC/DCS/FILLSTATE")
+            conddb.addFolder('TDAQ', '/TDAQ/RunCtrl/DataTakingMode', className='AthenaAttributeList')
+            conddb.addFolder('TRIGGER', "/TRIGGER/LVL1/RFPhase")
+            conddb.addFolder('TRIGGER', '/TRIGGER/LVL1/CTPCoreInputMapping')
+
+        monMan.AthenaMonTools += [ CTBSMonTool ]
 
-    processByteStream = True
 
 
-    if 'IS_SIMULATION' not in metadata['eventTypes']:
-        from IOVDbSvc.CondDB import conddb
-        conddb.addFolder('TRIGGER', '/TRIGGER/LUMI/LBLB') 
-        if LHCFillStateAvailable:
-            conddb.addFolder('DCS_OFL', "/LHC/DCS/FILLSTATE")
-        conddb.addFolder('TDAQ', '/TDAQ/RunCtrl/DataTakingMode', className='AthenaAttributeList')
-        conddb.addFolder('TRIGGER', "/TRIGGER/LVL1/RFPhase")
-        conddb.addFolder('TRIGGER', '/TRIGGER/LVL1/CTPCoreInputMapping')
 
-    monMan.AthenaMonTools += [ CTBSMonTool ]
+del ctpmonlog
diff --git a/Trigger/TrigT1/TrigT1CTMonitoring/src/BSMonitoring.cxx b/Trigger/TrigT1/TrigT1CTMonitoring/src/BSMonitoring.cxx
index 2cc5dc070c64..85b337cfa4a2 100644
--- a/Trigger/TrigT1/TrigT1CTMonitoring/src/BSMonitoring.cxx
+++ b/Trigger/TrigT1/TrigT1CTMonitoring/src/BSMonitoring.cxx
@@ -17,11 +17,10 @@
 #include "TrigT1Result/RoIBResult.h"
 
 // TrigConf includes
-//#include "TrigConfigSvc/ILVL1ConfigSvc.h"
-#include "TrigConfInterfaces/ILVL1ConfigSvc.h"
 #include "TrigConfL1Data/CTPConfig.h"
 #include "TrigConfL1Data/Menu.h"
 #include "TrigConfStorage/TrigConfCoolFolderSpec.h"
+#include "TrigConfData/L1Menu.h"
 
 // COOL includes
 #include "CoraCool/CoraCoolDatabaseSvcFactory.h"
@@ -60,99 +59,35 @@
 
 using namespace std;
 
-TrigT1CTMonitoring::BSMonitoring::
-BSMonitoring(const std::string & type, const std::string & name, const IInterface * parent)
-  :ManagedMonitorToolBase(type, name, parent), 
-   m_configSvc("TrigConf::TrigConfigSvc/TrigConfigSvc", name), 
-   m_rpcRoiSvc( "LVL1RPC::RPCRecRoiSvc", name ),
-   m_tgcRoiSvc( "LVL1TGC::TGCRecRoiSvc", name ),
-   m_histogramsBooked(false), 
-   m_retrievedLumiBlockTimes(false),
-   m_currentLumiBlock(0),
-   m_runNumber(0),
-   m_eventNumber(0),
-   m_inclusiveTriggerThresholds(true),
-   m_processMuctpi(true),
-   m_processMuctpiRIO(true),
-   m_processCTP(true),
-   m_processRoIB(true),
-   m_compareRerun(false),
-   m_runOnESD(false),
-   m_retrieveCoolData(true),
-   m_eventCount(0),
-   m_firstEventTime(0),
-   m_firstEventBcid(0),
-   m_firstEventTC(0),
-   m_filledEventCount(0),
-   m_maxLumiBlock(0),
-   m_lumiBlockOfPreviousEvent(0),
-   m_defaultBcIntervalInNs(24.9507401),
-   m_bcsPerTurn(3564),
-   m_nLB(0),
-   m_lastminbc(0),
-   m_lastmaxbc(0) {
-
-  declareProperty( "DirectoryName", m_baseDirName = "CT/",
-                   "Directory in output root file where the histograms will be stored." );
-  declareProperty( "InclusiveTriggerThresholds", m_inclusiveTriggerThresholds = 1,
-                   "Flag to activate the inclusive counting of PT thresholds in trigger patterns" );
-  declareProperty( "ProcessMuctpiData", m_processMuctpi = 1,
-                   "Flag to activate the processing of Muctpi data" );
-  declareProperty( "ProcessMuctpiDataRIO", m_processMuctpiRIO = 1,
-                   "Flag to activate the processing of the Muctpi RIO" );
-  declareProperty( "ProcessCTPData", m_processCTP = 1,
-                   "Flag to activate the processing of CTP data" );
-  declareProperty( "ProcessRoIBResult", m_processRoIB = 1,
-                   "Flag to activate the processing of RoIBResult data" );
-  declareProperty( "CompareRerun", m_compareRerun = 0,
-                   "Flag to activate the processing of RoIBResult data" );
-  declareProperty( "RunOnESD", m_runOnESD = 0, 
-                   "Flag to run only on the ESD" );
-  declareProperty( "RetrieveCoolData", m_retrieveCoolData = 1, 
-                   "Flag to control whether or not to perform checks based on COOL data" );
-  declareProperty( "TrigConfigSvc", m_configSvc, 
-                   "Trigger Config Service" );
-  declareProperty( "RPCRecRoiSvc", m_rpcRoiSvc );
-  declareProperty( "TGCRecRoiSvc", m_tgcRoiSvc );
-  declareProperty( "DefaultBcIntervalInNs", m_defaultBcIntervalInNs = 24.9507401, 
-                   "Default bunch-crossing duration to use if not accessible in COOL" );
-  declareProperty( "BCsPerTurn", m_bcsPerTurn = 3564, 
-                   "Number of bunch crossings per turn" );
-  declareProperty( "LumiBlockTimeCoolFolderName", m_lbTimeCoolFolderName = "/TRIGGER/LUMI/LBLB", 
-                   "COOL folder in COOLONL_TRIGGER holding info about start and stop times for luminosity blocks" );
-  declareProperty( "RFPhaseCoolFolderName", m_rfPhaseCoolFolderName = "/TRIGGER/LVL1/RFPhase", 
-                   "COOL folder in COOLONL_TRIGGER holding LHC timing signal info and ATLAS related settings" );
-  declareProperty( "FillStateCoolFolderName", m_fillStateCoolFolderName = "/LHC/DCS/FILLSTATE", 
-                   "COOL folder in COOLOFL_DCS holding the LHC fill state info" );
-  declareProperty( "DataTakingModeCoolFolderName", m_dataTakingModeCoolFolderName = "/TDAQ/RunCtrl/DataTakingMode",
-                   "COOL folder in COOLONL_TDAQ holding the ATLAS data taking mode info" );
-}
-
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-initialize() {
+TrigT1CTMonitoring::BSMonitoring::BSMonitoring(const std::string & type, const std::string & name, const IInterface * parent)
+  : ManagedMonitorToolBase(type, name, parent)
+{}
 
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::initialize()
+{
   // make sure to call initialize of the base class!
-  CHECK( ManagedMonitorToolBase::initialize() );
+  ATH_CHECK( ManagedMonitorToolBase::initialize() );
 
-  ATH_MSG(DEBUG) << "begin initialize()" << endmsg;
   
   // connect to the config service
-  CHECK( m_configSvc.retrieve() );
+  ATH_CHECK( m_configSvc.retrieve() );
 
   // connect to RPC and TGC RoI services
   if ( m_processMuctpi ) {
-    CHECK( m_rpcRoiSvc.retrieve() );
-    CHECK( m_tgcRoiSvc.retrieve() );
+    ATH_CHECK( m_rpcRoiSvc.retrieve() );
+    ATH_CHECK( m_tgcRoiSvc.retrieve() );
   }
 
   return StatusCode::SUCCESS;
 }
 
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-bookHistograms() {
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::bookHistograms()
+{
    try {
-      ATH_MSG(DEBUG) << "begin bookHistograms()" << endmsg;
-      ATH_MSG(DEBUG) << "Clearing HistMap and resetting event counters for new run" << endmsg;
+      ATH_MSG_DEBUG( "bookHistograms()");
+      ATH_MSG_DEBUG( "Clearing HistMap and resetting event counters for new run");
 
       m_histNames.clear();
       m_eventCount = 0;
@@ -174,7 +109,7 @@ bookHistograms() {
       m_histogramsBooked = true;
 
       if (m_retrieveCoolData) {
-         ATH_MSG(DEBUG) << "Will now try to access LB times in folder " << m_lbTimeCoolFolderName << endmsg;
+         ATH_MSG_DEBUG( "Will now try to access LB times in folder " << m_lbTimeCoolFolderName);
          m_lumiBlocks.clear();
          m_lbStartTimes.clear();
          m_lbEndTimes.clear();
@@ -184,22 +119,20 @@ bookHistograms() {
          const DataHandle<CTP_RIO> theCTP_RIO = 0;
          if (!(evtStore()->retrieve(theCTP_RIO, "CTP_RIO").isFailure())) {
             getCoolData(theCTP_RIO->getRunNumber());
-            ATH_MSG(DEBUG) << m_lumiBlocks.size() << " lumi blocks found" << endmsg;
+            ATH_MSG_DEBUG( m_lumiBlocks.size() << " lumi blocks found");
             for ( std::vector<uint32_t>::const_iterator lbIt = m_lumiBlocks.begin(); 
                   lbIt != m_lumiBlocks.end(); ++lbIt ) {
-               ATH_MSG(DEBUG) << "LB " << *lbIt << ": start time = " << m_lbStartTimes[*lbIt] 
-                              << ", end time = " << m_lbEndTimes[*lbIt] << endmsg;
+               ATH_MSG_DEBUG( "LB " << *lbIt << ": start time = " << m_lbStartTimes[*lbIt] 
+                              << ", end time = " << m_lbEndTimes[*lbIt]);
             }
             if (m_lbStartTimes.size() == 0) {
-               ATH_MSG(WARNING) << "Lumi block timestamps not found!" << endmsg;
+               ATH_MSG_WARNING( "Lumi block timestamps not found!");
             }
             else {
                m_retrievedLumiBlockTimes = true;
             }
          }
       }
-      ATH_MSG(DEBUG) << "end bookHistograms()" << endmsg;    
-      return StatusCode::SUCCESS;
    }
    catch(const std::exception & e) {
       std::cerr << "Caught standard C++ exception: " << e.what() << " from bookHistograms()" << std::endl;
@@ -208,19 +141,18 @@ bookHistograms() {
    return StatusCode::SUCCESS;
 }
 
-
-
 StatusCode
-TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
+TrigT1CTMonitoring::BSMonitoring::fillHistograms()
+{
    //evtStore()->dump();
    try {
       if (!m_histogramsBooked) {
-         ATH_MSG(ERROR) << "fillHistograms() called before bookHistograms(*,*,1)!" << endmsg;
-         ATH_MSG(ERROR) << "calling bookHistograms(1,1,1) manually..." << endmsg;
+         ATH_MSG_ERROR( "fillHistograms() called before bookHistograms(*,*,1)!");
+         ATH_MSG_ERROR( "calling bookHistograms(1,1,1) manually...");
          CHECK( bookHistograms() );
       }
 
-      ATH_MSG(DEBUG) << "begin fillHistograms()" << endmsg;
+      ATH_MSG_DEBUG( "begin fillHistograms()");
 
       // Now see what exists in StoreGate...
       const DataHandle<MuCTPI_RDO> theMuCTPI_RDO = 0;
@@ -247,7 +179,7 @@ TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
       TH1F_LW* incompleteFragmentType = getTH1("incompleteFragmentType");
 
       if ( !errorSummary || !errorSummaryPerLumiBlock || !errorPerLumiBlock || !incompleteFragmentType ) {
-         ATH_MSG(FATAL) << "Problems finding error histograms!" << endmsg;
+         ATH_MSG_FATAL("Problems finding error histograms!");
          return StatusCode::FAILURE;
       }
     
@@ -256,25 +188,25 @@ TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
       if (m_processMuctpi) {
          sc = evtStore()->retrieve(theMuCTPI_RDO, "MUCTPI_RDO");
          if (sc.isFailure()) {
-	   ATH_MSG(WARNING) << "Could not find \"MUCTPI_RDO\" in StoreGate" << endmsg;
+	   ATH_MSG_WARNING( "Could not find \"MUCTPI_RDO\" in StoreGate");
 	   validMuCTPI_RDO = false;
 	   ++numberOfInvalidFragments;
          }
 	 // now try to get RPC and TGC SL output for comparisons
 	 sc = evtStore()->retrieve(theRPCContainer, "RPC_SECTORLOGIC");
          if (sc.isFailure()) {
-	   ATH_MSG(WARNING) << "Could not find RPC container in StoreGate" << endmsg;
+	   ATH_MSG_WARNING( "Could not find RPC container in StoreGate");
             validRPCContainer = false;
          }
 	 sc = evtStore()->retrieve(theTGCContainer, "TrigT1CoinDataCollection");
          if (sc.isFailure()) {
-	   ATH_MSG(WARNING) << "Could not find TGC container in StoreGate" << endmsg;
+	   ATH_MSG_WARNING( "Could not find TGC container in StoreGate");
             validTGCContainer = false;
          }
          if (m_processMuctpiRIO && !m_runOnESD) {
             sc = evtStore()->retrieve(theMuCTPI_RIO, "MUCTPI_RIO");
             if (sc.isFailure()) {
-               ATH_MSG(WARNING) << "Could not find \"MUCTPI_RIO\" in StoreGate" << endmsg;
+               ATH_MSG_WARNING( "Could not find \"MUCTPI_RIO\" in StoreGate");
                validMuCTPI_RIO = false;
                ++numberOfInvalidFragments;
             }
@@ -284,14 +216,14 @@ TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
       if (m_processCTP) {
          sc = evtStore()->retrieve(theCTP_RDO, "CTP_RDO");
          if (sc.isFailure()) {
-            ATH_MSG(WARNING) << "Could not find \"CTP_RDO\" in StoreGate" << endmsg;
+            ATH_MSG_WARNING( "Could not find \"CTP_RDO\" in StoreGate");
             validCTP_RDO = false;
             ++numberOfInvalidFragments;
          }
          if (!m_runOnESD) {
             sc = evtStore()->retrieve(theCTP_RIO, "CTP_RIO");
             if (sc.isFailure()) {
-               ATH_MSG(WARNING) << "Could not find \"CTP_RIO\" in StoreGate" << endmsg;
+               ATH_MSG_WARNING( "Could not find \"CTP_RIO\" in StoreGate");
                validCTP_RIO = false;
                ++numberOfInvalidFragments;
             }
@@ -300,7 +232,7 @@ TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
       if (m_processRoIB && m_processMuctpiRIO) {
          sc = evtStore()->retrieve(roIBResult, "RoIBResult");
          if (sc.isFailure()) {
-            ATH_MSG(WARNING) << "Could not find \"RoIBResult\" in StoreGate" << endmsg;
+            ATH_MSG_WARNING( "Could not find \"RoIBResult\" in StoreGate");
             validRoIBResult = false;
             ++numberOfInvalidFragments;
          }
@@ -313,42 +245,38 @@ TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
          m_eventNumber = eventInfo->event_ID()->event_number();
          m_lumiBlockOfPreviousEvent = m_currentLumiBlock;
          m_currentLumiBlock = eventInfo->event_ID()->lumi_block();
-         if ( eventInfo ) {
-            incompleteEvent = eventInfo->eventFlags(EventInfo::Core) & 0x40000;
-         }
-         ATH_MSG(DEBUG) << "Successfully retrieved EventInfo (run: " 
-                        << m_runNumber << ", event: " << m_eventNumber 
-                        << ")" << endmsg;
+         incompleteEvent = eventInfo->eventFlags(EventInfo::Core) & 0x40000;
+         ATH_MSG_DEBUG( "Successfully retrieved EventInfo (run: " << m_runNumber << ", event: " << m_eventNumber << ")");
       }
       else {
-         ATH_MSG(WARNING) << "Could not retrieve EventInfo from StoreGate => run# = event# = 0, LB# = 99" << endmsg;
+         ATH_MSG_WARNING( "Could not retrieve EventInfo from StoreGate => run# = event# = 0, LB# = 99");
          m_lumiBlockOfPreviousEvent = m_currentLumiBlock;
          m_currentLumiBlock = 99; // dummy LB in case EventInfo is not available - prevents DQ defect flagging with LB# 0...
       }
 
       if ( incompleteEvent ) {
-         ATH_MSG(WARNING) << "Incomplete event according to EventInfo flag" << endmsg;
+         ATH_MSG_WARNING( "Incomplete event according to EventInfo flag");
          incompleteFragmentType->Fill(5,1);
       }
-    
+
       bool l1ctObjectMissingInStoreGate = ( !validCTP_RDO || !validCTP_RIO || !validMuCTPI_RDO || !validMuCTPI_RIO || !validRoIBResult );
       if ( l1ctObjectMissingInStoreGate ) {
-         ATH_MSG(WARNING) << "At least one L1CT object is missing in SG" << endmsg;
+         ATH_MSG_WARNING( "At least one L1CT object is missing in SG");
       }
-    
+
       dumpData(theCTP_RDO, theCTP_RIO, theMuCTPI_RDO, theMuCTPI_RIO, roIBResult);
 
       if ( m_processCTP ) {
          if ( validCTP_RDO ) {
             const std::vector<uint32_t> &cDataWords = theCTP_RDO->getDataWords();
             if ( cDataWords.size() == 0 ) {
-               ATH_MSG(WARNING) << "CTP_RDO is empty, ignoring CTP" << endmsg;
+               ATH_MSG_WARNING( "CTP_RDO is empty, ignoring CTP");
                validCTP_RDO = false;
             }
          }
          if ( validCTP_RIO ) {
             if ( !m_runOnESD && (theCTP_RIO->getDetectorEventType() & 0xffff) == 0 ) {//LB == 0 only if RIO is empty
-               ATH_MSG(WARNING) << "CTP_RIO is not valid, ignoring CTP" << endmsg;
+               ATH_MSG_WARNING( "CTP_RIO is not valid, ignoring CTP");
                validCTP_RIO = false;
             }
          }
@@ -360,37 +288,34 @@ TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
             // consider the fragment incomplete if the number of data words is less than
             // the reported number of candidates (zero words valid for muon-less events!)
             if (theMuCTPI_RDO->dataWord().size() < multWord.getNCandidates()) {
-               ATH_MSG(INFO) 
-                  << "MuCTPI_RDO reports " << multWord.getNCandidates() 
+               ATH_MSG_INFO("MuCTPI_RDO reports " << multWord.getNCandidates() 
                   << "  candidates, but there are only " << theMuCTPI_RDO->dataWord().size()
-                  << " data words, ignoring MuCTPI" << endmsg;
+                  << " data words, ignoring MuCTPI");
                validMuCTPI_RDO = false;
             }
          }
          // Note: there's no simple way of checking the validity of the MUCTPI_RIO, so we don't for now.
       }
-    
+
       // if at least one fragment is missing/incomplete, print out a summary
       if (!validCTP_RDO || !validCTP_RIO || !validMuCTPI_RDO || !validMuCTPI_RIO || !validRoIBResult) {
-         ATH_MSG(WARNING) << "At least one missing/invalid L1CT fragment detected" << endmsg;
-         ATH_MSG(WARNING) 
-            << "CTP_RDO: " << validCTP_RDO << ", CTP_RIO: " << validCTP_RIO 
+         ATH_MSG_WARNING( "At least one missing/invalid L1CT fragment detected");
+         ATH_MSG_WARNING( "CTP_RDO: " << validCTP_RDO << ", CTP_RIO: " << validCTP_RIO 
             << ", MuCTPI_RIO: " << validMuCTPI_RIO << ", MuCTPI_RDO: " << validMuCTPI_RDO 
-            << ", RoIBResult: " << validRoIBResult << endmsg;
-         //ATH_MSG(WARNING) << getEventInfoString() << endmsg;
+            << ", RoIBResult: " << validRoIBResult);
+         //ATH_MSG_WARNING( getEventInfoString());
          if (validCTP_RIO) {
-            ATH_MSG(WARNING) 
-               << "CTP_RIO says LB: " << (theCTP_RIO->getDetectorEventType() & 0xffff) 
+            ATH_MSG_WARNING( "CTP_RIO says LB: " << (theCTP_RIO->getDetectorEventType() & 0xffff) 
                << ", L1ID: " << std::dec << theCTP_RIO->getLvl1Id() 
                << " (HEX: " << std::hex << theCTP_RIO->getLvl1Id() << ")" << std::dec 
-               << ", BCID: " << theCTP_RIO->getBCID() << endmsg;
+               << ", BCID: " << theCTP_RIO->getBCID());
          }
          else if (eventInfo) {
-            ATH_MSG(WARNING) << "CTP_RIO missing, EventInfo says LB: " << eventInfo->event_ID()->lumi_block()
-                             << ", BCID: " << eventInfo->event_ID()->bunch_crossing_id() << endmsg; // no L1ID available
+            ATH_MSG_WARNING( "CTP_RIO missing, EventInfo says LB: " << eventInfo->event_ID()->lumi_block()
+                             << ", BCID: " << eventInfo->event_ID()->bunch_crossing_id()); // no L1ID available
          }
          else {
-            ATH_MSG(WARNING) << "Not printing event details since both CTP_RIO and EventInfo objects are missing" << endmsg;
+            ATH_MSG_WARNING( "Not printing event details since both CTP_RIO and EventInfo objects are missing");
          }
 
          // only fill error-per-LB histograms if L1CT fragments are missing and global incomplete-event flag 
@@ -429,7 +354,7 @@ TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
 
       // if the event is incomplete (missing L1CT objects or according to EventInfo), skip filling the rest of the histograms
       if ( !validCTP_RDO || !validCTP_RIO || !validMuCTPI_RDO || !validMuCTPI_RIO || !validRoIBResult || incompleteEvent ) {
-         ATH_MSG(WARNING) << "Event incomplete, will skip filling of all non-error histograms" << endmsg;
+         ATH_MSG_WARNING( "Event incomplete, will skip filling of all non-error histograms");
          return StatusCode::SUCCESS;
       }
 
@@ -441,17 +366,19 @@ TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
          doCtp(theCTP_RDO, theCTP_RIO);
       }
 
-      if (m_processMuctpi && m_processCTP && validCTP_RDO && validCTP_RIO && validMuCTPI_RDO && validMuCTPI_RIO)
-	doCtpMuctpi(theCTP_RDO, theCTP_RIO, theMuCTPI_RDO, theMuCTPI_RIO);
+      if (m_processMuctpi && m_processCTP && validCTP_RDO && validCTP_RIO && validMuCTPI_RDO && validMuCTPI_RIO) {
+      	doCtpMuctpi(theCTP_RDO, theCTP_RIO, theMuCTPI_RDO, theMuCTPI_RIO);
+      }
 
       if (m_processMuctpi && validMuCTPI_RDO && validMuCTPI_RIO && validTGCContainer && validRPCContainer) {
-	doMuctpi(theMuCTPI_RDO, theMuCTPI_RIO, theRPCContainer, theTGCContainer );
-         if (m_processRoIB && m_processMuctpiRIO) 
+         doMuctpi(theMuCTPI_RDO, theMuCTPI_RIO, theRPCContainer, theTGCContainer);
+         if (m_processRoIB && m_processMuctpiRIO) {
             doMuonRoI(theMuCTPI_RDO, theMuCTPI_RIO, roIBResult);
+         }
       }
       ++m_eventCount;
-    
-      ATH_MSG(DEBUG) << "end fillHistograms()" << endmsg;
+
+      ATH_MSG_DEBUG( "end fillHistograms()");
       return StatusCode::SUCCESS;
    }
    catch(const std::exception & e) {
@@ -460,11 +387,11 @@ TrigT1CTMonitoring::BSMonitoring::fillHistograms() {
    }
 }
 
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::procHistograms()
+{
 
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-procHistograms() {
-
-  ATH_MSG(DEBUG) << "begin procHistograms()" << endmsg;
+  ATH_MSG_DEBUG( "begin procHistograms()");
   
   updateRangeUser();
   
@@ -474,99 +401,108 @@ procHistograms() {
     h1->getROOTHist()->GetXaxis()->SetRangeUser(0, lastFilledXBin);
   }
 
-  ATH_MSG(DEBUG) << "processed " << m_eventCount << " events ("
-		 << m_filledEventCount << " filled )" << endmsg;
-  ATH_MSG(DEBUG) << "end procHistograms()" << endmsg;
+  ATH_MSG_DEBUG( "processed " << m_eventCount << " events ("
+		 << m_filledEventCount << " filled )");
+  ATH_MSG_DEBUG( "end procHistograms()");
   return StatusCode::SUCCESS;
 }
 
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-initCtpHistograms() {
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::initCtpHistograms()
+{
 
   // error histograms
-  m_dirName=m_baseDirName+"/";
-
-  CHECK( registerTProfile("errorSummary", "CTP and MuCTPI errors; ; Error rate", 20, 0.5, 20.5, -1, 2) );
-  CHECK( registerTH2("errorSummaryPerLumiBlock", "Errors per lumi block; LB number; Errors", 2000, 0.5, 2000.5, 20, 0.5, 20.5) );
-  CHECK( registerTH1("errorPerLumiBlock", "Number of errors per lumi block; LB number; Errors", 2001, -0.5, 2000.5) );
-  CHECK( registerTH1("incompleteFragmentType", "Number of missing fragments per type; Fragment type; Number of incomplete fragments", 8, -0.5, 7.5) );
-
-  // CTP histograms
-  m_dirName=m_baseDirName+"CTP/";
-  CHECK( registerTH1("deltaBcid", "CTP Data BCID - ROD Header BCID; #DeltaBCID; Entries", 401, -200.5, 200.5) );
-  CHECK( registerTH1("triggerType", "Trigger Type; Trigger Type; Entries", 256, -0.5, 255.5) );
-  CHECK( registerTH1("timeSinceLBStart", "Time Since LB Start; Time After New LB (ms); Entries", 1000, -500, 1500) );
-  CHECK( registerTH1("timeUntilLBEnd", "Time Until LB End; Time Until Next LB (ms); Entries", 1000, -500, 1500) );
-  CHECK( registerTH1("timeSinceL1A", "Time since last L1A; Time since last L1A (ms); Entries", 2000, -1, 30) );
-  CHECK( registerTH1("turnCounterTimeError", "Error of time based on turn counter and BCID; t_{TC+BCID}-t_{GPS} [#mus]; Entries", 2000, -1000., 1000.) );
-  CHECK( registerTProfile("turnCounterTimeErrorVsLb", "Error of (TC+BCID)-based time vs. LB; LB; t_{TC+BCID}-t_{GPS} [#mus]", 2001, -0.5, 2000.5, -1000., 1000.) );
-  CHECK( registerTH2("pitBC", "CTP BC vs. PIT; PIT; BC", 320, -0.5, 319.5, 127, -63.5, 63.5) );
-  CHECK( registerTH2("pitFirstBC", "First CTP BC vs. PIT; PIT; BC", 320, -0.5, 319.5, 127, -63.5, 63.5) );
-  CHECK( registerTH1("tav", "Trigger Items After Veto; CTP TAV; Entries", 512, -0.5, 511.5) );
-  CHECK( registerTH1("ctpStatus1", "CTP Status Word 1; Bit; Number of times ON", 24, -0.5, 23.5) );
-  CHECK( registerTH1("ctpStatus2", "CTP Status Word 2; Bit; Number of times ON", 24, -0.5, 23.5) );
-
-  CHECK( registerTH1("l1ItemsBPSimMismatch","Sim mismatch L1 Items before prescale", 512, 0, 512) );
-  CHECK( registerTH1("l1ItemsBPSimMismatchItems","Sim mismatch L1 Items before prescale, mismatched ones only", 512, 0, 512) );
-
-  // fix cosmetics of some histos, e.g. bin labels
-
-  TH1F_LW* l1ItemsBPSimMismatch = getTH1("l1ItemsBPSimMismatch");
-  for(const TrigConf::TriggerItem * item : m_configSvc->ctpConfig()->menu().itemVector()) {
-    if(item==nullptr) continue;
-    string label = item->name() + " (CTP ID " + boost::lexical_cast<string,int>(item->ctpId())+ ")";
-    l1ItemsBPSimMismatch->GetXaxis()->SetBinLabel(item->ctpId()+1,label.c_str());
-  }
-
-  std::map<int, std::string> errorSummaryBinLabels;
-  errorSummaryBinLabels[1] = "CTP/ROD BCID Offset";
-  errorSummaryBinLabels[2] = "No BCs in Readout";
-  errorSummaryBinLabels[3] = "CTP/MuCTPI BCID Offset";
-  errorSummaryBinLabels[4] = "Wrong Cand Word Number";
-  errorSummaryBinLabels[5] = "Wrong Pt in Mult Word";
-  errorSummaryBinLabels[6] = "Wrong Num of RoI";
-  errorSummaryBinLabels[7] = "No Cand for RoI";
-  errorSummaryBinLabels[8] = "Cand BC Out of Range";
-  errorSummaryBinLabels[9] = "Invalid Lumi Block";
-  errorSummaryBinLabels[10] = "LB Out of Time";
-  errorSummaryBinLabels[11] = "Nanosec > 1e9";
-  errorSummaryBinLabels[12] = "TAP w/out TBP";
-  errorSummaryBinLabels[13] = "TAV w/out TAP";
-  errorSummaryBinLabels[14] = "CTP sim. mismatch";
-  errorSummaryBinLabels[15] = "Incomplete fragment";
-  errorSummaryBinLabels[16] = "Missing orbit pulse";
-  errorSummaryBinLabels[17] = "MuCTPI/noRPC candidate mismatch";
-  errorSummaryBinLabels[18] = "MuCTPI/noTGC candidate mismatch";
-  errorSummaryBinLabels[19] = "RPC/noMuCTPI candidate mismatch";
-  errorSummaryBinLabels[20] = "TGC/noMuCTPI candidate mismatch";
-
-  TProfile_LW* errorSummary = getTProfile("errorSummary");
-  TH2F_LW* errorSummaryPerLumiBlock = getTH2("errorSummaryPerLumiBlock");
-  if (errorSummary) {
-    errorSummary->GetXaxis()->SetLabelSize(0.03);
-    errorSummaryPerLumiBlock->GetYaxis()->SetLabelSize(0.03);
-    for (unsigned int bin = 1; bin < errorSummaryBinLabels.size()+1; ++bin) {
-      errorSummary->GetXaxis()->SetBinLabel(bin, errorSummaryBinLabels[bin].c_str());
-      errorSummaryPerLumiBlock->GetYaxis()->SetBinLabel(bin, errorSummaryBinLabels[bin].c_str());
-    }
-  }
+   m_dirName=m_baseDirName+"/";
+
+   CHECK( registerTProfile("errorSummary", "CTP and MuCTPI errors; ; Error rate", 20, 0.5, 20.5, -1, 2) );
+   CHECK( registerTH2("errorSummaryPerLumiBlock", "Errors per lumi block; LB number; Errors", 2000, 0.5, 2000.5, 20, 0.5, 20.5) );
+   CHECK( registerTH1("errorPerLumiBlock", "Number of errors per lumi block; LB number; Errors", 2001, -0.5, 2000.5) );
+   CHECK( registerTH1("incompleteFragmentType", "Number of missing fragments per type; Fragment type; Number of incomplete fragments", 8, -0.5, 7.5) );
+
+   // CTP histograms
+   m_dirName=m_baseDirName+"CTP/";
+   CHECK( registerTH1("deltaBcid", "CTP Data BCID - ROD Header BCID; #DeltaBCID; Entries", 401, -200.5, 200.5) );
+   CHECK( registerTH1("triggerType", "Trigger Type; Trigger Type; Entries", 256, -0.5, 255.5) );
+   CHECK( registerTH1("timeSinceLBStart", "Time Since LB Start; Time After New LB (ms); Entries", 1000, -500, 1500) );
+   CHECK( registerTH1("timeUntilLBEnd", "Time Until LB End; Time Until Next LB (ms); Entries", 1000, -500, 1500) );
+   CHECK( registerTH1("timeSinceL1A", "Time since last L1A; Time since last L1A (ms); Entries", 2000, -1, 30) );
+   CHECK( registerTH1("turnCounterTimeError", "Error of time based on turn counter and BCID; t_{TC+BCID}-t_{GPS} [#mus]; Entries", 2000, -1000., 1000.) );
+   CHECK( registerTProfile("turnCounterTimeErrorVsLb", "Error of (TC+BCID)-based time vs. LB; LB; t_{TC+BCID}-t_{GPS} [#mus]", 2001, -0.5, 2000.5, -1000., 1000.) );
+   CHECK( registerTH2("pitBC", "CTP BC vs. PIT; PIT; BC", 320, -0.5, 319.5, 127, -63.5, 63.5) );
+   CHECK( registerTH2("pitFirstBC", "First CTP BC vs. PIT; PIT; BC", 320, -0.5, 319.5, 127, -63.5, 63.5) );
+   CHECK( registerTH1("tav", "Trigger Items After Veto; CTP TAV; Entries", 512, -0.5, 511.5) );
+   CHECK( registerTH1("ctpStatus1", "CTP Status Word 1; Bit; Number of times ON", 24, -0.5, 23.5) );
+   CHECK( registerTH1("ctpStatus2", "CTP Status Word 2; Bit; Number of times ON", 24, -0.5, 23.5) );
+
+   CHECK( registerTH1("l1ItemsBPSimMismatch","Sim mismatch L1 Items before prescale", 512, 0, 512) );
+   CHECK( registerTH1("l1ItemsBPSimMismatchItems","Sim mismatch L1 Items before prescale, mismatched ones only", 512, 0, 512) );
+
+   // bin lables
+   TH1F_LW* l1ItemsBPSimMismatch = getTH1("l1ItemsBPSimMismatch");
+   if(m_useNewConfig) {
+      const TrigConf::L1Menu * l1menu = nullptr;
+      ATH_CHECK(detStore()->retrieve(l1menu));
+      for(const TrigConf::L1Item & item : *l1menu) {
+         string label = item.name() + " (CTP ID " + boost::lexical_cast<string,int>(item.ctpId())+ ")";
+         l1ItemsBPSimMismatch->GetXaxis()->SetBinLabel(item.ctpId()+1,label.c_str());
+      }
+   } else {  
+      for(const TrigConf::TriggerItem * item : m_configSvc->ctpConfig()->menu().itemVector()) {
+         if(item==nullptr) continue;
+         string label = item->name() + " (CTP ID " + boost::lexical_cast<string,int>(item->ctpId())+ ")";
+         l1ItemsBPSimMismatch->GetXaxis()->SetBinLabel(item->ctpId()+1,label.c_str());
+      }
+   }
+   std::map<int, std::string> errorSummaryBinLabels;
+   errorSummaryBinLabels[1] = "CTP/ROD BCID Offset";
+   errorSummaryBinLabels[2] = "No BCs in Readout";
+   errorSummaryBinLabels[3] = "CTP/MuCTPI BCID Offset";
+   errorSummaryBinLabels[4] = "Wrong Cand Word Number";
+   errorSummaryBinLabels[5] = "Wrong Pt in Mult Word";
+   errorSummaryBinLabels[6] = "Wrong Num of RoI";
+   errorSummaryBinLabels[7] = "No Cand for RoI";
+   errorSummaryBinLabels[8] = "Cand BC Out of Range";
+   errorSummaryBinLabels[9] = "Invalid Lumi Block";
+   errorSummaryBinLabels[10] = "LB Out of Time";
+   errorSummaryBinLabels[11] = "Nanosec > 1e9";
+   errorSummaryBinLabels[12] = "TAP w/out TBP";
+   errorSummaryBinLabels[13] = "TAV w/out TAP";
+   errorSummaryBinLabels[14] = "CTP sim. mismatch";
+   errorSummaryBinLabels[15] = "Incomplete fragment";
+   errorSummaryBinLabels[16] = "Missing orbit pulse";
+   errorSummaryBinLabels[17] = "MuCTPI/noRPC candidate mismatch";
+   errorSummaryBinLabels[18] = "MuCTPI/noTGC candidate mismatch";
+   errorSummaryBinLabels[19] = "RPC/noMuCTPI candidate mismatch";
+   errorSummaryBinLabels[20] = "TGC/noMuCTPI candidate mismatch";
+
+   TProfile_LW* errorSummary = getTProfile("errorSummary");
+   TH2F_LW* errorSummaryPerLumiBlock = getTH2("errorSummaryPerLumiBlock");
+   if (errorSummary) {
+      errorSummary->GetXaxis()->SetLabelSize(0.03);
+      errorSummaryPerLumiBlock->GetYaxis()->SetLabelSize(0.03);
+      for (unsigned int bin = 1; bin < errorSummaryBinLabels.size()+1; ++bin) {
+         errorSummary->GetXaxis()->SetBinLabel(bin, errorSummaryBinLabels[bin].c_str());
+         errorSummaryPerLumiBlock->GetYaxis()->SetBinLabel(bin, errorSummaryBinLabels[bin].c_str());
+      }
+   }
 
-  TH1F_LW* incompleteFragmentType = getTH1("incompleteFragmentType");
-  if (incompleteFragmentType) {
-    incompleteFragmentType->GetXaxis()->SetBinLabel(1, "CTP RIO");
-    incompleteFragmentType->GetXaxis()->SetBinLabel(2, "CTP RDO");
-    incompleteFragmentType->GetXaxis()->SetBinLabel(3, "MuCTPI RIO");
-    incompleteFragmentType->GetXaxis()->SetBinLabel(4, "MuCTPI RDO");
-    incompleteFragmentType->GetXaxis()->SetBinLabel(5, "RoIBResult");
-    incompleteFragmentType->GetXaxis()->SetBinLabel(6, "TGC SL RDO");
-    incompleteFragmentType->GetXaxis()->SetBinLabel(7, "RPC SL RDO");
-  }
+   TH1F_LW* incompleteFragmentType = getTH1("incompleteFragmentType");
+   if (incompleteFragmentType) {
+      incompleteFragmentType->GetXaxis()->SetBinLabel(1, "CTP RIO");
+      incompleteFragmentType->GetXaxis()->SetBinLabel(2, "CTP RDO");
+      incompleteFragmentType->GetXaxis()->SetBinLabel(3, "MuCTPI RIO");
+      incompleteFragmentType->GetXaxis()->SetBinLabel(4, "MuCTPI RDO");
+      incompleteFragmentType->GetXaxis()->SetBinLabel(5, "RoIBResult");
+      incompleteFragmentType->GetXaxis()->SetBinLabel(6, "TGC SL RDO");
+      incompleteFragmentType->GetXaxis()->SetBinLabel(7, "RPC SL RDO");
+   }
 
-  return StatusCode::SUCCESS;
+   return StatusCode::SUCCESS;
 }
 
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-initMuctpiHistograms() {
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::initMuctpiHistograms()
+{
 
   m_dirName=m_baseDirName+"MUCTPI/";
 
@@ -636,8 +572,9 @@ initMuctpiHistograms() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-initCtpMuctpiHistograms() {
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::initCtpMuctpiHistograms()
+{
 
   m_dirName=m_baseDirName+"CTPMUCTPI/";
 
@@ -648,8 +585,9 @@ initCtpMuctpiHistograms() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-initRoIHistograms() {
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::initRoIHistograms()
+{
 
   m_dirName=m_baseDirName+"ROI/";
 
@@ -676,8 +614,11 @@ initRoIHistograms() {
   return StatusCode::SUCCESS;
 }
 
-void TrigT1CTMonitoring::BSMonitoring::
-doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO> theMuCTPI_RIO, const DataHandle <RpcSectorLogicContainer> theRPCContainer, const DataHandle <Muon::TgcCoinDataContainer> theTGCContainer) {
+void
+TrigT1CTMonitoring::BSMonitoring::doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO> theMuCTPI_RIO, 
+                                            const DataHandle <RpcSectorLogicContainer> theRPCContainer, 
+                                            const DataHandle <Muon::TgcCoinDataContainer> theTGCContainer)
+{
 
   TProfile_LW* errorSummary = getTProfile("errorSummary");
   TH2F_LW* errorSummaryPerLumiBlock = getTH2("errorSummaryPerLumiBlock");
@@ -701,15 +642,15 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
   TH1F_LW* endcapPt = getTH1("endcapPt");
   TH1F_LW* forwardPt = getTH1("forwardPt");
 
-  if ( !errorSummary || !errorSummaryPerLumiBlock || !errorPerLumiBlock || !nCandidates || !nCandidatesDataWord || !pt || !muctpiStatus1
+   if ( !errorSummary || !errorSummaryPerLumiBlock || !errorPerLumiBlock || !nCandidates || !nCandidatesDataWord || !pt || !muctpiStatus1
       || !muctpiStatus2 || !nCandidatesMictpMioct || !bcidMictpMioct || !bcidMictpHeader
       || !endcapSectorIDOverlapBit || !barrelSectorID || !endcapSectorID || !forwardSectorID 
       || !barrelPt || !endcapSectorIDAll || !forwardSectorIDAll || !barrelSectorIDAll 
-      || !endcapPt || !forwardPt ) {
-    ATH_MSG(FATAL) << "Problems finding 1D histograms for MuCTPI!"
-	<< endmsg;
-    return;
-  }
+      || !endcapPt || !forwardPt )
+   {
+      ATH_MSG_FATAL("Problems finding 1D histograms for MuCTPI!");
+      return;
+   }
   TH2F_LW *barrelRoiSectorID = getTH2("barrelRoiSectorID");
   TH2F_LW *endcapRoiSectorID = getTH2("endcapRoiSectorID");
   TH2F_LW *forwardRoiSectorID = getTH2("forwardRoiSectorID");
@@ -735,10 +676,9 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
        !nCandidatesPt || !barrelSectorIDOverlapBits || !muctpiNoRPCCandfound ||
        !rpcNoMuCTPICandfound || !muctpiNoTGCecCandfound || !tgcecNoMuCTPICandfound ||
        !muctpiNoTGCfwCandfound || !tgcfwNoMuCTPICandfound) {
-    ATH_MSG(FATAL) << "Problems finding 2D histograms for MuCTPI!"
-	<< endmsg;
+    ATH_MSG_FATAL("Problems finding 2D histograms for MuCTPI!");
     return;
-  }
+   }
 
   // maps for comapring MuCTPI and RPC/TGC candidates
   std::map <std::string,MuCTPI_DataWord_Decoder> muctpiCandidates;
@@ -845,9 +785,8 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
   int diffNCandidates = (static_cast<int>(numberCandidates) - numberDataWords);
 
   if (diffNCandidates != 0) {
-    ATH_MSG(WARNING) << "Number of candidates in multiplicity word " << numberCandidates 
-		     << " != number of candidates " << numberDataWords << " from " << vDataWords.size() 
-		     << " data words" << endmsg;
+    ATH_MSG_WARNING( "Number of candidates in multiplicity word " << numberCandidates 
+		     << " != number of candidates " << numberDataWords << " from " << vDataWords.size() << " data words");
     // dump multiplicity and data words (DEBUG level)
     multWord.dumpData();
     for ( std::vector<uint32_t>::const_iterator it = vDataWords.begin(); it != vDataWords.end(); ++it ) {
@@ -897,50 +836,33 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
       forwardRoiSectorIDAll->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere(), dataWord.getRoiNumber());
     }
 
-/*    candidateBcid = dataWord.getBCID();
-
-    int candbcdiff = candidateBcid - mictpBcid;	
-    if (candbcdiff > 3) candbcdiff -= 8; 
-    if (candbcdiff < -3) candbcdiff += 8;
-    bcidMictpMioct->Fill(candbcdiff);
-
-    if (abs(candbcdiff)>3) {
-      ATH_MSG(WARNING) << "MIOCT candidate BC " << candidateBcid << " out of range of MICTP BC " 
-	  << mictpBcid << endmsg;
-      errorSummary->Fill(8,1);
-      errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 8);
-      errorPerLumiBlock->Fill(m_currentLumiBlock);
-    }
-    else errorSummary->Fill(8,0);
-*/  
-    //Use only non-vetoed candidates from the same BCID for multiplicity calculation
-    if ( //(dataWord.getBCID() == multWord.getBCID()) && 
-	 !dataWord.getVetoed() ) {
+    // Use only non-vetoed candidates from the same BCID for multiplicity calculation
+    if ( ! dataWord.getVetoed() ) {
       uint16_t candPt = dataWord.getPt();
       pt->Fill(candPt);
       if (0 < candPt && candPt <= MuCTPI_RDO::MULT_THRESH_NUM) {
-	if (m_inclusiveTriggerThresholds) {
-	  for ( uint16_t i(0); i < candPt; ++i )
-	    if (MioctPtCount[i] < 7) {
-	      MioctPtCount[i] += 1;
-	    }
-	} 
-	else {
-	  if (MioctPtCount[candPt - 1] < 7)
-	    MioctPtCount[candPt - 1] += 1;
-	}
+        if (m_inclusiveTriggerThresholds) {
+          for ( uint16_t i(0); i < candPt; ++i )
+            if (MioctPtCount[i] < 7) {
+              MioctPtCount[i] += 1;
+            }
+        } else {
+          if (MioctPtCount[candPt - 1] < 7) {
+            MioctPtCount[candPt - 1] += 1;
+          }
+        }
       }
       if (dataWord.getSectorLocation() == MuCTPI_RDO::BARREL) {
-	barrelSectorID->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere());
-	barrelRoiSectorID->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere(), dataWord.getRoiNumber());
+        barrelSectorID->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere());
+        barrelRoiSectorID->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere(), dataWord.getRoiNumber());
       }
       else if (dataWord.getSectorLocation() == MuCTPI_RDO::ENDCAP) {
-	endcapSectorID->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere());
-	endcapRoiSectorID->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere(), dataWord.getRoiNumber());
+        endcapSectorID->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere());
+        endcapRoiSectorID->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere(), dataWord.getRoiNumber());
       }
       else if (dataWord.getSectorLocation() == MuCTPI_RDO::FORWARD) {
-	forwardSectorID->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere());
-	forwardRoiSectorID->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere(), dataWord.getRoiNumber());
+        forwardSectorID->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere());
+        forwardRoiSectorID->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere(), dataWord.getRoiNumber());
       }
     }
     if (dataWord.getSectorLocation() == MuCTPI_RDO::BARREL) {
@@ -961,8 +883,8 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
   for ( uint16_t i = 0; i < MuCTPI_RDO::MULT_THRESH_NUM; ++i ) {
     if ( multWord.getMultiplicity(i) != MioctPtCount[i] ) {
       anyMismatch = true;
-      ATH_MSG(WARNING) << "pT threshold " << i+1 << ": MICTP multiplicity (" << multWord.getMultiplicity(i)
-		       << ") not equal MIOCT multiplicity (" << MioctPtCount[i] << ")" <<  endmsg;
+      ATH_MSG_WARNING( "pT threshold " << i+1 << ": MICTP multiplicity (" << multWord.getMultiplicity(i)
+                        << ") not equal MIOCT multiplicity (" << MioctPtCount[i] << ")");
       errorSummary->Fill(5,1);
       errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 5);
       errorPerLumiBlock->Fill(m_currentLumiBlock);
@@ -986,22 +908,21 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
     std::vector<uint32_t> vStatus =
       theMuCTPI_RIO->getHeaderStatusWords();
     for ( uint32_t i = 0; i < num; ++i ) {
-      if (vStatus[i] != 0) {
-	TH1F_LW *hist = 0;
-	if (i == 0) {
-	  ATH_MSG(DEBUG) << "MuCTPI error status word #" << i
-	      << ": 0x" << MSG::hex << vStatus[i] << MSG::dec
-	      << endmsg;
-	  hist = muctpiStatus1;
-	} else if (i == 1) {
-	  hist = muctpiStatus2;
-	} else {
-	  continue;
-	}
-	for ( int bit = 0; bit < 24; ++bit ) {
-	  if (vStatus[i] & (1 << bit))
-	    hist->Fill(bit);
-	}
+      if (vStatus[i] == 0) {
+        continue;
+      }
+      TH1F_LW *hist = 0;
+      if (i == 0) {
+        ATH_MSG_DEBUG( "MuCTPI error status word #" << i << ": 0x" << MSG::hex << vStatus[i] << MSG::dec);
+        hist = muctpiStatus1;
+      } else if (i == 1) {
+        hist = muctpiStatus2;
+      } else {
+        continue;
+      }
+      for ( int bit = 0; bit < 24; ++bit ) {
+        if (vStatus[i] & (1 << bit))
+          hist->Fill(bit);
       }
     }
   }
@@ -1009,9 +930,9 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
   const EventInfo* eventInfo = 0; 
   StatusCode sc = StatusCode::SUCCESS;
   sc = evtStore()->retrieve(eventInfo);
-      if (!sc.isSuccess()) {
-         ATH_MSG(WARNING) << "Could not retrieve EventInfo from StoreGate" << endmsg;
-      }
+  if (!sc.isSuccess()) {
+    ATH_MSG_WARNING( "Could not retrieve EventInfo from StoreGate");
+  }
 
   // Get candidates from TGC and RPC SLs for comparisons
 
@@ -1067,9 +988,9 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
     int tgcnum = tgcCandidates.count(it_mui->first); 
     int rpcnum = rpcCandidates.count(it_mui->first); 
     if (tgcnum > 0 || rpcnum > 0 ) {
-      ATH_MSG(DEBUG) << "MuCTPI to RPC/TGC match found: MuCTPI key/ MuCTPI BCID / #TGC matches / #RPC matches: "
+      ATH_MSG_DEBUG( "MuCTPI to RPC/TGC match found: MuCTPI key/ MuCTPI BCID / #TGC matches / #RPC matches: "
 		     << it_mui->first << " / " << /*it_mui->second.getBCID() <<*/ " / " 
-		     << tgcnum << " / " << rpcnum << endmsg;
+		     << tgcnum << " / " << rpcnum);
     } else {
       if ( (it_mui->first).substr(0,2) == "BA" )  { 
 	int baSecID = (it_mui->second).getSectorID(1)+32*(it_mui->second).getHemisphere();
@@ -1087,11 +1008,11 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
 	muctpiNoTGCfwCandfound->Fill(fwRoIID,fwSecID);
 	miTGCmismatch= true;
       } else {
-	ATH_MSG(WARNING) << "Invalid string label in MuCTPI to RPC/TGC map: " 
-			 << (it_mui->first).substr(0,2) << endmsg;
+	ATH_MSG_WARNING( "Invalid string label in MuCTPI to RPC/TGC map: " 
+			 << (it_mui->first).substr(0,2));
       }
-      ATH_MSG(WARNING) << "No Muctpi to RPC/TGC match found: MuCTPI key / MuCTPI BCID: " 
-		       << it_mui->first  << " / " << /*it_mui->second.getBCID() <<*/ endmsg;
+      ATH_MSG_WARNING( "No Muctpi to RPC/TGC match found: MuCTPI key / MuCTPI BCID: " 
+		       << it_mui->first  << " / ");
     }
   }
 
@@ -1117,16 +1038,16 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
        it_rpc != rpcCandidates.end(); ++it_rpc) {
     int muinum = muctpiCandidates.count(it_rpc->first); 
     if (muinum > 0) {
-      ATH_MSG(DEBUG) << " RPC to Muctpi match found: RPC key / RPC BCID / # matches: "
+      ATH_MSG_DEBUG( " RPC to Muctpi match found: RPC key / RPC BCID / # matches: "
 		     << it_rpc->first << " / " <<  it_rpc->second->rowinBcid()  << " / " 
-		     << muinum << endmsg;
+		     << muinum);
     } else {
       int idEnd = (it_rpc->first).find("-RoI");
       int secID = std::stoi((it_rpc->first).substr(2,idEnd-2));
       int roiID = (it_rpc->second)->roi();
       rpcNoMuCTPICandfound->Fill(roiID,secID);
-      ATH_MSG(WARNING) << "No RPC to Muctpi  match found: RPC key / RPC BCID: " 
-		       << it_rpc->first << " / " <<  it_rpc->second->rowinBcid() << endmsg;
+      ATH_MSG_WARNING( "No RPC to Muctpi  match found: RPC key / RPC BCID: " 
+		       << it_rpc->first << " / " <<  it_rpc->second->rowinBcid());
       rpcMImismatch =true;
     }
   }
@@ -1143,8 +1064,8 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
        it_tgc != tgcCandidates.end(); ++it_tgc) {
     int muinum = muctpiCandidates.count(it_tgc->first); 
     if (muinum > 0) {
-      ATH_MSG(DEBUG) << "TGC to Muctpi match found: TGC key / TGC BCID / # matches: "
-		     << it_tgc->first  << " / " << (int)TgcDigit::BC_CURRENT << muinum << endmsg;
+      ATH_MSG_DEBUG( "TGC to Muctpi match found: TGC key / TGC BCID / # matches: "
+		     << it_tgc->first  << " / " << (int)TgcDigit::BC_CURRENT << muinum);
     } else {
       int idEnd = (it_tgc->first).find("-RoI");
       int secID = std::stoi((it_tgc->first).substr(2,idEnd-2));
@@ -1155,10 +1076,10 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
 	int fwRoIID = (it_tgc->second)->roi();
 	tgcfwNoMuCTPICandfound->Fill(fwRoIID,secID);
       } else {
-	ATH_MSG(WARNING) << "Invalid string label in TGC to MuCTPI map: " 
-			 << (it_tgc->first).substr(0,2) << endmsg;
+	ATH_MSG_WARNING( "Invalid string label in TGC to MuCTPI map: " 
+			 << (it_tgc->first).substr(0,2));
       }
-      ATH_MSG(WARNING) << "No TGC to Muctpi match found: TGC key: " << it_tgc->first << endmsg;
+      ATH_MSG_WARNING( "No TGC to Muctpi match found: TGC key: " << it_tgc->first);
       tgcMImismatch =true;
     }
   }
@@ -1171,13 +1092,9 @@ doMuctpi(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO
   }
 }
 
-
-
-
-
-void TrigT1CTMonitoring::BSMonitoring::
-doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO) {
-
+void
+TrigT1CTMonitoring::BSMonitoring::doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
+{
    TProfile_LW *errorSummary = getTProfile("errorSummary");
    TH1F_LW *errorPerLumiBlock = getTH1("errorPerLumiBlock");
    TH1F_LW *deltaBcid = getTH1("deltaBcid");
@@ -1193,17 +1110,16 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
 
    if ( !errorSummary || !errorPerLumiBlock || !deltaBcid || !triggerType || !timeSinceLBStart || 
         !timeUntilLBEnd || !timeSinceL1A || !tcTimeError || !tcTimeErrorVsLb || !ctpStatus1 || !tav || !ctpStatus2 ) {
-      ATH_MSG(FATAL) << "Problems finding 1D histograms for CTP!" << endmsg;
+      ATH_MSG_FATAL("Problems finding 1D histograms for CTP!");
       return;
    }
 
    TH2F_LW* errorSummaryPerLumiBlock = getTH2("errorSummaryPerLumiBlock");
    TH2F_LW *pitBC = getTH2("pitBC");
    TH2F_LW *pitFirstBC = getTH2("pitFirstBC");
-  
+
    if ( !errorSummaryPerLumiBlock || !pitBC || !pitFirstBC ) {
-      ATH_MSG(FATAL) << "Problems finding 2D histograms for CTP!"
-                     << endmsg;
+      ATH_MSG_FATAL("Problems finding 2D histograms for CTP!");
       return;
    }
 
@@ -1223,17 +1139,17 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
 
       // check that the LB number is the same in the EventInfo and the CTP_RIO. TODO: add error for this?
       if (m_currentLumiBlock != (theCTP_RIO->getDetectorEventType() & 0xffff)) {
-         ATH_MSG(WARNING) << "LB number in EventInfo (" << m_currentLumiBlock 
+         ATH_MSG_WARNING( "LB number in EventInfo (" << m_currentLumiBlock 
                           << ") does not match the one in the CTP_RIO object (" 
-                          << (theCTP_RIO->getDetectorEventType() & 0xffff) << ")" << endmsg;
+                          << (theCTP_RIO->getDetectorEventType() & 0xffff) << ")");
       }
     
-      //ATH_MSG(DEBUG) << getEventInfoString() << endmsg;
+      //ATH_MSG_DEBUG( getEventInfoString());
 
       if (m_currentLumiBlock > m_maxLumiBlock) m_maxLumiBlock = m_currentLumiBlock;
       if (m_currentLumiBlock < 1 || 
           (m_retrievedLumiBlockTimes && (find(m_lumiBlocks.begin(), m_lumiBlocks.end(), m_currentLumiBlock) == m_lumiBlocks.end()))) {
-         ATH_MSG(WARNING) << "Invalid lumi block: " << m_currentLumiBlock << endmsg;
+         ATH_MSG_WARNING( "Invalid lumi block: " << m_currentLumiBlock);
          errorSummary->Fill(9,1);
          errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 9);
          errorPerLumiBlock->Fill(m_currentLumiBlock);
@@ -1243,10 +1159,10 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
          if (m_retrievedLumiBlockTimes) {
             uint64_t eventTime = static_cast<uint64_t>(theCTP_RDO->getTimeSec()*1e09 + theCTP_RDO->getTimeNanoSec());
             if (eventTime < m_lbStartTimes[m_currentLumiBlock] || eventTime > m_lbEndTimes[m_currentLumiBlock]) {
-               ATH_MSG(WARNING) << "Event time (" << eventTime 
+               ATH_MSG_WARNING( "Event time (" << eventTime 
                                 << ") not within time interval for current lumi block (LB: " << m_currentLumiBlock 
                                 << ", start: " <<  m_lbStartTimes[m_currentLumiBlock] 
-                                << ", stop: " << m_lbEndTimes[m_currentLumiBlock] << ")" << endmsg;
+                                << ", stop: " << m_lbEndTimes[m_currentLumiBlock] << ")");
                errorSummary->Fill(10,1);
                errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 10);
                errorPerLumiBlock->Fill(m_currentLumiBlock);
@@ -1272,12 +1188,12 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
                else {
                   bcDurationInNs = 1./freqFromCool*1e9;
                }
-               ATH_MSG(DEBUG) << "Will use BC interval calculated from frequency measurement(s) in COOL: f = " 
-                              << freqFromCool << " Hz => t_BC = " << bcDurationInNs << " ns" << endmsg; 
+               ATH_MSG_DEBUG( "Will use BC interval calculated from frequency measurement(s) in COOL: f = " 
+                              << freqFromCool << " Hz => t_BC = " << bcDurationInNs << " ns"); 
             }
             else {
-               ATH_MSG(DEBUG) << "No valid frequency measurements found in COOL, will use hardcoded BC interval: t_BC = " 
-                              << bcDurationInNs << " ns" << endmsg; //TODO: make this a WARNING when everything is in place in COOL
+               ATH_MSG_DEBUG( "No valid frequency measurements found in COOL, will use hardcoded BC interval: t_BC = " 
+                              << bcDurationInNs << " ns"); //TODO: make this a WARNING when everything is in place in COOL
             }
 
             // set the reference variables for the turn counter monitoring if this is the first processed event of the run/LB
@@ -1303,8 +1219,8 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
                     !((m_dataTakingMode.find(m_currentLumiBlock) != m_dataTakingMode.end()) &&
                       (m_dataTakingMode[m_currentLumiBlock] == true)) && 
                     (fabs(tDiffInNs) > 45000) ) { 
-                  ATH_MSG(WARNING) << "Turn-counter based time off by " << tDiffInNs 
-                                   << " ns (> 0.5 LHC turn) during stable beams - missing orbit pulse?" << endmsg;
+                  ATH_MSG_WARNING( "Turn-counter based time off by " << tDiffInNs 
+                                   << " ns (> 0.5 LHC turn) during stable beams - missing orbit pulse?");
                   errorSummary->Fill(16,1);
                   errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 16);
                   errorPerLumiBlock->Fill(m_currentLumiBlock);
@@ -1316,14 +1232,14 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
                tcTimeErrorVsLb->Fill(m_currentLumiBlock, tDiffInNs/1e03);
             }
             else {
-               ATH_MSG(DEBUG) << "Turn counter = 0 for both first processed and current event, not filling TC histograms" << endmsg;
+               ATH_MSG_DEBUG( "Turn counter = 0 for both first processed and current event, not filling TC histograms");
             }
          }
       }
    }
 
    if (theCTP_RDO->getTimeNanoSec() > 1e09) {
-      ATH_MSG(WARNING) << "Nanosecond timestamp too large: " << theCTP_RDO->getTimeNanoSec() << endmsg;
+      ATH_MSG_WARNING( "Nanosecond timestamp too large: " << theCTP_RDO->getTimeNanoSec());
       errorSummary->Fill(11,1);
       errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 11);
       errorPerLumiBlock->Fill(m_currentLumiBlock);
@@ -1346,8 +1262,8 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
       deltaBcid->Fill(bcid_offset);
       if (bcid_offset != 0) {
          if (!m_runOnESD) {
-            ATH_MSG(WARNING) << "Found BCID offset of "<< bcid_offset << " between ROD Header (" 
-                             << headerBcid << ") and data (" << (bcid&0xf) << ")" << endmsg;
+            ATH_MSG_WARNING( "Found BCID offset of "<< bcid_offset << " between ROD Header (" 
+                             << headerBcid << ") and data (" << (bcid&0xf) << ")");
             errorSummary->Fill(1,1);
             errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 1);
             errorPerLumiBlock->Fill(m_currentLumiBlock);
@@ -1409,7 +1325,7 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
          if ( (!bunchIndex) && (m_compareRerun) ) {//gives position of L1A
             StatusCode sc = compareRerun(*it);
             if ( sc.isFailure() ) {
-               ATH_MSG(WARNING) << "compareRerun() returned failure" << endmsg;
+               ATH_MSG_WARNING( "compareRerun() returned failure");
             }
          }
 
@@ -1444,25 +1360,25 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
       bool allTAPFine=true;
       bool allTAVFine=true;
       for ( unsigned int i=0; i<m_tapItems.size(); i++ ) {
-         ATH_MSG(DEBUG) << m_tapItems.at(i) << " TAP fired at BC " << m_tapBC.at(i) << endmsg;
+         ATH_MSG_DEBUG( m_tapItems.at(i) << " TAP fired at BC " << m_tapBC.at(i));
          bool isTBP=false;
          for ( unsigned int j=0; j<m_tbpItems.size() && isTBP==false; j++ ) {
             if ( m_tbpItems.at(j)==m_tapItems.at(i) && m_tbpBC.at(j)==m_tapBC.at(i) ) isTBP=true;
          }
          if ( isTBP==false ) {
             allTAPFine=false;
-            ATH_MSG(WARNING) << "TAP item " << m_tapItems.at(i) << " at BC " << m_tapBC.at(i) << " not found in TBP" << endmsg;
+            ATH_MSG_WARNING( "TAP item " << m_tapItems.at(i) << " at BC " << m_tapBC.at(i) << " not found in TBP");
          }
       }
       for ( unsigned int i=0; i<m_tavItems.size(); i++ ) {
-         ATH_MSG(DEBUG) << m_tavItems.at(i) << " TAV fired at BC " << m_tavBC.at(i) << endmsg;
+         ATH_MSG_DEBUG( m_tavItems.at(i) << " TAV fired at BC " << m_tavBC.at(i));
          bool isTAP=false;
          for ( unsigned int j=0; j<m_tapItems.size() && isTAP==false; j++ ) {
             if ( m_tapItems.at(j)==m_tavItems.at(i) && m_tapBC.at(j)==m_tavBC.at(i) ) isTAP=true;
          }
          if ( isTAP==false ) {
             allTAVFine=false;
-            ATH_MSG(WARNING) << "TAV item " << m_tavItems.at(i) << " at BC " << m_tavBC.at(i) << " not found in TAP" << endmsg;
+            ATH_MSG_WARNING( "TAV item " << m_tavItems.at(i) << " at BC " << m_tavBC.at(i) << " not found in TAP");
          }
       }
 
@@ -1495,11 +1411,11 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
       for ( unsigned int i = 0; i < triggersFired.size(); ++i ) {
          str << triggersFired[i] << " ";
       }
-      ATH_MSG(DEBUG) << triggersFired.size() << " trigger items fired: " << str.str() << endmsg;
+      ATH_MSG_DEBUG( triggersFired.size() << " trigger items fired: " << str.str());
    } 
    else {
       if (!m_runOnESD) {
-         ATH_MSG(WARNING) << "Zero bunches in CTP data for ext. LVL1 ID 0x" << MSG::hex << evId << MSG::dec << endmsg;
+         ATH_MSG_WARNING( "Zero bunches in CTP data for ext. LVL1 ID 0x" << MSG::hex << evId << MSG::dec);
          errorSummary->Fill(2,1);
          errorSummary->Fill(m_currentLumiBlock, 2);
          errorPerLumiBlock->Fill(m_currentLumiBlock);
@@ -1516,7 +1432,7 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
          if (vStatus[i] != 0) {
             TH1F_LW *hist = 0;
             if (i == 0) {
-               ATH_MSG(DEBUG) << "CTP error status word #" << i << ": 0x" << MSG::hex << vStatus[i] << MSG::dec << endmsg;
+               ATH_MSG_DEBUG( "CTP error status word #" << i << ": 0x" << MSG::hex << vStatus[i] << MSG::dec);
                hist = ctpStatus1;
             } else if (i == 1) {
                hist = ctpStatus2;
@@ -1532,10 +1448,9 @@ doCtp(const DataHandle<CTP_RDO> theCTP_RDO,const DataHandle<CTP_RIO> theCTP_RIO)
    }
 }
 
-
-
-void TrigT1CTMonitoring::BSMonitoring::
-updateRangeUser() {
+void
+TrigT1CTMonitoring::BSMonitoring::updateRangeUser()
+{
   //Make 2D plots readable
   if (m_lastminbc!=m_lastmaxbc) {
     TH2F_LW* h;
@@ -1547,12 +1462,10 @@ updateRangeUser() {
   if ((h1=getTH1("errorPerLumiBlock"))) h1->getROOTHist()->GetXaxis()->SetRangeUser(-0.5, m_maxLumiBlock+0.5);
 }
 
-void TrigT1CTMonitoring::BSMonitoring::
-doCtpMuctpi(const DataHandle<CTP_RDO> theCTP_RDO,
-	    const DataHandle<CTP_RIO> theCTP_RIO,
-	    const DataHandle<MuCTPI_RDO> theMuCTPI_RDO,
-	    const DataHandle<MuCTPI_RIO> theMuCTPI_RIO) {
-
+void
+TrigT1CTMonitoring::BSMonitoring::doCtpMuctpi( const DataHandle<CTP_RDO> theCTP_RDO, const DataHandle<CTP_RIO> theCTP_RIO,
+                                                const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO> theMuCTPI_RIO)
+{
   TProfile_LW *errorSummary = getTProfile("errorSummary");
   TH2F_LW* errorSummaryPerLumiBlock = getTH2("errorSummaryPerLumiBlock");
   TH1F_LW *errorPerLumiBlock = getTH1("errorPerLumiBlock");
@@ -1560,7 +1473,7 @@ doCtpMuctpi(const DataHandle<CTP_RDO> theCTP_RDO,
   TH1F_LW *headerBCIDDifference = getTH1("headerBCIDDifference");
   TH1F_LW *bcidDifference = getTH1("bcidDifference");
   if ( !errorSummary || !errorSummaryPerLumiBlock || !errorPerLumiBlock || !headerL1IdDifference || !headerBCIDDifference || !bcidDifference ) {
-    ATH_MSG(FATAL) << "Problems finding histograms for CTP_MuCTPI!" << endmsg;
+    ATH_MSG_FATAL("Problems finding histograms for CTP_MuCTPI!");
     return;
   }
   if (theCTP_RIO && theMuCTPI_RIO) {
@@ -1575,7 +1488,7 @@ doCtpMuctpi(const DataHandle<CTP_RDO> theCTP_RDO,
     headerL1IdDifference->Fill(diffValEvid);
     headerBCIDDifference->Fill(diffValBcid);
     if (diffValBcid!=0) {
-      ATH_MSG(WARNING) << "BCID mismatch between CTP and MuCTPI RIOs, filling error histograms" << endmsg;
+      ATH_MSG_WARNING( "BCID mismatch between CTP and MuCTPI RIOs, filling error histograms");
       errorSummary->Fill(3,1);
       errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 3);
       errorPerLumiBlock->Fill(m_currentLumiBlock);
@@ -1584,14 +1497,12 @@ doCtpMuctpi(const DataHandle<CTP_RDO> theCTP_RDO,
 
     if (diffValBcid < headerBCIDDifference->getXMin()
 	|| diffValBcid > headerBCIDDifference->getXMax()) {
-      ATH_MSG(WARNING) << "BCID difference out of range. CTP_RODHeader_BCID: "
-		       << ctp_bcid << " MuCTPI_RODHeader_BCID: " << (muctpi_bcid) << endmsg;      
+      ATH_MSG_WARNING( "BCID difference out of range. CTP_RODHeader_BCID: "
+		       << ctp_bcid << " MuCTPI_RODHeader_BCID: " << (muctpi_bcid));      
     }
   }
-  MuCTPI_MultiplicityWord_Decoder multWord(theMuCTPI_RDO->
-					   candidateMultiplicity(),
-					   m_inclusiveTriggerThresholds);
-  MuCTPI_DataWord_Decoder dataWord(0);
+   MuCTPI_MultiplicityWord_Decoder multWord(theMuCTPI_RDO->candidateMultiplicity(), m_inclusiveTriggerThresholds);
+   MuCTPI_DataWord_Decoder dataWord(0);
 
   CTP_Decoder ctp;
   ctp.setRDO(theCTP_RDO);
@@ -1606,237 +1517,267 @@ doCtpMuctpi(const DataHandle<CTP_RDO> theCTP_RDO,
   }
 }
 
-void TrigT1CTMonitoring::BSMonitoring::
-doMuonRoI(const DataHandle<MuCTPI_RDO> theMuCTPI_RDO,
-	  const DataHandle<MuCTPI_RIO> theMuCTPI_RIO,
-	  const DataHandle<ROIB::RoIBResult> roib) {
-
-  TProfile_LW *errorSummary = getTProfile("errorSummary");
-  TH2F_LW* errorSummaryPerLumiBlock = getTH2("errorSummaryPerLumiBlock");
-  TH1F_LW *errorPerLumiBlock = getTH1("errorPerLumiBlock");
-  TH1F_LW *roiEta = getTH1("roiEta");
-  TH1F_LW *roiPhi = getTH1("roiPhi");
-  TH1F_LW *nCandidates_secLoc = getTH1("nCandidates_secLoc");
+void
+TrigT1CTMonitoring::BSMonitoring::doMuonRoI( const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO> theMuCTPI_RIO,
+                                             const DataHandle<ROIB::RoIBResult> roib)
+{
+   TProfile_LW *errorSummary = getTProfile("errorSummary");
+   TH2F_LW* errorSummaryPerLumiBlock = getTH2("errorSummaryPerLumiBlock");
+   TH1F_LW *errorPerLumiBlock = getTH1("errorPerLumiBlock");
+   TH1F_LW *roiEta = getTH1("roiEta");
+   TH1F_LW *roiPhi = getTH1("roiPhi");
+   TH1F_LW *nCandidates_secLoc = getTH1("nCandidates_secLoc");
 
-  if ( !errorSummary || !errorSummaryPerLumiBlock || !errorPerLumiBlock || !roiEta || !roiPhi || !nCandidates_secLoc ) {
-    ATH_MSG(FATAL) << "Problems finding 1D histograms for RoI!" << endmsg;
-    return;
-  }
-  TH2F_LW *roiEtaPhi = getTH2("roiEtaPhi");
-  TH2F_LW *barrelSectorIDRoi = getTH2("barrelSectorIDRoi");
-  TH2F_LW *endcapSectorIDRoi = getTH2("endcapSectorIDRoi");
-  TH2F_LW *forwardSectorIDRoi = getTH2("forwardSectorIDRoi");
-  TH2F_LW *barrelSectorIDRoiEta = getTH2("barrelSectorIDRoiEta");
-  TH2F_LW *endcapSectorIDRoiEta = getTH2("endcapSectorIDRoiEta");
-  TH2F_LW *forwardSectorIDRoiEta = getTH2("forwardSectorIDRoiEta");
-  TH2F_LW *barrelSectorIDRoiPhi = getTH2("barrelSectorIDRoiPhi");
-  TH2F_LW *endcapSectorIDRoiPhi = getTH2("endcapSectorIDRoiPhi");
-  TH2F_LW *forwardSectorIDRoiPhi = getTH2("forwardSectorIDRoiPhi");
+   if ( !errorSummary || !errorSummaryPerLumiBlock || !errorPerLumiBlock || !roiEta || !roiPhi || !nCandidates_secLoc ) {
+      ATH_MSG_FATAL("Problems finding 1D histograms for RoI!");
+      return;
+   }
+   TH2F_LW *roiEtaPhi = getTH2("roiEtaPhi");
+   TH2F_LW *barrelSectorIDRoi = getTH2("barrelSectorIDRoi");
+   TH2F_LW *endcapSectorIDRoi = getTH2("endcapSectorIDRoi");
+   TH2F_LW *forwardSectorIDRoi = getTH2("forwardSectorIDRoi");
+   TH2F_LW *barrelSectorIDRoiEta = getTH2("barrelSectorIDRoiEta");
+   TH2F_LW *endcapSectorIDRoiEta = getTH2("endcapSectorIDRoiEta");
+   TH2F_LW *forwardSectorIDRoiEta = getTH2("forwardSectorIDRoiEta");
+   TH2F_LW *barrelSectorIDRoiPhi = getTH2("barrelSectorIDRoiPhi");
+   TH2F_LW *endcapSectorIDRoiPhi = getTH2("endcapSectorIDRoiPhi");
+   TH2F_LW *forwardSectorIDRoiPhi = getTH2("forwardSectorIDRoiPhi");
   if ( !roiEtaPhi || !barrelSectorIDRoi || !endcapSectorIDRoi || !forwardSectorIDRoi || 
        !barrelSectorIDRoiEta || !endcapSectorIDRoiEta || !forwardSectorIDRoiEta || 
        !barrelSectorIDRoiPhi || !endcapSectorIDRoiPhi || !forwardSectorIDRoiPhi ) {
-    ATH_MSG(FATAL) << "Problems finding 2D histograms for RoI!" << endmsg;
+      ATH_MSG_FATAL("Problems finding 2D histograms for RoI!");
     return;
   }
 
-  const std::vector<ROIB::MuCTPIRoI> roiVec = roib->muCTPIResult().roIVec();
-
-  int bcidMismatch = 0;
-  uint16_t bcId;
-  uint16_t pTval;
-  uint16_t pTnum;
-  double eta;
-  double phi;
-  uint16_t secID;
-  uint16_t sysID;
-  uint16_t hemisphere;
-  uint16_t roInum;
-  bool accepted;
-  bool first;
-  bool duplicatedRoI;
-  bool duplicatedSector;
-  int candNum=0;
+   const std::vector<ROIB::MuCTPIRoI> roiVec = roib->muCTPIResult().roIVec();
+   int bcidMismatch = 0;
+   uint16_t bcId;
+   uint16_t pTval;
+   uint16_t pTnum;
+   double eta;
+   double phi;
+   uint16_t secID;
+   uint16_t sysID;
+   uint16_t hemisphere;
+   uint16_t roInum;
+   bool accepted;
+   bool first;
+   bool duplicatedRoI;
+   bool duplicatedSector;
+   int candNum=0;
 
   if (theMuCTPI_RIO) {
     for ( int i = 0; i < theMuCTPI_RIO->getNRoI(); i++ ) {
       if (!theMuCTPI_RIO->getRoI(i, bcId, pTval, pTnum, eta, phi, secID, sysID, hemisphere, 
-				 roInum, accepted, first, duplicatedRoI, duplicatedSector)) {
-	ATH_MSG(WARNING) << "RoI with index " << i  << " not found, skipping this RoI" << endmsg;
-	continue;
+         roInum, accepted, first, duplicatedRoI, duplicatedSector)) {
+      ATH_MSG_WARNING( "RoI with index " << i  << " not found, skipping this RoI");
+      continue;
+         }
+         roiEtaPhi->Fill(eta, phi);
+         roiEta->Fill(eta);
+         roiPhi->Fill(phi);
+         if (theMuCTPI_RIO->getBCID() != bcId) bcidMismatch++;
       }
-      roiEtaPhi->Fill(eta, phi);
-      roiEta->Fill(eta);
-      roiPhi->Fill(phi);
-      if (theMuCTPI_RIO->getBCID() != bcId) bcidMismatch++;
-    }
 
     for ( unsigned int j = 0; j < roiVec.size(); j++ ) {
       bool isCand = false;
       for ( int i = 0; i < theMuCTPI_RIO->getNRoI(); i++ ) {
-	theMuCTPI_RIO->getRoI(i, bcId, pTval, pTnum, eta, phi, secID, sysID, hemisphere, 
-			      roInum, accepted, first, duplicatedRoI, duplicatedSector);
-	if ((roiVec[j].getRoiNumber() == roInum) && 
-	    (roiVec[j].pt() == pTnum) && 
-	    (roiVec[j].getSectorID() == secID) &&
-	    (roiVec[j].getSectorLocation() == sysID) &&
-	    (roiVec[j].getHemisphere() == hemisphere) &&
-	    (theMuCTPI_RIO->getBCID() == bcId)) {
-	  isCand=true;
-	  candNum=i;
-	}
+  theMuCTPI_RIO->getRoI(i, bcId, pTval, pTnum, eta, phi, secID, sysID, hemisphere, 
+            roInum, accepted, first, duplicatedRoI, duplicatedSector);
+  if ((roiVec[j].getRoiNumber() == roInum) && 
+         (roiVec[j].pt() == pTnum) && 
+         (roiVec[j].getSectorID() == secID) &&
+         (roiVec[j].getSectorLocation() == sysID) &&
+         (roiVec[j].getHemisphere() == hemisphere) &&
+         (theMuCTPI_RIO->getBCID() == bcId)) {
+      isCand=true;
+      candNum=i;
+      }
+         }
+         if (isCand == false) {
+      ATH_MSG_WARNING( "No DAQ muon for RoI number " 
+         << roiVec[j].getRoiNumber() << ", pT " << roiVec[j].pt() << ", and sector ID " 
+         << roiVec[j].getSectorID());
+      errorSummary->Fill(7,1);
+      errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 7);
+      errorPerLumiBlock->Fill(m_currentLumiBlock);
+         }
+         else {
+      errorSummary->Fill(7,0);
+      theMuCTPI_RIO->getRoI(candNum, bcId, pTval, pTnum, eta, phi, secID, sysID, hemisphere, 
+                  roInum, accepted, first, duplicatedRoI, duplicatedSector);
+      if (theMuCTPI_RDO) {// go back to data words to check sector locations
+      MuCTPI_DataWord_Decoder dataWord(0);
+      const std::vector<uint32_t> &vDataWords = theMuCTPI_RDO->dataWord();
+      for ( std::vector<uint32_t>::const_iterator it = vDataWords.begin(); it != vDataWords.end(); ++it ) {
+         dataWord.setWord(*it);
+
+         // MuCTPI_DataWord_Decoder only corrects sector ID for hemisphere if candidate is barrel
+         // correct back for this by providing an argument to getSectorID
+         uint16_t sectorID = dataWord.getSectorID();
+         if (dataWord.getSectorLocation() == MuCTPI_RDO::BARREL)
+            sectorID=dataWord.getSectorID(1);
+         
+         if (//(dataWord.getBCID() == theMuCTPI_RIO->getBCID())
+         //&& 
+         (sectorID == secID)
+         && (dataWord.getRoiNumber() == roInum)
+         && (dataWord.getSectorLocation() == sysID)
+         && (dataWord.getHemisphere() == hemisphere)) {
+
+            nCandidates_secLoc->Fill(dataWord.getSectorLocation());
+            
+            if (dataWord.getSectorLocation() == MuCTPI_RDO::BARREL) {
+         barrelSectorIDRoi->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere(), roInum); 
+         barrelSectorIDRoiEta->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere(), eta);
+         barrelSectorIDRoiPhi->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere(), phi);
+            }
+            else if (dataWord.getSectorLocation() == MuCTPI_RDO::ENDCAP) {
+         endcapSectorIDRoi->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere(), roInum);
+         endcapSectorIDRoiEta->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere(), eta);
+         endcapSectorIDRoiPhi->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere(), phi);
+            }
+            else if (dataWord.getSectorLocation() == MuCTPI_RDO::FORWARD) {
+         forwardSectorIDRoi->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere(), roInum);
+         forwardSectorIDRoiEta->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere(), eta);
+         forwardSectorIDRoiPhi->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere(), phi);
+            }
+         }
       }
-      if (isCand == false) {
-	ATH_MSG(WARNING) << "No DAQ muon for RoI number " 
-	    << roiVec[j].getRoiNumber() << ", pT " << roiVec[j].pt() << ", and sector ID " 
-	    << roiVec[j].getSectorID() << endmsg;
-	errorSummary->Fill(7,1);
-	errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 7);
-	errorPerLumiBlock->Fill(m_currentLumiBlock);
       }
-      else {
-	errorSummary->Fill(7,0);
-	theMuCTPI_RIO->getRoI(candNum, bcId, pTval, pTnum, eta, phi, secID, sysID, hemisphere, 
-			      roInum, accepted, first, duplicatedRoI, duplicatedSector);
-	if (theMuCTPI_RDO) {// go back to data words to check sector locations
-	  MuCTPI_DataWord_Decoder dataWord(0);
-	  const std::vector<uint32_t> &vDataWords = theMuCTPI_RDO->dataWord();
-	  for ( std::vector<uint32_t>::const_iterator it = vDataWords.begin(); it != vDataWords.end(); ++it ) {
-	    dataWord.setWord(*it);
-
-	    // MuCTPI_DataWord_Decoder only corrects sector ID for hemisphere if candidate is barrel
-	    // correct back for this by providing an argument to getSectorID
-	    uint16_t sectorID = dataWord.getSectorID();
-	    if (dataWord.getSectorLocation() == MuCTPI_RDO::BARREL)
-	      sectorID=dataWord.getSectorID(1);
-	    
-	    if (//(dataWord.getBCID() == theMuCTPI_RIO->getBCID())
-		//&& 
-		(sectorID == secID)
-		&& (dataWord.getRoiNumber() == roInum)
-		&& (dataWord.getSectorLocation() == sysID)
-		&& (dataWord.getHemisphere() == hemisphere)) {
-
-	      nCandidates_secLoc->Fill(dataWord.getSectorLocation());
-	      
-	      if (dataWord.getSectorLocation() == MuCTPI_RDO::BARREL) {
-		barrelSectorIDRoi->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere(), roInum); 
-		barrelSectorIDRoiEta->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere(), eta);
-		barrelSectorIDRoiPhi->Fill(dataWord.getSectorID(1)+32*dataWord.getHemisphere(), phi);
-	      }
-	      else if (dataWord.getSectorLocation() == MuCTPI_RDO::ENDCAP) {
-		endcapSectorIDRoi->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere(), roInum);
-		endcapSectorIDRoiEta->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere(), eta);
-		endcapSectorIDRoiPhi->Fill(dataWord.getSectorID()+48*dataWord.getHemisphere(), phi);
-	      }
-	      else if (dataWord.getSectorLocation() == MuCTPI_RDO::FORWARD) {
-		forwardSectorIDRoi->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere(), roInum);
-		forwardSectorIDRoiEta->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere(), eta);
-		forwardSectorIDRoiPhi->Fill(dataWord.getSectorID()+24*dataWord.getHemisphere(), phi);
-	      }
-	    }
-	  }
-	}
+         }
       }
-    }
 
-    int lvl2Expected = static_cast<int>(theMuCTPI_RIO->getNRoI()) - bcidMismatch;
-    if (lvl2Expected != static_cast<int>(roiVec.size()) && lvl2Expected <= 14) {
-      ATH_MSG(WARNING) << "Expected " << lvl2Expected
-	  << " LVL2 RoIs, but found " << roiVec.size()
-	  << "!" << endmsg;
-      errorSummary->Fill(6,1);
-      errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 6);
-      errorPerLumiBlock->Fill(m_currentLumiBlock);
-    }
-    else if (static_cast<int>(roiVec.size()) != 14 && lvl2Expected >= 14) {
-      ATH_MSG(WARNING) << "Expected 14 RoI's from " << lvl2Expected
-	  << " MuCTPI RoI's, but found " << roiVec.size()
-	  << "!" << endmsg;
-      errorSummary->Fill(6,1);
-      errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 6);
-      errorPerLumiBlock->Fill(m_currentLumiBlock);
-    }
-    else errorSummary->Fill(6,0);
-  }
+      int lvl2Expected = static_cast<int>(theMuCTPI_RIO->getNRoI()) - bcidMismatch;
+      if (lvl2Expected != static_cast<int>(roiVec.size()) && lvl2Expected <= 14) {
+         ATH_MSG_WARNING( "Expected " << lvl2Expected
+      << " LVL2 RoIs, but found " << roiVec.size()
+      << "!");
+         errorSummary->Fill(6,1);
+         errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 6);
+         errorPerLumiBlock->Fill(m_currentLumiBlock);
+      }
+      else if (static_cast<int>(roiVec.size()) != 14 && lvl2Expected >= 14) {
+         ATH_MSG_WARNING( "Expected 14 RoI's from " << lvl2Expected
+      << " MuCTPI RoI's, but found " << roiVec.size()
+      << "!");
+         errorSummary->Fill(6,1);
+         errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 6);
+         errorPerLumiBlock->Fill(m_currentLumiBlock);
+      }
+      else errorSummary->Fill(6,0);
+   }
 }
 
-StatusCode TrigT1CTMonitoring::BSMonitoring::compareRerun(const CTP_BC &bunchCrossing) {
-
-  int Mismatch=0;
-
-  TProfile_LW *errorSummary = getTProfile("errorSummary");
-  TH2F_LW* errorSummaryPerLumiBlock = getTH2("errorSummaryPerLumiBlock");
-  TH1F_LW *errorPerLumiBlock = getTH1("errorPerLumiBlock");
-  TH1F_LW* l1ItemsBPSimMismatch = getTH1("l1ItemsBPSimMismatch");
-  TH1F_LW* l1ItemsBPSimMismatchItems = getTH1("l1ItemsBPSimMismatchItems");
-
-  const CTP_RDO* theCTP_RDO_Rerun = 0;
-  ATH_MSG(DEBUG) << "Retrieving CTP_RDO from SG with key CTP_RDO_Rerun" << endmsg;
-  CHECK( evtStore()->retrieve(theCTP_RDO_Rerun, "CTP_RDO_Rerun") );
-  
-  CTP_Decoder ctp_rerun;
-  ctp_rerun.setRDO(theCTP_RDO_Rerun);
-
-  const std::vector<CTP_BC> ctp_bc_rerun=ctp_rerun.getBunchCrossings();
-  if (ctp_bc_rerun.size() != 1) {
-    ATH_MSG(ERROR) << "Rerun simulation has non unity number of bunch crossings " << endmsg;
-    return StatusCode::FAILURE;
-  }
-
-
-  ATH_MSG(DEBUG) << "In compareRerun: dumping data for BC " << bunchCrossing.getBCID() << endmsg;
-  bunchCrossing.dumpData(msg());
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::compareRerun(const CTP_BC &bunchCrossing)
+{
+   bool itemMismatch{false};
 
-  ATH_MSG(DEBUG) << "In compareRerun: dumping rerun data for BC 0" << endmsg;
-  ctp_bc_rerun.at(0).dumpData(msg());
-  
-  ATH_MSG(DEBUG) << "Comparing TBP from CTP_RDO objects with keys CTP_RDO (from data) and CTP_RDO_Rerun (from simulation)" << endmsg;
-  
-  const std::bitset<512> currentTBP(bunchCrossing.getTBP());
-  const std::bitset<512> currentTBP_rerun(ctp_bc_rerun.at(0).getTBP());
- 
-  if ( currentTBP != currentTBP_rerun ) {
-    for ( TrigConf::TriggerItem* item: m_configSvc->ctpConfig()->menu().items() ) {
+   TProfile_LW *errorSummary = getTProfile("errorSummary");
+   TH2F_LW* errorSummaryPerLumiBlock = getTH2("errorSummaryPerLumiBlock");
+   TH1F_LW *errorPerLumiBlock = getTH1("errorPerLumiBlock");
+   TH1F_LW* l1ItemsBPSimMismatch = getTH1("l1ItemsBPSimMismatch");
+   TH1F_LW* l1ItemsBPSimMismatchItems = getTH1("l1ItemsBPSimMismatchItems");
+
+   const CTP_RDO* theCTP_RDO_Rerun = 0;
+   ATH_MSG_DEBUG( "Retrieving CTP_RDO from SG with key CTP_RDO_Rerun");
+   CHECK( evtStore()->retrieve(theCTP_RDO_Rerun, "CTP_RDO_Rerun") );
+   
+   CTP_Decoder ctp_rerun;
+   ctp_rerun.setRDO(theCTP_RDO_Rerun);
+
+   const std::vector<CTP_BC> ctp_bc_rerun=ctp_rerun.getBunchCrossings();
+   if (ctp_bc_rerun.size() != 1) {
+      ATH_MSG_ERROR( "Rerun simulation has non unity number of bunch crossings ");
+      return StatusCode::FAILURE;
+   }
 
-      std::vector<unsigned int> randoms;
-      item->topNode()->getAllRandomTriggers(randoms);
-      
-      //do not include random and non-simulated triggers in this test, so skip those
-      bool skip = randoms.size()>0 || item->name().find("L1_TRT") != string::npos || item->name().find("L1_ZB") != string::npos || item->name().find("_AFP") != string::npos;
-
-      if( skip ) continue;
-
-      bool tbp       = currentTBP.test( item->ctpId() );
-      bool tbp_rerun = currentTBP_rerun.test( item->ctpId() );
-      if ( tbp !=  tbp_rerun) {
-         ATH_MSG(WARNING) << "CTPSimulation TBP / TPB_rerun mismatch!! For L1Item '" << item->name() << "' (CTP ID " << item->ctpId() << "): data=" 
-                         << (tbp?"pass":"fail") << " != simulation=" << (tbp_rerun?"pass":"fail") << endmsg;
-        Mismatch=1;
-	l1ItemsBPSimMismatch->Fill(item->ctpId(),1);
-	l1ItemsBPSimMismatchItems->getROOTHist()->Fill( (item->name()).c_str(), 1 );
+   ATH_MSG_DEBUG( "In compareRerun: dumping data for BC " << bunchCrossing.getBCID());
+   bunchCrossing.dumpData(msg());
+
+   ATH_MSG_DEBUG( "In compareRerun: dumping rerun data for BC 0");
+   ctp_bc_rerun.at(0).dumpData(msg());
+   
+   ATH_MSG_DEBUG( "Comparing TBP from CTP_RDO objects with keys CTP_RDO (from data) and CTP_RDO_Rerun (from simulation)");
+   
+   const std::bitset<512> currentTBP(bunchCrossing.getTBP());
+   const std::bitset<512> currentTBP_rerun(ctp_bc_rerun.at(0).getTBP());
+   
+   if ( currentTBP != currentTBP_rerun ) {
+      if(m_useNewConfig) {
+         const TrigConf::L1Menu * l1menu = nullptr;
+         ATH_CHECK(detStore()->retrieve(l1menu));
+         for(const TrigConf::L1Item & item : *l1menu) {
+
+            //do not include random and non-simulated triggers in this test (can be configured)
+            bool skip = item.definition().find("RNDM") != string::npos;
+            for(const std::string & p : m_ignorePatterns) {
+               if(item.name().find(p) != string::npos) {
+                  skip = true;
+                  break;
+               }
+            }
+            if( skip ) continue;
+
+            bool tbp       = currentTBP.test( item.ctpId() );
+            bool tbp_rerun = currentTBP_rerun.test( item.ctpId() );
+            if ( tbp !=  tbp_rerun) {
+               ATH_MSG_WARNING( "CTPSimulation TBP / TPB_rerun mismatch!! For L1Item '" << item.name() 
+                              << "' (CTP ID " << item.ctpId() << "): data=" 
+                              << (tbp?"pass":"fail") << " != simulation=" << (tbp_rerun?"pass":"fail"));
+               itemMismatch=true;
+               l1ItemsBPSimMismatch->Fill(item.ctpId(),1);
+               l1ItemsBPSimMismatchItems->getROOTHist()->Fill( (item.name()).c_str(), 1 );
+            }
+         }
+      } else {  
+         for ( TrigConf::TriggerItem* item: m_configSvc->ctpConfig()->menu().items() ) {
+            std::vector<unsigned int> randoms;
+            item->topNode()->getAllRandomTriggers(randoms);
+
+            //do not include random and non-simulated triggers in this test (can be configured)
+            bool skip = randoms.size()>0;
+            for(const std::string & p : m_ignorePatterns) {
+               if(item->name().find(p) != string::npos) {
+                  skip = true;
+                  break;
+               }
+            }
+            if( skip ) continue;
+
+            bool tbp       = currentTBP.test( item->ctpId() );
+            bool tbp_rerun = currentTBP_rerun.test( item->ctpId() );
+            if ( tbp !=  tbp_rerun) {
+               ATH_MSG_WARNING( "CTPSimulation TBP / TPB_rerun mismatch!! For L1Item '" << item->name() 
+                              << "' (CTP ID " << item->ctpId() << "): data=" 
+                              << (tbp?"pass":"fail") << " != simulation=" << (tbp_rerun?"pass":"fail"));
+               itemMismatch=true;
+               l1ItemsBPSimMismatch->Fill(item->ctpId(),1);
+               l1ItemsBPSimMismatchItems->getROOTHist()->Fill( (item->name()).c_str(), 1 );
+            }
+         }
       }
-    }
-  }
+   }
 
-  if (Mismatch) {
-    ATH_MSG(WARNING) << "Mismatch between CTP data and simulation" << endmsg;
-    errorSummary->Fill(14,1);
-    errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 14);
-    errorPerLumiBlock->Fill(m_currentLumiBlock);
-  }
-  else errorSummary->Fill(14,0);
-  return StatusCode::SUCCESS;
+   if (itemMismatch) {
+      ATH_MSG_WARNING( "Mismatch between CTP data and simulation in BC " << bunchCrossing.getBCID());
+      errorSummary->Fill(14,1);
+      errorSummaryPerLumiBlock->Fill(m_currentLumiBlock, 14);
+      errorPerLumiBlock->Fill(m_currentLumiBlock);
+   } else {
+      errorSummary->Fill(14,0);
+   }
+   return StatusCode::SUCCESS;
 }
 
-void TrigT1CTMonitoring::BSMonitoring::
-dumpData(const DataHandle<CTP_RDO> theCTP_RDO,
-	 const DataHandle<CTP_RIO> theCTP_RIO,
-	 const DataHandle<MuCTPI_RDO> theMuCTPI_RDO,
-	 const DataHandle<MuCTPI_RIO> theMuCTPI_RIO,
-	 const DataHandle<ROIB::RoIBResult> roib) {
-
-  if ( !msgLvl(MSG::DEBUG) )
-    return;
+void
+TrigT1CTMonitoring::BSMonitoring::dumpData( const DataHandle<CTP_RDO> theCTP_RDO, const DataHandle<CTP_RIO> theCTP_RIO,
+                                            const DataHandle<MuCTPI_RDO> theMuCTPI_RDO, const DataHandle<MuCTPI_RIO> theMuCTPI_RIO,
+                                            const DataHandle<ROIB::RoIBResult> roib)
+{
+   if ( !msgLvl(MSG::DEBUG) )
+      return;
   if ( m_processMuctpi ) {
     // MuCTPI Multiplicity data
     MuCTPI_MultiplicityWord_Decoder multWord(theMuCTPI_RDO->
@@ -1846,12 +1787,12 @@ dumpData(const DataHandle<CTP_RDO> theCTP_RDO,
     multWord.dumpData();
     // MuCTPI candidate data
     MuCTPI_DataWord_Decoder dataWord(0);
-    ATH_MSG(DEBUG) << "MIOCT candidate data :" << endmsg;
+    ATH_MSG_DEBUG( "MIOCT candidate data :");
     std::vector<uint32_t>::const_iterator it =
       theMuCTPI_RDO->dataWord().begin();
     int count = 1;
     for ( ; it != theMuCTPI_RDO->dataWord().end(); ++it ) {
-      ATH_MSG(DEBUG) << "Candidate " << count << endmsg;
+      ATH_MSG_DEBUG( "Candidate " << count);
       dataWord.setWord(*it);
       dataWord.dumpData();
       ++count;
@@ -1877,11 +1818,12 @@ dumpData(const DataHandle<CTP_RDO> theCTP_RDO,
 }
 
 //------------
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-registerTH1(const std::string& histName, const std::string& histTitle, int nbins, float minX, float maxX) {
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::registerTH1(const std::string& histName, const std::string& histTitle, int nbins, float minX, float maxX)
+{
   HistMap_t::iterator it = m_histNames.find(histName);
   if (it != m_histNames.end()) {
-    ATH_MSG(ERROR) << "Histogram " << histName << " already registered" << endmsg;
+    ATH_MSG_ERROR( "Histogram " << histName << " already registered");
     return StatusCode::FAILURE;
   }
   TH1F_LW *hist = TH1F_LW::create(histName.c_str(), histTitle.c_str(), nbins, minX, maxX);
@@ -1890,12 +1832,12 @@ registerTH1(const std::string& histName, const std::string& histTitle, int nbins
 }
 
 //------------
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-registerTProfile(const std::string& histName, const std::string& histTitle, int nbins,
-		 float minX, float maxX, float minY, float maxY) {
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::registerTProfile(const std::string& histName, const std::string& histTitle, int nbins, float minX, float maxX, float minY, float maxY)
+{
   HistMap_t::iterator it = m_histNames.find(histName);
   if (it != m_histNames.end()) {
-    ATH_MSG(ERROR) << "Histogram " << histName << " already registered" << endmsg;
+    ATH_MSG_ERROR( "Histogram " << histName << " already registered");
     return StatusCode::FAILURE;
   }
   TProfile_LW *hist = TProfile_LW::create(histName.c_str(), histTitle.c_str(), nbins, minX, maxX, minY, maxY);
@@ -1904,12 +1846,13 @@ registerTProfile(const std::string& histName, const std::string& histTitle, int
 }
 
 //------------
-StatusCode TrigT1CTMonitoring::BSMonitoring::
-registerTH2(const std::string& histName, const std::string& histTitle, int nbinsX,
-	    float minX, float maxX, int nbinsY, float minY, float maxY) {
+StatusCode
+TrigT1CTMonitoring::BSMonitoring::registerTH2( const std::string& histName, const std::string& histTitle, int nbinsX,
+                                                float minX, float maxX, int nbinsY, float minY, float maxY)
+{
   HistMap_t::iterator it = m_histNames.find(histName);
   if (it != m_histNames.end()) {
-    ATH_MSG(ERROR) << "Histogram " << histName << " already registered" << endmsg;
+    ATH_MSG_ERROR( "Histogram " << histName << " already registered");
     return StatusCode::FAILURE;
   }
   TH2F_LW *hist = TH2F_LW::create(histName.c_str(), histTitle.c_str(), nbinsX, minX, maxX, nbinsY, minY, maxY);
@@ -1918,63 +1861,67 @@ registerTH2(const std::string& histName, const std::string& histTitle, int nbins
 }
 
 //------------
-TH1F_LW *TrigT1CTMonitoring::BSMonitoring::
-getTH1(const char* histLabel) {
+TH1F_LW *
+TrigT1CTMonitoring::BSMonitoring::getTH1(const char* histLabel) 
+{
   m_tmpstr = histLabel;
   HistMap_t::iterator it = m_histNames.find(m_tmpstr);
   if (it == m_histNames.end()) {
-    ATH_MSG(ERROR) << "Histogram under " << histLabel << " not found " << endmsg;
+    ATH_MSG_ERROR( "Histogram under " << histLabel << " not found ");
     return 0;
   }
   TH1F_LW* h = dynamic_cast<TH1F_LW*>(it->second);
   if (!h)
-    ATH_MSG(ERROR) << "Problems converting histogram " << histLabel << " to TH1F_LW " << endmsg;
+    ATH_MSG_ERROR( "Problems converting histogram " << histLabel << " to TH1F_LW ");
   return h;
 }
 
 //------------
-TH2F_LW *TrigT1CTMonitoring::BSMonitoring::
-getTH2(const char* histLabel) {
+TH2F_LW *
+TrigT1CTMonitoring::BSMonitoring::getTH2(const char* histLabel)
+{
   m_tmpstr = histLabel;
   HistMap_t::iterator it = m_histNames.find(m_tmpstr);
   if (it == m_histNames.end()) {
-    ATH_MSG(ERROR) << "Histogram under " << histLabel << " not found " << endmsg;
+    ATH_MSG_ERROR( "Histogram under " << histLabel << " not found ");
     return 0;
   }
   TH2F_LW* h = dynamic_cast<TH2F_LW*>(it->second);
   if (!h)
-    ATH_MSG(ERROR) << "Problems converting histogram " << histLabel << " to TH2F_LW " << endmsg;
+    ATH_MSG_ERROR( "Problems converting histogram " << histLabel << " to TH2F_LW ");
   return h;
 }
 
 //------------
-TProfile_LW *TrigT1CTMonitoring::BSMonitoring::
-getTProfile(const char* histLabel) {
+TProfile_LW *
+TrigT1CTMonitoring::BSMonitoring::getTProfile(const char* histLabel)
+{
   m_tmpstr = histLabel;
   HistMap_t::iterator it = m_histNames.find(m_tmpstr);
   if (it == m_histNames.end()) {
-    ATH_MSG(ERROR) << "Histogram under " << histLabel << " not found " << endmsg;
+    ATH_MSG_ERROR( "Histogram under " << histLabel << " not found ");
     return 0;
   }
   TProfile_LW* h = dynamic_cast<TProfile_LW*>(it->second);
   if (!h)
-    ATH_MSG(ERROR) << "Problems converting histogram " << histLabel << " to TProfile_LW " << endmsg;
+    ATH_MSG_ERROR( "Problems converting histogram " << histLabel << " to TProfile_LW ");
   return h;
 }
 
 //------------
-void TrigT1CTMonitoring::BSMonitoring::
-getCoolData(unsigned int runNumber) {
+void
+TrigT1CTMonitoring::BSMonitoring::getCoolData(unsigned int runNumber)
+{
 
   // establish a connection to COOLONL_TRIGGER
   CoraCoolDatabaseSvc& corasvc = CoraCoolDatabaseSvcFactory::databaseService();
   CoraCoolDatabasePtr coradb;
   try {
     coradb = corasvc.openDatabase("COOLONL_TRIGGER/CONDBR2",true);
-    ATH_MSG(DEBUG) << "Database connection open OK" << endmsg;
+    ATH_MSG_DEBUG( "Database connection open OK");
   }
   catch (std::exception& e) {
-    ATH_MSG(WARNING) << "Problem opening CORAL database:" << e.what() << endmsg;
+    ATH_MSG_WARNING( "Problem opening CORAL database:" << e.what());
   }
   
   // get DB pointer
@@ -1984,7 +1931,7 @@ getCoolData(unsigned int runNumber) {
   //cool::IDatabasePtr cooldb = coradb->coolDatabase();
   //const std::vector<std::string>& folders = cooldb->listAllNodes();
   //for ( std::vector<std::string>::const_iterator itr = folders.begin(); itr != folders.end(); ++itr ) 
-  //  ATH_MSG(DEBUG) << *itr << endmsg;
+  //  ATH_MSG_DEBUG( *itr);
 
   cool::ValidityKey since(runNumber);
   cool::ValidityKey until(since+1);
@@ -1998,24 +1945,21 @@ getCoolData(unsigned int runNumber) {
 
   cool::IFolderPtr lbTimeFolder;
   try {
-    ATH_MSG(DEBUG) << "Will now try to retrieve LB times in folder " << m_lbTimeCoolFolderName << endmsg;
+    ATH_MSG_DEBUG( "Will now try to retrieve LB times in folder " << m_lbTimeCoolFolderName);
     lbTimeFolder = cooldb->getFolder(m_lbTimeCoolFolderName);
   }
   catch (cool::Exception& e) {
-    ATH_MSG(WARNING) << "Exception during cool:IDatabasePtr::getFolder(): " << e.what() << endmsg;
+    ATH_MSG_WARNING( "Exception during cool:IDatabasePtr::getFolder(): " << e.what());
     return;
   }
 
   // printout specification of folder
   //const cool::IRecordSpecification& spec = lbTimeFolder->payloadSpecification();
   //for ( unsigned int i = 0; i < spec.size(); ++i ) {
-  //  ATH_MSG(WARNING) << "Payload column: " << spec[i].name() << " type: " << 
-  //    spec[i].storageType().name() << endmsg;
+  //  ATH_MSG_WARNING( "Payload column: " << spec[i].name() << " type: " << 
+  //    spec[i].storageType().name());
   //}
 
-  uint64_t stime = 0;
-  uint64_t etime = 1;
-
   cool::IObjectIteratorPtr lbTimeObjects = lbTimeFolder->browseObjects( since, until, 0 );
   if ( lbTimeObjects->size() != 0 ) {
     while ( lbTimeObjects->goToNext() ) {
@@ -2025,17 +1969,17 @@ getCoolData(unsigned int runNumber) {
       uint32_t startLumiBlock = (obj.since() & 0xffffffff);
       uint32_t endRun = (obj.until() >> 32) & 0x7fffffff; // same here
       uint32_t endLumiBlock = (obj.until() & 0xffffffff);
-      ATH_MSG(DEBUG) << "LB " << " since: run = " << startRun << ", LB = " << startLumiBlock << ", "
-		     << " until: run = " << endRun << ", LB = " << endLumiBlock << ")" << payload << endmsg;
-      stime = payload["StartTime"].data<uint64_t>();
-      etime=payload["EndTime"].data<uint64_t>();
+      ATH_MSG_DEBUG( "LB " << " since: run = " << startRun << ", LB = " << startLumiBlock << ", "
+                     << " until: run = " << endRun << ", LB = " << endLumiBlock << ")" << payload);
+      auto stime = static_cast<uint64_t>(payload["StartTime"].data<cool::UInt63>());
+      auto etime = static_cast<uint64_t>(payload["EndTime"].data<cool::UInt63>());
       m_lumiBlocks.push_back(startLumiBlock);
       m_lbStartTimes[startLumiBlock] = stime;
       m_lbEndTimes[startLumiBlock] = etime;
     }
   }
   else {
-    ATH_MSG(DEBUG) << "No lumi block start and stop times found in COOL for this run!" << endmsg;
+    ATH_MSG_DEBUG( "No lumi block start and stop times found in COOL for this run!");
   }
 
   //--------------------------------//
@@ -2047,7 +1991,7 @@ getCoolData(unsigned int runNumber) {
     freqMeasFolder = cooldb->getFolder(m_rfPhaseCoolFolderName);
   }
   catch (cool::Exception& e) {
-    ATH_MSG(WARNING) << "Exception caught when retrieving LHC timing signal info from COOL: " << e.what() << endmsg;
+    ATH_MSG_WARNING( "Exception caught when retrieving LHC timing signal info from COOL: " << e.what());
   }
 
   double frequency = 0;
@@ -2057,16 +2001,16 @@ getCoolData(unsigned int runNumber) {
   if ( freqMeasObjects->size() != 0 ) {
     while ( freqMeasObjects->goToNext() ) {
       const cool::IObject& obj = freqMeasObjects->currentRef();
-      //ATH_MSG(WARNING) << obj << endmsg;
+      //ATH_MSG_WARNING( obj);
       const cool::IRecord& payload = obj.payload();
       startTime = payload["StartTimeSeconds"].data<uint32_t>()*1e9+payload["StartTimeNanoSeconds"].data<uint32_t>();
       frequency = payload["FreqBCctp"].data<double>();
-      ATH_MSG(DEBUG) << "StartTime: " << startTime << " ns, FreqBCctp: " << frequency << " Hz" << endmsg;
+      ATH_MSG_DEBUG( "StartTime: " << startTime << " ns, FreqBCctp: " << frequency << " Hz");
       m_freqMeasurements[startTime] = frequency;
     }
   }
   else {
-    ATH_MSG(DEBUG) << "No frequency measurements found in COOL for this run!" << endmsg;
+    ATH_MSG_DEBUG( "No frequency measurements found in COOL for this run!");
   }
 
   // now fill the measured frequencies closest to the start of each LB
@@ -2074,7 +2018,7 @@ getCoolData(unsigned int runNumber) {
 	lbIt != m_lumiBlocks.end(); ++lbIt ) {
     double freq = getFrequencyMeasurement(m_lbStartTimes[*lbIt]);
     m_lbStartFreqMeasurements[*lbIt] = freq;
-    ATH_MSG(DEBUG) << "Frequency for LB " << *lbIt << " (start time: " << m_lbStartTimes[*lbIt] << "): " << freq << " Hz" << endmsg;
+    ATH_MSG_DEBUG( "Frequency for LB " << *lbIt << " (start time: " << m_lbStartTimes[*lbIt] << "): " << freq << " Hz");
   }
 
   //-------------------------------//
@@ -2084,21 +2028,21 @@ getCoolData(unsigned int runNumber) {
   // establish a connection to COOLOFL_DCS
   try {
     coradb = corasvc.openDatabase("COOLOFL_DCS/CONDBR2",true);
-    ATH_MSG(DEBUG) << "Database connection open OK" << endmsg;
+    ATH_MSG_DEBUG( "Database connection open OK");
   }
   catch (std::exception& e) {
-    ATH_MSG(WARNING) << "Problem opening CORAL database:" << e.what() << endmsg;
+    ATH_MSG_WARNING( "Problem opening CORAL database:" << e.what());
   }
   // get DB pointer
   cool::IDatabasePtr cooldb2 = coradb->coolDatabase();
   if(m_fillStateCoolFolderName!="Unavailable"){
     cool::IFolderPtr fillStateFolder;
     try {
-      ATH_MSG(DEBUG) << "Will now try to retrieve LHC fill state info in folder " << m_fillStateCoolFolderName << endmsg;
+      ATH_MSG_DEBUG( "Will now try to retrieve LHC fill state info in folder " << m_fillStateCoolFolderName);
       fillStateFolder = cooldb2->getFolder(m_fillStateCoolFolderName);
     }
     catch (cool::Exception& e) {
-      ATH_MSG(WARNING) << "Exception from cool::IDatabasePtr::getFolder(): " << e.what() << endmsg;
+      ATH_MSG_WARNING( "Exception from cool::IDatabasePtr::getFolder(): " << e.what());
     return;
     }
     
@@ -2116,8 +2060,8 @@ getCoolData(unsigned int runNumber) {
 	  currentBeamMode = payload["BeamMode"].data<cool::String4k>();
 	  startTime = obj.since();
 	  endTime = obj.until();
-	  ATH_MSG(DEBUG) << "BEAM MODE: " << currentBeamMode << ", start time: " 
-			 << startTime << ", stop time: " << endTime << endmsg;
+	  ATH_MSG_DEBUG( "BEAM MODE: " << currentBeamMode << ", start time: " 
+			 << startTime << ", stop time: " << endTime);
 	  
 	  // fill the beam mode map, cases ordered by how often they appear
 	  if (!strcmp(currentBeamMode.c_str(), "RAMP"))
@@ -2160,8 +2104,8 @@ getCoolData(unsigned int runNumber) {
 	    m_beamMode[startTime] = NOBEAM;
 	  else {
 	    m_beamMode[startTime] = UNKNOWN;
-	    ATH_MSG(WARNING) << "Unknown LHC beam mode read from COOL: " << payload["BeamMode"] 
-			     << " (will treat as unstable)" << endmsg;
+	    ATH_MSG_WARNING( "Unknown LHC beam mode read from COOL: " << payload["BeamMode"] 
+			     << " (will treat as unstable)");
 	  }
 	  // fill an entry with unknown after the validity of the last real entry is over
 	  m_beamMode[endTime] = UNKNOWN;
@@ -2176,12 +2120,12 @@ getCoolData(unsigned int runNumber) {
 	
 	while (bm != m_beamMode.end()) {
 	  currentBeamMode = bm->second;
-	  ATH_MSG(DEBUG) << "Beam mode at time " << bm->first << ": " << currentBeamMode << endmsg;
+	  ATH_MSG_DEBUG( "Beam mode at time " << bm->first << ": " << currentBeamMode);
 	  if (currentBeamMode == previousBeamMode) {
 	    previousbm = bm;
 	    ++bm;
 	    m_beamMode.erase(previousbm);
-	    ATH_MSG(DEBUG) << " => Removing!" << endmsg;
+	    ATH_MSG_DEBUG( " => Removing!");
 	  }
 	  else {
 	    ++bm;
@@ -2190,15 +2134,15 @@ getCoolData(unsigned int runNumber) {
 	}
       }
       else {
-	ATH_MSG(DEBUG) << "No Beam Mode info found in COOL for this run!" << endmsg;
+	ATH_MSG_DEBUG( "No Beam Mode info found in COOL for this run!");
       }
     }
     else{ //cool publication is not available
-      ATH_MSG(DEBUG) << "No Beam Mode info found in COOL for this run as folder is unavailable!" << endmsg;
+      ATH_MSG_DEBUG( "No Beam Mode info found in COOL for this run as folder is unavailable!");
     }
   }
   else{ //no lumi block available
-    ATH_MSG(DEBUG) << "No lumi block available for this run!" << endmsg;
+    ATH_MSG_DEBUG( "No lumi block available for this run!");
   }
 
   //-----------------------------------------------//
@@ -2208,10 +2152,10 @@ getCoolData(unsigned int runNumber) {
   // establish a connection to COOLOFL_DCS
   try {
     coradb = corasvc.openDatabase("COOLONL_TDAQ/CONDBR2",true);
-    ATH_MSG(DEBUG) << "Database connection open OK" << endmsg;
+    ATH_MSG_DEBUG( "Database connection open OK");
   }
   catch (std::exception& e) {
-    ATH_MSG(WARNING) << "Problem opening CORAL database:" << e.what() << endmsg;
+    ATH_MSG_WARNING( "Problem opening CORAL database:" << e.what());
   }
   // get DB pointer
   cool::IDatabasePtr cooldb3 = coradb->coolDatabase();
@@ -2220,7 +2164,7 @@ getCoolData(unsigned int runNumber) {
     dataTakingModeFolder = cooldb3->getFolder(m_dataTakingModeCoolFolderName);
   }
   catch (cool::Exception& e) {
-    ATH_MSG(WARNING) << "Exception caught when retrieving ATLAS data taking mode info from COOL: " << e.what() << endmsg;
+    ATH_MSG_WARNING( "Exception caught when retrieving ATLAS data taking mode info from COOL: " << e.what());
   }
 
   uint32_t readyForPhysics = 0;
@@ -2233,24 +2177,24 @@ getCoolData(unsigned int runNumber) {
       uint32_t startLumiBlock = (obj.since() & 0xffffffff);
       uint32_t endRun = (obj.until() >> 32) & 0x7fffffff; // same here
       uint32_t endLumiBlock = (obj.until() & 0xffffffff);
-      ATH_MSG(DEBUG) << "Current entry "
+      ATH_MSG_DEBUG( "Current entry "
 		       << " since: run = " << startRun << ", LB = " << startLumiBlock << ", "
 		       << " until: run = " << endRun << ", LB = " << endLumiBlock << ")"
-		       << payload << endmsg;
+		       << payload);
       readyForPhysics = payload["ReadyForPhysics"].data<uint32_t>();
       if (readyForPhysics == 0)
 	m_dataTakingMode[startLumiBlock] = false;
       else {
 	m_dataTakingMode[startLumiBlock] = true;
 	if (readyForPhysics != 1) {
-	  ATH_MSG(WARNING) << "ReadyForPhysics is neither 0 nor 1, retrieved value was: " 
-			   << readyForPhysics << " => will interpret as true" << endmsg;
+	  ATH_MSG_WARNING( "ReadyForPhysics is neither 0 nor 1, retrieved value was: " 
+			   << readyForPhysics << " => will interpret as true");
 	}
       }
     }
   }
   else {
-    ATH_MSG(DEBUG) << "No data taking mode info found in COOL for this run!" << endmsg;
+    ATH_MSG_DEBUG( "No data taking mode info found in COOL for this run!");
   }
 
   // now clean out all the entries that repeat the previous data taking mode and only keep the ones where it changes
@@ -2262,29 +2206,33 @@ getCoolData(unsigned int runNumber) {
   
   while (dtm != m_dataTakingMode.end()) {
     currentDataTakingMode = dtm->second;
-    ATH_MSG(DEBUG) << "Data taking mode starting at LB " << dtm->first << ": " << currentDataTakingMode << endmsg;
+    ATH_MSG_DEBUG( "Data taking mode starting at LB " << dtm->first << ": " << currentDataTakingMode);
     if (currentDataTakingMode == previousDataTakingMode && dtm != m_dataTakingMode.begin()) { // don't remove 1st
       previousdtm = dtm;
       ++dtm;
       m_dataTakingMode.erase(previousdtm);
-      ATH_MSG(DEBUG) << " => Removing!" << endmsg;
+      ATH_MSG_DEBUG( " => Removing!");
     }
     else {
       ++dtm;
     }
     previousDataTakingMode = currentDataTakingMode;
   }
-  
+
   return;
 }
 
-std::string TrigT1CTMonitoring::BSMonitoring::getEventInfoString() {
+std::string
+TrigT1CTMonitoring::BSMonitoring::getEventInfoString()
+{
   std::stringstream ss;
   ss << "Run number: " << m_runNumber << ", event: " << m_eventNumber << ", LB: " << m_currentLumiBlock;
   return std::string(ss.str());
 }
 
-double TrigT1CTMonitoring::BSMonitoring::getFrequencyMeasurement(uint64_t eventTimeInNs) const {
+double
+TrigT1CTMonitoring::BSMonitoring::getFrequencyMeasurement(uint64_t eventTimeInNs) const
+{
   if (m_freqMeasurements.size() == 0) {
     return -1.0; // if there are no frequency measurements available for this run, return invalid frequency
   }
@@ -2300,12 +2248,14 @@ double TrigT1CTMonitoring::BSMonitoring::getFrequencyMeasurement(uint64_t eventT
   if ( freqMeasAfter != m_freqMeasurements.begin() && (fabs(eventTimeInNs - freqMeasBefore->first) < fabs(eventTimeInNs - freqMeasAfter->first)) )
     fm = freqMeasBefore;
 
-  ATH_MSG(DEBUG) << "Closest frequency measurement for time " << eventTimeInNs 
-		 << "): " << fm->second << " Hz (at " << fm->first << ")" << endmsg;
+  ATH_MSG_DEBUG( "Closest frequency measurement for time " << eventTimeInNs 
+		 << "): " << fm->second << " Hz (at " << fm->first << ")");
   return fm->second;
 }
 
-TrigT1CTMonitoring::BeamMode TrigT1CTMonitoring::BSMonitoring::getBeamMode(uint64_t eventTimeInNs) const {
+TrigT1CTMonitoring::BeamMode 
+TrigT1CTMonitoring::BSMonitoring::getBeamMode(uint64_t eventTimeInNs) const
+{
   // get the pair for the first beam mode transition *after* the provided timestamp
   std::map<uint64_t,BeamMode>::const_iterator bm = m_beamMode.lower_bound(eventTimeInNs);
   BeamMode beamMode = UNKNOWN;
@@ -2313,6 +2263,6 @@ TrigT1CTMonitoring::BeamMode TrigT1CTMonitoring::BSMonitoring::getBeamMode(uint6
   if ( bm != m_beamMode.begin() && bm != m_beamMode.end() ) {
     beamMode = (--bm)->second;
   }
-  ATH_MSG(DEBUG) << "Beam mode at time " << eventTimeInNs << ": " << beamMode << endmsg;
+  ATH_MSG_DEBUG( "Beam mode at time " << eventTimeInNs << ": " << beamMode);
   return beamMode;
 }
diff --git a/Trigger/TrigT1/TrigT1CTMonitoring/src/BSMonitoring.h b/Trigger/TrigT1/TrigT1CTMonitoring/src/BSMonitoring.h
index 850741fe7d7f..72f219976460 100644
--- a/Trigger/TrigT1/TrigT1CTMonitoring/src/BSMonitoring.h
+++ b/Trigger/TrigT1/TrigT1CTMonitoring/src/BSMonitoring.h
@@ -28,6 +28,8 @@
 #include "MuonRDO/RpcSectorLogicContainer.h"
 #include "MuonDigitContainer/TgcDigit.h"
 
+#include "TrigConfInterfaces/ILVL1ConfigSvc.h"
+
 class CTP_RDO;
 class CTP_RIO;
 class MuCTPI_RDO;
@@ -44,10 +46,6 @@ namespace cool {
   class IHvsNode;
 }
 
-namespace TrigConf {
-  class ILVL1ConfigSvc;
-}
-
 namespace ROIB {
   class RoIBResult;
 }
@@ -107,11 +105,6 @@ namespace TrigT1CTMonitoring {
 		 const IInterface * parent);
 
   private:
-    
-    ServiceHandle<TrigConf::ILVL1ConfigSvc> m_configSvc;
-    ServiceHandle< LVL1::RecMuonRoiSvc > m_rpcRoiSvc; ///RPC rec. RoI service
-    ServiceHandle< LVL1::RecMuonRoiSvc > m_tgcRoiSvc; ///TGC rec. RoI service
-      
     StatusCode initialize();
     StatusCode bookHistograms();
     StatusCode fillHistograms();
@@ -121,39 +114,44 @@ namespace TrigT1CTMonitoring {
     StatusCode initCtpMuctpiHistograms();
     StatusCode initRoIHistograms();
 
-    StatusCode registerTH1(const std::string& histName, const std::string& histTitle,
-			   int nbins, float minX, float maxX);
+    StatusCode registerTH1( const std::string& histName, const std::string& histTitle,
+                            int nbins, float minX, float maxX);
     StatusCode registerTProfile(const std::string& histName,
-				const std::string& histTitle, int nbins,
-				float minX, float maxX, float minY,
-				float maxY);
-    StatusCode registerTH2(const std::string& histName, const std::string& histTitle,
-			   int nbinsX, float minX, float maxX,
-			   int nbinsY, float minY, float maxY);
+                                const std::string& histTitle, int nbins,
+                                float minX, float maxX, float minY,
+                                float maxY);
+    StatusCode registerTH2( const std::string& histName, const std::string& histTitle,
+                            int nbinsX, float minX, float maxX,
+                            int nbinsY, float minY, float maxY);
     TH1F_LW *getTH1(const char* histLabel);
     TH2F_LW *getTH2(const char* histLabel);
     TProfile_LW *getTProfile(const char* histLabel);
 
     void getCoolData(unsigned int runNumber);
 
-    void doMuonRoI(const DataHandle < MuCTPI_RDO > theMuCTPI_RDO,
-		   const DataHandle < MuCTPI_RIO > theMuCTPI_RIO,
-		   const DataHandle < ROIB::RoIBResult > roib);
-    void doCtp(const DataHandle < CTP_RDO > theCTP_RDO,
-	       const DataHandle < CTP_RIO > theCTP_RIO);
+    void doMuonRoI( const DataHandle < MuCTPI_RDO > theMuCTPI_RDO,
+                    const DataHandle < MuCTPI_RIO > theMuCTPI_RIO,
+                    const DataHandle < ROIB::RoIBResult > roib);
+
+    void doCtp( const DataHandle < CTP_RDO > theCTP_RDO,
+                const DataHandle < CTP_RIO > theCTP_RIO);
+
     void doMuctpi(const DataHandle < MuCTPI_RDO > theMuCTPI_RDO,
-		  const DataHandle < MuCTPI_RIO > theMuCTPI_RIO,
-		  const DataHandle < RpcSectorLogicContainer > theRPCContainer,
-		  const DataHandle < Muon::TgcCoinDataContainer > theTGCContainer);
-    void doCtpMuctpi(const DataHandle < CTP_RDO > theCTP_RDO,
-		     const DataHandle < CTP_RIO > theCTP_RIO,
-		     const DataHandle < MuCTPI_RDO > theMuCTPI_RDO,
-		     const DataHandle < MuCTPI_RIO > theMuCTPI_RIO);
+                  const DataHandle < MuCTPI_RIO > theMuCTPI_RIO,
+                  const DataHandle < RpcSectorLogicContainer > theRPCContainer,
+                  const DataHandle < Muon::TgcCoinDataContainer > theTGCContainer);
+
+    void doCtpMuctpi( const DataHandle < CTP_RDO > theCTP_RDO,
+                      const DataHandle < CTP_RIO > theCTP_RIO,
+                      const DataHandle < MuCTPI_RDO > theMuCTPI_RDO,
+                      const DataHandle < MuCTPI_RIO > theMuCTPI_RIO);
+
     void dumpData(const DataHandle < CTP_RDO > theCTP_RDO,
-		  const DataHandle < CTP_RIO > theCTP_RIO,
-		  const DataHandle < MuCTPI_RDO > theMuCTPI_RDO,
-		  const DataHandle < MuCTPI_RIO > theMuCTPI_RIO,
-		  const DataHandle < ROIB::RoIBResult > roib);
+                  const DataHandle < CTP_RIO > theCTP_RIO,
+                  const DataHandle < MuCTPI_RDO > theMuCTPI_RDO,
+                  const DataHandle < MuCTPI_RIO > theMuCTPI_RIO,
+                  const DataHandle < ROIB::RoIBResult > roib);
+                  
     StatusCode compareRerun(const CTP_BC &bunchCrossing);
 
     std::string getEventInfoString();
@@ -161,39 +159,51 @@ namespace TrigT1CTMonitoring {
     TrigT1CTMonitoring::BeamMode getBeamMode(uint64_t eventTimeInNs) const;
     bool getDataTakingMode(uint32_t lbNumber) const;
 
-    bool m_histogramsBooked;
-    bool m_retrievedLumiBlockTimes;
-    uint32_t m_currentLumiBlock;
-    unsigned int m_runNumber;
-    unsigned int m_eventNumber;
-
-    bool m_inclusiveTriggerThresholds;
-    bool m_processMuctpi;
-    bool m_processMuctpiRIO;
-    bool m_processCTP;
-    bool m_processRoIB;
-    bool m_compareRerun;
-    bool m_runOnESD;
-    bool m_retrieveCoolData;
-    std::string m_baseDirName;
-    std::string m_dirName;
+
+    bool m_histogramsBooked{false};
+    bool m_retrievedLumiBlockTimes{false};
+    uint32_t m_currentLumiBlock{0};
+    unsigned int m_runNumber{0};
+    unsigned int m_eventNumber{0};
+
+    ServiceHandle<TrigConf::ILVL1ConfigSvc> m_configSvc{ this, "TrigConfigSvc", "TrigConf::TrigConfigSvc/TrigConfigSvc", "Trigger Config Service" };
+    ServiceHandle< LVL1::RecMuonRoiSvc > m_rpcRoiSvc{ this, "RPCRecRoiSvc", "LVL1RPC::RPCRecRoiSvc"}; 
+    ServiceHandle< LVL1::RecMuonRoiSvc > m_tgcRoiSvc{ this, "TGCRecRoiSvc", "LVL1TGC::TGCRecRoiSvc"}; 
+
+    Gaudi::Property<bool> m_useNewConfig { this, "UseNewConfig", false, "When true, read the menu from detector store, when false use the L1ConfigSvc" };
+
+    Gaudi::Property<std::string> m_baseDirName{ this, "DirectoryName", "CT/", "Directory in output root file where the histograms will be stored." };
+    Gaudi::Property<bool> m_inclusiveTriggerThresholds{ this, "InclusiveTriggerThresholds", true, "Flag to activate the inclusive counting of PT thresholds in trigger patterns" };
+    Gaudi::Property<bool> m_processMuctpi{ this, "ProcessMuctpiData", true, "Flag to activate the processing of Muctpi data" };
+    Gaudi::Property<bool> m_processMuctpiRIO{ this, "ProcessMuctpiDataRIO",  true, "Flag to activate the processing of the Muctpi RIO" };
+    Gaudi::Property<bool> m_processCTP{ this, "ProcessCTPData", true, "Flag to activate the processing of CTP data" };
+    Gaudi::Property<bool> m_processRoIB{ this, "ProcessRoIBResult", true, "Flag to activate the processing of RoIBResult data" };
+    Gaudi::Property<bool> m_compareRerun{ this, "CompareRerun", false, "Flag to activate the processing of RoIBResult data" };
+    Gaudi::Property<bool> m_runOnESD{ this, "RunOnESD", false, "Flag to run only on the ESD" };
+    Gaudi::Property<bool> m_retrieveCoolData{ this, "RetrieveCoolData", true, "Flag to control whether or not to perform checks based on COOL data" };
+
+
+    Gaudi::Property<double> m_defaultBcIntervalInNs{ this, "DefaultBcIntervalInNs", 24.9507401, "Default bunch-crossing duration to use if not accessible in COOL" };
+    Gaudi::Property<int64_t> m_bcsPerTurn{ this, "BCsPerTurn", 3564, "Number of bunch crossings per turn" };
+    Gaudi::Property<std::string > m_lbTimeCoolFolderName{ this, "LumiBlockTimeCoolFolderName", "/TRIGGER/LUMI/LBLB", 
+                                                          "COOL folder in COOLONL_TRIGGER holding info about start and stop times for luminosity blocks" };
+    Gaudi::Property<std::string > m_rfPhaseCoolFolderName{ this, "RFPhaseCoolFolderName", "/TRIGGER/LVL1/RFPhase", 
+                                                            "COOL folder in COOLONL_TRIGGER holding LHC timing signal info and ATLAS related settings" };
+    Gaudi::Property<std::string > m_fillStateCoolFolderName{ this, "FillStateCoolFolderName", "/LHC/DCS/FILLSTATE", 
+                                                              "COOL folder in COOLOFL_DCS holding the LHC fill state info" };
+    Gaudi::Property<std::string> m_dataTakingModeCoolFolderName{ this, "DataTakingModeCoolFolderName", "/TDAQ/RunCtrl/DataTakingMode",
+                                                                  "COOL folder in COOLONL_TDAQ holding the ATLAS data taking mode info" };
+    Gaudi::Property<std::vector<std::string>> m_ignorePatterns{ this, "IgnorePatterns", {"L1_TRT", "L1_ZB", "_AFP", "L1_BPTX", "L1_BCM", "L1_LUCID"}, 
+                                                                "patters that are excluded from check (no regex)"};
+    std::string m_dirName{""};
     HistMap_t m_histNames;
-    uint32_t m_eventCount;
-    uint64_t m_firstEventTime;
-    int64_t m_firstEventBcid;
-    int64_t m_firstEventTC;
-    uint32_t m_filledEventCount;
-    uint32_t m_maxLumiBlock;
-    uint32_t m_lumiBlockOfPreviousEvent;
-
-    // COOL folder names
-    std::string m_lbTimeCoolFolderName;
-    std::string m_rfPhaseCoolFolderName;
-    std::string m_fillStateCoolFolderName;
-    std::string m_dataTakingModeCoolFolderName;
-    //
-    double m_defaultBcIntervalInNs;
-    int64_t m_bcsPerTurn;
+    uint32_t m_eventCount{0};
+    uint64_t m_firstEventTime{0};
+    int64_t m_firstEventBcid{0};
+    int64_t m_firstEventTC{0};
+    uint32_t m_filledEventCount{0};
+    uint32_t m_maxLumiBlock{0};
+    uint32_t m_lumiBlockOfPreviousEvent{0};
 
     // STL containers for info from COOL
     std::vector<uint32_t> m_lumiBlocks;
@@ -204,7 +214,7 @@ namespace TrigT1CTMonitoring {
     std::map<uint64_t,BeamMode> m_beamMode;
     std::map<uint32_t,bool> m_dataTakingMode;
 
-    unsigned int m_nLB;
+    unsigned int m_nLB{0};
 
     //Vectors of TBP/TAP/TAB
     std::vector<int> m_tbpItems;
@@ -219,8 +229,8 @@ namespace TrigT1CTMonitoring {
 
     //TK: Like this so we can use LW hists when not in online mode:
     void updateRangeUser();
-    int m_lastminbc;
-    int m_lastmaxbc;
+    int m_lastminbc{0};
+    int m_lastmaxbc{0};
   };
 }
 #endif
diff --git a/Trigger/TrigT1/TrigT1CTP/python/TrigT1CTPConfig.py b/Trigger/TrigT1/TrigT1CTP/python/TrigT1CTPConfig.py
index 95f290d5188e..46154ac7a2fd 100755
--- a/Trigger/TrigT1/TrigT1CTP/python/TrigT1CTPConfig.py
+++ b/Trigger/TrigT1/TrigT1CTP/python/TrigT1CTPConfig.py
@@ -42,6 +42,7 @@ class CTPSimulationOnData(DefaultCTPSimulation):
         self.DoNIM=True
         self.DoRNDM=True
         self.DoPSCL=False
+        self.ForceBunchGroupPattern = False # on data we will take the bunchgroups from COOL
         from AthenaCommon.AppMgr import ServiceMgr as svcMgr
         if hasattr(svcMgr,'DSConfigSvc'):
             # this case is still needed for reading Run 2 data configuration from the TriggerDB
diff --git a/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.cxx b/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.cxx
index b91330a886df..c79e74eb3871 100644
--- a/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.cxx
+++ b/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.cxx
@@ -8,6 +8,7 @@
 #include "TrigConfL1Data/L1DataDef.h"
 #include "TrigConfL1Data/ClusterThresholdValue.h"
 #include "TrigT1Interfaces/TrigT1StoreGateKeys.h"
+#include "TrigConfData/L1BunchGroupSet.h"
 
 #include "./CTPTriggerThreshold.h"
 #include "./CTPTriggerItem.h"
@@ -60,6 +61,11 @@ StatusCode
 LVL1CTP::CTPSimulation::initialize() {
 
    ATH_MSG_DEBUG("initialize");
+   if(m_forceBunchGroupPattern) {
+      ATH_MSG_INFO("Will use bunchgroup pattern 0x" << std::hex << m_bunchGroupPattern);
+   } else {
+      ATH_MSG_INFO("Will use bunchgroup definition from bunchgroup set");
+   }
 
    if( m_isData ) {
       CHECK( m_oKeyRDO.assign(LVL1CTP::DEFAULT_RDOOutputLocation_Rerun) );
@@ -773,7 +779,22 @@ LVL1CTP::CTPSimulation::extractMultiplicities(std::map<std::string, unsigned int
       }
    } else {
       // use bunchgroup definition from configuration and pick according to the BCID
-      if( ! l1menu ) {
+      if( m_useNewConfig ) {
+         const TrigConf::L1BunchGroupSet *l1bgs = nullptr;
+         detStore()->retrieve(l1bgs).ignore();
+         if (l1bgs)
+         {
+            for (size_t i = 0; i < l1bgs->maxNBunchGroups(); ++i)
+            {
+               std::shared_ptr<TrigConf::L1BunchGroup> bg = l1bgs->getBunchGroup(i);
+               thrMultiMap[std::string("BGRP") + std::to_string(i)] = bg->contains(bcid) ? 1 : 0;
+            }
+         }
+         else
+         {
+            ATH_MSG_ERROR("Did not find L1BunchGroupSet in DetectorStore");
+         }
+      } else {
          for( const TrigConf::BunchGroup & bg : m_configSvc->ctpConfig()->bunchGroupSet().bunchGroups() ) {
             std::string bgName("BGRP");
             bgName += std::to_string(bg.internalNumber());
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/python/Lvl1SimulationConfig.py b/Trigger/TriggerCommon/TriggerJobOpts/python/Lvl1SimulationConfig.py
index f3484f317a2b..a93c1e96bc90 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/python/Lvl1SimulationConfig.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/python/Lvl1SimulationConfig.py
@@ -365,6 +365,7 @@ def Lvl1SimulationSequence( ConfigFlags ):
     svcMgr += conf2toConfigurable(getL1ConfigSvc(ConfigFlags))
     svcMgr += conf2toConfigurable(getL1TopoConfigSvc(ConfigFlags))
 
+    log.info("UseNewConfig = %s", ConfigFlags.Trigger.readLVL1FromJSON)
     if ConfigFlags.Input.isMC and not ConfigFlags.Common.isOnline:
         log.info("Setting up L1 simulation for MC")
         l1SimSeq = Lvl1SimulationSequence_MC( ConfigFlags )
-- 
GitLab