diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/AthenaPoolTestWrite.py b/AtlasTest/DatabaseTest/AthenaPoolTest/share/AthenaPoolTestWrite.py
index 6c2472465406e4b2f49461b9e8a6adce66d420c3..5fc8b48b3395a2facecf65c497c31ae23a4c8dfd 100755
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/AthenaPoolTestWrite.py
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/AthenaPoolTestWrite.py
@@ -13,10 +13,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-gbl.AthenaServices.SetFatalHandler(438)
-
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
@@ -27,6 +23,9 @@ from AthenaCommon.AppMgr import ServiceMgr as svcMgr
 ## get a handle to the ApplicationManager
 from AthenaCommon.AppMgr import theApp
 
+# Set handler for traceback
+svcMgr.CoreDumpSvc.FatalHandler = 438
+
 #--------------------------------------------------------------
 # Load POOL support
 #--------------------------------------------------------------
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.py b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.py
index af7bd07c828aaf2211d6c15cfcd5dd915a84847a..4efa3fc4e2a70824c9503337e8f554ed81a1c789 100755
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.py
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.py
@@ -13,10 +13,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllReadCool.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllReadCool.py
index acf11bd900242def1836fd56f562eb4b164df466..978e94b7686524b5af6ecab6023c52b5326f6249 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllReadCool.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllReadCool.py
@@ -7,9 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 #import password for devdb10 from devdb10pwd.py
 from devdb10_pwd import devdb10pwd
 
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllWriteCool.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllWriteCool.py
index 282f4cd98d04689f1d7da46effb96b4b130881ab..4a38dbff0a526af4914183dd3753998e12e1ff8a 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllWriteCool.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllWriteCool.py
@@ -1,5 +1,4 @@
 import AthenaCommon.AtlasUnixGeneratorJob
-gbl.AthenaServices.SetFatalHandler(438)
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
 from AthenaCommon.AppMgr import ServiceMgr as svcMgr
@@ -10,6 +9,8 @@ from devdb10_pwd import devdb10pwd
 
 import IOVDbSvc.IOVDb
 
+svcMgr.CoreDumpSvc.FatalHandler = 438
+
 from IOVDbTestAlg.IOVDbTestAlgConf import IOVDbTestAlg
 topSequence += IOVDbTestAlg( "IOVDbTestAlg" )
 
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCool.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCool.py
index 0f988a2ba809b81fadbe78d918c397fef5d90400..cc9e6a4da2603e212990391c421a64915843a39c 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCool.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCool.py
@@ -7,9 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAfterTwoStep.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAfterTwoStep.py
index 5e65fb0af50f7bfd24e815ee1ef6faba6c41c3fe..91f6f2725338c5db45d718b301c36e3c4e34eb7c 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAfterTwoStep.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAfterTwoStep.py
@@ -6,9 +6,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAndReg.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAndReg.py
index d0d1372a0c840ead36160d20be2b518300ed302a..512575927b3559dca9f4a45e5ca32fbb92821e54 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAndReg.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAndReg.py
@@ -7,9 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolFromMetaData.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolFromMetaData.py
index 51194796060552be9ae40720346b1174cc19d08b..f1328760141e9ba628447b3e8c8cb30d5bfbf5bf 100644
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolFromMetaData.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolFromMetaData.py
@@ -6,9 +6,6 @@
 ## basic job configuration
 import AthenaCommon.AtlasUnixStandardJob
 
-# Set handler for traceback
-gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle on the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
@@ -31,6 +28,9 @@ from AthenaCommon.AppMgr import ServiceMgr as svcMgr
 ## get a handle on the ToolSvc
 from AthenaCommon.AppMgr import ToolSvc
 
+# Set handler for traceback
+svcMgr.CoreDumpSvc.FatalHandler = 438
+
 #svcMgr.EventSelector.InputCollections = [ "SimplePoolFile1.root" ]
 svcMgr.EventSelector.InputCollections = [ "SimpleEventPoolFile.root" ]
 
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNewTag.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNewTag.py
index 8e88b4f9e965038174620c28a71805f193740b14..c42d7927035149eb0ae9dca198792ba599a5f2df 100644
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNewTag.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNewTag.py
@@ -7,9 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNoReg.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNoReg.py
index a13ba7d6fcc026ab78e763d94b18fb7e25dfefad..cc5d7d3a317aefd01d0b56f94b78f1cc13afcb5c 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNoReg.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNoReg.py
@@ -7,10 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolWriteMD.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolWriteMD.py
index c60f585d421c8fd2c991f6089c02fc0683757a34..bec0bb629a3c8b085d54ace3f9ef084226342097 100644
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolWriteMD.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolWriteMD.py
@@ -7,9 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCool.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCool.py
index fa7b4746d407d131110e5ccc4c937ab13f18e89e..5a2911b776f2ebcd6f52da5f55afeca616ac42d3 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCool.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCool.py
@@ -7,9 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNewTag.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNewTag.py
index 18e6b225a31108ae336ed8125d336c3876dadf9a..cd6fdbdd2746174893e8cf6d0de841c6f96ce88e 100644
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNewTag.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNewTag.py
@@ -7,9 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNoReg.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNoReg.py
index 0329d150b13f0e41aefe652af4e21c307bb1bc67..06ad40ade26d6f89b3f1df847e002c8a36a92033 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNoReg.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNoReg.py
@@ -7,10 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep2.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep2.py
index 42b834a9f0cc36c3f340ab0416f424a750ae078e..8d3508f7defc2524ddb28ffca8da20abf3d6e520 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep2.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep2.py
@@ -7,9 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep3.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep3.py
index 872b368e51ce1771f126d58c10943493acd40ad6..f2baa7693604dca4d4a44b3e6e4fed97d897cced 100755
--- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep3.py
+++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep3.py
@@ -7,9 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/AtlasTest/TestTools/share/post.sh b/AtlasTest/TestTools/share/post.sh
index 1cae95b38bce46ec6167d2283752be28059d56b3..aa1e079d26a3a4c7f6361a8fbb7d76ee724a8c88 100755
--- a/AtlasTest/TestTools/share/post.sh
+++ b/AtlasTest/TestTools/share/post.sh
@@ -213,6 +213,9 @@ PP="$PP"'|Warning in <TInterpreter::ReadRootmapFile>: enum'
 # Ignore sourceID message from EventSelector.
 PP="$PP"'|Disconnecting input sourceID'
 
+# Printouts from new-style job configuration.
+PP="$PP"'|Py:ComponentAccumulator +INFO '
+PP="$PP"'|^[a-zA-Z0-9.]+ +: [^ ]'
 
 if [ "$extrapatterns" != "" ]; then
  PP="$PP""|$extrapatterns"
diff --git a/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h b/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h
index d4859d19c71fbb59c0fdaf9aea666fc030962c0b..3bc7a103484cc5beab572ce3b6a98bf0c7da437d 100644
--- a/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h
+++ b/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h
@@ -42,7 +42,7 @@ namespace MyAnalysisCal {
     /** standard Athena-Algorithm method */
     virtual StatusCode          initialize() override;
     /** standard Athena-Algorithm method */
-    virtual StatusCode          execute_r(const EventContext& ctx) const override;
+    virtual StatusCode          execute(const EventContext& ctx) const override;
     /** standard Athena-Algorithm method */
     virtual StatusCode          finalize() override;
   private:
diff --git a/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx b/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx
index 4e2bc56114e690e124ae5daf5922b6c0b018fdec..67ada897510eb13c89f673d6ccd0032acc73f7f1 100644
--- a/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx
+++ b/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx
@@ -51,7 +51,7 @@ namespace MyAnalysisCal {
   }
   
   //__________________________________________________________________________
-  StatusCode AnalysisCal::execute_r (const EventContext& ctx) const
+  StatusCode AnalysisCal::execute (const EventContext& ctx) const
   {
     //.............................................
     
diff --git a/Calorimeter/CaloRec/CaloRec/ToolWithConstantsMixin.icc b/Calorimeter/CaloRec/CaloRec/ToolWithConstantsMixin.icc
index d16e950c9d8dd98c284c76b0d855403fdf5f1fb9..89ff976865d123415a87f8ca7a2bfc7e99409e1b 100644
--- a/Calorimeter/CaloRec/CaloRec/ToolWithConstantsMixin.icc
+++ b/Calorimeter/CaloRec/CaloRec/ToolWithConstantsMixin.icc
@@ -43,7 +43,7 @@ StatusCode do_declare (ToolWithConstantsMixin* self,
   if (AlgTool* x = dynamic_cast<AlgTool*> (self)) {
     x->declareProperty (name, c);
     return StatusCode::SUCCESS;
-  } else if (Algorithm* x = dynamic_cast<Algorithm*> (self)) {
+  } else if (Gaudi::Algorithm* x = dynamic_cast<Gaudi::Algorithm*> (self)) {
     x->declareProperty (name, c);
     return StatusCode::SUCCESS;
   } else if (Service* x = dynamic_cast<Service*> (self)) {
diff --git a/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.cxx b/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.cxx
index a0f324f807e5dbca47dda582943a190be08831b6..eb23fe09a2cbfc55733b2fb9af804082b05b4735 100644
--- a/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.cxx
+++ b/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.cxx
@@ -46,7 +46,7 @@ StatusCode  CaloBCIDAvgAlg::finalize() {
 
 //----------------------------------------------------------------------------------------
 
-StatusCode CaloBCIDAvgAlg::execute_r(const EventContext& ctx) const {
+StatusCode CaloBCIDAvgAlg::execute(const EventContext& ctx) const {
 
   SG::ReadHandle<xAOD::EventInfo> ei(m_eventInfoKey,ctx);
 
diff --git a/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.h b/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.h
index c53fa6597c6ac67f86548cad93dfc456cbf8fe64..72f5c9879664d8cfd513a2589a2daa739b0c5baa 100644
--- a/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.h
+++ b/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.h
@@ -28,7 +28,7 @@ public:
 
   // Algorithm virtual methods 
   StatusCode initialize();
-  StatusCode execute_r(const EventContext& ctx) const;
+  StatusCode execute(const EventContext& ctx) const;
   StatusCode finalize();
 
 private:
diff --git a/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.cxx b/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.cxx
index 40e8eb77cc63b690f5c1622edec6f5c09c21b234..fe06a71efa812817e3e571ecda1e18c4a1349f25 100644
--- a/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.cxx
+++ b/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.cxx
@@ -80,7 +80,7 @@ StatusCode CaloCell2ClusterMapper::finalize()
 
 //###############################################################################
 
-StatusCode CaloCell2ClusterMapper::execute_r(const EventContext& ctx) const {
+StatusCode CaloCell2ClusterMapper::execute(const EventContext& ctx) const {
 
   // make a DataVector of Navigable CaloClusterContainer 
   ATH_MSG_DEBUG(" Recording Cell2Cluster Map " << m_mapOutputKey.key());
diff --git a/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.h b/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.h
index 6f497d6d699c066fb0c94f6e7adc9a2188e7850f..db39d8be16d68757fb2afba4fa814b8a5344ac93 100644
--- a/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.h
+++ b/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.h
@@ -35,7 +35,7 @@ class CaloCell2ClusterMapper : public AthReentrantAlgorithm
   CaloCell2ClusterMapper(const std::string& name, ISvcLocator* pSvcLocator);
   virtual ~CaloCell2ClusterMapper();
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
   virtual StatusCode finalize() override;
 
  protected:
diff --git a/Calorimeter/CaloRec/src/CaloClusterMaker.cxx b/Calorimeter/CaloRec/src/CaloClusterMaker.cxx
index 20b364f66b7c34e5bf5d8a4783e02bdbe674fba9..8819e2a15f6d96f56cab73e70adeb77e6f72c11f 100644
--- a/Calorimeter/CaloRec/src/CaloClusterMaker.cxx
+++ b/Calorimeter/CaloRec/src/CaloClusterMaker.cxx
@@ -132,7 +132,7 @@ StatusCode CaloClusterMaker::finalize() {
 
 //###############################################################################
 
-StatusCode CaloClusterMaker::execute_r (const EventContext& ctx) const
+StatusCode CaloClusterMaker::execute (const EventContext& ctx) const
 {
 
   // make a Cluster Container 
diff --git a/Calorimeter/CaloRec/src/CaloClusterMaker.h b/Calorimeter/CaloRec/src/CaloClusterMaker.h
index b490c417a485bd706d42645a3ec90f36687524d9..05c8fd631d244b2f14e05df08f634fa3c183b99c 100644
--- a/Calorimeter/CaloRec/src/CaloClusterMaker.h
+++ b/Calorimeter/CaloRec/src/CaloClusterMaker.h
@@ -40,7 +40,7 @@ class CaloClusterMaker : public AthReentrantAlgorithm
   CaloClusterMaker(const std::string& name, ISvcLocator* pSvcLocator);
   virtual ~CaloClusterMaker() override;
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r(const EventContext& ctx) const override;
+  virtual StatusCode execute(const EventContext& ctx) const override;
   virtual StatusCode finalize() override;
 
   const std::string& getOutputContainerName() const;
diff --git a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx
index e68e0b1e2e90972ca75e17592da2b4055e338983..55afed800e3f0aa001438dafcbf846ce34bd6061 100644
--- a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx
+++ b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx
@@ -152,7 +152,7 @@ StatusCode CaloTopoTowerAlg::initialize()
 ///==============================================
 /// EXECUTE
 ///==============================================
-StatusCode CaloTopoTowerAlg::execute_r (const EventContext& ctx) const
+StatusCode CaloTopoTowerAlg::execute (const EventContext& ctx) const
 {
   /// Say hello
   ATH_MSG_DEBUG( "In CaloTopoTowerAlg::execute()"  );
diff --git a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.h b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.h
index 0aaac831cef67c923888796e55e31cafac5c7c64..fb65ce621da926b93d8ef05d3c634aa6a2807041 100644
--- a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.h
+++ b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.h
@@ -61,7 +61,7 @@ class CaloTopoTowerAlg : public AthReentrantAlgorithm
   virtual  StatusCode  finalize() override;
   
   /// Execute
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 private:
   // Container name strings
diff --git a/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.cxx b/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.cxx
index e652ebfc2526aa98608272474c54a26a39614fb2..6581b2a8cb6bcc573c8e61bfc07339ee62708d9a 100644
--- a/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.cxx
+++ b/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.cxx
@@ -206,7 +206,7 @@ StatusCode CaloTopoTowerAlgorithm::initialize()
 // Execute //
 /////////////
 
-StatusCode CaloTopoTowerAlgorithm::execute_r (const EventContext& ctx) const
+StatusCode CaloTopoTowerAlgorithm::execute (const EventContext& ctx) const
 {
 
   //////////////////////////
diff --git a/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.h b/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.h
index bd46bd5fe1627bffffb11289fc115ed7f3067009..24c6f06327fc461fdd21fdaa3367144a876c6215 100644
--- a/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.h
+++ b/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.h
@@ -50,7 +50,7 @@ class CaloTopoTowerAlgorithm : public AthReentrantAlgorithm
 
   /// inherited from Algorithm
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
   virtual StatusCode finalize() override;
 
  protected:
diff --git a/Calorimeter/CaloRec/src/CaloTowerAlgorithm.cxx b/Calorimeter/CaloRec/src/CaloTowerAlgorithm.cxx
index 0f477e0c074b125e4ba04304466a191db3ca73ee..0ba432ed5354fe4d4b6425f7e1fd8b6cb070103f 100644
--- a/Calorimeter/CaloRec/src/CaloTowerAlgorithm.cxx
+++ b/Calorimeter/CaloRec/src/CaloTowerAlgorithm.cxx
@@ -114,7 +114,7 @@ StatusCode CaloTowerAlgorithm::initialize()
 // Execute //
 /////////////
 
-StatusCode CaloTowerAlgorithm::execute_r (const EventContext& ctx) const
+StatusCode CaloTowerAlgorithm::execute (const EventContext& ctx) const
 {
 
   //////////////////////////
diff --git a/Calorimeter/CaloRec/src/CaloTowerAlgorithm.h b/Calorimeter/CaloRec/src/CaloTowerAlgorithm.h
index a3142cbd5e4ab55a0c4711166c87a6500fb57dd3..a642742773cdc07b9c5adae5991baa3c6a119653 100644
--- a/Calorimeter/CaloRec/src/CaloTowerAlgorithm.h
+++ b/Calorimeter/CaloRec/src/CaloTowerAlgorithm.h
@@ -46,7 +46,7 @@ class CaloTowerAlgorithm: public AthReentrantAlgorithm {
 
     /// inherited from Algorithm
     virtual StatusCode initialize() override;
-    virtual StatusCode execute_r (const EventContext& ctx) const override;
+    virtual StatusCode execute (const EventContext& ctx) const override;
     virtual StatusCode finalize() override;
 
   protected:
diff --git a/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.cxx b/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.cxx
index c57a41e3c2dbd94eaa265a0ef2bd100c67115a3e..260a909d009f7d6a8cb60d8a63b0eb222355ea75 100644
--- a/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.cxx
+++ b/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.cxx
@@ -45,7 +45,7 @@ StatusCode CaloTowerxAODFromCells::initialize() {
   return initBase();
 }
 
-StatusCode CaloTowerxAODFromCells::execute_r(const EventContext& ctx) const
+StatusCode CaloTowerxAODFromCells::execute(const EventContext& ctx) const
 { 
   SG::ReadHandle<CaloCellContainer> inputCellContainer(m_inputCellContainerKey, ctx);
   if (!inputCellContainer.isValid()) {
diff --git a/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.h b/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.h
index 4810f17ab2fe1130b46d7397bc7191f09b169f0f..d2bf214acad8ca0fecf8aac9d0b12bf994d26d0c 100644
--- a/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.h
+++ b/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.h
@@ -33,7 +33,7 @@ public:
   /// @name @c AthAlgorithm interface implementation
   /// @{
   virtual StatusCode initialize() override;     ///< @brief Initialize algorithm
-  virtual StatusCode execute_r(const EventContext& ctx) const override;        ///< @brief Execute algorithm
+  virtual StatusCode execute(const EventContext& ctx) const override;        ///< @brief Execute algorithm
   virtual StatusCode finalize() override;       ///< @brief Finalize algorithm
   /// @}
 
diff --git a/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.cxx b/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.cxx
index 7236142f1827ded242119e816eab444728db4aa4..358b544b3c5f2d6842d1ef4144aa67e50676176f 100644
--- a/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.cxx
+++ b/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.cxx
@@ -30,7 +30,7 @@ StatusCode CaloTowerxAODFromClusters::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode CaloTowerxAODFromClusters::execute_r(const EventContext& ctx) const
+StatusCode CaloTowerxAODFromClusters::execute(const EventContext& ctx) const
 { 
   SG::ReadHandle<xAOD::CaloClusterContainer> inputClusterContainer(m_inputClusterContainerKey, ctx);
 
diff --git a/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.h b/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.h
index 6b4b24b3a19c98385f0eae4bcf5d47bd4b0b7c08..63ae13ce993d41ce8f221a8b2f20184ec70441f4 100644
--- a/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.h
+++ b/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.h
@@ -27,7 +27,7 @@ public:
   /// @name @c AthAlgorithm interface implementation
   /// @{
   virtual StatusCode initialize() override;     ///< @brief Initialize algorithm
-  virtual StatusCode execute_r(const EventContext&) const override;        ///< @brief Execute algorithm
+  virtual StatusCode execute(const EventContext&) const override;        ///< @brief Execute algorithm
   virtual StatusCode finalize() override;       ///< @brief Finalize algorithm
   /// @}
 
diff --git a/Calorimeter/CaloRec/src/ToolWithConstantsMixin.cxx b/Calorimeter/CaloRec/src/ToolWithConstantsMixin.cxx
index d093358143300860f9002bf387aae23c4eb3458b..17e9fae866938a25ff165c2002677269538ec983 100755
--- a/Calorimeter/CaloRec/src/ToolWithConstantsMixin.cxx
+++ b/Calorimeter/CaloRec/src/ToolWithConstantsMixin.cxx
@@ -75,7 +75,7 @@ ToolWithConstantsMixin::finish_ctor (const std::string& toolcls /*= ""*/)
     if (m_toolcls.empty())
       m_toolcls = thistool->type();
   }
-  else if (Algorithm* thisalg = dynamic_cast<Algorithm*> (this)) {
+  else if (Gaudi::Algorithm* thisalg = dynamic_cast<Gaudi::Algorithm*> (this)) {
     thisalg->declareProperty ("detStoreKey", m_detStoreKey);
     thisalg->declareProperty ("prefix",      m_prefix);
     thisalg->declareProperty ("useCallback", m_use_callback);
diff --git a/Control/AthAnalysisBaseComps/AthAnalysisBaseComps/AthAnalysisHelper.h b/Control/AthAnalysisBaseComps/AthAnalysisBaseComps/AthAnalysisHelper.h
index d05f7fc57052c8fcf1d3e1effb0044adb0b22b07..128ed9f575b6bd78d1bc1ef544f63f5aec918a1f 100644
--- a/Control/AthAnalysisBaseComps/AthAnalysisBaseComps/AthAnalysisHelper.h
+++ b/Control/AthAnalysisBaseComps/AthAnalysisBaseComps/AthAnalysisHelper.h
@@ -119,7 +119,7 @@ public:
 
    ///setProperty on an alg, even when initialized
    template<typename W> static StatusCode setProperty(IAlgorithm* alg, const std::string& property, const W& value) {
-      Algorithm* theAlg = dynamic_cast<Algorithm*>(alg);
+     Gaudi::Algorithm* theAlg = dynamic_cast<Gaudi::Algorithm*>(alg);
       if(!theAlg) {
          std::cout << "ERROR: alg is not an Algorithm. Cannot AthAnalysisHelper::setProperty on it" << std::endl;
          return StatusCode::FAILURE;
diff --git a/Control/AthenaBaseComps/AthenaBaseComps/AthLegacySequence.h b/Control/AthenaBaseComps/AthenaBaseComps/AthLegacySequence.h
new file mode 100644
index 0000000000000000000000000000000000000000..4745fe0a44a6d5e8a7a3d21e2e99f5cb2f982945
--- /dev/null
+++ b/Control/AthenaBaseComps/AthenaBaseComps/AthLegacySequence.h
@@ -0,0 +1,69 @@
+/*
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
+*/
+
+// AthLegacySequence.h
+// Header file for class AthLegacySequence
+/////////////////////////////////////////////////////////////////// 
+#ifndef ATHENABASECOMPS_ATHLEGACYEQUENCE_H
+#define ATHENABASECOMPS_ATHLEGACYEQUENCE_H 1
+
+#pragma once
+
+
+// Framework includes
+#include "AthenaBaseComps/AthCommonDataStore.h"
+#include "AthenaBaseComps/AthCommonMsg.h"
+#include "Gaudi/Sequence.h"
+#include "GaudiKernel/ThreadLocalContext.h"
+
+namespace Athena {
+  namespace details {
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Woverloaded-virtual"
+    class AthLegacySequenceAdapter
+      : public AthCommonDataStore<AthCommonMsg< Gaudi::Sequence >>
+    { 
+    public: 
+      
+      /// Constructor with parameters: 
+      AthLegacySequenceAdapter(const std::string& name, 
+                               ISvcLocator* pSvcLocator);
+      
+      virtual StatusCode execute() = 0;
+      
+      const EventContext& getContext() const { return Gaudi::Hive::currentContext(); }
+
+      virtual const DataObjIDColl& extraOutputDeps() const override;
+      
+    protected:
+      bool isReEntrant() const override final { return false; }
+      
+    private:
+      StatusCode execute( const EventContext& ) const override final
+      {
+        return const_cast<AthLegacySequenceAdapter*>( this )->execute();
+      }
+      
+      DataObjIDColl m_extendedExtraObjects;
+      
+    }; 
+#pragma GCC diagnostic pop
+  }
+}
+
+
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Woverloaded-virtual"
+/// Alias for backward compatibility
+class AthLegacySequence : public Athena::details::AthLegacySequenceAdapter
+{
+public:
+  using Athena::details::AthLegacySequenceAdapter::AthLegacySequenceAdapter;
+  // this is to explicitly hide the other signature of `execute`
+  StatusCode execute() override = 0;
+};
+#pragma GCC diagnostic pop
+
+
+#endif //> !ATHENABASECOMPS_ATHLEGACYSEQUENCE_H
diff --git a/Control/AthenaBaseComps/AthenaBaseComps/AthReentrantAlgorithm.h b/Control/AthenaBaseComps/AthenaBaseComps/AthReentrantAlgorithm.h
index 4472d43ea233388abae444a7f4ea4a5ce24141a4..65b21b18b6a7d4eb6ddb76f20bda70d31b0bda25 100644
--- a/Control/AthenaBaseComps/AthenaBaseComps/AthReentrantAlgorithm.h
+++ b/Control/AthenaBaseComps/AthenaBaseComps/AthReentrantAlgorithm.h
@@ -22,13 +22,7 @@
 #include "AthenaBaseComps/AthMemMacros.h"
 
 
-// Framework includes
-#ifndef REENTRANT_GAUDI
- #define ReEntAlgorithm Algorithm
- #include "GaudiKernel/Algorithm.h"
-#else
- #include "GaudiKernel/ReEntAlgorithm.h"
-#endif
+#include "Gaudi/Algorithm.h"
 
 
 /**
@@ -40,19 +34,19 @@
  * derives from @c AthReentrantAlgorithm, then the same algorithm object may
  * be used in multiple threads without cloning.
  *
- * Rather than @c execute, a reentrant algorithm will call @c execute_r,
- * which has two differences.  First, @c execute_r is @c const.  If the
+ * Rather than @c execute, a reentrant algorithm will call @c execute,
+ * which has two differences.  First, @c execute is @c const.  If the
  * same object is being used in multiple threads, it should not have any
  * state which is being changed.  Any attempt to get around this with
  * @c mutable or @c const_cast should be viewed with great suspicion:
  * that may not be thread-safe.
  *
- * Second, the @c execute_r method takes an explicit event context argument.
+ * Second, the @c execute method takes an explicit event context argument.
  * This may be used to find the proper store for the event being processed
  * by the current thread.
  *
  * The typical usage will be to declare a key object as a property of the
- * algorithm and then construct a transient handle instance during @c execute_r
+ * algorithm and then construct a transient handle instance during @c execute
  * from the key and the event context.  For example:
  *
  *@code
@@ -74,7 +68,7 @@
  *    return StatusCode::SUCCESS;
  *  }
  *
- *  StatusCode MyAlg::execute_r (const EventContext& ctx) const
+ *  StatusCode MyAlg::execute (const EventContext& ctx) const
  *  {
  *    SG::ReadHandle<MyObj> myobj (m_rhandle, ctx);
  *    const MyObj& p = *myobj;
@@ -85,7 +79,7 @@
 
 
 class AthReentrantAlgorithm
-  : public AthCommonDataStore<AthCommonMsg<ReEntAlgorithm>>
+  : public AthCommonDataStore<AthCommonMsg<Gaudi::Algorithm>>
 { 
   /////////////////////////////////////////////////////////////////// 
   // Public methods: 
@@ -102,27 +96,6 @@ class AthReentrantAlgorithm
   /// Destructor: 
   virtual ~AthReentrantAlgorithm() override; 
 
-
-#ifndef REENTRANT_GAUDI
-  /**
-   * @brief Standard Gaudi execute method.
-   *
-   * This cannot be overridden; you should override the reentrant method
-   * @c execute_r instead.
-   */
-  virtual StatusCode execute() override final;
-
-
-  /**
-   * @brief Reentrant execute method.
-   * @param ctx The current event context.
-   *
-   * Override this for your algorithm.
-   */
-  virtual StatusCode execute_r (const EventContext& ctx) const = 0;
-#endif
-
-
   /** Specify if the algorithm is clonable
    *
    * Reentrant algorithms are clonable.
@@ -137,16 +110,6 @@ class AthReentrantAlgorithm
   virtual unsigned int cardinality() const override;
 
 
-  /**
-   * @brief Return the current event context.
-   *
-   * Override this because the base class version won't work correctly
-   * for reentrant algorithms.  (We shouldn't really be using this
-   * for reentrant algorithms, but just in case.).
-   */
-  virtual const EventContext& getContext() const override;
-
-
   /**
    * @brief Execute an algorithm.
    *
@@ -156,7 +119,6 @@ class AthReentrantAlgorithm
    */
   virtual StatusCode sysExecute (const EventContext& ctx) override;
 
-
   
   /**
    * @brief Return the list of extra output dependencies.
diff --git a/Control/AthenaBaseComps/src/AthLegacySequence.cxx b/Control/AthenaBaseComps/src/AthLegacySequence.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..eaea8b72b8bb90f7dba8d67a0a03e512e672f542
--- /dev/null
+++ b/Control/AthenaBaseComps/src/AthLegacySequence.cxx
@@ -0,0 +1,32 @@
+/*
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
+*/
+// AthenaBaseComps includes
+#include "AthenaBaseComps/AthLegacySequence.h"
+#include "AthAlgorithmDHUpdate.h"
+
+
+namespace Athena {
+  namespace details {
+    AthLegacySequenceAdapter::AthLegacySequenceAdapter(const std::string& name, 
+                                         ISvcLocator* pSvcLocator): 
+      ::AthCommonDataStore<AthCommonMsg<Gaudi::Sequence>> ( name, pSvcLocator)
+    {
+      setProperty("Cardinality", 1);
+      m_updateDataHandles =
+        std::make_unique<AthenaBaseComps::AthAlgorithmDHUpdate>
+        (m_extendedExtraObjects,
+         std::move (m_updateDataHandles));        
+    }
+    
+
+    const DataObjIDColl& 
+    AthLegacySequenceAdapter::extraOutputDeps() const {
+      if (!m_extendedExtraObjects.empty()) {
+        return m_extendedExtraObjects;
+      }
+      return Gaudi::Sequence::extraOutputDeps();
+    }
+  }
+
+}
diff --git a/Control/AthenaBaseComps/src/AthReentrantAlgorithm.cxx b/Control/AthenaBaseComps/src/AthReentrantAlgorithm.cxx
index f60c8cd210d2b3b173ad7d6e60632e70ec7c5963..d958beeb8caf6008f0b5e31b8e9853724becbd87 100644
--- a/Control/AthenaBaseComps/src/AthReentrantAlgorithm.cxx
+++ b/Control/AthenaBaseComps/src/AthReentrantAlgorithm.cxx
@@ -19,7 +19,7 @@
 AthReentrantAlgorithm::AthReentrantAlgorithm( const std::string& name, 
 			    ISvcLocator* pSvcLocator,
 			    const std::string& version ) : 
-  ::AthCommonDataStore<AthCommonMsg<ReEntAlgorithm>>   ( name, pSvcLocator, version )
+  ::AthCommonDataStore<AthCommonMsg<Gaudi::Algorithm>>   ( name, pSvcLocator, version )
 {
 
   // Set up to run AthAlgorithmDHUpdate in sysInitialize before
@@ -38,19 +38,6 @@ AthReentrantAlgorithm::~AthReentrantAlgorithm()
   ATH_MSG_DEBUG ("Calling destructor");
 }
 
-#ifndef REENTRANT_GAUDI
-/**
- * @brief Standard Gaudi execute method.
- *
- * Find the event context and call @c execute_r.
- */
-StatusCode AthReentrantAlgorithm::execute()
-{
-  return execute_r (Gaudi::Hive::currentContext());
-}
-#endif
-
-
 /** Specify if the algorithm is clonable
  */
 bool AthReentrantAlgorithm::isClonable() const
@@ -69,18 +56,6 @@ unsigned int AthReentrantAlgorithm::cardinality() const
   return 0;
 }
 
-/**
- * @brief Return the current event context.
- *
- * Override this because the base class version won't work correctly
- * for reentrant algorithms.  (We shouldn't really be using this
- * for reentrant algorithms, but just in case.).
- */
-const EventContext& AthReentrantAlgorithm::getContext() const
-{
-  return Gaudi::Hive::currentContext();
-}
-
 /**
  * @brief Execute an algorithm.
  *
@@ -90,23 +65,7 @@ const EventContext& AthReentrantAlgorithm::getContext() const
  */
 StatusCode AthReentrantAlgorithm::sysExecute (const EventContext& ctx)
 {
-  EventContext ctx2 = ctx;
-  // sysExecute will assign the context we pass in to a member variable of 
-  // the algorithm.  If the context is referencing any dynamic memory,
-  // then we can end up with a double-delete.  So clear out any extension ---
-  // we won't actually use the context we pass to here for anything anyway.
-
-  if (ctx.hasExtension<Atlas::ExtendedEventContext>()) {
-    ctx2.setExtension( Atlas::ExtendedEventContext() );
-  } else if (ctx.hasExtension()) {
-    ATH_MSG_ERROR("EventContext " << ctx
-                  << " has an extended context of an unknown type: \""
-                  << System::typeinfoName( ctx.getExtensionType() )
-                  << "\". Can't progress.");
-    return StatusCode::FAILURE;
-  }
-
-  return ::ReEntAlgorithm::sysExecute (ctx2);
+  return Gaudi::Algorithm::sysExecute (ctx);
 }
 
 
diff --git a/Control/AthenaBaseComps/test/AthReentrantAlgorithm_test.cxx b/Control/AthenaBaseComps/test/AthReentrantAlgorithm_test.cxx
index 31df7275dcf8acebb57a183cea503c3e2d85348a..93babbcf671b78f7d0ea8b541224f9cea647540b 100644
--- a/Control/AthenaBaseComps/test/AthReentrantAlgorithm_test.cxx
+++ b/Control/AthenaBaseComps/test/AthReentrantAlgorithm_test.cxx
@@ -45,7 +45,7 @@ public:
   MyAlg (const std::string& name, ISvcLocator* svcLoc);
 
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
   virtual void declare(Gaudi::DataHandle& hnd) override;
   virtual void addDependency (const DataObjID& obj, const Gaudi::DataHandle::Mode& mode) override;
@@ -83,7 +83,7 @@ StatusCode MyAlg::initialize()
 }
 
 
-StatusCode MyAlg::execute_r (const EventContext& ctx) const
+StatusCode MyAlg::execute (const EventContext& ctx) const
 {
   pdict = ctx.getExtension<Atlas::ExtendedEventContext>().proxy();
   return StatusCode::SUCCESS;
@@ -171,7 +171,7 @@ void test1 (ISvcLocator* svcLoc)
 
   Gaudi::Hive::setCurrentContext (ctx);
 
-  assert (alg.execute().isSuccess());
+  assert (alg.execute( ctx ).isSuccess());
   assert (pdict == xdict);
 
   DataObjIDColl exp = {
@@ -193,7 +193,7 @@ class MyArrAlg : public AthReentrantAlgorithm
 public:
   MyArrAlg (const std::string& name, ISvcLocator* svcLoc);
 
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
   SG::ReadHandleKey<MyObj> rkey;
   SG::WriteHandleKey<MyObj> wkey;
@@ -215,7 +215,7 @@ MyArrAlg::MyArrAlg  (const std::string& name, ISvcLocator* svcLoc)
 }
 
 
-StatusCode MyArrAlg::execute_r (const EventContext& /*ctx*/) const
+StatusCode MyArrAlg::execute (const EventContext& /*ctx*/) const
 {
   return StatusCode::SUCCESS;
 }
diff --git a/Control/AthenaCommon/share/Preparation.py b/Control/AthenaCommon/share/Preparation.py
index 480815d784da0e0047089418b5d38d81bdb36451..0a4786ea1ed3a2eb12ccc082bb48c0f8127a8c19 100644
--- a/Control/AthenaCommon/share/Preparation.py
+++ b/Control/AthenaCommon/share/Preparation.py
@@ -81,22 +81,6 @@ if min_cppyy_vmem_growth:
    del vmem_before_cppyy
 del min_cppyy_vmem_growth, grow_vmem, vmem_mb
 
-from cppyy import gbl
-## backward compat...
-class _AthenaServicesDictBwd:
-  @staticmethod
-  def SetFatalHandler(flags=-1):
-     import AthenaCommon.Logging as L
-     info = L.log.info
-     info("'gbl.AthenaServices.SetFatalHandler(flag)' is DEPRECATED")
-     info("instead, please consider using:")
-     info(" svcMgr.CoreDumpSvc.FatalHandler = flag")
-
-     from AthenaCommon.AppMgr import ServiceMgr as svcMgr
-     svcMgr.CoreDumpSvc.FatalHandler = flags
-setattr(gbl, 'AthenaServices', _AthenaServicesDictBwd)
-del _AthenaServicesDictBwd
-## end --
 if not (not opts.run_batch and theApp.EventLoop == "PyAthenaEventLoopMgr"):
    # make SIG_INT fatal
    svcMgr.CoreDumpSvc.FatalHandler = -1
diff --git a/Control/AthenaConfiguration/python/ComponentAccumulator.py b/Control/AthenaConfiguration/python/ComponentAccumulator.py
index d100edbfac63e9c88f16d2c3e2626862530ec70e..4f67c0f2542119a47b6985bd3cf0c020f1c77e47 100644
--- a/Control/AthenaConfiguration/python/ComponentAccumulator.py
+++ b/Control/AthenaConfiguration/python/ComponentAccumulator.py
@@ -548,7 +548,7 @@ class ComponentAccumulator(object):
             # if local bootstrap is missing, use one from the release
             bsfilename=find_datafile("bootstrap.pkl")
         else:
-            bsfilename = localbs[0]
+            bsfilename = "./"+localbs[0]
 
         bsfile=open(bsfilename)
         self._jocat=pickle.load(bsfile)
@@ -565,8 +565,11 @@ class ComponentAccumulator(object):
                 evtalgseq.append( alg.getFullName() )
 
 
-        for seqName, algoList  in flatSequencers( self._sequence ).iteritems():
-            self._jocat[seqName]["Members"]=str( [alg.getFullName() for alg in algoList] )
+        for seqName, algoList  in flatSequencers( self._sequence ).iteritems():            
+            # part of the sequence may come from the bootstrap, we need to retain the content, that is done here
+            mergedSequence = ast.literal_eval(self._jocat[seqName]["Members"]) +  [alg.getFullName() for alg in algoList] 
+            self._jocat[seqName]["Members"] = str( mergedSequence )
+                
 
         #Conditions Algorithms:
         condalgseq=[]
diff --git a/Control/AthenaConfiguration/python/iconfTool/__init__.py b/Control/AthenaConfiguration/python/iconfTool/__init__.py
old mode 100755
new mode 100644
diff --git a/Control/AthenaConfiguration/python/iconfTool/utils/__init__.py b/Control/AthenaConfiguration/python/iconfTool/utils/__init__.py
old mode 100644
new mode 100755
diff --git a/Control/AthenaExamples/AthAsgExUnittest/test/gt_AthExUnittest.cxx b/Control/AthenaExamples/AthAsgExUnittest/test/gt_AthExUnittest.cxx
index 07cd88c2a673c0e00a4bf2823b4404fcd5c28c17..c7db4954c3321d2564286a211f56d860ca5d84b3 100644
--- a/Control/AthenaExamples/AthAsgExUnittest/test/gt_AthExUnittest.cxx
+++ b/Control/AthenaExamples/AthAsgExUnittest/test/gt_AthExUnittest.cxx
@@ -46,7 +46,7 @@ namespace Athena_test {
       IAlgorithm* ialg= Algorithm::Factory::create( "MyPackageAlg",
 						    "MyPackageAlg",
 						    Gaudi::svcLocator() ).release();
-      myAlg= dynamic_cast<Algorithm*>( ialg );
+      myAlg= dynamic_cast<Gaudi::Algorithm*>( ialg );
 
     }
 
@@ -64,7 +64,7 @@ namespace Athena_test {
       return std::stoi( prop );
     }
 
-    Algorithm* myAlg;
+    Gaudi::Algorithm* myAlg;
 
   };
   
diff --git a/Control/AthenaExamples/AthExHive/src/HiveAlgR.cxx b/Control/AthenaExamples/AthExHive/src/HiveAlgR.cxx
index e433a9bce04ca2b71b5b957d2dfbf538f623e71b..5d87ca857cb520474ae949c97cbdc073e0908e48 100644
--- a/Control/AthenaExamples/AthExHive/src/HiveAlgR.cxx
+++ b/Control/AthenaExamples/AthExHive/src/HiveAlgR.cxx
@@ -38,7 +38,7 @@ StatusCode HiveAlgR::finalize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode HiveAlgR::execute_r(const EventContext& ctx) const {
+StatusCode HiveAlgR::execute(const EventContext& ctx) const {
 
   info() << "execute_R: " << index() << " on " << ctx << endmsg;
 
diff --git a/Control/AthenaExamples/AthExHive/src/HiveAlgR.h b/Control/AthenaExamples/AthExHive/src/HiveAlgR.h
index a7bcfbd16b6c8f32bbb8ff4235f8d495e9619b40..7be555e7b9ec98bf1e21a7a93691035d3e11ccd9 100644
--- a/Control/AthenaExamples/AthExHive/src/HiveAlgR.h
+++ b/Control/AthenaExamples/AthExHive/src/HiveAlgR.h
@@ -24,7 +24,7 @@ public:
   // Define the initialize, execute and finalize methods:
   
   StatusCode initialize();
-  StatusCode execute_r(const EventContext&) const;
+  StatusCode execute(const EventContext&) const;
   StatusCode finalize();
   
 private:
diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.cxx b/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.cxx
index 9d63867debb7b093ab8d40d745fea1a9db07d035..ddc3bc4496cfa4603664856f8f093a929ab9a1a4 100644
--- a/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.cxx
+++ b/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.cxx
@@ -33,7 +33,7 @@ StatusCode ExampleAlg::initialize()
 }
 
 
-StatusCode ExampleAlg::execute_r (const EventContext& ctx) const
+StatusCode ExampleAlg::execute (const EventContext& ctx) const
 {
   // Construct handles from the keys.
   // Since this is a reentrant algorithm, we have an explicit event context,
diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.h b/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.h
index de06b3e3853c1f9deffbae58deca58eb0fd1e87b..22d6b4708c971347bc84b958d14ca1e057d1dc56 100644
--- a/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.h
+++ b/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.h
@@ -29,7 +29,7 @@ class ExampleAlg
 public:
   ExampleAlg (const std::string& name, ISvcLocator* svcLocator);
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 private:
   // Declare the keys used to access the data: one for reading and one
diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.cxx b/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.cxx
index fcfe02f317d15ddc2d5a3d3b597aa90783b31c7a..ba8920403c5b0f9b27f671b88abd259b5f2962a5 100644
--- a/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.cxx
+++ b/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.cxx
@@ -69,7 +69,7 @@ StatusCode ReadDataReentrant::initialize()
 
 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 
 
-StatusCode ReadDataReentrant::execute_r (const EventContext& ctx) const
+StatusCode ReadDataReentrant::execute (const EventContext& ctx) const
 {
 
   // An algorithm, like this one, retrieving an object from the StoreGate(SG)
diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.h b/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.h
index d2f0fd136ecea6c64597813841d440962ddaaef7..93c54318dd3b2b153822bbf834e05b30a1e9d0db 100644
--- a/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.h
+++ b/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.h
@@ -31,7 +31,7 @@ class ReadDataReentrant
 public:
   ReadDataReentrant (const std::string& name, ISvcLocator* pSvcLocator);
   virtual StatusCode initialize() override final;
-  virtual StatusCode execute_r (const EventContext& ctx) const override final;
+  virtual StatusCode execute (const EventContext& ctx) const override final;
   virtual StatusCode finalize() override final;
   
 private:
diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.cxx b/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.cxx
index 842a29da1d4772d80a3d4609178f62fd91bb4079..8ad1cc179eb586babe8f9a1107495fabaabd080a 100644
--- a/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.cxx
+++ b/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.cxx
@@ -78,7 +78,7 @@ StatusCode WriteDataReentrant::initialize()
 
 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 
 
-StatusCode WriteDataReentrant::execute_r (const EventContext& ctx) const
+StatusCode WriteDataReentrant::execute (const EventContext& ctx) const
 {
   //this example illustrates how to record objects into the StoreGate(SG)
   //with and without providing a key
diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.h b/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.h
index 67221fa97b4c668f2ab13384e331931e8506ab09..7db055a45b86a90b2424f8040fd43be873962c04 100644
--- a/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.h
+++ b/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.h
@@ -32,7 +32,7 @@ public:
   WriteDataReentrant (const std::string& name, ISvcLocator* pSvcLocator);
   virtual StatusCode initialize() override final;
   virtual StatusCode finalize() override final;
-  virtual StatusCode execute_r (const EventContext& ctx) const override final;
+  virtual StatusCode execute (const EventContext& ctx) const override final;
 
 private:
   SG::WriteHandleKey<MyDataObj> m_dobjKey;
diff --git a/Control/AthenaExamples/AthExUnittest/test/gt_AthExUnittest.cxx b/Control/AthenaExamples/AthExUnittest/test/gt_AthExUnittest.cxx
index 5c656b82bf448beb78b46c75f4e40f09c47f32d0..e890dcb1be6886bc2e332005ede7337e92203419 100644
--- a/Control/AthenaExamples/AthExUnittest/test/gt_AthExUnittest.cxx
+++ b/Control/AthenaExamples/AthExUnittest/test/gt_AthExUnittest.cxx
@@ -46,7 +46,7 @@ namespace Athena_test {
       IAlgorithm* ialg= Algorithm::Factory::create( "AthExUnittestAlg",
 						    "AthExUnittestAlg",
 						    Gaudi::svcLocator() ).release();
-      myAlg= dynamic_cast<Algorithm*>( ialg );
+      myAlg= dynamic_cast<Gaudi::Algorithm*>( ialg );
 
     }
 
@@ -64,7 +64,7 @@ namespace Athena_test {
       return std::stoi( prop );
     }
 
-    Algorithm* myAlg = nullptr;
+    Gaudi::Algorithm* myAlg = nullptr;
 
   };
   
diff --git a/Control/AthenaMonitoring/src/AthMonBench.h b/Control/AthenaMonitoring/src/AthMonBench.h
index 307a12a2c36ef2192a78b2da3fb70870eb4a1a19..a934ce38b891473d33e8ec460fffb59b2f9f0d71 100644
--- a/Control/AthenaMonitoring/src/AthMonBench.h
+++ b/Control/AthenaMonitoring/src/AthMonBench.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 
@@ -30,7 +30,7 @@ public:
   static const MSG::Level s_resourceMonThreshold = MSG::DEBUG;
 
   AthMonBench();
-  ~AthMonBench(){}
+  ~AthMonBench() = default;
 
   //Modify:
   void reset();
diff --git a/Control/AthenaPython/AthenaPython/PyAthenaAlg.h b/Control/AthenaPython/AthenaPython/PyAthenaAlg.h
index 0d1ddeec4ff0a6910acaedb91d8a003a7800db57..b69045c2872eac16536fcea38fa3303ef9d72e77 100644
--- a/Control/AthenaPython/AthenaPython/PyAthenaAlg.h
+++ b/Control/AthenaPython/AthenaPython/PyAthenaAlg.h
@@ -51,8 +51,6 @@ class Alg : virtual public ::IPyComponent,
 
   virtual StatusCode sysInitialize() override;
 
-  virtual void resetExecuted() override;
-
   /////////////////////////////////////////////////////////////////// 
   // Const methods: 
   ///////////////////////////////////////////////////////////////////
diff --git a/Control/AthenaPython/src/PyAthenaAlg.cxx b/Control/AthenaPython/src/PyAthenaAlg.cxx
index dd0bc8c06550b2d3b880a99e7d3b5bf06e5e8121..687b3b15abfd12eda565405c272b8e784e9aa11a 100644
--- a/Control/AthenaPython/src/PyAthenaAlg.cxx
+++ b/Control/AthenaPython/src/PyAthenaAlg.cxx
@@ -99,12 +99,6 @@ Alg::execute()
   return sc;
 }
 
-void 
-Alg::resetExecuted()
-{  
-  PyAthena::callPyMethod( m_self, "resetExecuted" ).ignore();
-}
-
 StatusCode
 Alg::sysInitialize()
 {
diff --git a/Control/AthenaServices/python/PyAthenaEventLoopMgr.py b/Control/AthenaServices/python/PyAthenaEventLoopMgr.py
index ec08cccd8c0ace2425005d2a5d5b5926fcf3f904..4de2415d8f3538374800291f21eac6eff4eb6703 100644
--- a/Control/AthenaServices/python/PyAthenaEventLoopMgr.py
+++ b/Control/AthenaServices/python/PyAthenaEventLoopMgr.py
@@ -130,7 +130,7 @@ class PyAthenaEventLoopMgr( PyGaudi.iService ):
             if not alg._ialg:
                alg.retrieveInterface()
             ialg = alg._ialg
-            ialg.resetExecuted()
+            ialg.execState(ctx).reset()
             result = ialg.sysExecute(ctx)
             if result.isFailure():
                from AthenaCommon.Logging import log as msg
diff --git a/Control/AthenaServices/src/AthIncFirerAlg.cxx b/Control/AthenaServices/src/AthIncFirerAlg.cxx
index 07fcc114f63cb1e893554d39fd0d047d2d9d3f83..8d126b4688234545cc0ddd086da5b72ef4f233cb 100644
--- a/Control/AthenaServices/src/AthIncFirerAlg.cxx
+++ b/Control/AthenaServices/src/AthIncFirerAlg.cxx
@@ -5,14 +5,12 @@
 #include "EventInfo/EventIncident.h"
 #include "AthenaKernel/errorcheck.h"
 
-AthIncFirerAlg::AthIncFirerAlg( const std::string& name, ISvcLocator* pSvcLocator ):AthAlgorithm(name,pSvcLocator),m_Serial(false){
+AthIncFirerAlg::AthIncFirerAlg( const std::string& name, ISvcLocator* pSvcLocator ):AthReentrantAlgorithm(name,pSvcLocator),m_Serial(false){
   declareProperty("Incidents",m_incLists,"Incidents to fire");
   declareProperty("FireSerial",m_Serial,"Whether to fire serial incidents");  
 }
 
 StatusCode AthIncFirerAlg::initialize(){
-  auto sc=AthAlgorithm::initialize();
-  if (sc.isFailure()) return sc;  
   m_incSvc = service("IncidentSvc",true);
   //Copied from CPUCruncher.cpp
   if (m_incLists.value().size()==0){
@@ -22,30 +20,14 @@ StatusCode AthIncFirerAlg::initialize(){
   return StatusCode::SUCCESS;
 }
 
-StatusCode AthIncFirerAlg::execute() {
-  for(auto & i:m_incLists.value()){
-    ATH_MSG_VERBOSE("Firing incident "<<i);
-    if((i=="BeginEvent")||(i=="EndEvent")){
-      const EventInfo* event(0);
-      CHECK( evtStore()->retrieve(event) );
-      m_incSvc->fireIncident(std::make_unique<EventIncident>(*event, name(),i));
-      if(m_Serial.value())m_incSvc->fireIncident(EventIncident(*event, name(),i));
-    }else{
-      m_incSvc->fireIncident(std::make_unique<Incident>(name(),i));
-      if(m_Serial.value())m_incSvc->fireIncident(Incident( name(),i));
-    }
-  }
-  return StatusCode::SUCCESS;
-}
-
-StatusCode AthIncFirerAlg::execute_r(const EventContext& ctx)const {
+StatusCode AthIncFirerAlg::execute(const EventContext& ctx)const {
   auto ctxcp=ctx;
   for(auto & i:m_incLists.value()){
     ATH_MSG_VERBOSE("Firing incident "<<i);
 
     if((i=="BeginEvent")||(i=="EndEvent")){
       const EventInfo* event(0);
-      evtStore()->retrieve(event);
+      evtStore()->retrieve(event).ignore();
       m_incSvc->fireIncident(std::make_unique<EventIncident>(*event, name(),i,ctxcp));
       if(m_Serial.value())m_incSvc->fireIncident(EventIncident(*event, name(),i,ctxcp));
     }else{
diff --git a/Control/AthenaServices/src/AthIncFirerAlg.h b/Control/AthenaServices/src/AthIncFirerAlg.h
index 96485337142802ed5610c3a8f9cfbdef60ef4aa0..017da68379ea14456e6059fea77feb30610699f7 100644
--- a/Control/AthenaServices/src/AthIncFirerAlg.h
+++ b/Control/AthenaServices/src/AthIncFirerAlg.h
@@ -4,18 +4,17 @@
 
 #include <vector>
 #include <string>
-#include "AthenaBaseComps/AthAlgorithm.h"
+#include "AthenaBaseComps/AthReentrantAlgorithm.h"
 #include "GaudiKernel/Property.h"
 #include "GaudiKernel/ServiceHandle.h"
 
 class IIncidentSvc;
 
-class AthIncFirerAlg : public AthAlgorithm{
+class AthIncFirerAlg : public AthReentrantAlgorithm{
 public:
   AthIncFirerAlg( const std::string& name, ISvcLocator* pSvcLocator );  
   StatusCode initialize() override;
-  StatusCode execute() override;
-  StatusCode execute_r(const EventContext& ctx) const ;
+  StatusCode execute(const EventContext& ctx) const ;
   StatusCode finalize() override;
 private:
   // Gaudi::Property<std::vector<std::string>> m_incLists{this, "Incidents", {},"List of incidents to fire"};
diff --git a/Control/AthenaServices/src/AthenaOutputStream.cxx b/Control/AthenaServices/src/AthenaOutputStream.cxx
index ace89895181e59281ff402ef08a4140f8b270a55..51d84cba12d00a0263c54a954e14efe2798d5e76 100644
--- a/Control/AthenaServices/src/AthenaOutputStream.cxx
+++ b/Control/AthenaServices/src/AthenaOutputStream.cxx
@@ -317,7 +317,7 @@ StatusCode AthenaOutputStream::initialize() {
 
 StatusCode AthenaOutputStream::stop()
 {
-   ATH_MSG_INFO("AthenaOutputStream " << this->name() << " ::stop()");
+   ATH_MSG_DEBUG("AthenaOutputStream " << this->name() << " ::stop()");
    for (std::vector<ToolHandle<IAthenaOutputTool> >::iterator iter = m_helperTools.begin();
         iter != m_helperTools.end(); iter++) {
       if (!(*iter)->preFinalize().isSuccess()) {
diff --git a/Control/CxxUtils/CxxUtils/ConcurrentBitset.h b/Control/CxxUtils/CxxUtils/ConcurrentBitset.h
index cdab7e0163309bb217deee9bc26ea6b70a1a3755..add96c3fbf61116cf7cd7355a1558f95bd475591 100644
--- a/Control/CxxUtils/CxxUtils/ConcurrentBitset.h
+++ b/Control/CxxUtils/CxxUtils/ConcurrentBitset.h
@@ -1,6 +1,6 @@
 // This file's extension implies that it's C, but it's really -*- C++ -*-.
 /*
- * Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration.
+ * Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration.
  */
 // $Id$
 /**
@@ -209,6 +209,16 @@ public:
   ConcurrentBitset (std::initializer_list<bit_t> l, bit_t nbits = 0);
 
 
+  /**
+   * @brief Move constructor.
+   * @param other Container to move.
+   *
+   * No concurrent access may be in progress on @c other.
+   * After this returns, @c other can only be deleted.
+   */
+  ConcurrentBitset (ConcurrentBitset&& other);
+
+
   /**
    * @brief Destructor.
    */
@@ -225,6 +235,16 @@ public:
   ConcurrentBitset& operator= (const ConcurrentBitset& other);
 
 
+  /**
+   * @brief Move.
+   * @param other Bitset from which to move.
+   *
+   * No concurrent access may be in progress on @c other.
+   * After this returns, @c other can only be deleted.
+   */
+  ConcurrentBitset& operator= (ConcurrentBitset&& other);
+
+
   /**
    * @brief Clean up old versions of the set.
    *
diff --git a/Control/CxxUtils/Root/ConcurrentBitset.cxx b/Control/CxxUtils/Root/ConcurrentBitset.cxx
index 25a368dacb9d59775afc20ba4885d4d8f4c3cc6a..0cc542f94b1bc6071023df7f32d3a3a48b76678c 100644
--- a/Control/CxxUtils/Root/ConcurrentBitset.cxx
+++ b/Control/CxxUtils/Root/ConcurrentBitset.cxx
@@ -70,6 +70,22 @@ ConcurrentBitset::ConcurrentBitset (std::initializer_list<bit_t> l,
 }
 
 
+/**
+ * @brief Move constructor.
+ * @param other Container to move.
+ *
+ * No concurrent access may be in progress on @c other.
+ * After this returns, @c other can only be deleted.
+ */
+ConcurrentBitset::ConcurrentBitset (ConcurrentBitset&& other)
+{
+  other.emptyGarbage();
+  Impl* impl = other.m_impl;
+  other.m_impl = nullptr;
+  m_impl = impl;
+}
+
+
 /**
  * @brief Destructor.
  */
@@ -98,6 +114,27 @@ ConcurrentBitset& ConcurrentBitset::operator= (const ConcurrentBitset& other)
 }
 
 
+/**
+ * @brief Move.
+ * @param other Bitset from which to move.
+ *
+ * No concurrent access may be in progress on @c other.
+ * After this returns, @c other can only be deleted.
+ */
+ConcurrentBitset& ConcurrentBitset::operator= (ConcurrentBitset&& other)
+{
+  if (this != &other) {
+    emptyGarbage();
+    other.emptyGarbage();
+    delete m_impl;
+    Impl* impl = other.m_impl;
+    other.m_impl = nullptr;
+    m_impl = impl;
+  }
+  return *this;
+}
+
+
 /**
  * @brief Clean up old versions of the set.
  *
diff --git a/Control/CxxUtils/test/ConcurrentBitset_test.cxx b/Control/CxxUtils/test/ConcurrentBitset_test.cxx
index c305ee051234ef8c3054502872f48e52784ed3fb..2efd1811d246877b3e007093f599cfa493c75b86 100644
--- a/Control/CxxUtils/test/ConcurrentBitset_test.cxx
+++ b/Control/CxxUtils/test/ConcurrentBitset_test.cxx
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration.
+ * Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration.
  */
 
 // $Id$
@@ -320,7 +320,7 @@ void test_insert()
 }
 
 
-// Copy/assign
+// Copy/assign/move
 void test_copy()
 {
   std::cout << "test_copy\n";
@@ -365,6 +365,15 @@ void test_copy()
   bs3 = bs1;
   std::vector<size_t> v3 (bs3.begin(), bs3.end());
   assert (v3 == (std::vector<size_t> {5, 45, 87, 501}));
+
+  CxxUtils::ConcurrentBitset bs4 = std::move(bs1);
+  std::vector<size_t> v4 (bs4.begin(), bs4.end());
+  assert (v4 == (std::vector<size_t> {5, 45, 87, 501}));
+
+  CxxUtils::ConcurrentBitset bs5;
+  bs5 = std::move(bs4);
+  std::vector<size_t> v5 (bs5.begin(), bs5.end());
+  assert (v5 == (std::vector<size_t> {5, 45, 87, 501}));
 }
 
 
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.cxx
index 1c4d514f58ea9c908facd3eecad35206e68e28f8..0d7f4caf263d2b535fc27b85d06a6110728d6436 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.cxx
@@ -45,7 +45,7 @@ StatusCode CondAlg1::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode CondAlg1::execute_r (const EventContext& ctx) const
+StatusCode CondAlg1::execute (const EventContext& ctx) const
 {
   SG::ReadCondHandle<AthenaAttributeList> attrList (m_attrListKey, ctx);
   int xint = (**attrList)["xint"].data<int>();
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.h b/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.h
index 5a8afa2372448ee07b596ae04a98e402605febec..37fda17d17c240507c53d81c4ad5309b93bff68c 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.h
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.h
@@ -46,7 +46,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.cxx
index f91246d40b37ba5c1561ab81dc7499f6816a595c..079279a66ec19a874daf485338064ea50f50c5be 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.cxx
@@ -61,7 +61,7 @@ StatusCode CondReaderAlg::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode CondReaderAlg::execute_r (const EventContext& ctx) const
+StatusCode CondReaderAlg::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx);
 
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.h b/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.h
index 237d77c15482477e368cfc81a92b7eb2610088a1..06781d9024b326bb3353a2f8d1a6c5b381eb0eeb 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.h
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.h
@@ -49,7 +49,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.cxx
index 61347ae0e6afda2bdc9d3de0cb6ddc8e1cc575e8..88fd2d9700d2ab778197bd95c1cd2153eadff27b 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.cxx
@@ -45,7 +45,7 @@ StatusCode MetaReaderAlg::initialize()
  * @brief Algorithm execute method.
  * @param ctx Event context.
  */
-StatusCode MetaReaderAlg::execute_r (const EventContext& ctx) const
+StatusCode MetaReaderAlg::execute (const EventContext& ctx) const
 {
   // Get proper dbkey.
   const DataHeader* thisDH = nullptr;
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.h b/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.h
index c1f2bd4749b848892cb74df5dbc6312c46c362cd..149fced29774f5d5c4f80d679b75b3207307a93a 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.h
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.h
@@ -47,7 +47,7 @@ public:
    * @brief Algorithm execute method.
    * @param ctx Event context.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.cxx
index 2f07dafba3e86c432ffd73c39fbb49de7b73c89b..b79938bd03e53addb73a8515d714c044309149bc 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.cxx
@@ -44,7 +44,7 @@ StatusCode xAODTestAlg::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestAlg::execute_r (const EventContext& ctx) const
+StatusCode xAODTestAlg::execute (const EventContext& ctx) const
 {
   for (const auto& t : m_tools)
     ATH_CHECK( t->doit (ctx) );
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.h
index 44f39f83de0de5d4f9ac71123c055e8c37309e48..cd2e5824a6e939cf36ce5a6513a192bdbbbdc9da 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.h
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.h
@@ -45,7 +45,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.cxx
index 551b35e9add8d0a62ebb67aee44adf5c99d0a2ba..e56022f27ccddd7535dd71ffa165cdebb438b6a1 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.cxx
@@ -69,7 +69,7 @@ StatusCode xAODTestDecor::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestDecor::execute_r (const EventContext& ctx) const
+StatusCode xAODTestDecor::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx);
   unsigned int count = eventInfo->event_ID()->event_number() + 1;
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.h
index cf0b32004c96f22165a89502d50d1b2d06d1570f..1251a2c6a1f588a8734752032124ac4ee8d2dc90 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.h
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.h
@@ -52,7 +52,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override; 
+  virtual StatusCode execute (const EventContext& ctx) const override; 
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx
index 489b62499d2f95f433c49f8b9668618638e89a1b..b3b0b48fc2f64dad1f88118d9dbc0de42893192b 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx
@@ -62,7 +62,7 @@ StatusCode xAODTestReadDecor::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestReadDecor::execute_r (const EventContext& ctx) const
+StatusCode xAODTestReadDecor::execute (const EventContext& ctx) const
 {
   {
     std::ostringstream ss;
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.h
index 113f994046d77a3bcb11504a732edc7ea129f9a8..62d92088f1b8a46348601b781a2355f4ed17a298 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.h
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.h
@@ -48,7 +48,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override; 
+  virtual StatusCode execute (const EventContext& ctx) const override; 
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.cxx
index 31e3a94d7d757c774c35263d1d63081d42974145..0a5056e239a4eab7c47afb1ee127cb7740c20c26 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.cxx
@@ -38,7 +38,7 @@ StatusCode xAODTestReadSymlink::initialize()
 }
 
 
-StatusCode xAODTestReadSymlink::execute_r (const EventContext& ctx) const
+StatusCode xAODTestReadSymlink::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<SG::AuxElement> c (m_objKey, ctx);
   SG::ReadHandle<DMTest::S1> s1 (m_s1Key, ctx);
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.h
index 55561d6328b62edd0d79c8deb53a0fca83414545..a8db4bc9dbb055a0f4c4310181e300e31cfeb153 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.h
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.h
@@ -48,7 +48,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.cxx
index 6eaeef6adf044f5d683441ef75b808598041b6b7..46c6935b81ef4b5e11ee79352e782fc551a1b066 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.cxx
@@ -55,7 +55,7 @@ StatusCode xAODTestWriteCInfo::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestWriteCInfo::execute_r (const EventContext& ctx) const
+StatusCode xAODTestWriteCInfo::execute (const EventContext& ctx) const
 {
   //SG::ReadHandle<xAOD::EventInfo> eventInfo (m_eventInfoKey, ctx);
   //unsigned int count = eventInfo->eventNumber()  + 1;
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.h
index ad3d2de6bf4cacc546113f33e265fc29afcfed2a..0e4ee559826bb227c8b5e04fffc00e08285e0f57 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.h
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.h
@@ -53,7 +53,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.cxx
index 640f302d671f68fd766b4f5c0dec31bd1f1ba211..7e97df33bc6ca1e02970baffd7edaf28085a630f 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.cxx
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.cxx
@@ -54,7 +54,7 @@ StatusCode xAODTestFilterCVec::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestFilterCVec::execute_r (const EventContext& ctx) const
+StatusCode xAODTestFilterCVec::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<DMTest::CVec> cvec (m_cvecKey, ctx);
   const static C::Accessor<ElementLink<DMTest::CVec> > cEL ("cEL");
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.h
index f6220c7e8af24eb4ec498aad701ecb6302c4539b..7e1dbdc16c07f2913e6a639e0fc18b2c7dd595b5 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.h
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.h
@@ -50,7 +50,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.cxx
index 507990d44627d2bbb4c3774641b365623c63b78f..e01a0f3b89ac0f6fc82bb3df656a8871a53896fc 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.cxx
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.cxx
@@ -51,7 +51,7 @@ StatusCode xAODTestReadCInfo::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestReadCInfo::execute_r (const EventContext& ctx) const
+StatusCode xAODTestReadCInfo::execute (const EventContext& ctx) const
 {
   static const C::Accessor<int> anInt2 ("anInt2");
   static const C::Accessor<int> anInt10 ("anInt10");
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.h
index 22ddd89b1ac265ea551a2004d33c1544f202a64d..77fb515eb62dab4eaf9456d8df937d64963fc8b7 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.h
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.h
@@ -47,7 +47,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const;
+  virtual StatusCode execute (const EventContext& ctx) const;
 
 
 private:
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.cxx
index a9468898e3d05b801c2f49c78d9973c676aa5878..54224900a2e33d251b97146af57d028d41ec7926 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.cxx
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.cxx
@@ -65,7 +65,7 @@ StatusCode xAODTestReadCVec::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestReadCVec::execute_r (const EventContext& ctx) const
+StatusCode xAODTestReadCVec::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<DMTest::CVec> cvec (m_cvecKey, ctx);
 
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.h
index d45f552feebeef3f51063a8f917fa2f59fad4b4f..4b2a74c25e5dbf09afda872ab0b45ec8a9c0c13b 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.h
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.h
@@ -50,7 +50,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.cxx
index a0a95e62e9f5c5c71d321cdaebd78786828c62e6..2c7fd98ac5e580ba64f523c10c2bd867ea7af31a 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.cxx
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.cxx
@@ -54,7 +54,7 @@ StatusCode xAODTestReadCView::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestReadCView::execute_r (const EventContext& ctx) const
+StatusCode xAODTestReadCView::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<DMTest::CView> cview (m_cviewKey, ctx);
 
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.h
index 9a722b5977adce46078e03e5918d2af502c6b344..eeb513f850779548d484a52e0e1619b4b6150dbe 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.h
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.h
@@ -50,7 +50,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.cxx
index ea93300e21a698ca66dd25049fa4a223eabaf788..ec6526dd0e9eb7e217dbff165271998b5e7eb4d2 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.cxx
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.cxx
@@ -64,7 +64,7 @@ StatusCode xAODTestReadHVec::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestReadHVec::execute_r (const EventContext& ctx) const
+StatusCode xAODTestReadHVec::execute (const EventContext& ctx) const
 {
   const DMTest::HVec* hvec = SG::get (m_hvecKey, ctx);
   std::cout << m_hvecKey.key() << ":";
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.h
index c749ab28f13e23a0770b09d5ae4d559533a8e29f..e6dc370b7bb732d757a8cad2dd0fa58a2e052b20 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.h
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.h
@@ -51,7 +51,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.cxx
index 164615717c98bc6cc45d7d79c86b3c0ec7e56585..9e1fc6a73b10bba0c2dfcafb46eb4fa25e808bb4 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.cxx
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.cxx
@@ -77,7 +77,7 @@ StatusCode xAODTestWrite::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestWrite::execute_r (const EventContext& ctx) const
+StatusCode xAODTestWrite::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx);
   unsigned int count = eventInfo->event_ID()->event_number() + 1;
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.h
index bf5af6cbee38f633d0361eb33727f08445dae998..b85a3695688f14a3afab41f56088613aa67c373b 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.h
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.h
@@ -53,7 +53,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.cxx
index 05bd50affc78fa15b6a0434460d451d7055fb9c0..50bfe4227a120ccc7c3ca88b0cecf8c5d3981de7 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.cxx
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.cxx
@@ -71,7 +71,7 @@ StatusCode xAODTestWriteCVec::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestWriteCVec::execute_r (const EventContext& ctx) const
+StatusCode xAODTestWriteCVec::execute (const EventContext& ctx) const
 {
   //SG::ReadHandle<xAOD::EventInfo> eventInfo (m_eventInfoKey, ctx);
   //unsigned int count = eventInfo->eventNumber()  + 1;
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.h
index e7da4af15ade979137f4f5677884b5ab70d8903b..151956d790d0f606f334a23dd545bfb49377d613 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.h
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.h
@@ -53,7 +53,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.cxx
index 3f54d8c62cfe14972b9e3e2084ee3620d804a55c..ce978de84878a08a76bfb39ba7de24977c879c8e 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.cxx
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.cxx
@@ -50,7 +50,7 @@ StatusCode xAODTestWriteCVecConst::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestWriteCVecConst::execute_r (const EventContext& ctx) const
+StatusCode xAODTestWriteCVecConst::execute (const EventContext& ctx) const
 {
   auto coll = CxxUtils::make_unique<DMTest::CVec>();
   auto store = CxxUtils::make_unique<DMTest::CAuxContainer>();
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.h
index 5802915bdc886a3df0c6682a21be9e3c1e169566..fd8d71abf2bfe9fadeac7b6927eb9978e7e50803 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.h
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.h
@@ -49,7 +49,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.cxx
index b9a3417d759cab6df01285e82c0aaa7370d23d95..96a4bf7e3a2359e78f81c1ce9d89af31694a332c 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.cxx
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.cxx
@@ -52,7 +52,7 @@ StatusCode xAODTestWriteCView::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestWriteCView::execute_r (const EventContext& ctx) const
+StatusCode xAODTestWriteCView::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<DMTest::CVec> cvec (m_cvecKey, ctx);
   auto cview = std::make_unique<ConstDataVector<DMTest::CView> >(SG::VIEW_ELEMENTS);
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.h
index 89cf85142768914a2ef9b645609aa8a2fd4e7a37..46bc298d25765b7b49f273f005927fca0e23a5b5 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.h
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.h
@@ -52,7 +52,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.cxx
index d091fc269321e02683e20048078887b5e2420d5f..b9598e4146528481a8da39c3d9efca6d38681d05 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.cxx
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.cxx
@@ -56,7 +56,7 @@ StatusCode xAODTestWriteHVec::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestWriteHVec::execute_r (const EventContext& ctx) const
+StatusCode xAODTestWriteHVec::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx);
   unsigned int count = eventInfo->event_ID()->event_number() + 1;
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.h
index a932ea9f9ec657531496b9282c59c350d3fb644e..389b258bfa212294ed8338d42d2c01a9e41d3205 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.h
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.h
@@ -53,7 +53,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   /**
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.cxx
index 549dfef439f0e48f169b5f751e559d0424a34613..efac81f2886fdf6363f32117d82684cef0a93f2a 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.cxx
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.cxx
@@ -53,7 +53,7 @@ StatusCode xAODTestWriteSymlinks::initialize()
 /**
  * @brief Algorithm event processing.
  */
-StatusCode xAODTestWriteSymlinks::execute_r (const EventContext& ctx) const
+StatusCode xAODTestWriteSymlinks::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx);
   SG::WriteHandle<DMTest::S2> s2 (m_s2Key, ctx);
diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.h
index e58707d95c4ca54cfe18ce1c4d5e94e4f4d0de3a..a5eab365e414381b4b9cd978973f58c4c393b82c 100644
--- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.h
+++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.h
@@ -50,7 +50,7 @@ public:
   /**
    * @brief Algorithm event processing.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override; 
+  virtual StatusCode execute (const EventContext& ctx) const override; 
 
 
 private:
diff --git a/Control/GaudiSequencer/src/AthRetrySequencer.cxx b/Control/GaudiSequencer/src/AthRetrySequencer.cxx
index 39d9b9296457695728ad717a33b911725762c4c6..c7a9b0f6d4c353288c75e177171bc33e4a583224 100644
--- a/Control/GaudiSequencer/src/AthRetrySequencer.cxx
+++ b/Control/GaudiSequencer/src/AthRetrySequencer.cxx
@@ -44,16 +44,16 @@ AthRetrySequencer::AthRetrySequencer( const std::string& name,
 AthRetrySequencer::~AthRetrySequencer()
 {}
 
-StatusCode AthRetrySequencer::execute()
+StatusCode AthRetrySequencer::execute( const EventContext& ctx ) const
 {  
   ATH_MSG_DEBUG ("Executing " << name() << "...");
   int iloop = 0;
 
   while (iloop < m_maxRetries || m_maxRetries == -1) {
     iloop += 1;
-    this->AthSequencer::resetExecuted();
-    if (this->AthSequencer::execute().isSuccess() && 
-        filterPassed()) {
+    this->AthSequencer::resetExecuted( ctx );
+    if (this->AthSequencer::execute( ctx ).isSuccess() &&
+        this->execState(ctx).filterPassed()) {
       return StatusCode::SUCCESS;
     }
   }
diff --git a/Control/GaudiSequencer/src/AthRetrySequencer.h b/Control/GaudiSequencer/src/AthRetrySequencer.h
index be505503398360a6784c6a101051f8e66d54ebf4..0654858d380103ec57c649755b95dea630a87ee3 100644
--- a/Control/GaudiSequencer/src/AthRetrySequencer.h
+++ b/Control/GaudiSequencer/src/AthRetrySequencer.h
@@ -47,7 +47,7 @@ class AthRetrySequencer
   //AthRetrySequencer &operator=(const AthRetrySequencer &alg); 
 
   // Athena algorithm's Hooks
-  virtual StatusCode  execute();
+  virtual StatusCode  execute( const EventContext& ) const override;
 
   /////////////////////////////////////////////////////////////////// 
   // Const methods: 
diff --git a/Control/GaudiSequencer/src/AthSequencer.cxx b/Control/GaudiSequencer/src/AthSequencer.cxx
index 393fc3dc992d1137cd5e38f8306dfd7ee44f2dbf..5bee1662a514b5d35e602a5a3fe5cdb8791ee523 100644
--- a/Control/GaudiSequencer/src/AthSequencer.cxx
+++ b/Control/GaudiSequencer/src/AthSequencer.cxx
@@ -31,6 +31,10 @@
 #include <execinfo.h>
 #endif
 
+/// timer will abort job once timeout for any algorithm or sequence is reached
+thread_local Athena::AlgorithmTimer s_abortTimer{ 0, NULL, Athena::AlgorithmTimer::DEFAULT };
+
+
 #include "valgrind/valgrind.h"
 
 /**
@@ -49,7 +53,7 @@ bool AthSequencer::m_installedSignalHandler;
  **/
 AthSequencer::AthSequencer( const std::string& name, 
                             ISvcLocator* pSvcLocator ):
-  AthAlgorithm (name, pSvcLocator),
+  ::AthCommonDataStore<AthCommonMsg<Gaudi::Sequence>>   ( name, pSvcLocator ),
   m_timeoutMilliseconds(0),
   m_abortTimer(0, NULL, Athena::AlgorithmTimer::DEFAULT ),
   m_continueEventloopOnFPE(false)
@@ -89,13 +93,6 @@ AthSequencer::AthSequencer( const std::string& name,
 AthSequencer::~AthSequencer()
 {}
 
-/// Mark as a sequencer.
-bool AthSequencer::isSequence() const
-{
-  return true;
-}
-
-
 StatusCode
 AthSequencer::initialize()
 {
@@ -107,52 +104,60 @@ AthSequencer::initialize()
       m_timeoutMilliseconds = 0;
     }
   
-  std::vector<Algorithm*>* theAlgs;
-  std::vector<Algorithm*>::iterator it;
-  std::vector<Algorithm*>::iterator itend;
+  std::vector<Gaudi::Algorithm*>* theAlgs;
+  std::vector<Gaudi::Algorithm*>::iterator it;
+  std::vector<Gaudi::Algorithm*>::iterator itend;
   
   if (!decodeMemberNames().isSuccess()) {
     ATH_MSG_ERROR ("Unable to configure one or more sequencer members ");
     return StatusCode::FAILURE;
   }
   
+  StatusCode sc(StatusCode::SUCCESS);
   // Loop over all sub-algorithms
   theAlgs = subAlgorithms( );
   itend   = theAlgs->end( );
   for (it = theAlgs->begin(); it != itend; it++) {
-    Algorithm* theAlgorithm = (*it);
+    Gaudi::Algorithm* theAlgorithm = (*it);
     if (!theAlgorithm->sysInitialize( ).isSuccess()) {
-      ATH_MSG_ERROR ("Unable to initialize Algorithm " << theAlgorithm->name());
-      return StatusCode::FAILURE;
+      ATH_MSG_ERROR ("Unable to initialize Algorithm "
+                     << theAlgorithm->type() << "/" << theAlgorithm->name());
+      sc= StatusCode::FAILURE;      
     }
   }
 
-  return StatusCode::SUCCESS;
+  return sc;
 }
 
 StatusCode
 AthSequencer::reinitialize()
 {
+  StatusCode sc(StatusCode::SUCCESS);
   // Bypass the loop if this sequencer is disabled
   if ( isEnabled( ) ) {
     
     // Loop over all members calling their reinitialize functions
     // if they are not disabled.
-    std::vector<Algorithm*>* theAlgms = subAlgorithms( );
-    std::vector<Algorithm*>::iterator it;
-    std::vector<Algorithm*>::iterator itend = theAlgms->end( );
+    std::vector<Gaudi::Algorithm*>* theAlgms = subAlgorithms( );
+    std::vector<Gaudi::Algorithm*>::iterator it;
+    std::vector<Gaudi::Algorithm*>::iterator itend = theAlgms->end( );
     for (it = theAlgms->begin(); it != itend; it++) {
-      Algorithm* theAlgorithm = (*it);
-      if ( ! theAlgorithm->isEnabled( ) ) {
-        theAlgorithm->reinitialize( ).ignore();
+      Gaudi::Algorithm* theAlgorithm = (*it);
+      if ( theAlgorithm->isEnabled( ) ) {
+        if (theAlgorithm->sysReinitialize( ).isFailure()) {
+          ATH_MSG_ERROR ("Unable to reinitialize Algorithm "
+                         << theAlgorithm->type () << "/"
+                         << theAlgorithm->name());
+          sc = StatusCode::FAILURE;
+        }
       }
     }
   }
-  return StatusCode::SUCCESS;
+  return sc;
 }
 
 StatusCode
-AthSequencer::execute()
+AthSequencer::execute( const EventContext& ctx ) const
 {
   volatile bool all_good = true;
   volatile bool caughtfpe= false;
@@ -160,34 +165,32 @@ AthSequencer::execute()
   bool seqPass = !m_modeOR;
 
   ATH_MSG_DEBUG ("Executing " << name() << "...");
+
+  auto& state = execState( ctx );
   
   // Bypass the loop if this sequencer is disabled or has already been executed
-  if ( isEnabled( ) && ! isExecuted( ) ) {
+  if ( isEnabled( ) && state.state() != AlgExecState::State::Done ) {
 
     // Prevent multiple executions of this sequencer for the current event
-    setExecuted( true );
+    state.setState( AlgExecState::State::Executing );
 
     // Loop over all algorithms calling their execute functions if they
     // are (a) not disabled, and (b) aren't already executed. Note that
     // in the latter case the filter state is still examined. Terminate
     // the loop if an algorithm indicates that it's filter didn't pass.
-    std::vector<Algorithm*>* subAlgms = subAlgorithms( );
-    //volatile std::vector<Algorithm*>::iterator it;
-    //std::vector<Algorithm*>::iterator itend = subAlgms->end( );
-    //for (it = subAlgms->begin(); it != itend; it++) {
-    //volatile Algorithm* theAlgorithm = (*it);
-    for (Algorithm* theAlgorithm : *subAlgms) {
+    const std::vector<Gaudi::Algorithm*>* subAlgms = subAlgorithms( );
+    for (auto theAlgorithm : *subAlgms) {
       if ( theAlgorithm->isEnabled( ) ) {
-        if ( ! theAlgorithm->isExecuted( ) ) {
-          sc = executeAlgorithm (theAlgorithm, all_good, caughtfpe);
+        if ( theAlgorithm->execState(ctx).state() == AlgExecState::State::None ) {
+          sc = executeAlgorithm (theAlgorithm, ctx, all_good, caughtfpe);
         }
 	
         if ( all_good ) {
 	  
           if ( !m_ignoreFilter ) {
             // Take the filter passed status of this algorithm as my own status
-            bool passed = theAlgorithm->filterPassed( );
-            setFilterPassed( passed );
+            bool passed = theAlgorithm->execState( ctx ).filterPassed();
+            state.setFilterPassed( passed );
             
             // The behaviour when the filter fails depends on the 
             // StopOverride property.
@@ -206,16 +209,18 @@ AthSequencer::execute()
     }
   }
 
-  if ( !m_ignoreFilter && !m_names.empty() ) setFilterPassed( seqPass );
+  if ( !m_ignoreFilter && !m_names.empty() ) state.setFilterPassed( seqPass );
 
+  state.setState( AlgExecState::State::Done );
 
   return caughtfpe ? StatusCode::RECOVERABLE : sc;
 }
 
 
-StatusCode AthSequencer::executeAlgorithm (Algorithm* theAlgorithm,
+StatusCode AthSequencer::executeAlgorithm (Gaudi::Algorithm* theAlgorithm,
+                                           const EventContext& ctx,
                                            volatile bool& all_good,
-                                           volatile bool& caughtfpe)
+                                           volatile bool& caughtfpe) const
 {
   StatusCode sc = StatusCode::SUCCESS;
 
@@ -226,13 +231,11 @@ StatusCode AthSequencer::executeAlgorithm (Algorithm* theAlgorithm,
        !sigsetjmp(s_fpe_landing_zone, 1) )
   {
     // Call the sysExecute() of the method the algorithm
-    m_abortTimer.start(m_timeoutMilliseconds);
-    sc = theAlgorithm->sysExecute( getContext() );
+    s_abortTimer.start(m_timeoutMilliseconds);
+    sc = theAlgorithm->sysExecute( ctx );
     all_good = sc.isSuccess();
-    // I think this should be done by the algorithm itself, 
-    // but just in case...
-    theAlgorithm->setExecuted( true );
-    int tmp=m_abortTimer.stop();
+
+    int tmp=s_abortTimer.stop();
     // but printout only if non-zero timeout was used
     if (m_timeoutMilliseconds) {
       ATH_MSG_DEBUG ("Time left before interrupting <" 
@@ -253,92 +256,98 @@ StatusCode AthSequencer::executeAlgorithm (Algorithm* theAlgorithm,
   return sc;
 }
 
-StatusCode
-AthSequencer::finalize()
-{
-  ATH_MSG_DEBUG ("Finalizing " << name() << "...");
-  return StatusCode::SUCCESS;
-}
-
 StatusCode
 AthSequencer::start()
 {
+  StatusCode sc(StatusCode::SUCCESS);
 #ifdef GAUDIKERNEL_STATEMACHINE_H_
 
-  std::vector<Algorithm*>* theAlgs;
-  std::vector<Algorithm*>::iterator it;
-  std::vector<Algorithm*>::iterator itend;
+  std::vector<Gaudi::Algorithm*>* theAlgs;
+  std::vector<Gaudi::Algorithm*>::iterator it;
+  std::vector<Gaudi::Algorithm*>::iterator itend;
   
   // Loop over all sub-algorithms
   theAlgs = subAlgorithms( );
   itend   = theAlgs->end( );
   for (it = theAlgs->begin(); it != itend; it++) {
-    Algorithm* theAlgorithm = (*it);
+    Gaudi::Algorithm* theAlgorithm = (*it);
     if (!theAlgorithm->sysStart( ).isSuccess()) {
-      ATH_MSG_ERROR ("Unable to start Algorithm " << theAlgorithm->name());
-      return StatusCode::FAILURE;
+      ATH_MSG_ERROR ("Unable to start Algorithm "
+                     << theAlgorithm->type () << "/"
+                     << theAlgorithm->name());
+      sc = StatusCode::FAILURE;
     }
   }
 
 #endif // !GAUDIKERNEL_STATEMACHINE_H_
-
-  return StatusCode::SUCCESS;
+  return sc;
 }
 
 StatusCode
 AthSequencer::stop()
 {
+  StatusCode sc(StatusCode::SUCCESS);
 #ifdef GAUDIKERNEL_STATEMACHINE_H_
   // Loop over all sub-algorithms if they are not disabled.
-  std::vector<Algorithm*>* theAlgs;
-  std::vector<Algorithm*>::iterator it;
-  std::vector<Algorithm*>::iterator itend;
+  std::vector<Gaudi::Algorithm*>* theAlgs;
+  std::vector<Gaudi::Algorithm*>::iterator it;
+  std::vector<Gaudi::Algorithm*>::iterator itend;
   
   theAlgs = subAlgorithms( );
   itend   = theAlgs->end( );
   for (it = theAlgs->begin(); it != itend; it++) {
-    Algorithm* theAlgorithm = (*it);
+    Gaudi::Algorithm* theAlgorithm = (*it);
     if (theAlgorithm->sysStop( ).isFailure()) {
-      ATH_MSG_ERROR ("Unable to stop Algorithm " << theAlgorithm->name());
+      ATH_MSG_ERROR ("Unable to stop Algorithm "
+                     << theAlgorithm->type () << "/"
+                     << theAlgorithm->name());
+      sc = StatusCode::FAILURE;
     }
   }
   
 #endif // !GAUDIKERNEL_STATEMACHINE_H_
-  return StatusCode::SUCCESS;
+  return sc;
 }
 
 StatusCode
 AthSequencer::beginRun()
 {
   // Bypass the loop if this sequencer is disabled
+  StatusCode sc(StatusCode::SUCCESS);
   if ( isEnabled( ) ) {
     
     // Loop over all members calling their sysInitialize functions
     // if they are not disabled. Note that the Algoriithm::sysInitialize
     // function protects this from affecting Algorithms that have already
     // been initialized.
-    std::vector<Algorithm*>* theAlgs = subAlgorithms( );
-    std::vector<Algorithm*>::iterator it;
-    std::vector<Algorithm*>::iterator itend = theAlgs->end( );
+    std::vector<Gaudi::Algorithm*>* theAlgs = subAlgorithms( );
+    std::vector<Gaudi::Algorithm*>::iterator it;
+    std::vector<Gaudi::Algorithm*>::iterator itend = theAlgs->end( );
     for (it = theAlgs->begin(); it != itend; it++) {
-      Algorithm* theAlgorithm = (*it);
+      Gaudi::Algorithm* theAlgorithm = (*it);
       if (!theAlgorithm->sysInitialize( ).isSuccess()) {
         ATH_MSG_ERROR 
           ("Unable to initialize Algorithm " << theAlgorithm->name());
-        return StatusCode::FAILURE;
+        sc = StatusCode::FAILURE;
+        return sc;
       }
     }
     
     // Loop over all members calling their beginRun functions
     // if they are not disabled.
     for (it = theAlgs->begin(); it != itend; it++) {
-      Algorithm* theAlgorithm = (*it);
-      if ( ! theAlgorithm->isEnabled( ) ) {
+      Gaudi::Algorithm* theAlgorithm = (*it);
+      if ( theAlgorithm->isEnabled( ) ) {
 #ifdef __GNUC__
 #pragma GCC diagnostic push
 #pragma GCC diagnostic ignored "-Wdeprecated-declarations"
 #endif
-        theAlgorithm->beginRun( ).ignore();
+        if (theAlgorithm->sysBeginRun( ).isFailure()) {
+          ATH_MSG_ERROR("Unable to BeginRun Algorithm "
+                        << theAlgorithm->type() << "/"
+                        << theAlgorithm->name());
+          sc = StatusCode::FAILURE;
+        }
 #ifdef __GNUC__
 #pragma GCC diagnostic pop
 #endif
@@ -347,50 +356,56 @@ AthSequencer::beginRun()
     
   }
 
-  return StatusCode::SUCCESS;
+  return sc;
 }
 
 StatusCode
 AthSequencer::endRun()
 {
+  StatusCode sc(StatusCode::SUCCESS);
   // Bypass the loop if this sequencer is disabled
   if ( isEnabled( ) ) {
     
     // Loop over all members calling their endRun functions
     // if they are not disabled.
-    std::vector<Algorithm*>* theAlgms = subAlgorithms( );
-    std::vector<Algorithm*>::iterator it;
-    std::vector<Algorithm*>::iterator itend = theAlgms->end( );
+    std::vector<Gaudi::Algorithm*>* theAlgms = subAlgorithms( );
+    std::vector<Gaudi::Algorithm*>::iterator it;
+    std::vector<Gaudi::Algorithm*>::iterator itend = theAlgms->end( );
     for (it = theAlgms->begin(); it != itend; it++) {
-      Algorithm* theAlgorithm = (*it);
-      if ( ! theAlgorithm->isEnabled( ) ) {
+      Gaudi::Algorithm* theAlgorithm = (*it);
+      if ( theAlgorithm->isEnabled( ) ) {
 #ifdef __GNUC__
 #pragma GCC diagnostic push
 #pragma GCC diagnostic ignored "-Wdeprecated-declarations"
 #endif
-        theAlgorithm->endRun( ).ignore();
+        if ( theAlgorithm->sysEndRun( ).isFailure() ) {
+          ATH_MSG_ERROR("Unable to EndRun Algorithm "
+                        << theAlgorithm->type() << "/"
+                        << theAlgorithm->name());
+          sc = StatusCode::FAILURE;
+        }
 #ifdef __GNUC__
 #pragma GCC diagnostic pop
 #endif
       }
     }
   }
-  return StatusCode::SUCCESS;
+  return sc;
 }
 
 void
-AthSequencer::resetExecuted( )
+AthSequencer::resetExecuted( const EventContext& ctx ) const
 {
-  Algorithm::resetExecuted( );
+  execState(ctx).reset();
   
   // Loop over all members calling their resetExecuted functions
   // if they are not disabled.
-  std::vector<Algorithm*>* subAlgms = subAlgorithms( );
-  std::vector<Algorithm*>::iterator it;
-  std::vector<Algorithm*>::iterator itend = subAlgms->end( );
+  const std::vector<Gaudi::Algorithm*>* subAlgms = subAlgorithms( );
+  std::vector<Gaudi::Algorithm*>::const_iterator it;
+  std::vector<Gaudi::Algorithm*>::const_iterator itend = subAlgms->end( );
   for (it = subAlgms->begin(); it != itend; it++) {
-    Algorithm* theAlgorithm = (*it);
-    theAlgorithm->resetExecuted( );
+    Gaudi::Algorithm* theAlgorithm = (*it);
+    theAlgorithm->execState(ctx).reset();
   }
 }
 
@@ -401,7 +416,7 @@ AthSequencer::isStopOverride( ) const
 }
 
 StatusCode
-AthSequencer::append( Algorithm* pAlgorithm )
+AthSequencer::append( Gaudi::Algorithm* pAlgorithm )
 {
   return append( pAlgorithm, subAlgorithms( ) );
 }
@@ -409,13 +424,13 @@ AthSequencer::append( Algorithm* pAlgorithm )
 StatusCode
 AthSequencer::createAndAppend( const std::string& type,
                                const std::string& name,
-                               Algorithm*& pAlgorithm )
+                               Gaudi::Algorithm*& pAlgorithm )
 {
   return createAndAppend( type, name, pAlgorithm, subAlgorithms( ) );
 }
 
 StatusCode
-AthSequencer::remove( Algorithm* pAlgorithm )
+AthSequencer::remove( Gaudi::Algorithm* pAlgorithm )
 {
   return remove (pAlgorithm->name());
 }
@@ -444,16 +459,16 @@ AthSequencer::membershipHandler( Property& /* theProp */ )
  **/
 
 StatusCode
-AthSequencer::append( Algorithm* pAlgorithm,
-                      std::vector<Algorithm*>* theAlgs )
+AthSequencer::append( Gaudi::Algorithm* pAlgorithm,
+                      std::vector<Gaudi::Algorithm*>* theAlgs )
 {
   bool all_good = true;
   // Check that the specified algorithm doesn't already exist 
   // in the membership list
-  std::vector<Algorithm*>::iterator it;
-  std::vector<Algorithm*>::iterator itend = theAlgs->end( );
+  std::vector<Gaudi::Algorithm*>::iterator it;
+  std::vector<Gaudi::Algorithm*>::iterator itend = theAlgs->end( );
   for (it = theAlgs->begin(); it != itend; it++) {
-    Algorithm* theAlgorithm = (*it);
+    Gaudi::Algorithm* theAlgorithm = (*it);
     if ( theAlgorithm == pAlgorithm ) {
       all_good = false;
       break;
@@ -469,8 +484,8 @@ AthSequencer::append( Algorithm* pAlgorithm,
 StatusCode 
 AthSequencer::createAndAppend( const std::string& type,
                                const std::string& algName,
-                               Algorithm*& pAlgorithm,
-                               std::vector<Algorithm*>* theAlgs )
+                               Gaudi::Algorithm*& pAlgorithm,
+                               std::vector<Gaudi::Algorithm*>* theAlgs )
 {
   StatusCode result = StatusCode::FAILURE;
   IAlgManager* theAlgMgr;
@@ -484,7 +499,7 @@ AthSequencer::createAndAppend( const std::string& type,
     result = theAlgMgr->createAlgorithm( type, algName, tmp );
     if ( result.isSuccess( ) ) {
       try{
-        pAlgorithm = dynamic_cast<Algorithm*>(tmp);
+        pAlgorithm = dynamic_cast<Gaudi::Algorithm*>(tmp);
         theAlgs->push_back( pAlgorithm );
       } catch(...){
         ATH_MSG_ERROR ("Unable to create Algorithm " << algName);
@@ -498,7 +513,7 @@ AthSequencer::createAndAppend( const std::string& type,
 
 StatusCode
 AthSequencer::decodeNames( Gaudi::Property<std::vector<std::string>>& theNames,
-                           std::vector<Algorithm*>* theAlgs )
+                           std::vector<Gaudi::Algorithm*>* theAlgs )
 {
   StatusCode result;
   IAlgManager* theAlgMgr;
@@ -536,10 +551,10 @@ AthSequencer::decodeNames( Gaudi::Property<std::vector<std::string>>& theNames,
       // Check whether the suppied name corresponds to an existing
       // Algorithm object.
       IAlgorithm* theIAlg;
-      Algorithm*  theAlgorithm;
+      Gaudi::Algorithm*  theAlgorithm;
       StatusCode status = theAlgMgr->getAlgorithm( theName, theIAlg );
       if ( status.isSuccess( ) ) {
-        theAlgorithm = dynamic_cast<Algorithm*>(theIAlg);
+        theAlgorithm = dynamic_cast<Gaudi::Algorithm*>(theIAlg);
         if (!theAlgorithm) {
           ATH_MSG_WARNING 
             (theName << " is not an Algorithm - Failed dynamic cast");
@@ -581,7 +596,7 @@ AthSequencer::decodeNames( Gaudi::Property<std::vector<std::string>>& theNames,
   if ( result.isSuccess() && !theAlgs->empty() ) {
     msg(MSG::DEBUG) << "Member list: ";
     bool first = true;
-    for (Algorithm* alg : *theAlgs) {
+    for (Gaudi::Algorithm* alg : *theAlgs) {
       if (first)
         first = false;
       else
@@ -599,15 +614,15 @@ AthSequencer::decodeNames( Gaudi::Property<std::vector<std::string>>& theNames,
 
 StatusCode
 AthSequencer::remove( const std::string& algname, 
-                      std::vector<Algorithm*>* theAlgs )
+                      std::vector<Gaudi::Algorithm*>* theAlgs )
 {
   StatusCode result = StatusCode::FAILURE;
   
   // Test that the algorithm exists in the member list
-  std::vector<Algorithm*>::iterator it;
-  std::vector<Algorithm*>::iterator itend = theAlgs->end( );
+  std::vector<Gaudi::Algorithm*>::iterator it;
+  std::vector<Gaudi::Algorithm*>::iterator itend = theAlgs->end( );
   for (it = theAlgs->begin(); it != itend; it++) {
-    Algorithm* theAlgorithm = (*it);
+    Gaudi::Algorithm* theAlgorithm = (*it);
     if ( theAlgorithm->name( ) == algname ) {
       
       // Algorithm with specified name exists in the algorithm list - remove it
@@ -671,7 +686,7 @@ void AthSequencer::fpe_callback( int /* sig_number */, siginfo_t *info, void* /*
 }
 
 void
-AthSequencer::cleanupAfterFPE(siginfo_t *info)
+AthSequencer::cleanupAfterFPE(siginfo_t *info) const
 {
   if (info->si_signo != SIGFPE)                      /* should never happen */
     {
@@ -696,6 +711,7 @@ AthSequencer::cleanupAfterFPE(siginfo_t *info)
       // now have to unwind gaudi stack
       // Check if the AlgContextSvc is running
       IAlgContextSvc* algContextSvc(0);
+      EventContext ctx = Gaudi::Hive::currentContext();
       if (service("AlgContextSvc", algContextSvc, /*createIf=*/ false).isSuccess() && algContextSvc)
         {
           IAlgorithm* alg = algContextSvc->currentAlg();
@@ -718,7 +734,7 @@ AthSequencer::cleanupAfterFPE(siginfo_t *info)
                   }
               }
               while ( algContextSvc->algorithms().size() && algContextSvc->currentAlg()->name() != this->name() )
-                if ( algContextSvc->unSetCurrentAlg(algContextSvc->currentAlg()).isFailure() )
+                if ( algContextSvc->unSetCurrentAlg(algContextSvc->currentAlg(),ctx).isFailure() )
                   this->msg() << "cannot unwind: " << algContextSvc->currentAlg();
               this->msg() << endmsg;
             }
diff --git a/Control/GaudiSequencer/src/AthSequencer.h b/Control/GaudiSequencer/src/AthSequencer.h
index 516d33275e0ceb77d85a589b730077f212b6c5f4..13fa4d45e993cda130dedb64f10abec4752964b6 100644
--- a/Control/GaudiSequencer/src/AthSequencer.h
+++ b/Control/GaudiSequencer/src/AthSequencer.h
@@ -13,8 +13,11 @@
 #define GAUDISEQUENCER_ATHSEQUENCER_H
 
 // Include files
-#include "AthenaBaseComps/AthAlgorithm.h"
+#include "AthenaBaseComps/AthCommonDataStore.h"
+#include "AthenaBaseComps/AthCommonMsg.h"
+
 #include "GaudiKernel/Property.h"
+#include "Gaudi/Sequence.h"
 
 #include "AthenaKernel/AlgorithmTimer.h"
 
@@ -34,7 +37,8 @@
  **             terminated and the AthSequencer assumes the same filtered state as the
  **             last member.
  **/
-class AthSequencer : public AthAlgorithm 
+class AthSequencer
+  : public AthCommonDataStore<AthCommonMsg<Gaudi::Sequence>>
 {
 public:
 
@@ -54,8 +58,6 @@ public:
    ** Public Function Members **
    *****************************/
 
-  /// Mark as a sequencer.
-  virtual bool isSequence() const override final;
 
   /**
    ** Initialization of a sequencer. Typically things like histogram creation,
@@ -74,13 +76,8 @@ public:
    ** The actions to be performed by the sequencer on an event. This method
    ** is invoked once per event.
    **/
-  virtual StatusCode execute( ) override;
-  
-  /**
-   ** AthSequencer finalization.
-   **/
-  virtual StatusCode finalize( ) override;
-  
+  virtual StatusCode execute( const EventContext& ctx ) const override;
+    
   /**
    ** AthSequencer beginRun.
    **/
@@ -102,7 +99,7 @@ public:
   /**
    ** Reset the AthSequencer executed state for the current event.
    **/
-  virtual void resetExecuted( ) override;
+  virtual void resetExecuted( const EventContext& ctx ) const;
 
   /**
    ** Has the StopOverride mode been set?
@@ -112,7 +109,7 @@ public:
   /**
    ** Append an algorithm to the sequencer.
    **/
-  StatusCode append( Algorithm* pAlgorithm );
+  StatusCode append( Gaudi::Algorithm* pAlgorithm );
 
   /**
    ** Create a algorithm and append it to the sequencer. A call to this method
@@ -126,13 +123,13 @@ public:
   StatusCode createAndAppend(
                              const std::string& type,  // The concrete algorithm class of the algorithm
                              const std::string& name,  // The name to be given to the algorithm
-                             Algorithm*& pAlgorithm    // Set to point to the newly created algorithm object
+                             Gaudi::Algorithm*& pAlgorithm    // Set to point to the newly created algorithm object
                              );
 
   /**
    ** Remove the specified algorithm from the sequencer
    **/
-  StatusCode remove( Algorithm* pAlgorithm );
+  StatusCode remove( Gaudi::Algorithm* pAlgorithm );
   StatusCode remove( const std::string& name );
 
   /// Decode Member Name list
@@ -152,8 +149,8 @@ protected:
   /**
    ** Append an algorithm to the sequencer.
    **/
-  StatusCode append( Algorithm* pAlgorithm,
-                     std::vector<Algorithm*>* theAlgs );
+  StatusCode append( Gaudi::Algorithm* pAlgorithm,
+                     std::vector<Gaudi::Algorithm*>* theAlgs );
 
   /**
    ** Create a algorithm and append it to the sequencer. A call to this method
@@ -167,21 +164,21 @@ protected:
   StatusCode createAndAppend(
                              const std::string& type,  // The concrete algorithm class of the algorithm
                              const std::string& name,  // The name to be given to the algorithm
-                             Algorithm*& pAlgorithm,    // Set to point to the newly created algorithm object
-                             std::vector<Algorithm*>* theAlgs
+                             Gaudi::Algorithm*& pAlgorithm,    // Set to point to the newly created algorithm object
+                             std::vector<Gaudi::Algorithm*>* theAlgs
                              );
 
   /**
    ** Decode algorithm names, creating or appending algorithms as appropriate
    **/
   StatusCode decodeNames( Gaudi::Property<std::vector<std::string>>& theNames,
-                          std::vector<Algorithm*>* theAlgs );
+                          std::vector<Gaudi::Algorithm*>* theAlgs );
 
   /**
    ** Remove the specified algorithm from the sequencer
    **/
 
-  StatusCode remove( const std::string& algname, std::vector<Algorithm*>* theAlgs );
+  StatusCode remove( const std::string& algname, std::vector<Gaudi::Algorithm*>* theAlgs );
 
 private:
 
@@ -201,9 +198,10 @@ private:
 
   /// Run one algorithm.
   /// Broken out to avoid warnings related to longjmp.
-  StatusCode executeAlgorithm (Algorithm* theAlgorithm,
+  StatusCode executeAlgorithm (Gaudi::Algorithm* theAlgorithm,
+                               const EventContext& ctx,
                                volatile bool& all_good,
-                               volatile bool& caughtfpe);
+                               volatile bool& caughtfpe) const;
 
   /**************************
    ** Private Data Members **
@@ -247,7 +245,7 @@ private:
   static void fpe_trap_enable();
   static void fpe_callback(int, siginfo_t*, void*);
   static bool prepareCatchAndEnableFPE();
-  void cleanupAfterFPE(siginfo_t*);
+  void cleanupAfterFPE(siginfo_t*) const;
   static void uninstallFPESignalHandler();
   
   static const size_t s_maxArraySize = 50;
diff --git a/Control/SGComps/src/AddressRemappingSvc.cxx b/Control/SGComps/src/AddressRemappingSvc.cxx
index e976546742877a517b66d3a6c8d6902946c0d48a..8efdb0af1a2d89c2b1553bcd1ddb8d805176d175 100644
--- a/Control/SGComps/src/AddressRemappingSvc.cxx
+++ b/Control/SGComps/src/AddressRemappingSvc.cxx
@@ -465,7 +465,7 @@ void AddressRemappingSvc::initDeletes()
   m_haveDeletes = true;
 
   for (IAlgorithm* ialg : m_algResourcePool->getFlatAlgList()) {
-    if (Algorithm* alg = dynamic_cast<Algorithm*> (ialg)) {
+    if (Gaudi::Algorithm* alg = dynamic_cast<Gaudi::Algorithm*> (ialg)) {
       // Need to ignore SGInputLoader; it'll have output deps
       // on everything being read.
       if (alg->name() == "SGInputLoader") continue;
@@ -488,7 +488,10 @@ void AddressRemappingSvc::initDeletes()
           }
         }
       }
+    } else {
+      ATH_MSG_WARNING(ialg->name() << " doesn't seem to be an Algorithm" );
     }
+    
   }
 }
 //______________________________________________________________________________
diff --git a/Control/StoreGate/StoreGate/MetaHandleKey.icc b/Control/StoreGate/StoreGate/MetaHandleKey.icc
index 1bfa1f608995964a729539da78bf99f9502b3c90..7cfbf252105773801b49a4ee6fb9d5dfaa3daa8e 100644
--- a/Control/StoreGate/StoreGate/MetaHandleKey.icc
+++ b/Control/StoreGate/StoreGate/MetaHandleKey.icc
@@ -49,7 +49,7 @@ namespace SG {
         return StatusCode::FAILURE;
       }
       else {
-        msg << MSG::INFO << "MetaCont found with key= " 
+        msg << MSG::DEBUG << "MetaCont found with key= " 
             << SG::VarHandleKey::key() << endmsg;
       }
     } else {
diff --git a/Control/StoreGate/StoreGate/ReadDecorHandle.h b/Control/StoreGate/StoreGate/ReadDecorHandle.h
index 025ca9964e6efa70da33b04a2b69a48c53245032..83884e546853952c1f402a9af0d909275bdddd03 100644
--- a/Control/StoreGate/StoreGate/ReadDecorHandle.h
+++ b/Control/StoreGate/StoreGate/ReadDecorHandle.h
@@ -73,7 +73,7 @@ namespace SG {
  *    ...
  *  }
  *
- *  StatusCode MyAlgorithm::execute_r (const EventContext& ctx) const
+ *  StatusCode MyAlgorithm::execute (const EventContext& ctx) const
  *  {
  *    SG::ReadDecorHandle<MyCont, float> h (m_key, ctx);
  *    for (const MyObj& o : *h) {  // Access the container.
diff --git a/Control/StoreGate/StoreGate/ReadDecorHandleKey.h b/Control/StoreGate/StoreGate/ReadDecorHandleKey.h
index 1e4f643519d5f38d575286ca87a8cac3a2171cf0..d05be29b4aa3c3f98fdf1cfd30b25b4745018405 100644
--- a/Control/StoreGate/StoreGate/ReadDecorHandleKey.h
+++ b/Control/StoreGate/StoreGate/ReadDecorHandleKey.h
@@ -55,7 +55,7 @@ namespace SG {
  *    ...
  *  }
  *
- *  StatusCode MyAlgorithm::execute_r (const EventContext& ctx) const
+ *  StatusCode MyAlgorithm::execute (const EventContext& ctx) const
  *  {
  *    SG::ReadDecorHandle<MyCont, float> h (m_key, ctx);
  *    for (const MyObj& o : *h) {  // Access the container.
diff --git a/Control/StoreGate/StoreGate/WriteDecorHandle.h b/Control/StoreGate/StoreGate/WriteDecorHandle.h
index ced61555169efd9d5d63ab9a27268396efeaf188..c50b96f81bd72d3f39cd68c02ad3c5e018d27352 100644
--- a/Control/StoreGate/StoreGate/WriteDecorHandle.h
+++ b/Control/StoreGate/StoreGate/WriteDecorHandle.h
@@ -75,7 +75,7 @@ namespace SG {
  *    ...
  *  }
  *
- *  StatusCode MyAlgorithm::execute_r (const EventContext& ctx) const
+ *  StatusCode MyAlgorithm::execute (const EventContext& ctx) const
  *  {
  *    SG::WriteDecorHandle<MyCont, float> h (m_key, ctx);
  *    for (const MyObj& o : *h) {  // Access the container.
diff --git a/Control/StoreGate/StoreGate/WriteDecorHandleKey.h b/Control/StoreGate/StoreGate/WriteDecorHandleKey.h
index 8576bc78b070ae0257ba5b582f6141ccf82a8326..e8820fb81ebe9b85fe76272686e2695dd0deeeb8 100644
--- a/Control/StoreGate/StoreGate/WriteDecorHandleKey.h
+++ b/Control/StoreGate/StoreGate/WriteDecorHandleKey.h
@@ -60,7 +60,7 @@ namespace SG {
  *    ...
  *  }
  *
- *  StatusCode MyAlgorithm::execute_r (const EventContext& ctx) const
+ *  StatusCode MyAlgorithm::execute (const EventContext& ctx) const
  *  {
  *    SG::WriteDecorHandle<MyCont, float> h (m_key, ctx);
  *    for (const MyObj& o : *h) {  // Access the container.
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.cxx
index cdd88c845a488efac3c90f95c0c695e4e6861db0..4c45d79ceff27dc4834fcb85e19ddf8d59be9e96 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.cxx
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.cxx
@@ -41,7 +41,7 @@ StatusCode ReWriteData::initialize() {
    return StatusCode::SUCCESS;
 }
 //___________________________________________________________________________
-StatusCode ReWriteData::execute_r (const EventContext& ctx) const {
+StatusCode ReWriteData::execute (const EventContext& ctx) const {
    ATH_MSG_DEBUG("in execute()");
 
    if (!m_exampleHitKey.key().empty()) {
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.h
index 2d98b4f84f0216d2992955f56181ebca67db96ee..5a564c8162feb0e4b523584386f419eeff3f2482 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.h
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.h
@@ -32,7 +32,7 @@ public: // Constructor and Destructor
 public:
 /// Gaudi Service Interface method implementations:
    virtual StatusCode initialize() override;
-   virtual StatusCode execute_r (const EventContext& ctx) const override;
+   virtual StatusCode execute (const EventContext& ctx) const override;
    virtual StatusCode finalize() override;
 
 private:
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.cxx
index 446a26a5f3b3057c1ef8dceb1225844e6e2f96b4..0cff7e2dc641f1fc306d3768a5027acd596a344d 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.cxx
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.cxx
@@ -54,7 +54,7 @@ StatusCode ReadData::initialize() {
    return StatusCode::SUCCESS;
 }
 //___________________________________________________________________________
-StatusCode ReadData::execute_r (const EventContext& ctx) const {
+StatusCode ReadData::execute (const EventContext& ctx) const {
    ATH_MSG_DEBUG("in execute()");
 
    SG::ConstIterator<EventStreamInfo> esi1, esi2;
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.h
index 62bad7121f9091488bdbb94f21ce37c1b5a440c1..4c209285fa8571586ee6645253f59cab982aa5ef 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.h
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.h
@@ -34,7 +34,7 @@ public: // Constructor and Destructor
 public:
 /// Gaudi Service Interface method implementations:
    virtual StatusCode initialize() override;
-   virtual StatusCode execute_r (const EventContext& ctx) const override;
+   virtual StatusCode execute (const EventContext& ctx) const override;
    virtual StatusCode finalize() override;
 
 private:
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.cxx
index 85e08478ebc86dfaf6323947ad94b781744a264e..a28b1e16e362d1d6a67cbef012837e3cf09e1ecb 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.cxx
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.cxx
@@ -45,7 +45,7 @@ StatusCode WriteCond::initialize() {
    return StatusCode::SUCCESS;
 }
 //___________________________________________________________________________
-StatusCode WriteCond::execute_r (const EventContext& ctx) const {
+StatusCode WriteCond::execute (const EventContext& ctx) const {
    ATH_MSG_DEBUG("in execute()");
 
    SG::ReadHandle<ExampleHitContainer> hits (m_exampleHitKey, ctx);
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.h
index 813489ff99dac9069ce4121175c4de80b337e3b2..330b4fa343a8e6a7918e8d12d0f5b06f55d91e59 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.h
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.h
@@ -30,7 +30,7 @@ public: // Constructor and Destructor
 public:
 /// Gaudi Service Interface method implementations:
    virtual StatusCode initialize() override;
-   virtual StatusCode execute_r (const EventContext& ctx) const override;
+   virtual StatusCode execute (const EventContext& ctx) const override;
    virtual StatusCode stop() override;
 
 private:
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.cxx
index 014e904dd27b8084afdffa592c0fa1974e57dcfc..e06c58555536ef68aa7ae9a8f38d4cae2e50398a 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.cxx
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.cxx
@@ -32,7 +32,7 @@ StatusCode WriteData::initialize() {
    return StatusCode::SUCCESS;
 }
 //___________________________________________________________________________
-StatusCode WriteData::execute_r (const EventContext& ctx) const {
+StatusCode WriteData::execute (const EventContext& ctx) const {
    ATH_MSG_DEBUG("in execute()");
 
    int eventNumber = ctx.eventID().event_number();
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.h
index 03ccdcd069173bfad313ef50a38513571547d90e..0eedbdc1d1fa2f34e361a4598caa60c32c2e8afe 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.h
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.h
@@ -30,7 +30,7 @@ public: // Constructor and Destructor
 public:
 /// Gaudi Service Interface method implementations:
    virtual StatusCode initialize() override;
-   virtual StatusCode execute_r (const EventContext& ctx) const override;
+   virtual StatusCode execute (const EventContext& ctx) const override;
    virtual StatusCode finalize() override;
 
    SG::WriteHandleKey<ExampleHitContainer> m_exampleHitKey { this, "ExampleHitKey", "MyHits" };
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.cxx
index 4d55425c6c6f33b7d491a96b0daa49ee1ca87083..d51e4620a5f2b5dfec5be20316d8df506ce5e89a 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.cxx
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.cxx
@@ -50,7 +50,7 @@ StatusCode WriteTag::initialize() {
    return StatusCode::SUCCESS;
 }
 //___________________________________________________________________________
-StatusCode WriteTag::execute_r (const EventContext& ctx) const {
+StatusCode WriteTag::execute (const EventContext& ctx) const {
    ATH_MSG_DEBUG("in execute()");
 
    unsigned int eventNumber = ctx.eventID().event_number();
diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.h
index 7d7d1006a8f36aefc5b48678f3ea1932dc138c19..874f3f5124fbc1b5aeb54ed7ef9b883116eeb0c6 100755
--- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.h
+++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.h
@@ -33,7 +33,7 @@ public: // Constructor and Destructor
 public:
 /// Gaudi Service Interface method implementations:
    virtual StatusCode initialize() override;
-   virtual StatusCode execute_r (const EventContext& ctx) const override;
+   virtual StatusCode execute (const EventContext& ctx) const override;
    virtual StatusCode finalize() override;
 
 private:
diff --git a/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.cxx b/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.cxx
index a34750fb2167a47b6a75bda65eeef0c86afbe9ea..1f20118e7e8e236b0276d06be094eabddf09ca97 100644
--- a/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.cxx
+++ b/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.cxx
@@ -34,7 +34,7 @@ StatusCode MakeInputDataHeader::initialize() {
    return(StatusCode::SUCCESS);
 }
 //___________________________________________________________________________
-StatusCode MakeInputDataHeader::execute_r (const EventContext& ctx) const
+StatusCode MakeInputDataHeader::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<DataHeader> dh (m_streamName, ctx);
   ATH_CHECK( dh.alias (m_aliasName) );
diff --git a/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.h b/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.h
index a99cf8fc9bdb3677ae688ec3881b7cf9d3993a12..4fc503d7ac30eb890553599cced7c78d6d4fafe0 100644
--- a/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.h
+++ b/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.h
@@ -38,7 +38,7 @@ public:
    virtual ~MakeInputDataHeader();
    /// AthAlgorithm Interface method implementations:
    virtual StatusCode initialize() override;
-   virtual StatusCode execute_r(const EventContext& ctx) const override;
+   virtual StatusCode execute(const EventContext& ctx) const override;
    virtual StatusCode finalize() override;
 
 private:
diff --git a/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.cxx b/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.cxx
index 1085be4378ff911894aa09b54255cedf6d892a7f..81783c7e1cb8dcdbf6411ae32eaa732f495547fa 100644
--- a/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.cxx
+++ b/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.cxx
@@ -34,7 +34,7 @@ OnlineLumiCalibrationCondAlg::initialize()
 
 
 StatusCode
-OnlineLumiCalibrationCondAlg::execute_r (const EventContext& ctx) const
+OnlineLumiCalibrationCondAlg::execute (const EventContext& ctx) const
 {
   SG::ReadCondHandle<CondAttrListCollection> calibrationFolder
     (m_calibrationFolderName, ctx);
diff --git a/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.h b/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.h
index 4b3966d57342125e7b1db26e07a50893cb48b1f2..d267e68b5e2e56b7586026fdb7ce3c5faf87d86f 100644
--- a/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.h
+++ b/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.h
@@ -29,7 +29,7 @@ public:
 
 
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/Database/CoolLumiUtilities/test/OnlineLumiCalibrationCondAlg_test.cxx b/Database/CoolLumiUtilities/test/OnlineLumiCalibrationCondAlg_test.cxx
index d0ad5af704a72576fe9b83ac75adc83e03f6bb6d..3eaea94dc88902d47e7489eab7181d84c52a85f2 100644
--- a/Database/CoolLumiUtilities/test/OnlineLumiCalibrationCondAlg_test.cxx
+++ b/Database/CoolLumiUtilities/test/OnlineLumiCalibrationCondAlg_test.cxx
@@ -104,7 +104,7 @@ void test1 (ISvcLocator* svcloc)
   ServiceHandle<StoreGateSvc> conditionStore ("ConditionStore", "test");
   assert( conditionStore->record (std::move (cc1), "testcalib") );
 
-  assert( alg.execute_r (ctx).isSuccess() );
+  assert( alg.execute (ctx).isSuccess() );
 
   CondCont<OnlineLumiCalibrationCondData>* cc2 = nullptr;
   assert( conditionStore->retrieve (cc2, "OnlineLumiCalibrationCondData").isSuccess() );
diff --git a/DetectorDescription/IdDictParser/test/tid.cxx b/DetectorDescription/IdDictParser/test/tid.cxx
index 71a75efb57fad78d4d1fc7ebe71ceb33e22083b0..c810e16c3beac39e692b66e19f2e7852f2ef4458 100755
--- a/DetectorDescription/IdDictParser/test/tid.cxx
+++ b/DetectorDescription/IdDictParser/test/tid.cxx
@@ -97,7 +97,10 @@ int main (int argc, char* argv[])
  
 //  	    IdDictDictionary::bits32 b = dictionary->pack32 (id, 0, 6); 
 	Identifier packedB((Identifier::value_type)0);
-	dictionary->pack32 (id, 0, 6, packedB); 
+	if (dictionary->pack32 (id, 0, 6, packedB) != 0) {
+          std::cout << "error from pack32\n";
+          return 1;
+        }
  
         std::cout << "b=[" << packedB << "]" << std::endl; 
  
diff --git a/DetectorDescription/RegSelSvcTest/CMakeLists.txt b/DetectorDescription/RegSelSvcTest/CMakeLists.txt
index d71d783ae86c3623a61e2062451aef14b6716c78..8928aa2dea0b440aaa55f621a63db1cb5f1d7c7a 100644
--- a/DetectorDescription/RegSelSvcTest/CMakeLists.txt
+++ b/DetectorDescription/RegSelSvcTest/CMakeLists.txt
@@ -7,8 +7,6 @@ atlas_subdir( RegSelSvcTest )
 
 # Declare the package's dependencies:
 atlas_depends_on_subdirs( PUBLIC
-                          Control/CLIDSvc
-                          Control/SGTools
                           DetectorDescription/IRegionSelector
                           DetectorDescription/Identifier
                           GaudiKernel
@@ -27,11 +25,11 @@ atlas_depends_on_subdirs( PUBLIC
 atlas_add_library( RegSelSvcTestLib
                    NO_PUBLIC_HEADERS
                    src/*.cxx
-                   PRIVATE_LINK_LIBRARIES SGTools IRegionSelector Identifier GaudiKernel StoreGateLib SGtests AthenaBaseComps AthenaPoolUtilities RegSelLUT PathResolver TrigSteeringEvent )
+                   PRIVATE_LINK_LIBRARIES IRegionSelector Identifier GaudiKernel StoreGateLib SGtests AthenaBaseComps AthenaPoolUtilities RegSelLUT PathResolver TrigSteeringEvent )
 
 atlas_add_component( RegSelSvcTest
                      src/components/*.cxx
-                     LINK_LIBRARIES SGTools IRegionSelector Identifier GaudiKernel AthenaBaseComps StoreGateLib SGtests AthenaPoolUtilities RegSelLUT PathResolver TrigSteeringEvent RegionSelectorLib RegSelSvcTestLib )
+                     LINK_LIBRARIES IRegionSelector Identifier GaudiKernel AthenaBaseComps StoreGateLib SGtests AthenaPoolUtilities RegSelLUT PathResolver TrigSteeringEvent RegionSelectorLib RegSelSvcTestLib )
 
 atlas_add_test( RegSel_dump SCRIPT test/test_RegSel_dump.sh
 		PROPERTIES TIMEOUT 1200
diff --git a/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.cxx b/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.cxx
index 78301af97fd7a3f347591f4fb4065dc56a497312..c483744ceddba0dc00f690bbac7ec0346650e4e2 100644
--- a/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.cxx
+++ b/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.cxx
@@ -29,7 +29,7 @@ StatusCode RegSelTestAlg::finalize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode RegSelTestAlg::execute_r(const EventContext& /*context*/) const {  
+StatusCode RegSelTestAlg::execute(const EventContext& /*context*/) const {  
   ATH_MSG_DEBUG ("Executing " << name() << "...");
   if ( m_mt ) 
     CHECK( mt() );
diff --git a/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.h b/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.h
index 724b2a25731444ef1d822e195a0244d790370505..6ff141f9dffad3bc9318cd6ac97888b8241655ce 100644
--- a/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.h
+++ b/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.h
@@ -25,7 +25,7 @@ class RegSelTestAlg
 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r(const EventContext& context) const override;
+  virtual StatusCode  execute(const EventContext& context) const override;
   virtual StatusCode  finalize() override;
   StatusCode dump() const;
   StatusCode mt() const;
diff --git a/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.cxx b/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.cxx
index 4d712dc83cca66a254b9f511afed70444d0cb885..1f796ef516ac30fa6936615ceac208ad61e2b99c 100644
--- a/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.cxx
+++ b/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.cxx
@@ -57,7 +57,7 @@ private:
 
 
 
-StatusCode ROBDataProviderMTTest::execute_r( const EventContext& context ) const
+StatusCode ROBDataProviderMTTest::execute( const EventContext& context ) const
 {  
   // will be asking for many ROBs from the list and check if all of them come from the same physical event
   const RawEvent* ev = m_robDataProvider->getEvent( context );
diff --git a/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.h b/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.h
index 12468b2d71dd1c04423f6261608c32fb9008d202..853641e4c39c333abc16fc3f9690174bf30c944f 100644
--- a/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.h
+++ b/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.h
@@ -28,7 +28,7 @@ class ROBDataProviderMTTest
   //ROBDataProviderMTTest &operator=(const ROBDataProviderMTTest &alg); 
 
   StatusCode  initialize() override;
-  StatusCode  execute_r(const EventContext& context) const override;
+  StatusCode  execute(const EventContext& context) const override;
   StatusCode  finalize() override;
  
  private: 
diff --git a/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.cxx b/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.cxx
index cdc4b67c9f961d0a824233e0ff42ba0484e4f5bf..9ad9029219a1501730a4441811651b1387c45c52 100644
--- a/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.cxx
+++ b/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.cxx
@@ -59,7 +59,7 @@ namespace xAODMaker {
       return StatusCode::SUCCESS;
    }
 
-   StatusCode EventInfoCnvAlg::execute_r (const EventContext& ctx) const {
+   StatusCode EventInfoCnvAlg::execute (const EventContext& ctx) const {
 
       // Check if anything needs to be done:
       // FIXME: Job configuration should be fixed so we don't need this test.
@@ -158,7 +158,7 @@ namespace xAODMaker {
        ATH_MSG_DEBUG( "Preparing xAOD::EventInfo object in beginRun()" );
        
        // Run the conversion using the execute function:
-       CHECK( execute_r (Gaudi::Hive::currentContext()) );
+       CHECK( execute (Gaudi::Hive::currentContext()) );
      }
 
       // Return gracefully:
diff --git a/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.h b/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.h
index ba1887428768786d846e3f0bfde690e63c455289..40781a4634a511151bf2557a5a337d7cc5d731be 100644
--- a/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.h
+++ b/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.h
@@ -43,7 +43,7 @@ namespace xAODMaker {
       /// Function initialising the algorithm
       virtual StatusCode initialize() override;
       /// Function executing the algorithm
-      virtual StatusCode execute_r (const EventContext& ctx) const override;
+      virtual StatusCode execute (const EventContext& ctx) const override;
 
       /// Function executed at the beginning of the job, once the first event
       /// from the input file is already open
diff --git a/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/CompositeParticleAuxContainer_v1.h b/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/CompositeParticleAuxContainer_v1.h
index 96362abdfa144f5838a0e691cbc93cf0090d3926..3f5ecae3d5abed6f15cd028ccd253738b05601e1 100644
--- a/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/CompositeParticleAuxContainer_v1.h
+++ b/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/CompositeParticleAuxContainer_v1.h
@@ -1,7 +1,7 @@
 // Dear emacs, this is -*- c++ -*-
 
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 // $Id: CompositeParticleAuxContainer_v1.h 677235 2015-06-22 16:08:20Z kkoeneke $
@@ -35,7 +35,7 @@ namespace xAOD {
     /// Default constructor
     CompositeParticleAuxContainer_v1();
     /// Destructor
-    ~CompositeParticleAuxContainer_v1() {}
+    ~CompositeParticleAuxContainer_v1() = default;
 
 
 
diff --git a/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/ParticleAuxContainer_v1.h b/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/ParticleAuxContainer_v1.h
index b6b50707a626767e2615fee3035f8fb402ebe523..23c0f44b06a2fca7a4a0711d565143dbdb2a534b 100644
--- a/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/ParticleAuxContainer_v1.h
+++ b/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/ParticleAuxContainer_v1.h
@@ -1,7 +1,7 @@
 // Dear emacs, this is -*- c++ -*-
 
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 // $Id: ParticleAuxContainer_v1.h 637086 2014-12-19 16:02:19Z kkoeneke $
@@ -34,7 +34,7 @@ namespace xAOD {
     /// Default constructor
     ParticleAuxContainer_v1();
     /// Destructor
-    ~ParticleAuxContainer_v1() {}
+    ~ParticleAuxContainer_v1() = default;
 
 
 
diff --git a/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.cxx b/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.cxx
index 6fe5bd6b21169b0baa103a21deff5812dcf32f39..1e8ed9c0126c5ca8ba9eb48530f1911142305358 100644
--- a/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.cxx
+++ b/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.cxx
@@ -85,7 +85,7 @@ namespace xAODMaker {
     }
     
     
-    StatusCode xAODTruthCnvAlg::execute_r (const EventContext& ctx) const {
+    StatusCode xAODTruthCnvAlg::execute (const EventContext& ctx) const {
         
         SG::WriteHandle<xAODTruthParticleLinkVector> truthLinkVec(m_truthLinkContainerKey, ctx);
 	ATH_CHECK(truthLinkVec.record(std::make_unique<xAODTruthParticleLinkVector>()));
diff --git a/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.h b/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.h
index 10b3fb5c02b7864a1c93fcc6db47e6a5d3f66bad..dcdccf5d2bb25e00a7f3cb33ad4e401a8750d4ac 100644
--- a/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.h
+++ b/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.h
@@ -53,7 +53,7 @@ namespace xAODMaker {
     /// Function initialising the algorithm
     virtual StatusCode initialize() override;
     /// Function executing the algorithm
-    virtual StatusCode execute_r (const EventContext& ctx) const override;
+    virtual StatusCode execute (const EventContext& ctx) const override;
 
 
   private:
diff --git a/ForwardDetectors/LUCID/LUCID_DigiTools/LUCID_DigiTools/LUCID_DigiSettings.h b/ForwardDetectors/LUCID/LUCID_DigiTools/LUCID_DigiTools/LUCID_DigiSettings.h
index b217134a125279b3aaff0f83b84b27e7bac407a7..fcc929838aa5ed7044fbcb7e23c04700718028a3 100644
--- a/ForwardDetectors/LUCID/LUCID_DigiTools/LUCID_DigiTools/LUCID_DigiSettings.h
+++ b/ForwardDetectors/LUCID/LUCID_DigiTools/LUCID_DigiTools/LUCID_DigiSettings.h
@@ -27,7 +27,7 @@ class LUCID_DigiSettings {
   double GetDigiParDouble(std::string);
   int    GetDigiParInt   (std::string);
   
-  void   OverwriteDigiParProperties(Algorithm*);
+  void   OverwriteDigiParProperties(Gaudi::Algorithm*);
   void   OverwriteDigiParValues();
   
   void Print() const;
diff --git a/ForwardDetectors/LUCID/LUCID_DigiTools/src/LUCID_DigiSettings.cxx b/ForwardDetectors/LUCID/LUCID_DigiTools/src/LUCID_DigiSettings.cxx
index 7085cc2676a40b3e4429650ae8ac9a2cb4ab63ee..37fe7480ba4c028eb40998f8bb1229448115eca9 100644
--- a/ForwardDetectors/LUCID/LUCID_DigiTools/src/LUCID_DigiSettings.cxx
+++ b/ForwardDetectors/LUCID/LUCID_DigiTools/src/LUCID_DigiSettings.cxx
@@ -45,7 +45,7 @@ void LUCID_DigiSettings::SetDefaultValues() {
   m_tdcFedNoiseFactor = 0.8;
 }
 
-void LUCID_DigiSettings::OverwriteDigiParProperties(Algorithm* alg) {
+void LUCID_DigiSettings::OverwriteDigiParProperties(Gaudi::Algorithm* alg) {
   
   std::map <std::string, parDouble>::iterator doubleMapIt  = m_doubleMap.begin();
   std::map <std::string, parInt>::iterator    intMapIt     = m_intMap.begin();
diff --git a/Generators/GenAnalysisTools/TruthHelper/TruthHelper/GenIMCselector.h b/Generators/GenAnalysisTools/TruthHelper/TruthHelper/GenIMCselector.h
index 50b81a3bd47856ece3fdcb270bf80c85739b4722..cd2e7f1edad5bd43356ee1434956cbb9b137a3e2 100644
--- a/Generators/GenAnalysisTools/TruthHelper/TruthHelper/GenIMCselector.h
+++ b/Generators/GenAnalysisTools/TruthHelper/TruthHelper/GenIMCselector.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRUTHHELPER_GENIMCSELECTOR_H
@@ -17,7 +17,7 @@ namespace TruthHelper {
   public:
 
     // Virtual destructor to allow inheritance
-    virtual ~GenIMCselector() { }
+    virtual ~GenIMCselector() = default;
 
     // Allow selector objects to be copied (to be implemented).
     virtual GenIMCselector* create() const = 0;
diff --git a/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.cxx b/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.cxx
index 9d8a72ff20bed2c2c18768c200f7a797f2b52c16..45ff6f53daab16eaf0f3abfa675fbe2ca6908249 100644
--- a/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.cxx
+++ b/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.cxx
@@ -42,9 +42,9 @@ StatusCode MTCalibPebHypoAlg::finalize() {
 }
 
 // =============================================================================
-// Implementation of AthReentrantAlgorithm::execute_r
+// Implementation of AthReentrantAlgorithm::execute
 // =============================================================================
-StatusCode MTCalibPebHypoAlg::execute_r(const EventContext& eventContext) const {
+StatusCode MTCalibPebHypoAlg::execute(const EventContext& eventContext) const {
   ATH_MSG_DEBUG("Executing " << name());
 
   // New output
diff --git a/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.h b/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.h
index 81cf142d5455628ba172654025826b90d53c0a17..af8791804762b6eb53d15aa5c92729cfc8a0c0e8 100644
--- a/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.h
+++ b/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.h
@@ -22,7 +22,7 @@ public:
   // ------------------------- AthReentrantAlgorithm methods -------------------
   virtual StatusCode initialize() override;
   virtual StatusCode finalize() override;
-  virtual StatusCode execute_r(const EventContext& eventContext) const override;
+  virtual StatusCode execute(const EventContext& eventContext) const override;
 private:
   ToolHandleArray<MTCalibPebHypoTool> m_hypoTools {this, "HypoTools", {}, "Tools to perform selection"};
 };
diff --git a/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.cxx b/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.cxx
index a7cee61fc80e18f282a8d26c518e300796cd89b7..bdd0ef2c8497342d9ede62875f5e1d63a102f025 100644
--- a/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.cxx
+++ b/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.cxx
@@ -27,7 +27,7 @@ StatusCode InDet::InDetBeamSpotReader::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode InDet::InDetBeamSpotReader::execute_r(const EventContext& ctx) const {
+StatusCode InDet::InDetBeamSpotReader::execute(const EventContext& ctx) const {
   ATH_MSG_DEBUG( "in execute()");
 
   //get the set of 
diff --git a/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.h b/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.h
index 3be3e5f167a2051514311fca8c3499e139e79326..8533e0c824744c74b09df77476c8d93de6858144 100644
--- a/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.h
+++ b/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.h
@@ -27,7 +27,7 @@ namespace InDet {
     //Standard constructor and methods
     InDetBeamSpotReader  (const std::string& name, ISvcLocator* pSvcLocator);
     StatusCode initialize() override;
-    StatusCode execute_r(const EventContext& ctx) const override;
+    StatusCode execute(const EventContext& ctx) const override;
     StatusCode finalize() override;
 
 
diff --git a/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.cxx b/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.cxx
index 69ed0bb97d540c1dbd12942b354c4b4029874c26..16ca558d36b213bfaaebda72b2b5fb4a5a2d3ac1 100644
--- a/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.cxx
+++ b/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.cxx
@@ -151,7 +151,7 @@ StatusCode SpecialPixelMapCondAlg::initialize()
     return StatusCode::SUCCESS;
 }
 
-StatusCode SpecialPixelMapCondAlg::execute_r (const EventContext& ctx) const
+StatusCode SpecialPixelMapCondAlg::execute (const EventContext& ctx) const
 {
     ATH_MSG_DEBUG("Entering SpecialPixelMapCondAlg");
     const std::array<const SG::ReadCondHandleKey<CondAttrListCollection>*, s_max> condarray{{ &m_ConAttrList1, &m_ConAttrList2, &m_ConAttrList3, &m_ConAttrList4 }};
diff --git a/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.h b/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.h
index 57b77ee1dfd9da0780a99ddd3cb63b7bfcda78b8..02be8f33b188ae5768873de8540226be2fd140a2 100644
--- a/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.h
+++ b/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.h
@@ -23,7 +23,7 @@ class SpecialPixelMapCondAlg: public AthReentrantAlgorithm {
   ~SpecialPixelMapCondAlg();
   
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r (const EventContext&) const override;
+  virtual StatusCode execute (const EventContext&) const override;
 
 
 private:
diff --git a/InnerDetector/InDetDetDescr/PixelCabling/run/dumpCabling_jobOptions.py b/InnerDetector/InDetDetDescr/PixelCabling/run/dumpCabling_jobOptions.py
index 9dbdab7fea11985258aee5ebe892225cf92d524f..99a94377c32969407c9408309f4750d21b0f5748 100644
--- a/InnerDetector/InDetDetDescr/PixelCabling/run/dumpCabling_jobOptions.py
+++ b/InnerDetector/InDetDetDescr/PixelCabling/run/dumpCabling_jobOptions.py
@@ -4,8 +4,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
 from AthenaCommon.GlobalFlags import globalflags
 globalflags.DataSource = 'data'
 
diff --git a/InnerDetector/InDetDetDescr/PixelCabling/run/readCabling_jobOptions.py b/InnerDetector/InDetDetDescr/PixelCabling/run/readCabling_jobOptions.py
index 3c256dfb85bc8db7c34227beac475ce1f94f88f5..51280c9fe8f4f4c4747d2b32ac07737958658d18 100644
--- a/InnerDetector/InDetDetDescr/PixelCabling/run/readCabling_jobOptions.py
+++ b/InnerDetector/InDetDetDescr/PixelCabling/run/readCabling_jobOptions.py
@@ -4,8 +4,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
 from AthenaCommon.GlobalFlags import globalflags
 globalflags.DataSource = 'data'
 
diff --git a/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.cxx b/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.cxx
index ef471a0cd7787c66c92e092bf53ba05d4428af6a..fd9401c1492c9f7be504e265ccbb1bd3c5e72da9 100644
--- a/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.cxx
+++ b/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.cxx
@@ -327,7 +327,7 @@ const std::vector<float>* SCT_DistortionsTool::readDistortions(int RegionID, int
 }
 
 
-bool SCT_DistortionsTool::loadData() const
+bool SCT_DistortionsTool::loadData()
 {
 
   int temp(0);
@@ -528,7 +528,7 @@ int SCT_DistortionsTool::identifyRegion(IdentifierHash id) const
   ATH_MSG_DEBUG( "Identifying module common profile region: " ); 
   //int REGION=0;//1=J1,2=J2,3=UK,4=USA,5=Scand
   //Identifier::value_type ID = id.get_compact();
-  std::map<int,int>::iterator it;
+  std::map<int,int>::const_iterator it;
   
   int ID = id;
   it = m_moduleSites.find(ID);
diff --git a/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.h b/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.h
index 4817b5b5959a4b2e12f86b9de955c4d3e78c0b3e..00fbde4aefef2e4a9c686fa42e997d9f12bcbd0f 100644
--- a/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.h
+++ b/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.h
@@ -60,7 +60,7 @@ class SCT_DistortionsTool : public AthAlgTool, virtual public ISCT_ModuleDistort
 
     float m_distortionsScale;
 
-    mutable std::map<int,int> m_moduleSites;
+    std::map<int,int> m_moduleSites;
     
     std::vector<float>* m_dataJap1_S0;
     std::vector<float>* m_dataJap2_S0;
@@ -74,7 +74,7 @@ class SCT_DistortionsTool : public AthAlgTool, virtual public ISCT_ModuleDistort
     std::vector<float>* m_dataUSA_S1;
     std::vector<float>* m_dataScand_S1;
     
-    bool loadData() const;
+    bool loadData();
 
 };
 
diff --git a/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.cxx b/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.cxx
index 33ea2736b868acbefd84211b6e98e008af722788..6b21e1775d2a432306931dce59b8efdf4e3b0cc5 100644
--- a/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.cxx
+++ b/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.cxx
@@ -98,49 +98,49 @@
 
         mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_0_20V.root")); 
 
-        fluence_layers.push_back(1e-10);
+        m_fluence_layers.push_back(1e-10);
 
     } else if (m_fluence == 2) {
 
         mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_1e14_20V.root"));
 
-        fluence_layers.push_back(1e14);
+        m_fluence_layers.push_back(1e14);
 
     } else if (m_fluence == 3) {
 
         mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_2e14_30V.root"));
 
-        fluence_layers.push_back(2e14);
+        m_fluence_layers.push_back(2e14);
 
     } else if (m_fluence == 4) {
 
         mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_5e14_40V.root")); 
 
-        fluence_layers.push_back(5e14);
+        m_fluence_layers.push_back(5e14);
 
     } else if (m_fluence == 5) {
 
         mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_1e15_50V.root"));
 
-        fluence_layers.push_back(1e15); 
+        m_fluence_layers.push_back(1e15); 
 
     } else if (m_fluence == 6) {
 
         mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_5e15_160V.root"));
 
-        fluence_layers.push_back(5e15);
+        m_fluence_layers.push_back(5e15);
 
     } else if (m_fluence == 7) {
 
         mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_6e15_190V_new.root"));       
 
-        fluence_layers.push_back(6e15);
+        m_fluence_layers.push_back(6e15);
 
     } else if (m_fluence == 8) {
 
         mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_1e16_260V_new.root"));
 
-        fluence_layers.push_back(1e16);
+        m_fluence_layers.push_back(1e16);
     }
 
     // *****************************
@@ -172,9 +172,9 @@
         }
         //ramoPotentialMap.push_back(ramoPotentialMap_hold);
         ramoPotentialMap[Layer] = ramoPotentialMap_hold;
-        fluence_layersMaps[Layer] = fluence_layers.at(i);
+        m_fluence_layersMaps[Layer] = m_fluence_layers.at(i);
 
-        ATH_MSG_INFO("Using fluence " << fluence_layers.at(i));
+        ATH_MSG_INFO("Using fluence " << m_fluence_layers.at(i));
 
         //Now setup the E-field.
         TH2F * eFieldMap_hold;
@@ -270,7 +270,7 @@ StatusCode SensorSim3DTool::induceCharge(const TimedHitPtr < SiHit > & phit, SiC
 
     //Calculate trapping times based on fluence (already includes check for fluence=0)
     if (m_doRadDamage) {
-                std::pair < double, double > trappingTimes = m_radDamageUtil->getTrappingTimes(fluence_layers.at(0));   //0 = IBL
+                std::pair < double, double > trappingTimes = m_radDamageUtil->getTrappingTimes(m_fluence_layers.at(0));   //0 = IBL
                 m_trappingTimeElectrons = trappingTimes.first;
                 m_trappingTimeHoles = trappingTimes.second;
             }
@@ -286,7 +286,7 @@ StatusCode SensorSim3DTool::induceCharge(const TimedHitPtr < SiHit > & phit, SiC
     double ncharges = initialConditions[6];
     double iTotalLength = initialConditions[7];
     ncharges = 50;
-    temperature = 300; // K 
+    m_temperature = 300; // K 
 
     ATH_MSG_VERBOSE("Applying 3D sensor simulation.");
     double sensorThickness = Module.design().thickness();
@@ -401,7 +401,7 @@ StatusCode SensorSim3DTool::induceCharge(const TimedHitPtr < SiHit > & phit, SiC
                         double phiRand = CLHEP::RandGaussZiggurat::shoot(m_rndmEngine);
 
                         //Apply diffusion. rdif is teh max. diffusion
-                        double Dt = getMobility(efield, isHole) * (0.024) * std::min(driftTime, timeToElectrode) * temperature / 273.;
+                        double Dt = getMobility(efield, isHole) * (0.024) * std::min(driftTime, timeToElectrode) * m_temperature / 273.;
                         double rdif = sqrt(Dt) / 1000; //in mm
                         double xposDiff = x_pix + rdif * phiRand;
                         double etaRand = CLHEP::RandGaussZiggurat::shoot(m_rndmEngine);
@@ -639,14 +639,14 @@ double SensorSim3DTool::getMobility(double electricField, bool isHoleBit) {
     //These parameterizations come from C. Jacoboni et al., Solid‐State Electronics 20 (1977) 77‐89. (see also https://cds.cern.ch/record/684187/files/indet-2001-004.pdf).
 
     if (!isHoleBit) {
-        vsat = 15.3 * pow(temperature, -0.87); // mm/ns
-        ecrit = 1.01E-7 * pow(temperature, 1.55); // MV/mm
-        beta = 2.57E-2 * pow(temperature, 0.66);
+        vsat = 15.3 * pow(m_temperature, -0.87); // mm/ns
+        ecrit = 1.01E-7 * pow(m_temperature, 1.55); // MV/mm
+        beta = 2.57E-2 * pow(m_temperature, 0.66);
     }
     if (isHoleBit) {
-        vsat = 1.62 * pow(temperature, -0.52); // mm/ns
-        ecrit = 1.24E-7 * pow(temperature, 1.68); // MV/mm
-        beta = 0.46 * pow(temperature, 0.17);
+        vsat = 1.62 * pow(m_temperature, -0.52); // mm/ns
+        ecrit = 1.24E-7 * pow(m_temperature, 1.68); // MV/mm
+        beta = 0.46 * pow(m_temperature, 0.17);
     }
 
     double mobility = (vsat / ecrit) / pow(1 + pow((electricField / ecrit), beta), (1 / beta));
diff --git a/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.h b/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.h
index 890e1f94b2a3d640f820121e1c4ea2f5dd079093..ae0a260dcbbfe6bf6ac6988bcc64481eabaab868 100644
--- a/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.h
+++ b/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.h
@@ -70,14 +70,14 @@ class SensorSim3DTool : public SensorSimTool {
     int    m_numberOfCharges;  
     double m_diffusionConstant;
 
-    double temperature;
+    double m_temperature;
 
     bool m_doRadDamage;
     bool m_doChunkCorrection;
     double m_fluence; //eventually, this should be pulled from the conditions.
 
-    std::vector<double> fluence_layers;
-    std::map<std::pair<int, int>, double> fluence_layersMaps;
+    std::vector<double> m_fluence_layers;
+    std::map<std::pair<int, int>, double> m_fluence_layersMaps;
     double m_trappingTimeElectrons;
     double m_trappingTimeHoles;
     ServiceHandle<IChargeCollProbSvc> m_chargeCollSvc;
diff --git a/InnerDetector/InDetEventCnv/PixelRawDataByteStreamCnv/share/Pixel_main.py b/InnerDetector/InDetEventCnv/PixelRawDataByteStreamCnv/share/Pixel_main.py
index 0d8ee8434c38d50b862672c1c63a1ad1406af9ee..3fd5d4d3c62da6f999ec1f06b393dbc373b4ad5c 100644
--- a/InnerDetector/InDetEventCnv/PixelRawDataByteStreamCnv/share/Pixel_main.py
+++ b/InnerDetector/InDetEventCnv/PixelRawDataByteStreamCnv/share/Pixel_main.py
@@ -115,8 +115,7 @@ ServiceMgr.StoreGateSvc.Dump            = False
 # get stack dump
 # ------------------------------------------------------------
 
-gbl.AthenaServices.SetFatalHandler(438)
-
+ServiceMgr.CoreDumpSvc.FatalHandler = 438
 
 # ------------------------------------------------------------
 # Use auditors
diff --git a/InnerDetector/InDetExample/InDetRecExample/share/InDetRec_all.py b/InnerDetector/InDetExample/InDetRecExample/share/InDetRec_all.py
index 43fa4afd36414a6ae03adbb6d42d88393b2772dc..95ab8547b5811fef0084ddf4e2824e31b67283e9 100755
--- a/InnerDetector/InDetExample/InDetRecExample/share/InDetRec_all.py
+++ b/InnerDetector/InDetExample/InDetRecExample/share/InDetRec_all.py
@@ -138,7 +138,7 @@ ServiceMgr.StoreGateSvc.Dump            = False
 # get stack dump
 # ------------------------------------------------------------
 
-gbl.AthenaServices.SetFatalHandler(438)
+ServiceMgr.CoreDumpSvc.FatalHandler = 438
 
 #--------------------------------------------------------------
 # run JiveXML for Atlantis event display
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptionsNewSteering.py b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptionsNewSteering.py
index 33de8b9bc158c4e0decb40c03788aac2d2f5dfca..def20c510f7028515432f22f919da5886fcb09d2 100755
--- a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptionsNewSteering.py
+++ b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptionsNewSteering.py
@@ -364,8 +364,8 @@ ServiceMgr.StoreGateSvc.Dump            = False
 # get stack dump
 # ------------------------------------------------------------
 
-gbl.AthenaServices.SetFatalHandler(438)
-         
+ServiceMgr.CoreDumpSvc.FatalHandler = 438
+
 if doAuditors:
  # load AuditorSvc
  theAuditorSvc = AuditorSvc()
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample.py b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample.py
index 844fce15c950a380d22fb200fa95896a39fc5b7e..370a1ac7b899c97c769f0bea851507161dbe66da 100755
--- a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample.py
+++ b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample.py
@@ -363,7 +363,7 @@ ServiceMgr.StoreGateSvc.Dump            = False
 # get stack dump
 # ------------------------------------------------------------
 
-gbl.AthenaServices.SetFatalHandler(438)
+ServiceMgr.CoreDumpSvc.FatalHandler = 438
          
 if doAuditors:
  # load AuditorSvc
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_backTracking.py b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_backTracking.py
index 95ec2cb520f2bdd57bc8e13b33618d2085ba97ca..44aa7c83f0d16b75e2f99fda6dde2d555d6af07f 100755
--- a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_backTracking.py
+++ b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_backTracking.py
@@ -316,8 +316,8 @@ ServiceMgr.StoreGateSvc.Dump            = False
 # get stack dump
 # ------------------------------------------------------------
 
-gbl.AthenaServices.SetFatalHandler(438)
-         
+ServiceMgr.CoreDumpSvc.FatalHandler = 438
+
 if doAuditors:
  # load AuditorSvc
  theAuditorSvc = AuditorSvc()
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_doReadBS.py b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_doReadBS.py
index 0ec9c1afe9f7d0369e9ee739ebd9d6b96eab4582..b44c7b1593a5b0255a5b25e732aa49ca1aef6fee 100755
--- a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_doReadBS.py
+++ b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_doReadBS.py
@@ -366,8 +366,8 @@ ServiceMgr.StoreGateSvc.Dump            = False
 # get stack dump
 # ------------------------------------------------------------
 
-gbl.AthenaServices.SetFatalHandler(438)
-         
+ServiceMgr.CoreDumpSvc.FatalHandler = 438
+
 if doAuditors:
  # load AuditorSvc
  theAuditorSvc = AuditorSvc()
diff --git a/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/InDetCaloClusterROISelector/CaloClusterROI_Selector.h b/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/InDetCaloClusterROISelector/CaloClusterROI_Selector.h
index 312c5d863fbf39e78769860dcd9f35abcd79a0fa..d737c2760af0179732daa09c46bdf59b65ae4828 100755
--- a/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/InDetCaloClusterROISelector/CaloClusterROI_Selector.h
+++ b/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/InDetCaloClusterROISelector/CaloClusterROI_Selector.h
@@ -44,7 +44,7 @@ class CaloClusterROI_Selector : public AthReentrantAlgorithm
   /** @brief finalize method*/
   StatusCode finalize();
   /** @brief execute method*/
-  StatusCode execute_r(const EventContext& ctx) const;
+  StatusCode execute(const EventContext& ctx) const;
 
  private:
 
diff --git a/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/src/CaloClusterROI_Selector.cxx b/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/src/CaloClusterROI_Selector.cxx
index ded679b271a645e321085a7296cca11673bbedcb..6f77152ac95dfb5412e4aaa28ddd33d0a16ff06e 100755
--- a/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/src/CaloClusterROI_Selector.cxx
+++ b/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/src/CaloClusterROI_Selector.cxx
@@ -77,7 +77,7 @@ StatusCode InDet::CaloClusterROI_Selector::finalize()
 }
 
 // ======================================================================
-StatusCode InDet::CaloClusterROI_Selector::execute_r(const EventContext& ctx) const
+StatusCode InDet::CaloClusterROI_Selector::execute(const EventContext& ctx) const
 {
     //
     // athena execute method
diff --git a/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/InDetExtensionProcessor/InDetExtensionProcessor.h b/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/InDetExtensionProcessor/InDetExtensionProcessor.h
index 3e525a67b8e51768a617a7b55d86e3822304cf23..9a08f71ead06998ae915d824be9a47ccb0ac1fde 100755
--- a/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/InDetExtensionProcessor/InDetExtensionProcessor.h
+++ b/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/InDetExtensionProcessor/InDetExtensionProcessor.h
@@ -40,7 +40,7 @@ public:
   InDetExtensionProcessor(const std::string &name,ISvcLocator *pSvcLocator);
 
   virtual StatusCode initialize();
-  virtual StatusCode execute_r(const EventContext& ctx) const;
+  virtual StatusCode execute(const EventContext& ctx) const;
   virtual StatusCode finalize();
 
 private:
diff --git a/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/src/InDetExtensionProcessor.cxx b/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/src/InDetExtensionProcessor.cxx
index ad32cae93dd9c4ffc83695af36c5614c81472c68..97414860ef42ca725d2eb0ac45745d7f8c472971 100755
--- a/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/src/InDetExtensionProcessor.cxx
+++ b/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/src/InDetExtensionProcessor.cxx
@@ -115,7 +115,7 @@ StatusCode InDet::InDetExtensionProcessor::initialize()
 //==================================================================================================
 
 // Execute method:
-StatusCode InDet::InDetExtensionProcessor::execute_r(const EventContext& ctx) const
+StatusCode InDet::InDetExtensionProcessor::execute(const EventContext& ctx) const
 {
   // process the extensions
   SG::ReadHandle<TrackCollection>   tracks(m_trackName, ctx);
diff --git a/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.cxx b/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.cxx
index 2e5411fead0b0209498487467b6e13d404a4bf2f..ed8be743ba739bcfc13116e33a498b7161250dcc 100644
--- a/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.cxx
+++ b/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.cxx
@@ -55,7 +55,7 @@ namespace InDet{
 
     CacheCreator::~CacheCreator() {}
 
-    StatusCode CacheCreator::execute_r (const EventContext& ctx) const
+    StatusCode CacheCreator::execute (const EventContext& ctx) const
     {
 
         if(!m_disableTRT) ATH_CHECK(CreateContainer(m_rioContainerCacheKey, m_pTRTHelper->straw_layer_hash_max(), ctx));
diff --git a/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.h b/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.h
index 1ed4085d859a984cd51ccdcdf0244426f477442f..2f47911654d8f0ead15322f5088edfac5afaaa18 100644
--- a/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.h
+++ b/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.h
@@ -37,7 +37,7 @@ namespace InDet{
         CacheCreator(const std::string &name,ISvcLocator *pSvcLocator);
         virtual ~CacheCreator()  ;
         virtual StatusCode initialize () override;
-        virtual StatusCode execute_r (const EventContext& ctx) const override;
+        virtual StatusCode execute (const EventContext& ctx) const override;
         //No need for finalize
     protected:
         const TRT_ID* m_pTRTHelper;
diff --git a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/SiSpacePointFormation/SiTrackerSpacePointFinder.h b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/SiSpacePointFormation/SiTrackerSpacePointFinder.h
index 1ebf0e96642bd386d3bf18d9b84bcd0857e2ed9a..0f89649a0022dcf02c921fac7ea0902b4d6b0080 100755
--- a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/SiSpacePointFormation/SiTrackerSpacePointFinder.h
+++ b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/SiSpacePointFormation/SiTrackerSpacePointFinder.h
@@ -95,7 +95,7 @@ namespace InDet {
     
     StatusCode initialize() override;
     
-    StatusCode execute_r (const EventContext& ctx) const override;
+    StatusCode execute (const EventContext& ctx) const override;
 
     StatusCode finalize() override;
 
diff --git a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx
index 0230f094c480aa21039e853ac7b84b08cb49d6ad..6cd6c38df275455c2bfd73ecbfeb00671d283cfe 100755
--- a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx
+++ b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx
@@ -164,7 +164,7 @@ StatusCode SiTrackerSpacePointFinder::initialize()
 
 //-------------------------------------------------------------------------
 
-StatusCode SiTrackerSpacePointFinder::execute_r (const EventContext& ctx) const
+StatusCode SiTrackerSpacePointFinder::execute (const EventContext& ctx) const
 {
 
 
diff --git a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/CMakeLists.txt b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/CMakeLists.txt
index 2a7e9db21e70ab80991e718a2f7452f08210c182..59e9895cbc2d335b0305d06f9b4cb6b7ceb86af3 100644
--- a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/CMakeLists.txt
+++ b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/CMakeLists.txt
@@ -9,7 +9,7 @@ atlas_subdir( TRT_SeededTrackFinder )
 atlas_depends_on_subdirs( PUBLIC
                           Control/AthenaBaseComps
                           GaudiKernel
-                          InnerDetector/InDetConditions/InDetBeamSpotService
+                          InnerDetector/InDetConditions/BeamSpotConditionsData
                           InnerDetector/InDetRecTools/InDetRecToolInterfaces
                           Tracking/TrkEvent/TrkSegment
                           Tracking/TrkEvent/TrkTrack
diff --git a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/TRT_SeededTrackFinder/TRT_SeededTrackFinder.h b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/TRT_SeededTrackFinder/TRT_SeededTrackFinder.h
index 1452ffd95f62eea5e146717e5bf8f72e53c32a42..fb156428679ce8f99fc94f01d00834680e9d81a5 100755
--- a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/TRT_SeededTrackFinder/TRT_SeededTrackFinder.h
+++ b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/TRT_SeededTrackFinder/TRT_SeededTrackFinder.h
@@ -32,7 +32,7 @@
 #include "InDetRecToolInterfaces/ITRT_TrackExtensionTool.h"
 
 #include "TrkExInterfaces/IExtrapolator.h"
-#include "InDetBeamSpotService/IBeamCondSvc.h"
+#include "BeamSpotConditionsData/BeamSpotData.h"
 #include "InDetRecToolInterfaces/ITRT_SeededTrackFinder.h" 
 
 
@@ -100,7 +100,7 @@ namespace InDet {
 
 
       ToolHandle<Trk::IExtrapolator>   m_extrapolator; //!< the extrapoator
-      ServiceHandle<IBeamCondSvc>      m_iBeamCondSvc; //!< pointer to the beam condition service
+      SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" };
       bool   m_SiExtensionCuts; //!< enable cuts after Si segment finding
       double m_minPt;           //!< minimal Pt cut
       double m_maxEta;          //!< maximal Eta cut
diff --git a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/src/TRT_SeededTrackFinder.cxx b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/src/TRT_SeededTrackFinder.cxx
index 46501530b62cc3a2321a2c8f1867eacc0a98071b..3137f7924d832529266d902fbb90b288304fc72b 100755
--- a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/src/TRT_SeededTrackFinder.cxx
+++ b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/src/TRT_SeededTrackFinder.cxx
@@ -39,8 +39,7 @@ InDet::TRT_SeededTrackFinder::TRT_SeededTrackFinder
     m_fitterTool("Trk::KalmanFitter/InDetTrackFitter"),
     m_trtExtension("InDet::TRT_TrackExtensionTool_xk"),
     m_Segments("TRTSegments"),
-    m_outTracks("TRTSeededTracks"),
-    m_iBeamCondSvc("BeamCondSvc",name)
+    m_outTracks("TRTSeededTracks")
 {
   m_doRefit          = false                                ;       //Do a final careful refit of tracks
   m_doExtension      = false                                ;       //Find the track TRT extension
@@ -69,7 +68,6 @@ InDet::TRT_SeededTrackFinder::TRT_SeededTrackFinder
   declareProperty("maxRPhiImp",        m_maxRPhiImp         = 10.);
   declareProperty("maxZImp",           m_maxZImp            = 250.);
   declareProperty("Extrapolator",      m_extrapolator);
-  declareProperty("BeamPositionSvc",   m_iBeamCondSvc );
 }
 
 ///////////////////////////////////////////////////////////////////
@@ -98,9 +96,10 @@ StatusCode InDet::TRT_SeededTrackFinder::initialize()
     // get extrapolator
     ATH_CHECK( m_extrapolator.retrieve());
     // get beam spot service
-    ATH_CHECK( m_iBeamCondSvc.retrieve());
+    ATH_CHECK( m_beamSpotKey.initialize() );
   } else {
     m_extrapolator.disable();
+    //disable m_beamSpotKey when able to
   }
 
   // Get tool for track extension to TRT
@@ -298,7 +297,10 @@ StatusCode InDet::TRT_SeededTrackFinder::execute()
 
 	      // --- beam spot position
 	      Amg::Vector3D beamSpotPosition(0,0,0);
-	      if (m_iBeamCondSvc) beamSpotPosition = m_iBeamCondSvc->beamVtx().position();
+	      if (m_SiExtensionCuts){
+              SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+              beamSpotPosition = beamSpotHandle->beamVtx().position();
+          }
 	      // --- create surface
 	      Trk::PerigeeSurface perigeeSurface(beamSpotPosition);
 
diff --git a/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/InDetCompetingRIOsOnTrack/CompetingSCT_ClustersOnTrack.h b/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/InDetCompetingRIOsOnTrack/CompetingSCT_ClustersOnTrack.h
index 324108680d21b2e9db0d408343614a6fd039a85f..6364b47fb98f5590a6f301e7fe339bbc9e36c239 100755
--- a/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/InDetCompetingRIOsOnTrack/CompetingSCT_ClustersOnTrack.h
+++ b/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/InDetCompetingRIOsOnTrack/CompetingSCT_ClustersOnTrack.h
@@ -11,13 +11,11 @@
 
 // Trk
 #include "TrkCompetingRIOsOnTrack/CompetingRIOsOnTrack.h"
-//#include "TrkEventPrimitives/GlobalPosition.h"
-//#include "TrkEventPrimitives/ErrorMatrix.h"
-// #include "TrkParameters/TrackParameters.h"
 #include "InDetRIO_OnTrack/SCT_ClusterOnTrack.h" // cannot fwd-declare because of covariant method
+
 #include <iosfwd>
+#include <mutex>
 
-//#include <iostream.h>
 class MsgStream;
 
 namespace Trk {class Surface;}
@@ -107,8 +105,10 @@ private:
     void                               clearChildRotVector();
 
 
-    /** The global Position */
+    /** The global position */
     mutable const Amg::Vector3D*        m_globalPosition;
+    /** Mutex to protect the global position */
+    mutable std::mutex m_mutex;
 
     /** The vector of contained InDet::SCT_ClusterOnTrack objects */
     std::vector<const InDet::SCT_ClusterOnTrack*>*   m_containedChildRots;
@@ -139,10 +139,11 @@ inline const InDet::SCT_ClusterOnTrack& CompetingSCT_ClustersOnTrack::rioOnTrack
         return * m_containedChildRots->operator[](indx);
 }
 
- inline const Amg::Vector3D& CompetingSCT_ClustersOnTrack::globalPosition() const {
-    if (m_globalPosition)
-        return (*m_globalPosition);
-    m_globalPosition = associatedSurface().localToGlobal(localParameters());
+inline const Amg::Vector3D& CompetingSCT_ClustersOnTrack::globalPosition() const {
+    if (m_globalPosition==nullptr) {
+        std::lock_guard<std::mutex> lock{m_mutex};
+        m_globalPosition = associatedSurface().localToGlobal(localParameters());
+    }
     return (*m_globalPosition);
 }
 
diff --git a/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/src/CompetingSCT_ClustersOnTrack.cxx b/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/src/CompetingSCT_ClustersOnTrack.cxx
index e3fba303f1f2a2b535d0a830ecbc3c0afadb6a1f..8c4eec43588220d45b2b2a1707034af18766eee8 100755
--- a/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/src/CompetingSCT_ClustersOnTrack.cxx
+++ b/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/src/CompetingSCT_ClustersOnTrack.cxx
@@ -18,7 +18,8 @@
 // default constructor
 InDet::CompetingSCT_ClustersOnTrack::CompetingSCT_ClustersOnTrack():
         Trk::CompetingRIOsOnTrack(),
-        m_globalPosition(0),
+        m_globalPosition(nullptr),
+        m_mutex(),
         m_containedChildRots(0)
         //
         {}
@@ -26,7 +27,8 @@ InDet::CompetingSCT_ClustersOnTrack::CompetingSCT_ClustersOnTrack():
 // copy constructor
 InDet::CompetingSCT_ClustersOnTrack::CompetingSCT_ClustersOnTrack(const InDet::CompetingSCT_ClustersOnTrack& compROT) :
         Trk::CompetingRIOsOnTrack(compROT),
-        m_globalPosition(compROT.m_globalPosition ? new Amg::Vector3D(*compROT.m_globalPosition) : 0),
+        m_globalPosition(compROT.m_globalPosition ? new Amg::Vector3D(*compROT.m_globalPosition) : nullptr),
+        m_mutex(),
         m_containedChildRots(0) {
     m_containedChildRots = new std::vector< const InDet::SCT_ClusterOnTrack* >;
     std::vector< const InDet::SCT_ClusterOnTrack* >::const_iterator rotIter = compROT.m_containedChildRots->begin();
@@ -43,7 +45,8 @@ InDet::CompetingSCT_ClustersOnTrack::CompetingSCT_ClustersOnTrack(
     
 ):
 Trk::CompetingRIOsOnTrack(assgnProb),
-m_globalPosition(0),
+m_globalPosition(nullptr),
+m_mutex(),
 m_containedChildRots(childrots)
 {
   // initialize local position and error matrix
@@ -61,10 +64,12 @@ InDet::CompetingSCT_ClustersOnTrack& InDet::CompetingSCT_ClustersOnTrack::operat
         delete m_globalPosition;
         m_containedChildRots = new std::vector<const InDet::SCT_ClusterOnTrack*>;
 
-        m_globalPosition     = compROT.m_globalPosition ? new Amg::Vector3D(*compROT.m_globalPosition) : 0;
         std::vector<const InDet::SCT_ClusterOnTrack*>::const_iterator rotIter = compROT.m_containedChildRots->begin();
         for (; rotIter!=compROT.m_containedChildRots->end(); ++rotIter)
             m_containedChildRots->push_back((*rotIter)->clone());
+
+        std::lock_guard<std::mutex> lock{m_mutex};
+        m_globalPosition     = compROT.m_globalPosition ? new Amg::Vector3D(*compROT.m_globalPosition) : nullptr;
     }
     return (*this);
 }
@@ -90,7 +95,7 @@ MsgStream& InDet::CompetingSCT_ClustersOnTrack::dump( MsgStream& out ) const {
                     "over different surfaces") << "  (given prob>cut)" << std::endl;
   Trk::CompetingRIOsOnTrack::dump(out);
   out << "  - GlobalPosition        : ";
-  if (m_globalPosition==NULL) out << "null pointer"<<endmsg;
+  if (m_globalPosition==nullptr) out << "null pointer"<<endmsg;
   else out << *m_globalPosition<<endmsg;
   return out;
 }
@@ -103,7 +108,7 @@ std::ostream& InDet::CompetingSCT_ClustersOnTrack::dump( std::ostream& out ) con
                     "over different surfaces") << "  (given prob>cut)" << std::endl;
   Trk::CompetingRIOsOnTrack::dump(out);
   out << "  - GlobalPosition        : ";
-  if (m_globalPosition==NULL) out << "null pointer"<<std::endl;
+  if (m_globalPosition==nullptr) out << "null pointer"<<std::endl;
   else out << *m_globalPosition<<std::endl;
   return out;
 }
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/CMakeLists.txt b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/CMakeLists.txt
index 79c04d47459e3070f3c6f1158b3d261721cf6f15..bc34afcd990044150623271912af7d261e68523c 100644
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/CMakeLists.txt
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/CMakeLists.txt
@@ -17,7 +17,6 @@ atlas_depends_on_subdirs( PUBLIC
                           Tracking/TrkEvent/TrkParticleBase
                           Tracking/TrkEvent/TrkTrack
 			  InnerDetector/InDetConditions/BeamSpotConditionsData
-			  InnerDetector/InDetConditions/InDetBeamSpotService
                           PRIVATE
                           Control/AthContainers
                           DetectorDescription/GeoPrimitives
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptiveMultiPriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptiveMultiPriVxFinderTool.h
index 38cee93cdec7353cf5b2c2a29ebbb58a8007cfc7..793fa3d7f91ecde033ece1a7e89dc9207626c5bb 100755
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptiveMultiPriVxFinderTool.h
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptiveMultiPriVxFinderTool.h
@@ -97,10 +97,10 @@
 #include "xAODTracking/TrackParticleFwd.h"
 #include "xAODTracking/VertexContainerFwd.h"
 #include "xAODTracking/TrackParticleContainerFwd.h"
-
+#include "BeamSpotConditionsData/BeamSpotData.h"
 class TrackToVtxLinkContainer;
 class NN;
-class IBeamCondSvc;
+
 
 namespace Trk
 {
@@ -155,7 +155,7 @@ namespace InDet
     ToolHandle< Trk::IVertexSeedFinder > m_SeedFinder;
     ToolHandle< InDet::IInDetTrackSelectionTool > m_trkFilter;
 
-    ServiceHandle<IBeamCondSvc> m_iBeamCondSvc; //!< pointer to the beam condition service
+    SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" };
 
     /** Define a beam constraint for the fit */
     bool m_useBeamConstraint; //!<  Use a vertex/beam constraint
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptivePriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptivePriVxFinderTool.h
index bd0f6fcbca6366f8696d618021804e4af6ff511d..f1974942d5639051c0698faee5fd605f7eb35579 100755
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptivePriVxFinderTool.h
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptivePriVxFinderTool.h
@@ -56,7 +56,7 @@
  * Forward declarations 
  */
  
-class IBeamCondSvc;
+#include "BeamSpotConditionsData/BeamSpotData.h"
 #include "xAODTracking/VertexFwd.h"
 #include "xAODTracking/TrackParticleFwd.h"
 #include "xAODTracking/VertexContainerFwd.h"
@@ -113,7 +113,7 @@ public:
    ToolHandle< Trk::IVertexFitter > m_iVertexFitter;
    ToolHandle< InDet::IInDetTrackSelectionTool > m_trkFilter;
    
-   ServiceHandle<IBeamCondSvc> m_iBeamCondSvc; //!< pointer to the beam condition service
+    SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" };
    
 
    void SGError(std::string errService);
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetIterativePriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetIterativePriVxFinderTool.h
index f0aa49bd286133992e6b8b84b2c7f48c7fa3a58a..8c9b8898e9a70f5b73273651bafcee5856378fda 100755
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetIterativePriVxFinderTool.h
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetIterativePriVxFinderTool.h
@@ -47,7 +47,6 @@
  * Forward declarations 
  */
  
-class IBeamCondSvc;
 #include "xAODTracking/VertexFwd.h"
 #include "xAODTracking/TrackParticleFwd.h"
 #include "xAODTracking/VertexContainerFwd.h"
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetMultiPriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetMultiPriVxFinderTool.h
index 3f0673ef2da4987d4380e47795d1aca9000b0702..b8b1028521149311678a13757f1dd06bf304963c 100644
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetMultiPriVxFinderTool.h
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetMultiPriVxFinderTool.h
@@ -38,8 +38,7 @@
 /**
  * Forward declarations 
  */
- 
-class IBeamCondSvc;
+#include "BeamSpotConditionsData/BeamSpotData.h"
 #include "xAODTracking/VertexFwd.h"
 #include "xAODTracking/TrackParticleFwd.h"
 #include "xAODTracking/VertexContainerFwd.h"
@@ -119,7 +118,7 @@ public:
    ToolHandle< Trk::IVertexSeedFinder > m_SeedFinder;
    ToolHandle< Trk::IImpactPoint3dEstimator > m_ImpactPoint3dEstimator;
 
-   ServiceHandle<IBeamCondSvc> m_iBeamCondSvc; //!< pointer to the beam condition service
+   SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" };
 
    bool m_useBeamConstraint;
    double m_significanceCutSeeding;
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetPriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetPriVxFinderTool.h
index a8c8ed804832c63249abf46b22bc0ae248a1c388..befc34946fa3330872c984d79f26620207832194 100755
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetPriVxFinderTool.h
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetPriVxFinderTool.h
@@ -86,12 +86,12 @@
 */
 
 /* Forward declarations */
-class IBeamCondSvc;
+
 #include "xAODTracking/Vertex.h"
 #include "xAODTracking/TrackParticle.h"
 #include "xAODTracking/VertexContainer.h"
 #include "xAODTracking/TrackParticleContainer.h"
-
+#include "BeamSpotConditionsData/BeamSpotData.h"
 namespace Trk
 {
 class IVertexFitter;
@@ -120,7 +120,7 @@ private:
     ToolHandle < Trk::IVertexFitter > m_iVertexFitter;
     ToolHandle< InDet::IInDetTrackSelectionTool > m_trkFilter;
 
-    ServiceHandle<IBeamCondSvc> m_iBeamCondSvc; //!< pointer to the beam condition service
+    SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" }; //!< pointer to the beam condition service
     
     /** Define a beam constraint for the fit */
     bool m_useBeamConstraint; //!<  Use a vertex/beam constraint
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptiveMultiPriVxFinderTool.cxx b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptiveMultiPriVxFinderTool.cxx
index a020683f493037b5f151cb95eb35ca8f481db094..d493845fbbe81626e33df964420780da0c7db796 100755
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptiveMultiPriVxFinderTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptiveMultiPriVxFinderTool.cxx
@@ -34,7 +34,7 @@
 
 #include "NN.h"
 #include "InDetTrackSelectionTool/IInDetTrackSelectionTool.h"
-#include "InDetBeamSpotService/IBeamCondSvc.h"
+
 
 #include "VxMultiVertex/MvfFitInfo.h"
 #include "VxMultiVertex/MVFVxTrackAtVertex.h"
@@ -67,7 +67,6 @@ namespace InDet
     m_MultiVertexFitter("Trk::AdaptiveMultiVertexFitter"),
     m_SeedFinder("Trk::ZScanSeedFinder"),
     m_trkFilter("InDet::InDetTrackSelection"),
-    m_iBeamCondSvc("BeamCondSvc", n),
     m_useBeamConstraint(true),
     m_TracksMaxZinterval(1.),
     m_maxVertexChi2(18.42),
@@ -98,7 +97,6 @@ namespace InDet
     declareProperty("realMultiVertex", m_realMultiVertex);
     declareProperty("useFastCompatibility", m_useFastCompatibility);
     declareProperty("useBeamConstraint", m_useBeamConstraint);
-    declareProperty("BeamPositionSvc", m_iBeamCondSvc);
     declareProperty("addSingleTrackVertices", m_addSingleTrackVertices);
     //********* signal vertex selection (for pile up) ****
     declareProperty("selectiontype", m_selectiontype);
@@ -121,7 +119,7 @@ namespace InDet
 
     ATH_CHECK(m_SeedFinder.retrieve());
 
-    ATH_CHECK(m_iBeamCondSvc.retrieve());
+    ATH_CHECK(m_beamSpotKey.initialize());
 
     ATH_CHECK(m_trkFilter.retrieve());
 
@@ -152,11 +150,12 @@ namespace InDet
     /*
        xAOD::Vertex beamposition;
        beamposition.makePrivateStore();
-       beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-       beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+       beamposition.setPosition(beamSpotHandle->beamVtx().position());
+       beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
      */
 
-    Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx());
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx());
 
     std::vector<const Trk::ITrackLink*> selectedTracks;
 
@@ -205,11 +204,12 @@ namespace InDet
     /*
        xAOD::Vertex beamposition;
        beamposition.makePrivateStore();
-       beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-       beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+       beamposition.setPosition(beamSpotHandle->beamVtx().position());
+       beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
      */
 
-    Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx());
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx());
 
     typedef DataVector<Trk::TrackParticleBase>::const_iterator TrackParticleDataVecIter;
 
@@ -252,11 +252,11 @@ namespace InDet
   std::pair<xAOD::VertexContainer*, xAOD::VertexAuxContainer*>
   InDetAdaptiveMultiPriVxFinderTool::findVertex(const xAOD::TrackParticleContainer* trackParticles) {
     std::vector<const Trk::ITrackLink*> selectedTracks;
-
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
     xAOD::Vertex beamposition;
     beamposition.makePrivateStore();
-    beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-    beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+    beamposition.setPosition(beamSpotHandle->beamVtx().position());
+    beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
 
     typedef DataVector<xAOD::TrackParticle>::const_iterator TrackParticleDataVecIter;
 
@@ -354,7 +354,7 @@ namespace InDet
     //prepare iterators for tracks only necessary for seeding
     std::vector<const Trk::ITrackLink*>::iterator seedtrkbegin = seedTracks.begin();
     std::vector<const Trk::ITrackLink*>::iterator seedtrkend = seedTracks.end();
-
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
     int iteration = 0;
     unsigned int seedtracknumber = seedTracks.size();
     do {
@@ -381,10 +381,10 @@ namespace InDet
       if (m_useBeamConstraint) {
         constraintVertex = new xAOD::Vertex();
         constraintVertex->makePrivateStore();
-        constraintVertex->setPosition(m_iBeamCondSvc->beamVtx().position());
-        constraintVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
-        constraintVertex->setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(),
-                                        m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF());
+        constraintVertex->setPosition(beamSpotHandle->beamVtx().position());
+        constraintVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
+        constraintVertex->setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(),
+                                        beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF());
         actualVertex = m_SeedFinder->findSeed(perigeeList, constraintVertex);
       } else {
         actualVertex = m_SeedFinder->findSeed(perigeeList);
@@ -801,8 +801,8 @@ namespace InDet
       ATH_MSG_WARNING("No vertices found: returning a place-holder at the beam spot center.");
       xAOD::Vertex* beamspotCandidate = new xAOD::Vertex;
       beamspotCandidate->makePrivateStore();
-      beamspotCandidate->setPosition(m_iBeamCondSvc->beamVtx().position());
-      beamspotCandidate->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+      beamspotCandidate->setPosition(beamSpotHandle->beamVtx().position());
+      beamspotCandidate->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
       beamspotCandidate->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
       // TODO: I don't need to set fitQuality too do I?
       myxAODVertices.push_back(xAODVertex_pair(0, beamspotCandidate));
@@ -889,8 +889,8 @@ namespace InDet
       xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex;
       theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its
                                                       // aux store
-      dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position());
-      dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+      dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position());
+      dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
       dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
       dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx);
     }
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptivePriVxFinderTool.cxx b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptivePriVxFinderTool.cxx
index 58ca183dee14d5f8c727b3cdd225b9e1d41322c3..e213911d5bed64420e551fd3940d14c1b39eb1ce 100755
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptivePriVxFinderTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptivePriVxFinderTool.cxx
@@ -34,7 +34,6 @@
 #include "EventPrimitives/EventPrimitivesHelpers.h"
 #include "GeoPrimitives/GeoPrimitives.h"
 
-#include "InDetBeamSpotService/IBeamCondSvc.h"
 #include "InDetTrackSelectionTool/IInDetTrackSelectionTool.h"
 
 //#include "VxVertex/VxContainer.h"
@@ -75,13 +74,12 @@ namespace InDet
                                                              const IInterface* p)
     : AthAlgTool(t, n, p),
     m_iVertexFitter("Trk::AdaptiveVertexFitter"),
-    m_trkFilter("InDet::InDetTrackSelection"),
-    m_iBeamCondSvc("BeamCondSvc", n) {
+    m_trkFilter("InDet::InDetTrackSelection")
+  {
     declareInterface<IVertexFinder>(this);//by GP: changed from InDetAdaptivePriVxFinderTool to IPriVxFinderTool
     /* Retrieve StoreGate container and tool names from job options */
     declareProperty("VertexFitterTool", m_iVertexFitter);
     declareProperty("TrackSelector", m_trkFilter);
-    declareProperty("BeamPositionSvc", m_iBeamCondSvc);
     /* Cuts for track preselection */
   }
 
@@ -98,11 +96,7 @@ namespace InDet
       return StatusCode::FAILURE;
     }
 
-    sc = m_iBeamCondSvc.retrieve();
-    if (sc.isFailure()) {
-      msg(MSG::ERROR) << "Could not find BeamCondSvc." << endmsg;
-      return sc;
-    }
+    ATH_CHECK(m_beamSpotKey.initialize());
 
     if (m_trkFilter.retrieve().isFailure()) {
       msg(MSG::ERROR) << " Unable to retrieve " << m_trkFilter << endmsg;
@@ -123,11 +117,11 @@ namespace InDet
     /*
        xAOD::Vertex beamposition;
        beamposition.makePrivateStore();
-       beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-       beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+       beamposition.setPosition(beamSpotHandle->beamVtx().position());
+       beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
      */
-
-    Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx());
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx());
 
     //---- Start of preselection of tracks ---------------//
     std::vector<const Trk::TrackParameters*> origParameters;
@@ -179,11 +173,12 @@ namespace InDet
     /*
        xAOD::Vertex beamposition;
        beamposition.makePrivateStore();
-       beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-       beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+       beamposition.setPosition(beamSpotHandle->beamVtx().position());
+       beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
      */
 
-    Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx());
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx());
 
     //---- Start of preselection of tracks ---------------//
     std::vector<const Trk::TrackParameters*> origParameters;
@@ -242,11 +237,13 @@ namespace InDet
   std::pair<xAOD::VertexContainer*, xAOD::VertexAuxContainer*>
   InDetAdaptivePriVxFinderTool::findVertex(const xAOD::TrackParticleContainer* trackParticles) {
     ATH_MSG_DEBUG(" Number of input tracks before track selection: " << trackParticles->size());
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+
 
     xAOD::Vertex beamposition;
     beamposition.makePrivateStore();
-    beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-    beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+    beamposition.setPosition(beamSpotHandle->beamVtx().position());
+    beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
 
     //---- Start of preselection of tracks ---------------//
     std::vector<const Trk::TrackParameters*> origParameters;
@@ -328,11 +325,12 @@ namespace InDet
 
     //---- Start of fitting section ------------------------------------------------------//
     if (origParameters.size() >= 1) {
+      SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
       xAOD::Vertex beamposition;
       beamposition.makePrivateStore();
-      beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-      beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
-      beamposition.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF());
+      beamposition.setPosition(beamSpotHandle->beamVtx().position());
+      beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
+      beamposition.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF());
       myxAODVertex = m_iVertexFitter->fit(origParameters, beamposition);
       /* @TODO? The fit tool does not return tracks chi2 ordered anymore
                 We have to do it */
@@ -392,11 +390,12 @@ namespace InDet
     }
     //---- if no vertex is there let dummy be at beam spot
     else if (theVertexContainer->size() == 0) {
+      SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
       xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex;
       theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its
                                                       // aux store
-      dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position());
-      dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+      dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position());
+      dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
       dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
       dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx);
     }
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetMultiPriVxFinderTool.cxx b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetMultiPriVxFinderTool.cxx
index 62d549095d204a1ee232c33de067ea1950e49bc3..9b21e38ba10dcafcda7fd36d5646862bb329e9f1 100755
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetMultiPriVxFinderTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetMultiPriVxFinderTool.cxx
@@ -34,7 +34,6 @@
 #include "GeoPrimitives/GeoPrimitives.h"
 
 #include "TrkVertexFitterInterfaces/IImpactPoint3dEstimator.h"
-#include "InDetBeamSpotService/IBeamCondSvc.h"
 #include "InDetTrackSelectionTool/IInDetTrackSelectionTool.h"
 #include "TrkVertexFitterInterfaces/IVertexSeedFinder.h"
 
@@ -68,7 +67,6 @@ namespace InDet
     m_trkFilter("InDet::InDetTrackSelection"),
     m_SeedFinder("Trk::ImagingSeedFinder"),
     m_ImpactPoint3dEstimator("Trk::ImpactPoint3dEstimator"),
-    m_iBeamCondSvc("BeamCondSvc", n),
     m_useBeamConstraint(false),
     m_significanceCutSeeding(10),
     m_maximumChi2cutForSeeding(6. * 6.),
@@ -80,7 +78,6 @@ namespace InDet
 
     declareProperty("VertexFitterTool", m_iVertexFitter);
     declareProperty("TrackSelector", m_trkFilter);
-    declareProperty("BeamPositionSvc", m_iBeamCondSvc);
     declareProperty("SeedFinder", m_SeedFinder);
     declareProperty("ImpactPoint3dEstimator", m_ImpactPoint3dEstimator);
 
@@ -99,9 +96,7 @@ namespace InDet
 
   StatusCode
   InDetMultiPriVxFinderTool::initialize() {
-    StatusCode sc;
-
-
+    
     if (m_createSplitVertices == true && m_useBeamConstraint == true) {
       msg(MSG::FATAL) << " Split vertices cannot be obtained if beam spot constraint is true! Change settings..." <<
       endmsg;
@@ -124,11 +119,7 @@ namespace InDet
       return StatusCode::FAILURE;
     }
 
-    sc = m_iBeamCondSvc.retrieve();
-    if (sc.isFailure()) {
-      msg(MSG::ERROR) << "Could not find BeamCondSvc." << endmsg;
-      return sc;
-    }
+    ATH_CHECK(m_beamSpotKey.initialize());
 
     if (m_trkFilter.retrieve().isFailure()) {
       msg(MSG::ERROR) << " Unable to retrieve " << m_trkFilter << endmsg;
@@ -154,16 +145,20 @@ namespace InDet
     typedef DataVector<Trk::Track>::const_iterator TrackDataVecIter;
 
     bool selectionPassed{false};
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    const InDet::BeamSpotData* beamdata = nullptr;
+    if(m_useBeamConstraint && beamSpotHandle.isValid()) beamdata = beamSpotHandle.retrieve();
+    
     for (TrackDataVecIter itr = (*trackTES).begin(); itr != (*trackTES).end(); itr++) {
       if (m_useBeamConstraint) {
         // TODO: change trkFilter to allow for this replacement
         /*
            xAOD::Vertex beamposition;
            beamposition.makePrivateStore();
-           beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-           beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+           beamposition.setPosition(beamdata->beamVtx().position());
+           beamposition.setCovariancePosition(beamdata->beamVtx().covariancePosition());
          */
-        Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx());
+        Trk::RecVertex beamposition(beamdata->beamVtx());
         selectionPassed = static_cast<bool>(m_trkFilter->accept(**itr, &beamposition));
       } else {
         Trk::Vertex null(Amg::Vector3D(0, 0, 0));
@@ -195,16 +190,20 @@ namespace InDet
     typedef DataVector<Trk::TrackParticleBase>::const_iterator TrackParticleDataVecIter;
 
     bool  selectionPassed{false};
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    const InDet::BeamSpotData* beamdata = nullptr;
+    if(m_useBeamConstraint && beamSpotHandle.isValid()) beamdata = beamSpotHandle.retrieve();
+    
     for (TrackParticleDataVecIter itr = (*trackTES).begin(); itr != (*trackTES).end(); itr++) {
       if (m_useBeamConstraint) {
         // TODO: change trkFilter to allow for this replacement
         /*
            xAOD::Vertex beamposition;
            beamposition.makePrivateStore();
-           beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-           beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+           beamposition.setPosition(beamdata->beamVtx().position());
+           beamposition.setCovariancePosition(beamdata->beamVtx().covariancePosition());
          */
-        Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx());
+        Trk::RecVertex beamposition(beamdata->beamVtx());
         selectionPassed = static_cast<bool>(m_trkFilter->accept(*((*itr)->originalTrack()), &beamposition));
       } else {
         Trk::Vertex null(Amg::Vector3D(0, 0, 0));
@@ -233,7 +232,10 @@ namespace InDet
     ATH_MSG_DEBUG(" Number of input tracks before track selection: " << trackParticles->size());
 
     std::vector<Trk::ITrackLink*> selectedTracks;
-
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    const InDet::BeamSpotData* beamdata = nullptr;
+    if(m_useBeamConstraint && beamSpotHandle.isValid()) beamdata = beamSpotHandle.retrieve();
+    
     typedef DataVector<xAOD::TrackParticle>::const_iterator TrackParticleDataVecIter;
 
     bool selectionPassed{false};
@@ -241,8 +243,8 @@ namespace InDet
       if (m_useBeamConstraint) {
         xAOD::Vertex beamposition;
         beamposition.makePrivateStore();
-        beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-        beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+        beamposition.setPosition(beamdata->beamVtx().position());
+        beamposition.setCovariancePosition(beamdata->beamVtx().covariancePosition());
         selectionPassed = static_cast<bool> (m_trkFilter->accept(**itr, &beamposition));
       } else {
         xAOD::Vertex null;
@@ -302,10 +304,11 @@ namespace InDet
     xAOD::Vertex theconstraint;
     theconstraint.makePrivateStore();
     if (m_useBeamConstraint) {
-      theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position());
-      theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
-      theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(),
-                                  m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF());
+      SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+      theconstraint.setPosition(beamSpotHandle->beamVtx().position());
+      theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
+      theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(),
+                                  beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF());
       seedVertices = m_SeedFinder->findMultiSeeds(perigeeList, &theconstraint);
     } else {
       seedVertices = m_SeedFinder->findMultiSeeds(perigeeList);
@@ -520,8 +523,9 @@ namespace InDet
       xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex;
       theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its
                                                       // aux store
-      dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position());
-      dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+      SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+      dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position());
+      dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
       dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
       dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx);
     }
diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetPriVxFinderTool.cxx b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetPriVxFinderTool.cxx
index 0f2347fb4662c3aa6f23bd10979739376d7bf2f0..85f31d6c3c2bd6e7dc554f0b94e5275448c0c548 100755
--- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetPriVxFinderTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetPriVxFinderTool.cxx
@@ -36,7 +36,6 @@
 #include "VxVertex/VxCandidate.h"
 #include "VxVertex/VxTrackAtVertex.h"
 
-#include "InDetBeamSpotService/IBeamCondSvc.h"
 #include "InDetTrackSelectionTool/IInDetTrackSelectionTool.h"
 #include "TrkVertexFitterInterfaces/IVertexFitter.h"
 #include "InDetRecToolInterfaces/IMultiPVSeedFinder.h"
@@ -73,7 +72,6 @@ namespace InDet
     m_iPriVxSeedFinder("InDet::SlidingWindowMultiSeedFinder"),
     m_iVertexFitter("Trk::FastVertexFitter"),
     m_trkFilter("InDet::InDetTrackSelection"),
-    m_iBeamCondSvc("BeamCondSvc", n),
     m_useBeamConstraint(false),
     m_chi2CutMethod(1),
     m_enableMultipleVertices(true),
@@ -90,7 +88,6 @@ namespace InDet
     declareProperty("maxChi2PerTrack", m_maxChi2PerTrack);
     declareProperty("enableMultipleVertices", m_enableMultipleVertices);
     declareProperty("clusterLength", m_clusterLength);
-    declareProperty("BeamPositionSvc", m_iBeamCondSvc);
     declareProperty("createSplitVertices", m_createSplitVertices);
     declareProperty("splitVerticesTrkInvFraction", m_splitVerticesTrkInvFraction,
                     "inverse fraction to split tracks (1:N)");
@@ -136,10 +133,7 @@ namespace InDet
       msg(MSG::INFO) << "Retrieved tool " << m_iVertexFitter << endmsg;
     }
 
-    if (m_iBeamCondSvc.retrieve().isFailure()) {
-      msg(MSG::ERROR) << "Could not find BeamCondSvc." << endmsg;
-      return StatusCode::FAILURE;
-    }
+    ATH_CHECK(m_beamSpotKey.initialize());
 
     msg(MSG::INFO) << "Initialization successful" << endmsg;
     return StatusCode::SUCCESS;
@@ -153,11 +147,12 @@ namespace InDet
     /*
        xAOD::Vertex beamposition;
        beamposition.makePrivateStore();
-       beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-       beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+       beamposition.setPosition(beamSpotHandle->beamVtx().position());
+       beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
      */
-
-    Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx());
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    
+    const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx());
 
     //---- create a vector of track particle base objects ---------------//
     std::vector<const Trk::Track*> origTracks;
@@ -269,11 +264,11 @@ namespace InDet
     /*
        xAOD::Vertex beamposition;
        beamposition.makePrivateStore();
-       beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-       beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+       beamposition.setPosition(beamSpotHandle->beamVtx().position());
+       beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
      */
-
-    Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx());
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx());
 
     //---- create a vector of track particle base objects ---------------//
     std::vector<const Trk::TrackParticleBase*> origTrackParticles;
@@ -387,11 +382,12 @@ namespace InDet
   std::pair<xAOD::VertexContainer*, xAOD::VertexAuxContainer*>
   InDetPriVxFinderTool::findVertex(const xAOD::TrackParticleContainer* trackParticles) {
     ATH_MSG_DEBUG(" Number of input tracks before track selection: " << trackParticles->size());
-
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+    
     xAOD::Vertex beamposition;
     beamposition.makePrivateStore();
-    beamposition.setPosition(m_iBeamCondSvc->beamVtx().position());
-    beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+    beamposition.setPosition(beamSpotHandle->beamVtx().position());
+    beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
 
     std::vector<const xAOD::TrackParticle*> origTPs;
     origTPs.clear();
@@ -510,6 +506,7 @@ namespace InDet
     std::vector<xAOD::Vertex*> splitVtxVector;
     double vertexPt;
     xAOD::Vertex* myxAODVertex = 0;
+    SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
     for (unsigned int i = 0; i < zTrackColl.size(); i++) {
       // std::cout<<"Inside the loop"<<std::endl;
       if (msgLvl(MSG::DEBUG)) msg() << "Fitting vertex of Z-Cluster " << i << " with " << zTrackColl[i].size() << " Tracks" << endmsg;
@@ -521,26 +518,26 @@ namespace InDet
       if (origParameters.size() == 1 && m_useBeamConstraint) {
         xAOD::Vertex theconstraint;
         theconstraint.makePrivateStore();
-        theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position());
-        theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
-        theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF());
+        theconstraint.setPosition(beamSpotHandle->beamVtx().position());
+        theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
+        theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF());
         myxAODVertex = m_iVertexFitter->fit(origParameters, theconstraint);
       } else if (origParameters.size() < 2 && m_createSplitVertices) {
         // in the case this is a split vertex and it has only one track
         // we make a dummy vertex and push it back to the container
         myxAODVertex = new xAOD::Vertex;
         myxAODVertex->makePrivateStore();
-        myxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position());
-        myxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+        myxAODVertex->setPosition(beamSpotHandle->beamVtx().position());
+        myxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
         myxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
         myxAODVertex->setVertexType(xAOD::VxType::NoVtx);
       } else if (origParameters.size() > 1) {
         if (m_useBeamConstraint) {
           xAOD::Vertex theconstraint;
           theconstraint.makePrivateStore();
-          theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position());
-          theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
-          theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF());
+          theconstraint.setPosition(beamSpotHandle->beamVtx().position());
+          theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
+          theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF());
           myxAODVertex = m_iVertexFitter->fit(origParameters, theconstraint);
         } else {
           myxAODVertex = m_iVertexFitter->fit(origParameters, vertex);
@@ -584,9 +581,9 @@ namespace InDet
             if (m_useBeamConstraint) {
               xAOD::Vertex theconstraint;
               theconstraint.makePrivateStore();
-              theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position());
-              theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
-              theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF());
+              theconstraint.setPosition(beamSpotHandle->beamVtx().position());
+              theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
+              theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF());
               myxAODVertex = m_iVertexFitter->fit(origParameters, theconstraint);
             } else {
               myxAODVertex = m_iVertexFitter->fit(origParameters, vertex);
@@ -619,9 +616,9 @@ namespace InDet
               if (m_useBeamConstraint) {
                 xAOD::Vertex theconstraint;
                 theconstraint.makePrivateStore();
-                theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position());
-                theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
-                theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF());
+                theconstraint.setPosition(beamSpotHandle->beamVtx().position());
+                theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
+                theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF());
                 myxAODVertex = m_iVertexFitter->fit(origParameters, theconstraint);
               } else {
                 myxAODVertex = m_iVertexFitter->fit(origParameters, vertex);
@@ -661,8 +658,8 @@ namespace InDet
         } else {
           xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex;
           dummyxAODVertex->makePrivateStore();
-          dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position());
-          dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+          dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position());
+          dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
           dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
           dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx);
           splitVtxVector.push_back(dummyxAODVertex);
@@ -708,8 +705,8 @@ namespace InDet
       xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex;
       theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its
                                                       // aux store
-      dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position());
-      dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+      dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position());
+      dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
       dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
       dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx);
     }
@@ -719,8 +716,8 @@ namespace InDet
       xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex;
       theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its
                                                       // aux store
-      dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position());
-      dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+      dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position());
+      dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
       dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
       dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx);
       if (m_createSplitVertices) {
@@ -728,8 +725,8 @@ namespace InDet
         xAOD::Vertex* new_dummyxAODVertex = new xAOD::Vertex;
         theVertexContainer->push_back(new_dummyxAODVertex); // have to add vertex to container here first so it can use
                                                             // its aux store
-        new_dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position());
-        new_dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition());
+        new_dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position());
+        new_dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition());
         new_dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
         new_dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx);
       }
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.cxx b/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.cxx
index 47abf1be458a458f7d348e886830c8bb592e28e0..27acecaf8ef6f914dc5741bd03efa59eb0eadd97 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.cxx
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.cxx
@@ -44,7 +44,7 @@ StatusCode InDet::ToolTester::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode InDet::ToolTester::execute_r(const EventContext &ctx) const {
+StatusCode InDet::ToolTester::execute(const EventContext &ctx) const {
 
   // Retrieve the tracks:
   SG::ReadHandle<xAOD::TrackParticleContainer> tracks(m_sgKey,ctx);
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.h b/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.h
index 08bc2a208ce1ca2c4647b9cc679427562273d204..445d5290a1de7f4fbb6ed0d4a6c119a1b326484f 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.h
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.h
@@ -34,7 +34,7 @@ namespace InDet {
       /// Function initialising the algorithm
       virtual StatusCode initialize();
       /// Function executing the algorithm
-      virtual StatusCode execute_r(const EventContext &ctx) const;
+      virtual StatusCode execute(const EventContext &ctx) const;
 
    private:
       /// StoreGate key for the track container to investigate
diff --git a/InnerDetector/InDetRecTools/PixelToTPIDTool/share/PixeldEdxWriteCool.py b/InnerDetector/InDetRecTools/PixelToTPIDTool/share/PixeldEdxWriteCool.py
index d8f6a3b29ab1d86e51734b3564247a69172b8ac0..49a6f70bb9d383dec3645e136ff0306cd5a5d74b 100755
--- a/InnerDetector/InDetRecTools/PixelToTPIDTool/share/PixeldEdxWriteCool.py
+++ b/InnerDetector/InDetRecTools/PixelToTPIDTool/share/PixeldEdxWriteCool.py
@@ -7,10 +7,6 @@
 ## basic job configuration (for generator)
 import AthenaCommon.AtlasUnixGeneratorJob
 
-# Set handler for traceback
-#gbl.AthenaServices.SetFatalHandler(438)
-
-
 ## get a handle to the default top-level algorithm sequence
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
diff --git a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/CMakeLists.txt b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/CMakeLists.txt
index 9c80a92d68e73378131221eb5982a0393965c841..8ae2bd4893699fc9ed15d384847a0dc1f1225919 100644
--- a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/CMakeLists.txt
+++ b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/CMakeLists.txt
@@ -9,7 +9,7 @@ atlas_subdir( SiTrackMakerTool_xk )
 atlas_depends_on_subdirs( PUBLIC
                           Control/AthenaBaseComps
                           GaudiKernel
-                          InnerDetector/InDetConditions/InDetBeamSpotService
+                          InnerDetector/InDetConditions/BeamSpotConditionsData
                           InnerDetector/InDetRecTools/InDetRecToolInterfaces
                           MagneticField/MagFieldInterfaces
                           Tracking/TrkDetDescr/TrkGeometry
diff --git a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/SiTrackMakerTool_xk/SiTrackMaker_xk.h b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/SiTrackMakerTool_xk/SiTrackMaker_xk.h
index bd3e460d3bddc1e6915ca6797fb3a8a533d3e32a..af35b2e65e7dcf224a589ff8f6eac89390bf2474 100755
--- a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/SiTrackMakerTool_xk/SiTrackMaker_xk.h
+++ b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/SiTrackMakerTool_xk/SiTrackMaker_xk.h
@@ -26,13 +26,12 @@
 #include "InDetRecToolInterfaces/ISeedToTrackConversionTool.h"
 #include "TrkGeometry/MagneticFieldProperties.h"
 #include "TrkCaloClusterROI/CaloClusterROI_Collection.h"
+#include "BeamSpotConditionsData/BeamSpotData.h"
 
 #include <list>
-#include <map>
 #include <iosfwd>
 
 class MsgStream;
-class IBeamCondSvc;
 
 namespace InDet{
 
@@ -102,7 +101,7 @@ namespace InDet{
       ToolHandle<InDet::ISiDetElementsRoadMaker>     m_roadmaker   ;
       ToolHandle<InDet::ISiCombinatorialTrackFinder> m_tracksfinder;
       ToolHandle<InDet::ISeedToTrackConversionTool>  m_seedtrack   ;
-      IBeamCondSvc*                                  m_beam  {}      ;
+      SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" };
 
       int                            m_nprint{}        ;  // Kind output information
       int                            m_inputseeds{}    ;  // Number input seeds
@@ -116,7 +115,6 @@ namespace InDet{
 //      std::string      m_inputHadClusterContainerName;
       SG::ReadHandleKey<CaloClusterROI_Collection> m_caloCluster;
       SG::ReadHandleKey<CaloClusterROI_Collection> m_caloHad;
-      std::string                    m_beamconditions;
       Trk::TrackInfo                 m_trackinfo     ;
       bool                           m_pix{}           ;
       bool                           m_sct{}           ;
diff --git a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/src/SiTrackMaker_xk.cxx b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/src/SiTrackMaker_xk.cxx
index 8e2ef308bc6a0ad25bcc6f29c410c45ac7c16e8d..e69a0725677f46e6fd0f39f974a68121be10dc45 100755
--- a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/src/SiTrackMaker_xk.cxx
+++ b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/src/SiTrackMaker_xk.cxx
@@ -20,7 +20,6 @@
 #include "SiTrackMakerTool_xk/SiTrackMaker_xk.h"
 
 #include "TrkCaloClusterROI/CaloClusterROI.h"
-#include "InDetBeamSpotService/IBeamCondSvc.h"
 
 
 ///////////////////////////////////////////////////////////////////
@@ -75,7 +74,6 @@ InDet::SiTrackMaker_xk::SiTrackMaker_xk
   m_seedsegmentsWrite = false;
 //  m_inputClusterContainerName    = "InDetCaloClusterROIs"   ;
 //  m_inputHadClusterContainerName = "InDetHadCaloClusterROIs";
-  m_beamconditions               = "BeamCondSvc"            ;
 
   declareInterface<ISiTrackMaker>(this);
 
@@ -130,14 +128,9 @@ InDet::SiTrackMaker_xk::~SiTrackMaker_xk()
 
 StatusCode InDet::SiTrackMaker_xk::initialize()
 {
-  StatusCode sc = AlgTool::initialize(); 
-
   // Get beam geometry
   //
-  m_beam = 0;
-  if(m_beamconditions!="") {
-    sc = service(m_beamconditions,m_beam);
-  }
+  ATH_CHECK( m_beamSpotKey.initialize() );
 
   // Get magnetic field service
   //
@@ -375,8 +368,9 @@ std::ostream& InDet::operator <<
 
 void InDet::SiTrackMaker_xk::newEvent(bool PIX,bool SCT)
 {
-  if(m_beam) {Amg::Vector3D cb = m_beam->beamPos(); m_xybeam[0] = cb[0]; m_xybeam[1] = cb[1];}
-  else       {                                      m_xybeam[0] =    0.; m_xybeam[1] =    0.;}
+  SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey };
+  if(beamSpotHandle.isValid()) { m_xybeam[0] = beamSpotHandle->beamPos()[0]; m_xybeam[1] = beamSpotHandle->beamPos()[1];}
+  else       {                   m_xybeam[0] =    0.;                        m_xybeam[1] =    0.;}
   
   m_pix          = PIX && m_usePix;
   m_sct          = SCT && m_useSct;
diff --git a/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/InDetDetailedTrackTruthMaker.h b/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/InDetDetailedTrackTruthMaker.h
index 264c084ed3b022b2b4b8ca00687a116d7278827d..fd60e199cdcf7f016a0431deb265cebdcf3644dd 100755
--- a/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/InDetDetailedTrackTruthMaker.h
+++ b/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/InDetDetailedTrackTruthMaker.h
@@ -34,7 +34,7 @@ public:
   InDetDetailedTrackTruthMaker(const std::string &name,ISvcLocator *pSvcLocator);
 
   virtual StatusCode initialize();
-  virtual StatusCode execute_r(const EventContext &ctx) const;
+  virtual StatusCode execute(const EventContext &ctx) const;
   virtual StatusCode finalize();
 
 private:
diff --git a/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/PRD_MultiTruthMaker.h b/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/PRD_MultiTruthMaker.h
index 84f3abd67dcda39c44d5dbf72e1e1adc18a6676d..83a06f5e02a16352a6b9e7cba3c71891a073b0d6 100755
--- a/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/PRD_MultiTruthMaker.h
+++ b/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/PRD_MultiTruthMaker.h
@@ -32,7 +32,7 @@ public:
   PRD_MultiTruthMaker(const std::string &name,ISvcLocator *pSvcLocator);
 
   virtual StatusCode initialize();
-  virtual StatusCode execute_r(const EventContext &ctx) const;
+  virtual StatusCode execute(const EventContext &ctx) const;
   virtual StatusCode finalize();
 
 private:
diff --git a/InnerDetector/InDetTruth/InDetTruthAlgs/src/InDetDetailedTrackTruthMaker.cxx b/InnerDetector/InDetTruth/InDetTruthAlgs/src/InDetDetailedTrackTruthMaker.cxx
index 9262a1c5cb52275a53ac2702d45ea2b29fc22723..eccdd3a9556a9e679e05c03a751acdbe95258b6e 100755
--- a/InnerDetector/InDetTruth/InDetTruthAlgs/src/InDetDetailedTrackTruthMaker.cxx
+++ b/InnerDetector/InDetTruth/InDetTruthAlgs/src/InDetDetailedTrackTruthMaker.cxx
@@ -64,9 +64,9 @@ StatusCode InDetDetailedTrackTruthMaker::finalize()
 }
 
 // -----------------------------------------------------------------------------------------------------
-StatusCode InDetDetailedTrackTruthMaker::execute_r(const EventContext &ctx) const
+StatusCode InDetDetailedTrackTruthMaker::execute(const EventContext &ctx) const
 {
-  ATH_MSG_DEBUG ("InDetDetailedTrackTruthMaker::execute_r(...)");
+  ATH_MSG_DEBUG ("InDetDetailedTrackTruthMaker::execute(...)");
 
   //----------------------------------------------------------------
   // Retrieve track collection
diff --git a/InnerDetector/InDetTruth/InDetTruthAlgs/src/PRD_MultiTruthMaker.cxx b/InnerDetector/InDetTruth/InDetTruthAlgs/src/PRD_MultiTruthMaker.cxx
index 060e76998f8784d9dd3ba236e0488521fb4b0de8..5fd65d0558e30ef7cda172a6aea4c687afd86851 100755
--- a/InnerDetector/InDetTruth/InDetTruthAlgs/src/PRD_MultiTruthMaker.cxx
+++ b/InnerDetector/InDetTruth/InDetTruthAlgs/src/PRD_MultiTruthMaker.cxx
@@ -81,7 +81,7 @@ StatusCode PRD_MultiTruthMaker::finalize()
 }
 
 // -----------------------------------------------------------------------------------------------------
-StatusCode PRD_MultiTruthMaker::execute_r(const EventContext &ctx) const {
+StatusCode PRD_MultiTruthMaker::execute(const EventContext &ctx) const {
 
   ATH_MSG_DEBUG ("PRD_MultiTruthMaker::execute()");
 
diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.cxx b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.cxx
index 5aa001129a2d33d01169ebe8d8da1536455585a2..c986a0642bb8ce92abed5e2182001155641257f0 100644
--- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.cxx
+++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.cxx
@@ -32,7 +32,7 @@
 
 
 InDetPhysHitDecoratorAlg::InDetPhysHitDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator) :
-  AthAlgorithm(name,pSvcLocator),
+  AthReentrantAlgorithm(name,pSvcLocator),
   m_holeSearchTool("InDet::InDetTrackHoleSearchTool"),
   m_updatorHandle("Trk::KalmanUpdator/TrkKalmanUpdator"),
   m_residualPullCalculator("Trk::ResidualPullCalculator/ResidualPullCalculator"),
@@ -109,15 +109,9 @@ InDetPhysHitDecoratorAlg::finalize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode
-InDetPhysHitDecoratorAlg::execute() {
-  const EventContext context{ Gaudi::Hive::currentContext() };
-  return execute_r(context);
-}
-
 // to migrate to AthReentrantAlgorithm later
 StatusCode
-InDetPhysHitDecoratorAlg::execute_r(const EventContext &ctx) const {
+InDetPhysHitDecoratorAlg::execute(const EventContext &ctx) const {
   SG::ReadHandle<xAOD::TrackParticleContainer> ptracks(m_trkParticleName);
   if ((not ptracks.isValid())) {
     return StatusCode::FAILURE;
diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.h b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.h
index b1f08b4df07edcb7d79915fc43577bf96ae55a9e..8a95ee1049720f29c80cfb4ced9fc9e8985509ed 100644
--- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.h
+++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.h
@@ -12,7 +12,7 @@
  **/
 // STL includes
 #include <string>
-#include "AthenaBaseComps/AthAlgorithm.h"
+#include "AthenaBaseComps/AthReentrantAlgorithm.h"
 #include "GaudiKernel/ToolHandle.h"
 #include "xAODTracking/TrackParticleContainer.h"
 #include "StoreGate/WriteDecorHandle.h"
@@ -33,7 +33,7 @@ namespace Trk {
 
 
 // class to decorate xAOD::TruthParticles with additional information required by validation
-class InDetPhysHitDecoratorAlg: public AthAlgorithm {
+class InDetPhysHitDecoratorAlg: public AthReentrantAlgorithm {
 public:
   // L0PIXBARR : layer0 of pixel barrel (IBL in Run2)
   // PIXEL : in barrel all layers appart from layer0. In end-caps all disks/rings.
@@ -48,8 +48,7 @@ public:
   ~InDetPhysHitDecoratorAlg ();
   virtual StatusCode initialize() override;
   virtual StatusCode finalize()   override;
-  virtual StatusCode execute()    override;
-  virtual StatusCode execute_r(const EventContext &ctx) const;
+  virtual StatusCode execute(const EventContext &ctx) const;
 
 private:
   bool
diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.cxx b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.cxx
index b6f1a3e804214b6704607123ed3d0ba739e50834..454606b041994f9c6709dd90ce0fa308a16386ab 100644
--- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.cxx
+++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.cxx
@@ -27,7 +27,7 @@
 
 
 InDetPhysValTruthDecoratorAlg::InDetPhysValTruthDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator) :
-  AthAlgorithm(name, pSvcLocator),
+  AthReentrantAlgorithm(name, pSvcLocator),
   m_beamSpotSvc("BeamCondSvc", name) {
 }
 
@@ -71,14 +71,7 @@ InDetPhysValTruthDecoratorAlg::finalize() {
 }
 
 StatusCode
-InDetPhysValTruthDecoratorAlg::execute() {
-  const EventContext context{ Gaudi::Hive::currentContext() };
-  return execute_r(context);
-}
-
-// to migrate to AthReentrantAlgorithm later
-StatusCode
-InDetPhysValTruthDecoratorAlg::execute_r(const EventContext &ctx) const {
+InDetPhysValTruthDecoratorAlg::execute(const EventContext &ctx) const {
   SG::ReadHandle<xAOD::TruthParticleContainer> ptruth(m_truthParticleName);
   if ((not ptruth.isValid())) {
     return StatusCode::FAILURE;
diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.h b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.h
index 6a9ad9d4475c0cfa3324fa9d7629daad8ebfc2c5..11202a332889309cb371295bb057c9979ad01088 100644
--- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.h
+++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.h
@@ -13,7 +13,7 @@
 // STL includes
 #include <string>
 #include "xAODTruth/TruthParticleContainer.h"
-#include "AthenaBaseComps/AthAlgorithm.h"
+#include "AthenaBaseComps/AthReentrantAlgorithm.h"
 #include "GaudiKernel/ToolHandle.h"
 #include "GaudiKernel/ServiceHandle.h"
 #include "TrkExInterfaces/IExtrapolator.h"
@@ -29,17 +29,14 @@
 class IBeamCondSvc;
 
 // class to decorate xAOD::TruthParticles with additional information required by validation
-class InDetPhysValTruthDecoratorAlg: public AthAlgorithm {
+class InDetPhysValTruthDecoratorAlg: public AthReentrantAlgorithm {
 public:
   InDetPhysValTruthDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator);
   virtual
   ~InDetPhysValTruthDecoratorAlg ();
   virtual StatusCode initialize();
   virtual StatusCode finalize();
-  virtual StatusCode execute() override;
-
-  // to migrate to AthReentrantAlgorithm later
-  virtual StatusCode execute_r(const EventContext &ctx) const;
+  virtual StatusCode execute(const EventContext &ctx) const;
 
 private:
   bool decorateTruth(const xAOD::TruthParticle& particle,
diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.cxx b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.cxx
index f8d5d429ee12d5756a2c00d11e345fb62695048f..0f7ebce677ff7f983860e9bde493d00e0d943e19 100644
--- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.cxx
+++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.cxx
@@ -44,7 +44,7 @@ ParameterErrDecoratorAlg::finalize() {
 }
 
 StatusCode
-ParameterErrDecoratorAlg::execute_r(const EventContext &ctx) const {
+ParameterErrDecoratorAlg::execute(const EventContext &ctx) const {
   SG::ReadHandle<xAOD::TrackParticleContainer> ptracks(m_trkParticleName);
   if ((not ptracks.isValid())) {
     return StatusCode::FAILURE;
diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.h b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.h
index a9850f563f07cb90e003758f3ef4ee3429fa19b3..02ad809325d407a51bcac8acb3cd10e668d9d6aa 100644
--- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.h
+++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.h
@@ -28,7 +28,7 @@ public:
   ~ParameterErrDecoratorAlg();
   virtual StatusCode initialize();
   virtual StatusCode finalize();
-  virtual StatusCode execute_r(const EventContext &ctx) const;
+  virtual StatusCode execute(const EventContext &ctx) const;
 private:
   virtual bool decorateTrack(const xAOD::TrackParticle& particle,
                              std::vector< SG::WriteDecorHandle<xAOD::TrackParticleContainer,float> > &float_decor) const;
diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.cxx b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.cxx
index 5a83ab72e827e7e751cec6ba65496e905aac0b36..dcc8674da31f1f9ba0bf34efca0f358843f59b7a 100644
--- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.cxx
+++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.cxx
@@ -13,7 +13,7 @@
 
 
 TruthClassDecoratorAlg::TruthClassDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator) :
-  AthAlgorithm(name,pSvcLocator)
+  AthReentrantAlgorithm(name,pSvcLocator)
 {
 }
 
@@ -37,15 +37,9 @@ TruthClassDecoratorAlg::finalize() {
 }
 
 
-StatusCode
-TruthClassDecoratorAlg::execute() {
-  const EventContext context{ Gaudi::Hive::currentContext() };
-  return execute_r(context);
-}
-
 // to migrate to AthReentrantAlgorithm later
 StatusCode
-TruthClassDecoratorAlg::execute_r(const EventContext &ctx) const {
+TruthClassDecoratorAlg::execute(const EventContext &ctx) const {
   SG::ReadHandle<xAOD::TruthParticleContainer> ptruth(m_truthParticleName);
   if ((not ptruth.isValid())) {
     return StatusCode::FAILURE;
diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.h b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.h
index 8284785db4e209099c4b96de0f0488b6d3e028a8..2cb5b6b9d0c73968da18d1947bd651cf578bbd34 100644
--- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.h
+++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.h
@@ -13,7 +13,7 @@
 // STL includes
 #include <string>
 #include "xAODTruth/TruthParticleContainer.h"
-#include "AthenaBaseComps/AthAlgorithm.h"
+#include "AthenaBaseComps/AthReentrantAlgorithm.h"
 #include "GaudiKernel/ToolHandle.h"
 #include "GaudiKernel/EventContext.h"
 #include "StoreGate/WriteDecorHandleKey.h"
@@ -24,7 +24,7 @@
 #include "InDetPhysValMonitoring/IAthSelectionTool.h"
 
 // class to decorate xAOD::TruthParticles with type and origin, required by validation
-class TruthClassDecoratorAlg: public AthAlgorithm {
+class TruthClassDecoratorAlg: public AthReentrantAlgorithm {
 public:
   TruthClassDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator);
   virtual ~TruthClassDecoratorAlg () {/*nop*/
@@ -32,10 +32,7 @@ public:
   virtual StatusCode initialize() override;
   virtual StatusCode finalize() override;
 
-  virtual StatusCode execute() override;
-
-  // to migrate to AthReentrantAlgorithm later
-  virtual StatusCode execute_r(const EventContext &ctx) const;
+  virtual StatusCode execute(const EventContext &ctx) const;
 
 private:
   bool decorateTruth(const xAOD::TruthParticle& particle,
diff --git a/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/InDetTrackClusterAssValidation/TrackClusterAssValidation.h b/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/InDetTrackClusterAssValidation/TrackClusterAssValidation.h
index 2c5e0093f483da0bc5efda104b76cba2514c7b63..a90bdc2c0dd158fcb1fe14f46978fecbfbbf1290 100755
--- a/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/InDetTrackClusterAssValidation/TrackClusterAssValidation.h
+++ b/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/InDetTrackClusterAssValidation/TrackClusterAssValidation.h
@@ -85,7 +85,7 @@ namespace InDet {
       TrackClusterAssValidation(const std::string &name, ISvcLocator *pSvcLocator);
       virtual ~TrackClusterAssValidation() {}
       StatusCode initialize();
-      StatusCode execute_r(const EventContext& ctx) const;
+      StatusCode execute(const EventContext& ctx) const;
       StatusCode finalize();
 
     protected:
diff --git a/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/src/TrackClusterAssValidation.cxx b/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/src/TrackClusterAssValidation.cxx
index 8e4affef115d6f289d91aa5941f38d9c867a3732..17649691cbed6963ac4f4751aa9b942f21b75aba 100755
--- a/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/src/TrackClusterAssValidation.cxx
+++ b/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/src/TrackClusterAssValidation.cxx
@@ -144,7 +144,7 @@ StatusCode InDet::TrackClusterAssValidation::initialize()
 // Execute
 ///////////////////////////////////////////////////////////////////
 
-StatusCode InDet::TrackClusterAssValidation::execute_r(const EventContext& ctx) const
+StatusCode InDet::TrackClusterAssValidation::execute(const EventContext& ctx) const
 {
 
   if(!m_usePIX && !m_useSCT) return StatusCode::SUCCESS;
diff --git a/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/HoleSearchValidation.h b/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/HoleSearchValidation.h
index f896325e29e459a686c63266d47a8f4652b0e03b..770427d5a4a667ba9ef0227f44d4e16d0a7879ab 100755
--- a/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/HoleSearchValidation.h
+++ b/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/HoleSearchValidation.h
@@ -58,7 +58,7 @@ namespace InDet {
     /** standard Athena-Algorithm method */
     StatusCode          initialize();
     /** standard Athena-Algorithm method */
-    StatusCode          execute_r(const EventContext& ctx) const;
+    StatusCode          execute(const EventContext& ctx) const;
     /** standard Athena-Algorithm method */
     StatusCode          finalize();
 
diff --git a/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/InDetSplittedTracksCreator.h b/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/InDetSplittedTracksCreator.h
index 1e40a80f9123325f7ea57d963a947027a6224ecf..6fd969ce5e6185c299862832f5be9380196da921 100644
--- a/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/InDetSplittedTracksCreator.h
+++ b/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/InDetSplittedTracksCreator.h
@@ -35,7 +35,7 @@ public:
     /** standard Athena-Algorithm method */
     StatusCode          initialize();
     /** standard Athena-Algorithm method */
-    StatusCode execute_r(const EventContext& ctx) const;
+    StatusCode execute(const EventContext& ctx) const;
     /** standard Athena-Algorithm method */
     StatusCode          finalize();
 
diff --git a/InnerDetector/InDetValidation/InDetTrackValidation/src/HoleSearchValidation.cxx b/InnerDetector/InDetValidation/InDetTrackValidation/src/HoleSearchValidation.cxx
index 6186436a7cbcd0ff6f02874f34d13e63b9eeabe8..6322b581f67aaae23f2caf45a316f14f4823bb91 100755
--- a/InnerDetector/InDetValidation/InDetTrackValidation/src/HoleSearchValidation.cxx
+++ b/InnerDetector/InDetValidation/InDetTrackValidation/src/HoleSearchValidation.cxx
@@ -154,7 +154,7 @@ StatusCode HoleSearchValidation::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode HoleSearchValidation::execute_r(const EventContext& ctx) const {
+StatusCode HoleSearchValidation::execute(const EventContext& ctx) const {
 
   std::array<bool,Parts::kNParts> remove_parts;
   for (unsigned int part_i=0; part_i<Parts::kNParts; ++part_i) {
diff --git a/InnerDetector/InDetValidation/InDetTrackValidation/src/InDetSplittedTracksCreator.cxx b/InnerDetector/InDetValidation/InDetTrackValidation/src/InDetSplittedTracksCreator.cxx
index 4376a4523bb9197cd3f4bf269e6160bbb8ac9fe5..cd5604f465281c1614aaa478b67e5a36df682d64 100644
--- a/InnerDetector/InDetValidation/InDetTrackValidation/src/InDetSplittedTracksCreator.cxx
+++ b/InnerDetector/InDetValidation/InDetTrackValidation/src/InDetSplittedTracksCreator.cxx
@@ -47,7 +47,7 @@ StatusCode InDet::InDetSplittedTracksCreator::initialize(){
    return StatusCode::SUCCESS;
 }   
 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
-StatusCode InDet::InDetSplittedTracksCreator::execute_r(const EventContext& ctx) const {
+StatusCode InDet::InDetSplittedTracksCreator::execute(const EventContext& ctx) const {
    ATH_MSG_DEBUG("InDetSplittedTracksCreator execute()");
    ATH_MSG_DEBUG("Input Track Collection: " << m_TrackCol);
 
diff --git a/LArCalorimeter/LArCellRec/share/LArCellBuilderFromLArHitTool_test.ref b/LArCalorimeter/LArCellRec/share/LArCellBuilderFromLArHitTool_test.ref
index a5f028aaf96c29f0d4c3c06f8b35900d94e2572b..051220ee50516696ec0782547ddeb99384b577d2 100644
--- a/LArCalorimeter/LArCellRec/share/LArCellBuilderFromLArHitTool_test.ref
+++ b/LArCalorimeter/LArCellRec/share/LArCellBuilderFromLArHitTool_test.ref
@@ -1,14 +1,14 @@
-Sat Nov 10 05:32:00 CET 2018
+Thu Dec  6 05:01:02 CET 2018
 Preloading tcmalloc_minimal.so
 Py:Athena            INFO including file "AthenaCommon/Preparation.py"
-Py:Athena            INFO using release [AthenaWorkDir-22.0.1] [x86_64-slc6-gcc62-dbg] [atlas-work3/6f2b6978e1b] -- built on [2018-11-10T0506]
+Py:Athena            INFO using release [AthenaWorkDir-22.0.1] [x86_64-slc6-gcc62-opt] [atlas-work3/fa0fd6d0989] -- built on [2018-12-06T0405]
 Py:Athena            INFO including file "AthenaCommon/Atlas.UnixStandardJob.py"
 Py:Athena            INFO executing ROOT6Setup
 Py:Athena            INFO including file "AthenaCommon/Execution.py"
 Py:Athena            INFO including file "LArCellRec/LArCellBuilderFromLArHitTool_test.py"
 [?1034hSetGeometryVersion.py obtained major release version 22
 Py:Athena            INFO including file "IdDictDetDescrCnv/IdDictDetDescrCnv_joboptions.py"
-Py:ConfigurableDb    INFO Read module info for 5558 configurables from 52 genConfDb files
+Py:ConfigurableDb    INFO Read module info for 5473 configurables from 52 genConfDb files
 Py:ConfigurableDb    INFO No duplicates have been found: that's good !
 EventInfoMgtInit: Got release version  Athena-22.0.1
 Py:IOVDbSvc.CondDB    INFO Setting up conditions DB access to instance OFLP200
@@ -42,8 +42,8 @@ ApplicationMgr       INFO Updating Gaudi::PluginService::SetDebug(level) to leve
 ApplicationMgr       INFO Updating Gaudi::PluginService::SetDebug(level) to level= 'PluginDebugLevel':0
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v30r4)
-                                          running on lxplus051.cern.ch on Sat Nov 10 05:32:19 2018
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v30r5)
+                                          running on lxplus077.cern.ch on Thu Dec  6 05:01:24 2018
 ====================================================================================================================================
 ApplicationMgr       INFO Successfully loaded modules : AthenaServices
 ApplicationMgr       INFO Application Manager Configured successfully
@@ -60,8 +60,8 @@ PoolSvc              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.x
 PoolSvc              INFO Set connectionsvc retry/timeout/IDLE timeout to  'ConnectionRetrialPeriod':300/ 'ConnectionRetrialTimeOut':3600/ 'ConnectionTimeOut':5 seconds with connection cleanup disabled
 PoolSvc              INFO Frontier compression level set to 5
 DBReplicaSvc         INFO Frontier server at (serverurl=http://atlasfrontier-local.cern.ch:8000/atlr)(serverurl=http://atlasfrontier-ai.cern.ch:8000/atlr)(serverurl=http://lcgft-atlas.gridpp.rl.ac.uk:3128/frontierATLAS)(serverurl=http://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy-wigner.cern.ch:3128)(proxyurl=http://atlasbpfrontier.cern.ch:3127)(proxyurl=http://atlasbpfrontier.fnal.gov:3127) will be considered for COOL data
-DBReplicaSvc         INFO Read replica configuration from /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/dbreplica.config
-DBReplicaSvc         INFO Total of 10 servers found for host lxplus051.cern.ch [ATLF ATLAS_COOLPROD atlas_dd ATLAS_CONFIG INT8R INTR ATONR_COOL ATONR_CONF DEVDB11 ATLF ]
+DBReplicaSvc         INFO Read replica configuration from /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/dbreplica.config
+DBReplicaSvc         INFO Total of 10 servers found for host lxplus077.cern.ch [ATLF ATLAS_COOLPROD atlas_dd ATLAS_CONFIG INT8R INTR ATONR_COOL ATONR_CONF DEVDB11 ATLF ]
 PoolSvc              INFO Successfully setup replica sorting algorithm
 PoolSvc              INFO Setting up APR FileCatalog and Streams
 PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
@@ -77,14 +77,14 @@ IOVDbSvc             INFO Global tag: OFLCOND-RUN12-SDR-35 set from joboptions
 IOVDbSvc             INFO Folder /LAR/Identifier/OnOffIdMap, adding new key tag with value LARIdentifierOnOffIdMap-012
 IOVDbSvc             INFO Folder /LAR/Identifier/CalibIdMap, adding new key tag with value LARIdentifierCalibIdMap-012
 IOVDbSvc             INFO Folder /LAR/Identifier/FebRodMap, adding new key tag with value LARIdentifierFebRodMap-005
-IOVDbSvc             INFO Read from meta data only for folder /TagInfo
+IOVDbFolder          INFO Read from meta data only for folder /TagInfo
 IOVDbSvc             INFO Initialised with 3 connections and 24 folders
 IOVDbSvc             INFO Service IOVDbSvc initialised successfully
 IOVDbSvc             INFO preLoadAddresses: Removing folder /TagInfo. It should only be in the file meta data and was not found.
 IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
 IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
 IOVSvcTool           INFO IOVRanges will be checked at every Event
-ClassIDSvc           INFO  getRegistryEntries: read 2132 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 2134 CLIDRegistry entries for module ALL
 IOVDbSvc             INFO Opening COOL connection for COOLOFL_CALO/OFLP200
 IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
 IOVDbSvc             INFO Disconnecting from COOLOFL_CALO/OFLP200
@@ -112,7 +112,7 @@ IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/LArTTCellMapA
 IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/fSampl
 IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/uA2MeV
 ClassIDSvc           INFO  getRegistryEntries: read 17 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 5227 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 2879 CLIDRegistry entries for module ALL
 ClassIDSvc           INFO  getRegistryEntries: read 18 CLIDRegistry entries for module ALL
 DetDescrCnvSvc       INFO  initializing 
 DetDescrCnvSvc       INFO Found DetectorStore service
@@ -201,12 +201,12 @@ EndcapDMConstru...   INFO Start building EC electronics geometry
   multi-layered version of absorbers activated, mlabs == 1
 ================================================
 EndcapDMConstru...   INFO Start building EC electronics geometry
-GeoModelSvc          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 28072Kb 	 Time = 1.51S
+GeoModelSvc          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 21904Kb 	 Time = 0.75S
 ClassIDSvc           INFO  getRegistryEntries: read 213 CLIDRegistry entries for module ALL
 ClassIDSvc           INFO  getRegistryEntries: read 65 CLIDRegistry entries for module ALL
 AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 6828 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 670 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 6826 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 605 CLIDRegistry entries for module ALL
 CondInputLoader      INFO Initializing CondInputLoader...
 CondInputLoader      INFO Adding base classes:
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/BadChannels/MissingFEBs' )   ->
@@ -276,15 +276,15 @@ CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_ID helper object in th
 AtlasDetectorID      INFO initialize_from_dictionary - OK
 CaloIDHelper_ID...   INFO in createObj: creating a LArFCAL_ID helper object in the detector store
 AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCal2DNeighbors-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCal3DNeighborsNext-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCal3DNeighborsPrev-April2011.txt
+LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCal2DNeighbors-April2011.txt
+LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCal3DNeighborsNext-April2011.txt
+LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCal3DNeighborsPrev-April2011.txt
 CaloIDHelper_ID...   INFO in createObj: creating a LArMiniFCAL_ID helper object in the detector store
 AtlasDetectorID      INFO initialize_from_dictionary - OK
 LArMiniFCAL_ID       INFO  initialize_from_dict - LArCalorimeter dictionary does NOT contain miniFCAL description. Unable to initialize LArMiniFCAL_ID.
 CaloIDHelper_ID...   INFO in createObj: creating a TileID helper object in the detector store
 AtlasDetectorID      INFO initialize_from_dictionary - OK
-TileNeighbour        INFO Reading file  /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/TileNeighbour_reduced.txt
+TileNeighbour        INFO Reading file  /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/TileNeighbour_reduced.txt
 AtlasDetectorID      INFO initialize_from_dictionary - OK
 CaloIdMgrDetDes...   INFO in createObj: creating a CaloDescrManager object in the detector store
 CaloIDHelper_ID...   INFO in createObj: creating a CaloDM_ID helper object in the detector store
@@ -303,28 +303,28 @@ CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_SuperCell_ID helper ob
 AtlasDetectorID      INFO initialize_from_dictionary - OK
 CaloIDHelper_ID...   INFO in createObj: creating a LArFCAL_SuperCell_ID helper object in the detector store
 AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCalSuperCells2DNeighborsNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCalSuperCells3DNeighborsPrevNew-April2014.txt
+LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
+LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
+LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCalSuperCells3DNeighborsPrevNew-April2014.txt
 CaloIDHelper_ID...   INFO in createObj: creating a Tile_SuperCell_ID helper object in the detector store
 AtlasDetectorID      INFO initialize_from_dictionary - OK
-TileNeighbour        INFO Reading file  /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/TileSuperCellNeighbour.txt
+TileNeighbour        INFO Reading file  /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/TileSuperCellNeighbour.txt
 AtlasDetectorID      INFO initialize_from_dictionary - OK
 CaloIdMgrDetDes...   INFO  Finished 
 CaloIdMgrDetDes...   INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
 DetectorStore     WARNING retrieve(default): No valid proxy for default object 
  of type TileDetDescrManager(CLID 2941)
 CaloMgrDetDescrCnvWARNING Could not get the TileDetectorManager. No Calo Elements will be built for Tile
- <ROOT.CaloDetDescrManager object at 0x16d1ba40>
-ClassIDSvc           INFO  getRegistryEntries: read 4258 CLIDRegistry entries for module ALL
+ <ROOT.CaloDetDescrManager object at 0x1679d480>
+ClassIDSvc           INFO  getRegistryEntries: read 4203 CLIDRegistry entries for module ALL
 ToolSvc.tool1em      INFO  No threshold on hit energy 
 ToolSvc.tool1em      INFO THRESHOLD CHOICE : No Threshold !
 ToolSvc.CaloNoi...   INFO CaloNoiseTool called ToolSvc.CaloNoiseToolDefault initialize() begin
 LArOnlineIDDetD...   INFO in createObj: creating a LArOnlineID helper object in the detector store
 LArOnlineID          INFO initialize_from_dictionary
 AtlasDetectorID      INFO initialize_from_dictionary - OK
-ClassIDSvc           INFO  getRegistryEntries: read 2826 CLIDRegistry entries for module ALL
-IOVSvcTool           INFO Still in initialize phase, not tiggering callback for LArCablingService[0x29631e00]+7f1ebdd81054 bound to AthenaAttributeList[/LAR/Identifier/OnOffIdMap]
+ClassIDSvc           INFO  getRegistryEntries: read 2605 CLIDRegistry entries for module ALL
+IOVSvcTool           INFO Still in initialize phase, not tiggering callback for LArCablingService[0x1cd28a00]+7f3320d16630 bound to AthenaAttributeList[/LAR/Identifier/OnOffIdMap]
 ToolSvc.LArCabl...   INFO Successfully installed callback on folder/LAR/Identifier/OnOffIdMap
 ToolSvc.LArCabl...   INFO Successfully installed callback on folder/LAR/Identifier/CalibIdMap
 ToolSvc.LArCabl...   INFO Successfully installed callback on folder/LAR/Identifier/FebRodMap
@@ -334,7 +334,7 @@ ToolSvc.LArADC2...   INFO Registered callback for key: LArDAC2uA
 ToolSvc.LArADC2...   INFO Registered callback for key: LAruA2MeV
 ToolSvc.LArADC2...   INFO Registered callback for key: LArMphysOverMcal
 ToolSvc.LArADC2...   INFO Registered callback for key: LArHVScaleCorr
-IOVSvcTool           INFO Still in initialize phase, not tiggering callback for LArMCSymTool[0x29633200]+189 bound to /LAR/Identifier/FebRodMap
+IOVSvcTool           INFO Still in initialize phase, not tiggering callback for LArMCSymTool[0x1cd29e00]+189 bound to /LAR/Identifier/CalibIdMap
 ClassIDSvc           INFO  getRegistryEntries: read 53 CLIDRegistry entries for module ALL
 ToolSvc.LArAuto...   INFO Registered callback for key: LArShape
 ToolSvc.LArAuto...   INFO Registered callback for key: LArAutoCorr
@@ -342,19 +342,19 @@ ToolSvc.LArOFCT...   INFO Registered callback for key: LArShape
 ToolSvc.LArOFCT...   INFO Registered callback for key: LArNoise
 ToolSvc.LArOFCT...   INFO Registered callback for LArOFCTool/LArAutoCorrTotalTool
 ToolSvc.CaloNoi...   INFO Will cache electronic noise
-IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArNoiseMC[LArNoise]
+IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArNoiseMC[LArNoise]
 ToolSvc.CaloNoi...   INFO Registered callback for key: LArNoise
-IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArAutoCorrMC[LArAutoCorr]
+IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArAutoCorrMC[LArAutoCorr]
 ToolSvc.CaloNoi...   INFO Registered callback for key: LArAutoCorr
-IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArShape32MC[LArShape]
+IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArShape32MC[LArShape]
 ToolSvc.CaloNoi...   INFO Registered callback for key: LArShape
-IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArfSamplMC[LArfSampl]
+IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArfSamplMC[LArfSampl]
 ToolSvc.CaloNoi...   INFO Registered callback for key: LArfSampl
-IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArMinBiasMC[LArMinBias]
+IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArMinBiasMC[LArMinBias]
 ToolSvc.CaloNoi...   INFO Registered callback for key: LArMinBias
-IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArRamp
+IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArDAC2uA
 ToolSvc.CaloNoi...   INFO Registered callbacks for LArADC2MeVTool -> CaloNoiseTool
-IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArShape
+IOVSvcTool           INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArAutoCorr
 ToolSvc.CaloNoi...   INFO Registered callbacks for LArOFCTool -> CaloNoiseTool
 ToolSvc.CaloNoi...   INFO CaloNoiseTool initialize() end
 ToolSvc.tool1em      INFO  no noise selected 
@@ -433,26 +433,24 @@ EventPersistenc...   INFO Added successfully Conversion service:AthenaPoolCnvSvc
 EventPersistenc...   INFO Added successfully Conversion service:TagInfoMgr
 ClassIDSvc           INFO  getRegistryEntries: read 109 CLIDRegistry entries for module ALL
 IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARAlign-IOVDEP-00 for folder /LAR/Align
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArBadChannelsBadChannels-IOVDEP-06 for folder /LAR/BadChannels/BadChannels
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArBadChannelsMissingFEBs-IOVDEP-04 for folder /LAR/BadChannels/MissingFEBs
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCAutoCorr-Apr2010 for folder /LAR/ElecCalibMC/AutoCorr
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArCellPositionShift-ideal for folder /LAR/LArCellPositionShift
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCDAC2uA-CSC02-J for folder /LAR/ElecCalibMC/DAC2uA
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCHVScaleCorr-IOVDEP-00 for folder /LAR/ElecCalibMC/HVScaleCorr
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMinBias-IOVDEP-01 for folder /LAR/ElecCalibMC/MinBias
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMinBiasAverage-IOVDEP-01 for folder /LAR/ElecCalibMC/MinBiasAverage
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMphysOverMcal-CSC02-I for folder /LAR/ElecCalibMC/MphysOverMcal
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCNoise-Apr2010 for folder /LAR/ElecCalibMC/Noise
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCPedestal-DC3-B-IdFix7 for folder /LAR/ElecCalibMC/Pedestal
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCRamp-CSC02-K for folder /LAR/ElecCalibMC/Ramp
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCShape-Apr2010 for folder /LAR/ElecCalibMC/Shape
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARIdentifierLArTTCellMapAtlas-HadFcalFix2 for folder /LAR/Identifier/LArTTCellMapAtlas
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCfSampl-G496-19213-FTFP_BERT_BIRK for folder /LAR/ElecCalibMC/fSampl
-IOVDbSvc             INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARuA2MeV-Feb2011 for folder /LAR/ElecCalibMC/uA2MeV
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARAlign-IOVDEP-00 for folder /LAR/Align
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArBadChannelsBadChannels-IOVDEP-06 for folder /LAR/BadChannels/BadChannels
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArBadChannelsMissingFEBs-IOVDEP-04 for folder /LAR/BadChannels/MissingFEBs
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCAutoCorr-Apr2010 for folder /LAR/ElecCalibMC/AutoCorr
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArCellPositionShift-ideal for folder /LAR/LArCellPositionShift
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCDAC2uA-CSC02-J for folder /LAR/ElecCalibMC/DAC2uA
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCHVScaleCorr-IOVDEP-00 for folder /LAR/ElecCalibMC/HVScaleCorr
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMinBias-IOVDEP-01 for folder /LAR/ElecCalibMC/MinBias
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMinBiasAverage-IOVDEP-01 for folder /LAR/ElecCalibMC/MinBiasAverage
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMphysOverMcal-CSC02-I for folder /LAR/ElecCalibMC/MphysOverMcal
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCNoise-Apr2010 for folder /LAR/ElecCalibMC/Noise
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCPedestal-DC3-B-IdFix7 for folder /LAR/ElecCalibMC/Pedestal
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCRamp-CSC02-K for folder /LAR/ElecCalibMC/Ramp
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCShape-Apr2010 for folder /LAR/ElecCalibMC/Shape
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARIdentifierLArTTCellMapAtlas-HadFcalFix2 for folder /LAR/Identifier/LArTTCellMapAtlas
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCfSampl-G496-19213-FTFP_BERT_BIRK for folder /LAR/ElecCalibMC/fSampl
+IOVDbFolder          INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARuA2MeV-Feb2011 for folder /LAR/ElecCalibMC/uA2MeV
 IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
 Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] EACFEBD4-9BD2-E211-848A-02163E006B20
 Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000057.gen.COND/cond09_mc.000057.gen.COND._0001.pool.root
 RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000057.gen.COND/cond09_mc.000057.gen.COND._0001.pool.root File version:52200
@@ -476,9 +474,13 @@ RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond
 Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] D27D07D4-C135-E011-84A9-003048F0E01E
 Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000027.gen.COND/cond09_mc.000027.gen.COND._0001.pool.root
 RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000027.gen.COND/cond09_mc.000027.gen.COND._0001.pool.root File version:52600
+/cvmfs/atlas-co...   INFO Database being retired...
+Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] EACFEBD4-9BD2-E211-848A-02163E006B20
 Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 7C42BC12-BD96-E011-B8EC-003048F0E01C
 Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000032.gen.COND/cond09_mc.000032.gen.COND._0001.pool.root
 RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000032.gen.COND/cond09_mc.000032.gen.COND._0001.pool.root File version:52600
+/cvmfs/atlas-co...   INFO Database being retired...
+Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
 Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 303FCBD8-653E-DD11-ABBD-000423D99862
 Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/oflcond/oflcond.000003.conditions.simul.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0061.pool.root
 RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/oflcond/oflcond.000003.conditions.simul.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0061.pool.root File version:51800
@@ -584,17 +586,19 @@ Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/r
 Warning in <TClass::Init>: no dictionary for class DataHeader_p1 is available
 Warning in <TClass::Init>: no dictionary for class DataHeaderElement_p1 is available
 RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cmccond/cmccond.000001.conditions.simul.pool.v0000/oflcond.000002.conditions.simul.pool.v0000._0053.pool.root__DQ2-1250193473 File version:51000
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/oflcond/oflcond.000003.conditions.simul.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0061.pool.root File version:51800
 /cvmfs/atlas-co...   INFO Database being retired...
 Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] FE8535CE-AD50-DC11-952F-000423D67862
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000009.gen.COND/cond09_mc.000009.gen.COND._0013.pool.root File version:52200
+RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/oflcond/oflcond.000003.conditions.simul.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0061.pool.root File version:51800
 /cvmfs/atlas-co...   INFO Database being retired...
 Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662
+RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000009.gen.COND/cond09_mc.000009.gen.COND._0013.pool.root File version:52200
+/cvmfs/atlas-co...   INFO Database being retired...
+Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 9229AE70-AC4C-DF11-A934-003048D2BC4A
 Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 445FAD9A-5DB3-E14A-81DB-BA6244602734
 Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000084.gen.COND/cond09_mc.000084.gen.COND._0001.pool.root
 RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000084.gen.COND/cond09_mc.000084.gen.COND._0001.pool.root File version:53413
 /cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 9229AE70-AC4C-DF11-A934-003048D2BC4A
+Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 180A4AF2-F47E-DB11-9E8F-000E0C4DEA2D
 RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000027.gen.COND/cond09_mc.000027.gen.COND._0001.pool.root File version:52600
 /cvmfs/atlas-co...   INFO Database being retired...
 Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 303FCBD8-653E-DD11-ABBD-000423D99862
@@ -619,15 +623,8 @@ LArSymCondition...   INFO recorded new LArMinBiasAverageSym with range {[0,l:0]
 LArSymCondition...   INFO recorded new LArShapeSym with range {[0,l:0] - [INVALID]} into Conditions Store
 LArSymCondition...   INFO recorded new LArMphysOverMcalSym with range {[0,l:0] - [INVALID]} into Conditions Store
 xAODMaker::Even...WARNING xAOD::EventInfo with key "EventInfo" is already in StoreGate; EventInfoCnvAlg should not be scheduled.
-ClassIDSvc           INFO  getRegistryEntries: read 2254 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 1223 CLIDRegistry entries for module ALL
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #1, run #1 1 events processed so far  <<<===
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] EACFEBD4-9BD2-E211-848A-02163E006B20
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 180A4AF2-F47E-DB11-9E8F-000E0C4DEA2D
-Domain[ROOT_All]     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #2, run #1 1 events processed so far  <<<===
 ClassIDSvc           INFO  getRegistryEntries: read 708 CLIDRegistry entries for module ALL
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #2, run #1 2 events processed so far  <<<===
@@ -652,16 +649,19 @@ ToolSvc.tool5fcal WARNING  windows not reimplemented yet
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #5, run #1 5 events processed so far  <<<===
 /cvmfs/atlas-co...   INFO Database being retired...
 /cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] D27D07D4-C135-E011-84A9-003048F0E01E
-/cvmfs/atlas-co...   INFO Database being retired...
 /cvmfs/atlas-co...   INFO Database being retired...
 /cvmfs/atlas-co...   INFO Database being retired...
 /cvmfs/atlas-co...   INFO Database being retired...
 /cvmfs/atlas-co...   INFO Database being retired...
 Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] F4885664-6C4D-DF11-A94A-00304867340C
 /cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 445FAD9A-5DB3-E14A-81DB-BA6244602734
 /cvmfs/atlas-co...   INFO Database being retired...
+Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] D27D07D4-C135-E011-84A9-003048F0E01E
+/cvmfs/atlas-co...   INFO Database being retired...
+/cvmfs/atlas-co...   INFO Database being retired...
+/cvmfs/atlas-co...   INFO Database being retired...
+/cvmfs/atlas-co...   INFO Database being retired...
+Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 445FAD9A-5DB3-E14A-81DB-BA6244602734
 /cvmfs/atlas-co...   INFO Database being retired...
 Domain[ROOT_All]     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
 ApplicationMgr       INFO Application Manager Stopped successfully
@@ -671,42 +671,42 @@ testalg1             INFO Finalizing testalg1...
 IncidentProcAlg2     INFO Finalize
 PyComponentMgr       INFO Finalizing PyComponentMgr...
 IdDictDetDescrCnv    INFO in finalize
-IOVDbSvc             INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.24 ))s
-IOVDbSvc             INFO Folder /LAR/BadChannels/BadChannels (AttrListColl) db-read 1/1 objs/chan/bytes 0/8/0 ((     0.05 ))s
-IOVDbSvc             INFO Folder /LAR/BadChannels/MissingFEBs (AttrList) db-read 1/1 objs/chan/bytes 1/1/16 ((     0.05 ))s
-IOVDbSvc             INFO Folder /LAR/Identifier/CalibIdMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/1520148 ((     0.07 ))s
-IOVDbSvc             INFO Folder /LAR/Identifier/FebRodMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/6100 ((     0.19 ))s
-IOVDbSvc             INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/780292 ((     0.33 ))s
-IOVDbSvc             INFO Folder /CALO/Ofl/Identifier/CaloTTOnAttrIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
-IOVDbSvc             INFO Folder /CALO/Ofl/Identifier/CaloTTOnOffIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
-IOVDbSvc             INFO Folder /CALO/Ofl/Identifier/CaloTTPpmRxIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/AutoCorr (PoolColl) db-read 1/2 objs/chan/bytes 3/3/486 ((     0.05 ))s
-IOVDbSvc             INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     0.03 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/DAC2uA (PoolColl) db-read 1/2 objs/chan/bytes 1/1/170 ((     0.04 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/HVScaleCorr (PoolColl) db-read 1/2 objs/chan/bytes 12/12/1980 ((     0.18 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/MinBias (PoolColl) db-read 1/2 objs/chan/bytes 1/1/174 ((     0.08 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/MinBiasAverage (PoolColl) db-read 1/1 objs/chan/bytes 1/1/181 ((     0.04 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/MphysOverMcal (PoolColl) db-read 1/2 objs/chan/bytes 3/3/516 ((     0.04 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/Noise (PoolColl) db-read 1/2 objs/chan/bytes 3/3/516 ((     0.05 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/Pedestal (PoolRef) db-read 1/1 objs/chan/bytes 1/1/167 ((     0.04 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/Ramp (PoolColl) db-read 1/2 objs/chan/bytes 3/3/489 ((     0.05 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/Shape (PoolColl) db-read 1/2 objs/chan/bytes 3/3/477 ((     0.04 ))s
-IOVDbSvc             INFO Folder /LAR/Identifier/LArTTCellMapAtlas (PoolRef) db-read 1/0 objs/chan/bytes 1/1/173 ((     0.04 ))s
-IOVDbSvc          WARNING Folder /LAR/Identifier/LArTTCellMapAtlas is requested but no data retrieved
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/fSampl (PoolColl) db-read 1/2 objs/chan/bytes 1/1/194 ((     0.06 ))s
-IOVDbSvc             INFO Folder /LAR/ElecCalibMC/uA2MeV (PoolColl) db-read 1/2 objs/chan/bytes 1/1/165 ((     0.11 ))s
-IOVDbSvc             INFO Total payload read from COOL: 2312609 bytes in ((      1.78 ))s
+IOVDbFolder          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.84 ))s
+IOVDbFolder          INFO Folder /LAR/BadChannels/BadChannels (AttrListColl) db-read 1/1 objs/chan/bytes 0/8/0 ((     0.99 ))s
+IOVDbFolder          INFO Folder /LAR/BadChannels/MissingFEBs (AttrList) db-read 1/1 objs/chan/bytes 1/1/16 ((     0.55 ))s
+IOVDbFolder          INFO Folder /LAR/Identifier/CalibIdMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/1520148 ((     0.52 ))s
+IOVDbFolder          INFO Folder /LAR/Identifier/FebRodMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/6100 ((     0.01 ))s
+IOVDbFolder          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/780292 ((     0.07 ))s
+IOVDbFolder          INFO Folder /CALO/Ofl/Identifier/CaloTTOnAttrIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
+IOVDbFolder          INFO Folder /CALO/Ofl/Identifier/CaloTTOnOffIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
+IOVDbFolder          INFO Folder /CALO/Ofl/Identifier/CaloTTPpmRxIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/AutoCorr (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/486 ((     0.59 ))s
+IOVDbFolder          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     0.43 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/DAC2uA (PoolRefColl) db-read 1/2 objs/chan/bytes 1/1/170 ((     0.48 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/HVScaleCorr (PoolRefColl) db-read 1/2 objs/chan/bytes 12/12/1980 ((     0.49 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/MinBias (PoolRefColl) db-read 1/2 objs/chan/bytes 1/1/174 ((     0.49 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/MinBiasAverage (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/181 ((     0.50 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/MphysOverMcal (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/516 ((     0.41 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/Noise (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/516 ((     0.49 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/Pedestal (PoolRef) db-read 1/1 objs/chan/bytes 1/1/167 ((     2.22 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/Ramp (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/489 ((     0.49 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/Shape (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/477 ((     0.49 ))s
+IOVDbFolder          INFO Folder /LAR/Identifier/LArTTCellMapAtlas (PoolRef) db-read 1/0 objs/chan/bytes 1/1/173 ((     0.44 ))s
+IOVDbFolder       WARNING Folder /LAR/Identifier/LArTTCellMapAtlas is requested but no data retrieved
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/fSampl (PoolRefColl) db-read 1/2 objs/chan/bytes 1/1/194 ((     0.50 ))s
+IOVDbFolder          INFO Folder /LAR/ElecCalibMC/uA2MeV (PoolRefColl) db-read 1/2 objs/chan/bytes 1/1/165 ((     0.52 ))s
+IOVDbSvc             INFO  bytes in ((     11.52 ))s
 IOVDbSvc             INFO Connection sqlite://;schema=mycool.db;dbname=OFLP200 : nConnect: 0 nFolders: 0 ReadTime: ((     0.00 ))s
-IOVDbSvc             INFO Connection COOLOFL_LAR/OFLP200 : nConnect: 2 nFolders: 20 ReadTime: ((     1.78 ))s
+IOVDbSvc             INFO Connection COOLOFL_LAR/OFLP200 : nConnect: 2 nFolders: 20 ReadTime: ((    11.52 ))s
 IOVDbSvc             INFO Connection COOLOFL_CALO/OFLP200 : nConnect: 1 nFolders: 3 ReadTime: ((     0.00 ))s
 AthDictLoaderSvc     INFO in finalize...
 ToolSvc              INFO Removing all tools created by ToolSvc
 *****Chrono*****     INFO ****************************************************************************************************
 *****Chrono*****     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
 *****Chrono*****     INFO ****************************************************************************************************
-cObjR_ALL            INFO Time User   : Tot= 1.12  [s] Ave/Min/Max=0.0172(+-0.077)/    0/ 0.58  [s] #= 65
-cObj_ALL             INFO Time User   : Tot= 2.11  [s] Ave/Min/Max=0.0728(+-0.159)/    0/ 0.68  [s] #= 29
-ChronoStatSvc        INFO Time User   : Tot=  101  [s]                                             #=  1
+cObjR_ALL            INFO Time User   : Tot= 0.92  [s] Ave/Min/Max=0.0142(+-0.0755)/    0/ 0.57  [s] #= 65
+cObj_ALL             INFO Time User   : Tot= 1.28  [s] Ave/Min/Max=0.0441(+-0.126)/    0/ 0.62  [s] #= 29
+ChronoStatSvc        INFO Time User   : Tot=   52  [s]                                             #=  1
 *****Chrono*****     INFO ****************************************************************************************************
 ChronoStatSvc.f...   INFO  Service finalized successfully 
 ApplicationMgr       INFO Application Manager Finalized successfully
diff --git a/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.cxx b/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.cxx
index 751ba1962a14331bc79fe374595c96373eb57af3..af1babc4fc48dac2246b0ca79dd8d7a261f0f8b0 100644
--- a/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.cxx
+++ b/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.cxx
@@ -34,7 +34,7 @@ StatusCode LArNoisyROAlg::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode LArNoisyROAlg::execute_r (const EventContext& ctx) const
+StatusCode LArNoisyROAlg::execute (const EventContext& ctx) const
 {
   SG::ReadHandle<CaloCellContainer> cellContainer(m_CaloCellContainerName, ctx);
   if (!cellContainer.isValid()) { 
diff --git a/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.h b/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.h
index 9ada3ebafcd6e3014e1647dd470d7d974d7d10f5..1f706dcdffa919ec7670471d19d9398f21fd3c84 100644
--- a/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.h
+++ b/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.h
@@ -35,7 +35,7 @@ class LArNoisyROAlg : public AthReentrantAlgorithm
 
   LArNoisyROAlg(const std::string &name,ISvcLocator *pSvcLocator);
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r (const EventContext& ctx) const override;   
+  virtual StatusCode execute (const EventContext& ctx) const override;   
   virtual StatusCode finalize() override;
 
  
diff --git a/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.cxx b/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.cxx
index 822c0f0568076b238eaa9d6f5ff3467029e2a2c8..d03908a402acd8c1977b96f79a2b50d0588560b3 100644
--- a/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.cxx
+++ b/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.cxx
@@ -45,7 +45,7 @@ StatusCode LArTimeVetoAlg::finalize()
   }
   
 //__________________________________________________________________________
-StatusCode LArTimeVetoAlg::execute_r( const EventContext& ctx ) const
+StatusCode LArTimeVetoAlg::execute( const EventContext& ctx ) const
 {
   ATH_MSG_DEBUG("LArTimeVetoAlg execute()");
 
diff --git a/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.h b/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.h
index e4e5478e324382fc3ae877f39e14acee61d79901..87a34c39a99ed3e9de19eeacb6ed58dfa625dea7 100644
--- a/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.h
+++ b/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.h
@@ -24,7 +24,7 @@ class LArTimeVetoAlg : public AthReentrantAlgorithm {
     ~LArTimeVetoAlg();
     
     virtual StatusCode          initialize() override;
-    virtual StatusCode          execute_r (const EventContext& ctx) const override;
+    virtual StatusCode          execute (const EventContext& ctx) const override;
     virtual StatusCode          finalize() override;
 
   private:
diff --git a/LArCalorimeter/LArClusterRec/LArClusterRec/LArDigitThinnerFromEMClust.h b/LArCalorimeter/LArClusterRec/LArClusterRec/LArDigitThinnerFromEMClust.h
index aaf8ce4129d8fedf0eca5f807a75bfd96c36b592..31759dd1c341bde17cd202c0541794f8a36fd77f 100755
--- a/LArCalorimeter/LArClusterRec/LArClusterRec/LArDigitThinnerFromEMClust.h
+++ b/LArCalorimeter/LArClusterRec/LArClusterRec/LArDigitThinnerFromEMClust.h
@@ -43,7 +43,7 @@ class LArDigitThinnerFromEMClust : public AthReentrantAlgorithm
   ~LArDigitThinnerFromEMClust();
   
   StatusCode initialize() override;
-  StatusCode execute_r(const EventContext& ctx) const override;
+  StatusCode execute(const EventContext& ctx) const override;
   StatusCode finalize() override;
  
   private:
diff --git a/LArCalorimeter/LArClusterRec/src/LArDigitThinnerFromEMClust.cxx b/LArCalorimeter/LArClusterRec/src/LArDigitThinnerFromEMClust.cxx
index 0f9a71a8ded823ac7117d449efa33543b30e62aa..0c7bf3cceadb55bdf43f84ba20fee87d3414a8f7 100755
--- a/LArCalorimeter/LArClusterRec/src/LArDigitThinnerFromEMClust.cxx
+++ b/LArCalorimeter/LArClusterRec/src/LArDigitThinnerFromEMClust.cxx
@@ -47,7 +47,7 @@ StatusCode LArDigitThinnerFromEMClust::finalize() {
 }
 
 
-StatusCode LArDigitThinnerFromEMClust::execute_r(const EventContext& ctx) const {
+StatusCode LArDigitThinnerFromEMClust::execute(const EventContext& ctx) const {
 
   //Get inputs from read handles:
   SG::ReadHandle<LArDigitContainer> inputContainer(m_inputContainerKey,ctx);
diff --git a/LArCalorimeter/LArExample/LArConditionsCommon/share/LArMinimalSetup.py b/LArCalorimeter/LArExample/LArConditionsCommon/share/LArMinimalSetup.py
index 1a07d2878d85230598ca91dd5c145226d32858c2..b3ef2adc4b3379251872657bfa9d3ee3e88a71ef 100644
--- a/LArCalorimeter/LArExample/LArConditionsCommon/share/LArMinimalSetup.py
+++ b/LArCalorimeter/LArExample/LArConditionsCommon/share/LArMinimalSetup.py
@@ -14,7 +14,7 @@ globalflags.InputFormat.set_Value_and_Lock('bytestream')
 globalflags.DatabaseInstance.set_Value_and_Lock('CONDBR2')
 
 from AthenaCommon.JobProperties import jobproperties
-jobproperties.Global.DetDescrVersion = "ATLAS-GEO-20-00-00"
+jobproperties.Global.DetDescrVersion = "ATLAS-R2-2016-01-00-01"
 
 from AthenaCommon.DetFlags import DetFlags
 DetFlags.Calo_setOff()  #Switched off to avoid geometry
diff --git a/LArCalorimeter/LArMonTools/python/LArMonFlags.py b/LArCalorimeter/LArMonTools/python/LArMonFlags.py
index 9b6b81e31a5f6db8b5f7f972b2e875ba0cec3f64..aff95ffeb0c4a70a5dbc7131013b921c1046f2b2 100644
--- a/LArCalorimeter/LArMonTools/python/LArMonFlags.py
+++ b/LArCalorimeter/LArMonTools/python/LArMonFlags.py
@@ -136,6 +136,13 @@ class doLArRODMonTool(JobProperty):
     StoredValue=True
 list+=[doLArRODMonTool]
 
+class doLArNoiseCorrelationMon(JobProperty):
+    """ Global switch for doLArNoiseCorrelationMon """
+    statusOn=True
+    allowedTypes=['bool']
+    StoredValue=True
+list+=[doLArNoiseCorrelationMon]
+
 ##-----------------------------------------------------------------------------
 ## 2nd step
 ## Definition of the LArMon flag container
diff --git a/LArCalorimeter/LArMonTools/share/LArAllMonitoring_jobOptions.py b/LArCalorimeter/LArMonTools/share/LArAllMonitoring_jobOptions.py
index 26b4057b64c8f8ad279a7f4536b253666dda2c5f..b00be98b100223e084c1a9903b8356b852618a57 100755
--- a/LArCalorimeter/LArMonTools/share/LArAllMonitoring_jobOptions.py
+++ b/LArCalorimeter/LArMonTools/share/LArAllMonitoring_jobOptions.py
@@ -51,6 +51,8 @@ else:
 if 'LArDigitKey'  in dir() :
     LArMonFlags.LArDigitKey=LArDigitKey 
 
+
+
 # This is the main block choosing what monitoring to run.
 # There is some repetition, but I think maintenance is easier (Rob).
 
@@ -74,6 +76,8 @@ if jobproperties.Beam.beamType() == 'cosmics':
                 include ("LArMonTools/LArCoverage_jobOptions.py")
             if LArMonFlags.doLArDigitMon():
                 include ("LArMonTools/LArDigitMon_jobOptions.py")
+            if LArMonFlags.doLArNoiseCorrelationMon():
+                include ("LArMonTools/LArNoiseCorrelationMon_jobOptions.py")
             if LArMonFlags.doLArNoisyROMon():
                 include ("LArMonTools/LArNoisyROMon_jobOptions.py")
             if LArMonFlags.doLArRawChannelMon():
@@ -81,6 +85,7 @@ if jobproperties.Beam.beamType() == 'cosmics':
             if LArMonFlags.doLArCollisionTimeMon():
                 include("LArMonTools/LArCollisionTimeMonTool_jobOptions.py")
 
+
 elif jobproperties.Beam.beamType() == 'singlebeam':
     if larESDMon and not athenaCommonFlags.isOnline():
         if LArMonFlags.doLArAffectedRegions():
@@ -99,6 +104,8 @@ elif jobproperties.Beam.beamType() == 'singlebeam':
                 include ("LArMonTools/LArCoverage_jobOptions.py")
             if LArMonFlags.doLArDigitMon():
                 include ("LArMonTools/LArDigitMon_jobOptions.py")
+            if LArMonFlags.doLArNoiseCorrelationMon():
+                include ("LArMonTools/LArNoiseCorrelationMon_jobOptions.py")
             if LArMonFlags.doLArNoisyROMon():
                 include ("LArMonTools/LArNoisyROMon_jobOptions.py")
             if LArMonFlags.doLArRawChannelMon():
@@ -123,6 +130,8 @@ else:  # should be jobproperties.Beam.beamType() =='collisions'
                 include ("LArMonTools/LArCoverage_jobOptions.py")
             if LArMonFlags.doLArDigitMon():
                 include ("LArMonTools/LArDigitMon_jobOptions.py")
+            if LArMonFlags.doLArNoiseCorrelationMon():
+                include ("LArMonTools/LArNoiseCorrelationMon_jobOptions.py")
             if LArMonFlags.doLArNoisyROMon():
                 include ("LArMonTools/LArNoisyROMon_jobOptions.py")
             if LArMonFlags.doLArRawChannelMon():
diff --git a/LArCalorimeter/LArMonTools/share/LArCalibRunMonitoringOffline.py b/LArCalorimeter/LArMonTools/share/LArCalibRunMonitoringOffline.py
new file mode 100644
index 0000000000000000000000000000000000000000..a71d27273054ba4fb0e786e6514349795807b3ed
--- /dev/null
+++ b/LArCalorimeter/LArMonTools/share/LArCalibRunMonitoringOffline.py
@@ -0,0 +1,34 @@
+# Calibration runs
+
+#### to be run like this (from run/ directory):
+# athena.py -s -c 'RunNumber='$rn';InputDir="'$folderIn'";OutputDir="'$outDataFolder'";OutName="'$aname'_'$gain'";Gain="'$gain'";Partition="ALL";EvtNo='$evts';FEBSforStatTest=["endcapAft04slot02","barrelCft01slot03"]' ../build/x86_64-slc6-gcc62-opt/jobOptions/LArMonTools/LArCalibRunMonitoringOffline.py 
+#
+# OutName - if you want to modify the output name
+# Gain=HIGH/MEDIUM/LOW
+# EvtNo set if you want to run on a limited number of events, do not set otherwise
+# FEBSforStatTest tellse the coherent noise what to run on, if not set there's a default 
+###
+
+from AthenaCommon.ConcurrencyFlags import jobproperties as jps  
+
+online = False
+
+#
+# Common header to all LArMon jobs
+#
+
+coherent_noise_febs = FEBSforStatTest #list of FEBs to be monitored, if empty, runs on them all
+print coherent_noise_febs
+#coherent_noise_PublishPartialSums = True #if true, publish the partial sums histograms, can be useful for debugging. False by default
+coherent_noise_calibration_run = True
+
+
+from LArMonTools.LArMonFlags import LArMonFlags
+include("LArMonTools/LArMonJobOptionsOffline.py") # contains the setting up of athena for the monitoring + rootfile naming  + LArBuilders
+svcMgr.IOVDbSvc.GlobalTag="CONDBR2-ES1PA-2018-03"
+# needed at P1
+#Service("PoolSvc").SortReplicas = False
+
+svcMgr.MessageSvc.OutputLevel  = 4 #2 to set DEBUG mode, 4 to remove debug
+
+
diff --git a/LArCalorimeter/LArMonTools/share/LArMonByteStream.py b/LArCalorimeter/LArMonTools/share/LArMonByteStream.py
index 66d82f9fa851111a370479e76c8610f0d797b3f7..843471ffe9d54b4bcb2d15d7addb38cd69bdfb7a 100755
--- a/LArCalorimeter/LArMonTools/share/LArMonByteStream.py
+++ b/LArCalorimeter/LArMonTools/share/LArMonByteStream.py
@@ -4,14 +4,7 @@
 #
 if not online:
     theByteStreamInputSvc = svcMgr.ByteStreamInputSvc
-    if not 'FullFileName' in dir():
-        theByteStreamInputSvc.InputDirectory = [ InputDir ] 
-        theByteStreamInputSvc.FilePrefix     = [ FilePrefix ]
-        theByteStreamInputSvc.RunNumber      = [ RunNumber ]
-    else:
-        for i in range(len(FullFileNameTab)):
-            theByteStreamInputSvc.NumFile += [ 10000 ]        
-        theByteStreamInputSvc.FullFileName = FullFileNameTab
+    theByteStreamInputSvc.FullFileName = FullFileName
     theByteStreamInputSvc.MaxBadEvents=0
 else:
     theApp.CreateSvc += ["ByteStreamCnvSvc"]
diff --git a/LArCalorimeter/LArMonTools/share/LArMonCommonTrailer_jobOptions.py b/LArCalorimeter/LArMonTools/share/LArMonCommonTrailer_jobOptions.py
index d3aad2014c7d76bf1eaa0c77b12b83cee022e52f..143b18a7b1754c76afe7e5d6b1af515a6cf3b3a8 100755
--- a/LArCalorimeter/LArMonTools/share/LArMonCommonTrailer_jobOptions.py
+++ b/LArCalorimeter/LArMonTools/share/LArMonCommonTrailer_jobOptions.py
@@ -4,7 +4,7 @@ if not online:
     if os.path.exists(RootHistOutputFileName): 
         os.remove(RootHistOutputFileName)
     svcMgr += THistSvc()
-    svcMgr.THistSvc.Output = ["AllMon DATAFILE='"+RootHistOutputFileName+"' OPT='New'"] 
+    svcMgr.THistSvc.Output = ["AllMon DATAFILE='"+RootHistOutputFileName+"' OPT='APPEND'"] 
     if Type == 'Delay' and DelayNtuple:
         theApp.Dlls += [ "RootHistCnv" ]
         theApp.HistogramPersistency = "ROOT"
diff --git a/LArCalorimeter/LArMonTools/share/LArMonTools.py b/LArCalorimeter/LArMonTools/share/LArMonTools.py
index e84c8f140b49ab9adaa0379f74b320bf4bfa7f19..e1e08735b8ef6dd1b4874ba4011efaf948dfd34e 100755
--- a/LArCalorimeter/LArMonTools/share/LArMonTools.py
+++ b/LArCalorimeter/LArMonTools/share/LArMonTools.py
@@ -8,14 +8,14 @@ theLArBadChannelsMasker.ProblemsToMask=[
     ]
 ToolSvc+=theLArBadChannelsMasker
 
+include("LArConditionsCommon/LArConditionsCommon_comm_jobOptions.py")
+
 include("LArMonTools/LArFEBMon_jobOptions.py") # Data integrity checks - Includes LArFEBMon tool and LArEventInfo
 if Type == 'Pedestal':
-    include("LArMonTools/LArDigitNoiseMonTool_jobOptions.py")       # Monitoring of digits (noise, pedestal, correlation...)
-    include("LArMonTools/LArOddCellsMonTool_jobOptions.py")         # Monitoring of digits compared with DB pedestal / noise
-#    include("LArMonTools/LArRawChannelNoiseMonTool_jobOptions.py") # Monitoring of raw channels (noise, pedestal, correlation...)
-#    include("LArMonTools/LArScaNoiseMonTool_jobOptions.py")        # Monitoring of fixed pattern noise
-#    include("LArMonTools/LArFebNoiseMonTool_jobOptions.py")        # Monitoring of noise shape (using FEB as a scope)
-#    include("LArMonTools/LArFebNoiseMonToolAlt_jobOptions.py")     # Monitoring of noise shape (using FEB as a scope)
+    coherent_noise_calibration_run=True
+    include("LArMonTools/LArNoiseCorrelationMon_jobOptions.py")    # Coherent noise plots
+
+
 elif Type == 'Delay':
     include("LArMonTools/LArDelayMon_jobOptions.py") # includes LArWaveMon tool and LArJitterMon
 #    include("LArMonTools/LArXtalk_jobOptions.py")    # includes LArWaveXtalk tool
diff --git a/LArCalorimeter/LArMonTools/share/LArMonVariables.py b/LArCalorimeter/LArMonTools/share/LArMonVariables.py
index edbad925f8ffe16e8eb3c496d1075afbb323291f..6f04ae10880fa9c50ca1929ddf52426ec1298efb 100755
--- a/LArCalorimeter/LArMonTools/share/LArMonVariables.py
+++ b/LArCalorimeter/LArMonTools/share/LArMonVariables.py
@@ -10,20 +10,36 @@ if 'SubDet' not in dir():
 if 'InputDir' not in dir():
     InputDir = "/castor/cern.ch/grid/atlas/DAQ/lar/ElecCalib/2009/00102562"
     
+if 'FullFileName' in dir():    
+   if 'RunNumber' not in dir():
+       RunNumber = int(FullFileName.strip().split('.')[1])
+
+   if 'Type' not in dir():
+       Type = str(FullFileName.strip().split('.')[2].strip().split('-')[1])
+       print Type
+
+   if 'Partition' not in dir():
+       Partition = str(FullFileName.strip().split('.')[6].split('-')[1])
+       print Partition
+
+   if not 'FullFileNameTab' in dir():
+       FullFileNameTab = [ InputDir+"/"+FullFileName ]
+
+   pass
+
 if 'FullFileName' not in dir():
-    FullFileName = "data09_calib.00102562.calibration_LArElec-Pedestal-7s-Low-HecFcal.daq.RAW._lb0000._EB-FCAL._0001.data"
+     include("LArCalibProcessing/GetInputFiles.py")
+     if 'FilePrefix' not in dir():
+        FilePrefix="data18"
+     FullFileName =[]
+     FullFileName+=GetInputFilesFromTokens(InputDir,int(RunNumber),FilePrefix,".*")
+     if len(FullFileName) == 0:
+        print "No input files !!!"
+        sys.exit(-1)
+     word = FullFileName[0].split('-')
+     Type = word[1]
     
-if 'RunNumber' not in dir():
-    RunNumber = int(FullFileName.strip().split('.')[1])
     
-if 'Type' not in dir():
-    Type = str(FullFileName.strip().split('.')[2].strip().split('-')[1])
-    print Type
-
-if 'Partition' not in dir():
-    Partition = str(FullFileName.strip().split('.')[6].split('-')[1])
-    print Partition
-
 if not 'online' in dir():
     online = False
 
@@ -45,8 +61,6 @@ if not 'LArDigitKey' in dir():
 if not 'LArRawChannelKey' in dir():
     LArRawChannelKey="LArRawChannels"
 
-if not 'FullFileNameTab' in dir():
-    FullFileNameTab = [ InputDir+"/"+FullFileName ]
 
 if not 'DelayNtuple' in dir():
     DelayNtuple = False
diff --git a/LArCalorimeter/LArMonTools/share/LArNoiseCorrelationMon_jobOptions.py b/LArCalorimeter/LArMonTools/share/LArNoiseCorrelationMon_jobOptions.py
new file mode 100644
index 0000000000000000000000000000000000000000..265bb1e05f264c939b3da60629aaecaf18cbb4de
--- /dev/null
+++ b/LArCalorimeter/LArMonTools/share/LArNoiseCorrelationMon_jobOptions.py
@@ -0,0 +1,57 @@
+#from LArCellRec.LArNoisyROFlags import larNoisyROFlags
+
+# --- for athena online running ---
+if 'EventBlockSize' not in dir():
+    EventBlockSize=0
+
+
+#Run is Online or Offline:
+from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
+OnlineMode=athenaCommonFlags.isOnline()
+
+
+#some FEBs to be monitored (updated 04 may 2018)
+MiniNoiseBurstFlagging_FEBs = ["barrelAft09slot02","barrelAft09slot14","barrelAft10slot10","barrelAft10slot14","barrelAft31slot14","barrelCft08slot14","barrelCft22slot07","barrelCft27slot05","barrelCft27slot14"]
+NewlyNoisy_FEBs = ["barrelCft02slot14","barrelCft01slot14","barrelCft07slot09","barrelCft07slot11","barrelCft06slot14"]
+NoisyRegionsInOuterWheel_FEBs = ["endcapCft21slot04","endcapCft21slot02","endcapCft02slot04","endcapCft02slot02","endcapCft09slot02","endcapCft09slot03","endcapAft21slot04","endcapAft21slot02","endcapAft21slot03"]
+NotNoisyRegionForComparison_FEBs = ["endcapAft02slot04"]
+FEBs_from_DQ_run_350440 = ["endcapAft19slot12","endcapAft19slot09","endcapAft20slot09"]
+
+defaultFEBs=NotNoisyRegionForComparison_FEBs+NoisyRegionsInOuterWheel_FEBs+NewlyNoisy_FEBs+MiniNoiseBurstFlagging_FEBs+FEBs_from_DQ_run_350440
+if 'coherent_noise_febs' in dir():
+    defaultFEBs=coherent_noise_febs
+    pass
+
+###### LArNoiseCorrelationMon Configuration ###############
+from LArMonTools.LArMonToolsConf import LArNoiseCorrelationMon
+theLArNoiseCorrelationMon = LArNoiseCorrelationMon(name="LArNoiseCorrelationMon",
+                             LArDigitContainerKey  = LArMonFlags.LArDigitKey(),
+                             IsOnline              = OnlineMode,
+                             IgnoreBadChannels     = True,
+                             LArBadChannelMask     = theLArBadChannelsMasker,
+                             ProcessNEvents        = EventBlockSize,
+                             TriggerChain          = "HLT_noalg_zb_L1ZB, HLT_noalg_cosmiccalo_L1RD1_EMPTY",
+                             FEBsToMonitor         = defaultFEBs,
+                             IsCalibrationRun      = False,
+                             )
+
+
+
+
+if 'coherent_noise_calibration_run' in dir():
+    if coherent_noise_calibration_run:
+        theLArNoiseCorrelationMon.IsCalibrationRun=True
+        theLArNoiseCorrelationMon.LArDigitContainerKey=Gain
+        theLArNoiseCorrelationMon.TriggerChain=""
+        theLArNoiseCorrelationMon.TrigDecisionTool=""
+        pass
+    pass                
+
+if 'coherent_noise_PublishPartialSums' in dir():
+    theLArNoiseCorrelationMon.PublishPartialSums = coherent_noise_PublishPartialSums
+    pass
+
+#ToolSvc += theLArNoiseCorrelationMon
+LArMon.AthenaMonTools+=[ theLArNoiseCorrelationMon ] 
+
+
diff --git a/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.cxx b/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.cxx
new file mode 100755
index 0000000000000000000000000000000000000000..0059ea6aba28974319bf61db7a40876ff321648f
--- /dev/null
+++ b/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.cxx
@@ -0,0 +1,692 @@
+/*
+  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+*/
+
+
+// ********************************************************************
+// NAME:     LArNoiseCorrelationMon.cxx
+// PACKAGE:  LArMonTools
+//
+// AUTHOR:   Margherita Spalla (margherita.spalla@cern.ch)
+//           Based on structure of LArDigitMon by Helary Louis (helary@lapp.in2p3.fr)
+// 
+// Computes and plots the correlation between single channels to monitor coherent noise. 
+// The correlation is computed as: 
+//    corr(i,j) = Cov(i,j)/sqrt(Var(i)*Var(j)) where 'Cov(i,j)' is the sample covariance of channels  i and j and 'Var(i)' is the sample variance of channel i.
+//    Variance and covariance are computed summing over all samples and all events for each channel: Cov(i,j)=[sum(x_i*x_j)-N*mean_i*mean_j]/(N-1) , where x_i is the single sample minus the pedestal.
+//
+// Correlation histograms are computed per FEB. The FEBs to be monitored are set in the JO.
+//
+// Available parameters in the jo file:
+//   1) List of FEBs to be monitored: should be passed as a list of strings of the form 'BarrelCFT00Slot02', case insensitive (corresponding to type  LARONLINEID defined in the package atlas/LArCalorimeter/LArMonTools/LArMonTools/LArOnlineIDStrHelper.h). If the list is empty, all FEBs are monitored.
+//   2) control PublishAllFebsOnline: if it is set to true, switched off the monitoring in case the FEB list (1) is empty and the algorithm is running online.
+//   3) list of triggers to be used ('TriggerChain'): to be passed as a single string "trigger_chain_1, trigger_chain_2". The default is "HLT_noalg_zb_L1ZB, HLT_noalg_cosmiccalo_L1RD1_EMPTY", for the latter, only events in the abort gap are used, selection done by hand.
+//   4) control IsCalibrationRun: to be set to true when running on calibration, it switches off the trigger selection.
+//   5) control PublishPartialSums: tells the algorithm to also publish the partial sum histograms. default is false.
+
+//
+// ********************************************************************
+
+//Histograms
+#include "GaudiKernel/ITHistSvc.h"
+#include "LWHists/TProfile_LW.h"
+#include "LWHists/TH2F_LW.h"
+
+//STL:
+#include <sstream>
+#include <iomanip>
+#include <cmath>
+#include <vector>
+#include <algorithm>
+
+//ROOT
+#include "TPRegexp.h"
+#include "TF1.h"
+
+//LAr infos:
+#include "Identifier/HWIdentifier.h"
+#include "LArOnlineIDStrHelper.h"
+#include "LArIdentifier/LArOnlineID.h"
+#include "LArRawEvent/LArDigit.h"
+#include "LArRawEvent/LArDigitContainer.h"
+#include "LArRecEvent/LArNoisyROSummary.h"
+#include "TrigDecisionTool/TrigDecisionTool.h"
+
+//Events infos:
+#include "xAODEventInfo/EventInfo.h"
+
+//for looping on FEBs
+#include "LArRawEvent/LArFebHeaderContainer.h"
+
+//Header:
+#include "LArNoiseCorrelationMon.h"
+
+
+// BCIDs of the abort gap
+const int ABORT_GAP_START = 3446;
+const int ABORT_GAP_END   = 3563;
+
+
+
+
+/*---------------------------------------------------------*/
+LArNoiseCorrelationMon::LArNoiseCorrelationMon(const std::string& type, 
+			 const std::string& name,
+			 const IInterface* parent)
+  : ManagedMonitorToolBase(type, name, parent), 
+    m_strHelper(nullptr),
+    m_LArOnlineIDHelper(nullptr),
+    m_badChannelMask("BadLArRawChannelMask"),
+    m_LArCablingService("LArCablingService")
+{
+  /** FEBs to be monitored. If empty, all FEBs will be monitored*/
+  std::vector<std::string> empty_vector(0);
+  declareProperty("FEBsToMonitor",m_FEBsToMonitor=empty_vector);
+	
+  /** If false, blocks the histogram booking in case it's running online and the 'm_FEBsToMonitor' list is empty. i.e. prevents the algorithm from publishing one histogram per FEB for all FEBs in online environnement */
+  declareProperty("PublishAllFebsOnline",m_publishAllFebsOnline=true);
+  declareProperty("PublishPartialSums",m_publishPartialSums=false);
+
+  /** To be set to true when running on calibration run. It swithces off trigger selection*/
+  declareProperty("IsCalibrationRun",m_isCalibrationRun=false);
+
+   /**bool use to mask the bad channels*/
+  declareProperty("IgnoreBadChannels", m_ignoreKnownBadChannels=false);
+  declareProperty("LArBadChannelMask",m_badChannelMask);
+  declareProperty("LArDigitContainerKey", m_LArDigitContainerKey = "FREE");
+  declareProperty("IsOnline",            m_IsOnline=false);
+
+  /**bool enable summary plot */
+  declareProperty("DoSummary",           m_DoSummary=true);
+}
+
+/*---------------------------------------------------------*/
+LArNoiseCorrelationMon::~LArNoiseCorrelationMon()
+{
+}
+
+StatusCode 
+LArNoiseCorrelationMon::finalize()
+{
+  ATH_MSG_INFO( "finalHists LArNoiseCorrelationMon" );
+
+  /** delete local histograms. */
+  if(m_IsOnline)
+    {
+      for (auto const& feb_entry : m_FEBhistograms)
+	{
+	  m_histos=feb_entry.second;
+	  if(m_histos.second.first)
+	    {
+	      LWHist::safeDelete(m_histos.second.first);
+	      m_histos.second.first=nullptr;
+	    }
+	  if(m_histos.second.second)
+	    {
+	      LWHist::safeDelete(m_histos.second.second);
+	      m_histos.second.second=nullptr;
+	    }
+	}
+    }
+  return StatusCode::SUCCESS;
+ 
+}
+
+/*---------------------------------------------------------*/
+StatusCode 
+LArNoiseCorrelationMon::initialize()
+{
+  
+  ATH_MSG_INFO( "Initialize LArNoiseCorrelationMon" );
+
+  m_evtCounter=0;
+  
+  /** Get LAr Online Id Helper*/
+  ATH_CHECK(detStore()->retrieve( m_LArOnlineIDHelper, "LArOnlineID" ));
+
+    
+  /** Get LAr Calbling Service*/
+  ATH_CHECK(m_LArCablingService.retrieve());
+
+  
+  /** Get bad-channel mask (only if jO IgnoreBadChannels is true)*/
+  if (m_ignoreKnownBadChannels) {
+    ATH_CHECK(m_badChannelMask.retrieve());
+  }
+  
+  /** Retrieve pedestals container*/
+  ATH_CHECK(m_keyPedestal.initialize());
+
+  /** get the trigger list from the 'm_triggerChainProp'*/
+  m_triggers.clear();
+  if(m_isCalibrationRun) {
+    ATH_MSG_INFO( "Running as 'calibration run'. No trigger selection will be applied.");
+  }
+  else {
+    ATH_MSG_DEBUG( "Parsing trigger chain list" );
+      StatusCode sc=ManagedMonitorToolBase::parseList(m_triggerChainProp, m_triggers);
+    if(sc.isFailure()) {
+      ATH_MSG_ERROR( "Error parsing the trigger chain list, exiting." );
+      return StatusCode::FAILURE;
+    }
+  }
+
+  return ManagedMonitorToolBase::initialize();
+}
+
+/*---------------------------------------------------------*/
+StatusCode 
+LArNoiseCorrelationMon::bookHistograms()
+{
+    /** lar noise correlation */
+    m_Nchan=128;
+    m_chan_low=-0.5;
+    m_chan_up=127.5;
+
+    MonGroup GroupEMBA( this, "/LAr/NoiseCorrelation/EMBA", run, ATTRIB_MANAGED );
+    MonGroup GroupEMBC( this, "/LAr/NoiseCorrelation/EMBC", run, ATTRIB_MANAGED );
+    MonGroup GroupEMECA( this, "/LAr/NoiseCorrelation/EMECA", run, ATTRIB_MANAGED );
+    MonGroup GroupEMECC( this, "/LAr/NoiseCorrelation/EMECC", run, ATTRIB_MANAGED );
+    MonGroup GroupHECA( this, "/LAr/NoiseCorrelation/HECA", run, ATTRIB_MANAGED );
+    MonGroup GroupHECC( this, "/LAr/NoiseCorrelation/HECC", run, ATTRIB_MANAGED );
+    MonGroup GroupFCALA( this, "/LAr/NoiseCorrelation/FCALA", run, ATTRIB_MANAGED );
+    MonGroup GroupFCALC( this, "/LAr/NoiseCorrelation/FCALC", run, ATTRIB_MANAGED );
+
+    /**declare strings for histograms title*/
+    m_hist_name = "NoiseCorr_"; 
+    m_hist_summary_name1 = "SummaryPlot_maximumCorr"; 
+    m_hist_summary_name2 = "SummaryPlot_maximumCorr_sigma"; 
+    m_hist_title = "LAr Noise Correlation";
+    m_strHelper = new LArOnlineIDStrHelper(m_LArOnlineIDHelper);
+    m_strHelper->setDefaultNameType(LArOnlineIDStrHelper::LARONLINEID);
+
+    /** Check which (if any) FEBs we want to monitor*/ 
+    if(m_FEBsToMonitor.size()==0) {
+      if(!m_publishAllFebsOnline && m_IsOnline) {
+	ATH_MSG_INFO("'m_publishAllFebsOnline' set to false: cannot publish all FEBs in online run. Do nothing.");
+	return StatusCode::SUCCESS;
+      }
+      bookAllFEBs(GroupEMBA,GroupEMBC,GroupEMECA,GroupEMECC,GroupHECA,GroupHECC,GroupFCALA,GroupFCALC);
+    }
+    else bookSelectedFEBs(GroupEMBA,GroupEMBC,GroupEMECA,GroupEMECC,GroupHECA,GroupHECC,GroupFCALA,GroupFCALC);
+  
+  return StatusCode::SUCCESS;
+}
+
+
+/*---------------------------------------------------------*/
+StatusCode 
+LArNoiseCorrelationMon::fillHistograms()
+{
+  /** if publishing all FEBs has been forbidden and m_FEBsToMonitor is empty, then no histogram will be published anyway: no need to loop over channels */
+  if(!m_publishAllFebsOnline && m_IsOnline && m_FEBsToMonitor.size()==0) {
+      ATH_MSG_DEBUG("'m_publishAllFebsOnline' set to false and empty FEB list in online run. No FEB will be monitored.");
+      return StatusCode::SUCCESS;
+    }
+
+  ATH_MSG_DEBUG("in fillHists()" );
+    
+  /**increase internal event counter, for calibration run only */
+  m_evtCounter++;
+
+  /** check trigger */
+  bool passTrig = m_isCalibrationRun;
+  if(!m_isCalibrationRun) { 
+     /**EventID is a part of EventInfo, search event informations:*/
+     const xAOD::EventInfo* thisEvent;
+     ATH_CHECK(evtStore()->retrieve(thisEvent));
+  
+     m_evtId = thisEvent->eventNumber();
+     ATH_MSG_DEBUG("Event nb " << m_evtId );  
+
+    bool passBCID;
+    if(!m_trigDecTool.empty()) {
+      for(auto trig_chain : m_triggers) {
+	passBCID = ((trig_chain == "HLT_noalg_cosmiccalo_L1RD1_EMPTY")?(thisEvent->bcid() >= ABORT_GAP_START && thisEvent->bcid() <= ABORT_GAP_END):true);
+	passTrig=(passTrig || (passBCID && m_trigDecTool->isPassed(trig_chain)));
+      }
+    }
+  }
+
+  if (!passTrig) {
+      ATH_MSG_DEBUG ( " Failed trigger selection " );
+      if(m_IsOnline && (endOfLumiBlockFlag() || endOfEventsBlockFlag())) fillInCorrelations(); //seems not to work offline, so done for online only
+      return StatusCode::SUCCESS;
+  } else {
+    ATH_MSG_DEBUG ( " Pass trigger selection " );
+  }
+  
+
+  /*retrieve pedestal*/
+  SG::ReadCondHandle<ILArPedestal> pedestalHdl{m_keyPedestal};
+  const ILArPedestal* pedestals=*pedestalHdl;
+
+  /** retrieve LArDigitContainer*/
+  const LArDigitContainer* pLArDigitContainer=nullptr;
+  ATH_CHECK(evtStore()->retrieve(pLArDigitContainer, m_LArDigitContainerKey));
+  
+  
+  ATH_MSG_DEBUG ( " LArDigitContainer size "<<pLArDigitContainer->size()<<" for key "<<m_LArDigitContainerKey); 
+  /** Define iterators to loop over Digits containers*/
+  LArDigitContainer::const_iterator itDig = pLArDigitContainer->begin(); 
+  LArDigitContainer::const_iterator itDig_2;
+  LArDigitContainer::const_iterator itDig_e= pLArDigitContainer->end(); 
+  
+  /** Loop over digits*/
+  for ( ; itDig!=itDig_e;++itDig) {
+    const LArDigit* pLArDigit = *itDig;
+    
+    /** Retrieve pedestals */
+    HWIdentifier id = pLArDigit->hardwareID();
+    CaloGain::CaloGain gain = pLArDigit->gain();
+    float pedestal = pedestals->pedestal(id,gain);    
+
+    if(!isGoodChannel(id,pedestal))
+	continue;
+    
+    /** Retrieve samples*/
+    const std::vector<short>* digito = &pLArDigit->samples();
+    
+    /** Retrieve once, all the cell info:*/
+    m_febID = m_LArOnlineIDHelper->feb_Id(id);
+    m_ch1 = m_LArOnlineIDHelper->channel(id);
+
+    try {
+      m_histos=m_FEBhistograms.at(m_febID);
+    }
+    catch (const std::out_of_range& oor) {
+	continue;
+    }
+
+    /** Second loop over digit */
+    bool av_set=false;
+    for(itDig_2 = itDig; itDig_2!=itDig_e;++itDig_2)
+      {
+	const LArDigit* pLArDigit2 = *itDig_2;
+	HWIdentifier id2 = pLArDigit2->hardwareID();
+	if(m_LArOnlineIDHelper->feb_Id(id2)!=m_febID) continue;
+
+	/** get the pedestal */
+	CaloGain::CaloGain gain2 = pLArDigit2->gain();
+	float pedestal2 = pedestals->pedestal(id2,gain2);
+
+	if(!isGoodChannel(id2,pedestal2))  continue;
+
+	/** get the channel number */
+	m_ch2 = m_LArOnlineIDHelper->channel(id2);
+
+	/** get the samples */
+	const std::vector<short>* digito2 = &pLArDigit2->samples();
+	std::vector<short>::const_iterator iterSam2= digito2->begin();
+	std::vector<short>::const_iterator iterSam= digito->begin();
+
+	double part_sum=0;
+	int Nsam=pLArDigit->nsamples();
+	if(pLArDigit2->nsamples()!=Nsam)
+	  {
+	    ATH_MSG_WARNING( Form("Different number of samples between channels %d vs %d: skipping these two",Nsam,pLArDigit2->nsamples()) );
+	    continue;
+	  }
+
+	/** Loop over the samples and compute average and sum of squares*/
+	for(int i=0;i<Nsam;i++,iterSam++,iterSam2++)
+	  {
+	    if(!av_set) { /** fill the mean only once per ch1. This code is here to avoid one additional loop over samples before the second loop. */
+	      m_histos.second.second->Fill(m_ch1,(*iterSam-pedestal));
+	    }
+	    /** now compute sum of squares */
+	    part_sum+=((*iterSam-pedestal)*(*iterSam2-pedestal2));
+	  }
+	av_set=true; /** now the average is set and I won't do this again in next ch2 loop*/
+	m_histos.second.first->Fill(m_ch1,m_ch2,part_sum);
+	m_histos.second.first->Fill(m_ch2,m_ch1,part_sum);
+      }/** End of second loop on LArDigit*/    
+  }/** End of loop on LArDigit*/
+ 
+
+  /** compute correlation and update the published plot once per LB (seems not to work offline, so done for online only)*/
+  if(m_IsOnline && (endOfLumiBlockFlag() || endOfEventsBlockFlag())) fillInCorrelations();
+ 
+  return StatusCode::SUCCESS;
+}
+
+/*---------------------------------------------------------*/
+StatusCode LArNoiseCorrelationMon::procHistograms()
+{
+  if(endOfRunFlag()) 
+    {
+      fillInCorrelations();
+      if(m_IsOnline)
+	{
+	  for (auto const& feb_entry : m_FEBhistograms)
+	    {
+	      m_histos=feb_entry.second;
+	      if(m_histos.second.first) m_histos.second.first->Reset(); 
+	      if(m_histos.second.second) m_histos.second.second->Reset(); 
+	    }
+	}
+    }
+  return StatusCode::SUCCESS;
+}
+
+
+/*---------------------------------------------------------*/
+/** check if channel is ok for monitoring */
+ bool LArNoiseCorrelationMon::isGoodChannel(const HWIdentifier ID,const float ped) const
+ {
+    /** Remove problematic channels*/
+   if (m_ignoreKnownBadChannels && m_badChannelMask->cellShouldBeMasked(ID))
+     return false;
+
+    /**skip cells with no pedestals reference in db.*/
+    if(ped <= (1.0+LArElecCalib::ERRORCODE))
+      return false;
+    
+    /**skip disconnected channels:*/
+    if(!m_LArCablingService->isOnlineConnected(ID))
+      return false;
+
+    return true;
+ }
+
+
+/*---------------------------------------------------------*/
+/**Compute correlations and fill in the plots*/
+void LArNoiseCorrelationMon::fillInCorrelations()
+{
+  double mean1,mean2;
+  double sumVar1,sumVar2;
+  double N;
+  double cor;
+  for (auto const& feb_entry : m_FEBhistograms)
+    {
+      double tmp_maxcorr = 0.0;
+      TH1F *hist_tmp_correlation;
+      hist_tmp_correlation         = new TH1F("Tmp_correlation_value", "TMP correlation value", 40, -1.0, 1.0 );
+      double tmp_RMS  = 0.0;
+      m_histos=feb_entry.second;
+      for(int i=1;i<=m_Nchan;i++)
+	{
+	  mean1=m_histos.second.second->GetBinContent(i);
+	  sumVar1=m_histos.second.first->GetBinContent(i,i);
+	  N=m_histos.second.second->GetBinEntries(i);
+	  if(N==0) 
+	    {
+	      ATH_MSG_DEBUG( "Bin " << i << " has 0 entries" );
+	      continue;
+	    }
+	  for(int j=i+1;j<=m_Nchan;j++)
+	    {
+	      mean2=m_histos.second.second->GetBinContent(j);
+	      sumVar2=m_histos.second.first->GetBinContent(j,j);
+	      if((sumVar1-N*mean1*mean1)*(sumVar2-N*mean2*mean2)==0) {
+		ATH_MSG_DEBUG( "sigma_i*sigma_j is zero for bin (" << i << "," << j << "). Correlation cannot be computed." );
+		continue;
+	      }
+	      cor=(m_histos.second.first->GetBinContent(i,j)-N*mean1*mean2)/TMath::Sqrt((sumVar1-N*mean1*mean1)*(sumVar2-N*mean2*mean2));
+	      m_histos.first->SetBinContent(i,j,cor);
+	      m_histos.first->SetBinContent(j,i,cor);
+	      /** calculate maximum correlation */
+	      /** First variable: maximum correlation in the FEB */
+	      if ( tmp_maxcorr < std::abs(cor) )
+		tmp_maxcorr = std::abs(cor);
+	      /** Second valiable: RMS value in correlation distribution */
+	      hist_tmp_correlation->Fill(cor);
+	    }
+	}
+
+      tmp_RMS = hist_tmp_correlation->GetRMS();
+
+      // Fill in summary histogram
+      TPMERegexp tmp('_');
+      int nsplit = tmp.Split( m_histos.first->GetTitle() );
+      if(m_DoSummary){
+	if(nsplit > 1){
+	  // EMB
+	  if(m_LArOnlineIDHelper->isEMBchannel( feb_entry.first )){
+	    if(m_LArOnlineIDHelper->pos_neg(feb_entry.first) ){
+	      m_h_summary_plot1_EMBA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1,  tmp_maxcorr);
+	      m_h_summary_plot2_EMBA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1,  tmp_RMS);
+	    }
+	    else{
+	      m_h_summary_plot1_EMBC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1,  tmp_maxcorr);
+	      m_h_summary_plot2_EMBC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1,  tmp_RMS);
+	    }
+	  }
+	  // EMEC
+	  else if(m_LArOnlineIDHelper->isEMECchannel( feb_entry.first )){
+	    if(m_LArOnlineIDHelper->pos_neg(feb_entry.first)){
+	      m_h_summary_plot1_EMECA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr);
+	      m_h_summary_plot2_EMECA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS);
+	    }
+	    else{
+	      m_h_summary_plot1_EMECC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr);
+	      m_h_summary_plot2_EMECC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS);
+	    }
+	  }
+	  // HEC
+	  else if(m_LArOnlineIDHelper->isHECchannel( feb_entry.first )){
+	    if(m_LArOnlineIDHelper->pos_neg(feb_entry.first)){
+	      m_h_summary_plot1_HECA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1,  tmp_maxcorr );
+	      m_h_summary_plot2_HECA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1,  tmp_RMS );
+	    }
+	    else{
+	      m_h_summary_plot1_HECC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1,  tmp_maxcorr );
+	      m_h_summary_plot2_HECC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1,  tmp_RMS );
+	    }
+	  }
+	  // FCAL
+	  else if(m_LArOnlineIDHelper->isFCALchannel( feb_entry.first )){
+	    if(m_LArOnlineIDHelper->pos_neg(feb_entry.first)){
+	      m_h_summary_plot1_FCALA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr );
+	      m_h_summary_plot2_FCALA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS );
+	    }
+	    else{
+	      m_h_summary_plot1_FCALC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr );
+	      m_h_summary_plot2_FCALC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS );
+	    }
+	  }
+	}
+      }
+      // Delete them in order to save the memory
+      delete hist_tmp_correlation;
+
+    }
+}
+
+
+
+
+
+/*---------------------------------------------------------*/
+/**Loops on selected FEBS to book and define histograms.*/
+void LArNoiseCorrelationMon::bookSelectedFEBs(MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC)
+{
+  ATH_MSG_INFO( "Booking selected FEBs: " << m_FEBsToMonitor.size() << " provided." );
+  std::string aFEB; /**aFEB is the feb to monitor*/
+  HWIdentifier febid;
+  for(uint feb_i=0;feb_i<m_FEBsToMonitor.size();feb_i++) {
+    aFEB=m_FEBsToMonitor[feb_i];
+    febid=m_strHelper->feb_id(aFEB);
+    if(!febid.is_valid()) {
+      ATH_MSG_WARNING( "FEB id " << aFEB << " not valid. It will not be monitored." );
+      continue;
+    }
+    bookThisFEB(febid,grEMBA,grEMBC,grEMECA,grEMECC,grHECA,grHECC,grFCALA,grFCALC);
+  }
+  // summary plot
+  if(m_DoSummary){
+    m_h_summary_plot1_EMBA     = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMBA"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_EMBC     = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMBC"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_EMECA    = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMECA" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_EMECC    = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMECC" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_HECA     = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot HECA"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_HECC     = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot HECC"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_FCALA    = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot FCALA" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_FCALC    = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot FCALC" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_EMBA     = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMBA"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_EMBC     = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMBC"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_EMECA    = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMECA" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_EMECC    = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMECC" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_HECA     = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot HECA"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_HECC     = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot HECC"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_FCALA    = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot FCALA" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_FCALC    = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot FCALC" ,16, 0, 16, 34, 0, 34);
+    grEMBA.regHist(m_h_summary_plot1_EMBA).ignore();  
+    grEMBC.regHist(m_h_summary_plot1_EMBC).ignore();  
+    grEMECA.regHist(m_h_summary_plot1_EMECA).ignore();  
+    grEMECC.regHist(m_h_summary_plot1_EMECC).ignore();  
+    grHECA.regHist(m_h_summary_plot1_HECA).ignore();  
+    grHECC.regHist(m_h_summary_plot1_HECC).ignore();  
+    grFCALA.regHist(m_h_summary_plot1_FCALA).ignore();  
+    grFCALC.regHist(m_h_summary_plot1_FCALC).ignore();  
+    grEMBA.regHist(m_h_summary_plot2_EMBA).ignore();  
+    grEMBC.regHist(m_h_summary_plot2_EMBC).ignore();  
+    grEMECA.regHist(m_h_summary_plot2_EMECA).ignore();  
+    grEMECC.regHist(m_h_summary_plot2_EMECC).ignore();  
+    grHECA.regHist(m_h_summary_plot2_HECA).ignore();  
+    grHECC.regHist(m_h_summary_plot2_HECC).ignore();  
+    grFCALA.regHist(m_h_summary_plot2_FCALA).ignore();  
+    grFCALC.regHist(m_h_summary_plot2_FCALC).ignore();  
+  }
+}
+
+
+/*---------------------------------------------------------*/
+/**Loops on all FEBS to book and define histograms.*/
+void LArNoiseCorrelationMon::bookAllFEBs(MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC)
+{
+  ATH_MSG_INFO( "No selected FEBs provided: booking all FEBs.");
+  
+  /** loop on FEBs to init histograms */
+  std::vector<HWIdentifier>::const_iterator feb_it = m_LArOnlineIDHelper->feb_begin();
+  std::vector<HWIdentifier>::const_iterator feb_it_e = m_LArOnlineIDHelper->feb_end();
+  for ( ; feb_it!=feb_it_e;++feb_it) {
+    bookThisFEB((*feb_it),grEMBA,grEMBC,grEMECA,grEMECC,grHECA,grHECC,grFCALA,grFCALC);
+  }
+  // summary plot
+  if(m_DoSummary){
+    m_h_summary_plot1_EMBA     = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMBA"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_EMBC     = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMBC"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_EMECA    = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMECA" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_EMECC    = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMECC" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_HECA     = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot HECA"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_HECC     = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot HECC"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_FCALA    = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot FCALA" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot1_FCALC    = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot FCALC" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_EMBA     = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMBA"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_EMBC     = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMBC"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_EMECA    = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMECA" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_EMECC    = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMECC" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_HECA     = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot HECA"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_HECC     = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot HECC"  ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_FCALA    = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot FCALA" ,16, 0, 16, 34, 0, 34);
+    m_h_summary_plot2_FCALC    = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot FCALC" ,16, 0, 16, 34, 0, 34);
+
+    grEMBA.regHist(m_h_summary_plot1_EMBA).ignore();  
+    grEMBC.regHist(m_h_summary_plot1_EMBC).ignore();  
+    grEMECA.regHist(m_h_summary_plot1_EMECA).ignore();  
+    grEMECC.regHist(m_h_summary_plot1_EMECC).ignore();  
+    grHECA.regHist(m_h_summary_plot1_HECA).ignore();  
+    grHECC.regHist(m_h_summary_plot1_HECC).ignore();  
+    grFCALA.regHist(m_h_summary_plot1_FCALA).ignore();  
+    grFCALC.regHist(m_h_summary_plot1_FCALC).ignore();  
+
+    grEMBA.regHist(m_h_summary_plot2_EMBA).ignore();  
+    grEMBC.regHist(m_h_summary_plot2_EMBC).ignore();  
+    grEMECA.regHist(m_h_summary_plot2_EMECA).ignore();  
+    grEMECC.regHist(m_h_summary_plot2_EMECC).ignore();  
+    grHECA.regHist(m_h_summary_plot2_HECA).ignore();  
+    grHECC.regHist(m_h_summary_plot2_HECC).ignore();  
+    grFCALA.regHist(m_h_summary_plot2_FCALA).ignore();  
+    grFCALC.regHist(m_h_summary_plot2_FCALC).ignore();  
+
+  }
+}
+
+/*---------------------------------------------------------*/
+/**Book and defines histogramms for a given FEB.*/
+void LArNoiseCorrelationMon::bookThisFEB(HWIdentifier id,MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC)
+{
+  std::string this_name=m_strHelper->feb_str(id);
+  int num_slot          = m_LArOnlineIDHelper->slot(id);
+  int num_feedthrough   = m_LArOnlineIDHelper->feedthrough(id);
+  std::string slot_feed_title = std::to_string(num_slot) + "_" + std::to_string(num_feedthrough);
+
+  TH2F_LW* h_corr = TH2F_LW::create((m_hist_name+this_name).c_str(), slot_feed_title.c_str(), m_Nchan,m_chan_low,m_chan_up,m_Nchan,m_chan_low,m_chan_up);
+  TH2F_LW* h_TMP_sums = TH2F_LW::create((m_hist_name+this_name+"_TMP_sum").c_str(),(m_hist_title+" TMP sum").c_str(),m_Nchan,m_chan_low,m_chan_up,m_Nchan,m_chan_low,m_chan_up);
+  TProfile_LW* h_av = TProfile_LW::create((m_hist_name+this_name+"_TMP_av").c_str(),(m_hist_title+" TMP av").c_str(),m_Nchan,m_chan_low,m_chan_up,"s");
+  m_FEBhistograms[id]=std::make_pair(h_corr,std::make_pair(h_TMP_sums,h_av));
+
+  if(m_LArOnlineIDHelper->isEMBchannel(id)) {
+    if(m_LArOnlineIDHelper->pos_neg(id)==1) {
+      grEMBA.regHist(h_corr).ignore();
+      if(m_publishPartialSums && !m_IsOnline) {
+	grEMBA.regHist(h_av).ignore();
+	grEMBA.regHist(h_TMP_sums).ignore();
+      }
+    }
+    else {
+      grEMBC.regHist(h_corr).ignore();
+      if(m_publishPartialSums && !m_IsOnline) {
+	grEMBC.regHist(h_av).ignore();
+	grEMBC.regHist(h_TMP_sums).ignore();
+      }
+    }
+  }
+  else
+    if(m_LArOnlineIDHelper->isEMECchannel(id)) {
+      if(m_LArOnlineIDHelper->pos_neg(id)==1) {
+	grEMECA.regHist(h_corr).ignore();
+	if(m_publishPartialSums && !m_IsOnline) {
+	  grEMECA.regHist(h_av).ignore();
+	  grEMECA.regHist(h_TMP_sums).ignore();
+	}
+      }
+      else {
+	grEMECC.regHist(h_corr).ignore();
+      if(m_publishPartialSums && !m_IsOnline) {
+	grEMECC.regHist(h_av).ignore();
+	grEMECC.regHist(h_TMP_sums).ignore();
+      }
+      }
+    }
+    else
+      if(m_LArOnlineIDHelper->isHECchannel(id)) {
+	if(m_LArOnlineIDHelper->pos_neg(id)==1) {
+	  grHECA.regHist(h_corr).ignore();
+	  if(m_publishPartialSums && !m_IsOnline) {
+	    grHECA.regHist(h_av).ignore();
+	    grHECA.regHist(h_TMP_sums).ignore();
+	  }
+	}
+	else {
+	  grHECC.regHist(h_corr).ignore();
+	  if(m_publishPartialSums && !m_IsOnline) {
+	    grHECC.regHist(h_av).ignore();
+	    grHECC.regHist(h_TMP_sums).ignore();
+	  }
+	}
+      }
+      else
+	if(m_LArOnlineIDHelper->isFCALchannel(id)) {
+	  if(m_LArOnlineIDHelper->pos_neg(id)==1) {
+	    grFCALA.regHist(h_corr).ignore();
+	    if(m_publishPartialSums && !m_IsOnline) {
+	      grFCALA.regHist(h_av).ignore();
+	      grFCALA.regHist(h_TMP_sums).ignore();
+	    }
+	  }
+	  else {
+	    grFCALC.regHist(h_corr).ignore();
+	    if(m_publishPartialSums && !m_IsOnline) {
+	      grFCALC.regHist(h_av).ignore();
+	      grFCALC.regHist(h_TMP_sums).ignore();
+	    }
+	  }
+	}
+}
+
+
+
+
diff --git a/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.h b/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.h
new file mode 100755
index 0000000000000000000000000000000000000000..df0befd0f313ba9d1d14b5e4400b38c6fe90fe5d
--- /dev/null
+++ b/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.h
@@ -0,0 +1,144 @@
+/*
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
+*/
+
+/**
+ * @class LArNoiseCorrelationMon
+ * @author Margherita Spalla 
+ *
+ */
+
+#ifndef LARCORRMON_H
+#define LARCORRMON_H
+
+//inheritance:
+#include "AthenaMonitoring/ManagedMonitorToolBase.h"
+
+
+//LAr services:
+#include "LArElecCalib/ILArPedestal.h"
+#include "LArRecConditions/ILArBadChannelMasker.h"
+#include "LArCabling/LArCablingService.h"
+
+
+//STL:
+#include <string>
+
+
+
+class LArOnlineID;
+class HWIdentifier;
+class LArOnlineIDStrHelper;
+class TProfile2D_LW;
+class TProfile_LW;
+class TH2F_LW;
+
+class LArNoiseCorrelationMon: public ManagedMonitorToolBase
+{
+  
+  
+public:
+  LArNoiseCorrelationMon(const std::string& type, 
+	      const std::string& name,
+	      const IInterface* parent);
+  
+  /** @brief Default destructor */
+  virtual ~LArNoiseCorrelationMon();
+  
+  
+   
+  virtual StatusCode initialize() override;
+  virtual StatusCode finalize() override;
+  virtual StatusCode bookHistograms() override;
+  virtual StatusCode fillHistograms() override;
+  virtual StatusCode procHistograms() override;
+  
+protected:
+  
+  
+  /** services  */
+  LArOnlineIDStrHelper* m_strHelper;
+  const LArOnlineID* m_LArOnlineIDHelper;
+
+  /** Handle to bad-channel mask */
+  ToolHandle<ILArBadChannelMasker> m_badChannelMask;
+
+  /** Handle to LArCablingService */
+  ToolHandle<LArCablingService> m_LArCablingService; 
+  
+  
+  /** Handle to pedestal */
+  SG::ReadCondHandleKey<ILArPedestal> m_keyPedestal{this,"LArPedestalKey","LArPedestal","SG key of LArPedestal CDO"};
+  
+private:
+  
+  /**correlation histograms*/
+  int m_Nchan; 
+  double m_chan_low,m_chan_up;
+  std::string  m_hist_name;
+  std::string  m_hist_summary_name1;
+  std::string  m_hist_summary_name2;
+  std::string m_hist_title;
+
+  /** The FEB map*/
+  std::map<HWIdentifier,std::pair<TH2F_LW*,std::pair<TH2F_LW*,TProfile_LW*> > > m_FEBhistograms; 
+  std::pair<TH2F_LW*,std::pair<TH2F_LW*,TProfile_LW*> > m_histos;  //for handling histograms
+
+  /** Summary plot*/
+  TH2F_LW * m_h_summary_plot1_EMBA;
+  TH2F_LW * m_h_summary_plot1_EMBC;
+  TH2F_LW * m_h_summary_plot1_EMECA;
+  TH2F_LW * m_h_summary_plot1_EMECC;
+  TH2F_LW * m_h_summary_plot1_HECA;
+  TH2F_LW * m_h_summary_plot1_HECC;
+  TH2F_LW * m_h_summary_plot1_FCALA;
+  TH2F_LW * m_h_summary_plot1_FCALC;
+
+  TH2F_LW * m_h_summary_plot2_EMBA;
+  TH2F_LW * m_h_summary_plot2_EMBC;
+  TH2F_LW * m_h_summary_plot2_EMECA;
+  TH2F_LW * m_h_summary_plot2_EMECC;
+  TH2F_LW * m_h_summary_plot2_HECA;
+  TH2F_LW * m_h_summary_plot2_HECC;
+  TH2F_LW * m_h_summary_plot2_FCALA;
+  TH2F_LW * m_h_summary_plot2_FCALC;
+
+
+  /** list of FEBs to monitor. FEB names are expected to be of the type  LARONLINEID defined in the package atlas/LArCalorimeter/LArMonTools/LArMonTools/LArOnlineIDStrHelper.h  e.g. 'BarrelCFT00Slot02'  */
+  std::vector<std::string> m_FEBsToMonitor; 
+
+  /** to publish partial sums (offline only) if needed*/
+  bool m_publishPartialSums;
+
+  /** to avoid publishing tons of histograms online, in case it's a problem*/
+  bool m_publishAllFebsOnline;
+
+  /** to avoid asking for triggers in case of a calibration run*/
+  bool m_isCalibrationRun;
+  
+  /**declare identifier*/
+  HWIdentifier m_febID;
+  int m_ch1,m_ch2;  
+
+  /**other variables used in joboptions*/
+  bool m_IsOnline; 
+  bool m_ignoreKnownBadChannels;
+  bool m_DoSummary;
+
+  std::string m_LArDigitContainerKey;
+  
+  /** Private members*/
+  int m_evtId;
+  std::vector<std::string> m_triggers;
+  int m_evtCounter;
+  
+  /** Declare methods used*/
+  bool isGoodChannel(const HWIdentifier id,const float ped) const;
+  void fillInCorrelations();
+  void bookSelectedFEBs(MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC);
+  void bookAllFEBs(MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC);
+  void bookThisFEB(HWIdentifier id,MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC);
+
+};
+
+#endif
diff --git a/LArCalorimeter/LArMonTools/src/components/LArMonTools_entries.cxx b/LArCalorimeter/LArMonTools/src/components/LArMonTools_entries.cxx
index 63b710decd52a56b67f076230f8c23d28148c017..8f9afe207c760b37692d11097b825c287871ede6 100644
--- a/LArCalorimeter/LArMonTools/src/components/LArMonTools_entries.cxx
+++ b/LArCalorimeter/LArMonTools/src/components/LArMonTools_entries.cxx
@@ -8,6 +8,7 @@
 #include "../LArAffectedRegions.h"
 #include "../LArHVCorrectionMonTool.h"
 #include "../LArNoisyROMon.h"
+#include "../LArNoiseCorrelationMon.h"
 
 
 DECLARE_COMPONENT( LArFEBMon )
@@ -20,4 +21,5 @@ DECLARE_COMPONENT( LArRODMonTool )
 DECLARE_COMPONENT( LArAffectedRegions )
 DECLARE_COMPONENT( LArHVCorrectionMonTool )
 DECLARE_COMPONENT( LArNoisyROMon )
+DECLARE_COMPONENT( LArNoiseCorrelationMon )
 
diff --git a/LArCalorimeter/LArROD/LArROD/LArDigitThinner.h b/LArCalorimeter/LArROD/LArROD/LArDigitThinner.h
index 069d42705444edc197f3b66c909cda20f371ddbc..e8b4b4081cc787e6bd8095af25f708088865d00c 100755
--- a/LArCalorimeter/LArROD/LArROD/LArDigitThinner.h
+++ b/LArCalorimeter/LArROD/LArROD/LArDigitThinner.h
@@ -43,7 +43,7 @@ class LArDigitThinner : public AthReentrantAlgorithm
   ~LArDigitThinner();
   
   StatusCode initialize() override;
-  StatusCode execute_r(const EventContext& ctx) const override;
+  StatusCode execute(const EventContext& ctx) const override;
   StatusCode finalize() override;
 
  private:
diff --git a/LArCalorimeter/LArROD/LArROD/LArRawChannelBuilderAlg.h b/LArCalorimeter/LArROD/LArROD/LArRawChannelBuilderAlg.h
index cc4921c3d9d6d675aa9d0c985d79e46abdd95c80..f393c21811a28243d2c75a829b83a5ffac2a5a9f 100644
--- a/LArCalorimeter/LArROD/LArROD/LArRawChannelBuilderAlg.h
+++ b/LArCalorimeter/LArROD/LArROD/LArRawChannelBuilderAlg.h
@@ -30,7 +30,7 @@ class LArRawChannelBuilderAlg : public AthReentrantAlgorithm {
   LArRawChannelBuilderAlg(const std::string& name, ISvcLocator* pSvcLocator);
 
   StatusCode initialize() override;
-  StatusCode execute_r(const EventContext& ctx) const override;
+  StatusCode execute(const EventContext& ctx) const override;
   StatusCode finalize() override;
 
 
diff --git a/LArCalorimeter/LArROD/src/LArDigitThinner.cxx b/LArCalorimeter/LArROD/src/LArDigitThinner.cxx
index 578b6eb4aad197a3fa3787f0a796133b27bbb2cb..48f23506b33132bcf7f47c0e6d8295596f4bcb59 100755
--- a/LArCalorimeter/LArROD/src/LArDigitThinner.cxx
+++ b/LArCalorimeter/LArROD/src/LArDigitThinner.cxx
@@ -136,7 +136,7 @@ StatusCode LArDigitThinner::finalize()
 }
 
 
-StatusCode LArDigitThinner::execute_r(const EventContext& ctx) const {
+StatusCode LArDigitThinner::execute(const EventContext& ctx) const {
   
   initCutValues(ctx); //Should return right away if the cut values are already initialized
 
diff --git a/LArCalorimeter/LArROD/src/LArRawChannelBuilderAlg.cxx b/LArCalorimeter/LArROD/src/LArRawChannelBuilderAlg.cxx
index fe5bf88b8e83cc027a8669ae8b885403a68bcdc3..06a86f4a7eebeb9bdd187376638db4543b278234 100644
--- a/LArCalorimeter/LArROD/src/LArRawChannelBuilderAlg.cxx
+++ b/LArCalorimeter/LArROD/src/LArRawChannelBuilderAlg.cxx
@@ -30,7 +30,7 @@ StatusCode LArRawChannelBuilderAlg::finalize() {
   return StatusCode::SUCCESS;
 } 
 
-StatusCode LArRawChannelBuilderAlg::execute_r(const EventContext& ctx) const {
+StatusCode LArRawChannelBuilderAlg::execute(const EventContext& ctx) const {
 
   //Get event inputs from read handles:
   SG::ReadHandle<LArDigitContainer> inputContainer(m_digitKey,ctx);
diff --git a/LArCalorimeter/LArRawEvent/LArRawEvent/LArOFIterResults.h b/LArCalorimeter/LArRawEvent/LArRawEvent/LArOFIterResults.h
index 66bf8a6d80742b92799f43183e6eabc5a1d18eb9..b4d22ef8bf56ba692227ec9f89e1e3a9e320f74a 100644
--- a/LArCalorimeter/LArRawEvent/LArRawEvent/LArOFIterResults.h
+++ b/LArCalorimeter/LArRawEvent/LArRawEvent/LArOFIterResults.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 //Dear emacs, this is -*-c++-*-
@@ -34,7 +34,7 @@ class LArOFIterResults  {
 		    );
 
   // Destructor 
-  virtual ~LArOFIterResults() {};
+  ~LArOFIterResults() = default;
   
   // Return Functions given below inline
   HWIdentifier           getChannelID() const;
diff --git a/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.cxx b/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.cxx
index 646e08e20c7c4903f1d7cdea3e0df3a6f5ec290d..56284850ad2ed0465d156d7ab188e647de8c7566 100755
--- a/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.cxx
+++ b/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.cxx
@@ -127,7 +127,7 @@ StatusCode LArHVCondAlg::initialize(){
 }
 
 
-StatusCode LArHVCondAlg::execute_r(const EventContext& ctx) const {
+StatusCode LArHVCondAlg::execute(const EventContext& ctx) const {
 
   ATH_MSG_DEBUG("executing");
   bool doHVData=false;
diff --git a/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.h b/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.h
index b715569aa23a2e498668697666303d7ad6b65c52..b69427da2f8386b3d278b4c1a96c1d3aaeb7eb0b 100755
--- a/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.h
+++ b/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.h
@@ -55,7 +55,7 @@ class LArHVCondAlg: public AthReentrantAlgorithm
 
   virtual StatusCode initialize() override;
   virtual StatusCode finalize() override;
-  StatusCode execute_r(const EventContext& ctx) const override;
+  StatusCode execute(const EventContext& ctx) const override;
 
 
   private:
diff --git a/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.cxx b/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.cxx
index 4312ee307aa59877751bbc559f517e19196a03da..6c20c20337a8b89f3bc012e163b2671f3fdf9a2c 100755
--- a/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.cxx
+++ b/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.cxx
@@ -109,7 +109,7 @@ AthenaAttributeList* LArHVPathologyDbCondAlg::hvPathology2AttrList(const LArHVPa
 }
 */
 
-StatusCode LArHVPathologyDbCondAlg::execute_r(const EventContext& ctx) const {
+StatusCode LArHVPathologyDbCondAlg::execute(const EventContext& ctx) const {
 
   SG::WriteCondHandle<LArHVPathology > writeHandle{m_hvPAthologyKey, ctx};
 
diff --git a/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.h b/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.h
index 5006fd67d1bab0a64d5e5057f88360723417e878..95c034f44fff15a33dc3e4113eeb82cbb67b4f40 100755
--- a/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.h
+++ b/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.h
@@ -31,7 +31,7 @@ class LArHVPathologyDbCondAlg: public AthReentrantAlgorithm
 
   virtual StatusCode initialize() override;
   virtual StatusCode finalize() override;
-  virtual StatusCode execute_r(const EventContext& ctx) const override;
+  virtual StatusCode execute(const EventContext& ctx) const override;
 
  private:
 
diff --git a/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/MSVertexRecoAlg/MSVertexRecoAlg.h b/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/MSVertexRecoAlg/MSVertexRecoAlg.h
index fbbb7eda3ec48a56e424f1307f7effd6510bd9bb..00741af01daf2d686afaabaeab4bf1baf37dd76e 100644
--- a/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/MSVertexRecoAlg/MSVertexRecoAlg.h
+++ b/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/MSVertexRecoAlg/MSVertexRecoAlg.h
@@ -20,7 +20,7 @@ class MSVertexRecoAlg : public AthReentrantAlgorithm
   ~MSVertexRecoAlg();
 
   StatusCode initialize() override;
-  StatusCode execute_r (const EventContext& ctx) const override;
+  StatusCode execute (const EventContext& ctx) const override;
   StatusCode finalize() override;
 
 
diff --git a/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/src/MSVertexRecoAlg.cxx b/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/src/MSVertexRecoAlg.cxx
index b0b5a2c344ad561b4095b9ffb32684153ad18110..3d9b0d6be1eb104b2c329125a0fbb6291123a653 100644
--- a/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/src/MSVertexRecoAlg.cxx
+++ b/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/src/MSVertexRecoAlg.cxx
@@ -48,7 +48,7 @@ StatusCode MSVertexRecoAlg::initialize(){
 //** ----------------------------------------------------------------------------------------------------------------- **//
 
 
-StatusCode MSVertexRecoAlg::execute_r (const EventContext& ctx) const {
+StatusCode MSVertexRecoAlg::execute (const EventContext& ctx) const {
 
   std::vector<Tracklet> tracklets;
   std::vector<MSVertex*> vertices;
diff --git a/MuonSpectrometer/MuonCnv/MuonMM_CnvTools/CMakeLists.txt b/MuonSpectrometer/MuonCnv/MuonMM_CnvTools/CMakeLists.txt
index e9f2ac5f984c550ddade2aee5420874700aed676..902c799d062b9fc9c07ddec165d6fc5047acedf8 100644
--- a/MuonSpectrometer/MuonCnv/MuonMM_CnvTools/CMakeLists.txt
+++ b/MuonSpectrometer/MuonCnv/MuonMM_CnvTools/CMakeLists.txt
@@ -11,8 +11,6 @@ atlas_depends_on_subdirs( PUBLIC
                           GaudiKernel
                           PRIVATE
                           Control/AthenaBaseComps
-                          Control/CLIDSvc
-                          Control/SGTools
                           Control/StoreGate
                           DetectorDescription/AtlasDetDescr
                           DetectorDescription/Identifier
@@ -33,7 +31,7 @@ atlas_add_component( MuonMM_CnvTools
                      src/*.cxx
                      src/components/*.cxx
                      INCLUDE_DIRS ${TDAQ-COMMON_INCLUDE_DIRS}
-                     LINK_LIBRARIES ${TDAQ-COMMON_LIBRARIES} ByteStreamData ByteStreamData_test GaudiKernel AthenaBaseComps SGTools StoreGateLib SGtests AtlasDetDescr Identifier ByteStreamCnvSvcBaseLib MuonContainerManager MuonReadoutGeometry MuonDigitContainer MuonIdHelpersLib MuonRDO MuonPrepRawData )
+                     LINK_LIBRARIES ${TDAQ-COMMON_LIBRARIES} ByteStreamData ByteStreamData_test GaudiKernel AthenaBaseComps StoreGateLib SGtests AtlasDetDescr Identifier ByteStreamCnvSvcBaseLib MuonContainerManager MuonReadoutGeometry MuonDigitContainer MuonIdHelpersLib MuonRDO MuonPrepRawData )
 
 # Install files from the package:
 atlas_install_headers( MuonMM_CnvTools )
diff --git a/PhysicsAnalysis/AnalysisCommon/AnalysisTools/AnalysisTools/AANTupleStream.h b/PhysicsAnalysis/AnalysisCommon/AnalysisTools/AnalysisTools/AANTupleStream.h
index 5476ffa4470b7ad931b3421b6fa8b342262b3e95..acbf504a1a370bdbebf9ee6cf50bef21088b95f8 100644
--- a/PhysicsAnalysis/AnalysisCommon/AnalysisTools/AnalysisTools/AANTupleStream.h
+++ b/PhysicsAnalysis/AnalysisCommon/AnalysisTools/AnalysisTools/AANTupleStream.h
@@ -10,7 +10,7 @@
 #include "GaudiKernel/IAddressCreator.h"
 #include "GaudiKernel/ServiceHandle.h"
 #include "GaudiKernel/IIoComponent.h"
-#include "AthenaBaseComps/AthAlgorithm.h"
+#include "AthenaBaseComps/AthLegacySequence.h"
 
 #include <map>
 #include <vector>
@@ -30,7 +30,7 @@ class TTree;
 class TBranch;
 
 class AANTupleStream : virtual public IIoComponent,
-                               public AthAlgorithm
+                               public AthLegacySequence
 {
 public:
     
diff --git a/PhysicsAnalysis/AnalysisCommon/AnalysisTools/src/AANTupleStream.cxx b/PhysicsAnalysis/AnalysisCommon/AnalysisTools/src/AANTupleStream.cxx
index c6199a7623b72a180a5888ca14963e64d85f8589..4375cdd5c952e2d297109d42bcdb0e003b83641a 100644
--- a/PhysicsAnalysis/AnalysisCommon/AnalysisTools/src/AANTupleStream.cxx
+++ b/PhysicsAnalysis/AnalysisCommon/AnalysisTools/src/AANTupleStream.cxx
@@ -47,7 +47,7 @@ using namespace AANTupleParams;
 
 // Standard Constructor
 AANTupleStream::AANTupleStream(const std::string& name, ISvcLocator* pSvcLocator) 
-  : AthAlgorithm(name, pSvcLocator),
+  : AthLegacySequence(name, pSvcLocator),
     m_persSvc      ("EventPersistencySvc", name),
     m_attribSpec(0),
     m_schemaDone(false),
@@ -153,8 +153,8 @@ StatusCode AANTupleStream::initialize()
     }      
 
   ATH_MSG_DEBUG ("End initialize ");
-  
-  return StatusCode::SUCCESS;
+
+  return AthLegacySequence::initialize();
 }
 
 
@@ -195,7 +195,7 @@ StatusCode AANTupleStream::finalize()
       gDirectory->cd(curDir.c_str());
     }
 
-  return StatusCode::SUCCESS;
+  return AthLegacySequence::finalize();
 }
 
 
@@ -606,6 +606,8 @@ StatusCode AANTupleStream::execute_subAlgos()
   
   ATH_MSG_DEBUG ("in execute_subAlgos() ...");
 
+  const EventContext& ctx = Gaudi::Hive::currentContext();
+  
   // -- run subalgorithms
   for ( unsigned int i=0; i < m_membersNames.size(); ++i )
     {
@@ -613,7 +615,7 @@ StatusCode AANTupleStream::execute_subAlgos()
       // skip disabled algo
       if (! (*(this->subAlgorithms()))[i]->isEnabled()) continue ;
       
-      sc = (*(this->subAlgorithms()))[i]->execute();
+      sc = (*(this->subAlgorithms()))[i]->execute(ctx);
       if ( sc.isFailure())
 	{
 	  ATH_MSG_ERROR
@@ -695,14 +697,17 @@ bool AANTupleStream::isEventAccepted() const
   // no filter
   if (m_acceptAlgs.empty())
     return true;
-    
+
+  const EventContext& ctx = Gaudi::Hive::currentContext();
+  
   // loop over all algs
   std::vector<Algorithm*>::const_iterator it;
   std::vector<Algorithm*>::const_iterator itend = m_acceptAlgs.end();
   for (it = m_acceptAlgs.begin(); it != itend; ++it)
     {
       const Algorithm* theAlgorithm = (*it);
-      if ( theAlgorithm->isExecuted() && (! theAlgorithm->filterPassed()))
+      if ( theAlgorithm->execState(ctx).state() == AlgExecState::State::Done &&
+             ( ! theAlgorithm->execState(ctx).filterPassed() ) )
 	return false;
     }
 
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/CMakeLists.txt b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/CMakeLists.txt
index d4cf699d1b57eccfe32724d66537a7b3693f4ef3..c7e5fd910502b1a5d47062e170b74efeed676261 100644
--- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/CMakeLists.txt
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/CMakeLists.txt
@@ -11,8 +11,7 @@ atlas_depends_on_subdirs( PUBLIC
                           Event/xAOD/xAODBase
                           GaudiKernel
                           PhysicsAnalysis/AnalysisCommon/PATCore
-			  PhysicsAnalysis/Interfaces/AsgAnalysisInterfaces
-			  PhysicsAnalysis/DerivationFramework/DerivationFrameworkInterfaces
+                          PhysicsAnalysis/DerivationFramework/DerivationFrameworkInterfaces
                           Trigger/TrigAnalysis/TrigDecisionTool
                           PRIVATE
                           Control/AthenaKernel
@@ -26,12 +25,11 @@ atlas_add_library( DerivationFrameworkToolsLib
                    src/*.cxx
                    PUBLIC_HEADERS DerivationFrameworkTools
                    PRIVATE_INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
-		   LINK_LIBRARIES AthenaBaseComps xAODBase GaudiKernel PATCoreLib AsgAnalysisInterfaces TrigDecisionToolLib ExpressionEvaluationLib
+                   LINK_LIBRARIES AthenaBaseComps xAODBase GaudiKernel PATCoreLib TrigDecisionToolLib ExpressionEvaluationLib
                    PRIVATE_LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaKernel )
 
 atlas_add_component( DerivationFrameworkTools
                      src/components/*.cxx
                      INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
-		     LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaBaseComps xAODBase GaudiKernel  AsgAnalysisInterfaces PATCoreLib TrigDecisionToolLib AthenaKernel 
-		     ExpressionEvaluationLib DerivationFrameworkToolsLib )
+                     LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaBaseComps xAODBase GaudiKernel PATCoreLib TrigDecisionToolLib AthenaKernel ExpressionEvaluationLib DerivationFrameworkToolsLib )
 
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/DerivationFrameworkTools/AsgSelectionToolWrapper.h b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/DerivationFrameworkTools/AsgSelectionToolWrapper.h
index cdf765f1cea2382c2c7e2cc292def9e048a3300c..b02c3360caeed81d5d1dd62ebf5e4d034d0beddd 100644
--- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/DerivationFrameworkTools/AsgSelectionToolWrapper.h
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/DerivationFrameworkTools/AsgSelectionToolWrapper.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
 */
 
 ///////////////////////////////////////////////////////////////////
@@ -13,7 +13,7 @@
 
 #include "AthenaBaseComps/AthAlgTool.h"
 #include "DerivationFrameworkInterfaces/IAugmentationTool.h"
-#include "AsgAnalysisInterfaces/ISelectionTool.h"
+#include "PATCore/IAsgSelectionTool.h"
 #include "GaudiKernel/ToolHandle.h"
 
 namespace DerivationFramework {
@@ -27,7 +27,7 @@ namespace DerivationFramework {
       virtual StatusCode addBranches() const;
 
     private:
-      ToolHandle<CP::ISelectionTool> m_tool;
+      ToolHandle<IAsgSelectionTool> m_tool;
       std::string m_cut;
       std::string m_sgName;
       std::string m_containerName;
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/src/AsgSelectionToolWrapper.cxx b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/src/AsgSelectionToolWrapper.cxx
index a358cceba1d3be428887a55dc7118372f5eab056..16644e5e113b72c78db9e4ba7dd226d8cf54cf5e 100644
--- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/src/AsgSelectionToolWrapper.cxx
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/src/AsgSelectionToolWrapper.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
 */
 
 ///////////////////////////////////////////////////////////////////
@@ -10,7 +10,7 @@
 
 #include "DerivationFrameworkTools/AsgSelectionToolWrapper.h"
 #include "xAODBase/IParticleContainer.h"
-#include "PATCore/AcceptData.h"
+#include "PATCore/TAccept.h"
 #include <vector>
 #include <string>
 
@@ -59,18 +59,18 @@ namespace DerivationFramework {
     
     // Write mask for each element and record to SG for subsequent selection
     for (xAOD::IParticleContainer::const_iterator pItr = particles->begin(); pItr!=particles->end(); ++pItr) {
-      asg::AcceptData theAccept=m_tool->accept(*pItr); 
+      Root::TAccept theAccept(m_tool->accept(*pItr)); 
       if(m_cut==""){
-        bool pass_selection = static_cast<bool>(theAccept);
-        if(pass_selection) decorator(**pItr) = 1;
-        else decorator(**pItr) = 0;
+	bool pass_selection = (bool) theAccept;
+	if(pass_selection) decorator(**pItr) = 1;
+	else decorator(**pItr) = 0;
       }
       else{
-        if (theAccept.getCutResult(m_cut)) {
-          decorator(**pItr) = 1;
-        } else {
-          decorator(**pItr) = 0;
-        }
+	if (theAccept.getCutResult(m_cut)) {
+	  decorator(**pItr) = 1;
+	} else {
+	  decorator(**pItr) = 0;
+	}
       }
     }
         
diff --git a/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.cxx b/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.cxx
index f103251e46e3902be4f6a653ca395526d1e01c13..6c7ce63a88aa924f5666a36580209f55250089f1 100644
--- a/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.cxx
+++ b/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.cxx
@@ -74,13 +74,13 @@ StatusCode PrimaryDPDPrescaler::initialize()
 
   //Print summary info and declare all child filters to CutFlwSvc
   ATH_MSG_DEBUG( "Accept Algs, Size: "  <<  m_theAcceptAlgs.size()  <<  " Empty: " << m_theAcceptAlgs.empty() );
-  for(std::vector<Algorithm*>::iterator i=m_theAcceptAlgs.begin(),end=m_theAcceptAlgs.end(); i != end; ++i) {
+  for(std::vector<Gaudi::Algorithm*>::iterator i=m_theAcceptAlgs.begin(),end=m_theAcceptAlgs.end(); i != end; ++i) {
     ATH_MSG_DEBUG( (*i)->name() );
     cutFlowSvc()->registerCut((*i)->name(), "", cutID());
   }
 
   ATH_MSG_DEBUG( "Require Algs, Size: " <<  m_theRequireAlgs.size()  <<  " Empty: " << m_theRequireAlgs.empty() );
-  for(std::vector<Algorithm*>::iterator i=m_theRequireAlgs.begin(),end=m_theRequireAlgs.end(); i != end; ++i) {
+  for(std::vector<Gaudi::Algorithm*>::iterator i=m_theRequireAlgs.begin(),end=m_theRequireAlgs.end(); i != end; ++i) {
     ATH_MSG_DEBUG(  (*i)->name() );
     cutFlowSvc()->registerCut((*i)->name(), "", cutID());
   }
@@ -270,7 +270,7 @@ void PrimaryDPDPrescaler::handle(const Incident& inc) {
 
 
 //__________________________________________________________________________
-StatusCode PrimaryDPDPrescaler::decodeAlgorithms(StringArrayProperty *theAlgNames, std::vector<Algorithm*> *theAlgs)
+StatusCode PrimaryDPDPrescaler::decodeAlgorithms(StringArrayProperty *theAlgNames, std::vector<Gaudi::Algorithm*> *theAlgs)
 {
   // Reset the list of Algorithms
   theAlgs->clear( );
@@ -291,21 +291,21 @@ StatusCode PrimaryDPDPrescaler::decodeAlgorithms(StringArrayProperty *theAlgName
       // Algorithm object.
       const std::string& theName = (*it);
       IAlgorithm* theIAlg;
-      Algorithm*  theAlgorithm;
+      Gaudi::Algorithm*  theAlgorithm;
       result = theAlgMgr->getAlgorithm( theName, theIAlg );
       if ( result.isSuccess( ) ) {
 	try{
-	  theAlgorithm = dynamic_cast<Algorithm*>(theIAlg);
+	  theAlgorithm = dynamic_cast<Gaudi::Algorithm*>(theIAlg);
 	} catch(...){
           result = StatusCode::FAILURE;
 	}
       }
       if ( result.isSuccess( ) ) {
 	// Check that the specified algorithm doesn't already exist in the list
-	std::vector<Algorithm*>::iterator ita;
-	std::vector<Algorithm*>::iterator itaend = theAlgs->end( );
+	std::vector<Gaudi::Algorithm*>::iterator ita;
+	std::vector<Gaudi::Algorithm*>::iterator itaend = theAlgs->end( );
 	for (ita = theAlgs->begin(); ita != itaend; ita++) {
-	  Algorithm* existAlgorithm = (*ita);
+          Gaudi::Algorithm* existAlgorithm = (*ita);
 	  if ( theAlgorithm == existAlgorithm ) {
 	    result = StatusCode::FAILURE;
 	    break;
@@ -332,7 +332,7 @@ StatusCode PrimaryDPDPrescaler::decodeAlgorithms(StringArrayProperty *theAlgName
 //__________________________________________________________________________
 bool PrimaryDPDPrescaler::isEventAccepted()
 {
-  typedef std::vector<Algorithm*>::iterator AlgIter;
+  typedef std::vector<Gaudi::Algorithm*>::iterator AlgIter;
   bool result = true;
  
   // Loop over all Algorithms in the accept list to see
@@ -352,6 +352,8 @@ bool PrimaryDPDPrescaler::isEventAccepted()
       bool passRequireAlgs(true);
 
 
+      const EventContext& ctx = Gaudi::Hive::currentContext();
+
       // Accept Algs (OR)
       bool isPassed(false);
       if ( m_theAcceptAlgs.empty() )
@@ -360,7 +362,8 @@ bool PrimaryDPDPrescaler::isEventAccepted()
         }
       for(AlgIter i=m_theAcceptAlgs.begin(),end=m_theAcceptAlgs.end(); i != end; ++i)
         {
-          if ( (*i)->isExecuted() && (*i)->filterPassed() )
+          if ( (*i)->execState(ctx).state() == AlgExecState::State::Done &&
+               (*i)->execState(ctx).filterPassed() )
             {
               isPassed = true;
               break;
@@ -373,7 +376,8 @@ bool PrimaryDPDPrescaler::isEventAccepted()
       bool isFailed(false);
       for(AlgIter i=m_theRequireAlgs.begin(),end=m_theRequireAlgs.end(); i != end; ++i)
         {
-          if ( (*i)->isExecuted() && !(*i)->filterPassed() )
+          if ( (*i)->execState(ctx).state() == AlgExecState::State::Done &&
+               ! (*i)->execState(ctx).filterPassed() )
             {
               isFailed = true;
               break;
diff --git a/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.h b/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.h
index 90b76e6e7f61aba8510c341a48bc6f5079a4ef1a..759de6ede7e7bd1b6435e780f730340f806caee4 100644
--- a/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.h
+++ b/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.h
@@ -46,7 +46,7 @@ public:
   // Private methods
 private:
 
-  StatusCode decodeAlgorithms(StringArrayProperty *theAlgNames, std::vector<Algorithm*> *theAlgs);
+  StatusCode decodeAlgorithms(StringArrayProperty *theAlgNames, std::vector<Gaudi::Algorithm*> *theAlgs);
   bool       isEventAccepted();
 
   void ResetSelfDescription();
@@ -78,10 +78,10 @@ private:
   double m_prescale;
   
   /// List of algorithms to combine with logical OR
-  std::vector<Algorithm*>  m_theAcceptAlgs;
+  std::vector<Gaudi::Algorithm*>  m_theAcceptAlgs;
 
   /// List of algorithms to combine with logical AND
-  std::vector<Algorithm*>  m_theRequireAlgs;
+  std::vector<Gaudi::Algorithm*>  m_theRequireAlgs;
   
 
   /// List of algorithms names to combine with logical OR
diff --git a/Projects/AthSimulation/externals.txt b/Projects/AthSimulation/externals.txt
index 8e6da56d3719325b70e94448557f1fe64750a4bd..6ef7f9b82ab2bfc02891e25f8d25aa252727cdc4 100644
--- a/Projects/AthSimulation/externals.txt
+++ b/Projects/AthSimulation/externals.txt
@@ -9,4 +9,4 @@
 AthSimulationExternalsVersion = 2.0.15
 
 # The version of atlas/Gaudi to use:
-GaudiVersion = v30r5.003
+GaudiVersion = v31r0.000
diff --git a/Projects/Athena/externals.txt b/Projects/Athena/externals.txt
index 3d7575d135ab79d071cf57f3c2418c25acd361f3..9527c8037d384bb5a54beb38cb7d466c0b0c4ce9 100644
--- a/Projects/Athena/externals.txt
+++ b/Projects/Athena/externals.txt
@@ -9,4 +9,4 @@
 AthenaExternalsVersion = 2.0.15
 
 # The version of atlas/Gaudi to use: 
-GaudiVersion = v30r5.003
+GaudiVersion = v31r0.000
diff --git a/Projects/Athena/package_filters.txt b/Projects/Athena/package_filters.txt
index 0bc39015a1adde3d90f5ac8d0bdf4bed8d6f96ee..2c431ffaabe675392dcbe21e3af287dd3cff3724 100644
--- a/Projects/Athena/package_filters.txt
+++ b/Projects/Athena/package_filters.txt
@@ -64,3 +64,7 @@
 
 # Don't build PerfMonVTune which has external Intel tool dependency
 - Control/PerformanceMonitoring/PerfMonVTune
+
+# Old packages that don't work with AthenaMT
+- LArCalorimeter/LArSim
+- PhysicsAnalysis/HiggsPhys/HSG5/HSG5DPDUtils
diff --git a/Reconstruction/MET/METReconstruction/src/METReaderAlg.cxx b/Reconstruction/MET/METReconstruction/src/METReaderAlg.cxx
index 8578113b765cb44ea6632dadba503f478862e142..347e5f2fc3d7f60867188c3e3f8ab86874b11a22 100644
--- a/Reconstruction/MET/METReconstruction/src/METReaderAlg.cxx
+++ b/Reconstruction/MET/METReconstruction/src/METReaderAlg.cxx
@@ -62,7 +62,7 @@ namespace met {
 
   //**********************************************************************
 
-  StatusCode METReaderAlg::execute_r (const EventContext& ctx) const{ 
+  StatusCode METReaderAlg::execute (const EventContext& ctx) const{ 
     ATH_MSG_VERBOSE("Executing " << name() << "...");
     // Loop over tools.
 
diff --git a/Reconstruction/MET/METReconstruction/src/METReaderAlg.h b/Reconstruction/MET/METReconstruction/src/METReaderAlg.h
index 932ccc688b4f6427dac08d5d9d619df1a8f8ddbe..befc14ef5d587aea94cbd9ac96fd6c73ec343fd2 100644
--- a/Reconstruction/MET/METReconstruction/src/METReaderAlg.h
+++ b/Reconstruction/MET/METReconstruction/src/METReaderAlg.h
@@ -26,7 +26,7 @@ namespace met {
 
     /// Athena algorithm's Hooks
     virtual StatusCode  initialize() override;
-    virtual StatusCode  execute_r (const EventContext& ctx) const override;
+    virtual StatusCode  execute (const EventContext& ctx) const override;
     virtual StatusCode  finalize() override;
 
   private: 
diff --git a/Reconstruction/RecExample/RecExCommon/share/AnalysisCommon_topOptions.py b/Reconstruction/RecExample/RecExCommon/share/AnalysisCommon_topOptions.py
index abba4bb4e4cec195731fa09785e68df07f0bd5f9..9aac79c1a85bb60d5e04941928f51654a1518448 100644
--- a/Reconstruction/RecExample/RecExCommon/share/AnalysisCommon_topOptions.py
+++ b/Reconstruction/RecExample/RecExCommon/share/AnalysisCommon_topOptions.py
@@ -4,7 +4,6 @@ include.block ("RecExCommon/AnalysisCommon_topOptions.py")
 ## Common job preparation ##
 ############################
 
-# gbl.AthenaServices.SetFatalHandler(438)
 svcMgr.CoreDumpSvc.FatalHandler = 438
 import traceback
 
diff --git a/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py b/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py
index 0cf0bb1102499b540dcb8d7985179c1d160a0e40..c187b44259ff514e346d9d0799ec604168607f96 100644
--- a/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py
+++ b/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py
@@ -4,7 +4,6 @@ include.block ("RecExCommon/RecExCommon_topOptions.py")
 ## Common job preparation ##
 ############################
 
-# gbl.AthenaServices.SetFatalHandler(438)
 svcMgr.CoreDumpSvc.FatalHandler = 438
 import traceback
 
diff --git a/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.cxx b/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.cxx
index 125240dd1a231878fd79e62b7b7b225c37a99b00..fb4b6e926cd776650912d5c45ee13f428f7d108f 100644
--- a/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.cxx
+++ b/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.cxx
@@ -73,7 +73,7 @@ namespace ClusterMatching {
     return StatusCode::SUCCESS;
   }
 
-  StatusCode CaloClusterMatchLinkAlg::execute_r(const EventContext& ctx) const
+  StatusCode CaloClusterMatchLinkAlg::execute(const EventContext& ctx) const
   {  
     ATH_MSG_DEBUG ("Executing " << name() << "...");
 
diff --git a/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.h b/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.h
index b0db9fb7dfd46eea58cc5852f9a5c341f5bf0954..2cc19713aa61d1a96a7bc47f865503f79f8632d6 100644
--- a/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.h
+++ b/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.h
@@ -44,7 +44,7 @@ namespace ClusterMatching {
 
     // Athena algorithm's Hooks
     virtual StatusCode  initialize();
-    virtual StatusCode  execute_r(const EventContext& ctx) const;
+    virtual StatusCode  execute(const EventContext& ctx) const;
     virtual StatusCode  finalize();
 
     /////////////////////////////////////////////////////////////////// 
diff --git a/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.cxx b/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.cxx
index a021c920ee85a9108c96a9fdf5f6db74e2a15902..d50a56161fcf3712a8e599ac8f58c702fa209205 100644
--- a/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.cxx
+++ b/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.cxx
@@ -91,7 +91,7 @@ StatusCode egammaForwardBuilder::finalize()
 }
 
 // ======================================================================
-StatusCode egammaForwardBuilder::execute_r(const EventContext& ctx) const
+StatusCode egammaForwardBuilder::execute(const EventContext& ctx) const
 {
   ATH_MSG_DEBUG("Executing egammaForwardBuilder ");
 
diff --git a/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.h b/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.h
index babf2d4e0b3b32f950fd8d70614162be314e9f56..9af4efff34b8ecca4fca849e374789b11d099dae 100644
--- a/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.h
+++ b/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.h
@@ -60,7 +60,7 @@ class egammaForwardBuilder : public AthReentrantAlgorithm
   /** @brief finalize method*/
   virtual StatusCode finalize() override final;
   /** @brief execute method*/
-  virtual StatusCode execute_r(const EventContext& ctx) const override final;
+  virtual StatusCode execute(const EventContext& ctx) const override final;
 
  private:
 
diff --git a/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.cxx b/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.cxx
index 95fdb681f65f87b81e0181d422e5a00cf62c4196..e571a700fb7366b0f672b7a108a6238b714a3ccc 100644
--- a/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.cxx
+++ b/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.cxx
@@ -62,7 +62,7 @@ StatusCode egammaTopoClusterCopier::finalize() {
 }
 
 // =========================================================================
-StatusCode egammaTopoClusterCopier::execute_r(const EventContext& ctx) const {
+StatusCode egammaTopoClusterCopier::execute(const EventContext& ctx) const {
 
   SG::ReadHandle<xAOD::CaloClusterContainer> inputTopoclusters(m_inputTopoCollection, ctx);
   SG::WriteHandle<xAOD::CaloClusterContainer> outputTopoclustersShallow(m_outputTopoCollectionShallow, ctx);
diff --git a/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.h b/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.h
index 4966225d026880cc97147e03ae4d8bfe3bf86c95..3daa1124432952d0a3f4485eca83d38a7b348649 100644
--- a/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.h
+++ b/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.h
@@ -23,7 +23,7 @@ class egammaTopoClusterCopier : public AthReentrantAlgorithm {
   /** @brief initialize method */
   virtual StatusCode initialize() override final;
   /** @brief execute on container */
-  virtual StatusCode execute_r(const EventContext& ctx) const override final;
+  virtual StatusCode execute(const EventContext& ctx) const override final;
   /** @brief finalize method */
   virtual StatusCode finalize() override final;
   
diff --git a/Simulation/G4Utilities/MCTruthAlgs/MCTruthAlgs/TrackRecordFilter.h b/Simulation/G4Utilities/MCTruthAlgs/MCTruthAlgs/TrackRecordFilter.h
index c84ebd79f358fc9e44ce09212fd75c844ed25d0a..efda43314d69d54dd6cb37ecb1053403727048f0 100755
--- a/Simulation/G4Utilities/MCTruthAlgs/MCTruthAlgs/TrackRecordFilter.h
+++ b/Simulation/G4Utilities/MCTruthAlgs/MCTruthAlgs/TrackRecordFilter.h
@@ -26,7 +26,7 @@ public:
 
   StatusCode initialize() override;
   StatusCode finalize() override;
-  StatusCode execute_r(const EventContext& ctx) const override;
+  StatusCode execute(const EventContext& ctx) const override;
 
 private:
   SG::ReadHandleKey<TrackRecordCollection> m_inputKey;
diff --git a/Simulation/G4Utilities/MCTruthAlgs/src/TrackRecordFilter.cxx b/Simulation/G4Utilities/MCTruthAlgs/src/TrackRecordFilter.cxx
index d0002f3986f571114e37a2d1e0be59757ea2b432..7dbd73b229c10bb23cefb19c51c1a76c186375c8 100755
--- a/Simulation/G4Utilities/MCTruthAlgs/src/TrackRecordFilter.cxx
+++ b/Simulation/G4Utilities/MCTruthAlgs/src/TrackRecordFilter.cxx
@@ -43,7 +43,7 @@ StatusCode TrackRecordFilter::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode TrackRecordFilter::execute_r(const EventContext& ctx) const {
+StatusCode TrackRecordFilter::execute(const EventContext& ctx) const {
 
   // Get message service
   ATH_MSG_DEBUG ( "TrackRecordFilter::execute()" );
diff --git a/Simulation/ISF/ISF_Core/ISF_Services/test/TruthSvc_test.cxx b/Simulation/ISF/ISF_Core/ISF_Services/test/TruthSvc_test.cxx
index 9cfd4baa78e729a98ebfa13993122083bc309057..3b701f284acf3759a9a1f5e5a1a555804632e79d 100644
--- a/Simulation/ISF/ISF_Core/ISF_Services/test/TruthSvc_test.cxx
+++ b/Simulation/ISF/ISF_Core/ISF_Services/test/TruthSvc_test.cxx
@@ -623,7 +623,7 @@ namespace ISFTesting {
 int main(int argc, char *argv[]) {
   ::testing::InitGoogleTest( &argc, argv );
 
-  // gets stuck forever while trying to finalize boost crap inside SGTools:
+  // gets stuck forever while trying to finalize boost stuff inside SGTools:
   //return RUN_ALL_TESTS();
   // skips proper finalization:
   std::quick_exit( RUN_ALL_TESTS() );
diff --git a/Simulation/RunDependentSim/RunDependentSimComps/python/RunDMCFlags.py b/Simulation/RunDependentSim/RunDependentSimComps/python/RunDMCFlags.py
index 9080a3e3a77a15b7aec400269b869a93d0562d8a..7205a0394d65c8c10cd7167a23608a16cf10c3ac 100644
--- a/Simulation/RunDependentSim/RunDependentSimComps/python/RunDMCFlags.py
+++ b/Simulation/RunDependentSim/RunDependentSimComps/python/RunDMCFlags.py
@@ -140,7 +140,12 @@ class RunToTimestampDict(JobProperty):
         300000:1500000000, ##MC16 pp (25 ns bunch spacing, nominal mu, 2017)
         305000:1525000000, ##MC16 pp (5 TeV 2017)
         309000:1540000000, ##MC16 XeXe (2017)
-        310000:1550000000  ##MC16 pp (25 ns bunch spacing, nominal mu, 2018)
+        310000:1550000000, ##MC16 pp (25 ns bunch spacing, nominal mu, 2018)
+        311000:1551000000, ##MC16 pp (25 ns bunch spacing, low mu, 2018)
+        312000:1552000000, ##MC16 pp (900 GeV high-beta ALFA, 2018)
+        313000:1553000000  ##MC16 PbPb (2018)
+
+
         }
     def addEntry( self, run, timestamp, force=False):
         if not type(run) == int:
diff --git a/TestBeam/TBRec/src/TBAlgoSequencer.cxx b/TestBeam/TBRec/src/TBAlgoSequencer.cxx
index f10becf0d506dece97304217cb0f12bff0fa2c8e..2ebd155c0aef66271b2a518a12a53203f556d47d 100644
--- a/TestBeam/TBRec/src/TBAlgoSequencer.cxx
+++ b/TestBeam/TBRec/src/TBAlgoSequencer.cxx
@@ -16,7 +16,7 @@
 
 TBAlgoSequencer::TBAlgoSequencer(const std::string& name,
 				 ISvcLocator* pSvcLocator) :
-  AthAlgorithm(name,pSvcLocator)
+  ::AthLegacySequence   ( name, pSvcLocator )
   , m_timingOn(true)
   , m_eventPrintFreq(100)
   , m_eventCounter(0)
@@ -56,7 +56,7 @@ TBAlgoSequencer::initialize()
 	  ! registerAlgs.isFailure() )
     {
       ListItem   theAlgItem(*subAlgos);
-      Algorithm* theAlgo;
+      Gaudi::Algorithm* theAlgo;
       registerAlgs = createSubAlgorithm(theAlgItem.type(),theAlgItem.name(), 
 					theAlgo);
       if ( ! registerAlgs.isFailure() && theAlgo != 0 )
@@ -93,9 +93,14 @@ TBAlgoSequencer::initialize()
 
   m_rejectPattern.clear();
   
-  return numberOfAlgorithms > 0
-    ? StatusCode::SUCCESS
-    : StatusCode::FAILURE;
+  // return numberOfAlgorithms > 0
+  //   ? StatusCode::SUCCESS
+  //   : StatusCode::FAILURE;
+
+  if (numberOfAlgorithms == 0) return StatusCode::FAILURE;
+
+  return AthLegacySequence::initialize();
+  
 }
 
 /////////////
@@ -137,12 +142,14 @@ TBAlgoSequencer::execute()
   AlgoIterator algoCounter = m_subAlgos.begin();
   StatusCode executeAlgs;
 
+  const EventContext& ctx = getContext();
+
   unsigned int algoIndex = 0;
   while ( ! executeAlgs.isFailure() && algoCounter != m_subAlgos.end() )
     {
       // execute the algorithm
       if ( m_timingOn ) theTicker->chronoStart(m_algoNameStore[algoIndex]);
-      executeAlgs = (*algoCounter)->execute();
+      executeAlgs = (*algoCounter)->execute(ctx);
       if ( m_timingOn ) theTicker->chronoStop(m_algoNameStore[algoIndex]);
       // failure/reject
       if ( executeAlgs.isFailure() )
@@ -264,6 +271,7 @@ TBAlgoSequencer::finalize()
   ATH_MSG_INFO
     ( "======================================================== " );
 
-  return StatusCode::SUCCESS;
+
+  return AthLegacySequence::finalize();
 
 }
diff --git a/TestBeam/TBRec/src/TBAlgoSequencer.h b/TestBeam/TBRec/src/TBAlgoSequencer.h
index d21fcdf5dd80e486297b4d152639775d7351839e..1566142c148018f0f3078b3efaa3f46cf879aa65 100755
--- a/TestBeam/TBRec/src/TBAlgoSequencer.h
+++ b/TestBeam/TBRec/src/TBAlgoSequencer.h
@@ -11,7 +11,8 @@
 //                                                                           //
 ///////////////////////////////////////////////////////////////////////////////
 
-#include "AthenaBaseComps/AthAlgorithm.h"
+#include "AthenaBaseComps/AthLegacySequence.h"
+
 
 #include <string>
 #include <vector>
@@ -19,11 +20,11 @@
 
 class StoreGateSvc;
 
-class TBAlgoSequencer : public AthAlgorithm
+class TBAlgoSequencer : public AthLegacySequence
 {
 
   typedef std::string             KeyType;
-  typedef std::vector<Algorithm*> AlgoStore;
+  typedef std::vector<Gaudi::Algorithm*> AlgoStore;
   typedef AlgoStore::iterator     AlgoIterator;
 
  public:
diff --git a/TileCalorimeter/TileCalib/TileCalibAlgs/TileCalibAlgs/TileLaserDefaultCalibTool.h b/TileCalorimeter/TileCalib/TileCalibAlgs/TileCalibAlgs/TileLaserDefaultCalibTool.h
index df52a945e1fd61cd02444e5cb975461f5769933a..a65829244a79afe6223894d2f1d1bf00e6909c0d 100644
--- a/TileCalorimeter/TileCalib/TileCalibAlgs/TileCalibAlgs/TileLaserDefaultCalibTool.h
+++ b/TileCalorimeter/TileCalib/TileCalibAlgs/TileCalibAlgs/TileLaserDefaultCalibTool.h
@@ -5,19 +5,22 @@
 #ifndef TILECALIBALG_TILELASERDEFAULTCALIBTOOL_H
 #define TILECALIBALG_TILELASERDEFAULTCALIBTOOL_H
 
-#include "AthenaBaseComps/AthAlgTool.h"
 
+// Tile includes
 #include "TileCalibAlgs/ITileCalibTool.h"
 #include "TileEvent/TileDQstatus.h"
-#include "StoreGate/ReadHandleKey.h"
-#include <string> 
-#include <map>
-#include <cmath>
-
 #include "TileConditions/TileCablingService.h"
 #include "TileConditions/TileCondToolEmscale.h"
 #include "TileConditions/ITileBadChanTool.h"
+#include "TileConditions/ITileDCSTool.h"
 
+// Athena includes
+#include "AthenaBaseComps/AthAlgTool.h"
+#include "StoreGate/ReadHandleKey.h"
+
+#include <string>
+#include <map>
+#include <cmath>
 
 
 #define NDIODES 10
@@ -39,7 +42,6 @@ class TileLaserObject;
 class TileHWID;
 class TFile;
 class RunningStat;
-class TileDCSSvc;
 class ITileStuckBitsProbsTool;
 
 class TileLaserDefaultCalibTool : public AthAlgTool, virtual public ITileCalibTool
@@ -74,8 +76,7 @@ class TileLaserDefaultCalibTool : public AthAlgTool, virtual public ITileCalibTo
   ToolHandle<ITileStuckBitsProbsTool> m_stuckBitsProbs;
   SG::ReadHandleKey<TileDQstatus> m_dqStatusKey;
 
-  ServiceHandle<TileDCSSvc>   m_tileDCSSvc; //!< Pointer to TileDCSSvc
-
+  ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"};
 
   // Parameter which will end up in the ROOTuple
   //
diff --git a/TileCalorimeter/TileCalib/TileCalibAlgs/src/TileLaserDefaultCalibTool.cxx b/TileCalorimeter/TileCalib/TileCalibAlgs/src/TileLaserDefaultCalibTool.cxx
index 614effeabff42477a1502002899f6b447b833c4e..650d7f9bf165d24394c456e2f6f8866d57e0023a 100644
--- a/TileCalorimeter/TileCalib/TileCalibAlgs/src/TileLaserDefaultCalibTool.cxx
+++ b/TileCalorimeter/TileCalib/TileCalibAlgs/src/TileLaserDefaultCalibTool.cxx
@@ -2,7 +2,15 @@
   Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
+// Tile includes
 #include "TileCalibAlgs/TileLaserDefaultCalibTool.h"
+#include "TileEvent/TileRawChannelContainer.h"
+#include "TileEvent/TileLaserObject.h"
+#include "TileConditions/TileCablingService.h"
+#include "TileCalibBlobObjs/TileCalibUtils.h"
+#include "TileConditions/ITileBadChanTool.h"
+#include "TileMonitoring/ITileStuckBitsProbsTool.h"
+
 
 #include "GaudiKernel/MsgStream.h"
 #include "GaudiKernel/Service.h"
@@ -13,14 +21,6 @@
 #include "Identifier/HWIdentifier.h"
 #include "StoreGate/ReadHandle.h"
 
-#include "TileEvent/TileRawChannelContainer.h"
-#include "TileEvent/TileLaserObject.h"
-#include "TileConditions/TileCablingService.h"
-#include "TileCalibBlobObjs/TileCalibUtils.h"
-#include "TileConditions/ITileBadChanTool.h"
-#include "TileConditions/TileDCSSvc.h"
-
-#include "TileMonitoring/ITileStuckBitsProbsTool.h"
 
 #include "TFile.h"
 #include "TTree.h"
@@ -46,7 +46,6 @@ TileLaserDefaultCalibTool::TileLaserDefaultCalibTool(const std::string& type, co
   m_tileToolEmscale("TileCondToolEmscale"),
   m_tileBadChanTool("TileBadChanTool"),
   m_stuckBitsProbs(""),
-  m_tileDCSSvc("TileDCSSvc",name),
   m_toolRunNo(0),
   m_ADC_problem(0),
   m_las_filter(0),
@@ -123,7 +122,6 @@ TileLaserDefaultCalibTool::TileLaserDefaultCalibTool(const std::string& type, co
   declareProperty("rawChannelContainer", m_rawChannelContainerName="");
   declareProperty("laserObjContainer", m_laserContainerName="");
   declareProperty("pisaMethod2", m_pisaMethod2=true);
-  declareProperty("TileDCSSvc",m_tileDCSSvc);
   declareProperty("StuckBitsProbsTool", m_stuckBitsProbs);
   declareProperty("TileDQstatus", m_dqStatusKey = "TileDQstatus");
 } // TileLaserDefaultCalibTool::TileLaserDefaultCalibTool
@@ -273,9 +271,9 @@ StatusCode TileLaserDefaultCalibTool::initialize(){
   ATH_CHECK( m_tileBadChanTool.retrieve() );
   
 
-  ATH_CHECK( m_tileDCSSvc.retrieve() );
+  ATH_CHECK( m_tileDCS.retrieve() );
 
-  CHECK( m_dqStatusKey.initialize() );
+  ATH_CHECK( m_dqStatusKey.initialize() );
 
   return StatusCode::SUCCESS;
 }
@@ -895,11 +893,9 @@ StatusCode TileLaserDefaultCalibTool::finalizeCalculations(){
   for(int part=0; part<NPARTITIONS; ++part){
     int ros = part+1;
     for(int drawer=0; drawer<NDRAWERS; ++drawer){
-      int module = drawer+1;
       for(int channel=0; channel<NCHANNELS; ++channel){
-        int pmt = abs(m_cabling->channel2hole(ros,channel));
-        m_HV[part][drawer][channel] = m_tileDCSSvc->getDCSHV(ros, module, pmt);
-        m_HVSet[part][drawer][channel] = m_tileDCSSvc->getDCSHVSET(ros, module, pmt);
+        m_HV[part][drawer][channel] = m_tileDCS->getChannelHV(ros, drawer, channel);
+        m_HVSet[part][drawer][channel] = m_tileDCS->getChannelHVSet(ros, drawer, channel);
       } // channel
     } // drawers
   } // partitions
diff --git a/TileCalorimeter/TileConditions/TileConditions/TileConditionsDict.h b/TileCalorimeter/TileConditions/TileConditions/TileConditionsDict.h
index 454b91d3dbc179243791d17f702d42e64b3b469a..d5ba3b83097023593be0e311ea9af6585e07d307 100644
--- a/TileCalorimeter/TileConditions/TileConditions/TileConditionsDict.h
+++ b/TileCalorimeter/TileConditions/TileConditions/TileConditionsDict.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 
@@ -9,6 +9,5 @@
 #include "TileConditions/TileBadChanTool.h"
 #include "TileConditions/TileCablingService.h"
 #include "TileConditions/TileCablingSvc.h"
-#include "TileConditions/TileDCSSvc.h"
 
-#endif
+#endif // TILECONDITIONS_TILECONDITIONSDICT_H
diff --git a/TileCalorimeter/TileConditions/TileConditions/TileDCSSvc.h b/TileCalorimeter/TileConditions/TileConditions/TileDCSSvc.h
deleted file mode 100644
index e1376a8d04e15a0bfd56f4948bae3d78b001f386..0000000000000000000000000000000000000000
--- a/TileCalorimeter/TileConditions/TileConditions/TileDCSSvc.h
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#ifndef TILECONDITIONS_TILECONDDCS_H
-#define TILECONDITIONS_TILECONDDCS_H
-
-// Tile includes
-#include "TileConditions/ITileDCSTool.h"
-#include "TileConditions/TileCablingSvc.h"
-
-// Athena includes
-#include "AthenaBaseComps/AthService.h"
-
-// Gaudi includes
-#include "GaudiKernel/ToolHandle.h"
-
-// Forward declaration
-class TileCablingService;
-
-
-template <class TYPE> class SvcFactory;
-
-
-//Class to provide DCS information about modules from the COOL database
-class TileDCSSvc: virtual public AthService {
-  friend class SvcFactory<TileDCSSvc>;
-
- public:
-  static const InterfaceID& interfaceID(); /*as in TileCablingSvc.h*/
-  TileDCSSvc( const std::string& name, ISvcLocator* pSvcLocator );
-  virtual ~TileDCSSvc(){ /*do nothing*/}
-  virtual StatusCode initialize();
-  virtual StatusCode finalize();
-  StatusCode queryInterface(const InterfaceID& riid, void** ppvInterface);
-
-  enum TileDCSStatus {NON_EXISTING=0, UNKNOWN=1,
-                      OK_DRAWER=10, OK_KNOWNBADPMT, OK,
-                      WARNING_DRAWER=20, WARNING_KNOWNBADPMT, WARNING,
-                      ALERT_DRAWER=30, ALERT_KNOWNBADPMT, ALERT};
-
-  // these 3 methods return values found in COOL
-  // and they use ros=1,2,3,4, module and pmt as parameter, all three starts from "1", like in DCS
-  float getDCSHV     (int ros,  int module,  int pmt) const;
-  float getDCSHVSET  (int ros,  int module,  int pmt) const;
-  int   getDCSSTATES (int ros,  int module) const;
-
-  // these 3 methods return status values which can be used to detect bad PMTs
-  // ros=1,2,3,4 as usual, while drawer and channel starts from "0"
-  TileDCSStatus getDCSHVSTATUS (int ros, int drawer, int channel) const; // status for HV deviation
-  TileDCSStatus getDCSSTATUS   (int ros, int drawer) const;              // status of drawer voltages
-  TileDCSStatus getDCSSTATUS   (int ros, int drawer, int channel) const;
-
-  bool statusHVIsBad (int ros, int drawer, int channel) const;
-  bool statusIsBad (int ros, int drawer) const;
-  bool statusIsBad (int ros, int drawer, int channel) const;
-
-  int  getNcalls() const { return m_ncalls; } // how many times callBack was triggered
-
-  std::string partitionName(int ros) {return m_partName[ros];}
-
- private:
-
-  ToolHandle<ITileDCSTool> m_dcsTool{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"};
-
-  int m_ncalls;
-
-  const TileCablingService* m_cabling;
-
-  int m_pmt2channel[2][68];
-
-  std::vector<std::string> m_partName;
-
-  int m_version;
-};
-
-#endif
diff --git a/TileCalorimeter/TileConditions/TileConditions/selection.xml b/TileCalorimeter/TileConditions/TileConditions/selection.xml
index f73dffa515be83249e464ad07b86a9b8938498ff..046fd44f3b72c48cff4710b423365f86889d2647 100644
--- a/TileCalorimeter/TileConditions/TileConditions/selection.xml
+++ b/TileCalorimeter/TileConditions/TileConditions/selection.xml
@@ -4,6 +4,5 @@
 <class name="ITileBadChanTool" />
 <class name="TileCablingService" />
 <class name="TileCablingSvc" />
-<class name="TileDCSSvc" />
 </lcgdict>
 
diff --git a/TileCalorimeter/TileConditions/python/TileInfoConfigurator.py b/TileCalorimeter/TileConditions/python/TileInfoConfigurator.py
index 499fb26ba9e9955e5250a5d87bdac11d8374503b..e47d47a876116faa8f93e99dac6adb8979fc644f 100644
--- a/TileCalorimeter/TileConditions/python/TileInfoConfigurator.py
+++ b/TileCalorimeter/TileConditions/python/TileInfoConfigurator.py
@@ -387,7 +387,7 @@ class _TileInfoConfigurator( TileInfoLoader ):
             return
         self._coolDCSIsConfigured = True
 
-        ##     #=== ensure the availability of TileDCSSvc
+        ##     #=== ensure the availability of TileDCS information
         from AthenaCommon.GlobalFlags import globalflags
         from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
         TileUseDCS = (not athenaCommonFlags.isOnline()) and globalflags.DataSource()=='data'
@@ -410,20 +410,6 @@ class _TileInfoConfigurator( TileInfoLoader ):
                                            ReadSTATES = useSTATUS,
                                            TileDCS = dcs)
 
-        from AthenaCommon.AppMgr import ServiceMgr as svcMgr
-        if TileUseDCS and not hasattr(svcMgr, "TileDCSSvc"):
-
-            self._msg.info("Adding TileDCSSvc to ServiceMgr")
-            svcMgr += CfgMgr.TileDCSSvc()
-
-            from IOVDbSvc.CondDB import conddb
-            if (conddb.GetInstance() == 'CONDBR2'):
-                self._msg.info("setting up TileDCSSvc for RUN2")
-                svcMgr.TileDCSSvc.Version=2
-            else:
-                self._msg.info("setting up TileDCSSvc for RUN1")
-                svcMgr.TileDCSSvc.Version=1
-
 
     #_______________________________________________________________
     def setupCOOLDspThreshold(self, defTag = "", dbConnection = ""):
diff --git a/TileCalorimeter/TileConditions/src/TileDCSSvc.cxx b/TileCalorimeter/TileConditions/src/TileDCSSvc.cxx
deleted file mode 100644
index 1f9a3b14657f492fb136a01402a40abbf6b5fc02..0000000000000000000000000000000000000000
--- a/TileCalorimeter/TileConditions/src/TileDCSSvc.cxx
+++ /dev/null
@@ -1,132 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-// Tile includes
-//#include "TileCalibBlobObjs/TileCalibUtils.h"
-#include "TileConditions/TileDCSSvc.h"
-//#include "src/TileDCSTool.h"
-#include "TileConditions/TileCablingService.h"
-
-// Athena includes
-#include "AthenaKernel/errorcheck.h"
-
-// Gaudi includes
-#include "GaudiKernel/ServiceHandle.h"
-
-
-static const InterfaceID IID_TileDCSSvc("TileDCSSvc", 1, 0);
-const InterfaceID& TileDCSSvc::interfaceID() {
-  return IID_TileDCSSvc;
-}
-
-TileDCSSvc::TileDCSSvc(const std::string& name, ISvcLocator* pSvcLocator)
-    : AthService(name, pSvcLocator)
-  , m_cabling(nullptr)
-  , m_version(2)
-{
-
-  declareProperty("Version", m_version); // 1 - RUN1 conditions DB, 2 - RUN2 conditions
-
-  m_partName.push_back("AUX");
-  m_partName.push_back("LBA");
-  m_partName.push_back("LBC");
-  m_partName.push_back("EBA");
-  m_partName.push_back("EBC");
-
-  m_ncalls = 0;
-
-}
-
-//_____________________________________________________________________________
-StatusCode TileDCSSvc::queryInterface(const InterfaceID& riid, void** ppvInterface) {
-  if (TileDCSSvc::interfaceID().versionMatch(riid)) {
-    *ppvInterface = dynamic_cast<TileDCSSvc*>(this);
-  } else {
-    return AthService::queryInterface(riid, ppvInterface);
-  }
-  addRef();
-  return StatusCode::SUCCESS;
-}
-
-//_____________________________________________________________________________
-StatusCode TileDCSSvc::initialize() {
-
-  //=== get TileDCSTool
-  ATH_CHECK( m_dcsTool.retrieve());
-
-  //=== get TileCablingSvc
-  ServiceHandle<TileCablingSvc> cablingSvc("TileCablingSvc", name());
-  ATH_CHECK( cablingSvc.retrieve());
-
-  //=== cache pointers to cabling helpers
-  m_cabling = cablingSvc->cablingService();
-  if (!m_cabling) {
-    ATH_MSG_ERROR( "Pointer to TileCablingService is zero: " << m_cabling);
-    return StatusCode::FAILURE;
-  }
-
-  for (int i = 0; i < 2; ++i) {
-    int ros = i + 2;
-    int channel = 0;
-    for (; channel < 48; ++channel) {
-      int pmt = std::abs(m_cabling->channel2hole(ros, channel));
-      m_pmt2channel[i][pmt - 1] = channel; // note - pmt-1 is used as index
-    }
-    for (; channel < 68; ++channel) {
-      m_pmt2channel[i][channel] = channel;
-    }
-  }
-
-
-  return StatusCode::SUCCESS;
-}
-
-//_____________________________________________________________________________
-StatusCode TileDCSSvc::finalize() {
-  return StatusCode::SUCCESS;
-}
-
-float TileDCSSvc::getDCSHV(int ros,  int module,  int pmt) const {
-  int lb_eb = (ros > 2) ? 1 : 0;
-  int channel = m_pmt2channel[lb_eb][pmt - 1];
-  return m_dcsTool->getChannelHV(ros, module - 1, channel);
-}
-
-float TileDCSSvc::getDCSHVSET(int ros,  int module,  int pmt) const {
-  int lb_eb = (ros > 2) ? 1 : 0;
-  int channel = m_pmt2channel[lb_eb][pmt - 1];
-  return m_dcsTool->getChannelHVSet(ros, module - 1, channel);
-}
-
-int   TileDCSSvc::getDCSSTATES (int ros,  int module) const {
-  return m_dcsTool->getDrawerStates(ros, module - 1);
-}
-
-
-//_____________________________________________________________________________
-TileDCSSvc::TileDCSStatus TileDCSSvc::getDCSHVSTATUS(int ros, int drawer, int channel) const {
-  return static_cast<TileDCSSvc::TileDCSStatus>(m_dcsTool->getDCSHVStatus(ros, drawer, channel));
-}
-
-//_____________________________________________________________________________
-TileDCSSvc::TileDCSStatus TileDCSSvc::getDCSSTATUS(int ros, int drawer) const {
-  return static_cast<TileDCSSvc::TileDCSStatus>(m_dcsTool->getDCSStatus(ros, drawer));
-}
-
-
-TileDCSSvc::TileDCSStatus TileDCSSvc::getDCSSTATUS(int ros, int drawer, int channel) const {
-  return static_cast<TileDCSSvc::TileDCSStatus>(m_dcsTool->getDCSStatus(ros, drawer, channel));
-}
-
-bool TileDCSSvc::statusHVIsBad (int ros, int drawer, int channel) const {
-  return m_dcsTool->isStatusHVBad(ros, drawer, channel);
-}
-
-bool TileDCSSvc::statusIsBad (int ros, int drawer) const {
-  return m_dcsTool->isStatusBad(ros, drawer);
-}
-
-bool TileDCSSvc::statusIsBad (int ros, int drawer, int channel) const {
-  return m_dcsTool->isStatusBad(ros, drawer, channel);
-}
diff --git a/TileCalorimeter/TileConditions/src/components/TileConditions_entries.cxx b/TileCalorimeter/TileConditions/src/components/TileConditions_entries.cxx
index 8b3393f48f8d509a5aac9917aef642ec9a0dacf0..bf1df2fe6d7de8505011f7bb72f3006783b0baa9 100644
--- a/TileCalorimeter/TileConditions/src/components/TileConditions_entries.cxx
+++ b/TileCalorimeter/TileConditions/src/components/TileConditions_entries.cxx
@@ -18,7 +18,6 @@
 #include "TileConditions/TileCondToolNoiseSample.h"
 #include "TileConditions/TileCondToolNoiseRawChn.h"
 #include "TileConditions/TileCondProxyWrapper.h"
-#include "TileConditions/TileDCSSvc.h"
 #include "TileConditions/TileCondDCS_Data.h"
 #include "TileConditions/TileCondToolAutoCr.h"
 #include "TileConditions/TileCondToolTMDB.h"
@@ -31,7 +30,6 @@
 
 DECLARE_COMPONENT( TileInfoLoader )
 DECLARE_COMPONENT( TileCablingSvc )
-DECLARE_COMPONENT( TileDCSSvc )
 DECLARE_COMPONENT( TileCondIdTransforms )
 DECLARE_COMPONENT( TileBadChanTool )
 DECLARE_COMPONENT( TileCondToolOfc )
diff --git a/TileCalorimeter/TileCoolDcs/python/TileDCSDataGrabber.py b/TileCalorimeter/TileCoolDcs/python/TileDCSDataGrabber.py
index 94a7acc6332a4ea6e9bdbcd40825dfb32e012c46..31e2b8f3baa2fbba732c4eca81b2e28c7c19a43c 100755
--- a/TileCalorimeter/TileCoolDcs/python/TileDCSDataGrabber.py
+++ b/TileCalorimeter/TileCoolDcs/python/TileDCSDataGrabber.py
@@ -658,7 +658,7 @@ class TileDCSDataGrabber:
                             while stmt.NextResultRow():
                                 if   varType==self.info.type_int:    value = stmt.GetInt(   1)
                                 elif varType==self.info.type_float:  value = stmt.GetDouble(1)
-                                #=== catch crap in oracle
+                                #=== catch in oracle
                                 if value < -10000:
                                     nCrap += 1
                                     continue
@@ -683,7 +683,7 @@ class TileDCSDataGrabber:
                         if not isDebug: bar.done()
                     folderVarSetList.append(folderVarSet)
                 if nCrap > 0:
-                    logging.warning("Found %i \"crap\" entries for %s, ignored those!"%(nCrap,var))
+                    logging.warning("Found %i \"bad\" entries for %s, ignored those!"%(nCrap,var))
         return folderVarSetList
 
 
diff --git a/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileCalibRec.py b/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileCalibRec.py
index 1420c85fbf025b912cc63af48aac948267bd3577..0ecbc992195ea2c8911e839985264f48d3491652 100644
--- a/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileCalibRec.py
+++ b/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileCalibRec.py
@@ -637,6 +637,9 @@ from AthenaCommon.BeamFlags import jobproperties
 #jobproperties.Beam.beamType.set_Value_and_Lock('cosmics')
 jobproperties.Beam.beamType.set_Value_and_Lock('collisions')
 
+from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
+athenaCommonFlags.FilesInput.set_Value_and_Lock(FileNameVec)
+
 from AthenaCommon.DetFlags import DetFlags
 DetFlags.Calo_setOff()  #Switched off to avoid geometry
 DetFlags.ID_setOff()
@@ -651,8 +654,6 @@ DetFlags.detdescr.LAr_setOn()
 DetFlags.detdescr.Tile_setOn()
 if TileL1CaloRun:
     DetFlags.detdescr.LVL1_setOn()
-    from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-    athenaCommonFlags.FilesInput.set_Value_and_Lock(FileNameVec)
 if ReadPool:
     DetFlags.readRDOPool.Tile_setOn()
     if TileL1CaloRun:
@@ -827,8 +828,20 @@ if not OfcFromCOOL and (doTileOpt2 or doTileOptATLAS or doTileOF1):
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
 
-from xAODEventInfoCnv.xAODEventInfoCreator import xAODMaker__EventInfoCnvAlg
-topSequence+=xAODMaker__EventInfoCnvAlg()
+if not 'newRDO' in dir() or newRDO is None:
+    if 'ReadRDO' in dir() and ReadRDO:
+        from RecExConfig.InputFilePeeker import inputFileSummary
+        from RecExConfig.ObjKeyStore import objKeyStore
+        objKeyStore.addManyTypesInputFile(inputFileSummary['eventdata_itemsList'])
+        newRDO = objKeyStore.isInInput( "xAOD::EventInfo" )
+    else:
+        newRDO = True
+
+if ReadPool and newRDO:
+    topSequence += CfgMgr.xAODMaker__EventInfoNonConstCnvAlg()
+else:
+    from xAODEventInfoCnv.xAODEventInfoCreator import xAODMaker__EventInfoCnvAlg
+    topSequence+=xAODMaker__EventInfoCnvAlg()
 
 #=============================================================
 #=== read ByteStream and reconstruct data
@@ -1190,20 +1203,6 @@ if doTileNtuple:
     dqStatus.TileDigitsContainer     = getattr (TileNtuple, 'TileDigitsContainer', '')
     dqStatus.TileRawChannelContainer = getattr (TileNtuple, 'TileRawChannelContainer', '')
 
-    # FIXME: TileAANtuple does a back-door set of properties
-    #        in TileBeamInfoProvider.  That doesn't really work with
-    #        handles and MT.  To compensate, also set the properties here.
-    def moveprop (pname):
-        pval = TileNtuple.properties()[pname]
-        if pval == TileNtuple.propertyNoValue:
-            pval = TileNtuple.getDefaultProperty(pname)
-        if pval:
-            setattr (ToolSvc.TileBeamInfoProvider, pname, pval)
-
-    moveprop ('TileBeamElemContainer')
-    moveprop ('TileDigitsContainer')
-    moveprop ('TileRawChannelContainer')
-
 if doTileMon:
     # Monitoring historgrams
     if not hasattr(svcMgr,"THistSvc"):
diff --git a/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileTBStat.py b/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileTBStat.py
index 53a19d34363384975b5c2cf3a66760cbb46b3f46..620d705a0970ed6cf4b10fda257a63c4444b4a18 100644
--- a/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileTBStat.py
+++ b/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileTBStat.py
@@ -339,6 +339,11 @@ topSequence += theTileTBDump
 theTileTBDump.dumpOnce = True
 theTileTBDump.dumpUnknown = False
 
+from TileRecUtils.TileDQstatusAlgDefault import TileDQstatusAlgDefault
+TileDQstatusAlgDefault (TileBeamElemContainer = 'TileBeamElemCnt',
+                        TileDigitsContainer = 'TileDigitsCnt',
+                        TileRawChannelContainer = 'TileRawChannelCnt')
+
 from TileTBRec.TileTBRecConf import TileTBStat
 theTileTBStat = TileTBStat()
 topSequence += theTileTBStat
diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragLWMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragLWMonTool.h
index 8bb51de01a19c9071e3dfae7b086507d0f596132..038073f4f1343aec6cb4f58397efebba5e219d3d 100644
--- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragLWMonTool.h
+++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragLWMonTool.h
@@ -16,12 +16,12 @@
 
 #include "TileMonitoring/TileFatherMonTool.h"
 #include "TileEvent/TileDQstatus.h"
+#include "TileConditions/ITileDCSTool.h"
 #include "StoreGate/ReadHandleKey.h"
 
 #include <array>
 
 class ITileBadChanTool;
-class TileDCSSvc;
 class TileDQstatus;
 class TileRawChannel;
 class TileRawChannelCollection;
@@ -67,7 +67,7 @@ class TileDQFragLWMonTool: public TileFatherMonTool {
     void fillBadDrawer(void);
 
     ToolHandle<ITileBadChanTool> m_tileBadChanTool; //!< Tile Bad Channel tool
-    ServiceHandle<TileDCSSvc> m_tileDCSSvc; //!< Pointer to TileDCSSvc
+    ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"};
 
     /*---------------------------------------------------------*/
     /* properties*/
@@ -84,7 +84,7 @@ class TileDQFragLWMonTool: public TileFatherMonTool {
     bool m_skipMasked;
     bool m_skipGapCells;
     bool m_doOnline;
-    bool m_checkDCS;  //!< if false, do not use TileDCSSvc at all
+    bool m_checkDCS;  //!< if false, do not use TileDCS at all
 
     /* njunior@cern.ch */
     const TileDQstatus* m_dqStatus;
diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragMonTool.h
index 9b92b57ae14cbade8f25fc3bc540f96334a88754..a826333dffa4718b3c14b2b8d53669083dde888d 100644
--- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragMonTool.h
+++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragMonTool.h
@@ -16,12 +16,12 @@
 
 #include "TileMonitoring/TileFatherMonTool.h"
 #include "TileEvent/TileDQstatus.h"
+#include "TileConditions/ITileDCSTool.h"
 #include "StoreGate/ReadHandleKey.h"
 
 #include <array>
 
 class ITileBadChanTool;
-class TileDCSSvc;
 class TileDQstatus;
 class TileRawChannel;
 class TileRawChannelCollection;
@@ -72,7 +72,7 @@ class TileDQFragMonTool: public TileFatherMonTool {
     void fillBadDrawer(void);
 
     ToolHandle<ITileBadChanTool> m_tileBadChanTool; //!< Tile Bad Channel tool
-    ServiceHandle<TileDCSSvc> m_tileDCSSvc; //!< Pointer to TileDCSSvc
+    ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"};
 
     /*---------------------------------------------------------*/
     /* properties*/
@@ -90,7 +90,7 @@ class TileDQFragMonTool: public TileFatherMonTool {
     bool m_skipGapCells;
     bool m_doPlots;
     bool m_doOnline;
-    bool m_checkDCS;  //!< if false, do not use TileDCSSvc at all
+    bool m_checkDCS;  //!< if false, do not use TileDCSTool at all
 
     /* njunior@cern.ch */
     const TileDQstatus* m_dqStatus;
diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDigiNoiseMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDigiNoiseMonTool.h
index e3fe1ff4268376c7831bc9e43c63d713cf9f1be1..731b13ee799b4d3d53c8e64e6bff2ec094137282 100644
--- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDigiNoiseMonTool.h
+++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDigiNoiseMonTool.h
@@ -75,7 +75,7 @@ class TileDigiNoiseMonTool : public TileFatherMonTool {
     bool m_fillPedestalDifference;
     std::vector<uint32_t> m_triggerTypes;
     SG::ReadHandleKey<TileDQstatus> m_DQstatusKey;
-    ToolHandle<ITileDCSTool> m_tileDCS;
+    ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"};
     bool m_checkDCS;
     bool m_histogramsNotBooked;
 };
diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelNoiseMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelNoiseMonTool.h
index ec1803fab2f1c30462ae57ae0e7f6b52f5e48d46..b23cbff23c92e2053e767df4d8980d7ae4ec8939 100644
--- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelNoiseMonTool.h
+++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelNoiseMonTool.h
@@ -19,12 +19,13 @@
 //            To perform the double gaussian fit use the option: m_do2gfit=true
 //
 /////////////////////////////////////////////////////////////////////////////////////////////////////////////
-#ifndef TILERAWCHANNELMONTOOL_H
-#define TILERAWCHANNELMONTOOL_H
+#ifndef TILEMONITORING_TILERAWCHANNELNOISEMONTOOL_H
+#define TILEMONITORING_TILERAWCHANNELNOISEMONTOOL_H
 
 #include "TileMonitoring/TileFatherMonTool.h"
 #include "TileEvent/TileDQstatus.h"
 #include "TileConditions/ITileDCSTool.h"
+
 #include "StoreGate/ReadHandleKey.h"
 
 class ITileBadChanTool;
@@ -100,8 +101,8 @@ class TileRawChannelNoiseMonTool: public TileFatherMonTool {
     int m_nbins;
     unsigned int m_minimumEventsNumberToFit;
     SG::ReadHandleKey<TileDQstatus> m_DQstatusKey;
-    ToolHandle<ITileDCSTool> m_tileDCS;
+    ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"};
     bool m_checkDCS;
 };
 
-#endif
+#endif // TILEMONITORING_TILERAWCHANNELNOISEMONTOOL_H
diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelTimeMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelTimeMonTool.h
index f37d570d9c37a13e87d7ec6f29ad8b2fd6c8fe96..e47e02e75b58d725882cb31995bed0d566e8ce14 100644
--- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelTimeMonTool.h
+++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelTimeMonTool.h
@@ -98,7 +98,7 @@ class TileRawChannelTimeMonTool: public TileFatherMonTool {
     std::vector<std::pair<int, int> > m_timeDifferenceBetweenROS;
     int m_nLumiblocks;
     SG::ReadHandleKey<TileDQstatus> m_DQstatusKey;
-    ToolHandle<ITileDCSTool> m_tileDCS;
+    ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"};
     bool m_checkDCS;
 };
 
diff --git a/TileCalorimeter/TileMonitoring/share/TileMon_jobOptions.py b/TileCalorimeter/TileMonitoring/share/TileMon_jobOptions.py
index e92bb48ca012c7a18e2c8f4644a885c525fe5e29..d05a9904271eab82d72a7dbdcfc90a29e1e5e49e 100644
--- a/TileCalorimeter/TileMonitoring/share/TileMon_jobOptions.py
+++ b/TileCalorimeter/TileMonitoring/share/TileMon_jobOptions.py
@@ -11,6 +11,10 @@ from AthenaCommon.BeamFlags import jobproperties
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
 
+from AthenaCommon.AlgSequence import AthSequencer
+condSequence = AthSequencer("AthCondSeq")
+tileCheckDCS = hasattr(condSequence, 'TileDCSCondAlg')
+
 from AthenaMonitoring.DQMonFlags import DQMonFlags
 
 if not 'rec' in dir():
@@ -204,7 +208,7 @@ if  tileRawMon:
                                                , TriggerChain        = "HLT_noalg_cosmiccalo_L1RD1_EMPTY"
                                                , TrigDecisionTool    = getattr(ToolSvc, DQMonFlags.nameTrigDecTool()) if DQMonFlags.useTrigger() else ""
                                                , TriggerTypes        = [ 0x82 ]
-                                               , CheckDCS                 = hasattr(ServiceMgr, "TileDCSSvc"))
+                                               , CheckDCS                 = tileCheckDCS)
 
         if globalflags.InputFormat() == 'pool':
             TileDigiNoiseMon.TileDigitsContainer = 'TileDigitsFlt'
@@ -221,7 +225,7 @@ if  tileRawMon:
                                           , SkipMasked               = True
                                           , SkipGapCells             = True
                                           , doOnline                 = athenaCommonFlags.isOnline()
-                                          , CheckDCS                 = hasattr(ServiceMgr, "TileDCSSvc")
+                                          , CheckDCS                 = tileCheckDCS
                                           , histoPathBase            = "/Tile/DMUErrors")
 
 
diff --git a/TileCalorimeter/TileMonitoring/share/TileMon_standalone_jobOptions.py b/TileCalorimeter/TileMonitoring/share/TileMon_standalone_jobOptions.py
index daf82eae4d0f7e80feda5eaf7e3899d49ffd504e..ea8339d1d63886abaeaa926a1d667d9c2183650c 100644
--- a/TileCalorimeter/TileMonitoring/share/TileMon_standalone_jobOptions.py
+++ b/TileCalorimeter/TileMonitoring/share/TileMon_standalone_jobOptions.py
@@ -4,11 +4,13 @@
 #
 #==============================================================
 
-
-
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
 
+from AthenaCommon.AlgSequence import AthSequencer
+condSequence = AthSequencer("AthCondSeq")
+tileCheckDCS = hasattr(condSequence, 'TileDCSCondAlg')
+
 from AthenaCommon.AppMgr import ServiceMgr as svcMgr
 
 from AthenaCommon import CfgMgr
@@ -40,7 +42,7 @@ toolSvc += CfgMgr.TileDQFragMonTool(name                          = 'TileDQFragM
                                     , SkipGapCells                = True
                                     , doOnline                    = athenaCommonFlags.isOnline()
                                     , doPlots                     = False
-                                    , CheckDCS                    = hasattr(svcMgr, "TileDCSSvc")
+                                    , CheckDCS                    = tileCheckDCS
                                     , histoPathBase               = "Tile/DMUErrors")
 
 ManagedAthenaTileMon.AthenaMonTools += [ toolSvc.TileDQFragMon ]
diff --git a/TileCalorimeter/TileMonitoring/src/TileDQFragLWMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileDQFragLWMonTool.cxx
index 2dcafa1660892b875cca94c27ab57a5435e8165e..8ba59e80e914d0caddcda2ac753b0cb426f59e5a 100644
--- a/TileCalorimeter/TileMonitoring/src/TileDQFragLWMonTool.cxx
+++ b/TileCalorimeter/TileMonitoring/src/TileDQFragLWMonTool.cxx
@@ -16,7 +16,6 @@
 
 #include "TileCalibBlobObjs/TileCalibUtils.h"
 #include "TileConditions/ITileBadChanTool.h"
-#include "TileConditions/TileDCSSvc.h"
 #include "TileEvent/TileDigitsContainer.h"
 #include "TileEvent/TileRawChannelContainer.h"
 #include "TileRecUtils/TileRawChannelBuilder.h"
@@ -35,7 +34,6 @@
 TileDQFragLWMonTool::TileDQFragLWMonTool(const std::string & type, const std::string & name, const IInterface* parent)
   : TileFatherMonTool(type, name, parent)
   , m_tileBadChanTool("TileBadChanTool")
-  , m_tileDCSSvc("TileDCSSvc",name)
   , m_dqStatus(0)
   , m_globalErrCount{}
   , m_global{}
@@ -151,14 +149,16 @@ StatusCode TileDQFragLWMonTool:: initialize() {
 
   ATH_MSG_INFO(  "in initialize()" );
 
-  CHECK(  m_tileBadChanTool.retrieve() );
+  ATH_CHECK(  m_tileBadChanTool.retrieve() );
 
-  CHECK( TileFatherMonTool::initialize() );
+  ATH_CHECK( TileFatherMonTool::initialize() );
 
-  CHECK( m_DQstatusKey.initialize() );
+  ATH_CHECK( m_DQstatusKey.initialize() );
 
   if (m_checkDCS) {
-    CHECK( m_tileDCSSvc.retrieve() );
+    ATH_CHECK( m_tileDCS.retrieve() );
+  } else {
+    m_tileDCS.disable();
   }
 
   return StatusCode::SUCCESS;
@@ -460,7 +460,7 @@ void TileDQFragLWMonTool::fillBadDrawer() {
 
             if ((pedestal > 80000. || quality > m_qualityCut)
                 && !(m_tileBadChanTool->getAdcStatus(adcId).isBad()
-                     || (m_checkDCS && m_tileDCSSvc->statusIsBad(ROS, drawer, channel)))) {
+                     || (m_checkDCS && m_tileDCS->isStatusBad(ROS, drawer, channel)))) {
 
               m_badPulseQuality[partition]->Fill(module, channel);
 
@@ -660,13 +660,13 @@ void TileDQFragLWMonTool::fillErrorsHistograms(unsigned int ros, unsigned int dr
 
       unsigned int drawerIdx = TileCalibUtils::getDrawerIdx(ros + 1, drawer);
       if (m_checkDCS 
-          && ((m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn)
+          && ((m_tileDCS->isStatusBad(ros + 1, drawer, ichn)
                && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn).contains(TileBchPrbs::NoHV)
                && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn).contains(TileBchPrbs::WrongHV))
-              || (m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn + 1) 
+              || (m_tileDCS->isStatusBad(ros + 1, drawer, ichn + 1)
                   && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 1).contains(TileBchPrbs::NoHV)
                   && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 1).contains(TileBchPrbs::WrongHV))
-              || (m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn + 2) 
+              || (m_tileDCS->isStatusBad(ros + 1, drawer, ichn + 2)
                   && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 2).contains(TileBchPrbs::NoHV)
                   && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 2).contains(TileBchPrbs::WrongHV)))) {
         
@@ -830,8 +830,8 @@ bool TileDQFragLWMonTool::isModuleDCSgood(unsigned int partition, unsigned int d
 /*---------------------------------------------------------*/
 
   if (m_checkDCS) {
-    TileDCSSvc::TileDCSStatus Status = m_tileDCSSvc->getDCSSTATUS(partition, drawer);
-    if (Status > TileDCSSvc::WARNING) {
+    TileDCSState::TileDCSStatus status = m_tileDCS->getDCSStatus(partition, drawer);
+    if (status > TileDCSState::WARNING) {
       return false;
     } else {
       return true;
diff --git a/TileCalorimeter/TileMonitoring/src/TileDQFragMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileDQFragMonTool.cxx
index 735278be199e3ed6a509c05c6dfa9ab85eddc318..92213e54e9d688c69f42c76561de2e16ab92a180 100644
--- a/TileCalorimeter/TileMonitoring/src/TileDQFragMonTool.cxx
+++ b/TileCalorimeter/TileMonitoring/src/TileDQFragMonTool.cxx
@@ -16,7 +16,6 @@
 
 #include "TileCalibBlobObjs/TileCalibUtils.h"
 #include "TileConditions/ITileBadChanTool.h"
-#include "TileConditions/TileDCSSvc.h"
 #include "TileEvent/TileDigitsContainer.h"
 #include "TileEvent/TileRawChannelContainer.h"
 #include "TileRecUtils/TileRawChannelBuilder.h"
@@ -40,7 +39,6 @@
 TileDQFragMonTool::TileDQFragMonTool(const std::string & type, const std::string & name, const IInterface* parent)
   : TileFatherMonTool(type, name, parent)
   , m_tileBadChanTool("TileBadChanTool")
-  , m_tileDCSSvc("TileDCSSvc",name)
   , m_dqStatus(0)
   , m_last_lb(0)
   , m_globalErrCount{}
@@ -214,15 +212,18 @@ StatusCode TileDQFragMonTool:: initialize() {
 
   ATH_MSG_INFO(  "in initialize()" );
 
-  CHECK(  m_tileBadChanTool.retrieve() );
+  ATH_CHECK(  m_tileBadChanTool.retrieve() );
 
-  CHECK( TileFatherMonTool::initialize() );
+  ATH_CHECK( TileFatherMonTool::initialize() );
 
   if (m_checkDCS) {
-    CHECK( m_tileDCSSvc.retrieve() );
+    ATH_CHECK( m_tileDCS.retrieve() );
+  } else {
+    m_tileDCS.disable();
   }
 
-  CHECK( m_DQstatusKey.initialize() );
+
+  ATH_CHECK( m_DQstatusKey.initialize() );
 
   return StatusCode::SUCCESS;
 
@@ -523,7 +524,7 @@ void TileDQFragMonTool::fillBadDrawer() {
           int drawer = fragId & 0x3F;  // range 0-63
           int ROS = fragId >> 8;  // range 1-4
           bool drbad = true;
-          if (m_checkDCS) drbad = m_tileDCSSvc->statusIsBad(ROS, drawer);
+          if (m_checkDCS) drbad = m_tileDCS->isStatusBad(ROS, drawer);
 
           if (!drbad) ++nBadDrNM;
         }
@@ -585,7 +586,7 @@ void TileDQFragMonTool::fillBadDrawer() {
 
             if ((pedestal > 80000. || quality > m_qualityCut)
                 && !(m_tileBadChanTool->getAdcStatus(adcId).isBad()
-                     || (m_checkDCS && m_tileDCSSvc->statusIsBad(ROS, drawer, channel)))) {
+                     || (m_checkDCS && m_tileDCS->isStatusBad(ROS, drawer, channel)))) {
 
               m_badPulseQuality[partition]->Fill(module, channel);
 
@@ -804,13 +805,13 @@ void TileDQFragMonTool::fillErrHist(int ros, int drawer) {
 
       unsigned int drawerIdx = TileCalibUtils::getDrawerIdx(ros + 1, drawer);
       if (m_checkDCS 
-          && ((m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn)
+          && ((m_tileDCS->isStatusBad(ros + 1, drawer, ichn)
                && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn).contains(TileBchPrbs::NoHV)
                && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn).contains(TileBchPrbs::WrongHV))
-              || (m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn + 1) 
+              || (m_tileDCS->isStatusBad(ros + 1, drawer, ichn + 1)
                   && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 1).contains(TileBchPrbs::NoHV)
                   && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 1).contains(TileBchPrbs::WrongHV))
-              || (m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn + 2) 
+              || (m_tileDCS->isStatusBad(ros + 1, drawer, ichn + 2)
                   && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 2).contains(TileBchPrbs::NoHV)
                   && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 2).contains(TileBchPrbs::WrongHV)))) {
 
@@ -1101,8 +1102,8 @@ bool TileDQFragMonTool::isModuleDCSgood(int partition, int drawer) const {
 /*---------------------------------------------------------*/
 
   if (m_checkDCS) {
-    TileDCSSvc::TileDCSStatus Status = m_tileDCSSvc->getDCSSTATUS(partition, drawer);
-    if (Status > TileDCSSvc::WARNING) {
+    TileDCSState::TileDCSStatus status = m_tileDCS->getDCSStatus(partition, drawer);
+    if (status > TileDCSState::WARNING) {
       return false;
     } else {
       return true;
diff --git a/TileCalorimeter/TileMonitoring/src/TileDigiNoiseMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileDigiNoiseMonTool.cxx
index 3601d6b9fce3ec33c63e2111e393ea36fa72e823..cc1d8031a20b0a7028f0d94a7628d8549809d8bc 100644
--- a/TileCalorimeter/TileMonitoring/src/TileDigiNoiseMonTool.cxx
+++ b/TileCalorimeter/TileMonitoring/src/TileDigiNoiseMonTool.cxx
@@ -18,15 +18,16 @@
 //
 // ********************************************************************
 
-#include "xAODEventInfo/EventInfo.h"
-
+// Tile includes
 #include "TileMonitoring/TileDigiNoiseMonTool.h"
-
 #include "TileEvent/TileDigitsContainer.h"
 #include "TileEvent/TileRawChannelContainer.h"
 #include "TileCalibBlobObjs/TileCalibUtils.h"
 #include "TileConditions/TileBadChanTool.h"
 #include "TileConditions/TileCondToolNoiseSample.h"
+
+// Athena includes
+#include "xAODEventInfo/EventInfo.h"
 #include "StoreGate/ReadHandle.h"
 
 #include <iostream>
@@ -42,7 +43,6 @@ TileDigiNoiseMonTool::TileDigiNoiseMonTool(const std::string & type, const std::
   , m_tileToolNoiseSample("TileCondToolNoiseSample")
   , m_DQstatus(0)
   , m_nEventsProcessed(0)
-  , m_tileDCS("TileDCSTool")
   , m_histogramsNotBooked(true)
 /*---------------------------------------------------------*/
 {
@@ -58,7 +58,6 @@ TileDigiNoiseMonTool::TileDigiNoiseMonTool(const std::string & type, const std::
   declareProperty("FillPedestalDifference", m_fillPedestalDifference = true);
   declareProperty("TriggerTypes", m_triggerTypes);
   declareProperty("TileDQstatus", m_DQstatusKey = "TileDQstatus");
-  declareProperty("TileDCSTool", m_tileDCS);
   declareProperty("CheckDCS", m_checkDCS = false);
 
   m_path = "/Tile/DigiNoise"; //ROOT File relative directory
@@ -77,8 +76,8 @@ StatusCode TileDigiNoiseMonTool:: initialize() {
 
   ATH_MSG_INFO( "in initialize()" );
 
-  CHECK(m_tileBadChanTool.retrieve());
-  if (m_fillEmtyFromDB || m_fillPedestalDifference) CHECK(m_tileToolNoiseSample.retrieve());
+  ATH_CHECK(m_tileBadChanTool.retrieve());
+  if (m_fillEmtyFromDB || m_fillPedestalDifference) ATH_CHECK(m_tileToolNoiseSample.retrieve());
 
   memset(m_sumPed1, 0, sizeof(m_sumPed1));
   memset(m_sumPed2, 0, sizeof(m_sumPed2));
@@ -98,12 +97,11 @@ StatusCode TileDigiNoiseMonTool:: initialize() {
     msg(MSG::INFO) << endmsg;
   }
 
-  CHECK( m_DQstatusKey.initialize() );
+  ATH_CHECK( m_DQstatusKey.initialize() );
 
   if (m_checkDCS) {
-    CHECK( m_tileDCS.retrieve() );
-  }
-  else {
+    ATH_CHECK( m_tileDCS.retrieve() );
+  } else {
     m_tileDCS.disable();
   }
 
@@ -217,12 +215,12 @@ StatusCode TileDigiNoiseMonTool::fillHistograms() {
   if (m_triggerTypes.empty()
       || std::find( m_triggerTypes.begin(), m_triggerTypes.end(), m_lvl1info) != m_triggerTypes.end()) {
 
-    if (m_histogramsNotBooked) CHECK( bookNoiseHistograms() );
+    if (m_histogramsNotBooked) ATH_CHECK( bookNoiseHistograms() );
 
     m_DQstatus = SG::makeHandle (m_DQstatusKey).get();
 
     const TileDigitsContainer* digitsContainer;
-    CHECK( evtStore()->retrieve(digitsContainer, m_digitsContainerName) );
+    ATH_CHECK( evtStore()->retrieve(digitsContainer, m_digitsContainerName) );
     
     for (const TileDigitsCollection* digitsCollection : *digitsContainer) {
 
diff --git a/TileCalorimeter/TileMonitoring/src/TileRawChannelNoiseMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileRawChannelNoiseMonTool.cxx
index 0c37fde070f51b81c6dc7be66873e3b224363150..9b38986f2b90650bf467e79edd39a422baea3166 100644
--- a/TileCalorimeter/TileMonitoring/src/TileRawChannelNoiseMonTool.cxx
+++ b/TileCalorimeter/TileMonitoring/src/TileRawChannelNoiseMonTool.cxx
@@ -18,12 +18,11 @@
 //
 // ********************************************************************
 
-#include "xAODEventInfo/EventInfo.h"
 
+// Tile includes
 #include "TileMonitoring/TileRawChannelNoiseMonTool.h"
 #include "TileMonitoring/PairBuilder.h"
 
-
 #include "TileCalibBlobObjs/TileCalibUtils.h"
 #include "TileIdentifier/TileHWID.h"
 #include "TileIdentifier/TileRawChannelUnit.h"
@@ -33,8 +32,12 @@
 
 #include "TileEvent/TileCell.h"
 #include "TileEvent/TileRawChannelContainer.h"
+
+// Athena includes
+#include "xAODEventInfo/EventInfo.h"
 #include "StoreGate/ReadHandle.h"
 
+
 #include "TH1F.h"
 #include "TH2F.h"
 #include "TF1.h"
@@ -65,7 +68,6 @@ TileRawChannelNoiseMonTool::TileRawChannelNoiseMonTool(const std::string & type,
   , m_gain(1)
   , m_nEventsProcessed(0)
   , m_minimumEventsNumberToFit(100)
-  , m_tileDCS("TileDCSTool")
 /*---------------------------------------------------------*/
 {
   declareInterface<IMonitorToolBase>(this);
@@ -87,7 +89,6 @@ TileRawChannelNoiseMonTool::TileRawChannelNoiseMonTool(const std::string & type,
   declareProperty("TriggerTypes", m_triggerTypes);
   declareProperty("MinimumEventsNumberToFit", m_minimumEventsNumberToFit);
   declareProperty("TileDQstatus", m_DQstatusKey = "TileDQstatus");
-  declareProperty("TileDCSTool", m_tileDCS);
   declareProperty("CheckDCS", m_checkDCS = false);
 
   m_path = "/Tile/RawChannelNoise";
@@ -106,7 +107,7 @@ StatusCode TileRawChannelNoiseMonTool::initialize() {
   ATH_MSG_INFO("in initialize() - m_path = " << m_path);
 
   //=== get TileBadChanTool
-  CHECK(m_tileBadChanTool.retrieve());
+  ATH_CHECK(m_tileBadChanTool.retrieve());
 
   if (m_gainName == "HG"){
     m_gain = 1;
@@ -129,12 +130,11 @@ StatusCode TileRawChannelNoiseMonTool::initialize() {
     msg(MSG::INFO) << endmsg;
   }
 
-  CHECK( m_DQstatusKey.initialize() );
+  ATH_CHECK( m_DQstatusKey.initialize() );
 
   if (m_checkDCS) {
-    CHECK( m_tileDCS.retrieve() );
-  }
-  else {
+    ATH_CHECK( m_tileDCS.retrieve() );
+  } else {
     m_tileDCS.disable();
   }
 
@@ -502,7 +502,7 @@ StatusCode TileRawChannelNoiseMonTool::fillHistoPerRawChannel() {
   m_DQstatus = SG::makeHandle (m_DQstatusKey).get();
 
   const TileRawChannelContainer* rawChannelContainer;
-  CHECK(evtStore()->retrieve(rawChannelContainer, m_rawChannelContainerName));
+  ATH_CHECK(evtStore()->retrieve(rawChannelContainer, m_rawChannelContainerName));
 
   // What is the unit used to store info in the RawChannelContainer ?
   TileRawChannelUnit::UNIT RChUnit = rawChannelContainer->get_unit();
@@ -515,7 +515,7 @@ StatusCode TileRawChannelNoiseMonTool::fillHistoPerRawChannel() {
   std::string module_name;
 
   const TileRawChannelContainer* rawChannelContainerDSP(nullptr);
-  CHECK(evtStore()->retrieve(rawChannelContainerDSP, m_rawChannelContainerDspName));
+  ATH_CHECK(evtStore()->retrieve(rawChannelContainerDSP, m_rawChannelContainerDspName));
 
 
   // Loop over the containers
@@ -620,7 +620,7 @@ StatusCode TileRawChannelNoiseMonTool::fillHistograms() {
   if (m_triggerTypes.empty()
       || std::find( m_triggerTypes.begin(), m_triggerTypes.end(), m_lvl1info) != m_triggerTypes.end()) {
 
-    CHECK(fillHistoPerRawChannel());
+    ATH_CHECK(fillHistoPerRawChannel());
   }
 
   if ((m_summaryUpdateFrequency > 0) 
diff --git a/TileCalorimeter/TileMonitoring/src/TileRawChannelTimeMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileRawChannelTimeMonTool.cxx
index b8f1d1878ac64c58f4fb42ec812593178ba02675..e2c0d12cff42d1b5f805a0e2282626b756d7fedd 100644
--- a/TileCalorimeter/TileMonitoring/src/TileRawChannelTimeMonTool.cxx
+++ b/TileCalorimeter/TileMonitoring/src/TileRawChannelTimeMonTool.cxx
@@ -12,11 +12,14 @@
 //
 // ********************************************************************
 
+// Tile includes
 #include "TileMonitoring/TileRawChannelTimeMonTool.h"
 
 #include "TileCalibBlobObjs/TileCalibUtils.h"
 #include "TileConditions/ITileBadChanTool.h"
 #include "TileEvent/TileRawChannelContainer.h"
+
+// Athena includes
 #include "StoreGate/ReadHandle.h"
 
 #include "TProfile.h"
@@ -51,7 +54,6 @@ TileRawChannelTimeMonTool::TileRawChannelTimeMonTool(const std::string & type, c
   , m_partitionTimeCorrection{{0}}
   , m_timeDifferenceBetweenROS{{1, 2}, {1, 3}, {1, 4}, {2, 3}, {2, 4}, {3, 4}}
   , m_nLumiblocks(3000)
-  , m_tileDCS("TileDCSTool")
 	 /*---------------------------------------------------------*/
 {
   declareInterface<IMonitorToolBase>(this);
@@ -70,7 +72,6 @@ TileRawChannelTimeMonTool::TileRawChannelTimeMonTool(const std::string & type, c
   declareProperty("TimeCorrectionEBC", m_timeCorrectionEBC);
   declareProperty("NumberOfLumiblocks", m_nLumiblocks = 3000);
   declareProperty("TileDQstatus", m_DQstatusKey = "TileDQstatus");
-  declareProperty("TileDCSTool", m_tileDCS);
   declareProperty("CheckDCS", m_checkDCS = false);
 
   m_path = "/Tile/RawChannelTime"; 
@@ -89,7 +90,7 @@ StatusCode TileRawChannelTimeMonTool::initialize()
 
   ATH_MSG_INFO("in initialize()");
 
-  CHECK(m_tileBadChanTool.retrieve());
+  ATH_CHECK(m_tileBadChanTool.retrieve());
 
   m_nEvents = 0;
   m_thresholds[0] = m_lowGainThreshold;
@@ -101,14 +102,13 @@ StatusCode TileRawChannelTimeMonTool::initialize()
                                 m_timeCorrectionEBA, 
                                 m_timeCorrectionEBC}};
 
-  CHECK(TileFatherMonTool::initialize());
+  ATH_CHECK(TileFatherMonTool::initialize());
 
-  CHECK( m_DQstatusKey.initialize() );
+  ATH_CHECK( m_DQstatusKey.initialize() );
 
   if (m_checkDCS) {
-    CHECK( m_tileDCS.retrieve() );
-  }
-  else {
+    ATH_CHECK( m_tileDCS.retrieve() );
+  } else {
     m_tileDCS.disable();
   }
 
@@ -246,7 +246,7 @@ StatusCode TileRawChannelTimeMonTool::fillHists()
   int32_t current_lumiblock = getLumiBlock();
 
   const TileRawChannelContainer* RawChannelCnt;
-  CHECK(evtStore()->retrieve(RawChannelCnt, m_contName));
+  ATH_CHECK(evtStore()->retrieve(RawChannelCnt, m_contName));
 
   std::vector<double> avgTimePerPart(TileCalibUtils::MAX_ROS, 0.0);
   std::vector<double> sumTimeCh(TileCalibUtils::MAX_ROS, 0.0);
diff --git a/TileCalorimeter/TileMuId/TileMuId/TileLookForMuAlg.h b/TileCalorimeter/TileMuId/TileMuId/TileLookForMuAlg.h
index 7ad48b8a60f1292784f97e54112cb81c8b41a6ee..af6181678c78a3bb4e52f04a2649e090891f8273 100755
--- a/TileCalorimeter/TileMuId/TileMuId/TileLookForMuAlg.h
+++ b/TileCalorimeter/TileMuId/TileMuId/TileLookForMuAlg.h
@@ -48,7 +48,7 @@ class TileLookForMuAlg: public AthReentrantAlgorithm {
     virtual ~TileLookForMuAlg();
 
     virtual StatusCode initialize() override;
-    virtual StatusCode execute_r (const EventContext& ctx) const override;
+    virtual StatusCode execute (const EventContext& ctx) const override;
     virtual StatusCode finalize() override;
 
 
diff --git a/TileCalorimeter/TileMuId/src/TileLookForMuAlg.cxx b/TileCalorimeter/TileMuId/src/TileLookForMuAlg.cxx
index 89571a11404d25e2c8ea327d5b245ef6a04e1b0f..01e677edb703ec279ea516d61efd56bb0cfaf9c9 100755
--- a/TileCalorimeter/TileMuId/src/TileLookForMuAlg.cxx
+++ b/TileCalorimeter/TileMuId/src/TileLookForMuAlg.cxx
@@ -100,7 +100,7 @@ StatusCode TileLookForMuAlg::initialize() {
 /////////////////////////////////////////////////////////////////////////////////
 //Execution                                                                     /
 /////////////////////////////////////////////////////////////////////////////////
-StatusCode TileLookForMuAlg::execute_r (const EventContext& ctx) const {
+StatusCode TileLookForMuAlg::execute (const EventContext& ctx) const {
 
   ATH_MSG_DEBUG("TileLookForMuAlg execution  started");
 
diff --git a/TileCalorimeter/TileRec/TileRec/TileAANtuple.h b/TileCalorimeter/TileRec/TileRec/TileAANtuple.h
index e7e9b1e636763a1282e80418934d46847cc0daa0..69e6722f896f0e1f5cf2e736b2edf362c0189779 100755
--- a/TileCalorimeter/TileRec/TileRec/TileAANtuple.h
+++ b/TileCalorimeter/TileRec/TileRec/TileAANtuple.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 //****************************************************************************
@@ -39,21 +39,22 @@
 /// 
 /// 
 //****************************************************************************
-#ifndef TileAANtuple_H
-#define TileAANtuple_H
+#ifndef TILEREC_TILEAANTUPLE_H
+#define TILEREC_TILEAANTUPLE_H
 
-// Gauid includes
-#include "GaudiKernel/ToolHandle.h"
-#include "GaudiKernel/ServiceHandle.h"
+// Tile includes
+#include "TileConditions/TileCablingService.h"
+#include "TileIdentifier/TileRawChannelUnit.h"
+#include "TileEvent/TileLaserObject.h"
+#include "TileConditions/ITileDCSTool.h"
 
 // Athena includes
 #include "AthenaKernel/IOVSvcDefs.h"
 #include "AthenaBaseComps/AthAlgorithm.h"
 
-// Tile includes
-#include "TileConditions/TileCablingService.h"
-#include "TileIdentifier/TileRawChannelUnit.h"
-#include "TileEvent/TileLaserObject.h"
+// Gauid includes
+#include "GaudiKernel/ToolHandle.h"
+#include "GaudiKernel/ServiceHandle.h"
 
 #include <string>
 #include <stdint.h>
@@ -82,7 +83,6 @@ class TileBeamInfoProvider;
 class TileBeamElemContByteStreamCnv;
 class ITileBadChanTool;
 class TileCondToolEmscale;
-class TileDCSSvc;
 class TileL2Builder;
 class ITHistSvc;
 
@@ -348,7 +348,7 @@ class TileAANtuple : public AthAlgorithm {
     int m_finalUnit;  //!< calibrate everything to this level
     bool m_calibMode;  //!< If data should be put in calib mode
     bool m_compareMode;  //!< If two sets of data should be compared (e.g. frag4 and frag5)
-    bool m_checkDCS;   //!< if false, do not use TileDCSSvc at all
+    bool m_checkDCS;   //!< if false, do not use TileDCS at all
     int m_DCSBranches;   //!< mask like 110101 - which DCS branches to fill
 
     // energy units
@@ -363,7 +363,6 @@ class TileAANtuple : public AthAlgorithm {
     // The ntuple
     TTree* m_ntuplePtr;
     TTree* m_DCSntuplePtr;
-    int m_DCScounter;
 
     // handle to THistSvc
     ServiceHandle<ITHistSvc> m_thistSvc;
@@ -384,7 +383,7 @@ class TileAANtuple : public AthAlgorithm {
 
     TileBeamElemContByteStreamCnv* m_beamCnv;
 
-    ServiceHandle<TileDCSSvc> m_tileDCSSvc; //!< Pointer to TileDCSSvc
+    ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"};
 
     // variables to check SumEt in frag5
     ToolHandle<TileL2Builder> m_l2Builder;  //<! Pointer to TileL2Builder
@@ -402,4 +401,4 @@ class TileAANtuple : public AthAlgorithm {
     int m_skipEvents;
 };
 
-#endif
+#endif // TILEREC_TILEAANTUPLE_H
diff --git a/TileCalorimeter/TileRec/src/TileAANtuple.cxx b/TileCalorimeter/TileRec/src/TileAANtuple.cxx
index 069b40c5057d7f86b280688eb1b87f94d4cfa6ca..0fcc904c00e78a8001e3536f2bd8d3508d9d3403 100755
--- a/TileCalorimeter/TileRec/src/TileAANtuple.cxx
+++ b/TileCalorimeter/TileRec/src/TileAANtuple.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 ///*****************************************************************************
@@ -17,26 +17,12 @@
 //
 //*****************************************************************************
 
-// Gaudi includes
-#include "GaudiKernel/ITHistSvc.h"
-
-//Atlas include
-#include "AthenaKernel/errorcheck.h"
-#include "xAODEventInfo/EventInfo.h"
-
-// Calo includes
-#include "CaloDetDescr/CaloDetDescrElement.h"
-#include "CaloDetDescr/MbtsDetDescrManager.h"
-#include "Identifier/IdentifierHash.h"
-#include "CaloIdentifier/TileID.h"
-
 //Tile includes
 #include "TileRec/TileAANtuple.h"
 #include "TileIdentifier/TileHWID.h"
 #include "TileCalibBlobObjs/TileCalibUtils.h"
 #include "TileConditions/TileCablingService.h"
 #include "TileConditions/ITileBadChanTool.h"
-#include "TileConditions/TileDCSSvc.h"
 #include "TileDetDescr/TileDetDescrManager.h"
 #include "TileConditions/TileCondToolEmscale.h"
 #include "TileEvent/TileDigitsContainer.h"
@@ -49,6 +35,19 @@
 #include "TileByteStream/TileBeamElemContByteStreamCnv.h"
 #include "TileL2Algs/TileL2Builder.h"
 
+// Calo includes
+#include "CaloDetDescr/CaloDetDescrElement.h"
+#include "CaloDetDescr/MbtsDetDescrManager.h"
+#include "Identifier/IdentifierHash.h"
+#include "CaloIdentifier/TileID.h"
+
+//Atlas include
+#include "AthenaKernel/errorcheck.h"
+#include "xAODEventInfo/EventInfo.h"
+
+// Gaudi includes
+#include "GaudiKernel/ITHistSvc.h"
+
 #include "TTree.h"
 #include <iomanip>
 #include "boost/date_time/local_time/local_time.hpp"
@@ -191,7 +190,6 @@ TileAANtuple::TileAANtuple(std::string name, ISvcLocator* pSvcLocator)
 , m_tileToolEmscale("TileCondToolEmscale")
 , m_beamInfo("TileBeamInfoProvider/TileBeamInfoProvider")
 , m_beamCnv(0)
-, m_tileDCSSvc("TileDCSSvc",name)
 , m_l2Builder()
 , m_sumEt_xx()
 , m_sumEz_xx()
@@ -205,7 +203,6 @@ TileAANtuple::TileAANtuple(std::string name, ISvcLocator* pSvcLocator)
 , m_bad()
 {
   declareProperty("TileCondToolEmscale", m_tileToolEmscale);
-  declareProperty("TileDCSSvc", m_tileDCSSvc);
   declareProperty("TileDigitsContainer", m_digitsContainer = "TileDigitsCnt");
   declareProperty("TileDigitsContainerFlt", m_fltDigitsContainer = "" /* "TileDigitsFlt" */);
   declareProperty("TileBeamElemContainer", m_beamElemContainer = "TileBeamElemCnt");
@@ -239,7 +236,6 @@ TileAANtuple::TileAANtuple(std::string name, ISvcLocator* pSvcLocator)
   declareProperty("SkipEvents", m_skipEvents = 0);
   
   m_evtNr = -1;
-  m_DCScounter = 0;
   
   // LASERII
   memset(m_chan, 0, sizeof(m_chan));
@@ -283,42 +279,44 @@ StatusCode TileAANtuple::initialize() {
   m_cabling = TileCablingService::getInstance();
   
   // retrieve TileDetDescr Manager det store
-  CHECK( detStore()->retrieve(m_tileMgr) );
+  ATH_CHECK( detStore()->retrieve(m_tileMgr) );
   
   // retrieve TileID helper from det store
-  CHECK( detStore()->retrieve(m_tileID) );
-  CHECK( detStore()->retrieve(m_tileHWID) );
+  ATH_CHECK( detStore()->retrieve(m_tileID) );
+  ATH_CHECK( detStore()->retrieve(m_tileHWID) );
   
-  //=== get TileDCSSvc
+  //=== get TileDCSTool
   if (m_checkDCS) {
-    CHECK( m_tileDCSSvc.retrieve() );
+    ATH_CHECK( m_tileDCS.retrieve() );
+  } else {
+    m_tileDCS.disable();
   }
   
   //=== get TileBadChanTool
-  CHECK( m_tileBadChanTool.retrieve() );
+  ATH_CHECK( m_tileBadChanTool.retrieve() );
   
   //=== get TileCondToolEmscale
-  CHECK( m_tileToolEmscale.retrieve() );
+  ATH_CHECK( m_tileToolEmscale.retrieve() );
   
   //=== get TileBeamInfo
-  CHECK( m_beamInfo.retrieve() );
+  ATH_CHECK( m_beamInfo.retrieve() );
   
   //=== get TileL2Builder
   if (m_compareMode) {
-    CHECK( m_l2Builder.retrieve() );
+    ATH_CHECK( m_l2Builder.retrieve() );
   }
   
   //=== change properties of TileBeamInfo - to make sure that all parameters are consistent
   if (m_beamElemContainer.size() > 0) {
-    CHECK( m_beamInfo->setProperty("TileBeamElemContainer",m_beamElemContainer) );
+    ATH_CHECK( m_beamInfo->setProperty("TileBeamElemContainer",m_beamElemContainer) );
   }
   
   if (m_digitsContainer.size() > 0) {
-    CHECK( m_beamInfo->setProperty("TileDigitsContainer",m_digitsContainer) );
+    ATH_CHECK( m_beamInfo->setProperty("TileDigitsContainer",m_digitsContainer) );
   }
   
   if (m_dspRawChannelContainer.size() > 0) {
-    CHECK( m_beamInfo->setProperty("TileRawChannelContainer",m_dspRawChannelContainer) );
+    ATH_CHECK( m_beamInfo->setProperty("TileRawChannelContainer",m_dspRawChannelContainer) );
   }
   
   ATH_MSG_INFO( "initialization completed" ) ;
@@ -379,7 +377,7 @@ StatusCode TileAANtuple::ntuple_initialize() {
   // set event number to 0 before first event
   m_evtNr = 0;
   
-  CHECK( m_thistSvc.retrieve() );
+  ATH_CHECK( m_thistSvc.retrieve() );
   
   if(initNTuple().isFailure()) {
     ATH_MSG_ERROR( " Error during ntuple initialization" );
@@ -546,7 +544,7 @@ StatusCode TileAANtuple::storeLaser() {
   ATH_MSG_DEBUG("TileAANtuple::storeLaser()");
   
   const TileLaserObject* laserObj;
-  CHECK( evtStore()->retrieve(laserObj, m_laserObject) );
+  ATH_CHECK( evtStore()->retrieve(laserObj, m_laserObject) );
   
   m_las_BCID = laserObj->getBCID();
   
@@ -721,7 +719,7 @@ TileAANtuple::storeRawChannels(std::string containerId
   
   // get named container
   const TileRawChannelContainer* rcCnt;
-  CHECK( evtStore()->retrieve(rcCnt, containerId) );
+  ATH_CHECK( evtStore()->retrieve(rcCnt, containerId) );
   ATH_MSG_VERBOSE( "Conteiner ID " << containerId );
   
   TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit();
@@ -890,7 +888,7 @@ TileAANtuple::storeRawChannels(std::string containerId
   if (m_compareMode && dspCont) {
     
     const TileL2Container* l2Cnt;
-    CHECK( evtStore()->retrieve(l2Cnt, "TileL2Cnt") );
+    ATH_CHECK( evtStore()->retrieve(l2Cnt, "TileL2Cnt") );
     
     TileL2Container::const_iterator it = l2Cnt->begin();
     TileL2Container::const_iterator end= l2Cnt->end();
@@ -923,7 +921,7 @@ TileAANtuple::storeMFRawChannels(std::string containerId
   
   // get named container
   const TileRawChannelContainer* rcCnt;
-  CHECK( evtStore()->retrieve(rcCnt, containerId) );
+  ATH_CHECK( evtStore()->retrieve(rcCnt, containerId) );
   
   TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit();
   ATH_MSG_VERBOSE( "RawChannel unit is " << rChUnit );
@@ -1094,7 +1092,7 @@ TileAANtuple::storeMFRawChannels(std::string containerId
   if (m_compareMode && dspCont) {
     
     const TileL2Container* l2Cnt;
-    CHECK( evtStore()->retrieve(l2Cnt, "TileL2Cnt") );
+    ATH_CHECK( evtStore()->retrieve(l2Cnt, "TileL2Cnt") );
     
     TileL2Container::const_iterator it = l2Cnt->begin();
     TileL2Container::const_iterator end= l2Cnt->end();
@@ -1125,7 +1123,7 @@ TileAANtuple::storeDigits(std::string containerId
   
   // Read Digits from TES
   const TileDigitsContainer* digitsCnt;
-  CHECK( evtStore()->retrieve(digitsCnt, containerId) );
+  ATH_CHECK( evtStore()->retrieve(digitsCnt, containerId) );
   
   bool emptyColl = true;
   
@@ -1304,7 +1302,7 @@ StatusCode TileAANtuple::storeTMDBDecision() {
     ATH_MSG_VERBOSE( "reading TMDB decision from " << m_tileMuRcvContainer ); 
 
     const TileMuonReceiverContainer *decisionCnt;
-    CHECK( evtStore()->retrieve(decisionCnt, m_tileMuRcvContainer) );
+    ATH_CHECK( evtStore()->retrieve(decisionCnt, m_tileMuRcvContainer) );
   
     TileMuonReceiverContainer::const_iterator it = decisionCnt->begin();
     TileMuonReceiverContainer::const_iterator itLast = decisionCnt->end();
@@ -1360,7 +1358,7 @@ StatusCode TileAANtuple::storeTMDBDigits() {
     ATH_MSG_VERBOSE( "reading TMDB digits from " << m_tileMuRcvDigitsContainer ); 
 
     const TileDigitsContainer* digitsCnt;
-    CHECK( evtStore()->retrieve(digitsCnt, m_tileMuRcvDigitsContainer) );
+    ATH_CHECK( evtStore()->retrieve(digitsCnt, m_tileMuRcvDigitsContainer) );
   
     TileDigitsContainer::const_iterator itColl1 = (*digitsCnt).begin();
     TileDigitsContainer::const_iterator itCollEnd1 = (*digitsCnt).end();
@@ -1432,7 +1430,7 @@ StatusCode TileAANtuple::storeTMDBRawChannel() {
     ATH_MSG_VERBOSE( "reading TMDB energies from " << m_tileMuRcvRawChannelContainer ); 
 
     const TileRawChannelContainer* rcCnt;
-    CHECK( evtStore()->retrieve(rcCnt, m_tileMuRcvRawChannelContainer) );
+    ATH_CHECK( evtStore()->retrieve(rcCnt, m_tileMuRcvRawChannelContainer) );
 
     TileRawChannelContainer::const_iterator itColl2 = (*rcCnt).begin();
     TileRawChannelContainer::const_iterator itCollEnd2 = (*rcCnt).end();
@@ -1520,7 +1518,7 @@ TileAANtuple::initNTuple(void) {
     CISPAR_addBranch();
     if (m_laserObject.size() > 0) {
       const TileLaserObject* laserObj;
-      CHECK( evtStore()->retrieve(laserObj, m_laserObject) );
+      ATH_CHECK( evtStore()->retrieve(laserObj, m_laserObject) );
       m_las_version = laserObj->getVersion();
       LASER_addBranch();
     }
@@ -2425,102 +2423,94 @@ void TileAANtuple::DCS_addBranch() {
   }
 }
 
-StatusCode TileAANtuple::storeDCS()
-{
-  if (m_DCScounter != m_tileDCSSvc->getNcalls()) {
-    
-    ATH_MSG_DEBUG( "Filling DCS ntuple: cnt=" << m_DCScounter
-                  <<" evtCnt=" << m_evtNr
-                  << " evt=" << m_evt
-                  << " lumi=" << m_lumiBlock << "  " << m_dateTime );
-    
-    m_DCScounter = m_tileDCSSvc->getNcalls();
-    
-    CLEAR(m_TEMP);
-    CLEAR(m_HV);
-    CLEAR(m_HVSET);
-    CLEAR(m_DRSTATES);
-    CLEAR(m_HVSTATUS);
-    CLEAR(m_DRSTATUS);
-    CLEAR(m_CHSTATUS);
-    
-    m_nBadDr = 0;
-    m_nBadHV = 0;
-    m_nBadDCS = 0;
-    m_nBadDB  = 0;
-    m_nBadTotal = 0;
-    for (int ROS = 1; ROS < 5; ++ROS) {
-      int rosI = ROS - 1;
+StatusCode TileAANtuple::storeDCS() {
+
+  ATH_MSG_DEBUG( "Filling DCS ntuple:"
+                 <<" evtCnt=" << m_evtNr
+                 << " evt=" << m_evt
+                 << " lumi=" << m_lumiBlock << "  " << m_dateTime );
+
+  CLEAR(m_TEMP);
+  CLEAR(m_HV);
+  CLEAR(m_HVSET);
+  CLEAR(m_DRSTATES);
+  CLEAR(m_HVSTATUS);
+  CLEAR(m_DRSTATUS);
+  CLEAR(m_CHSTATUS);
+
+  m_nBadDr = 0;
+  m_nBadHV = 0;
+  m_nBadDCS = 0;
+  m_nBadDB  = 0;
+  m_nBadTotal = 0;
+  for (int ROS = 1; ROS < 5; ++ROS) {
+    int rosI = ROS - 1;
       
-      for (int drawer = 0; drawer < 64; ++drawer) {
-        int module = drawer + 1;
-        m_DRSTATES[rosI][drawer] = m_tileDCSSvc->getDCSSTATES(ROS, module);
-        m_DRSTATUS[rosI][drawer] = m_tileDCSSvc->getDCSSTATUS(ROS, drawer);
-        bool drbad = m_tileDCSSvc->statusIsBad(ROS, drawer);
+    for (int drawer = 0; drawer < 64; ++drawer) {
+      m_DRSTATES[rosI][drawer] = m_tileDCS->getDrawerStates(ROS, drawer);
+      m_DRSTATUS[rosI][drawer] = m_tileDCS->getDCSStatus(ROS, drawer);
+      bool drbad = m_tileDCS->isStatusBad(ROS, drawer);
         
-        if (drbad) {
-          ++m_nBadDr;
-        }
+      if (drbad) {
+        ++m_nBadDr;
+      }
         
-        if (msgLvl(MSG::VERBOSE) || m_DRSTATUS[rosI][drawer] != TileDCSSvc::OK_DRAWER) {
-          ATH_MSG_VERBOSE( "Module=" << m_tileDCSSvc->partitionName(ROS)
-                           << std::setw(2) << std::setfill('0') << module
-                           << " DRSTATES=" << m_DRSTATES[rosI][drawer]
-                           << " DRSTATUS=" << m_DRSTATUS[rosI][drawer]
-                           << " => " << ((drbad) ? "bad" : "good")  );
-        }
+      if (msgLvl(MSG::VERBOSE) || m_DRSTATUS[rosI][drawer] != TileDCSState::OK_DRAWER) {
+        ATH_MSG_VERBOSE( "Module=" << TileCalibUtils::getDrawerString(ROS, drawer)
+                         << " DRSTATES=" << m_DRSTATES[rosI][drawer]
+                         << " DRSTATUS=" << m_DRSTATUS[rosI][drawer]
+                         << " => " << ((drbad) ? "bad" : "good")  );
+      }
         
-        unsigned int drawerIdx = TileCalibUtils::getDrawerIdx(ROS,drawer);
-        for (int channel=0; channel<48; ++channel){
-          TileBchStatus chStat = m_tileBadChanTool->getChannelStatus(drawerIdx,channel);
-          int pmt=abs(m_cabling->channel2hole(ROS,channel));
-          m_HV[rosI][drawer][channel]       = m_tileDCSSvc->getDCSHV(ROS, module, pmt);
-          m_HVSET[rosI][drawer][channel]    = m_tileDCSSvc->getDCSHVSET(ROS, module, pmt);
-          m_HVSTATUS[rosI][drawer][channel] = m_tileDCSSvc->getDCSHVSTATUS(ROS, drawer, channel);
-          m_CHSTATUS[rosI][drawer][channel] = m_tileDCSSvc->getDCSSTATUS(ROS, drawer, channel)
+      unsigned int drawerIdx = TileCalibUtils::getDrawerIdx(ROS,drawer);
+      for (int channel=0; channel<48; ++channel){
+        TileBchStatus chStat = m_tileBadChanTool->getChannelStatus(drawerIdx,channel);
+        int pmt=abs(m_cabling->channel2hole(ROS,channel));
+        m_HV[rosI][drawer][channel]       = m_tileDCS->getChannelHV(ROS, drawer, channel);
+        m_HVSET[rosI][drawer][channel]    = m_tileDCS->getChannelHVSet(ROS, drawer, channel);
+        m_HVSTATUS[rosI][drawer][channel] = m_tileDCS->getDCSHVStatus(ROS, drawer, channel);
+        m_CHSTATUS[rosI][drawer][channel] = m_tileDCS->getDCSStatus(ROS, drawer, channel)
           + 100 * m_tileBadChanTool->encodeStatus(chStat);
-          bool chbad=m_tileDCSSvc->statusIsBad(ROS,drawer,channel);
+        bool chbad = m_tileDCS->isStatusBad(ROS, drawer, channel);
           
-          if (chbad || chStat.isBad()) {
-            ++m_nBadTotal;
-            if (chbad) ++m_nBadDCS;
-            if (chStat.isBad()) ++m_nBadDB;
-          }
+        if (chbad || chStat.isBad()) {
+          ++m_nBadTotal;
+          if (chbad) ++m_nBadDCS;
+          if (chStat.isBad()) ++m_nBadDB;
+        }
           
-          if (m_tileDCSSvc->statusHVIsBad(ROS,drawer,channel)) {
-            ++m_nBadHV;
-          }
+        if (m_tileDCS->isStatusHVBad(ROS, drawer, channel)) {
+          ++m_nBadHV;
+        }
           
-          if (msgLvl(MSG::VERBOSE) || (chbad && !drbad)) {
-            ATH_MSG_VERBOSE( "Module=" << m_tileDCSSvc->partitionName(ROS)
-                             << std::setw(2) << std::setfill('0') << module
-                             << " channel=" << channel << " pmt=" << pmt
-                             << " HV=" << m_HV[rosI][drawer][channel]
-                             << " HVSET=" << m_HVSET[rosI][drawer][channel]
-                             << " HVSTATUS=" << m_HVSTATUS[rosI][drawer][channel]
-                             << " CHSTATUS=" << m_CHSTATUS[rosI][drawer][channel]
-                             << " => " << ((chbad) ? "bad" : "good")  );
-          }
+        if (msgLvl(MSG::VERBOSE) || (chbad && !drbad)) {
+          ATH_MSG_VERBOSE( "Module=" << TileCalibUtils::getDrawerString(ROS, drawer)
+                           << " channel=" << channel << " pmt=" << pmt
+                           << " HV=" << m_HV[rosI][drawer][channel]
+                           << " HVSET=" << m_HVSET[rosI][drawer][channel]
+                           << " HVSTATUS=" << m_HVSTATUS[rosI][drawer][channel]
+                           << " CHSTATUS=" << m_CHSTATUS[rosI][drawer][channel]
+                           << " => " << ((chbad) ? "bad" : "good")  );
         }
+      }
         
-        for (int ind=0; ind<7; ++ind){
-          m_TEMP[rosI][drawer][ind] = m_tileDCSSvc->getDCSHV(ROS, module, ind+49);
-          ATH_MSG_VERBOSE( "Module=" << m_tileDCSSvc->partitionName(ROS)
-                          << std::setw(2) << std::setfill('0') << module
-                          << " TEMP" << ind+1 << "=" << m_TEMP[rosI][drawer][ind] );
+      for (int ind=0; ind<7; ++ind){
+        m_TEMP[rosI][drawer][ind] = m_tileDCS->getChannelHV(ROS, drawer, ind+49);
+        ATH_MSG_VERBOSE( "Module=" << TileCalibUtils::getDrawerString(ROS, drawer)
+                         << " TEMP" << ind+1 << "=" << m_TEMP[rosI][drawer][ind] );
           
-        }
       }
     }
+  }
     
-    ATH_MSG_DEBUG( "BAD status in DCS: nBadDr=" << m_nBadDr
-                  << " nBadHV=" << m_nBadHV
-                  << " nBadDCS=" << m_nBadDCS
-                  << " nBadDB="  << m_nBadDB
-                  << " nBadTotal=" << m_nBadTotal );
+  ATH_MSG_DEBUG( "BAD status in DCS: nBadDr=" << m_nBadDr
+                 << " nBadHV=" << m_nBadHV
+                 << " nBadDCS=" << m_nBadDCS
+                 << " nBadDB="  << m_nBadDB
+                 << " nBadTotal=" << m_nBadTotal );
     
-    m_DCSntuplePtr->Fill();
-  }
+  m_DCSntuplePtr->Fill();
+
   
   return StatusCode::SUCCESS;
 }
diff --git a/TileCalorimeter/TileRecAlgs/src/TileCellSelector.cxx b/TileCalorimeter/TileRecAlgs/src/TileCellSelector.cxx
index b72e98da9b4f59e6ff47507c1c55080ad289d816..aeb8e3781025145b5648a38ee67feaa22576c0c9 100644
--- a/TileCalorimeter/TileRecAlgs/src/TileCellSelector.cxx
+++ b/TileCalorimeter/TileRecAlgs/src/TileCellSelector.cxx
@@ -11,7 +11,6 @@
 #include "TileCalibBlobObjs/TileCalibUtils.h"
 #include "TileConditions/TileCablingService.h"
 #include "TileConditions/ITileBadChanTool.h"
-#include "TileConditions/TileDCSSvc.h"
 
 // Calo includes
 #include "CaloIdentifier/TileID.h"
@@ -53,7 +52,6 @@ TileCellSelector::TileCellSelector(const std::string& name, ISvcLocator* pSvcLoc
   , m_tileHWID(0)
   , m_cabling(0)
   , m_tileBadChanTool("TileBadChanTool")
-  , m_tileDCSSvc("TileDCSSvc",name)
   , m_runNum(0)
   , m_lumiBlock(0)
   , m_evtNum(0)
@@ -142,15 +140,17 @@ StatusCode TileCellSelector::initialize() {
 
   ATH_CHECK( m_eventInfoKey.initialize() );
 
-  CHECK(detStore()->retrieve(m_tileID, "TileID"));
-  CHECK(detStore()->retrieve(m_tileHWID, "TileHWID"));
+  ATH_CHECK(detStore()->retrieve(m_tileID, "TileID"));
+  ATH_CHECK(detStore()->retrieve(m_tileHWID, "TileHWID"));
 
   m_cabling = TileCablingService::getInstance();
 
-  CHECK(m_tileBadChanTool.retrieve());
+  ATH_CHECK(m_tileBadChanTool.retrieve());
 
   if (m_checkDCS) {
-    CHECK(m_tileDCSSvc.retrieve());
+    ATH_CHECK(m_tileDCS.retrieve());
+  } else {
+    m_tileDCS.disable();
   }
 
   ATH_MSG_INFO( "Cell container " 
@@ -320,7 +320,7 @@ StatusCode TileCellSelector::initialize() {
     m_drawerToSkip.resize(1+TileCalibUtils::getDrawerIdx(4,63),false);
   }
 
-  CHECK( m_dqStatusKey.initialize() );
+  ATH_CHECK( m_dqStatusKey.initialize() );
 
   return StatusCode::SUCCESS;
 }
@@ -449,7 +449,7 @@ StatusCode TileCellSelector::execute() {
         int drmax = 65;
         for (int dr = 0; dr < drmax; ++dr) {
           int drawer = dr % 64;
-          if (m_tileDCSSvc->getDCSSTATUS(ros, drawer) == TileDCSSvc::ALERT_DRAWER) {
+          if (m_tileDCS->getDCSStatus(ros, drawer) == TileDCSState::ALERT_DRAWER) {
             if (m1 < 0) m1 = dr;
             m2 = dr;
             if (dr < 64) allmod.push_back((ros << 8) + dr);
@@ -1194,7 +1194,7 @@ StatusCode TileCellSelector::execute() {
               int adc = m_tileHWID->adc(adcId);
               m_chanBad[hash] = m_tileBadChanTool->getAdcStatus(drawerIdx,channel,adc).isBad() ||
                 (DQstatus && !DQstatus->isAdcDQgood(ros,drawer,channel,adc)) ||
-                (m_checkDCS && m_tileDCSSvc->getDCSSTATUS(ros,drawer,channel) > TileDCSSvc::WARNING);
+                (m_checkDCS && m_tileDCS->getDCSStatus(ros, drawer, channel) > TileDCSState::WARNING);
             }
 
             if (allowAmpCheck) {
@@ -1426,7 +1426,7 @@ StatusCode TileCellSelector::execute() {
               ++nChBad;
               ++nChBadDmu[dmu];
             }
-          } else if (m_checkDCS && m_tileDCSSvc->getDCSSTATUS(ros,drawer,channel) > TileDCSSvc::WARNING) {
+          } else if (m_checkDCS && m_tileDCS->getDCSStatus(ros, drawer, channel) > TileDCSState::WARNING) {
             badname = " BADDCS";
           } else if (m_tileBadChanTool->getAdcStatus(drawerIdx,channel,adc).isBad()) {
             badname = " BADDB";
@@ -1788,7 +1788,7 @@ StatusCode TileCellSelector::execute() {
                   badname = " BADDB";
                 } else if (DQstatus && !DQstatus->isAdcDQgood(ros, drawer, channel, adc)) {
                   badname = " BADDQ";
-                } else if (m_checkDCS && m_tileDCSSvc->getDCSSTATUS(ros, drawer, channel) > TileDCSSvc::WARNING) {
+                } else if (m_checkDCS && m_tileDCS->getDCSStatus(ros, drawer, channel) > TileDCSState::WARNING) {
                   badname = " BADDCS";
                 } else if (m_chanBad[hash]) {
                   if (badFromCell) {
diff --git a/TileCalorimeter/TileRecAlgs/src/TileCellSelector.h b/TileCalorimeter/TileRecAlgs/src/TileCellSelector.h
index 12cac4a132bfc976bb19e616cec092b7d432c2bc..c4356cddcec21a64415a9bd57000fba5a5949c7a 100644
--- a/TileCalorimeter/TileRecAlgs/src/TileCellSelector.h
+++ b/TileCalorimeter/TileRecAlgs/src/TileCellSelector.h
@@ -11,6 +11,7 @@
 #include "TileEvent/TileDigitsContainer.h"
 #include "TileEvent/TileRawChannelContainer.h"
 #include "TileEvent/TileDQstatus.h"
+#include "TileConditions/ITileDCSTool.h"
 
 // Calo includes
 #include "CaloEvent/CaloCellContainer.h"
@@ -31,7 +32,6 @@ class TileHWID;
 class TileCell;
 class TileCablingService;
 class ITileBadChanTool;
-class TileDCSSvc;
 
 
 /////////////////////////////////////////////////////////////////////////////
@@ -69,7 +69,7 @@ class TileCellSelector: public AthAlgorithm {
     const TileCablingService* m_cabling;
     ToolHandle<ITileBadChanTool> m_tileBadChanTool; //!< Tile Bad Channel tool
     SG::ReadHandleKey<TileDQstatus> m_dqStatusKey;
-    ServiceHandle<TileDCSSvc> m_tileDCSSvc; //!< Pointer to TileDCSSvc
+    ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"};
 
     unsigned int m_runNum;
     unsigned int m_lumiBlock;
diff --git a/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter.py b/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter.py
index dd28988cdc05e0d4083d528ad1a41450ed1d6578..0b58c45b3921778b6a8f54155e64bde872f052cd 100644
--- a/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter.py
+++ b/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter.py
@@ -56,7 +56,10 @@ class TileRawChannelGetter ( Configured)  :
         from TileRecUtils.TileRecFlags import jobproperties
         from TileRecUtils.TileRecUtilsConf import TileBeamInfoProvider
         theTileBeamInfoProvider = TileBeamInfoProvider()
-        if hasattr( ServiceMgr, "TileDCSSvc" ):
+
+        from AthenaCommon.AlgSequence import AthSequencer
+        condSequence = AthSequencer("AthCondSeq")
+        if hasattr(condSequence, 'TileDCSCondAlg'):
             theTileBeamInfoProvider.CheckDCS = True
 
         # true for real data, false for MC - GlobalFlags.DataSource.is_data()
diff --git a/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter_DigiHSTruth.py b/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter_DigiHSTruth.py
index 136d6fa045b2527620313982a72e9f507bbe6683..2bf19b5c5a2e5ba0592e5930c85c67e15206d568 100644
--- a/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter_DigiHSTruth.py
+++ b/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter_DigiHSTruth.py
@@ -52,7 +52,10 @@ class TileRawChannelGetter_DigiHSTruth ( Configured)  :
         from TileRecUtils.TileRecFlags import jobproperties
         from TileRecUtils.TileRecUtilsConf import TileBeamInfoProvider
         theTileBeamInfoProvider = TileBeamInfoProvider()
-        if hasattr( ServiceMgr, "TileDCSSvc" ):
+
+        from AthenaCommon.AlgSequence import AthSequencer
+        condSequence = AthSequencer("AthCondSeq")
+        if hasattr(condSequence, 'TileDCSCondAlg'):
             theTileBeamInfoProvider.CheckDCS = True
 
         # true for nominal ATLAS configuration - GlobalFlags.DetGeo.is_atlas()
diff --git a/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.cxx
index 977e4f640ddd936bb5b2c2713ac56978e3a523bd..f65eabf31d87a8a4c44d68571590897a6b565c4c 100644
--- a/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.cxx
+++ b/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.cxx
@@ -40,7 +40,7 @@ StatusCode TileBeamElemDumper::initialize()
  * @brief Algorithm event processing.
  * @param ctx Event Context.
  */
-StatusCode TileBeamElemDumper::execute_r (const EventContext& ctx) const
+StatusCode TileBeamElemDumper::execute (const EventContext& ctx) const
 {
   std::string fname = CxxUtils::strformat ("%s%s_%08u_%08lu.dump",
                                            m_prefix.value().c_str(),
diff --git a/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.h b/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.h
index 9dcf3b0b64d15b83279a9a0d945ea8b60b0a362f..2cc0c353cd1d524a107b9d848d0057e880040ec9 100644
--- a/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.h
+++ b/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.h
@@ -47,7 +47,7 @@ public:
    * @brief Algorithm event processing.
    * @param ctx Event Context.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/TileCalorimeter/TileRecUtils/src/TileBeamInfoProvider.cxx b/TileCalorimeter/TileRecUtils/src/TileBeamInfoProvider.cxx
index 6d47670062537afc708c97eba837f083afd69979..2fc73007887c0e37a0d8ca0f24d66eaecdc0173b 100644
--- a/TileCalorimeter/TileRecUtils/src/TileBeamInfoProvider.cxx
+++ b/TileCalorimeter/TileRecUtils/src/TileBeamInfoProvider.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 // TileCal includes
@@ -234,6 +234,8 @@ void TileBeamInfoProvider::handle(const Incident& inc) {
   // retrive all containers from detector store and cache pointers for future use
 
   if (m_checkBeam) {
+    // Needed due to back-door setting of the property.
+    m_beamElemContainerKey.initialize().ignore();
     SG::ReadHandle<TileBeamElemContainer> beamElemContainer(m_beamElemContainerKey);
     if (beamElemContainer.isValid()) {
       m_beamElemCnt = beamElemContainer.cptr();
diff --git a/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.cxx b/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.cxx
index 562eececf444d418f1752ec1895bbe7924bca9f3..3b259a007585ccbdedd00360e534629feb267c0d 100644
--- a/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.cxx
+++ b/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.cxx
@@ -55,7 +55,7 @@ StatusCode TileDQstatusAlg::initialize()
  * @brief Gaudi execute method.
  * @param ctx Event context.
  */
-StatusCode TileDQstatusAlg::execute_r (const EventContext& ctx) const
+StatusCode TileDQstatusAlg::execute (const EventContext& ctx) const
 {
   auto dqstatus = std::make_unique<TileDQstatus>();
 
diff --git a/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.h b/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.h
index 29385046411b961ada01aa7e493b3451101eaa80..59d669ff21a49ec0ea5773f263bcbf13dabb2299 100644
--- a/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.h
+++ b/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.h
@@ -56,7 +56,7 @@ public:
    * @brief Gaudi execute method.
    * @param ctx Event context.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.cxx
index 4584e32a62284f821dfb3437164195da32e98b7b..6c5e1cb20238e4f01c0606a79776f11f3a152661 100644
--- a/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.cxx
+++ b/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.cxx
@@ -43,7 +43,7 @@ StatusCode TileDigitsDumper::initialize()
  * @brief Algorithm event processing.
  * @param ctx Event Context.
  */
-StatusCode TileDigitsDumper::execute_r (const EventContext& ctx) const
+StatusCode TileDigitsDumper::execute (const EventContext& ctx) const
 {
   if (!m_altContKey.key().empty()) {
     SG::ReadHandle<TileDigitsContainer> altCont (m_altContKey, ctx);
diff --git a/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.h b/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.h
index 501efd757fafbb9bca604cd30571c6c1d84a4a57..6a21a149ae025319b0adb2863a530459f1b89b20 100644
--- a/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.h
+++ b/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.h
@@ -47,7 +47,7 @@ public:
    * @brief Algorithm event processing.
    * @param ctx Event Context.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/TileCalorimeter/TileRecUtils/src/TileL2Dumper.cxx b/TileCalorimeter/TileRecUtils/src/TileL2Dumper.cxx
index 8a731996b690668dc72f9b8f4b1166c3d808f33d..e3f84153fd5cd46297ef3a9cab3f13178e1c56ae 100644
--- a/TileCalorimeter/TileRecUtils/src/TileL2Dumper.cxx
+++ b/TileCalorimeter/TileRecUtils/src/TileL2Dumper.cxx
@@ -40,7 +40,7 @@ StatusCode TileL2Dumper::initialize()
  * @brief Algorithm event processing.
  * @param ctx Event Context.
  */
-StatusCode TileL2Dumper::execute_r (const EventContext& ctx) const
+StatusCode TileL2Dumper::execute (const EventContext& ctx) const
 {
   std::string fname = CxxUtils::strformat ("%s%s_%08u_%08lu.dump",
                                            m_prefix.value().c_str(),
diff --git a/TileCalorimeter/TileRecUtils/src/TileL2Dumper.h b/TileCalorimeter/TileRecUtils/src/TileL2Dumper.h
index 368379badfd1c636a38180bcfcfcd7ad7c085a61..d5c5a310a528b64aafe2b01d84b15c1d01b02e1c 100644
--- a/TileCalorimeter/TileRecUtils/src/TileL2Dumper.h
+++ b/TileCalorimeter/TileRecUtils/src/TileL2Dumper.h
@@ -47,7 +47,7 @@ public:
    * @brief Algorithm event processing.
    * @param ctx Event Context.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.cxx
index c969c075ea18423f236276109e5a921ef759a8d5..da2754dc514eab0dd8ecacfe5bff018ea21dcc8b 100644
--- a/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.cxx
+++ b/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.cxx
@@ -41,7 +41,7 @@ StatusCode TileLaserObjectDumper::initialize()
  * @brief Algorithm event processing.
  * @param ctx Event Context.
  */
-StatusCode TileLaserObjectDumper::execute_r (const EventContext& ctx) const
+StatusCode TileLaserObjectDumper::execute (const EventContext& ctx) const
 {
   std::string fname = CxxUtils::strformat ("%s%s_%08u_%08lu.dump",
                                            m_prefix.value().c_str(),
diff --git a/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.h b/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.h
index c953c0a2308182bd907a456dd9f60de0c689e683..ad458a8eda303683f856d85fac7d34258b5335ad 100644
--- a/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.h
+++ b/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.h
@@ -47,7 +47,7 @@ public:
    * @brief Algorithm event processing.
    * @param ctx Event Context.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.cxx
index d676d51ba1241f1e94b82e7c16e202b0cff8ded6..faf244c0cb9c1c5ab7c79cae06657cec3ec1fe03 100644
--- a/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.cxx
+++ b/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.cxx
@@ -41,7 +41,7 @@ StatusCode TileMuonReceiverDumper::initialize()
  * @brief Algorithm event processing.
  * @param ctx Event Context.
  */
-StatusCode TileMuonReceiverDumper::execute_r (const EventContext& ctx) const
+StatusCode TileMuonReceiverDumper::execute (const EventContext& ctx) const
 {
   std::string fname = CxxUtils::strformat ("%s%s_%08u_%08lu.dump",
                                            m_prefix.value().c_str(),
diff --git a/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.h b/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.h
index 9af75e8b83cae941d92f6c45cd02d85d087bbb95..ad56a6e270a16dd67a9866d3cddd4c4ec58a0610 100644
--- a/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.h
+++ b/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.h
@@ -47,7 +47,7 @@ public:
    * @brief Algorithm event processing.
    * @param ctx Event Context.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.cxx
index 4879ff2be1024880ef18d6796803b6adb4ca47b0..0995c768dde11a3fcc4db3b7a2f94f3277ffc2b4 100644
--- a/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.cxx
+++ b/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.cxx
@@ -43,7 +43,7 @@ StatusCode TileRawChannelDumper::initialize()
  * @brief Algorithm event processing.
  * @param ctx Event Context.
  */
-StatusCode TileRawChannelDumper::execute_r (const EventContext& ctx) const
+StatusCode TileRawChannelDumper::execute (const EventContext& ctx) const
 {
   if (!m_altContKey.key().empty()) {
     SG::ReadHandle<TileRawChannelContainer> altCont (m_altContKey, ctx);
diff --git a/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.h b/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.h
index 2e6e0fa0b5907752d563a05d03a53e4c4eac4065..0d27cd0b598d923bb887c0f904bce77f015851ba 100644
--- a/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.h
+++ b/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.h
@@ -47,7 +47,7 @@ public:
    * @brief Algorithm event processing.
    * @param ctx Event Context.
    */
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
 
 
 private:
diff --git a/TileCalorimeter/TileSimUtils/CMakeLists.txt b/TileCalorimeter/TileSimUtils/CMakeLists.txt
index 9a34e0affc3a41bccb2cd8b620dc7f5232d2d21f..340fa45d60796a87b6140536740d5aeb07887ac9 100644
--- a/TileCalorimeter/TileSimUtils/CMakeLists.txt
+++ b/TileCalorimeter/TileSimUtils/CMakeLists.txt
@@ -10,8 +10,6 @@ atlas_depends_on_subdirs( PUBLIC
                           Calorimeter/CaloIdentifier
                           Calorimeter/CaloSimEvent
                           Control/AthenaBaseComps
-                          Control/CLIDSvc
-                          Control/SGTools
                           GaudiKernel
                           PRIVATE
                           Control/AthenaKernel
@@ -28,7 +26,7 @@ atlas_add_library( TileSimUtilsLib
                    src/*.cxx
                    PUBLIC_HEADERS TileSimUtils
                    PRIVATE_INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
-                   LINK_LIBRARIES CaloIdentifier CaloSimEvent AthenaBaseComps SGTools GaudiKernel StoreGateLib SGtests
+                   LINK_LIBRARIES CaloIdentifier CaloSimEvent AthenaBaseComps GaudiKernel StoreGateLib SGtests
                    PRIVATE_LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaKernel )
 
 atlas_add_component( TileSimUtils
diff --git a/TileCalorimeter/TileSvc/TileByteStream/TileByteStream/TileROD_Decoder.h b/TileCalorimeter/TileSvc/TileByteStream/TileByteStream/TileROD_Decoder.h
index 87150e0c552cf97a02eefa15ff912eeaa433ff3f..91d82bc2fc97e07e11e66318354ab2591d17902b 100644
--- a/TileCalorimeter/TileSvc/TileByteStream/TileByteStream/TileROD_Decoder.h
+++ b/TileCalorimeter/TileSvc/TileByteStream/TileByteStream/TileROD_Decoder.h
@@ -10,6 +10,7 @@
 #include <string>
 #include <iostream>
 #include <cassert>
+#include <atomic>
 #include <stdint.h>
 
 // Gaudi includes
@@ -53,6 +54,35 @@ class TileCellBuilder;
 class TileL2Builder;
 class TileHid2RESrcID;
 
+namespace TileROD_Helper {
+
+
+// Helper to find the Tile container type corresponding to a container.
+template <class COLLECTION>
+struct ContainerForCollection {};
+
+template <>
+struct ContainerForCollection<TileBeamElemCollection>
+{
+  typedef TileBeamElemContainer type;
+};
+
+template <>
+struct ContainerForCollection<TileDigitsCollection>
+{
+  typedef TileDigitsContainer type;
+};
+
+template <>
+struct ContainerForCollection<TileRawChannelCollection>
+{
+  typedef TileRawChannelContainer type;
+};
+
+
+} // namespace TileROD_Helper
+
+
 /**
  *
  * @class TileROD_Decoder
@@ -113,7 +143,9 @@ class TileROD_Decoder: public AthAlgTool {
     /** This method calls the unpacking methods to decode the ROD data and fills
      the TileDigitsContainer and/or the TileRawChannelContainer
      */
-    void fillCollection(const ROBData * rob, COLLECTION& v);
+    void fillCollection(const ROBData * rob,
+                        COLLECTION& v,
+                        typename TileROD_Helper::ContainerForCollection<COLLECTION>::type* container = nullptr);
     uint32_t fillCollectionHLT(const ROBData * rob, TileCellCollection & v,
                                D0CellsHLT& d0cells);
     void fillCollectionL2(const ROBData * rob, TileL2Container & v);
@@ -140,8 +172,6 @@ class TileROD_Decoder: public AthAlgTool {
 
     void mergeD0cellsHLT (const D0CellsHLT& d0cells, TileCellCollection&);
 
-    // Set Pointer to container with raw channels
-    inline void PtrRChContainer(TileRawChannelContainer * container) { m_container = container; }
     void loadRw2Pmt(const int section, const std::vector<int>& vec) {
       for (unsigned int i = 0; i < vec.size(); ++i) {
         //	std::cout << vec[i] << std::endl;
@@ -149,6 +179,7 @@ class TileROD_Decoder: public AthAlgTool {
       }
     }
 
+    // Error reporting
     void printErrorCounter(bool printIfNoError);
     int getErrorCounter();
 
@@ -417,24 +448,28 @@ class TileROD_Decoder: public AthAlgTool {
                           DigitsMetaData_t& digitsMetaData,
                           RawChannelMetaData_t& rawchannelMetaData,
                           const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel,
-        TileBeamElemCollection& v) const;
+                          TileBeamElemCollection& v,
+                          TileBeamElemContainer* container) const;
     inline void make_copy(uint32_t bsflags,
                           TileFragHash::TYPE rChType,
                           TileRawChannelUnit::UNIT rChUnit,
                           DigitsMetaData_t& digitsMetaData,
                           RawChannelMetaData_t& rawchannelMetaData,
                           const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel,
-        TileDigitsCollection& v) const;
+                          TileDigitsCollection& v,
+                          TileDigitsContainer* container) const;
     inline void make_copy(uint32_t bsflags,
                           TileFragHash::TYPE rChType,
                           TileRawChannelUnit::UNIT rChUnit,
                           DigitsMetaData_t& digitsMetaData,
                           RawChannelMetaData_t& rawchannelMetaData,
                           const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel,
-        TileRawChannelCollection& v) const;
+                          TileRawChannelCollection& v,
+                          TileRawChannelContainer* container) const;
 
     uint32_t make_copyHLT(bool of2,
                           TileRawChannelUnit::UNIT rChUnit,
+                          bool correctAmplitude,
                           pFRwChVec & pChannel, TileCellCollection& v, const uint16_t DQuality,
                           D0CellsHLT& d0cells);
 
@@ -520,9 +555,6 @@ class TileROD_Decoder: public AthAlgTool {
 
     bool m_of2Default;
 
-    // TileRawChannelContainer
-    TileRawChannelContainer * m_container;
-
     bool m_maskBadDigits;
     // Pointer to a MBTS cell collection
     TileCellCollection* m_MBTS;
@@ -538,9 +570,8 @@ class TileROD_Decoder: public AthAlgTool {
     TileL2Builder* m_L2Builder;
     std::string m_TileDefaultL2Builder;
 
-    int m_WarningCounter;
-    int m_ErrorCounter;
-    bool m_correctAmplitude;
+    mutable std::atomic<int> m_WarningCounter;
+    mutable std::atomic<int> m_ErrorCounter;
 
     TileHid2RESrcID * m_hid2re;
     TileHid2RESrcID * m_hid2reHLT;
@@ -574,7 +605,7 @@ class TileROD_Decoder: public AthAlgTool {
         max_allowed_size = 0;
       if (size < 3 && size > 0) {
         if (rob->rod_source_id() > 0x50ffff) error |= 0x10000; // indicate error in frag size, but ignore error in laser ROD
-        if (m_WarningCounter < (m_maxWarningPrint--)) {
+        if (m_WarningCounter++ < m_maxWarningPrint) {
           ATH_MSG_WARNING("ROB " << MSG::hex << rob->source_id()
               << " ROD " << rob->rod_source_id() << MSG::dec
               << " has unexpected data size: " << size << " - assuming zero size " );
@@ -582,7 +613,7 @@ class TileROD_Decoder: public AthAlgTool {
         return 0;
       } else if (rob->rod_header_size_word() >= rob->rod_fragment_size_word()) {
         if (rob->rod_source_id() > 0x50ffff) error |= 0x10000; // indicate error in frag size, but ignore error in laser ROD
-        if (m_WarningCounter < (m_maxWarningPrint--)) {
+        if (m_WarningCounter++ < m_maxWarningPrint) {
           ATH_MSG_WARNING("ROB " << MSG::hex << rob->source_id()
               << " ROD " << rob->rod_source_id() << MSG::dec
               << " has unexpected header size: " << rob->rod_header_size_word()
@@ -655,7 +686,9 @@ void TileROD_Decoder::make_copy(uint32_t /*bsflags*/,
                                 DigitsMetaData_t& digitsMetaData,
                                 RawChannelMetaData_t& /*rawchannelMetaData*/,
                                 const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel,
-    TileDigitsCollection & v) const {
+                                TileDigitsCollection & v,
+                                TileDigitsContainer* /*container*/) const
+{
   copy_vec(pDigits, v); // Digits stored
 
   if (pChannel.size() > 0) { // RawChannels deleted
@@ -705,15 +738,16 @@ void TileROD_Decoder::make_copy(uint32_t bsflags,
                                 DigitsMetaData_t& /*digitsMetaData*/,
                                 RawChannelMetaData_t& rawchannelMetaData,
                                 const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel,
-    TileRawChannelCollection & v) const {
+                                TileRawChannelCollection & v,
+                                TileRawChannelContainer* container) const {
   if (pChannel.size() > 0) { // take available raw channels
                              // and store in collection
-    if (m_container) {
+    if (container) {
       ATH_MSG_VERBOSE( "RawChannel unit is " << rChUnit
                       << "  - setting unit in TileRawChannelContainer " );
-      m_container->set_unit(rChUnit);
-      m_container->set_type(rChType);
-      m_container->set_bsflags(bsflags);
+      container->set_unit(rChUnit);
+      container->set_type(rChType);
+      container->set_bsflags(bsflags);
     } else {
       ATH_MSG_ERROR( "Can't set unit=" << rChUnit << " in TileRawChannelContainer" );
     }
@@ -788,8 +822,10 @@ void TileROD_Decoder::make_copy(uint32_t /*bsflags*/,
                                 TileRawChannelUnit::UNIT /*rChUnit*/,
                                 DigitsMetaData_t& /*digitsMetaData*/,
                                 RawChannelMetaData_t& /*rawchannelMetaData*/,
-                                const ROBData * /* rob */, pDigiVec & pDigits
-    , pRwChVec & pChannel, TileBeamElemCollection &) const {
+                                const ROBData * /* rob */, pDigiVec & pDigits,
+                                pRwChVec & pChannel, TileBeamElemCollection &,
+                                TileBeamElemContainer* /*container*/) const
+{
   // do nothing
   delete_vec(pDigits);
   delete_vec(pChannel);
@@ -835,7 +871,10 @@ void TileROD_Decoder::make_copy(const ROBData * /* rob */, pBeamVec & pBeam,
  from a BLOCK of integers
  */
 template<class COLLECTION>
-void TileROD_Decoder::fillCollection(const ROBData * rob, COLLECTION & v) {
+void TileROD_Decoder::fillCollection(const ROBData * rob,
+                                     COLLECTION & v,
+                                     typename TileROD_Helper::ContainerForCollection<COLLECTION>::type* container /*= nullptr*/)
+{
   //
   // get info from ROD header
   //
@@ -1098,7 +1137,7 @@ void TileROD_Decoder::fillCollection(const ROBData * rob, COLLECTION & v) {
     } // end of all frags
 
     make_copy(bsflags, rChType, rChUnit, digitsMetaData, rawchannelMetaData,
-              rob, pDigits, pChannel, v);
+              rob, pDigits, pChannel, v, container);
   }
 
   return;
diff --git a/TileCalorimeter/TileSvc/TileByteStream/src/TileROD_Decoder.cxx b/TileCalorimeter/TileSvc/TileByteStream/src/TileROD_Decoder.cxx
index b53400efa7625766b225dd605ba52318215b0379..549197768eeb1922eaa21090094784c1ed257558 100644
--- a/TileCalorimeter/TileSvc/TileByteStream/src/TileROD_Decoder.cxx
+++ b/TileCalorimeter/TileSvc/TileByteStream/src/TileROD_Decoder.cxx
@@ -67,13 +67,11 @@ TileROD_Decoder::TileROD_Decoder(const std::string& type, const std::string& nam
   declareProperty("AllowedTimeMax", m_allowedTimeMax =  50.); // set amp to zero if time is above allowed time max
   declareProperty("fullTileMode", m_fullTileRODs); // run from which to take the cabling (for the moment, either 320000 - full 2017 mode - or 0 - 2016 mode)
 
-  m_correctAmplitude = false;
   updateAmpThreshold(15.);
   m_timeMinThresh = -25;
   m_timeMaxThresh = 25;
-  
+
   m_of2Default = true;
-  m_container = 0;
   m_MBTS = NULL;
   m_cell2Double.reserve(23); // Maximum number of cells in a drawer
   m_WarningCounter = 0;
@@ -3288,6 +3286,7 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect
     }
   }
   bool of2 = m_of2Default;
+  bool correctAmplitude = false;
   TileRawChannelUnit::UNIT rChUnit = TileRawChannelUnit::ADCcounts;
   uint16_t DQuality = 0x0;
   bool fragFound = false;
@@ -3332,13 +3331,13 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect
         case 2:
           fragFound = true;
           DQfragMissing = false;
-          m_correctAmplitude = false;
+          correctAmplitude = false;
           unpack_frag2HLT(version, sizeOverhead, p, m_pRwChVec);
           break;
         case 3:
           fragFound = true;
           DQfragMissing = false;
-          m_correctAmplitude = false;
+          correctAmplitude = false;
           unpack_frag3HLT(version, sizeOverhead, p, m_pRwChVec);
           break;
         case 4:
@@ -3352,13 +3351,13 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect
               
               of2 = ((idAndType & 0x4000000) != 0);
               int nIter = (idAndType & 0x3000000) >> 24;
-              m_correctAmplitude = (!nIter); // automatic detection of nIter
+              correctAmplitude = (!nIter); // automatic detection of nIter
               rChUnit = (TileRawChannelUnit::UNIT) (unit + TileRawChannelUnit::OnlineOffset); // Online units in real data
               
             } else { // simulated data
               
               DQfragMissing = false;
-              m_correctAmplitude = false;
+              correctAmplitude = false;
               rChUnit = (TileRawChannelUnit::UNIT) (unit); // Offline units in simulated data
             }
             
@@ -3372,7 +3371,7 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect
             int unit = (idAndType & 0xC0000000) >> 30;
             
             of2 = ((idAndType & 0x4000000) != 0);
-            m_correctAmplitude = true; // fragment 5 will appear only if there is no iterations, so correction required
+            correctAmplitude = true; // fragment 5 will appear only if there is no iterations, so correction required
             rChUnit = (TileRawChannelUnit::UNIT) (unit + TileRawChannelUnit::OnlineOffset);
             
             unpack_frag5HLT(version, sizeOverhead, unit, p, m_pRwChVec);
@@ -3399,7 +3398,8 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect
   
   if (fragFound) {
     if (masked_drawer) DQuality = 0x0;
-    error |= make_copyHLT(of2, rChUnit, m_pRwChVec, v, DQuality, d0cells);
+    error |= make_copyHLT(of2, rChUnit, correctAmplitude,
+                          m_pRwChVec, v, DQuality, d0cells);
   } else if (!masked_drawer) error |= 0x20000;
   
   return error;
@@ -3407,6 +3407,7 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect
 
 uint32_t TileROD_Decoder::make_copyHLT(bool of2,
                                        TileRawChannelUnit::UNIT rChUnit,
+                                       bool correctAmplitude,
                                        pFRwChVec & pChannel, TileCellCollection & v,
                                        const uint16_t DQuality,
                                        D0CellsHLT& d0cells) {
@@ -3476,7 +3477,7 @@ uint32_t TileROD_Decoder::make_copyHLT(bool of2,
                                                  TileRawChannelUnit::MegaElectronVolts);
         }
         // parabolic correction for good but slightly out-of-time signals
-        if (m_correctAmplitude) {
+        if (correctAmplitude) {
           if (time<m_allowedTimeMin || time>m_allowedTimeMax) {
             ener = 0.0F;
             time = 0.0F;
@@ -3533,7 +3534,7 @@ uint32_t TileROD_Decoder::make_copyHLT(bool of2,
                                                    TileRawChannelUnit::MegaElectronVolts);
           }
           // parabolic correction for good but slightly out-of-time signals
-          if (m_correctAmplitude) {
+          if (correctAmplitude) {
             if (time<m_allowedTimeMin || time>m_allowedTimeMax) {
               ener = 0.0F;
               time = 0.0F;
@@ -3590,7 +3591,7 @@ uint32_t TileROD_Decoder::make_copyHLT(bool of2,
                                                    rChUnit, TileRawChannelUnit::PicoCoulombs);
           }
           // parabolic correction for good but slightly out-of-time signals
-          if (m_correctAmplitude) {
+          if (correctAmplitude) {
             if (time<m_allowedTimeMin || time>m_allowedTimeMax) {
               ener = 0.0F;
               time = 0.0F;
diff --git a/TileCalorimeter/TileSvc/TileByteStream/src/TileRawChannelContByteStreamCnv.cxx b/TileCalorimeter/TileSvc/TileByteStream/src/TileRawChannelContByteStreamCnv.cxx
index 9606fec1e4d97cf879198d4785d53f9d6e9ed83f..9b22d6beb86e4a80b203b66fa0b1e84cc015ace1 100644
--- a/TileCalorimeter/TileSvc/TileByteStream/src/TileRawChannelContByteStreamCnv.cxx
+++ b/TileCalorimeter/TileSvc/TileByteStream/src/TileRawChannelContByteStreamCnv.cxx
@@ -80,7 +80,6 @@ StatusCode TileRawChannelContByteStreamCnv::initialize() {
   unit = TileRawChannelUnit::ADCcounts;
   m_containers[0] = new TileRawChannelContainer(true, type, unit); 
   m_containers[0]->addRef(); // make sure it's not deleted at the end of event
-  m_decoder->PtrRChContainer( m_containers[0] );
 
   type = TileFragHash::MF;
   unit = TileRawChannelUnit::ADCcounts;
@@ -147,7 +146,7 @@ StatusCode TileRawChannelContByteStreamCnv::createObj(IOpaqueAddress* pAddr, Dat
         if (isTMDB) {// reid for TMDB 0x5x010x
 	  m_decoder->fillCollection_TileMuRcv_RawChannel(robf[0], *rawChannelCollection);
         } else {
-          m_decoder->fillCollection(robf[0], *rawChannelCollection);
+          m_decoder->fillCollection(robf[0], *rawChannelCollection, m_containers[icnt]);
         }
       } else {
         rawChannelCollection->setFragGlobalCRC(TileROD_Decoder::NO_ROB);
diff --git a/TileCalorimeter/TileSvc/TileByteStream/test/TileROD_Decoder_test.cxx b/TileCalorimeter/TileSvc/TileByteStream/test/TileROD_Decoder_test.cxx
index 276a313e66160d9bb5034f65a1b3ef28a5c8e9e6..3f928b283108b30861e25632d2140d60d39a9907 100644
--- a/TileCalorimeter/TileSvc/TileByteStream/test/TileROD_Decoder_test.cxx
+++ b/TileCalorimeter/TileSvc/TileByteStream/test/TileROD_Decoder_test.cxx
@@ -148,8 +148,7 @@ void test1 (TileROD_Decoder* decoder)
   {
     TileRawChannelContainer cont;
     TileRawChannelCollection coll (256);
-    decoder->PtrRChContainer (&cont);
-    decoder->fillCollection (&data01.rob(), coll);
+    decoder->fillCollection (&data01.rob(), coll, &cont);
     std::cout << "TileRawChannelCollection: " << coll.size() << " "
               << cont.get_unit() << " "
               << cont.get_type() << " "
diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBAANtuple.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBAANtuple.h
index c621ee26dbb61df9c211ab6f183c3dc807e1fe09..387c789acec95ba9d6d50f9495ec8a4cb07d2deb 100755
--- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBAANtuple.h
+++ b/TileCalorimeter/TileTBRec/TileTBRec/TileTBAANtuple.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 //****************************************************************************
@@ -68,7 +68,6 @@ class TileHWID;
 class TileInfo;
 //class TileCablingSvc;
 class TileRawChannelBuilderFlatFilter;
-class TileBeamInfoProvider;
 class TileBeamElemContByteStreamCnv;
 class TileLaserObject;
 class TileCondToolEmscale;
@@ -534,8 +533,6 @@ class TileTBAANtuple: public AthAlgorithm {
 
     ToolHandle<TileCondToolEmscale> m_tileToolEmscale; //!< main Tile Calibration tool
 
-    ToolHandle<TileBeamInfoProvider> m_beamInfo;
-
     TileBeamElemContByteStreamCnv* m_beamCnv;
 
     std::string m_currentNtupleLoc;
diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBNtuple.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBNtuple.h
deleted file mode 100755
index fa2e30a76f2e3dea230906e6537fcd27d17747b7..0000000000000000000000000000000000000000
--- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBNtuple.h
+++ /dev/null
@@ -1,348 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-//****************************************************************************
-/// Filename : TileTBNtuple.h
-/// Author   : Paulo da Silva
-/// Created  : Oct, 2003
-///
-/// DESCRIPTION
-/// 
-///    To create TB beam Ntuple file from Digits container
-///
-/// Properties (JobOption Parameters):
-///
-///    TileDigitsContainer     string   key value of Digits in TDS 
-///    TileBeamElemContainer   string   key of BeamElems in TDS
-///    TileRawChannelContainerFlat      key of flat filtered RawChannels in TDS
-///    TileRawChannelContainerFit       key of fit filtered RawChannels in TDS
-///    CalibrateEnergy         bool     If calibration should be applied to energy
-///    CalibMode               bool     If data is in calibration mode
-///    NtupleLoc               string   pathname of ntuple file
-///    NtupleID                int      ID of ntuple
-///    BC1X1                   float    TDC Conv param
-///    BC1X2                   float    TDC Conv param
-///    BC1Y1                   float    TDC Conv param
-///    BC1Y2                   float    TDC Conv param
-///    BC1Z                    float    TDC Conv param
-///    BC2X1                   float    TDC Conv param
-///    BC2X2                   float    TDC Conv param
-///    BC2Y1                   float    TDC Conv param
-///    BC2Y2                   float    TDC Conv param
-///    BC2Z                    float    TDC Conv param
-///
-/// BUGS:
-///  
-/// History:
-///  
-//  
-//****************************************************************************
-#ifndef TileTBNtuple_H
-#define TileTBNtuple_H
-
-// Gaudi includes
-#include "GaudiKernel/NTuple.h"
-#include "GaudiKernel/ToolHandle.h"
-#include "GaudiKernel/ServiceHandle.h"
-
-// Athena includes
-#include "AthenaBaseComps/AthAlgorithm.h"
-
-#include "TileConditions/TileCablingService.h"
-
-class TileID;
-class TileHWID;
-class TileInfo;
-class TileRawChannelBuilderFlatFilter;
-class TileBeamInfoProvider;
-class TileBeamElemContByteStreamCnv;
-class TileCondToolEmscale;
-
-#include "TTree.h"
-#include <string>
-#include <vector>
-#include <map>
-
-/* @class TileTBNtuple
- @brief Osolete Class to create Ntuples. Use TileTBAANtuple for rel> 13.0.10
- */
-
-class TileTBNtuple: public AthAlgorithm {
-  public:
-    //Constructor
-    TileTBNtuple(std::string name, ISvcLocator* pSvcLocator);
-
-    //Destructor 
-    virtual ~TileTBNtuple();
-
-    //Gaudi Hooks
-    StatusCode initialize();
-    StatusCode execute();
-    StatusCode finalize();
-
-  private:
-
-    StatusCode storeRawChannels(std::string cntID
-                                , std::vector<NTuple::Array<float>*> *
-                                , std::vector<NTuple::Array<float>*> *
-                                , std::vector<NTuple::Array<float>*> *
-                                , std::vector<NTuple::Array<float>*> *);
-
-    StatusCode storeDigits();
-    StatusCode storeBeamElements();
-    StatusCode storeCells();
-
-    StatusCode initList(void);
-    StatusCode initNTuple(void);
-    StatusCode connectFile(void);
-
-    void getEta(void);
-
-    inline int digiChannel2PMT(int fragType, int chan) {
-      return (abs(m_cabling->channel2hole(fragType, chan)) - 1);
-    }
-
-    // If data should be put in calib mode
-    bool m_calibMode;
-
-    // The ntuple
-    NTuple::Tuple* m_ntuplePtr;
-    bool m_ntupleCreated;
-
-    // event number
-    int m_evtNr;
-
-    // Triger items
-    NTuple::Item<int> m_evTime;
-    NTuple::Item<int> m_run;
-    NTuple::Item<int> m_evt;
-    NTuple::Item<int> m_trigType;
-
-    // 0 - Beam, 1 neg eta, 2 pos eta
-    NTuple::Array<int> m_l1ID;
-    NTuple::Array<int> m_l1Type;
-    NTuple::Array<int> m_evBCID;
-    NTuple::Array<int> m_evType;
-
-    NTuple::Array<int> m_frBCID;
-
-    // Muon items
-    NTuple::Item<float> m_muBackHit;
-    NTuple::Item<float> m_muBackSum;
-    NTuple::Array<float> m_muBack; // MUON/MuBack
-    NTuple::Array<float> m_muCalib; // MUON/MuCalib
-
-    // Ecal
-    NTuple::Array<float> m_ecal;
-
-    // laser items
-    NTuple::Item<int> m_lasFlag;
-    NTuple::Item<float> m_las0;
-    NTuple::Item<float> m_las1;
-    NTuple::Item<float> m_las2;
-    NTuple::Item<float> m_las3;
-    NTuple::Array<float> m_lasExtra;
-
-    // pattern Unit in common beam crate
-    NTuple::Item<int> m_commonPU;
-
-    // Adder items
-    NTuple::Matrix<int> m_adder;
-    //NTuple::Array<int> m_addx;
-    NTuple::Array<float> m_eneAdd;
-    NTuple::Array<float> m_timeAdd;
-
-    // status
-    // NTuple::Matrix<float> m_status;
-
-    // Cispar
-    NTuple::Array<int> m_cispar;
-
-    // TDC/BEAM Items
-    NTuple::Item<int> m_s1cou;
-    NTuple::Item<int> m_s2cou;
-    NTuple::Item<int> m_s3cou;
-    NTuple::Item<int> m_cher1;
-    NTuple::Item<int> m_cher2;
-    NTuple::Item<int> m_muTag;
-    NTuple::Item<int> m_muHalo;
-    NTuple::Item<int> m_muVeto;
-
-    NTuple::Item<int> m_s2extra;
-    NTuple::Item<int> m_s3extra;
-
-    NTuple::Item<int> m_sc1;
-    NTuple::Item<int> m_sc2;
-
-    NTuple::Array<int> m_tof;
-    NTuple::Array<int> m_btdc1;
-    NTuple::Array<int> m_btdc2;
-
-    NTuple::Item<float> m_xChN2;
-    NTuple::Item<float> m_yChN2;
-    NTuple::Item<float> m_xChN1;
-    NTuple::Item<float> m_yChN1;
-    NTuple::Item<float> m_xCha0;
-    NTuple::Item<float> m_yCha0;
-
-    NTuple::Item<float> m_xCha1;
-    NTuple::Item<float> m_yCha1;
-    NTuple::Item<float> m_xCha2;
-    NTuple::Item<float> m_yCha2;
-    NTuple::Item<float> m_xImp;
-    NTuple::Item<float> m_yImp;
-
-    // Digi/Energy items
-    std::vector<NTuple::Item<int>*> m_evtVec;
-    std::vector<NTuple::Array<int>*> m_bcidVec;
-    std::vector<NTuple::Item<int>*> m_rodBCIDVec;
-    std::vector<NTuple::Item<int>*> m_sizeVec;
-    std::vector<NTuple::Array<int>*> m_dmuMaskVec;
-    std::vector<NTuple::Array<int>*> m_slinkCRCVec;
-    std::vector<NTuple::Array<int>*> m_gainVec;
-    std::vector<NTuple::Array<int>*> m_errVec;
-    std::vector<NTuple::Matrix<int>*> m_sampleVec;
-    std::vector<NTuple::Array<int>*> m_feCRCVec; //we use shorts, because vector<bool> is bugged
-    std::vector<NTuple::Array<int>*> m_rodCRCVec;
-
-    std::vector<NTuple::Array<float>*> m_eneVec;
-    std::vector<NTuple::Array<float>*> m_timeVec;
-    std::vector<NTuple::Array<float>*> m_efitVec;
-    std::vector<NTuple::Array<float>*> m_tfitVec;
-    std::vector<NTuple::Array<float>*> m_pedfitVec;
-    std::vector<NTuple::Array<float>*> m_chi2Vec;
-    std::vector<NTuple::Array<float>*> m_eOptVec;
-    std::vector<NTuple::Array<float>*> m_tOptVec;
-    std::vector<NTuple::Array<float>*> m_pedOptVec;
-    std::vector<NTuple::Array<float>*> m_chi2OptVec;
-    std::vector<NTuple::Array<float>*> m_eDspVec;
-    std::vector<NTuple::Array<float>*> m_tDspVec;
-    std::vector<NTuple::Array<float>*> m_chi2DspVec;
-
-    NTuple::Array<float> m_LarEne;
-    NTuple::Array<float> m_BarEne;
-    NTuple::Array<float> m_ExtEne;
-    NTuple::Array<float> m_GapEne;
-
-    NTuple::Array<int> m_coincTrig1;
-    NTuple::Array<int> m_coincTrig2;
-    NTuple::Array<int> m_coincTrig3;
-    NTuple::Array<int> m_coincTrig4;
-    NTuple::Array<int> m_coincTrig5;
-    NTuple::Array<int> m_coincTrig6;
-    NTuple::Array<int> m_coincTrig7;
-    NTuple::Array<int> m_coincTrig8;
-
-    NTuple::Item<int> m_coincFlag1;
-    NTuple::Item<int> m_coincFlag2;
-    NTuple::Item<int> m_coincFlag3;
-    NTuple::Item<int> m_coincFlag4;
-    NTuple::Item<int> m_coincFlag5;
-    NTuple::Item<int> m_coincFlag6;
-    NTuple::Item<int> m_coincFlag7;
-    NTuple::Item<int> m_coincFlag8;
-
-    std::vector<std::string> m_rosName; // name of arrays in ntuple for different ROSes
-    std::vector<std::string> m_drawerList; // list of frag IDs in correct order
-    std::vector<int> m_drawerType; // type of every drawer 1-4: B+, B-, EB+, EB-
-    std::map<unsigned int, unsigned int, std::less<unsigned int> > m_drawerMap; // map for frag IDs -> index
-
-    typedef std::map<unsigned int, unsigned int, std::less<unsigned int> >::iterator drawerMap_iterator;
-
-    std::vector<std::string> m_beamFragList; // list of beam frag IDs to store in the ntuple
-    bool m_beamIdList[32]; // list of beam frag IDs to store in the ntuple
-
-    // Params for Beam TDC
-    // Beam chambers -1 and -2
-    float m_beamBN2X1;
-    float m_beamBN2X2;
-    float m_beamBN2Y1;
-    float m_beamBN2Y2;
-    float m_beamBN2Z;
-
-    float m_beamBN1X1;
-    float m_beamBN1X2;
-    float m_beamBN1Y1;
-    float m_beamBN1Y2;
-    float m_beamBN1Z;
-
-    // Beam chamber 0
-    float m_beamBC0X1;
-    float m_beamBC0X2;
-    float m_beamBC0Y1;
-    float m_beamBC0Y2;
-    float m_beamBC0Z;
-
-    // Beam chambers 1 and 2
-    float m_beamBC1X1;
-    float m_beamBC1X2;
-    float m_beamBC1Y1;
-    float m_beamBC1Y2;
-    float m_beamBC1Z;
-
-    float m_beamBC2X1;
-    float m_beamBC2X2;
-    float m_beamBC2Y1;
-    float m_beamBC2Y2;
-    float m_beamBC2Z;
-    float m_beamBC2Zperiod1;
-    float m_beamBC2Zperiod2;
-
-    //run number
-    int m_runNumber;
-    float m_eta;
-    float m_theta;
-    std::string m_etaFileName;
-
-    //inner radius of calo
-    float m_radius;
-
-    // Container Parameters
-    std::string m_digitsContainer;
-    std::string m_beamElemContainer;
-    std::string m_flatRawChannelContainer;
-    std::string m_fitRawChannelContainer;
-    std::string m_fitcRawChannelContainer;
-    std::string m_optRawChannelContainer;
-    std::string m_dspRawChannelContainer;
-    std::string m_laserObject;
-
-    bool m_calibrateEnergyThisEvent;
-    bool m_calibrateEnergy;
-    bool m_useDspUnits;
-    bool m_unpackAdder;
-    bool m_completeNtuple;
-    bool m_commitNtuple;
-    bool m_bsInput;
-    int m_finalUnit;
-
-    // NTuple parameters
-    std::string m_ntupleID;
-    std::string m_ntupleLoc;
-    Long64_t m_treeSize;
-    int m_nSamples;
-    unsigned int m_nDrawers;
-
-    ToolHandle<TileRawChannelBuilderFlatFilter> m_adderFilterAlgTool;
-
-    // Identifiers
-    const TileID* m_tileID;
-    const TileHWID* m_tileHWID;
-
-    const TileCablingService* m_cabling;
-
-    ToolHandle<TileCondToolEmscale> m_tileToolEmscale; //!< main Tile Calibration tool
-
-    ToolHandle<TileBeamInfoProvider> m_beamInfo;
-
-    TileBeamElemContByteStreamCnv* m_beamCnv;
-
-    std::string m_currentNtupleLoc;
-    int m_currentFileNum;
-    int m_eventsPerFile;
-
-    std::string m_streamName;
-};
-
-#endif
diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleRead.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleRead.h
deleted file mode 100644
index 93b4fa08667bdc4f79c72d48a2ba732350895607..0000000000000000000000000000000000000000
--- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleRead.h
+++ /dev/null
@@ -1,90 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#ifndef TileTBOldNtupleRead_H
-#define TileTBOldNtupleRead_H
-
-#include "AthenaBaseComps/AthAlgorithm.h"
-#include "GaudiKernel/ToolHandle.h"
-
-// STL includes
-#include <string>
-#include <vector>
-
-// ROOT includes
-#include "TFile.h"
-#include "TTree.h"
-
-#include "TileConditions/TileCablingService.h"
-
-class StoreGateSvc;
-class TileHWID;
-class TileBeamInfoProvider;
-class TileTBOldNtupleStruct;
-
-class TileTBOldNtupleRead : public AthAlgorithm {
-public:
-  TileTBOldNtupleRead(std::string name, ISvcLocator* pSvcLocator);
-  virtual ~TileTBOldNtupleRead();
-
-  StatusCode initialize();
-  StatusCode execute();
-  StatusCode finalize();
-
-  int RunNumber()   {return m_runNumber;}
-  int EventNumber() {return m_eventNumber;}
-  int EventShift(int dr)  {return m_eventShift[dr];}
-  int TrigType()    {return m_trigType;}
-
-  int NSamp()   {return m_nSamp;}
-  bool BiGain() {return m_bigain;}
-
-  std::string& DigitsContainer() { return m_digitsContainer; }
-  std::string& BeamInfoContainer() { return m_beamContainer; }
-
-  TTree* getNtuple() {return m_ntuple;}
-  
-  static TileTBOldNtupleRead * getInstance();
-
-private:
-
-  std::string m_ntupleID;
-  std::string m_ntupleDir;
-  std::string m_digitsContainer;
-  std::string m_beamContainer;
-  
-  bool m_bigain;
-  bool m_pmtOrder;
-  bool m_barrelOnly;
-  bool m_adderFit;
-  std::vector<int> m_eventShift;
-
-  const TileHWID * m_tileHWID;
-  const TileCablingService * m_cabling;
-  ToolHandle<TileBeamInfoProvider> m_beamInfo;
-
-  int m_runNumber;
-  int m_eventNumber;
-  int m_maxEventNumber;
-  int m_trigType;
-  int m_nSamp;
-
-  TFile * m_file;
-  TTree * m_ntuple;
-  TileTBOldNtupleStruct * m_ntupleStruct;
-
-  static TileTBOldNtupleRead * s_instance ;
-
-  inline int digiChannel2PMT(int ros, int chan) {
-    return (abs(m_cabling->channel2hole(ros,chan))-1); 
-  }
-
-  inline int drawer2ros(int ros, int drawer) {
-    if (m_barrelOnly) return ros;
-    else return (drawer<2) ? ros : ros+2;
-  }
-      
-};
-
-#endif
diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleWrite.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleWrite.h
deleted file mode 100644
index c3c5154963f5484fdd87e0fdde52cd64f69363a9..0000000000000000000000000000000000000000
--- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleWrite.h
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#ifndef TileTBOldNtupleWrite_H
-#define TileTBOldNtupleWrite_H
-
-#include "AthenaBaseComps/AthAlgorithm.h"
-#include "GaudiKernel/ToolHandle.h"
-
-// STL includes
-#include <string>
-#include <vector>
-
-// ROOT includes
-#include "TFile.h"
-#include "TTree.h"
-
-#include "TileConditions/TileCablingService.h"
-
-class TileTBOldNtupleRead;
-class TileHWID;
-class TileInfo;
-class TileCondToolEmscale;
-
-class TileTBOldNtupleWrite : public AthAlgorithm {
-public:
-  TileTBOldNtupleWrite(std::string name, ISvcLocator* pSvcLocator);
-  virtual ~TileTBOldNtupleWrite();
-
-  StatusCode initialize();
-  StatusCode execute();
-  StatusCode finalize();
-
-private:
-
-  std::string m_ntupleID;
-  std::string m_ntupleDir;
-  std::string m_digitsContainer;
-  std::string m_rawChannelContainerFit;
-  std::string m_rawChannelContainerFlat;
-
-  bool m_bigain;
-  bool m_pmtOrder;
-  bool m_calibrateEnergy;
-  bool m_calibrateEnergyThisEvent;
-  
-  const TileHWID * m_tileHWID;
-  const TileCablingService * m_cabling;
-
-  ToolHandle<TileCondToolEmscale> m_tileToolEmscale; //!< main Tile Calibration tool
-
-  int m_runNumber;
-  int m_eventNumber;
-  int m_trigType;
-
-  TFile * m_file;
-  TTree * m_ntupleWrite;
-  TTree * m_ntupleRead;
-
-  TileTBOldNtupleRead * m_readNtupleAlg;
-
-  inline int digiChannel2PMT(int ros, int chan) {
-    return (abs(m_cabling->channel2hole(ros,chan))-1); 
-  }
-
-  Float_t * BranchWriteNtuple(const std::string name);
-
-  Float_t    m_ene[2][6][48];
-  Float_t   m_time[2][6][48];
-  Float_t   m_efit[2][6][48];
-  Float_t   m_tfit[2][6][48];
-  Float_t m_pedfit[2][6][48];
-  Float_t   m_chi2[2][6][48];
-};
-
-#endif
diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBStat.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBStat.h
index dc409476dcbcc403459798eed52734bbf6a6baac..73fb9cf8f0de79954f42f2ab8ef49b65d17de158 100755
--- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBStat.h
+++ b/TileCalorimeter/TileTBRec/TileTBRec/TileTBStat.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 //****************************************************************************
@@ -37,11 +37,13 @@
 
 // Athena incldues
 #include "AthenaBaseComps/AthAlgorithm.h"
+#include "StoreGate/ReadHandleKey.h"
+
+#include "TileEvent/TileDQstatus.h"
 
 class IROBDataProviderSvc;
 class TileID;
 class TileHWID;
-class TileBeamInfoProvider;
 class TileBeamElemContByteStreamCnv;
 
 #include <string>
@@ -78,9 +80,9 @@ class TileTBStat: public AthAlgorithm {
     virtual ~TileTBStat();
 
     //Gaudi Hooks
-    StatusCode initialize();
-    StatusCode execute();
-    StatusCode finalize();
+    virtual StatusCode initialize() override;
+    virtual StatusCode execute() override;
+    virtual StatusCode finalize() override;
 
   private:
 
@@ -90,11 +92,10 @@ class TileTBStat: public AthAlgorithm {
 
     bool m_printAllEvents;
     bool m_detectDummyFragments;
+    SG::ReadHandleKey<TileDQstatus> m_dqStatusKey;
 
     ServiceHandle<IROBDataProviderSvc> m_RobSvc;
 
-    ToolHandle<TileBeamInfoProvider> m_beamInfo;
-
     TileBeamElemContByteStreamCnv* m_beamCnv;
 
     int m_evtNr;
diff --git a/TileCalorimeter/TileTBRec/share/BeamNtuple_jobOptions.py b/TileCalorimeter/TileTBRec/share/BeamNtuple_jobOptions.py
deleted file mode 100755
index 33e9a3ef0cf13266a1e72db1132640688cd28a11..0000000000000000000000000000000000000000
--- a/TileCalorimeter/TileTBRec/share/BeamNtuple_jobOptions.py
+++ /dev/null
@@ -1,51 +0,0 @@
-#-------------------------------
-# Add beam elements to combined ntuple
-#-------------------------------
-
-# if not loaded - load these DLLs
-theApp.Dlls += [ "TileRecUtils", "TileTBRec" ]
-
-theApp.TopAlg += ["TileTBNtuple/BeamCrate"]
-BeamCrate = Algorithm( "BeamCrate" )
-
-BeamCrate.NTupleLoc = "/FILE1/TB"
-BeamCrate.NTupleID = "tree"
-
-BeamCrate.drawerList = [ ]
-
-BeamCrate.beamFragList = ["0x001","0x002","0x003","0x007",
-                          "0x010","0x011","0x012","0x013","0x014" ]
-
-BeamCrate.CompleteNtuple = FALSE
-BeamCrate.CommitNtuple = FALSE
-
-BeamCrate.BN2X1 =  0.522
-BeamCrate.BN2X2 =  0.175 
-BeamCrate.BN2Y1 =  1.44  
-BeamCrate.BN2Y2 =  0.173
-BeamCrate.BN2Z  =  1.0  
-
-BeamCrate.BN1X1 = -0.309
-BeamCrate.BN1X2 =  0.173 
-BeamCrate.BN1Y1 = -0.561
-BeamCrate.BN1Y2 =  0.175 
-BeamCrate.BN1Z  =  1.0  
-
-BeamCrate.BC0X1 = -0.111
-BeamCrate.BC0X2 =  0.185
-BeamCrate.BC0Y1 =  0.028
-BeamCrate.BC0Y2 =  0.181
-BeamCrate.BC0Z  =  1.0  
-
-BeamCrate.BC1X1 = -5.56 
-BeamCrate.BC1X2 =  0.183
-BeamCrate.BC1Y1 = -3.04 
-BeamCrate.BC1Y2 =  0.180 
-BeamCrate.BC1Z  =  15530.65  
-
-BeamCrate.BC2X1 = -2.22 
-BeamCrate.BC2X2 =  0.195  
-BeamCrate.BC2Y1 =  1.91 
-BeamCrate.BC2Y2 =  0.188  
-BeamCrate.BC2Z  =  11227.9  
-
diff --git a/TileCalorimeter/TileTBRec/share/TileTBNtuple_jobOptions.py b/TileCalorimeter/TileTBRec/share/TileTBNtuple_jobOptions.py
index a73c3b3f3f914aa323b18651736635850150be0d..43a918efd3e25c9b57ca88f1f10b311e9f61889a 100755
--- a/TileCalorimeter/TileTBRec/share/TileTBNtuple_jobOptions.py
+++ b/TileCalorimeter/TileTBRec/share/TileTBNtuple_jobOptions.py
@@ -42,6 +42,9 @@ TileTBNtuple.TileRawChannelContainerFit  = ""
 TileTBNtuple.TileRawChannelContainerFitCool  = ""
 TileTBNtuple.TileRawChannelContainerOpt  = ""
 
+#xxx TileDQstatusAlg.TileBeamElemContainer = 'TileBeamElemCnt'
+#xxx TileDQstatusAlg.TileDigitsContainer = 'TileDigitsCnt' if TBPeriod != 2017
+
 if doSim:
     theApp.Dlls += [ "TileRecUtils", "TileByteStream" ]
     TileTBNtuple.BSInput = FALSE
@@ -56,6 +59,8 @@ if doSim:
     # TileTBNtuple.TileRawChannelContainerFlat = "TileRawChannelCnt"
     TileTBNtuple.TileDigitsContainer = ""
     TileTBNtuple.TileBeamElemContainer = ""
+    #xxx TileDQstatusAlg.TileBeamElemContainer = ''
+    #xxx TileDQstatusAlg.TileDigitsContainer = '' if TBPeriod != 2017
     TileTBNtuple.TileLaserObject = ""
     if TileBarrelOnly:
         TileTBNtuple.drawerList = [ "0x200", "0x201", "0x202", "0x100", "0x101", "0x102" ]
diff --git a/TileCalorimeter/TileTBRec/share/jobOptions_TileTBNTuple.py b/TileCalorimeter/TileTBRec/share/jobOptions_TileTBNTuple.py
index 078c57dfa04b3071438917c09e452ba3bf61aa5a..e3fd82a52121f63a79625932e23bcd4a7b76feda 100644
--- a/TileCalorimeter/TileTBRec/share/jobOptions_TileTBNTuple.py
+++ b/TileCalorimeter/TileTBRec/share/jobOptions_TileTBNTuple.py
@@ -4,6 +4,8 @@
 # """This topOptions is intended to test the monitoring code"""
 #=================================================================
 
+#xxx configure TileDQstatusAlg
+
 from AthenaCommon.Logging import logging
 log_tbntuple = logging.getLogger( 'jobOptions_TileTBNtuple.py' )
 
@@ -116,6 +118,7 @@ if TileCisRun or TileMonoRun:
 
     # declare CIS tool(s) and set jobOptions if necessary
     TileCisTool = TileCisDefaultCalibTool()
+    # xxx set TileDQstatusAlg.TileRawChannelContainer="TileRawChannelCnt"
 
     if hasattr(ToolSvc, 'TileDigitsMon'):
         TileCisTool.StuckBitsProbsTool = ToolSvc.TileDigitsMon
diff --git a/TileCalorimeter/TileTBRec/src/TileTBAANtuple.cxx b/TileCalorimeter/TileTBRec/src/TileTBAANtuple.cxx
index 74bc40415bfb3185e67bf6983a8720535a2bcbcf..3c84692749ec936109c7073c14b0ce5bbb25ce60 100755
--- a/TileCalorimeter/TileTBRec/src/TileTBAANtuple.cxx
+++ b/TileCalorimeter/TileTBRec/src/TileTBAANtuple.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 //*****************************************************************************
@@ -43,7 +43,6 @@
 #include "TileEvent/TileRawChannelContainer.h"
 #include "TileEvent/TileLaserObject.h"
 #include "TileRecUtils/TileRawChannelBuilderFlatFilter.h"
-#include "TileRecUtils/TileBeamInfoProvider.h"
 #include "TileByteStream/TileBeamElemContByteStreamCnv.h"
 #include "TileByteStream/TileLaserObjByteStreamCnv.h"
 #include "TileEvent/TileHitContainer.h"
@@ -228,7 +227,6 @@ TileTBAANtuple::TileTBAANtuple(std::string name, ISvcLocator* pSvcLocator)
   , m_tileInfo(0)
   , m_cabling(0)
   , m_tileToolEmscale("TileCondToolEmscale")
-  , m_beamInfo("TileBeamInfoProvider/TileBeamInfoProvider")
   , m_beamCnv(0)
   , m_currentFileNum(0)
   , m_eventsPerFile(0)
@@ -384,13 +382,7 @@ StatusCode TileTBAANtuple::ntuple_initialize() {
   //=== get TileCondToolEmscale
   CHECK( m_tileToolEmscale.retrieve() );
 
-  CHECK( m_beamInfo.retrieve() );
-
-  CHECK( m_beamInfo->setProperty("TileBeamElemContainer", m_beamElemContainer) );
-
   if (m_TBperiod != 2017)
-    CHECK( m_beamInfo->setProperty("TileDigitsContainer", m_digitsContainer) );
-
   if (m_TBperiod >= 2015)  {
     m_unpackAdder = false;
 
diff --git a/TileCalorimeter/TileTBRec/src/TileTBNtuple.cxx b/TileCalorimeter/TileTBRec/src/TileTBNtuple.cxx
deleted file mode 100755
index a48b03963c7b79ab5f76c27dba3204ce6c165015..0000000000000000000000000000000000000000
--- a/TileCalorimeter/TileTBRec/src/TileTBNtuple.cxx
+++ /dev/null
@@ -1,2070 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-//*****************************************************************************
-//  Filename : TileTBNtuple.cxx
-//  Author   : Paulo da Silva
-//  Created  : Oct, 2003
-//
-//  DESCRIPTION:
-//     Implement the algorithm to save TB Beam ROD dataX
-//
-//  HISTORY:
-//
-//  BUGS:
-//
-//*****************************************************************************
-
-// Athena includes
-# include "AthenaKernel/errorcheck.h"
-
-//Event info
-#include "xAODEventInfo/EventInfo.h"
- 
-#include "PathResolver/PathResolver.h"
-#include <cmath>
-
-//Calo includes
-#include "CaloIdentifier/CaloCell_ID.h"
-#include "CaloEvent/CaloCellContainer.h"
-#include "CaloIdentifier/CaloID.h"
-
-//TileCalo includes
-#include "CaloIdentifier/TileID.h"
-#include "TileIdentifier/TileHWID.h"
-#include "TileIdentifier/TileTBFrag.h"
-#include "TileCalibBlobObjs/TileCalibUtils.h"
-#include "TileConditions/TileCablingService.h"
-#include "TileConditions/TileCondToolEmscale.h"
-#include "TileEvent/TileDigitsContainer.h"
-#include "TileEvent/TileBeamElemContainer.h"
-#include "TileEvent/TileRawChannelContainer.h"
-#include "TileRecUtils/TileRawChannelBuilderFlatFilter.h"
-#include "TileRecUtils/TileBeamInfoProvider.h"
-#include "TileByteStream/TileBeamElemContByteStreamCnv.h"
-#include "TileTBRec/TileTBNtuple.h"
-
-#include <fstream>
-
-#define WRONG_SAMPLE(frag,chan,size)                                  \
-msg(MSG::ERROR) << "Wrong no. of samples (" << size                   \
-                << ") for channel " << chan                           \
-                << " in frag 0x" << MSG::hex << frag << MSG::dec      \
-                << " - " << BeamFragName[frag&0x1F] << endmsg;
-
-#define WRONG_CHANNEL(frag,chan)                                      \
-msg(MSG::ERROR) << "Wrong channel " << chan                           \
-                << " in frag 0x" << MSG::hex << frag << MSG::dec      \
-                << " - " << BeamFragName[frag&0x1F] << endmsg;
-
-#define FRAG_FOUND(frag,chan,size)                                    \
-if (msgLvl(MSG::DEBUG))                                               \
-  msg(MSG::DEBUG) << "Found channel " << chan                         \
-                  << " in frag 0x" << MSG::hex << frag << MSG::dec    \
-                  << " - " << BeamFragName[frag&0x1F]                 \
-                  << " of size " << size << endmsg;
-
-
-#define SIGNAL_FOUND(frag,chan,amplitude)                             \
-if (msgLvl(MSG::DEBUG))                                               \
-  msg(MSG::DEBUG) << "Found channel " << chan                         \
-                  << " in frag 0x" << MSG::hex << frag << MSG::dec    \
-                  << " - " << BeamFragName[frag&0x1F]                 \
-                  << " with amp=" << amplitude << endmsg;
-
-// Constructor & deconstructor
-/// OBSLETE CLASS: Please, use TileTBAANtuple for rel > 13.0.30.
-// Constructor & deconstructor
-/** @class TileTBNtuple
- *  @brief Obsolete class to produce commissioning ntuples. use TileTBAANtuple for rel > 13.0.30.
- */
-TileTBNtuple::TileTBNtuple(std::string name, ISvcLocator* pSvcLocator)
-  : AthAlgorithm(name, pSvcLocator)
-  , m_calibMode(false)
-  , m_ntuplePtr(0)
-  , m_ntupleCreated(false)
-  , m_evtNr(0)
-  , m_beamBN2X1(0.0F)
-  , m_beamBN2X2(0.0F)
-  , m_beamBN2Y1(0.0F)
-  , m_beamBN2Y2(0.0F)
-  , m_beamBN2Z(0.0F)
-  , m_beamBN1X1(0.0F)
-  , m_beamBN1X2(0.0F)
-  , m_beamBN1Y1(0.0F)
-  , m_beamBN1Y2(0.0F)
-  , m_beamBN1Z(0.0F)
-  , m_beamBC0X1(0.0F)
-  , m_beamBC0X2(0.0F)
-  , m_beamBC0Y1(0.0F)
-  , m_beamBC0Y2(0.0F)
-  , m_beamBC0Z(0.0F)
-  , m_beamBC1X1(0.0F)
-  , m_beamBC1X2(0.0F)
-  , m_beamBC1Y1(0.0F)
-  , m_beamBC1Y2(0.0F)
-  , m_beamBC1Z(0.0F)
-  , m_beamBC2X1(0.0F)
-  , m_beamBC2X2(0.0F)
-  , m_beamBC2Y1(0.0F)
-  , m_beamBC2Y2(0.0F)
-  , m_beamBC2Z(0.0F)
-  , m_beamBC2Zperiod1(0.0F)
-  , m_beamBC2Zperiod2(0.0F)
-  , m_runNumber(0)
-  , m_eta(0.0F)
-  , m_theta(0.0F)
-  , m_radius(0.0F)
-  , m_calibrateEnergyThisEvent(false)
-  , m_calibrateEnergy(false)
-  , m_useDspUnits(false)
-  , m_unpackAdder(false)
-  , m_completeNtuple(false)
-  , m_commitNtuple(false)
-  , m_bsInput(false)
-  , m_finalUnit(0)
-  , m_treeSize(0)
-  , m_nSamples(0)
-  , m_nDrawers(0)
-  , m_adderFilterAlgTool("TileRawChannelBuilderFlatFilter/TileAdderFlatFilter",this)
-  , m_tileID(0)
-  , m_tileHWID(0)
-  , m_cabling(0)
-  , m_tileToolEmscale("TileCondToolEmscale")
-  , m_beamInfo("TileBeamInfoProvider/TileBeamInfoProvider")
-  , m_beamCnv(0)
-  , m_currentFileNum(0)
-{
-  declareProperty("TileCondToolEmscale", m_tileToolEmscale);
-  declareProperty("TileDigitsContainer", m_digitsContainer = "TileDigitsCnt");    
-  declareProperty("TileBeamElemContainer", m_beamElemContainer = "TileBeamElemCnt");
-  declareProperty("TileRawChannelContainerFlat", m_flatRawChannelContainer = "TileRawChannelFlat");
-  declareProperty("TileLaserObject", m_laserObject = "");
-  declareProperty("TileRawChannelContainerFit", m_fitRawChannelContainer = ""); // don't create
-  declareProperty("TileRawChannelContainerFitCool", m_fitcRawChannelContainer = ""); // don't create
-  declareProperty("TileRawChannelContainerOpt", m_optRawChannelContainer = ""); // by default
-  declareProperty("TileRawChannelContainerDsp", m_dspRawChannelContainer = ""); //
-  declareProperty("CalibrateEnergy", m_calibrateEnergy = true);
-  declareProperty("UseDspUnits", m_useDspUnits = false);
-  declareProperty("OfflineUnits", m_finalUnit = 4);
-  declareProperty("CalibMode", m_calibMode = false);  
-  declareProperty("UnpackAdder", m_unpackAdder = false);  
-  declareProperty("CompleteNtuple", m_completeNtuple = true);  
-  declareProperty("CommitNtuple", m_commitNtuple = true);
-  declareProperty("BSInput", m_bsInput = true);
-    
-  declareProperty("NTupleLoc", m_ntupleLoc = "/NTUPLES/FILE%d/TileRec");
-  declareProperty("NTupleID", m_ntupleID = "h1000");
-  declareProperty("TreeSize", m_treeSize = 16000000000LL); // dummy
-
-  declareProperty("NSamples", m_nSamples = 9);
-  declareProperty("NDrawers", m_nDrawers = 6);
-
-  declareProperty("EventsPerFile", m_eventsPerFile = 200000);
-  declareProperty("StreamName", m_streamName = ""); // dummy
-
-//  m_drawerList.resize(6);    m_drawerType.resize(6);
-//  m_drawerList[0] = "0x200"; m_drawerType[0] = 2; // barrel neg
-//  m_drawerList[1] = "0x201"; m_drawerType[1] = 2; // barrel neg
-//  m_drawerList[2] = "0x202"; m_drawerType[2] = 4; // ext barrel neg
-//  m_drawerList[3] = "0x100"; m_drawerType[3] = 1; // barrel pos
-//  m_drawerList[4] = "0x101"; m_drawerType[4] = 1; // barrel pos
-//  m_drawerList[5] = "0x102"; m_drawerType[5] = 3; // ext barrel pos
-
-  m_drawerList.resize(1);  m_drawerList[0] = "-1"; // setup drawer list from data
-  m_drawerType.clear();    // take drawer type from Frag ID (doesn't work for 2003)
-  m_drawerMap.clear();     // for 2003 need to use mapping given above
-
-  char frg[6] = "0x000";
-  m_beamFragList.clear();
-  for (unsigned int i = 0; i < sizeof(m_beamIdList) / sizeof(bool); ++i) {
-    m_beamIdList[i] = false;
-    // no coins trig by default (this is the case for 2004)
-    if (i <= ECAL_ADC_FRAG || i >= COMMON_ADC1_FRAG) {
-      sprintf(frg, "0x%3.3x", i);
-      m_beamFragList.push_back((std::string) frg);
-    }
-  }
-
-  m_rosName.push_back("B"); // 0 - this is beam rod name
-  m_rosName.push_back("A"); m_rosName.push_back("C");
-  m_rosName.push_back("D"); m_rosName.push_back("E");
-
-  declareProperty("rosName", m_rosName);
-  declareProperty("drawerList", m_drawerList);
-  declareProperty("drawerType", m_drawerType);  
-  declareProperty("beamFragList", m_beamFragList);
-
-  declareProperty("BN2X1",m_beamBN2X1 = 0.0);
-  declareProperty("BN2X2",m_beamBN2X2 = 0.2);
-  declareProperty("BN2Y1",m_beamBN2Y1 = 0.0);
-  declareProperty("BN2Y2",m_beamBN2Y2 = 0.2);
-  declareProperty("BN2Z", m_beamBN2Z  = 1.0);
-
-  declareProperty("BN1X1",m_beamBN1X1 = 0.0);
-  declareProperty("BN1X2",m_beamBN1X2 = 0.2);
-  declareProperty("BN1Y1",m_beamBN1Y1 = 0.0);
-  declareProperty("BN1Y2",m_beamBN1Y2 = 0.2);
-  declareProperty("BN1Z", m_beamBN1Z  = 1.0);
-
-  declareProperty("BC0X1",m_beamBC0X1 = 0.0);
-  declareProperty("BC0X2",m_beamBC0X2 = 0.2);
-  declareProperty("BC0Y1",m_beamBC0Y1 = 0.0);
-  declareProperty("BC0Y2",m_beamBC0Y2 = 0.2);
-  declareProperty("BC0Z", m_beamBC0Z  = 17138.0);
-
-  declareProperty("BC1X1",m_beamBC1X1 =-0.938);
-  declareProperty("BC1X2",m_beamBC1X2 = 0.1747);
-  declareProperty("BC1Y1",m_beamBC1Y1 = 0.125);
-  declareProperty("BC1Y2",m_beamBC1Y2 = 0.1765);
-  declareProperty("BC1Z", m_beamBC1Z  = 13788.0);
-  
-  declareProperty("BC2X1",m_beamBC2X1 =-0.9369);
-  declareProperty("BC2X2",m_beamBC2X2 = 0.191);
-  declareProperty("BC2Y1",m_beamBC2Y1 =-1.29);
-  declareProperty("BC2Y2",m_beamBC2Y2 = 0.187);
-  declareProperty("BC2Z", m_beamBC2Z  = 9411.0);
-
-  // for CTB 2004 only
-  declareProperty("BC2Zperiod1", m_beamBC2Zperiod1 = 9411.0);
-  declareProperty("BC2Zperiod2", m_beamBC2Zperiod2 = 12188.0);
-
-  declareProperty("Radius", m_radius = 2280.0);
-  declareProperty("EtaFileName", m_etaFileName = "TileEtaCTB.txt");
-
-  m_eta=0.0;
-  m_theta=0.0;
-  m_runNumber=0;
-}
-
-
-TileTBNtuple::~TileTBNtuple() {
-}
-
-// Alg standard interface function
-StatusCode TileTBNtuple::initialize() {
-
-  // find TileCablingService
-  m_cabling = TileCablingService::getInstance();
-
-  // retrieve TileID helper from det store
-
-  CHECK( detStore()->retrieve(m_tileID) );
-
-  CHECK( detStore()->retrieve(m_tileHWID) );
-
-  //=== get TileCondToolEmscale
-  CHECK( m_tileToolEmscale.retrieve() );
-
-  CHECK( m_beamInfo.retrieve() );
-
-  CHECK( m_beamInfo->setProperty("TileBeamElemContainer", m_beamElemContainer) );
-  CHECK( m_beamInfo->setProperty("TileDigitsContainer", m_digitsContainer) );
-
-  if (m_unpackAdder) {
-    // get TileRawChannelBuilderFlatFilter for adder energy calculation
-    CHECK( m_adderFilterAlgTool.retrieve() );
-
-    m_adderFilterAlgTool->setProperty("TileRawChannelContainer", "TileAdderFlat");
-    m_adderFilterAlgTool->setProperty("calibrateEnergy", "true");
-
-    m_adderFilterAlgTool->setProperty("PedStart", "0");
-    m_adderFilterAlgTool->setProperty("PedLength", "1");
-    m_adderFilterAlgTool->setProperty("PedOffset", "0");
-    m_adderFilterAlgTool->setProperty("SignalStart", "1");
-    m_adderFilterAlgTool->setProperty("SignalLength", "15");
-    m_adderFilterAlgTool->setProperty("FilterLength", "5");
-    m_adderFilterAlgTool->setProperty("FrameLength", "16");
-    m_adderFilterAlgTool->setProperty("DeltaCutLo", "9.5");
-    m_adderFilterAlgTool->setProperty("DeltaCutHi", "9.5");
-    m_adderFilterAlgTool->setProperty("RMSCutLo", "1.0");
-    m_adderFilterAlgTool->setProperty("RMSCutHi", "1.0");
-
-  }
-
-  ATH_MSG_INFO( "calibMode " << m_calibMode );
-  ATH_MSG_INFO( "calibrateEnergy " << m_calibrateEnergy );
-  ATH_MSG_INFO( "number of samples " << m_nSamples );
-
-
-  msg(MSG::INFO) << "drawerList " << MSG::hex;
-  unsigned int size = m_drawerList.size();
-  for (unsigned int dr = 0; dr < size; ++dr) {
-    int frag = strtol(m_drawerList[dr].data(), NULL, 0);
-    if (frag >= 0) {
-      m_drawerMap[frag] = dr;
-      if (dr == m_drawerType.size()) m_drawerType.push_back(frag >> 8);
-      msg(MSG::INFO) << " 0x" << frag;
-    } else {
-      msg(MSG::INFO) << " " << m_drawerList[dr];
-      // put negative number in first element (flag to read frag ID from data)
-      m_drawerList[0] = m_drawerList[dr];
-      m_drawerList.resize(1);
-      // m_drawerType.clear();
-      m_drawerMap.clear();
-      size = 0;
-      break;
-    }
-  }
-
-  if (size == 0) {
-    if (m_drawerList.size() > 0)
-      msg(MSG::INFO) << " - negative number, will read frag IDs from the data" << MSG::dec << endmsg;
-    else
-      msg(MSG::INFO) << "is empty, no drawer fragments in ntuple" << MSG::dec << endmsg;
-  } else {
-    msg(MSG::INFO) << MSG::dec << endmsg;
-
-    size = m_drawerType.size();
-    if (size < m_nDrawers) {
-      m_drawerType.resize(m_nDrawers);
-      for (; size < m_nDrawers; ++size)
-        m_drawerType[size] = 0;
-    }
-
-    msg(MSG::INFO) << "drawerType ";
-    for (unsigned int dr = 0; dr < size; ++dr)
-      msg(MSG::INFO) << " " << m_drawerType[dr];
-    msg(MSG::INFO) << endmsg;
-
-    if (size > m_nDrawers) {
-      ATH_MSG_INFO( "increasing m_nDrawers from " << m_nDrawers << " to " << size );
-      m_nDrawers = size;
-    }
-
-  }
-
-  msg(MSG::INFO) << "Beam Frag List " << MSG::hex;
-  size = m_beamFragList.size();
-  for (unsigned int dr = 0; dr < size; ++dr) {
-    int frag = strtol(m_beamFragList[dr].data(), NULL, 0);
-    if (frag >= 0) {
-      m_beamIdList[frag & 0x1F] = true;
-      msg(MSG::INFO) << " 0x" << frag;
-    }
-  }
-
-  if (size == 0) {
-    msg(MSG::INFO) << "is empty, no beam fragments in ntuple" << MSG::dec << endmsg;
-  } else {
-    msg(MSG::INFO) << MSG::dec << endmsg;
-  }
-
-  // set event number to 0 before first event
-  m_evtNr = 0;
-  m_currentFileNum = 0;
-
-  m_calibrateEnergyThisEvent = m_calibrateEnergy;
-
-  if (connectFile().isFailure()) {
-    ATH_MSG_ERROR( " Can't open file for Ntuple " );
-  }
-
-  ATH_MSG_INFO( "initialization completed" );
-
-  return StatusCode::SUCCESS;
-}
-
-StatusCode TileTBNtuple::execute() {
-
-  if (m_evtNr % 1000 == 0)
-    ATH_MSG_INFO( m_evtNr << " events processed so far" );
-
-  if (m_eventsPerFile > 0 && m_evtNr % m_eventsPerFile == 0 && m_evtNr > 0) {
-    ATH_MSG_INFO( "Booking ntuple in new file" );
-
-    if (connectFile().isFailure()) {
-      ATH_MSG_ERROR( " Can't open file for Ntuple " );
-    } else if (!m_ntupleCreated) {
-      if (initNTuple().isFailure()) {
-        ATH_MSG_ERROR( " Error during ntuple initialization" );
-      }
-    }
-  }
-
-  /// find event and beam ROD header, calib mode for digitizers
-
-  /// if first event: determine mode (normal or calib)
-  /// by examining the first TileDigitCollection
-  /// initialize NTuple accordingly
-  if (m_evtNr == 0) {
-
-    if (m_bsInput) {
-      ServiceHandle<IConversionSvc> cnvSvc("ByteStreamCnvSvc", "");
-      if (cnvSvc.retrieve().isFailure()) {
-        ATH_MSG_ERROR( " Can't get ByteStreamCnvSvc " );
-        m_beamCnv = NULL;
-      } else {
-
-        m_beamCnv = dynamic_cast<TileBeamElemContByteStreamCnv *>(cnvSvc->converter(ClassID_traits<TileBeamElemContainer>::ID()));
-
-        if (m_beamCnv == NULL) {
-          ATH_MSG_ERROR( " Can't get TileBeamElemContByteStreamCnv " );
-        }
-      }
-    } else {
-      m_beamCnv = NULL;
-    }
-
-    if (!m_ntupleCreated) {
-
-      bool calibMode = (m_beamInfo->calibMode() == 1);
-      if (calibMode != m_calibMode) {
-        ATH_MSG_INFO( "Calib mode from data is " );
-        ATH_MSG_INFO( "  Overwriting calib mode " );
-        m_calibMode = calibMode;
-      }
-
-      if (initList().isFailure()) {
-        ATH_MSG_ERROR( " Error during drawer list initialization" );
-      }
-
-      if (initNTuple().isFailure()) {
-        ATH_MSG_ERROR( " Error during ntuple initialization" );
-      }
-    }
-
-    if (m_unpackAdder) // in 2003 event number starts from 1
-      ++m_evtNr;
-  }
-
-  // store BeamElements
-  bool empty = storeBeamElements().isFailure();
-
-  if (m_drawerMap.size() > 0) {
-
-    // store TileDigits
-    if (m_nSamples > 0) {
-      empty &= (storeDigits().isFailure());
-    }
-
-    // store TileRawChannels
-    empty &= (storeRawChannels(m_fitRawChannelContainer, &m_efitVec, &m_tfitVec, &m_chi2Vec, &m_pedfitVec).isFailure());
-    empty &= (storeRawChannels(m_flatRawChannelContainer, &m_eneVec, &m_timeVec, 0, 0).isFailure());
-    empty &= (storeRawChannels(m_optRawChannelContainer, &m_eOptVec, &m_tOptVec, &m_chi2OptVec, &m_pedOptVec).isFailure());
-    empty &= (storeRawChannels(m_dspRawChannelContainer, &m_eDspVec, &m_tDspVec, &m_chi2DspVec, 0).isFailure());
-  }
-
-  if (m_completeNtuple) {
-    // store energy per sampling from all calorimeters
-    empty &= (storeCells().isFailure());
-  }
-
-  if (m_beamCnv) {
-    m_evTime = m_beamCnv->eventFragment()->bc_time_seconds();
-    m_evt = m_beamCnv->eventFragment()->global_id();
-    // m_runNo = m_beamCnv->eventFragment()->run_no();  // run_no is 0 here
-    if (m_beamCnv->validBeamFrag())
-      m_run = m_beamCnv->robFragment()->rod_run_no();   // take it from beam ROD header
-    else
-      m_run = 0;
-  } else {
-    m_evTime = 0;
-    m_evt = m_evtNr;
-    m_run = 0;
-  }
-
-  if (m_commitNtuple) {
-    /// Commit ntuple if collections are nonempty
-    /// or we share ntuple with somebody else and have to commit in any case
-    if (!empty || m_ntupleCreated) {
-      ATH_MSG_DEBUG( "Commiting Ntuple" );
-      CHECK( ntupleSvc()->writeRecord(m_ntuplePtr) );
-    } else
-      ATH_MSG_DEBUG( "No data stored for event " << m_evtNr << ", collections are empty" );
-  }
-  /// increase event nr
-  /// this number can be different from real event number if we skip events
-  ++m_evtNr;
-
-  // Execution completed.
-  ATH_MSG_DEBUG( "execute() completed successfully" );
-
-  return StatusCode::SUCCESS;
-}
-
-StatusCode TileTBNtuple::storeBeamElements() {
-
-
-  if (m_beamElemContainer.size() == 0) return StatusCode::SUCCESS;
-
-  const TileBeamElemContainer* BeamElemCnt;
-  CHECK( evtStore()->retrieve(BeamElemCnt, m_beamElemContainer) );
-
-  TileBeamElemContainer::const_iterator collItr = BeamElemCnt->begin();
-  TileBeamElemContainer::const_iterator lastColl = BeamElemCnt->end();
-
-  if (m_completeNtuple) {
-    // Store ROD header info from collection (just from first one)
-    if (collItr != lastColl) {
-      m_l1ID[m_nDrawers] = (*collItr)->getLvl1Id();
-      m_l1Type[m_nDrawers] = (*collItr)->getLvl1Type();
-      m_evType[m_nDrawers] = (*collItr)->getDetEvType();
-      m_evBCID[m_nDrawers] = (*collItr)->getRODBCID();
-    } else {
-      m_l1ID[m_nDrawers] = 0xFFFFFFFF;
-      m_l1Type[m_nDrawers] = 0xFFFFFFFF;
-      m_evType[m_nDrawers] = 0xFFFFFFFF;
-      m_evBCID[m_nDrawers] = 0xFFFFFFFF;
-    }
-  }
-
-  m_trigType = 0;
-
-  for (; collItr != lastColl; ++collItr) {
-
-    TileBeamElemCollection::const_iterator beamItr = (*collItr)->begin();
-    TileBeamElemCollection::const_iterator lastBeam = (*collItr)->end();
-
-    if (msgLvl(MSG::VERBOSE)) {
-
-      for (; beamItr != lastBeam; ++beamItr) {
-        HWIdentifier id = (*beamItr)->adc_HWID();
-        std::vector<uint32_t> digits = (*beamItr)->get_digits();
-        msg(MSG::VERBOSE) << " --- TileBeamElem -- Identifier " << m_tileHWID->to_string(id) << " "
-                          << (*beamItr)->get_digits().size() << " " << digits.size() << endmsg;
-
-        msg(MSG::VERBOSE) << MSG::VERBOSE << " --- TileBeamElem -- BeamElem : " << MSG::dec;
-        for (unsigned int k = 0; k < digits.size(); k++)
-          msg(MSG::VERBOSE) << digits[k] << " ";
-        msg(MSG::VERBOSE) << endmsg;
-      }
-
-      //restore iterator
-      beamItr = (*collItr)->begin();
-    }
-  
-    int frag = (*collItr)->identify();
-    ATH_MSG_DEBUG( " frag: " << frag );
-    ATH_MSG_DEBUG( " trigType " << (*collItr)->getLvl1Type() );
-    
-    if ( m_trigType == 0 && (*collItr)->getLvl1Type() != 0 ) // take it from the ROD header
-      m_trigType = (*collItr)->getLvl1Type();
-
-    // unpack only fragments which we want to store in ntuple
-    if (m_beamIdList[frag & 0x1F]) {
-
-      for (; beamItr != lastBeam; ++beamItr) {
-
-        HWIdentifier id = (*beamItr)->adc_HWID();
-        std::vector<uint32_t> digits = (*beamItr)->get_digits();
-        int cha = m_tileHWID->channel(id);
-        int dsize = digits.size();
-
-        if (dsize <= 0) {
-
-          WRONG_SAMPLE(frag, cha, dsize);
-
-        } else if (dsize != 16 && frag == ADD_FADC_FRAG) {
-
-          WRONG_SAMPLE(frag, cha, dsize);
-
-        } else if (dsize != 1 && frag != ADD_FADC_FRAG
-                    && frag != BEAM_TDC_FRAG && frag != COMMON_TDC1_FRAG
-                    && frag != COMMON_TOF_FRAG && frag != COMMON_TDC2_FRAG) {
-
-          WRONG_SAMPLE(frag, cha, dsize);
-
-        } else {
-
-          int amplitude = digits[0];
-          SIGNAL_FOUND(frag, cha, amplitude);
-
-          switch (frag) {
-
-            case BEAM_TDC_FRAG:
-
-              FRAG_FOUND(frag, cha, dsize);
-              if (cha < 8) m_btdc1[cha] = amplitude;
-              else if (cha < 16) m_btdc2[cha - 8] = amplitude;
-              else  WRONG_CHANNEL(frag, cha);
-              break;
-
-            case BEAM_ADC_FRAG:
-
-              if (m_unpackAdder) {
-                switch (cha) {
-                  // BEAM
-                  case 0:
-                    m_s1cou = amplitude;
-                    break;
-                  case 1:
-                    m_s2cou = amplitude;
-                    break;
-                  case 2:
-                    m_s3cou = amplitude;
-                    break;
-                  case 3:
-                    m_cher1 = amplitude;
-                    break; // swap of Cher1
-                  case 4:
-                    m_muTag = amplitude;
-                    break; // and S4 in 2003 data
-                  case 5:
-                    m_cher2 = amplitude;
-                    break;
-                  case 6:
-                    m_muHalo = amplitude;
-                    break;
-                  case 7:
-                    m_muVeto = amplitude;
-                    break;
-                    // LASER
-                  case 8:
-                    m_las0 = amplitude;
-                    break;
-                  case 9:
-                    m_las1 = amplitude;
-                    break;
-                  case 10:
-                    m_las2 = amplitude;
-                    break;
-                  case 11:
-                    m_las3 = amplitude;
-                    break;
-                  case 12:
-                    m_lasExtra[0] = amplitude;
-                    break;
-                  case 13:
-                    m_lasExtra[1] = amplitude;
-                    break;
-                  case 14:
-                    m_lasExtra[2] = amplitude;
-                    break;
-                  case 15:
-                    m_lasExtra[3] = amplitude;
-                    break;
-                  default:
-                    WRONG_CHANNEL(frag, cha);
-                }
-              } else { // 2004 data
-                switch (cha) {
-                  // BEAM
-                  case 0:
-                    m_sc1 = amplitude;
-                    break;
-                  case 1:
-                    m_sc2 = amplitude;
-                    break;
-                  case 2:
-                  case 3:
-                  case 4:
-                  case 5:
-                  case 6:
-                  case 7:
-                    break;
-                  default:
-                    WRONG_CHANNEL(frag, cha);
-                }
-              }
-              break;
-
-            case MUON_ADC_FRAG:
-
-              // first 14 are m_muBack
-              if (cha < 14) m_muBack[cha] = amplitude;
-              // last 2 are m_muCalib
-              else if (cha < 16) m_muCalib[cha - 14] = amplitude;
-              else  WRONG_CHANNEL(frag, cha);
-              break;
-
-            case ADDR_ADC_FRAG:
-
-              // second half of Muon Wall in 2004
-              if (cha < 6) m_muBack[cha + 8] = amplitude;
-              // last 2 are m_muCalib
-              else if (cha < 8) m_muCalib[cha - 6] = amplitude;
-              else WRONG_CHANNEL(frag, cha);
-              break;
-
-            case LASE_PTN_FRAG:
-
-              if (cha == 0) {
-                // laser pattern unit
-                m_lasFlag = amplitude;
-                if (amplitude & 0xFF00) m_trigType = amplitude >> 8;
-              } else {
-                WRONG_CHANNEL(frag, cha);
-              }
-              break;
-
-            case LASE_ADC_FRAG:
-
-              // laser in 2004
-              switch (cha) {
-                case 0:
-                  m_las0 = amplitude;
-                  break;
-                case 1:
-                  m_las1 = amplitude;
-                  break;
-                case 2:
-                  m_las2 = amplitude;
-                  break;
-                case 3:
-                  m_las3 = amplitude;
-                  break;
-                case 4:
-                  m_lasExtra[0] = amplitude;
-                  break;
-                case 5:
-                  m_lasExtra[1] = amplitude;
-                  break;
-                case 6:
-                  m_lasExtra[2] = amplitude;
-                  break;
-                case 7:
-                  m_lasExtra[3] = amplitude;
-                  break;
-                default:
-                  WRONG_CHANNEL(frag, cha);
-              }
-              break;
-
-            case ADD_FADC_FRAG:
-
-              if (m_unpackAdder) {
-
-                for (int k = 0; k < dsize; k++) {
-                  //m_addx[k]=k;
-                  m_adder[cha][k] = digits[k];
-                }
-                // FlatFiler adders
-                double ene, tim;
-                m_adderFilterAlgTool->flatFilter(digits, 0, ene, tim);
-                m_eneAdd[cha] = ene;
-                m_timeAdd[cha] = tim;
-              }
-              break;
-
-            case ECAL_ADC_FRAG:
-
-              if (cha < 8)
-                m_ecal[cha] = amplitude;
-              else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case DIGI_PAR_FRAG:
-
-              if (cha < 16)
-                m_cispar[cha] = amplitude;
-              else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COMMON_ADC1_FRAG:
-
-              switch (cha) {
-                // BEAM
-                case 0:
-                  m_s1cou = amplitude;
-                  break;
-                case 1:
-                  m_s2cou = amplitude;
-                  break;
-                case 2:
-                  m_s3cou = amplitude;
-                  break;
-                case 3:
-                  m_muTag = amplitude;
-                  break;
-                case 4:
-                  m_cher1 = amplitude;
-                  break;
-                case 5:
-                  m_cher2 = amplitude;
-                  break;
-                case 6:
-                  m_muHalo = amplitude;
-                  break;
-                case 7:
-                  m_muVeto = amplitude;
-                  break;
-                default:
-                  WRONG_CHANNEL(frag, cha);
-              }
-              break;
-
-            case COMMON_ADC2_FRAG:
-
-              if (!m_unpackAdder) {
-                switch (cha) {
-                  // BEAM
-                  case 0:
-                    break;
-                  case 1:
-                    m_s2extra = amplitude;
-                    break;
-                  case 2:
-                    m_s3extra = amplitude;
-                    break;
-                  case 3:
-                  case 4:
-                  case 5:
-                  case 6:
-                  case 7:
-                    break;
-                  default:
-                    WRONG_CHANNEL(frag, cha);
-                }
-              }
-              break;
-
-            case COMMON_PTN_FRAG:
-
-              if (cha == 0)
-                m_commonPU = amplitude;
-              else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COMMON_TOF_FRAG:
-
-              if (cha < 8)
-                m_tof[cha] = amplitude;
-              else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COMMON_TDC1_FRAG:
-
-              FRAG_FOUND(frag, cha, dsize);
-              if (cha < 16) m_btdc1[cha] = amplitude;
-              else WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COMMON_TDC2_FRAG:
-
-              FRAG_FOUND(frag, cha, dsize);
-              if (cha < 16) m_btdc2[cha] = amplitude;
-              else WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COIN_TRIG1_FRAG:
-
-              if (cha < 3) {
-                int idx = cha * 32;
-                for (int ibit = 0; ibit < 32; ++ibit) {
-                  m_coincTrig1[idx++] = (amplitude >> ibit) & 1;
-                }
-              } else if (cha == 3) {
-                m_coincFlag1 = amplitude;
-              } else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COIN_TRIG2_FRAG:
-
-              if (cha < 3) {
-                int idx = cha * 32;
-                for (int ibit = 0; ibit < 32; ++ibit) {
-                  m_coincTrig2[idx++] = (amplitude >> ibit) & 1;
-                }
-              } else if (cha == 3) {
-                m_coincFlag2 = amplitude;
-              } else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COIN_TRIG3_FRAG:
-
-              if (cha < 3) {
-                int idx = cha * 32;
-                for (int ibit = 0; ibit < 32; ++ibit) {
-                  m_coincTrig3[idx++] = (amplitude >> ibit) & 1;
-                }
-              } else if (cha == 3) {
-                m_coincFlag3 = amplitude;
-              } else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COIN_TRIG4_FRAG:
-
-              if (cha < 3) {
-                int idx = cha * 32;
-                for (int ibit = 0; ibit < 32; ++ibit) {
-                  m_coincTrig4[idx++] = (amplitude >> ibit) & 1;
-                }
-              } else if (cha == 3) {
-                m_coincFlag4 = amplitude;
-              } else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COIN_TRIG5_FRAG:
-
-              if (cha < 3) {
-                int idx = cha * 32;
-                for (int ibit = 0; ibit < 32; ++ibit) {
-                  m_coincTrig5[idx++] = (amplitude >> ibit) & 1;
-                }
-              } else if (cha == 3) {
-                m_coincFlag5 = amplitude;
-              } else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COIN_TRIG6_FRAG:
-
-              if (cha < 3) {
-                int idx = cha * 32;
-                for (int ibit = 0; ibit < 32; ++ibit) {
-                  m_coincTrig6[idx++] = (amplitude >> ibit) & 1;
-                }
-              } else if (cha == 3) {
-                m_coincFlag6 = amplitude;
-              } else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COIN_TRIG7_FRAG:
-
-              if (cha < 3) {
-                int idx = cha * 32;
-                for (int ibit = 0; ibit < 32; ++ibit) {
-                  m_coincTrig7[idx++] = (amplitude >> ibit) & 1;
-                }
-              } else if (cha == 3) {
-                m_coincFlag7 = amplitude;
-              } else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            case COIN_TRIG8_FRAG:
-
-              if (cha < 3) {
-                int idx = cha * 32;
-                for (int ibit = 0; ibit < 32; ++ibit) {
-                  m_coincTrig8[idx++] = (amplitude >> ibit) & 1;
-                }
-              } else if (cha == 3) {
-                m_coincFlag8 = amplitude;
-              } else
-                WRONG_CHANNEL(frag, cha);
-              break;
-
-            default:
-              break;
-          }
-        }
-      }
-    }
-  }
-
-  // calculate beam coords in Beam Chambers
-  if (m_unpackAdder) { // this is 2003 data
-
-    if (m_beamIdList[BEAM_TDC_FRAG]) {
-      m_xCha1 = m_beamBC1X1 + m_beamBC1X2 * (m_btdc1[6] - m_btdc1[7]); // last two channels of TDC !!!
-      m_yCha1 = m_beamBC1Y1 + m_beamBC1Y2 * (m_btdc1[2] - m_btdc1[3]);
-      m_xCha2 = m_beamBC2X1 + m_beamBC2X2 * (m_btdc2[0] - m_btdc2[1]);
-      m_yCha2 = m_beamBC2Y1 + m_beamBC2Y2 * (m_btdc2[2] - m_btdc2[3]);
-
-      m_xImp = m_xCha2 + (m_xCha2 - m_xCha1) * m_beamBC2Z / (m_beamBC1Z - m_beamBC2Z);
-      m_yImp = m_yCha2 + (m_yCha2 - m_yCha1) * m_beamBC2Z / (m_beamBC1Z - m_beamBC2Z);
-    }
-
-  } else { // this is 2004 data
-
-    if (m_beamIdList[COMMON_TDC1_FRAG]) {
-      m_yChN2 = m_beamBN2Y1 + m_beamBN2Y2 * (m_btdc1[0] - m_btdc1[1]);
-      m_xChN2 = m_beamBN2X1 + m_beamBN2X2 * (m_btdc1[2] - m_btdc1[3]);
-      m_yChN1 = m_beamBN1Y1 + m_beamBN1Y2 * (m_btdc1[4] - m_btdc1[5]);
-      m_xChN1 = m_beamBN1X1 + m_beamBN1X2 * (m_btdc1[6] - m_btdc1[7]);
-
-      m_yCha0 = m_beamBC0Y1 + m_beamBC0Y2 * (m_btdc1[8] - m_btdc1[9]);
-      m_xCha0 = m_beamBC0X1 + m_beamBC0X2 * (m_btdc1[10] - m_btdc1[11]);
-
-      if (msgLvl(MSG::DEBUG)) {
-        msg(MSG::DEBUG) << "BC-2x : ( " << m_btdc1[2] << " - " << m_btdc1[3] << " )\t" << static_cast<float>(m_xChN2) << endmsg;
-        msg(MSG::DEBUG) << "BC-2y : ( " << m_btdc1[0] << " - " << m_btdc1[1] << " )\t" << static_cast<float>(m_yChN2) << endmsg;
-        msg(MSG::DEBUG) << "BC-1x : ( " << m_btdc1[6] << " - " << m_btdc1[7] << " )\t" << static_cast<float>(m_xChN1) << endmsg;
-        msg(MSG::DEBUG) << "BC-1y : ( " << m_btdc1[4] << " - " << m_btdc1[5] << " )\t" << static_cast<float>(m_yChN1) << endmsg;
-        msg(MSG::DEBUG) << "BC0x  : ( " << m_btdc1[10] << " - " << m_btdc1[11] << " )\t" << static_cast<float>(m_xCha0) << endmsg;
-        msg(MSG::DEBUG) << "BC0y  : ( " << m_btdc1[8] << " - " << m_btdc1[9] << " )\t" << static_cast<float>(m_yCha0) << endmsg;
-      }
-
-    }
-    
-    if (m_beamIdList[COMMON_TDC2_FRAG]) {
-      m_yCha1 = m_beamBC1Y1 + m_beamBC1Y2 * (m_btdc2[0] - m_btdc2[1]);
-      m_xCha1 = m_beamBC1X1 + m_beamBC1X2 * (m_btdc2[2] - m_btdc2[3]);
-      m_yCha2 = m_beamBC2Y1 + m_beamBC2Y2 * (m_btdc2[4] - m_btdc2[5]);
-      m_xCha2 = m_beamBC2X1 + m_beamBC2X2 * (m_btdc2[6] - m_btdc2[7]);
-
-      m_xImp = 0.0;
-      m_yImp = 0.0;
-      if (msgLvl(MSG::DEBUG)) {
-        msg(MSG::DEBUG) << "BC1x  : ( " << (int) m_btdc2[2] << " - " << (int) m_btdc2[3] << " )\t" << (float) m_xCha1 << endmsg;
-        msg(MSG::DEBUG) << "BC1y  : ( " << (int) m_btdc2[0] << " - " << (int) m_btdc2[1] << " )\t" << (float) m_yCha1 << endmsg;
-        msg(MSG::DEBUG) << "BC2x  : ( " << (int) m_btdc2[6] << " - " << (int) m_btdc2[7] << " )\t" << (float) m_xCha2 << endmsg;
-        msg(MSG::DEBUG) << "BC2y  : ( " << (int) m_btdc2[4] << " - " << (int) m_btdc2[5] << " )\t" << (float) m_yCha2 << endmsg;
-      }
-    }
-    
-    if ( m_beamIdList[COMMON_TDC1_FRAG] && m_beamIdList[COMMON_TDC2_FRAG] ) {
-
-      ////////////////////////////////////////////////
-      // Get run number and eta  
-      if ( 0==m_runNumber ){
-        const xAOD::EventInfo* eventInfo(0);
-        if (evtStore()->retrieve(eventInfo).isFailure()){
-          ATH_MSG_ERROR( "No EventInfo object found! Can't read run number!"  );
-          m_runNumber = -1;
-        } else {
-          m_runNumber = eventInfo->runNumber();
-          getEta();
-        }  
-      } 
-      ////////////////////////////////////////////////
-
-      // Computation of X,Y imp on TileCal/LAr front
-      float tanBx = (m_xCha1 - m_xCha0) / (m_beamBC0Z - m_beamBC1Z);
-      float tanBy = (m_yCha1 - m_yCha0) / (m_beamBC0Z - m_beamBC1Z);
-
-      float Ximp = m_xCha1 + m_beamBC1Z * tanBx;
-      float Yimp = m_yCha1 + m_beamBC1Z * tanBy;
-
-      if (0.0 != cos(m_theta) * (1 + tanBx * tan(m_theta))) {
-        m_xImp = (Ximp + m_radius * (tanBx * (cos(m_theta) - 1) - sin(m_theta))) / (cos(m_theta) * (1 + tanBx * tan(m_theta)));
-        m_yImp = Yimp + tanBy * (m_radius * (1 - cos(m_theta)) - Ximp * sin(m_theta)) / (cos(m_theta) * (1 + tanBx * tan(m_theta)));
-      }
-    }
-  }
-
-
-  // do not apply Cesium and Laser calibration for CIS events
-  m_calibrateEnergyThisEvent = m_calibrateEnergy && (m_trigType != 8);
-
-  return StatusCode::SUCCESS;
-}
-
-/**
- * Fill ntuple with data from TRC.
- * Default TRC container contains flat filtered and
- * named container fitted/opt filtered
- */
-StatusCode TileTBNtuple::storeRawChannels(std::string containerId
-                                           , std::vector<NTuple::Array<float>*> *eneVec
-                                           , std::vector<NTuple::Array<float>*> *timeVec
-                                           , std::vector<NTuple::Array<float>*> *chi2Vec
-                                           , std::vector<NTuple::Array<float>*> *pedVec) {
-
-
-  if (containerId.size() == 0) // empty name, nothing to do
-    return StatusCode::FAILURE;
-
-  // get named container
-  const TileRawChannelContainer* rcCnt;
-  CHECK( evtStore()->retrieve(rcCnt, containerId) );
-
-  TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit();
-
-  // Get iterator for all TRCColl in TRCCont
-  TileRawChannelContainer::const_iterator itColl = (*rcCnt).begin(); 
-  TileRawChannelContainer::const_iterator itCollEnd = (*rcCnt).end(); 
-
-  TileRawChannelCollection::const_iterator it, itEnd;
-
-  // type is 0 - m_nDrawers-1, fragType is 1-4 B+/B-/EB+/EB-
-  int type, fragType;
-  
-  // Go through all TileRawChannelCollections
-  for (; itColl != itCollEnd; ++itColl) {
-    // determine type
-    int fragId = (*itColl)->identify();
-    int drawerIdx = TileCalibUtils::getDrawerIdxFromFragId(fragId);
-    drawerMap_iterator itr = m_drawerMap.find(fragId);
-    if (itr != m_drawerMap.end()) {
-      type = (*itr).second;
-    } else {
-      type = -1;
-    }
-
-    if (type < 0) {
-      if ((*itColl)->begin() != (*itColl)->end())
-        ATH_MSG_WARNING( "frag id 0x" << MSG::hex << fragId << MSG::dec << " was not found among valid frag IDs when storing TRC!"  );
-
-    } else {
-      fragType = m_drawerType[type];
-      ATH_MSG_DEBUG( "TRC (" << containerId
-                     << ") Event# " << m_evtNr
-                     << " Frag id 0x" << MSG::hex << fragId << MSG::dec
-                     << " index " << type );
-
-      // go through all TileRawChannels in collection
-      it = (*itColl)->begin();
-      itEnd = (*itColl)->end();
-
-      for (; it != itEnd; ++it) {
-        HWIdentifier hwid = (*it)->adc_HWID();
-        int index = type;
-
-        // determine channel and gain
-        int channel = m_tileHWID->channel(hwid);
-        int gain = m_tileHWID->adc(hwid);
-
-        if (m_calibMode) {
-          // gain, if hi add m_nDrawers to index
-          if (gain == 1) index += m_nDrawers;
-        }
-
-        /// Cesium and Laser calibration
-        /// we assume that CIS calibration was done already in Opt. filtering
-        /// and we have already energy in pCb
-        /// after cesium calibration we still have the same pCb for A and BC cells
-        /// what we do is just set the same scale for D-cells
-        double energy = (*it)->amplitude();
-        if (m_calibrateEnergyThisEvent) { // convert to GeV and not MeV !
-          energy = m_tileToolEmscale->channelCalib(drawerIdx, channel, gain, energy, rChUnit, TileRawChannelUnit::MegaElectronVolts) / 1000.;
-        }
-
-        // cabling for testbeam (convert to pmt#-1)
-        if (fragType > 0) channel = digiChannel2PMT(fragType, channel);
-
-        (*(*eneVec)[index])[channel] = energy;
-        (*(*timeVec)[index])[channel] = (*it)->time();
-        if (chi2Vec != 0) (*(*chi2Vec)[index])[channel] = (*it)->quality();
-        if (pedVec != 0) (*(*pedVec)[index])[channel] = (*it)->pedestal();
-
-        ATH_MSG_DEBUG( "TRC ene=" << energy
-                      << " time=" << (*it)->time()
-                      << " chi2=" << (*it)->quality()
-                      << " ped=" << (*it)->pedestal()
-                      << " pmt-1=" << channel
-                      << " index " << index );
-
-      }
-    }
-  }
-
-  return StatusCode::SUCCESS;
-}
-
-/**
- * Fill Ntuple with info from TileDigits
- * Return true if the collection is empty, 
- * which means that there are no RawChanels either.
- */
-StatusCode TileTBNtuple::storeDigits() {
-
-  bool emptyColl = true;
-
-  // Read Digits from TDS
-  const TileDigitsContainer *digitsCnt;
-  CHECK( evtStore()->retrieve(digitsCnt, m_digitsContainer) );
-
-  // Get iterator for all TDColl in TDCont
-  TileDigitsContainer::const_iterator itColl = (*digitsCnt).begin();
-  TileDigitsContainer::const_iterator itCollEnd = (*digitsCnt).end();
-
-  TileDigitsCollection::const_iterator it, itEnd;
-
-  // type is 0 - m_nDrawers-1, fragType is 1-4 B+/B-/EB+/EB-
-  int n, type, fragType, channel;
-
-  std::vector<float> sampleVec;
-  std::vector<uint32_t> headerVec;
-  std::vector<uint32_t> headerVecHi;
-  uint32_t CRCmask;
-  uint32_t fe_crc;
-  uint32_t rod_crc;
-
-  // Go through all TileDigitsCollections
-  for (; itColl != itCollEnd; itColl++) {
-    // determine type of frag
-    int fragId = (*itColl)->identify();
-    drawerMap_iterator itr = m_drawerMap.find(fragId);
-    if (itr != m_drawerMap.end()) {
-      type = (*itr).second;
-    } else {
-      type = -1;
-    }
-
-    if (type < 0) {
-      if ((*itColl)->begin() != (*itColl)->end())
-        ATH_MSG_WARNING( "frag id 0x" << MSG::hex << fragId << MSG::dec << " was not found among valid frag IDs when storing TRC!" );
-    } else {
-      fragType = m_drawerType[type];
-      if (msgLvl(MSG::DEBUG)) {
-
-        msg(MSG::DEBUG) << "Event# " << m_evtNr
-                        << " Frag id 0x"<< MSG::hex << fragId <<MSG::dec
-                        << " index " << type
-                        << " Calib " << m_calibMode << endmsg;
-
-        msg(MSG::DEBUG) << "       Size=" << (*itColl)->getFragSize()
-                        << " BCID=" << (*itColl)->getFragBCID() << MSG::hex
-                        << " CRC=0x" << ((*itColl)->getFragCRC() & 0xffff)
-                        << " DMUMask=0x" << ((*itColl)->getFragDMUMask() & 0xffff) << MSG::dec << endmsg;
-
-        msg(MSG::DEBUG) << "       Lvl1ID=" << (*itColl)->getLvl1Id()
-                        << " Lvl1Type=" << (*itColl)->getLvl1Type()
-                        << " EvBCID=" << (*itColl)->getRODBCID()
-                        << " EvType=" << (*itColl)->getDetEvType() << endmsg;
-
-        msg(MSG::DEBUG) << "       Header=" << (*itColl)->getFragChipHeaderWords() << endmsg;
-      }
-
-      if (m_completeNtuple) {
-        /// Store ROD header info from collection 
-        /// (should be just one per ROD,
-        /// but we don't know how many RODs we have,
-        /// so store it for every collection)
-        m_l1ID[type] = (*itColl)->getLvl1Id();
-        m_l1Type[type] = (*itColl)->getLvl1Type();
-        m_evType[type] = (*itColl)->getDetEvType();
-        m_evBCID[type] = (*itColl)->getRODBCID();
-        // store FrBCID
-        m_frBCID[type] = (*itColl)->getFragBCID();
-      }
-      
-      if(m_calibMode) {
-        // Digits in calib mode
-        // check gain for first digits in collection
-        
-        it = (*itColl)->begin();
-        itEnd = (*itColl)->end();
- 
-        // non empty collection
-        if(it != itEnd) {
-          // store evtnr, bcid,crc, size
-          // Same for lo and hi, because they come from the same fragment
-          *m_rodBCIDVec[type] = (*itColl)->getRODBCID();
-          *m_sizeVec[type] = (*itColl)->getFragSize();
-          *m_sizeVec[type+m_nDrawers] = (*itColl)->getFragSize();
-          *m_evtVec[type] = m_evtNr;
-          *m_evtVec[type+m_nDrawers] = m_evtNr;
-
-          headerVec = (*itColl)->getFragChipHeaderWords();
-          headerVecHi = (*itColl)->getFragChipHeaderWordsHigh();
-          CRCmask = (*itColl)->getFragDMUMask(); //mask of FE+ROD DMU crc check (16bit+16bit) 0xffffffff == All ok
-          fe_crc = CRCmask & 0xFFFF;
-          rod_crc = CRCmask >> 16;
-
-          unsigned int headsize = std::min(16U, static_cast<unsigned int>(headerVec.size()));
-          unsigned int headsizehi = std::min(16U, static_cast<unsigned int>(headerVecHi.size()));
-
-          for (unsigned int ih = 0; ih < headsize; ++ih) {
-            (*m_bcidVec[type])[ih] = (headerVec[ih] & 0xFFF);
-            (*m_feCRCVec[type])[ih] = (fe_crc >> ih & 0x1);
-            (*m_rodCRCVec[type])[ih] = (rod_crc >> ih & 0x1);
-          }
-
-          for (unsigned int ihhi = 0; ihhi < headsizehi; ++ihhi) {
-            (*m_bcidVec[type + m_nDrawers])[ihhi] = (headerVecHi[ihhi] & 0xFFF);
-          }
-
-          (*m_slinkCRCVec[type])[0] = ((*itColl)->getFragCRC() >> 16) & 0xffff;
-          (*m_dmuMaskVec[type])[0] = ((*itColl)->getFragDMUMask() >> 16) & 0xffff;
-          (*m_slinkCRCVec[type])[1] = (*itColl)->getFragCRC() & 0xffff;
-          (*m_dmuMaskVec[type])[1] = (*itColl)->getFragDMUMask() & 0xffff;
-
-          (*m_slinkCRCVec[type + m_nDrawers])[0] = ((*itColl)->getFragCRC() >> 16) & 0xffff;
-          (*m_dmuMaskVec[type + m_nDrawers])[0] = ((*itColl)->getFragDMUMask() >> 16) & 0xffff;
-          (*m_slinkCRCVec[type + m_nDrawers])[1] = (*itColl)->getFragCRC() & 0xffff;
-          (*m_dmuMaskVec[type + m_nDrawers])[1] = (*itColl)->getFragDMUMask() & 0xffff;
-      
-          // go through all TileDigits in collection
-          for (; it != itEnd; it++) {
-            emptyColl = false;
-
-            HWIdentifier hwid = (*it)->adc_HWID();
-            // determine gain
-            int gain = m_tileHWID->adc(hwid);
-            // add m_nDrawers to index if hi gain
-            int index = type;
-            if (gain == 1) index += m_nDrawers;
-
-            // determine channel       
-            channel = m_tileHWID->channel(hwid);
-            // cabling for testbeam (convert to pmt#-1)
-            if (fragType > 0) channel = digiChannel2PMT(fragType, channel);
-
-            // gain determined for all digits in collection
-            (*m_gainVec[index])[channel] = gain;
-            ATH_MSG_DEBUG( "Storing TD for channel: " << channel
-                           << " with gain " << m_tileHWID->adc(hwid)
-                           << " index " << index );
-
-            // get digits
-            sampleVec = (*it)->samples();
-            int siz = sampleVec.size();
-
-            if (msgLvl(MSG::DEBUG)) {
-              msg(MSG::DEBUG) << "Digits." << siz << " {";
-              for (int i = 0; i < siz; i++) {
-                msg(MSG::DEBUG) << (int) sampleVec[i] << " ";
-              }
-
-              if (siz > m_nSamples) {
-                msg(MSG::DEBUG) << "} ONLY " << m_nSamples << " digits saved to ntuple" << endmsg;
-              } else {
-                msg(MSG::DEBUG) << "}" << endmsg;
-              }
-            }
-
-            if (siz > m_nSamples) siz = m_nSamples;
-            for (n = 0; n < siz; n++) {
-              (*m_sampleVec[index])[channel][n] = (int) sampleVec[n];
-            }
-          }
-        }
-      } else {
-        // Digits in normal mode
-
-        // store evtnr, bcid,crc, size
-        *m_rodBCIDVec[type] = (*itColl)->getRODBCID();
-        *m_sizeVec[type] = (*itColl)->getFragSize();
-        *m_evtVec[type] = m_evtNr;
-
-        headerVec = (*itColl)->getFragChipHeaderWords();
-        CRCmask = (*itColl)->getFragDMUMask(); //mask of FE+ROD DMU crc check (16bit+16bit) 0xffffffff == All ok
-        fe_crc = CRCmask & 0xFFFF;
-        rod_crc = CRCmask >> 16;
-
-        int headsize = headerVec.size();
-
-        for (int ih = 0; ih < headsize; ih++) {
-          (*m_bcidVec[type])[ih] = (headerVec[ih] & 0xFFF);
-          (*m_feCRCVec[type])[ih] = (fe_crc >> ih & 0x1);
-          (*m_rodCRCVec[type])[ih] = (rod_crc >> ih & 0x1);
-        }
-      
-        (*m_slinkCRCVec[type])[0] = ((*itColl)->getFragCRC()>>16) & 0xffff;
-        (*m_dmuMaskVec[type])[0] = ((*itColl)->getFragDMUMask()>>16) & 0xffff;
-        (*m_slinkCRCVec[type])[1] = (*itColl)->getFragCRC() & 0xffff;
-        (*m_dmuMaskVec[type])[1] = (*itColl)->getFragDMUMask() & 0xffff;
-      
-        // go through all TileDigits in collection
-        it = (*itColl)->begin();
-        itEnd = (*itColl)->end();
-        
-        for(;it != itEnd;it++) {
-          emptyColl = false;
-          
-          HWIdentifier hwid=(*it)->adc_HWID();
-          // determine channel       
-          channel = m_tileHWID->channel(hwid);
-          // cabling for testbeam
-          if (fragType > 0) channel = digiChannel2PMT(fragType,channel);
- 
-          // gain
-          (*m_gainVec[type])[channel] = m_tileHWID->adc(hwid);
-          ATH_MSG_DEBUG( "Storing TD for channel: " << channel
-                         << " with gain " << m_tileHWID->adc(hwid) );
-
-        
-          // get digits
-          sampleVec = (*it)->samples();
-          int siz = sampleVec.size();
-
-          if (msgLvl(MSG::DEBUG)) {
-            msg(MSG::DEBUG) << "Digits." << siz << " {";
-            for (int i = 0; i < siz; i++) {
-              msg(MSG::DEBUG) << (int) sampleVec[i] << " ";
-            }
-            msg(MSG::DEBUG) << "}" << endmsg;
-          }
-
-          for (n = 0; n < siz; n++) {
-            (*m_sampleVec[type])[channel][n] = (int) sampleVec[n];
-          }
-        }
-      }
-    }
-    // next container
-  }
-  
-  if (emptyColl)
-    return StatusCode::FAILURE;
-  else
-    return StatusCode::SUCCESS;
-}
-
-StatusCode TileTBNtuple::finalize() {
-
-  ATH_MSG_INFO( "finalize() successfully" );
-
-  return StatusCode::SUCCESS;
-}
-
-StatusCode TileTBNtuple::connectFile(void) {
-  MsgStream log(msgSvc(), name());
-
-  m_ntupleCreated = false;
-  char file[100];
-  sprintf(file, m_ntupleLoc.c_str(), ++m_currentFileNum);
-  std::string ntupleLoc = file;
-
-  NTupleDirPtr DirPtr(ntupleSvc(), ntupleLoc);
-  if (!DirPtr) DirPtr = ntupleSvc()->createDirectory(ntupleLoc);
-  if (!DirPtr) {
-    ATH_MSG_ERROR( "Invalid Ntuple Directory: " );
-    return StatusCode::FAILURE;
-  }
-
-  m_ntuplePtr = ntupleSvc()->book(DirPtr.ptr(), m_ntupleID, CLID_ColumnWiseTuple, "TileBEAM-Ntuple");
-  if (!m_ntuplePtr) {
-
-    std::string ntupleCompleteID = ntupleLoc + "/" + m_ntupleID;
-
-    NTuplePtr nt(ntupleSvc(), ntupleCompleteID);
-    if (!nt) {
-      ATH_MSG_ERROR( "Failed to book or to retreive ntuple " << ntupleCompleteID );
-      return StatusCode::FAILURE;
-    } else {
-      ATH_MSG_INFO( "Reaccessing ntuple " << ntupleCompleteID );
-
-      m_ntuplePtr = nt;
-      // we share ntuple with some other algorithm
-      // so have to book all columns now, otherwise Athena will crash
-      m_ntupleCreated = true;
-      StatusCode sc = initNTuple();
-      if (sc.isFailure()) {
-        ATH_MSG_ERROR(  " Error during ntuple initialization" );
-      }
-    }
-  }
-
-  return StatusCode::SUCCESS;
-}
-
-StatusCode TileTBNtuple::initNTuple(void) {
-
-  m_evtVec.clear();
-  m_bcidVec.clear();
-  m_rodBCIDVec.clear();
-  m_sizeVec.clear();
-  m_dmuMaskVec.clear();
-  m_slinkCRCVec.clear();
-  m_gainVec.clear();
-  m_errVec.clear();
-  m_sampleVec.clear();
-  m_feCRCVec.clear();
-  m_rodCRCVec.clear();
-
-  m_eneVec.clear();
-  m_timeVec.clear();
-
-  m_efitVec.clear();
-  m_tfitVec.clear();
-  m_pedfitVec.clear();
-  m_chi2Vec.clear();
-
-  m_eOptVec.clear();
-  m_tOptVec.clear();
-  m_pedOptVec.clear();
-  m_chi2OptVec.clear();
-
-  m_eDspVec.clear();
-  m_tDspVec.clear();
-  m_chi2DspVec.clear();
-
-  // *** Create items for TRIGGER ***
-
-  CHECK( m_ntuplePtr->addItem("TRIGGER/EvTime", m_evTime) );
-  CHECK( m_ntuplePtr->addItem("TRIGGER/Run", m_run) );
-  CHECK( m_ntuplePtr->addItem("TRIGGER/Evt", m_evt) );
-  CHECK( m_ntuplePtr->addItem("TRIGGER/Trig", m_trigType, 0, 65535) );
-  
-
-  if ( m_completeNtuple ) {
-    // Info from ROD headers
-    // m_nDrawers drawers separately (i.e. with duplications) + Beam ROD
-    CHECK(m_ntuplePtr->addItem("TRIGGER/L1ID", m_nDrawers + 1, m_l1ID, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("TRIGGER/L1Type", m_nDrawers + 1, m_l1Type, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("TRIGGER/EvType", m_nDrawers + 1, m_evType, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("TRIGGER/EvBCID", m_nDrawers + 1, m_evBCID, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("TRIGGER/FrBCID", m_nDrawers, m_frBCID, 0, 65535));
-  }
-
-  // *** Create items for MUON ***
-  if ( m_beamIdList[MUON_ADC_FRAG] ||
-      m_beamIdList[ADDR_ADC_FRAG] ) {
-
-    CHECK(m_ntuplePtr->addItem("MUON/MuBackHit", m_muBackHit));
-    CHECK(m_ntuplePtr->addItem("MUON/MuBackSum", m_muBackSum));
-    CHECK(m_ntuplePtr->addItem("MUON/MuBack", 14, m_muBack));
-    CHECK(m_ntuplePtr->addItem("MUON/MuCalib", 2, m_muCalib));
-  }
-  
-  // *** Create items for ECAL ***
-  if ( m_beamIdList[ECAL_ADC_FRAG] ) {
-    CHECK( m_ntuplePtr->addItem("ECAL/Ecal",8,m_ecal) );
-  }
-      
-  // *** Create items for LASER ***
-  if ( m_beamIdList[LASE_PTN_FRAG] ) {
-    CHECK( m_ntuplePtr->addItem("LASER/LasFlag",m_lasFlag,0,65535) );
-  }
-  if ( (  m_unpackAdder && m_beamIdList[BEAM_ADC_FRAG] ) ||
-       ( !m_unpackAdder && m_beamIdList[LASE_ADC_FRAG] ) ) {
-
-    CHECK(m_ntuplePtr->addItem("LASER/Las0", m_las0));
-    CHECK(m_ntuplePtr->addItem("LASER/Las1", m_las1));
-    CHECK(m_ntuplePtr->addItem("LASER/Las2", m_las2));
-    CHECK(m_ntuplePtr->addItem("LASER/Las3", m_las3));
-    CHECK(m_ntuplePtr->addItem("LASER/LasExtra", 4, m_lasExtra));
-  }
-  
-  // *** Create items for ADDER ***
-  if (m_unpackAdder) {
-    if ( m_beamIdList[ADD_FADC_FRAG] ) {
-      CHECK(m_ntuplePtr->addItem("ADDER/Adder", 16, 16, m_adder, 0, 255));
-      CHECK(m_ntuplePtr->addItem("ADDER/EneAdd", 16, m_eneAdd));
-      CHECK(m_ntuplePtr->addItem("ADDER/TimeAdd", 16, m_timeAdd));
-    }
-  }
-  
-  // *** Create items for STATUS ***
-  // CHECK( m_ntuplePtr->addItem("STATUS/Status",2,3,m_status) );
-
-  // *** Create items for CISPAR ***
-  if ( m_beamIdList[DIGI_PAR_FRAG&0x1F] ) {
-    CHECK( m_ntuplePtr->addItem("CISPAR/Cispar",16,m_cispar) );
-  }
-  
-  // *** Create items for BEAM ***
-  if ( (  m_unpackAdder && m_beamIdList[BEAM_ADC_FRAG] ) ||
-       ( !m_unpackAdder && m_beamIdList[COMMON_ADC1_FRAG] ) ) {
-
-    CHECK(m_ntuplePtr->addItem("BEAM/S1cou", m_s1cou, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("BEAM/S2cou", m_s2cou, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("BEAM/S3cou", m_s3cou, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("BEAM/MuTag", m_muTag, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("BEAM/Cher1", m_cher1, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("BEAM/Cher2", m_cher2, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("BEAM/MuHalo", m_muHalo, 0, 65535));
-    CHECK(m_ntuplePtr->addItem("BEAM/MuVeto", m_muVeto, 0, 65535));
-  }
-  
-  if ( ! m_unpackAdder ) {
-
-    if ( m_beamIdList[COMMON_ADC2_FRAG] ) {
-      CHECK( m_ntuplePtr->addItem("BEAM/S2extra",m_s2extra,0,65535) );
-      CHECK( m_ntuplePtr->addItem("BEAM/S3extra",m_s3extra,0,65535) );
-    }
-    
-    if (m_beamIdList[BEAM_ADC_FRAG]) {
-      CHECK(m_ntuplePtr->addItem("BEAM/SC1", m_sc1, 0, 65535));
-      CHECK(m_ntuplePtr->addItem("BEAM/SC2", m_sc2, 0, 65535));
-    }
-
-    if (m_beamIdList[COMMON_PTN_FRAG]) {
-      CHECK(m_ntuplePtr->addItem("BEAM/pu", m_commonPU, 0, 65535));
-    }
-    
-    if (m_beamIdList[COMMON_TOF_FRAG]) {
-      CHECK(m_ntuplePtr->addItem("BEAM/tof", 8, m_tof, 0, 65535));
-    }
-
-    if (m_beamIdList[COMMON_TDC1_FRAG]) {
-      CHECK(m_ntuplePtr->addItem("BEAM/btdc1", 16, m_btdc1, 0, 65535));
-    }
-
-    if (m_beamIdList[COMMON_TDC2_FRAG]) {
-      CHECK(m_ntuplePtr->addItem("BEAM/btdc2", 16, m_btdc2, 0, 65535));
-    }
-
-    if (m_beamIdList[COMMON_TDC1_FRAG]) {
-      CHECK(m_ntuplePtr->addItem("BEAM/XchN2", m_xChN2));
-      CHECK(m_ntuplePtr->addItem("BEAM/YchN2", m_yChN2));
-      CHECK(m_ntuplePtr->addItem("BEAM/XchN1", m_xChN1));
-      CHECK(m_ntuplePtr->addItem("BEAM/YchN1", m_yChN1));
-    }
-    if ( m_beamIdList[COMMON_TDC2_FRAG] ) {
-      CHECK( m_ntuplePtr->addItem("BEAM/Xcha0",m_xCha0) );
-      CHECK( m_ntuplePtr->addItem("BEAM/Ycha0",m_yCha0) );
-    }
-  } else {
-    if (m_beamIdList[BEAM_TDC_FRAG]) {
-      CHECK(m_ntuplePtr->addItem("BEAM/btdc1", 8, m_btdc1, 0, 65535));
-      CHECK(m_ntuplePtr->addItem("BEAM/btdc2", 8, m_btdc2, 0, 65535));
-    }
-  }
-
-  if ((m_unpackAdder && m_beamIdList[BEAM_TDC_FRAG])
-      || (!m_unpackAdder && m_beamIdList[COMMON_TDC2_FRAG])) {
-
-    CHECK(m_ntuplePtr->addItem("BEAM/Xcha1", m_xCha1));
-    CHECK(m_ntuplePtr->addItem("BEAM/Ycha1", m_yCha1));
-    CHECK(m_ntuplePtr->addItem("BEAM/Xcha2", m_xCha2));
-    CHECK(m_ntuplePtr->addItem("BEAM/Ycha2", m_yCha2));
-    CHECK(m_ntuplePtr->addItem("BEAM/Ximp", m_xImp));
-    CHECK(m_ntuplePtr->addItem("BEAM/Yimp", m_yImp));
-  }
-  
-  // *** Create items for TileDigits and TileRawChannels ***
-
-  unsigned int listSize = std::min(m_nDrawers, static_cast<unsigned int>(m_drawerMap.size()));
-
-  if (listSize > 0) {
-
-    std::string digit[10] = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9" };
-    std::vector<std::string> suffixArr;
-    unsigned int length;
-    bool testbeam = TileCablingService::getInstance()->getTestBeam();
-
-    if (m_calibMode) {
-
-      length = 2 * m_nDrawers;
-      suffixArr.resize(length);
-
-      for (unsigned int i = 0; i < listSize; ++i) {
-        unsigned int ros = m_drawerType[i];
-        unsigned int drawer = strtol(m_drawerList[i].data(), NULL, 0) & 0x3F;
-        std::string digits;
-        if (testbeam) {
-          digits = digit[drawer & 7];
-        } else {
-          ++drawer; // count modules from 1
-          digits = digit[drawer / 10] + digit[drawer % 10];
-        }
-
-        if (ros == 0) {
-          std::string suff = m_drawerList[i];
-          suff.replace(suff.find("0x"), 2, "");
-          suffixArr[i] = suff + "lo";
-          suffixArr[i + m_nDrawers] = suff + "hi";
-        } else {
-          suffixArr[i] = m_rosName[ros] + digits + "lo";
-          suffixArr[i + m_nDrawers] = m_rosName[ros] + digits + "hi";
-        }
-      }
-    } else {
-
-      length = m_nDrawers;
-      suffixArr.resize(length);
-
-      for (unsigned int i = 0; i < listSize; ++i) {
-        unsigned int ros = m_drawerType[i];
-        unsigned int drawer = strtol(m_drawerList[i].data(), NULL, 0) & 0x3F;
-        std::string digits;
-        if (testbeam) {
-          digits = digit[drawer & 7];
-        } else {
-          ++drawer; // count modules from 1
-          digits = digit[drawer / 10] + digit[drawer % 10];
-        }
-
-        if (ros == 0) {
-          std::string suff = m_drawerList[i];
-          suff.replace(suff.find("0x"), 2, "");
-          suffixArr[i] = suff;
-        } else {
-          suffixArr[i] = m_rosName[ros] + digits;
-        }
-      }
-    }
-
-    // create NTuple objs in vectors
-    for (unsigned int i = 0; i < length; i++) {
-
-      if (i % m_nDrawers < listSize)
-      ATH_MSG_DEBUG("Adding items for " << suffixArr[i]);
-
-      NTuple::Item<int> *evt = new NTuple::Item<int>;
-      NTuple::Array<int> *bcid = new NTuple::Array<int>;
-      NTuple::Item<int> *rodBCID = new NTuple::Item<int>;
-      NTuple::Item<int> *size = new NTuple::Item<int>;
-      NTuple::Array<int> *dmu = new NTuple::Array<int>;
-      NTuple::Array<int> *crc = new NTuple::Array<int>;
-      NTuple::Array<int> *gain = new NTuple::Array<int>;
-      NTuple::Array<int> *err = new NTuple::Array<int>;
-      NTuple::Matrix<int> *sample = new NTuple::Matrix<int>;
-      NTuple::Array<int> *fe_crc = new NTuple::Array<int>;
-      NTuple::Array<int> *rod_crc = new NTuple::Array<int>;
-
-      NTuple::Array<float> *ene = new NTuple::Array<float>;
-      NTuple::Array<float> *time = new NTuple::Array<float>;
-
-      NTuple::Array<float> *efit = new NTuple::Array<float>;
-      NTuple::Array<float> *tfit = new NTuple::Array<float>;
-      NTuple::Array<float> *pedfit = new NTuple::Array<float>;
-      NTuple::Array<float> *chi2 = new NTuple::Array<float>;
-
-      NTuple::Array<float> *eOpt = new NTuple::Array<float>;
-      NTuple::Array<float> *tOpt = new NTuple::Array<float>;
-      NTuple::Array<float> *pedOpt = new NTuple::Array<float>;
-      NTuple::Array<float> *chi2Opt = new NTuple::Array<float>;
-
-      NTuple::Array<float> *eDsp = new NTuple::Array<float>;
-      NTuple::Array<float> *tDsp = new NTuple::Array<float>;
-      NTuple::Array<float> *chi2Dsp = new NTuple::Array<float>;
-
-      m_evtVec.push_back(evt); // I
-      m_bcidVec.push_back(bcid); // U
-      m_rodBCIDVec.push_back(rodBCID); // U
-      m_sizeVec.push_back(size); // U
-      m_dmuMaskVec.push_back(dmu); // U(2)
-      m_slinkCRCVec.push_back(crc); // U(2)
-      m_gainVec.push_back(gain); // U(48/96)
-      m_errVec.push_back(err); // U(48/96)
-      m_sampleVec.push_back(sample); // U(48/96,9)
-      m_feCRCVec.push_back(fe_crc); //U
-      m_rodCRCVec.push_back(rod_crc); //U
-
-      m_eneVec.push_back(ene);
-      m_timeVec.push_back(time);
-
-      m_efitVec.push_back(efit);
-      m_tfitVec.push_back(tfit);
-      m_pedfitVec.push_back(pedfit);
-      m_chi2Vec.push_back(chi2);
-
-      m_eOptVec.push_back(eOpt);
-      m_tOptVec.push_back(tOpt);
-      m_pedOptVec.push_back(pedOpt);
-      m_chi2OptVec.push_back(chi2Opt);
-
-      m_eDspVec.push_back(eDsp);
-      m_tDspVec.push_back(tDsp);
-      m_chi2DspVec.push_back(chi2Dsp);
-
-
-     if (i % m_nDrawers < listSize) {
-        // create ntuple layout
-        ATH_MSG_DEBUG( "Adding Leaf to Event '" << ("RAW" + suffixArr[i] + "/Evt" + suffixArr[i]) << "' @" << evt);
-
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Evt" + suffixArr[i], *evt) ); // uint
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/BCID" + suffixArr[i], 16, *bcid, 0, 65535) ); // uint
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/rodBCID" + suffixArr[i], *rodBCID, 0, 65535) ); //uint
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Size" + suffixArr[i], *size, 0, 65535) ); // uint
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/DMUMask" + suffixArr[i], 2, *dmu, 0, 65535) ); // uint
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/SlinkCRC" + suffixArr[i], 2, *crc, 0, 65535) ); // uint
-        // XXX: Number of samples taken from JobOptions and number of channels is hard-coded as 48
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Gain" + suffixArr[i], 48, *gain, 0, 1) ); // uint
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Err" + suffixArr[i], 48, *err, 0, 1023) ); // uint
-        if (m_nSamples > 0) {
-          CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Sample" + suffixArr[i], 48, m_nSamples, *sample, 0, 1023) ); // uint
-        }
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/feCRC" + suffixArr[i], 16, *fe_crc, 0, 1) ); // uint
-        CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/rodCRC" + suffixArr[i], 16, *rod_crc, 0, 1) ); // uint
-
-        if (m_flatRawChannelContainer.size() > 0) {
-
-          CHECK( m_ntuplePtr->addItem("ENE" + suffixArr[i] + "/Ene" + suffixArr[i], 48, *ene) ); // float
-          CHECK( m_ntuplePtr->addItem("ENE" + suffixArr[i] + "/Time" + suffixArr[i], 48, *time) ); // float
-        }
-
-        if (m_fitRawChannelContainer.size() > 0) {
-
-          CHECK( m_ntuplePtr->addItem("FIT" + suffixArr[i] + "/Efit" + suffixArr[i], 48, *efit) ); // float
-          CHECK( m_ntuplePtr->addItem("FIT" + suffixArr[i] + "/Tfit" + suffixArr[i], 48, *tfit) ); // float
-          CHECK( m_ntuplePtr->addItem("FIT" + suffixArr[i] + "/Pedfit" + suffixArr[i], 48, *pedfit) ); // float
-          CHECK( m_ntuplePtr->addItem("FIT" + suffixArr[i] + "/Chi2" + suffixArr[i], 48, *chi2) ); // float
-        }
-
-        if (m_optRawChannelContainer.size() > 0) {
-
-          CHECK( m_ntuplePtr->addItem("OPT" + suffixArr[i] + "/Eopt" + suffixArr[i], 48, *eOpt) ); // float
-          CHECK( m_ntuplePtr->addItem("OPT" + suffixArr[i] + "/Topt" + suffixArr[i], 48, *tOpt) ); // float
-          CHECK( m_ntuplePtr->addItem("OPT" + suffixArr[i] + "/Pedopt" + suffixArr[i], 48, *pedOpt) ); // float
-          CHECK( m_ntuplePtr->addItem("OPT" + suffixArr[i] + "/Chi2opt" + suffixArr[i], 48, *chi2Opt) ); // float
-        }
-
-        if (m_dspRawChannelContainer.size() > 0) {
-
-          CHECK( m_ntuplePtr->addItem("DSP" + suffixArr[i] + "/Edsp" + suffixArr[i], 48, *eDsp) ); // float
-          CHECK( m_ntuplePtr->addItem("DSP" + suffixArr[i] + "/Tdsp" + suffixArr[i], 48, *tDsp) ); // float
-          CHECK( m_ntuplePtr->addItem("DSP" + suffixArr[i] + "/Chi2dsp" + suffixArr[i], 48, *chi2Dsp) ); // float
-        }
-
-      }
-    }
-  }
-
-  if (m_completeNtuple) {
-    // *** Create items for total energy in samplings ***
-    CHECK( m_ntuplePtr->addItem("EneTotal/LarSmp", 4, m_LarEne) );
-    CHECK( m_ntuplePtr->addItem("EneTotal/BarSmp", 3, m_BarEne) );
-    CHECK( m_ntuplePtr->addItem("EneTotal/ExtSmp", 3, m_ExtEne) );
-    CHECK( m_ntuplePtr->addItem("EneTotal/GapSmp", 3, m_GapEne) );
-  }
-
-  if (m_beamIdList[COIN_TRIG1_FRAG]) {
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig1", 96, m_coincTrig1) );
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag1", m_coincFlag1) );
-  }
-
-  if (m_beamIdList[COIN_TRIG2_FRAG]) {
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig2", 96, m_coincTrig2) );
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag2", m_coincFlag2) );
-  }
-
-  if (m_beamIdList[COIN_TRIG3_FRAG]) {
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig3", 96, m_coincTrig3) );
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag3", m_coincFlag3) );
-  }
-
-  if (m_beamIdList[COIN_TRIG4_FRAG]) {
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig4", 96, m_coincTrig4) );
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag4", m_coincFlag4) );
-  }
-
-  if (m_beamIdList[COIN_TRIG5_FRAG]) {
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig5", 96, m_coincTrig5) );
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag5", m_coincFlag5) );
-  }
-
-  if (m_beamIdList[COIN_TRIG6_FRAG]) {
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig6", 96, m_coincTrig6) );
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag6", m_coincFlag6) );
-  }
-  if (m_beamIdList[COIN_TRIG7_FRAG]) {
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig7", 96, m_coincTrig7) );
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag7", m_coincFlag7) );
-  }
-
-  if (m_beamIdList[COIN_TRIG8_FRAG]) {
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig8", 96, m_coincTrig8) );
-    CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag8", m_coincFlag8) );
-  }
-
-  return StatusCode::SUCCESS;
-}
-
-StatusCode TileTBNtuple::storeCells() {
-
-  const CaloCellContainer* cellContainer;
-  //Retrieve Cell collection from SG
-
-  ATH_MSG_DEBUG( "retrieve cellContainer from SG" );
-
-  CHECK( evtStore()->retrieve(cellContainer, "AllCalo") );
-
-  //Loop over all cells in container. Sum up the Energy and fill 2DHistograms
-
-  ATH_MSG_DEBUG( "succeeded retrieving cellContainer from SG" );
-
-  CaloCellContainer::const_iterator ifirst = cellContainer->begin();
-  CaloCellContainer::const_iterator ilast = cellContainer->end();
-  ATH_MSG_DEBUG( "TileTBNtuple : about to iterate over CaloCells" );
-
-  m_LarEne[0] = m_LarEne[1] = m_LarEne[2] = m_LarEne[3] = 0.0;
-  m_BarEne[0] = m_BarEne[1] = m_BarEne[2] = 0.0;
-  m_ExtEne[0] = m_ExtEne[1] = m_ExtEne[2] = 0.0;
-  m_GapEne[0] = m_GapEne[1] = m_GapEne[2] = 0.0;
-
-  for (; ifirst != ilast; ++ifirst) {
-    //Decode cell information
-    const CaloCell* cell_ptr = *ifirst;    // pointer to cell object
-    const double energy = cell_ptr->energy();
-    const CaloDetDescrElement* caloDDE_ptr = cell_ptr->caloDDE(); //pointer to the DetectorDescriptionElement
-    const CaloCell_ID::CaloSample sampl = caloDDE_ptr->getSampling(); //To which sampling belongs this cell?
-//    const CaloCell_ID::SUBCALO subcalo= caloDDE_ptr->getSubCalo(); 
-
-    if (sampl == CaloCell_ID::PreSamplerB) {
-      m_LarEne[0] += energy;
-    } else if (sampl == CaloCell_ID::EMB1) {
-      m_LarEne[1] += energy;
-    } else if (sampl == CaloCell_ID::EMB2) {
-      m_LarEne[2] += energy;
-    } else if (sampl == CaloCell_ID::EMB3) {
-      m_LarEne[3] += energy;
-    } else if (sampl == CaloCell_ID::TileBar0) {
-      m_BarEne[0] += energy;
-    } else if (sampl == CaloCell_ID::TileBar1) {
-      m_BarEne[1] += energy;
-    } else if (sampl == CaloCell_ID::TileBar2) {
-      m_BarEne[2] += energy;
-    } else if (sampl == CaloCell_ID::TileExt0) {
-      m_ExtEne[0] += energy;
-    } else if (sampl == CaloCell_ID::TileExt1) {
-      m_ExtEne[1] += energy;
-    } else if (sampl == CaloCell_ID::TileExt2) {
-      m_ExtEne[2] += energy;
-    } else if (sampl == CaloCell_ID::TileGap1) {
-      m_GapEne[1] += energy;
-    } else if (sampl == CaloCell_ID::TileGap2) {
-      m_GapEne[2] += energy;
-    } else if (sampl == CaloCell_ID::TileGap3) {
-      m_GapEne[0] += energy;
-    }
-  }
-
-  return StatusCode::SUCCESS;
-}
-
-
-StatusCode TileTBNtuple::initList() {
-
-  unsigned int size = m_drawerList.size();
-
-  if (size > 0) {
-
-    int frag = strtol(m_drawerList[0].data(), NULL, 0);
-
-    if (frag < 0) { // setup frags IDs from the data
-
-      // Read Digits from TDS
-      const TileDigitsContainer *digitsCnt;
-
-      if (evtStore()->retrieve(digitsCnt, m_digitsContainer).isFailure()) {
-        ATH_MSG_ERROR( "can't retrieve Digits from TDS" );
-        ATH_MSG_ERROR( "can't set up fragment list for ntuple" );
-
-        if (m_nSamples != 0) {
-          ATH_MSG_WARNING( "Disable digit samples in ntuple" );
-          m_nSamples = 0;
-        }
-
-        return StatusCode::SUCCESS;
-      }
-
-      // Get iterator for all TDColl in TDCont
-      TileDigitsContainer::const_iterator itColl = (*digitsCnt).begin();
-      TileDigitsContainer::const_iterator itCollEnd = (*digitsCnt).end();
-
-      std::vector<unsigned int> frags;
-      // Go through all TileDigitsCollections
-      for (; itColl != itCollEnd; itColl++) {
-        // determine type of frag
-        if ((*itColl)->begin() != (*itColl)->end()) frags.push_back((*itColl)->identify());
-      }
-      size = frags.size();
-
-      if (size > 0) {
-
-        unsigned int rosOrder[5] = { 2, 1, 3, 4, 0 };
-        unsigned int dr = 0;
-        char frg[6] = "0x000";
-
-        m_drawerList.clear();
-        // m_drawerType.clear();
-        m_drawerMap.clear();
-
-        msg(MSG::INFO) << "setting drawerList from data " << MSG::hex;
-        for (unsigned int ir = 0; ir < 5; ++ir) {
-          for (unsigned int i = 0; i < size; ++i) {
-            unsigned int frag = frags[i];
-            if (frag >> 8 == rosOrder[ir]) {
-              sprintf(frg, "0x%3.3x", frag);
-              m_drawerList.push_back((std::string) frg);
-              if (dr == m_drawerType.size()) m_drawerType.push_back(frag >> 8);
-              m_drawerMap[frag] = dr;
-              msg(MSG::INFO) << " 0x" << frag;
-              ++dr;
-            }
-          }
-        }
-        msg(MSG::INFO) << MSG::dec << endmsg;
-
-        size = m_drawerType.size();
-        if (size < m_nDrawers) {
-          m_drawerType.resize(m_nDrawers);
-          for (; size < m_nDrawers; ++size)
-            m_drawerType[size] = 0;
-        }
-
-        msg(MSG::INFO) << "drawerType ";
-        for (unsigned int dr = 0; dr < size; ++dr)
-          msg(MSG::INFO) << " " << m_drawerType[dr];
-        msg(MSG::INFO) << endmsg;
-
-        if (size > m_nDrawers) {
-          ATH_MSG_INFO( "increasing m_nDrawers from " << m_nDrawers << " to " << size );
-           m_nDrawers = size;
-        }
-
-        if (size < 1) size = 1;
-        if (m_eventsPerFile == 0) {
-          m_eventsPerFile = (int) (200 / size) * 1000;
-          ATH_MSG_INFO( "Number of events per file was 0, set it to 200k/" << size << " = " << m_eventsPerFile );
-        }
-
-      } else {
-
-        ATH_MSG_ERROR( "can't find any TileDigits collections" );
-        ATH_MSG_ERROR( "can't set up fragment list for ntuple" );
-      }
-    }
-
-    // once again - check number of samples in the data
-    // but do not print any ERRORs now
-
-    // Read Digits from TDS
-    const TileDigitsContainer *digitsCnt;
-    if (evtStore()->retrieve(digitsCnt, m_digitsContainer).isSuccess()) {
-
-      // Get iterator for all TDColl in TDCont
-      TileDigitsContainer::const_iterator itColl = (*digitsCnt).begin();
-      TileDigitsContainer::const_iterator itCollEnd = (*digitsCnt).end();
-
-      // Go through all TileDigitsCollections
-      for (; itColl != itCollEnd; itColl++) {
-        if ((*itColl)->begin() != (*itColl)->end()) {
-          int siz = (*(*itColl)->begin())->samples().size();
-          if (siz > m_nSamples && m_nSamples != 0) {
-            ATH_MSG_WARNING(  "Increasing number of digit samples in ntuple from "
-                             << m_nSamples << " to " << siz );
-            m_nSamples = siz;
-          }
-        }
-      }
-    } else {
-      if (m_nSamples != 0) {
-        ATH_MSG_WARNING( "Disable digit samples in ntuple" );
-        m_nSamples = 0;
-      }
-    }
-  }
-
-  return StatusCode::SUCCESS;
-}
-
-
-
-//////////////////////////////////////////////////////////////////////////////
-void TileTBNtuple::getEta() {
-
-  // Get eta from an ASCII file with the following structure : 
-  // runnumber eta
-
-  ATH_MSG_INFO( "Get eta for run " << m_runNumber );
-
-  // Find the full path to filename:
-  std::string fileName = PathResolver::find_file(m_etaFileName, "DATAPATH");
-  ATH_MSG_INFO( "Reading file  " << fileName );
-
-  if (fileName.size() == 0) {
-    ATH_MSG_WARNING( "Could not find input file " << m_etaFileName );
-    ATH_MSG_WARNING( "Skip reading of eta value " );
-
-  } else {
-
-    std::ifstream etafile;
-    etafile.open(fileName.c_str());
-
-    if (etafile.good()) {
-
-      int runNumber = 0;
-      float eta = 0;
-      while ((runNumber != m_runNumber) && (!etafile.eof())) {
-        etafile >> runNumber >> eta;
-      }
-
-      if (runNumber != m_runNumber) {
-        ATH_MSG_INFO( "Run " << m_runNumber << " has not been found, keep eta and theta at zero" );
-        m_eta = m_theta = 0.0;
-      } else {
-        m_eta = eta;
-        m_theta = (M_PI_2 - 2 * atan(exp(m_eta)));
-        ATH_MSG_INFO( "Run " << m_runNumber
-                             << " has been found with eta=" << m_eta
-                             << ", theta =" << m_theta );
-      }
-
-    } else {
-
-      ATH_MSG_WARNING( "Problem with file " << fileName );
-      ATH_MSG_WARNING( "Skip reading of eta value " );
-    }
-
-    etafile.close();
-  }
-}
diff --git a/TileCalorimeter/TileTBRec/src/TileTBOldNtupleRead.cxx b/TileCalorimeter/TileTBRec/src/TileTBOldNtupleRead.cxx
deleted file mode 100644
index 0302d413bfdf200be09c3869d3917a19839c34d1..0000000000000000000000000000000000000000
--- a/TileCalorimeter/TileTBRec/src/TileTBOldNtupleRead.cxx
+++ /dev/null
@@ -1,322 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "Rtypes.h"
-#include "TileTBRec/TileTBOldNtupleRead.h"
-#include "TileTBRec/TileTBOldNtupleStruct.h"
-
-//Gaudi Includes
-#include "GaudiKernel/Bootstrap.h"
-#include "GaudiKernel/ISvcLocator.h"
-#include "GaudiKernel/IMessageSvc.h"
-#include "GaudiKernel/IDataProviderSvc.h"
-#include "GaudiKernel/IIncidentSvc.h"
-#include "GaudiKernel/SmartDataPtr.h"
-#include "StoreGate/StoreGateSvc.h"
-
-//TileCalo includes
-#include "CaloIdentifier/TileID.h"
-#include "TileIdentifier/TileHWID.h"
-#include "TileIdentifier/TileTBFrag.h"
-#include "TileConditions/TileCablingService.h"
-#include "TileEvent/TileDigitsContainer.h"
-#include "TileEvent/TileBeamElemContainer.h"
-#include "TileRecUtils/TileBeamInfoProvider.h"
-
-TileTBOldNtupleRead * TileTBOldNtupleRead::s_instance = 0;
-
-TileTBOldNtupleRead * TileTBOldNtupleRead::getInstance()
-{
-  return s_instance;
-}
-
-TileTBOldNtupleRead::TileTBOldNtupleRead(std::string name, ISvcLocator* pSvcLocator)
-  : AthAlgorithm(name, pSvcLocator)
-  , m_tileHWID(0)
-  , m_cabling(0)
-  , m_beamInfo("TileBeamInfoProvider")
-  , m_trigType(0)
-  , m_file(0)
-  , m_ntuple(0)
-  , m_ntupleStruct(0)
-{
-  m_eventShift.resize(6);
-  declareProperty("NtupleID",m_ntupleID = "h1000");
-  declareProperty("NtupleDir",m_ntupleDir = ".");
-  declareProperty("RunNumber",m_runNumber = 0);
-  declareProperty("TileDigitsContainer", m_digitsContainer = "TileDigitsCnt");
-  declareProperty("TileBeamElemContainer",m_beamContainer = "TileBeamElemCnt");
-  declareProperty("BiGain",m_bigain = false);
-  declareProperty("FrameLength", m_nSamp = 9);
-  declareProperty("PmtOrder", m_pmtOrder = true);
-  declareProperty("BarrelOnly", m_barrelOnly = false);
-  declareProperty("SkipEvents", m_eventNumber = 0);
-  declareProperty("AdderFit", m_adderFit = true);
-  declareProperty("EventShift", m_eventShift);
-
-  m_maxEventNumber=0;
-
-  s_instance = this;
-}
-
-TileTBOldNtupleRead::~TileTBOldNtupleRead() 
-{
-}
-
-//==============================================
-// initialize
-//==============================================
-StatusCode TileTBOldNtupleRead::initialize() 
-{
-  ATH_MSG_INFO ( "Initialization started" );
-  
-  // find TileCablingService
-  m_cabling = TileCablingService::getInstance();
-
-  ATH_CHECK( detStore()->retrieve(m_tileHWID) );
-
-  ATH_CHECK( m_beamInfo.retrieve() );
-  ATH_CHECK( m_beamInfo->setProperty("TileBeamElemContainer",m_beamContainer) );
-  ATH_CHECK( m_beamInfo->setProperty("TileDigitsContainer",m_digitsContainer) );
-
-  m_eventShift.resize(8);
-  for (int i=0; i<6; ++i) { // find miminum and maximum event shift
-    if (m_eventShift[i] < m_eventShift[6] ) m_eventShift[6] = m_eventShift[i];
-    if (m_eventShift[i] > m_eventShift[7] ) m_eventShift[7] = m_eventShift[i];
-  }
-  
-  if (m_eventNumber < 0) m_eventNumber = 0;
-  
-  if (m_eventNumber+m_eventShift[6]<0) {
-    ATH_MSG_INFO ( "Adjusting first ntuple entry to read, setting it to " << -m_eventShift[6] );
-    m_eventNumber = -m_eventShift[6] - 1;
-  } else {
-    ATH_MSG_INFO ( "Reading old ntuple starting from entry " << m_eventNumber );
-    m_eventNumber -= 1;
-  }
-  
-  if (m_eventShift[6] != 0 || m_eventShift[7] != 0) {
-    ATH_MSG_INFO ( "Additional shift for drawers"
-                   << "  N0: " << m_eventShift[0]
-                   << "  N1: " << m_eventShift[1]
-                   << "  N2: " << m_eventShift[2]
-                   << "  P0: " << m_eventShift[3]
-                   << "  P1: " << m_eventShift[4]
-                   << "  P2: " << m_eventShift[5] );
-  }
-
-  char fname[100];
-  sprintf(fname,"%s/r%7.7d.root",m_ntupleDir.c_str(),m_runNumber);
-  m_file=new TFile(fname,"OLD");
-  if (m_file == NULL) {
-    ATH_MSG_ERROR ( "File not found: " << fname );
-    return StatusCode::FAILURE;
-  }
-
-  m_ntuple=(TTree*)(m_file->Get(m_ntupleID.c_str()));
-  if (m_ntuple == NULL) {
-    ATH_MSG_ERROR ( "Ntuple not found: " << m_ntupleID );
-    return StatusCode::FAILURE;
-  }
-
-  if (m_nSamp != 9) {
-    ATH_MSG_ERROR ( "Unexpected number of samples: " << m_nSamp );
-    return StatusCode::FAILURE;
-  }
-  
-  m_maxEventNumber = m_ntuple->GetEntries() - m_eventShift[7];
-  ATH_MSG_INFO ( "Max available entry to read " << m_maxEventNumber );
-  
-  if (m_bigain) {
-    ATH_MSG_INFO ( "Assuming bi-gain ntuple structure with " << m_nSamp << " samples" );
-  } else {
-    ATH_MSG_INFO ( "Assuming mono-gain ntuple structure with " << m_nSamp << " samples" );
-  }
-
-  m_ntupleStruct = new TileTBOldNtupleStruct(m_ntuple,m_bigain,m_adderFit,m_eventShift);
-
-  ATH_MSG_INFO ( "Initialization completed." );
-  return StatusCode::SUCCESS;
-}
-
-//==============================================
-// execute
-//==============================================
-StatusCode TileTBOldNtupleRead::execute() 
-{
-  ++m_eventNumber;
-  if (m_eventNumber >= m_maxEventNumber) {
-    ATH_MSG_ERROR ( "All " << m_eventNumber << " entries processed. " );
-    return StatusCode::FAILURE;
-  }
-
-  m_ntupleStruct->GetEntry(m_eventNumber);
-  ATH_MSG_DEBUG ( "Reading entry " << m_eventNumber 
-                  << " event number from ntuple is " << m_ntupleStruct->Evt );
-  
-  // Fill beam elements container (PATTERN UNIT and CISPAR only)
-  TileBeamElemContainer* pBeamContainer = new TileBeamElemContainer(true);
-
-  m_trigType = m_ntupleStruct->Trig;
-  ATH_MSG_VERBOSE ( "Trig type = " << m_trigType );
-  HWIdentifier adc_id = m_tileHWID->adc_id(0,LASE_PTN_FRAG,0,0);
-  int value = (m_trigType << 8);
-  TileBeamElem * rc = new TileBeamElem(adc_id,value);
-  pBeamContainer->push_back(rc);
-
-  if (msgLvl(MSG::VERBOSE)) msg() << MSG::VERBOSE << "Cis par:";
-  for(int ch=0; ch<12; ++ch) {
-    adc_id = m_tileHWID->adc_id(0,DIGI_PAR_FRAG,ch,0);
-    value = m_ntupleStruct->cispar[ch];
-    if (msgLvl(MSG::VERBOSE)) msg() << "  " << value;
-    TileBeamElem * rc = new TileBeamElem(adc_id,value);
-    pBeamContainer->push_back(rc);
-  }
-  if (msgLvl(MSG::VERBOSE)) msg() << endmsg;
-  StatusCode sc=evtStore()->record(pBeamContainer, m_beamContainer, false);
-  if(sc.isFailure()) {
-    ATH_MSG_ERROR( "Failed to register the container: " << m_beamContainer );
-  }
-  
-  // Fill the TileDigitsContainer
-  TileDigitsContainer* pDigitsContainer = new TileDigitsContainer(true);
-  std::vector<double> digitSamples(m_nSamp);
-  
-  if (m_bigain) {
-
-    for(int iros=1; iros<=2; ++iros) { // loop over Positive/Negative side
-
-      for(int dr=0; dr<3; ++dr) { // loop over drawers 0,1,2
-
-        // cabling for testbeam (change ros for ext.barrel)
-        int ros = drawer2ros(iros,dr);
-        int drawerInd = (iros%2 == 0) ? dr : dr+3; // positive drawers shifted by 3
-
-	for(int ch=0; ch<48; ++ch) { // loop over channels
-
-          // cabling for testbeam (convert channel to pmt#-1)
-          int pmt = (m_pmtOrder) ? digiChannel2PMT(ros,ch) : ch;
-
-          for (int gain=0; gain<2; ++gain) {
-            
-            UShort_t * samples = 0;
-            switch (drawerInd*2+gain) {
-            case  0: samples = m_ntupleStruct->Samplen0lo[pmt]; break;
-            case  1: samples = m_ntupleStruct->Samplen0hi[pmt]; break;
-            case  2: samples = m_ntupleStruct->Samplen1lo[pmt]; break;
-            case  3: samples = m_ntupleStruct->Samplen1hi[pmt]; break;
-            case  4: samples = m_ntupleStruct->Samplen2lo[pmt]; break;
-            case  5: samples = m_ntupleStruct->Samplen2hi[pmt]; break;
-            case  6: samples = m_ntupleStruct->Samplep0lo[pmt]; break;
-            case  7: samples = m_ntupleStruct->Samplep0hi[pmt]; break;
-            case  8: samples = m_ntupleStruct->Samplep1lo[pmt]; break;
-            case  9: samples = m_ntupleStruct->Samplep1hi[pmt]; break;
-            case 10: samples = m_ntupleStruct->Samplep2lo[pmt]; break;
-            case 11: samples = m_ntupleStruct->Samplep2hi[pmt]; break;
-            default:
-              ATH_MSG_ERROR ( "Bad drawer ID: IROS=" << iros << ", dr=" << dr );
-            }
-
-            HWIdentifier adc_id = m_tileHWID->adc_id(ros,dr,ch,gain);
-            if (msgLvl(MSG::VERBOSE))
-              msg() << MSG::VERBOSE << m_tileHWID->to_string(adc_id)
-                  << " ch=" << ch << " pmt=" << pmt+1 << " gain=" << gain << " samples: ";
-          
-            if (samples) {
-              for(int i=0; i<m_nSamp; ++i) {
-                digitSamples[i] = samples[i];
-                if (msgLvl(MSG::VERBOSE)) msg() << " " << digitSamples[i];
-              }
-            } else {
-              for(int i=0; i<m_nSamp; ++i) {
-                digitSamples[i] = 0;
-              }
-            }
-            if (msgLvl(MSG::VERBOSE)) msg() << endmsg;
-          	  
-            TileDigits * digi = new TileDigits(adc_id,digitSamples);
-            pDigitsContainer->push_back(digi);
-            //if (verbose) {
-              //log << MSG::VERBOSE << m_tileHWID->to_string(adc_id) << " " << (std::string)(*digi) << endmsg;
-            //}
-          }
-	}
-      }
-    }
-
-  } else { // mono gain
-
-    for(int iros=1; iros<=2; ++iros) { // loop over Positive/Negative side
-
-      for(int dr=0; dr<3; ++dr) { // loop over drawers 0,1,2
-
-        // cabling for testbeam (change ros for ext.barrel)
-        int ros = drawer2ros(iros,dr);
-        int drawerInd = (iros%2 == 0) ? dr : dr+3; // positive drawers shifted by 3
-
-	for(int ch=0; ch<48; ++ch) { // loop over channels
-
-          // cabling for testbeam (convert channel to pmt#-1)
-          int pmt = (m_pmtOrder) ? digiChannel2PMT(ros,ch) : ch;
-
-          int gain = 0;
-          UShort_t * samples = 0;
-          switch (drawerInd) {
-          case 0: gain = m_ntupleStruct->Gainn0lo[pmt]; samples = m_ntupleStruct->Samplen0lo[pmt]; break;
-          case 1: gain = m_ntupleStruct->Gainn1lo[pmt]; samples = m_ntupleStruct->Samplen1lo[pmt]; break;
-          case 2: gain = m_ntupleStruct->Gainn2lo[pmt]; samples = m_ntupleStruct->Samplen2lo[pmt]; break;
-          case 3: gain = m_ntupleStruct->Gainp0lo[pmt]; samples = m_ntupleStruct->Samplep0lo[pmt]; break;
-          case 4: gain = m_ntupleStruct->Gainp1lo[pmt]; samples = m_ntupleStruct->Samplep1lo[pmt]; break;
-          case 5: gain = m_ntupleStruct->Gainp2lo[pmt]; samples = m_ntupleStruct->Samplep2lo[pmt]; break;
-          default:
-            ATH_MSG_ERROR ( "Bad drawer ID: IROS=" << iros << ", dr=" << dr );
-          }
-
-	  HWIdentifier adc_id = m_tileHWID->adc_id(ros,dr,ch,gain);
-          if (msgLvl(MSG::VERBOSE))
-            msg() << MSG::VERBOSE << m_tileHWID->to_string(adc_id)
-                << " ch=" << ch << " pmt=" << pmt+1 << " gain=" << gain << " samples: ";
-          
-	  for(int i=0; i<m_nSamp; ++i) {
-            digitSamples[i] = samples[i];
-            if (msgLvl(MSG::VERBOSE)) msg() << " " << digitSamples[i];
-          }
-          if (msgLvl(MSG::VERBOSE)) msg() << endmsg;
-          	  
-	  TileDigits * digi = new TileDigits(adc_id,digitSamples);
-	  pDigitsContainer->push_back(digi);
-          //if (verbose) {
-            //log << MSG::VERBOSE << m_tileHWID->to_string(adc_id) << " " << (std::string)(*digi) << endmsg;
-	  //}
-	}
-      }
-    }
-  }
-  
-  sc=evtStore()->record(pDigitsContainer, m_digitsContainer, false);
-  if(sc.isFailure()) {
-    ATH_MSG_ERROR( "Failed to register the container: " << m_digitsContainer );
-  }
-
-  Incident inc(name(),IncidentType::BeginEvent);
-  m_beamInfo->handle (inc);
-
-  return StatusCode::SUCCESS;
-}
-  
-//==============================================
-// finalize
-//==============================================
-StatusCode TileTBOldNtupleRead::finalize() 
-{
-  ATH_MSG_INFO("finalize()");
-
-  delete m_ntuple;
-  m_file->Close();
-  delete m_file;
-  delete m_ntupleStruct;
-
-  ATH_MSG_INFO("finalize() completed successfully");
-  return StatusCode::SUCCESS;
-}
diff --git a/TileCalorimeter/TileTBRec/src/TileTBOldNtupleWrite.cxx b/TileCalorimeter/TileTBRec/src/TileTBOldNtupleWrite.cxx
deleted file mode 100644
index fc200e3a332253c03f6dc66839358948a0e39be4..0000000000000000000000000000000000000000
--- a/TileCalorimeter/TileTBRec/src/TileTBOldNtupleWrite.cxx
+++ /dev/null
@@ -1,376 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "TileTBRec/TileTBOldNtupleWrite.h"
-#include "TileTBRec/TileTBOldNtupleRead.h"
-
-//Gaudi Includes
-#include "GaudiKernel/Bootstrap.h"
-#include "GaudiKernel/ISvcLocator.h"
-#include "GaudiKernel/IMessageSvc.h"
-#include "StoreGate/StoreGateSvc.h"
-
-//TileCalo includes
-#include "CaloIdentifier/TileID.h"
-#include "TileIdentifier/TileHWID.h"
-#include "TileIdentifier/TileTBFrag.h"
-#include "TileCalibBlobObjs/TileCalibUtils.h"
-#include "TileConditions/TileCablingService.h"
-#include "TileConditions/TileCondToolEmscale.h"
-#include "TileEvent/TileDigitsContainer.h"
-#include "TileEvent/TileBeamElemContainer.h"
-#include "TileEvent/TileRawChannelContainer.h"
-
-TileTBOldNtupleWrite::TileTBOldNtupleWrite(std::string name, ISvcLocator* pSvcLocator)
-   : AthAlgorithm(name, pSvcLocator)
-   , m_bigain(0)
-   , m_calibrateEnergyThisEvent(0)
-   , m_tileHWID(0)
-   , m_cabling(0)
-   , m_tileToolEmscale("TileCondToolEmscale")
-   , m_runNumber(0)
-   , m_eventNumber(0)
-   , m_trigType(0)
-   , m_file(0)
-   , m_ntupleWrite(0)
-   , m_ntupleRead(0)
-   , m_readNtupleAlg(0)
-{
-  declareProperty("TileCondToolEmscale", m_tileToolEmscale);
-  declareProperty("NtupleID",m_ntupleID = "h1000");
-  declareProperty("NtupleDir",m_ntupleDir = ".");
-  declareProperty("TileDigitsContainer", m_digitsContainer = "TileDigitsCnt");
-  declareProperty("TileRawChannelContainerFit", m_rawChannelContainerFit = "TileRawChannelFit");
-  declareProperty("TileRawChannelContainerFlat", m_rawChannelContainerFlat = ""); // do not fill by default
-  declareProperty("PmtOrder", m_pmtOrder = true);
-  declareProperty("CalibrateEnergy", m_calibrateEnergy = true);
-}
-
-TileTBOldNtupleWrite::~TileTBOldNtupleWrite()
-{
-}
-
-StatusCode TileTBOldNtupleWrite::initialize()
-{
-  ATH_MSG_INFO ( "Initialization started" );
-  
-  // find TileCablingService
-  m_cabling = TileCablingService::getInstance();
-
-  ATH_CHECK( detStore()->retrieve(m_tileHWID) );
-  ATH_CHECK( m_tileToolEmscale.retrieve() );
-
-  m_readNtupleAlg=TileTBOldNtupleRead::getInstance();
-
-  m_bigain = m_readNtupleAlg->BiGain();
-  m_runNumber = m_readNtupleAlg->RunNumber();
-  m_eventNumber = m_readNtupleAlg->EventNumber();
-  m_ntupleRead = m_readNtupleAlg->getNtuple();
-  
-  char fname[100];
-  sprintf(fname,"%s/r%7.7d.new.root",m_ntupleDir.c_str(),m_runNumber);
-  m_file= new TFile(fname,"RECREATE");
-  m_ntupleWrite=new TTree(m_ntupleID.c_str(),m_ntupleRead->GetTitle());
-  if (m_ntupleWrite == NULL) {
-    ATH_MSG_ERROR ( "Can not create ntuple  " << m_ntupleID );
-    return StatusCode::FAILURE;
-  }
-
-  // Initialize all branches in the m->writeNtuple, using the branches and 
-  // addresses from the m->readNtuple. Like that, no assignments should be 
-  // needed. However, need to exclude the branches that are filled in later on
-  // from StoreGate.
-
-  for(int i=0; i<m_ntupleRead->GetListOfBranches()->GetEntries(); i++) {
-    TBranch * br=(TBranch*)(m_ntupleRead->GetListOfBranches()->At(i));
-    std::string name = br->GetName();
-    std::string title = br->GetTitle();
-    Float_t * ptr=this->BranchWriteNtuple(name);
-    if (ptr == NULL) { 
-      m_ntupleWrite->Branch(name.c_str(),(void*)(br->GetAddress()),title.c_str());
-    } else {
-      m_ntupleWrite->Branch(name.c_str(),(void*)ptr,title.c_str());
-    }
-  }
-
-  ATH_MSG_INFO ( "Initialization completed." );
-  return StatusCode::SUCCESS;
-}
-  
-StatusCode TileTBOldNtupleWrite::execute()
-{
-  m_eventNumber = m_readNtupleAlg->EventNumber();
-  m_trigType = m_readNtupleAlg->TrigType();
-  ATH_MSG_DEBUG ( "Writing event " << m_eventNumber << " trig Type is " << m_trigType );
-
-  // do not apply Cesium and Laser calibration for CIS events
-  m_calibrateEnergyThisEvent = m_calibrateEnergy && (m_trigType != 8);
-
-  // get named container
-  const TileRawChannelContainer* rcCnt;
-
-  if (m_rawChannelContainerFit != "" ) {
-    
-    ATH_CHECK( evtStore()->retrieve(rcCnt, m_rawChannelContainerFit) );
-
-    TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit();
-
-    // Get iterator for all TRCColl in TRCCont
-    TileRawChannelContainer::const_iterator itColl = (*rcCnt).begin(); 
-    TileRawChannelContainer::const_iterator itCollEnd = (*rcCnt).end(); 
-
-    // Go through all TileRawChannelCollections
-    for(; itColl != itCollEnd; ++itColl) {
-      
-      // go through all TileRawChannels in collection
-      TileRawChannelCollection::const_iterator it = (*itColl)->begin();
-      TileRawChannelCollection::const_iterator itEnd = (*itColl)->end();
-      
-      for(; it != itEnd; ++it) {
-        HWIdentifier hwid=(*it)->adc_HWID();
-
-        int gain = m_tileHWID->adc(hwid);
-        int channel = m_tileHWID->channel(hwid);
-        int drawer = m_tileHWID->drawer(hwid);
-        int ros = m_tileHWID->ros(hwid);
-        int drawerIdx = TileCalibUtils::getDrawerIdx(ros,drawer);
-
-        /// Cesium and Laser calibration
-        /// we assume that CIS calibration was done already in Opt. filtering
-        /// and we have already energy in pCb
-        /// after cesium calibration we still have the same pCb for A and BC cells
-        /// what we do is just set the same scale for D-cells
-        double energy =  (*it)->amplitude();
-        if(m_calibrateEnergyThisEvent) {         
-          energy = m_tileToolEmscale->channelCalib(drawerIdx, channel, gain, energy,
-                                                   rChUnit, TileRawChannelUnit::CesiumPicoCoulombs);
-          /// probably we want to convert to MeV - use TileRawChannelUnit::MegaElectronVolts ?
-        }
-        
-        // cabling for testbeam (convert channel to pmt#-1)
-        int pmt = (m_pmtOrder) ? digiChannel2PMT(ros,channel) : channel;
-        
-        ATH_MSG_VERBOSE("TRC " << m_tileHWID->to_string(hwid)
-                        << " ene="<<energy<<" time="<<(*it)->time()
-                        <<" chi2="<<(*it)->quality()<<" ped="<<(*it)->pedestal()
-                        <<" pmt-1="<<pmt);
-
-        int gainMode = (m_bigain) ? gain : 0; // 0 - low gain, 1 - high gain
-        int drawerInd = (ros%2 == 0) ? drawer : drawer+3; // positive drawers shifted by 3
-
-        m_efit  [gainMode][drawerInd][pmt] = energy;
-        m_tfit  [gainMode][drawerInd][pmt] = (*it)->time();
-        m_pedfit[gainMode][drawerInd][pmt] = (*it)->pedestal();
-        m_chi2  [gainMode][drawerInd][pmt] = (*it)->quality();
-        
-      } // end of loop over channels
-    } // end of loop over collections
-  } // end of if for fit method container
-  
-
-  if (m_rawChannelContainerFlat != "" ) {
-    
-    ATH_CHECK( evtStore()->retrieve(rcCnt, m_rawChannelContainerFlat) );
-
-    TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit();
-
-    // Get iterator for all TRCColl in TRCCont
-    TileRawChannelContainer::const_iterator itColl = (*rcCnt).begin(); 
-    TileRawChannelContainer::const_iterator itCollEnd = (*rcCnt).end(); 
-
-    // Go through all TileRawChannelCollections
-    for(; itColl != itCollEnd; ++itColl) {
-      
-      // go through all TileRawChannels in collection
-      TileRawChannelCollection::const_iterator it = (*itColl)->begin();
-      TileRawChannelCollection::const_iterator itEnd = (*itColl)->end();
-      
-      for(; it != itEnd; ++it) {
-        HWIdentifier hwid=(*it)->adc_HWID();
-
-        int gain = m_tileHWID->adc(hwid);
-        int channel = m_tileHWID->channel(hwid);
-        int drawer = m_tileHWID->drawer(hwid);
-        int ros = m_tileHWID->ros(hwid);
-        int drawerIdx = TileCalibUtils::getDrawerIdx(ros,drawer);
-
-        /// Cesium and Laser calibration
-        /// we assume that CIS calibration was done already in Opt. filtering
-        /// and we have already energy in pCb
-        /// after cesium calibration we still have the same pCb for A and BC cells
-        /// what we do is just set the same scale for D-cells
-        double energy =  (*it)->amplitude();
-        if(m_calibrateEnergyThisEvent) {         
-          energy = m_tileToolEmscale->channelCalib(drawerIdx, channel, gain, energy,
-                                                   rChUnit, TileRawChannelUnit::CesiumPicoCoulombs);
-          /// probably we want to convert to MeV - use TileRawChannelUnit::MegaElectronVolts ?
-        }
-        
-        // cabling for testbeam (convert channel to pmt#-1)
-        int pmt = (m_pmtOrder) ? digiChannel2PMT(ros,channel) : channel;
-
-        ATH_MSG_VERBOSE("TRC " << m_tileHWID->to_string(hwid)
-                        << " flat ene="<<energy<<" time="<<(*it)->time()
-                        <<" pmt-1="<<pmt);
-
-        int gainMode = (m_bigain) ? gain : 0; // 0 - low gain, 1 - high gain
-        int drawerInd = (ros%2 == 0) ? drawer : drawer+3; // positive drawers shifted by 3
-
-        m_ene [gainMode][drawerInd][pmt] = energy;
-        m_time[gainMode][drawerInd][pmt] = (*it)->time();
-        
-      } // end of loop over channels
-    } // end of loop over collections
-  } // end of if for flat filter method container
-
-  m_ntupleWrite->Fill();
-
-  return StatusCode::SUCCESS;
-}
-
-StatusCode TileTBOldNtupleWrite::finalize()
-{
-  m_file->cd();
-  m_ntupleWrite->Write();
-  delete m_ntupleWrite;
-  m_file->Close();
-  delete m_file;
-
-  return StatusCode::SUCCESS;
-}
-
-Float_t * TileTBOldNtupleWrite::BranchWriteNtuple(const std::string name)
-{
-  // copy everything except of EfitXX, TfitXX, PedfitXX, Chi2XX, EneXX, TimeXX
-  // for these variables return the pointer to new private arrays
-
-  if (m_bigain) {
-    // first low-gain fit variables
-    if        (name == "Efitn0lo")   { return &m_efit[0][0][0];   
-    } else if (name == "Efitn1lo")   { return &m_efit[0][1][0];   
-    } else if (name == "Efitn2lo")   { return &m_efit[0][2][0];   
-    } else if (name == "Efitp0lo")   { return &m_efit[0][3][0];   
-    } else if (name == "Efitp1lo")   { return &m_efit[0][4][0];   
-    } else if (name == "Efitp2lo")   { return &m_efit[0][5][0];   
-    } else if (name == "Tfitn0lo")   { return &m_tfit[0][0][0];   
-    } else if (name == "Tfitn1lo")   { return &m_tfit[0][1][0];   
-    } else if (name == "Tfitn2lo")   { return &m_tfit[0][2][0];   
-    } else if (name == "Tfitp0lo")   { return &m_tfit[0][3][0];   
-    } else if (name == "Tfitp1lo")   { return &m_tfit[0][4][0];   
-    } else if (name == "Tfitp2lo")   { return &m_tfit[0][5][0];   
-    } else if (name == "Pedfitn0lo") { return &m_pedfit[0][0][0]; 
-    } else if (name == "Pedfitn1lo") { return &m_pedfit[0][1][0]; 
-    } else if (name == "Pedfitn2lo") { return &m_pedfit[0][2][0]; 
-    } else if (name == "Pedfitp0lo") { return &m_pedfit[0][3][0]; 
-    } else if (name == "Pedfitp1lo") { return &m_pedfit[0][4][0]; 
-    } else if (name == "Pedfitp2lo") { return &m_pedfit[0][5][0]; 
-    } else if (name == "Chi2n0lo")   { return &m_chi2[0][0][0];   
-    } else if (name == "Chi2n1lo")   { return &m_chi2[0][1][0];   
-    } else if (name == "Chi2n2lo")   { return &m_chi2[0][2][0];   
-    } else if (name == "Chi2p0lo")   { return &m_chi2[0][3][0];   
-    } else if (name == "Chi2p1lo")   { return &m_chi2[0][4][0];   
-    } else if (name == "Chi2p2lo")   { return &m_chi2[0][5][0];
-
-    // now high-gain fit variables
-    } else if (name == "Efitn0hi")   { return &m_efit[1][0][0];   
-    } else if (name == "Efitn1hi")   { return &m_efit[1][1][0];   
-    } else if (name == "Efitn2hi")   { return &m_efit[1][2][0];   
-    } else if (name == "Efitp0hi")   { return &m_efit[1][3][0];   
-    } else if (name == "Efitp1hi")   { return &m_efit[1][4][0];   
-    } else if (name == "Efitp2hi")   { return &m_efit[1][5][0];   
-    } else if (name == "Tfitn0hi")   { return &m_tfit[1][0][0];   
-    } else if (name == "Tfitn1hi")   { return &m_tfit[1][1][0];   
-    } else if (name == "Tfitn2hi")   { return &m_tfit[1][2][0];   
-    } else if (name == "Tfitp0hi")   { return &m_tfit[1][3][0];   
-    } else if (name == "Tfitp1hi")   { return &m_tfit[1][4][0];   
-    } else if (name == "Tfitp2hi")   { return &m_tfit[1][5][0];   
-    } else if (name == "Pedfitn0hi") { return &m_pedfit[1][0][0]; 
-    } else if (name == "Pedfitn1hi") { return &m_pedfit[1][1][0]; 
-    } else if (name == "Pedfitn2hi") { return &m_pedfit[1][2][0]; 
-    } else if (name == "Pedfitp0hi") { return &m_pedfit[1][3][0]; 
-    } else if (name == "Pedfitp1hi") { return &m_pedfit[1][4][0]; 
-    } else if (name == "Pedfitp2hi") { return &m_pedfit[1][5][0]; 
-    } else if (name == "Chi2n0hi")   { return &m_chi2[1][0][0];   
-    } else if (name == "Chi2n1hi")   { return &m_chi2[1][1][0];   
-    } else if (name == "Chi2n2hi")   { return &m_chi2[1][2][0];   
-    } else if (name == "Chi2p0hi")   { return &m_chi2[1][3][0];   
-    } else if (name == "Chi2p1hi")   { return &m_chi2[1][4][0];   
-    } else if (name == "Chi2p2hi")   { return &m_chi2[1][5][0];   
-
-    // now low-gain flat filter variables
-    } else if (m_rawChannelContainerFlat != "" && name == "Enen0lo")    { return &m_ene[0][0][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enen1lo")    { return &m_ene[0][1][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enen2lo")    { return &m_ene[0][2][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enep0lo")    { return &m_ene[0][3][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enep1lo")    { return &m_ene[0][4][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enep2lo")    { return &m_ene[0][5][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timen0lo")   { return &m_time[0][0][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timen1lo")   { return &m_time[0][1][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timen2lo")   { return &m_time[0][2][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timep0lo")   { return &m_time[0][3][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timep1lo")   { return &m_time[0][4][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timep2lo")   { return &m_time[0][5][0];   
-
-    // now high-gain flat filter variables
-    } else if (m_rawChannelContainerFlat != "" && name == "Enen0hi")    { return &m_ene[1][0][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enen1hi")    { return &m_ene[1][1][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enen2hi")    { return &m_ene[1][2][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enep0hi")    { return &m_ene[1][3][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enep1hi")    { return &m_ene[1][4][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enep2hi")    { return &m_ene[0][5][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timen0hi")   { return &m_time[1][0][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timen1hi")   { return &m_time[1][1][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timen2hi")   { return &m_time[1][2][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timep0hi")   { return &m_time[1][3][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timep1hi")   { return &m_time[1][4][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timep2hi")   { return &m_time[1][5][0];   
-
-    } else {
-      return(NULL);
-    }
-  } else { // monogain
-
-    if        (name == "Efitn0")   { return &m_efit[0][0][0];   
-    } else if (name == "Efitn1")   { return &m_efit[0][1][0];   
-    } else if (name == "Efitn2")   { return &m_efit[0][2][0];   
-    } else if (name == "Efitp0")   { return &m_efit[0][3][0];   
-    } else if (name == "Efitp1")   { return &m_efit[0][4][0];   
-    } else if (name == "Efitp2")   { return &m_efit[0][5][0];   
-    } else if (name == "Tfitn0")   { return &m_tfit[0][0][0];   
-    } else if (name == "Tfitn1")   { return &m_tfit[0][1][0];   
-    } else if (name == "Tfitn2")   { return &m_tfit[0][2][0];   
-    } else if (name == "Tfitp0")   { return &m_tfit[0][3][0];   
-    } else if (name == "Tfitp1")   { return &m_tfit[0][4][0];   
-    } else if (name == "Tfitp2")   { return &m_tfit[0][5][0];   
-    } else if (name == "Pedfitn0") { return &m_pedfit[0][0][0]; 
-    } else if (name == "Pedfitn1") { return &m_pedfit[0][1][0]; 
-    } else if (name == "Pedfitn2") { return &m_pedfit[0][2][0]; 
-    } else if (name == "Pedfitp0") { return &m_pedfit[0][3][0]; 
-    } else if (name == "Pedfitp1") { return &m_pedfit[0][4][0]; 
-    } else if (name == "Pedfitp2") { return &m_pedfit[0][5][0]; 
-    } else if (name == "Chi2n0")   { return &m_chi2[0][0][0];   
-    } else if (name == "Chi2n1")   { return &m_chi2[0][1][0];   
-    } else if (name == "Chi2n2")   { return &m_chi2[0][2][0];   
-    } else if (name == "Chi2p0")   { return &m_chi2[0][3][0];   
-    } else if (name == "Chi2p1")   { return &m_chi2[0][4][0];   
-    } else if (name == "Chi2p2")   { return &m_chi2[0][5][0];   
-
-    } else if (m_rawChannelContainerFlat != "" && name == "Enen0")    { return &m_ene[0][0][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enen1")    { return &m_ene[0][1][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enen2")    { return &m_ene[0][2][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enep0")    { return &m_ene[0][3][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enep1")    { return &m_ene[0][4][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Enep2")    { return &m_ene[0][5][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timen0")   { return &m_time[0][0][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timen1")   { return &m_time[0][1][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timen2")   { return &m_time[0][2][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timep0")   { return &m_time[0][3][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timep1")   { return &m_time[0][4][0];   
-    } else if (m_rawChannelContainerFlat != "" && name == "Timep2")   { return &m_time[0][5][0];   
-
-    } else {
-      return(NULL);
-    }
-  }
-}  
diff --git a/TileCalorimeter/TileTBRec/src/TileTBStat.cxx b/TileCalorimeter/TileTBRec/src/TileTBStat.cxx
index 6ee6ad8defd50b0791cbe4ca6ff38e0649def8f7..10eaebfe26a818f0497933252eb489e9bdec6fa0 100755
--- a/TileCalorimeter/TileTBRec/src/TileTBStat.cxx
+++ b/TileCalorimeter/TileTBRec/src/TileTBStat.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
 */
 
 //*****************************************************************************
@@ -22,6 +22,7 @@
 //Atlas include
 #include "eformat/FullEventFragment.h"
 #include "ByteStreamCnvSvcBase/ROBDataProviderSvc.h"
+#include "StoreGate/ReadHandle.h"
 #include "AthenaKernel/errorcheck.h"
 
 //TileCal include
@@ -31,7 +32,6 @@
 #include "TileEvent/TileDigitsContainer.h"
 #include "TileEvent/TileBeamElemContainer.h"
 #include "TileEvent/TileLaserObject.h"
-#include "TileRecUtils/TileBeamInfoProvider.h"
 #include "TileByteStream/TileBeamElemContByteStreamCnv.h"
 #include "TileTBRec/TileTBStat.h"
 
@@ -125,7 +125,6 @@ void StatInt::print(const char* s, bool minMaxOnly) {
 TileTBStat::TileTBStat(std::string name, ISvcLocator* pSvcLocator)
   : AthAlgorithm(name, pSvcLocator)
   , m_RobSvc("ROBDataProviderSvc", name)
-  , m_beamInfo("TileBeamInfoProvider/TileBeamInfoProvider")
   , m_beamCnv(0)
   , m_evtNr(0)
   , m_lasStatus(0)
@@ -156,6 +155,7 @@ TileTBStat::TileTBStat(std::string name, ISvcLocator* pSvcLocator)
 
   declareProperty("PrintAllEvents", m_printAllEvents = false);
   declareProperty("DetectDummyFragments", m_detectDummyFragments = false);
+  declareProperty("TileDQstatus", m_dqStatusKey = "TileDQstatus");
 
   m_runNo = m_evtMin =  m_evtMax = m_evtBegin = m_evtNo = 0;
 
@@ -179,11 +179,6 @@ StatusCode TileTBStat::initialize() {
   
   m_lasStatus = 0;
 
-
-  CHECK(  m_beamInfo.retrieve() );
-  CHECK( m_beamInfo->setProperty("TileBeamElemContainer", m_beamElemContainer) );
-  CHECK( m_beamInfo->setProperty("TileDigitsContainer", m_digitsContainer) );
-
   // start with event 0
   m_evtNr = 0;
   m_runNo = m_evTime = m_evtNo = m_trigType = m_nSpill = m_timeBegin = m_timeLast = m_evtMax = 0;
@@ -196,11 +191,15 @@ StatusCode TileTBStat::initialize() {
   m_timeStart = time(0);
   ATH_MSG_INFO( "initialization completed" );
 
+  CHECK( m_dqStatusKey.initialize() );
+
   return StatusCode::SUCCESS;
 } 
 
 StatusCode TileTBStat::execute() {
 
+  const EventContext& ctx = Gaudi::Hive::currentContext();
+  const TileDQstatus* dqStatus = SG::makeHandle (m_dqStatusKey, ctx).get();
 
   static bool first=true;
   static bool firstORsecond=true;
@@ -296,11 +295,11 @@ StatusCode TileTBStat::execute() {
       }
 
       if (m_printAllEvents)
-        std::cout << "Fragments found in event " << m_beamCnv->eventFragment()->global_id() << "  calib mode=" << m_beamInfo->checkCalibMode() << std::endl;
+        std::cout << "Fragments found in event " << m_beamCnv->eventFragment()->global_id() << "  calib mode=" << dqStatus->calibMode() << std::endl;
       else if (firstORsecond)
-        std::cout << "Fragments found in first event, calib mode=" << m_beamInfo->checkCalibMode() << std::endl;
+        std::cout << "Fragments found in first event, calib mode=" << dqStatus->calibMode() << std::endl;
       else
-        std::cout << "Fragments found in second event, calib mode=" << m_beamInfo->checkCalibMode() << std::endl;
+        std::cout << "Fragments found in second event, calib mode=" << dqStatus->calibMode() << std::endl;
       std::cout << "  ROB ID   ROD ID   Frag IDs" << std::endl;
       for (unsigned int i = 0; i < nrob; ++i) {
         std::cout << std::hex << " 0x" << m_fragMap[i].ROBid << " 0x" << m_fragMap[i].RODid;
@@ -313,7 +312,7 @@ StatusCode TileTBStat::execute() {
   
   // take values from event header
 
-  memcpy(m_cisPar,m_beamInfo->cispar(), sizeof (m_cisPar));
+  memcpy(m_cisPar,dqStatus->cispar(), sizeof (m_cisPar));
   
   unsigned int testsum=0;
   for (int k = 4; k < 16; ++k) testsum += m_cisPar[k];
@@ -342,7 +341,7 @@ StatusCode TileTBStat::execute() {
     m_evTime = m_cisPar[10];
   }
   
-  m_trigType = m_beamInfo->trigType();
+  m_trigType = dqStatus->trigType();
   if (m_trigType < 1 || m_trigType > 0x80 ) {
     if (m_evtNr == 0)
       ATH_MSG_WARNING( "no event trig type available (" << m_trigType << ") , taking trig from cispar (" << m_cisPar[12] << ")" );
@@ -362,11 +361,11 @@ StatusCode TileTBStat::execute() {
 
     m_timeBegin = m_evTime;
     m_evtBegin  = m_evtNo;
-    m_calibMode = m_beamInfo->calibMode();
+    m_calibMode = dqStatus->calibMode();
     memcpy(m_cisBeg,m_cisPar,sizeof(m_cisBeg));
   } else if (m_evtNr == 1) {
     // once again, first event can be junk
-    m_calibMode = m_beamInfo->calibMode();
+    m_calibMode = dqStatus->calibMode();
   }
 
   if ( ( m_evTime < m_timeBegin && (m_timeBegin - m_evTime) < 10*24*3600 ) ||  // less then 10 days shift in neg direction
diff --git a/TileCalorimeter/TileTBRec/src/components/TileTBRec_entries.cxx b/TileCalorimeter/TileTBRec/src/components/TileTBRec_entries.cxx
index 297c38bb95f5a7ce42139548005fa5faaf46bb3a..407c256632c226c250e516350282589894211e23 100644
--- a/TileCalorimeter/TileTBRec/src/components/TileTBRec_entries.cxx
+++ b/TileCalorimeter/TileTBRec/src/components/TileTBRec_entries.cxx
@@ -1,17 +1,11 @@
-#include "TileTBRec/TileTBNtuple.h"
 #include "TileTBRec/TileTBAANtuple.h"
 #include "TileTBRec/TileTBStat.h"
 #include "TileTBRec/TileTBDump.h"
-#include "TileTBRec/TileTBOldNtupleRead.h"
-#include "TileTBRec/TileTBOldNtupleWrite.h"
 #include "TileTBRec/TileDigitsGainFilter.h"
 
 
-DECLARE_COMPONENT( TileTBNtuple )
 DECLARE_COMPONENT( TileTBAANtuple )
 DECLARE_COMPONENT( TileTBStat )
 DECLARE_COMPONENT( TileTBDump )
-DECLARE_COMPONENT( TileTBOldNtupleRead )
-DECLARE_COMPONENT( TileTBOldNtupleWrite )
 DECLARE_COMPONENT( TileDigitsGainFilter )
 
diff --git a/Tools/CoolDozer/python/RTTDozerApp.py b/Tools/CoolDozer/python/RTTDozerApp.py
index e227ec66847d5c046ccf3c132e7471320e70f013..a1eaca39d378604e605b7718bef4228f19a3de7b 100644
--- a/Tools/CoolDozer/python/RTTDozerApp.py
+++ b/Tools/CoolDozer/python/RTTDozerApp.py
@@ -338,7 +338,7 @@ class RTTDozerApp( DozerApp ):
             
 
         else:
-            self.panic("--> db is closed, crap!")
+            self.panic("--> db is closed!")
             self.html( "Cannot open db..." )
         self.info("-> exiting reader")
         
diff --git a/Tools/PyUtils/python/scripts/gen_klass.py b/Tools/PyUtils/python/scripts/gen_klass.py
index 6dfe33145024f4cf249233a708e9b16559f1cebb..8b76c4c07907d0a43f01f5f758883f2c09b5e1dd 100644
--- a/Tools/PyUtils/python/scripts/gen_klass.py
+++ b/Tools/PyUtils/python/scripts/gen_klass.py
@@ -269,7 +269,7 @@ public:
   virtual ~%(klass)s() override;
 
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r(const EventContext& context) const override;
+  virtual StatusCode execute(const EventContext& context) const override;
   virtual StatusCode finalize() override;
 
 private:
@@ -306,7 +306,7 @@ StatusCode %(klass)s::finalize()
   return StatusCode::SUCCESS;
 }
 
-StatusCode %(klass)s::execute_r(const EventContext& context) const
+StatusCode %(klass)s::execute(const EventContext& context) const
 {
   return StatusCode::SUCCESS;
 }
diff --git a/Tracking/Acts/ActsGeometry/ActsGeometry/ActsExtrapolationAlg.h b/Tracking/Acts/ActsGeometry/ActsGeometry/ActsExtrapolationAlg.h
index 804781a38aa82fca8aca5ae6259e5038a1925493..8199f5b18be8772ded74582195f383c91f6b7777 100755
--- a/Tracking/Acts/ActsGeometry/ActsGeometry/ActsExtrapolationAlg.h
+++ b/Tracking/Acts/ActsGeometry/ActsGeometry/ActsExtrapolationAlg.h
@@ -51,7 +51,7 @@ class ActsExtrapolationAlg : public AthReentrantAlgorithm {
 public:
   ActsExtrapolationAlg (const std::string& name, ISvcLocator* pSvcLocator);
   StatusCode initialize() override;
-  StatusCode execute_r(const EventContext& ctx) const override;
+  StatusCode execute(const EventContext& ctx) const override;
   StatusCode finalize() override;
   
 private:
diff --git a/Tracking/Acts/ActsGeometry/src/ActsExtrapolationAlg.cxx b/Tracking/Acts/ActsGeometry/src/ActsExtrapolationAlg.cxx
index f3b6efd85c0d10ea1ad21ede143aa2d5852a1f0e..7116c589e66a3718333779faaf679bd98fb98f0f 100755
--- a/Tracking/Acts/ActsGeometry/src/ActsExtrapolationAlg.cxx
+++ b/Tracking/Acts/ActsGeometry/src/ActsExtrapolationAlg.cxx
@@ -58,7 +58,7 @@ StatusCode ActsExtrapolationAlg::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode ActsExtrapolationAlg::execute_r(const EventContext& ctx) const 
+StatusCode ActsExtrapolationAlg::execute(const EventContext& ctx) const 
 {
 
   ATH_MSG_VERBOSE(name() << "::" << __FUNCTION__);
diff --git a/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/TrkCollectionAliasAlg/TrkCollectionAliasAlg.h b/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/TrkCollectionAliasAlg/TrkCollectionAliasAlg.h
index 76247d48f6bdb14b0aa2ee5476404d67070045fb..f04d848c49879d0c212b8029efb4dcbafa8e50d9 100755
--- a/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/TrkCollectionAliasAlg/TrkCollectionAliasAlg.h
+++ b/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/TrkCollectionAliasAlg/TrkCollectionAliasAlg.h
@@ -39,7 +39,7 @@ namespace Trk
        /** standard Athena-Algorithm method */
        StatusCode          initialize();
        /** standard Athena-Algorithm method */
-       StatusCode          execute_r(const EventContext& ctx) const;
+       StatusCode          execute(const EventContext& ctx) const;
        /** standard Athena-Algorithm method */
        StatusCode          finalize();
 
diff --git a/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/src/TrkCollectionAliasAlg.cxx b/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/src/TrkCollectionAliasAlg.cxx
index 74255a52b705ea39e43ad40308262d010c15ca14..5f8f82ab459cbedc01d3a6e6f5739eafe8c70b6b 100755
--- a/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/src/TrkCollectionAliasAlg.cxx
+++ b/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/src/TrkCollectionAliasAlg.cxx
@@ -43,7 +43,7 @@ StatusCode Trk::TrkCollectionAliasAlg::finalize()
 
 //================ Execution ====================================================
 
-StatusCode Trk::TrkCollectionAliasAlg::execute_r(const EventContext& ctx) const
+StatusCode Trk::TrkCollectionAliasAlg::execute(const EventContext& ctx) const
 {
   SG::ReadHandle<TrackCollection> tracks(m_collectionName, ctx );
   return tracks.alias(m_aliasName);
diff --git a/Tracking/TrkFitter/TrkRefitAlg/CMakeLists.txt b/Tracking/TrkFitter/TrkRefitAlg/CMakeLists.txt
index 70017f1ba32d32f52a137c14cb6f433a7b46f7d5..aff343f6fe6ec53e810b945fbb4f72fcb8a55c5f 100644
--- a/Tracking/TrkFitter/TrkRefitAlg/CMakeLists.txt
+++ b/Tracking/TrkFitter/TrkRefitAlg/CMakeLists.txt
@@ -15,7 +15,6 @@ atlas_depends_on_subdirs( PUBLIC
                           Tracking/TrkFitter/TrkFitterUtils
                           InnerDetector/InDetConditions/BeamSpotConditionsData
                           PRIVATE
-                          InnerDetector/InDetConditions/InDetBeamSpotService
                           Tracking/TrkDetDescr/TrkSurfaces
                           Tracking/TrkEvent/TrkMeasurementBase
                           Tracking/TrkEvent/TrkParameters
diff --git a/Tracking/TrkFitter/TrkRefitAlg/src/ReFitTrack.cxx b/Tracking/TrkFitter/TrkRefitAlg/src/ReFitTrack.cxx
index 71e2448159d54c800874aa049bd29af7601fb97d..0ddf51b33f948f1ea0e1a3f34611efa962018b3c 100755
--- a/Tracking/TrkFitter/TrkRefitAlg/src/ReFitTrack.cxx
+++ b/Tracking/TrkFitter/TrkRefitAlg/src/ReFitTrack.cxx
@@ -27,7 +27,6 @@
 #include "TrkToolInterfaces/IPRD_AssociationTool.h"
 #include "TrkToolInterfaces/ITrackSelectorTool.h"
 #include "TrkExInterfaces/IExtrapolator.h"
-#include "InDetBeamSpotService/IBeamCondSvc.h"
 #include "VxVertex/VxContainer.h"
 #include "VxVertex/RecVertex.h"
 
diff --git a/Tracking/TrkTools/TrkParticleCreator/CMakeLists.txt b/Tracking/TrkTools/TrkParticleCreator/CMakeLists.txt
index a18f7f9f6c123d3fcf9416d3b9f816c87cdb84d8..88a0726d4b452a8d673039657a5f734017f2f2fb 100644
--- a/Tracking/TrkTools/TrkParticleCreator/CMakeLists.txt
+++ b/Tracking/TrkTools/TrkParticleCreator/CMakeLists.txt
@@ -27,7 +27,6 @@ atlas_depends_on_subdirs(
    DetectorDescription/AtlasDetDescr
    DetectorDescription/GeoPrimitives
    DetectorDescription/IdDictDetDescr
-   InnerDetector/InDetConditions/InDetBeamSpotService
    InnerDetector/InDetConditions/BeamSpotConditionsData
    InnerDetector/InDetRecEvent/InDetPrepRawData
    InnerDetector/InDetRecEvent/InDetRIO_OnTrack
diff --git a/Tracking/TrkTools/TrkParticleCreator/src/TrackParticleCreatorTool.cxx b/Tracking/TrkTools/TrkParticleCreator/src/TrackParticleCreatorTool.cxx
index b737e56dac0c52189e6d3ce733032a857903a214..0f715ddce3258669c92294d86ee18229d9e3cd07 100644
--- a/Tracking/TrkTools/TrkParticleCreator/src/TrackParticleCreatorTool.cxx
+++ b/Tracking/TrkTools/TrkParticleCreator/src/TrackParticleCreatorTool.cxx
@@ -18,7 +18,6 @@
 #include "TrkExInterfaces/IExtrapolator.h"
 #include "ITrackToVertex/ITrackToVertex.h" 
 #include "MagFieldInterfaces/IMagFieldSvc.h"
-#include "InDetBeamSpotService/IBeamCondSvc.h"
 #include "TrkTrack/Track.h"
 #include "Particle/TrackParticle.h"
 #include "VxVertex/VxCandidate.h"
diff --git a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.cxx b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.cxx
index cf49de8f78d389055edc392200a96fdef1335339..66e7c47f03ac14810961ed1bf9e375fd7c45eb6e 100644
--- a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.cxx
+++ b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.cxx
@@ -44,7 +44,7 @@ StatusCode HLTCaloCellMaker::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode HLTCaloCellMaker::execute_r( const EventContext& context ) const {
+StatusCode HLTCaloCellMaker::execute( const EventContext& context ) const {
 
 
   auto roisHandle = SG::makeHandle( m_roiCollectionKey );
diff --git a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.h b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.h
index 8bc57f09856657a5cb1d15efaeb6b0ea7ef07bf3..db57c58b91c267161d379c23618545f4bed6b2d4 100644
--- a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.h
+++ b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.h
@@ -39,7 +39,7 @@ class HLTCaloCellMaker: public AthReentrantAlgorithm {
 	HLTCaloCellMaker(const std::string & name, ISvcLocator* pSvcLocator);
 	~HLTCaloCellMaker();
 
-	StatusCode execute_r(const EventContext& context ) const ;
+	StatusCode execute(const EventContext& context ) const ;
 	StatusCode initialize();
      private:
 
diff --git a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.cxx b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.cxx
index dbe2c9194df939bcea33aaf02a96c3d3a0bc6ef4..873b4471cc9d0a18d6474b356e0b5eb2e3fb42b0 100644
--- a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.cxx
+++ b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.cxx
@@ -36,7 +36,7 @@ StatusCode HLTCaloCellSumMaker::initialize() {
         return StatusCode::SUCCESS;
 }
 
-StatusCode HLTCaloCellSumMaker::execute_r( const EventContext& /*context*/ ) const {
+StatusCode HLTCaloCellSumMaker::execute( const EventContext& /*context*/ ) const {
 
 
   if ( m_roiMode ) {
diff --git a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.h b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.h
index 95349f86e12128d721b83addeef65f116e9b1c1a..573c70c15335785fde18389d8662c300e271ffc3 100644
--- a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.h
+++ b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.h
@@ -29,7 +29,7 @@ class HLTCaloCellSumMaker: public AthReentrantAlgorithm {
         HLTCaloCellSumMaker(const std::string & name, ISvcLocator* pSvcLocator);
         ~HLTCaloCellSumMaker();
 
-        StatusCode execute_r(const EventContext& context ) const ;
+        StatusCode execute(const EventContext& context ) const ;
         StatusCode initialize();
      private:
 
diff --git a/Trigger/TrigAlgorithms/TrigEFMissingET/TrigEFMissingET/EFMissingETAlgMT.h b/Trigger/TrigAlgorithms/TrigEFMissingET/TrigEFMissingET/EFMissingETAlgMT.h
index 6c844543d1222b3f194da1d062318e7b97268909..3c463bc32749454104eba126ac9fd85100d6c096 100644
--- a/Trigger/TrigAlgorithms/TrigEFMissingET/TrigEFMissingET/EFMissingETAlgMT.h
+++ b/Trigger/TrigAlgorithms/TrigEFMissingET/TrigEFMissingET/EFMissingETAlgMT.h
@@ -32,7 +32,7 @@ class EFMissingETAlgMT : public ::AthReentrantAlgorithm
   //EFMissingETMT &operator=(const EFMissingETMT &alg); 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r(const EventContext& context) const override;
+  virtual StatusCode  execute(const EventContext& context) const override;
  
  private: 
   
diff --git a/Trigger/TrigAlgorithms/TrigEFMissingET/src/EFMissingETAlgMT.cxx b/Trigger/TrigAlgorithms/TrigEFMissingET/src/EFMissingETAlgMT.cxx
index 55b1375d0a63636ae2f169479a4c770514f08926..1deffc8ab57dcc42a03fd5623cbc16ead2bc65d4 100644
--- a/Trigger/TrigAlgorithms/TrigEFMissingET/src/EFMissingETAlgMT.cxx
+++ b/Trigger/TrigAlgorithms/TrigEFMissingET/src/EFMissingETAlgMT.cxx
@@ -41,7 +41,7 @@ double toLinGeV( double x, double fallback = 0, double epsilon = 1e-6 ) {
 }
 
 
-StatusCode EFMissingETAlgMT::execute_r( const EventContext& context ) const {  
+StatusCode EFMissingETAlgMT::execute( const EventContext& context ) const {  
   ATH_MSG_DEBUG ( "Executing " << name() << "..." );
   using namespace Monitored;
   auto totalTimer = MonitoredTimer::declare( "TIME_Total" );
diff --git a/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.cxx b/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.cxx
index 0d5c56479898d99bc186a32888dca5cc1e801319..99ac204d60a5bcca8c1124f405019def259a745c 100644
--- a/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.cxx
+++ b/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.cxx
@@ -326,7 +326,7 @@ void TestCaloDataAccess::emulateFixedRoIs( const EventContext& context, std::vec
 
 }
 
-StatusCode TestCaloDataAccess::execute_r( const EventContext& context ) const {  
+StatusCode TestCaloDataAccess::execute( const EventContext& context ) const {  
   ATH_MSG_DEBUG ( "Executing " << name() << "..." );
   
   std::vector<ParallelCallTest*> allRoIs;
diff --git a/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.h b/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.h
index 4e1adeb69133606e6156fcac959b7bbc16997cb4..2773288de16ea464296e4524346b01d52b402922 100644
--- a/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.h
+++ b/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.h
@@ -26,7 +26,7 @@ class TestCaloDataAccess
   TestCaloDataAccess( const std::string& name, ISvcLocator* pSvcLocator );
   virtual ~TestCaloDataAccess(); 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r(const EventContext& context) const override;
+  virtual StatusCode  execute(const EventContext& context) const override;
  
  private: 
   TestCaloDataAccess();
diff --git a/Trigger/TrigAlgorithms/TrigT2CaloEgamma/TrigT2CaloEgamma/T2CaloEgammaReFastAlgo.h b/Trigger/TrigAlgorithms/TrigT2CaloEgamma/TrigT2CaloEgamma/T2CaloEgammaReFastAlgo.h
index cac73b16f54145144f13e240ae2bf1521a20b21c..e8eaf1b5b194d5f9a663ec25bb09d6fe7d440145 100755
--- a/Trigger/TrigAlgorithms/TrigT2CaloEgamma/TrigT2CaloEgamma/T2CaloEgammaReFastAlgo.h
+++ b/Trigger/TrigAlgorithms/TrigT2CaloEgamma/TrigT2CaloEgamma/T2CaloEgammaReFastAlgo.h
@@ -47,7 +47,7 @@ class T2CaloEgammaReFastAlgo: public AthReentrantAlgorithm {
 
     /** main execute will call FEX IAlgToolCalo::execute() to process RoI.
 	called by the Steering per EMRoI. */
-    StatusCode execute_r(const EventContext& context ) const;
+    StatusCode execute(const EventContext& context ) const;
     /** initialize. Called by the Steering. */
     StatusCode initialize();
     /** hltFinalize. Called by the Steering. */
diff --git a/Trigger/TrigAlgorithms/TrigT2CaloEgamma/src/T2CaloEgammaReFastAlgo.cxx b/Trigger/TrigAlgorithms/TrigT2CaloEgamma/src/T2CaloEgammaReFastAlgo.cxx
index 5b16ba06c3b4f949b2658b8cd0fc79ff046dc4ed..23bf17a054db29331815d5e65a2d23e9dbf57aec 100755
--- a/Trigger/TrigAlgorithms/TrigT2CaloEgamma/src/T2CaloEgammaReFastAlgo.cxx
+++ b/Trigger/TrigAlgorithms/TrigT2CaloEgamma/src/T2CaloEgammaReFastAlgo.cxx
@@ -73,7 +73,7 @@ StatusCode T2CaloEgammaReFastAlgo::initialize()
 }
 
 
-StatusCode T2CaloEgammaReFastAlgo::execute_r(const EventContext& context) const
+StatusCode T2CaloEgammaReFastAlgo::execute(const EventContext& context) const
 {
   // Time total T2CaloEgamma execution time.
 //  if ( m_timersvc ) m_timer[0]->start();
diff --git a/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.cxx b/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.cxx
index 63f722c1d4e0894f86ab16b00b60b30518ebdb3d..53a9b8cc4b22b0d3984f9dcfb1525f942ba66b73 100644
--- a/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.cxx
+++ b/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.cxx
@@ -66,7 +66,7 @@ StatusCode TrigDecisionMakerMT::finalize()
 }
 
 
-StatusCode TrigDecisionMakerMT::execute_r(const EventContext& context) const 
+StatusCode TrigDecisionMakerMT::execute(const EventContext& context) const 
 {
   // increment event counter
   m_nEvents++;
diff --git a/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.h b/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.h
index 1d9e3a0af5e77d6d623734a98bdb66ca2a9d0446..4a9866733263c9d6959af6dc777241d7a6026e8d 100644
--- a/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.h
+++ b/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.h
@@ -76,7 +76,7 @@ namespace TrigDec {
 
     // IAlgorithm virtual methods to implement
     virtual StatusCode initialize() override; //!< std Gaudi initialize method -> read-in trigger configuration
-    virtual StatusCode execute_r( const EventContext& context ) const override; //!< Re-entrant execute to create the xAOD::TrigDecision
+    virtual StatusCode execute( const EventContext& context ) const override; //!< Re-entrant execute to create the xAOD::TrigDecision
     virtual StatusCode finalize() override;    //!< std Gaudi finalize method -> print out statistics
 
     StatusCode getL1Result (const LVL1CTP::Lvl1Result*& result, const EventContext& context) const; //!< retrieve LVL1 result (called in execute)
diff --git a/Trigger/TrigCost/TrigCostPython/macros/makeGroupXML.py b/Trigger/TrigCost/TrigCostPython/macros/makeGroupXML.py
index 972806d256440e9ba55a6bc01b1d8a4e04f9b386..ea0f27c7374b4cd36b29cfe31465e69ef4b4d383 100755
--- a/Trigger/TrigCost/TrigCostPython/macros/makeGroupXML.py
+++ b/Trigger/TrigCost/TrigCostPython/macros/makeGroupXML.py
@@ -398,7 +398,7 @@ def MakeGroups(trig_list, level) :
     return groups
 
     
-# Fill the group list with a bunch of crap    
+# Fill the group list with a bunch of stuff    
 def MakeCumulativeGroups(group_dict) :
 
     cumu_group = dict()
diff --git a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.cxx
index a3fa7c9fc92f5390868c1a5f215be2e8df620c05..3a7a9e67fbe45b8932ce04ba2803660cee3c94f9 100644
--- a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.cxx
+++ b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.cxx
@@ -42,7 +42,7 @@ StatusCode TrigBjetEtHypoAlgMT::finalize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode TrigBjetEtHypoAlgMT::execute_r( const EventContext& context ) const {  
+StatusCode TrigBjetEtHypoAlgMT::execute( const EventContext& context ) const {  
   ATH_MSG_INFO ( "Executing " << name() << "..." );
 
   // ========================================================================================================================== 
diff --git a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.h b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.h
index 675eac792f5e821307240ad202bc7ff03c20fddc..fa57097df4b891a19c70375aef732c52ebbd777d 100644
--- a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.h
+++ b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.h
@@ -34,7 +34,7 @@ class TrigBjetEtHypoAlgMT : public ::HypoBase {
   virtual ~TrigBjetEtHypoAlgMT(); 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r( const EventContext& context ) const override;
+  virtual StatusCode  execute( const EventContext& context ) const override;
   virtual StatusCode  finalize() override;
  
  private: 
diff --git a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.cxx
index fa48a143de29d341530831641eeda641bf817a8a..3d5da42c57c207306c46c1320c17777f548b0022 100644
--- a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.cxx
+++ b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.cxx
@@ -42,7 +42,7 @@ StatusCode TrigBjetHypoAlgMT::finalize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode TrigBjetHypoAlgMT::execute_r( const EventContext& context ) const {  
+StatusCode TrigBjetHypoAlgMT::execute( const EventContext& context ) const {  
   ATH_MSG_DEBUG ( "Executing " << name() << "..." );
 
   SG::ReadHandle< TrigCompositeUtils::DecisionContainer > prevDecisionHandle = SG::makeHandle( decisionInput(),context );
diff --git a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.h b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.h
index a4d71f886a8ed5dced9a8bf6dce19a1b71b9aafc..e141515784890d8a6fc2c69a9b8a26195df3659a 100644
--- a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.h
+++ b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.h
@@ -34,7 +34,7 @@ class TrigBjetHypoAlgMT : public ::HypoBase {
   virtual ~TrigBjetHypoAlgMT(); 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r( const EventContext& context ) const override;
+  virtual StatusCode  execute( const EventContext& context ) const override;
   virtual StatusCode  finalize() override;
  
  private: 
diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.cxx
index c85abd2c4bf60516c1372221b0d480513b87a603..b5d7bcf9eb119224617abc759c0c677095712bd5 100644
--- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.cxx
+++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.cxx
@@ -33,7 +33,7 @@ StatusCode TrigL2CaloHypoAlgMT::finalize() {
 }
 
 
-StatusCode TrigL2CaloHypoAlgMT::execute_r( const EventContext& context ) const {  
+StatusCode TrigL2CaloHypoAlgMT::execute( const EventContext& context ) const {  
   ATH_MSG_DEBUG ( "Executing " << name() << "..." );
   auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context );
   if( not previousDecisionsHandle.isValid() ) {//implicit
diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.h b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.h
index 39d75c7f156c0bba703a36d0cac731c0fe26e4aa..a7a7d4697ba66aafbf9b9855fb01f1d0bc5f5d87 100644
--- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.h
+++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.h
@@ -27,7 +27,7 @@ class TrigL2CaloHypoAlgMT : public ::HypoBase {
   virtual ~TrigL2CaloHypoAlgMT(); 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r( const EventContext& context ) const override;
+  virtual StatusCode  execute( const EventContext& context ) const override;
   virtual StatusCode  finalize() override;
  
  private: 
diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.cxx
index 439a3922b24cd7f7052ec20d760abcd32c351841..4d0b0016031389a77c63dbf2cde14e5d03f7de98 100644
--- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.cxx
+++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.cxx
@@ -38,7 +38,7 @@ StatusCode TrigL2ElectronHypoAlgMT::initialize() {
     return StatusCode::SUCCESS;
   }
 
-StatusCode TrigL2ElectronHypoAlgMT::execute_r( const EventContext& context ) const {  
+StatusCode TrigL2ElectronHypoAlgMT::execute( const EventContext& context ) const {  
   ATH_MSG_DEBUG ( "Executing " << name() << "..." );
   auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context );
   if( not previousDecisionsHandle.isValid() ) {//implicit
diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.h b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.h
index de5c9354cfb0b23c729732835722c0ce09bc46ba..530a4f1970d862165c1bd7f57ab354c35551eb59 100644
--- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.h
+++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.h
@@ -30,7 +30,7 @@ class TrigL2ElectronHypoAlgMT  :  public ::HypoBase
   virtual ~TrigL2ElectronHypoAlgMT(); 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r(const EventContext& context) const override;
+  virtual StatusCode  execute(const EventContext& context) const override;
   virtual StatusCode  finalize() override;
 
   
diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.cxx
index 5eee805ee8ad0bb6426596f585d3b35e45bec084..84267f8b9667c54870e1552dca856922bdebf6d8 100644
--- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.cxx
+++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.cxx
@@ -38,7 +38,7 @@ StatusCode TrigL2PhotonHypoAlgMT::finalize() {
 }
 
   
-StatusCode TrigL2PhotonHypoAlgMT::execute_r( const EventContext& context ) const {  
+StatusCode TrigL2PhotonHypoAlgMT::execute( const EventContext& context ) const {  
   ATH_MSG_DEBUG ( "Executing " << name() << "..." );
   auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context );
   if( not previousDecisionsHandle.isValid() ) {//implicit
diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.h b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.h
index b0c40fb1f76aabba75e568862942daa5b883a596..2961c2f5ef6545f82163b81e6d298a315d47c389 100644
--- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.h
+++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.h
@@ -33,7 +33,7 @@ class TrigL2PhotonHypoAlgMT  :  public ::HypoBase
   virtual ~TrigL2PhotonHypoAlgMT(); 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r(const EventContext& context) const override;
+  virtual StatusCode  execute(const EventContext& context) const override;
   virtual StatusCode  finalize() override;
 
   
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx
index b655c25ca093819010ec3514b98dd95ba648c975..e9d1626f137932879a9b57e8e759c0fecae60abb 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx
@@ -34,7 +34,7 @@ StatusCode TrigJetHypoAlgMT::initialize() {
 }
 
 
-StatusCode TrigJetHypoAlgMT::execute_r( const EventContext& context ) const {  
+StatusCode TrigJetHypoAlgMT::execute( const EventContext& context ) const {  
   ATH_MSG_DEBUG ( "Executing " << name() << "..." );
 
 
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.h
index c9284f39d28f0ebf645fd072eef40d3f399f8c6d..d4413eb184e538ed3e8714bd6a22e9ae32f5cd13 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.h
@@ -26,7 +26,7 @@ class TrigJetHypoAlgMT : public ::HypoBase {
   virtual ~TrigJetHypoAlgMT(); 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r( const EventContext& context ) const override;
+  virtual StatusCode  execute( const EventContext& context ) const override;
   virtual StatusCode  finalize() override;
  
  private:
diff --git a/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.cxx
index 31dded544e14b61cdf1090b214446c424dd22388..5e2a85c76c9cb8fea45de1a47af2b19d8e715545 100644
--- a/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.cxx
+++ b/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.cxx
@@ -34,7 +34,7 @@ StatusCode TrigL2CaloRingerHypoAlgMT::initialize() {
 }
 
 
-StatusCode TrigL2CaloRingerHypoAlgMT::execute_r( const EventContext& context ) const {  
+StatusCode TrigL2CaloRingerHypoAlgMT::execute( const EventContext& context ) const {  
   ATH_MSG_DEBUG ( "Executing " << name() << "..." );
   
   // prepare decisions container and link back to the clusters, and decision on clusters
diff --git a/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.h b/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.h
index a6bb833cd96faf7cd24da68672968ec5a64a8f30..2163e6e2840f9efadb5a976f97b7ee8cf739ca67 100644
--- a/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.h
+++ b/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.h
@@ -27,7 +27,7 @@ class TrigL2CaloRingerHypoAlgMT
   virtual ~TrigL2CaloRingerHypoAlgMT(); 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r(const EventContext& context) const override;
+  virtual StatusCode  execute(const EventContext& context) const override;
 
  
  private: 
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMufastHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMufastHypoAlg.h
index f0e47910b76f3417bda74bee9ce8204b9cd0fc04..c8582c347b07aa8e697151f7a3e76a47d057e42b 100644
--- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMufastHypoAlg.h
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMufastHypoAlg.h
@@ -33,7 +33,7 @@ class TrigMufastHypoAlg
    virtual ~TrigMufastHypoAlg();
 
    virtual StatusCode  initialize() override;
-   virtual StatusCode  execute_r( const EventContext& context ) const override;
+   virtual StatusCode  execute( const EventContext& context ) const override;
    virtual StatusCode  finalize() override;
     
   private:
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuisoHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuisoHypoAlg.h
index a1f2d650b0fcd1488fc3789f503e6dc015ffe5b4..7c312b640cd9ab5eef50a8c143922153e06c07c6 100644
--- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuisoHypoAlg.h
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuisoHypoAlg.h
@@ -42,7 +42,7 @@ class TrigMuisoHypoAlg
     virtual ~TrigMuisoHypoAlg();
 
     virtual StatusCode  initialize() override;
-    virtual StatusCode  execute_r( const EventContext& context ) const override;
+    virtual StatusCode  execute( const EventContext& context ) const override;
     virtual StatusCode  finalize() override;
     
   private:
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFCombinerHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFCombinerHypoAlg.h
index d1b8a8436f0f79e1a5b4806d28c31589b03334a9..01e488d97d9de7505b4a81af482c60cda62c64b6 100644
--- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFCombinerHypoAlg.h
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFCombinerHypoAlg.h
@@ -34,7 +34,7 @@ class TrigMuonEFCombinerHypoAlg
    virtual ~TrigMuonEFCombinerHypoAlg();
 
    virtual StatusCode  initialize() override;
-   virtual StatusCode  execute_r( const EventContext& context ) const override;
+   virtual StatusCode  execute( const EventContext& context ) const override;
    virtual StatusCode  finalize() override;
     
   private:
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFMSonlyHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFMSonlyHypoAlg.h
index de0f356c40da839334ecc32a1cc4083542ca953b..52d0cc03178b3bcbf241fb32512432d02023a380 100644
--- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFMSonlyHypoAlg.h
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFMSonlyHypoAlg.h
@@ -34,7 +34,7 @@ class TrigMuonEFMSonlyHypoAlg
    virtual ~TrigMuonEFMSonlyHypoAlg();
 
    virtual StatusCode  initialize() override;
-   virtual StatusCode  execute_r( const EventContext& context ) const override;
+   virtual StatusCode  execute( const EventContext& context ) const override;
    virtual StatusCode  finalize() override;
     
   private:
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFTrackIsolationHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFTrackIsolationHypoAlg.h
index c6fd5ff06fe445a78f13b1d7c7fbd81322c701db..490db37657c8a7d48e7293b5f6a5f13e7084d084 100644
--- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFTrackIsolationHypoAlg.h
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFTrackIsolationHypoAlg.h
@@ -34,7 +34,7 @@ class TrigMuonEFTrackIsolationHypoAlg
    virtual ~TrigMuonEFTrackIsolationHypoAlg();
 
    virtual StatusCode  initialize() override;
-   virtual StatusCode  execute_r( const EventContext& context ) const override;
+   virtual StatusCode  execute( const EventContext& context ) const override;
    virtual StatusCode  finalize() override;
     
   private:
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigmuCombHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigmuCombHypoAlg.h
index 6562a9155bf5c6a7e2ef7190cd2656664daa5a32..42e381e5de836f7e3570c53a90e919a123198edc 100644
--- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigmuCombHypoAlg.h
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigmuCombHypoAlg.h
@@ -34,7 +34,7 @@ class TrigmuCombHypoAlg
    virtual ~TrigmuCombHypoAlg();
 
    virtual StatusCode  initialize() override;
-   virtual StatusCode  execute_r( const EventContext& context ) const override;
+   virtual StatusCode  execute( const EventContext& context ) const override;
    virtual StatusCode  finalize() override;
     
   private:
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMufastHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMufastHypoAlg.cxx
index eb7531faa666cef0a969b67653d368b06a9a04e4..3be67843f23e973cc7a8d573cbd055fb88ee9edb 100755
--- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMufastHypoAlg.cxx
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMufastHypoAlg.cxx
@@ -53,11 +53,11 @@ StatusCode TrigMufastHypoAlg::finalize()
 // --------------------------------------------------------------------------------
 // --------------------------------------------------------------------------------
 
-StatusCode TrigMufastHypoAlg::execute_r( const EventContext& context ) const
+StatusCode TrigMufastHypoAlg::execute( const EventContext& context ) const
 {
 
   // common for all Hypos, to move in the base class
-  ATH_MSG_DEBUG("StatusCode TrigMufastHypoAlg::execute_r start");
+  ATH_MSG_DEBUG("StatusCode TrigMufastHypoAlg::execute start");
   auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context );
   if( not previousDecisionsHandle.isValid() ) {//implicit
     ATH_MSG_DEBUG( "No implicit RH for previous decisions "<<  decisionInput().key()<<": is this expected?" );
@@ -144,7 +144,7 @@ StatusCode TrigMufastHypoAlg::execute_r( const EventContext& context ) const
   }
 
 
-  ATH_MSG_DEBUG("StatusCode TrigMufastHypoAlg::execute_r success");
+  ATH_MSG_DEBUG("StatusCode TrigMufastHypoAlg::execute success");
   return StatusCode::SUCCESS;
 }
 
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuisoHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuisoHypoAlg.cxx
index 24be8036725e67f6a3cd7c7e98afa0a0fa0ce607..ee8041bba84fac3254da4a89ba7ea032a5f7bfa6 100644
--- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuisoHypoAlg.cxx
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuisoHypoAlg.cxx
@@ -50,10 +50,10 @@ StatusCode TrigMuisoHypoAlg::finalize()
 }
 
 
-StatusCode TrigMuisoHypoAlg::execute_r( const EventContext& context) const
+StatusCode TrigMuisoHypoAlg::execute( const EventContext& context) const
 {
   // common for all Hypos, to move in the base class
-  ATH_MSG_DEBUG("StatusCode TrigMuisoHypoAlg::execute_r start");
+  ATH_MSG_DEBUG("StatusCode TrigMuisoHypoAlg::execute start");
   auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context );
   if( not previousDecisionsHandle.isValid() ) {//implicit
     ATH_MSG_DEBUG( "No implicit RH for previous decisions "<<  decisionInput().key()<<": is this expected?" );
@@ -128,7 +128,7 @@ StatusCode TrigMuisoHypoAlg::execute_r( const EventContext& context) const
   }
 
 
-  ATH_MSG_DEBUG("StatusCode TrigMuisoHypoAlg::execute_r success");
+  ATH_MSG_DEBUG("StatusCode TrigMuisoHypoAlg::execute success");
   return StatusCode::SUCCESS;
 }
 
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFCombinerHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFCombinerHypoAlg.cxx
index 42e93cea363a8a3f27046650ec902cf6a3afc346..d05c606b61d62826d7f189d13002ecbb92b6abb7 100755
--- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFCombinerHypoAlg.cxx
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFCombinerHypoAlg.cxx
@@ -54,9 +54,9 @@ StatusCode TrigMuonEFCombinerHypoAlg::finalize()
 // --------------------------------------------------------------------------------
 // --------------------------------------------------------------------------------
 
-StatusCode TrigMuonEFCombinerHypoAlg::execute_r( const EventContext& context ) const
+StatusCode TrigMuonEFCombinerHypoAlg::execute( const EventContext& context ) const
 {
-  ATH_MSG_DEBUG("StatusCode TrigMuonEFCombinerHypoAlg::execute_r start");
+  ATH_MSG_DEBUG("StatusCode TrigMuonEFCombinerHypoAlg::execute start");
 
   // common for all hypos, to move in the base class
   auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context );
@@ -148,7 +148,7 @@ StatusCode TrigMuonEFCombinerHypoAlg::execute_r( const EventContext& context ) c
     } else ATH_MSG_WARNING( "Output decisions are NOT valid with key : " << decisionOutput().key() );
   }
 
-  ATH_MSG_DEBUG("StatusCode TrigMuonEFCombinerHypoAlg::execute_r success");
+  ATH_MSG_DEBUG("StatusCode TrigMuonEFCombinerHypoAlg::execute success");
   return StatusCode::SUCCESS;
 }
 
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFMSonlyHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFMSonlyHypoAlg.cxx
index 900abc99a14de50d48b1076d6e35f09fd6aeaba8..1c9ddf33e41a1cb11d6de4d081ecb50774036f72 100755
--- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFMSonlyHypoAlg.cxx
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFMSonlyHypoAlg.cxx
@@ -54,9 +54,9 @@ StatusCode TrigMuonEFMSonlyHypoAlg::finalize()
 // --------------------------------------------------------------------------------
 // --------------------------------------------------------------------------------
 
-StatusCode TrigMuonEFMSonlyHypoAlg::execute_r( const EventContext& context ) const
+StatusCode TrigMuonEFMSonlyHypoAlg::execute( const EventContext& context ) const
 {
-  ATH_MSG_DEBUG("StatusCode TrigMuonEFMSonlyHypoAlg::execute_r start");
+  ATH_MSG_DEBUG("StatusCode TrigMuonEFMSonlyHypoAlg::execute start");
 
   // common for all hypos, to move in the base class
   auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context );
@@ -148,7 +148,7 @@ StatusCode TrigMuonEFMSonlyHypoAlg::execute_r( const EventContext& context ) con
     } else ATH_MSG_WARNING( "Output decisions are NOT valid with key : " << decisionOutput().key() );
   }
 
-  ATH_MSG_DEBUG("StatusCode TrigMuonEFMSonlyHypoAlg::execute_r success");
+  ATH_MSG_DEBUG("StatusCode TrigMuonEFMSonlyHypoAlg::execute success");
   return StatusCode::SUCCESS;
 }
 
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFTrackIsolationHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFTrackIsolationHypoAlg.cxx
index 002218a2af3844a24a4d82eddd63b1f7c1acef0f..d4c867e04959f83367392632a45a6c11de61217a 100755
--- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFTrackIsolationHypoAlg.cxx
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFTrackIsolationHypoAlg.cxx
@@ -53,7 +53,7 @@ StatusCode TrigMuonEFTrackIsolationHypoAlg::finalize()
 // --------------------------------------------------------------------------------
 // --------------------------------------------------------------------------------
 
-StatusCode TrigMuonEFTrackIsolationHypoAlg::execute_r( const EventContext& context ) const
+StatusCode TrigMuonEFTrackIsolationHypoAlg::execute( const EventContext& context ) const
 {
 
   ATH_MSG_DEBUG("Executing ...");
diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigmuCombHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigmuCombHypoAlg.cxx
index 9de510e8c804cdf6f56d85801f5ec3b683231912..72609a6d2a914659c8a88ce28cb3ed52520c9696 100644
--- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigmuCombHypoAlg.cxx
+++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigmuCombHypoAlg.cxx
@@ -55,10 +55,10 @@ StatusCode TrigmuCombHypoAlg::finalize()
 // --------------------------------------------------------------------------------
 // --------------------------------------------------------------------------------
 
-StatusCode TrigmuCombHypoAlg::execute_r(const EventContext& context) const
+StatusCode TrigmuCombHypoAlg::execute(const EventContext& context) const
 {
   // common for all Hypos, to move in the base class
-  ATH_MSG_DEBUG("StatusCode TrigmuCombHypoAlg::execute_r start");
+  ATH_MSG_DEBUG("StatusCode TrigmuCombHypoAlg::execute start");
   auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context);
   if ( not previousDecisionsHandle.isValid() ) {//implicit
     ATH_MSG_DEBUG( "No implicit ReadHandles for previous decisions " << decisionInput().key() << ": is this expected?");
@@ -133,7 +133,7 @@ StatusCode TrigmuCombHypoAlg::execute_r(const EventContext& context) const
     }
   }
 
-  ATH_MSG_DEBUG("StatusCode TrigmuCombHypoAlg::execute_r success");
+  ATH_MSG_DEBUG("StatusCode TrigmuCombHypoAlg::execute success");
   return StatusCode::SUCCESS;
 }
 
diff --git a/Trigger/TrigMonitoring/TrigIDJpsiMonitoring/TrigIDJpsiMonitoring/AnalysisConfig_Jpsi.h b/Trigger/TrigMonitoring/TrigIDJpsiMonitoring/TrigIDJpsiMonitoring/AnalysisConfig_Jpsi.h
index 8f863bab35f7deb50c9e6479cd5a6b3b40326d63..ccca92f6a79b5c6abc519ef3f2902b15123ea998 100644
--- a/Trigger/TrigMonitoring/TrigIDJpsiMonitoring/TrigIDJpsiMonitoring/AnalysisConfig_Jpsi.h
+++ b/Trigger/TrigMonitoring/TrigIDJpsiMonitoring/TrigIDJpsiMonitoring/AnalysisConfig_Jpsi.h
@@ -154,7 +154,7 @@ namespace TrigInDetAnalysis {
         std::string idChainName;
         if(chain.find("2mu4T_")     != std::string::npos) idChainName = "L2_mu4T_IDTrkNoCut";
         //if(chain.find("2mu4T_")     != std::string::npos) idChainName = "L2_muon_standalone_mu4T";
-        //if(chain.find("2mu4T_")     != std::string::npos) idChainName = "someshit";
+        //if(chain.find("2mu4T_")     != std::string::npos) idChainName = "somestuff";
         if(chain.find("2mu4_")      != std::string::npos) idChainName = "L2_mu4_IDTrkNoCut";
         if(chain.find("2mu13_")     != std::string::npos) idChainName = "L2_mu13_IDTrkNoCut";
         if(chain.find("e4_etcut_Jpsi") != std::string::npos) idChainName = "L2_e4_etcutid";
diff --git a/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.cxx b/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.cxx
index 3d42335fe41582536cef005dbf28afe804ba262c..7a9e1a901de16f9123aee2c7a292e046d2eb8850 100644
--- a/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.cxx
+++ b/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.cxx
@@ -84,7 +84,7 @@ StatusCode TrigROBMoni::initialize()
   
   if ( m_steering ) {
     // Make list of algorithms able to request data (all but Hypo)
-    vector<Algorithm*>::const_iterator a;
+    vector<Gaudi::Algorithm*>::const_iterator a;
     for ( a = m_steering->subAlgorithms()->begin();
           a != m_steering->subAlgorithms()->end(); ++a ) {
       if ( dynamic_cast<const HLT::TECreateAlgo*>(*a) ) m_fexAlgos.push_back(*a);
@@ -153,7 +153,7 @@ StatusCode TrigROBMoni::bookHists()
 				 m_fexAlgos.size(), 0, m_fexAlgos.size(),
 				 m_fexAlgos.size(), 0, m_fexAlgos.size());
   
-  vector<Algorithm*>::const_iterator a;
+  vector<Gaudi::Algorithm*>::const_iterator a;
   int bin;
   for ( a = m_fexAlgos.begin(), bin=1; a != m_fexAlgos.end(); ++a, ++bin ) {
     m_h_shared_requests->GetXaxis()->SetBinLabel(bin, (*a)->name().c_str());
@@ -341,7 +341,7 @@ StatusCode HistSet<HTYPE>::book(TrigMonitorToolBase::TrigMonGroup& monGroup,
     hist[SDGROUP]->GetXaxis()->SetBinLabel(bin, (*sdg).second.c_str());
   }
 
-  //vector<Algorithm*>::const_iterator a;
+  //vector<Gaudi::Algorithm*>::const_iterator a;
   //for ( a = montool->m_fexAlgos.begin(), bin=1;
   //      a != montool->m_fexAlgos.end(); ++a, ++bin ) {
   //  hist[ALGO]->GetXaxis()->SetBinLabel(bin, (*a)->name().c_str());
diff --git a/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.h b/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.h
index 2974759e0abfabc82967799477c4a74c150f01ef..9c3670b2b103e2156efb4197063e673f37c2188d 100644
--- a/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.h
+++ b/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.h
@@ -148,7 +148,7 @@ private:
   const HLT::TrigSteer* m_steering;
 
   /// Steering FEX algos (the ones that can request data)
-  std::vector<Algorithm*> m_fexAlgos;
+  std::vector<Gaudi::Algorithm*> m_fexAlgos;
 
   /// Map to assign ROB history codes to bins
   std::map<robmonitor::ROBHistory, short> m_ROBHistoryToBin;
diff --git a/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeHistTool.cxx b/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeHistTool.cxx
index 7df3776e4220f5f5aead1158b47c60e32b5893ef..49e9e6e9e78f18e0a94b4ad018f186341e15c33e 100755
--- a/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeHistTool.cxx
+++ b/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeHistTool.cxx
@@ -66,7 +66,7 @@ StatusCode TrigTimeHistTool::bookHists()
   ATH_CHECK(timerSvc.retrieve());
 
   // find out for whom we are running (i.e. Algo)    
-  const Algorithm *parentAlg = dynamic_cast<const Algorithm*>(parent());
+  const Gaudi::Algorithm *parentAlg = dynamic_cast<const Gaudi::Algorithm*>(parent());
   if ( parentAlg ) 
     m_parentName = parentAlg->name();
   
diff --git a/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeTreeTool.cxx b/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeTreeTool.cxx
index f0cb0cc94334029ebb4b4eeae4d2f01791baf6a5..a6a20a9b48c91cc8043a9e5be567e2f2a80de805 100755
--- a/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeTreeTool.cxx
+++ b/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeTreeTool.cxx
@@ -47,7 +47,7 @@ StatusCode TrigTimeTreeTool::bookHists() {
   ATH_CHECK(rootHistSvc.retrieve());
 
   // find out for whom we are running (i.e. Algo)    
-  const Algorithm *parentAlg = dynamic_cast<const Algorithm*>(parent());
+  const Gaudi::Algorithm *parentAlg = dynamic_cast<const Gaudi::Algorithm*>(parent());
   if ( parentAlg ) 
 	m_parentName = parentAlg->name();
 
diff --git a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/HypoBase.h b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/HypoBase.h
index 3a83457515bd4c33ccc6c8fd0b8613c7582219d6..dfbb61fcbd841b126100994b91de23ed700095a5 100644
--- a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/HypoBase.h
+++ b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/HypoBase.h
@@ -24,7 +24,7 @@ This is a base class for HLT Hypos to reduce boilerplate and enforce the common
   /// initialise this base class and renounce input decision key handles
   virtual StatusCode sysInitialize() override;
   /// execute to be implemented in derived clas
-  virtual StatusCode execute_r(const EventContext&) const override = 0;
+  virtual StatusCode execute(const EventContext&) const override = 0;
   virtual StatusCode finalize() override = 0;
   virtual StatusCode initialize() override = 0;
 
diff --git a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/InputMakerBase.h b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/InputMakerBase.h
index 6d75733cad0e4f4a70a73317b466e1180311cffd..10d56a39c905e6f62cdd9cf5dd687950d68b8466 100644
--- a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/InputMakerBase.h
+++ b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/InputMakerBase.h
@@ -25,7 +25,7 @@ This is a base class for HLT InputMakers to reduce boilerplate and enforce the c
   /// initialise this base class and renounce input decision key handles
   virtual StatusCode sysInitialize() override;
   /// execute to be implemented in derived clas
-  virtual StatusCode execute_r(const EventContext&) const override = 0;
+  virtual StatusCode execute(const EventContext&) const override = 0;
   virtual StatusCode finalize() override = 0;
   virtual StatusCode initialize() override = 0;
   
diff --git a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.h b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.h
index 2fc341c12912bfbe7315bcf1dc83ea612190f403..f72f8f21b16729e9981b021606b7afc0a7101ac9 100644
--- a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.h
+++ b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.h
@@ -31,7 +31,7 @@ namespace TrigCompositeUtils {
    * @brief Creates and right away records the Container CONT with the key.
    * Returns the WriteHandle. 
    * No Aux store.
-   * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower.
+   * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower.
    **/
   template<class CONT>
     SG::WriteHandle<CONT> createAndStoreNoAux( const SG::WriteHandleKey<CONT>& key, const EventContext& ctx = Gaudi::Hive::currentContext());
@@ -40,7 +40,7 @@ namespace TrigCompositeUtils {
    * @brief Creates and right away records the Container CONT with the key.
    * Returns the WriteHandle. 
    * With Aux store.
-   * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower.
+   * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower.
    **/
   template<class CONT, class AUX>
     SG::WriteHandle<CONT> createAndStoreWithAux( const SG::WriteHandleKey<CONT>& key, const EventContext& ctx = Gaudi::Hive::currentContext());
@@ -48,7 +48,7 @@ namespace TrigCompositeUtils {
   /**
    * @brief Creates and right away records the DecisionContainer with the key.
    * Returns the WriteHandle. 
-   * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower.
+   * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower.
    **/
   SG::WriteHandle<DecisionContainer> createAndStore( const SG::WriteHandleKey<DecisionContainer>& key, const EventContext& ctx = Gaudi::Hive::currentContext() );
 
@@ -67,7 +67,7 @@ namespace TrigCompositeUtils {
    * output->push_back(d);    
    * If provided, the name is assigned to the TC object
    * Note that the supplied DecisionContainer must have been recorded in the event store.
-   * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower.
+   * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower.
    **/  
   Decision* newDecisionIn ( DecisionContainer* dc, const std::string& name = "", const EventContext& ctx = Gaudi::Hive::currentContext() );
 
diff --git a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.icc b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.icc
index a11b4bb04e0975fbec40ec01cadc899ecc22dba4..93edfe6534b6e3d21ea276e02ca6c463b14204ae 100644
--- a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.icc
+++ b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.icc
@@ -7,7 +7,7 @@ namespace TrigCompositeUtils {
    * @brief Creates and right away records the Container CONT with the key.
    * No Aux store.
    * Returns the WriteHandle. 
-   * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower.
+   * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower.
    **/
   template<class CONT>
   SG::WriteHandle<CONT> createAndStoreNoAux( const SG::WriteHandleKey<CONT>& key, const EventContext& ctx ) {
@@ -21,7 +21,7 @@ namespace TrigCompositeUtils {
    * @brief Creates and right away records the Container CONT with the key.
    * With Aux store.
    * Returns the WriteHandle. 
-   * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower.
+   * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower.
    **/
   template<class CONT, class AUX>
   SG::WriteHandle<CONT> createAndStoreWithAux( const SG::WriteHandleKey<CONT>& key, const EventContext& ctx ) {
diff --git a/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.cxx b/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.cxx
index 4049c021fc6d2bea275b1a04b14979b504665b6b..02488db94d84359d669f5d1ac3bc075fe5ea2606 100644
--- a/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.cxx
+++ b/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.cxx
@@ -156,7 +156,7 @@ void ComboHypo::fillDecisionsMap( std::vector< MultiplicityMap >&  dmap, const E
   }
 }
 
-StatusCode ComboHypo::execute_r(const EventContext& context ) const {
+StatusCode ComboHypo::execute(const EventContext& context ) const {
   ATH_MSG_DEBUG( "Executing " << name() << "..." );
  
   
diff --git a/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.h b/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.h
index df97b79b2c6815cf903b5f92cbf8439125d6f705..73879a2ce883a782d2d2eea1a73feba573e91583 100644
--- a/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.h
+++ b/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.h
@@ -27,7 +27,7 @@ public:
   virtual ~ComboHypo() override;
 
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r(const EventContext& context) const override;
+  virtual StatusCode execute(const EventContext& context) const override;
   virtual StatusCode finalize() override;
 
 private:
diff --git a/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.cxx b/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.cxx
index f05fdb890ec8edee689c0411cf31e05a2766fb08..46fb361a6da8485b3d041c294c2228c4935fa484 100644
--- a/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.cxx
+++ b/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.cxx
@@ -42,7 +42,7 @@ StatusCode DumpDecisions::finalize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode DumpDecisions:: execute_r( const EventContext& ctx ) const {  
+StatusCode DumpDecisions:: execute( const EventContext& ctx ) const {  
   using namespace TrigCompositeUtils;
   //  DecisionInput decisionInput;
   auto decisionInput = SG::makeHandle( m_decisionKey, ctx );
diff --git a/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.h b/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.h
index 71ec3ce57ac56ece71b872d08a6fbd93d72b6524..dc0af6a2977760ca9d4907b0259a6b7f445fe383 100644
--- a/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.h
+++ b/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.h
@@ -31,7 +31,7 @@ class DumpDecisions
 
   // Athena algorithm's Hooks
   StatusCode initialize() override;
-  StatusCode execute_r( const EventContext& ctx ) const override;
+  StatusCode execute( const EventContext& ctx ) const override;
   StatusCode finalize() override;
  private: 
 
diff --git a/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.cxx b/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.cxx
index dcbd7fb491fa9250be960a6df57e05a23f18402a..2b4e32176d6405021bef99ebc593558704812158 100644
--- a/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.cxx
+++ b/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.cxx
@@ -31,7 +31,7 @@ StatusCode  InputMakerForRoI::finalize() {
 }
 
 
-StatusCode  InputMakerForRoI::execute_r( const EventContext& context ) const {  
+StatusCode  InputMakerForRoI::execute( const EventContext& context ) const {  
   ATH_MSG_DEBUG( "Executing " << name() << "..." );
   
   // call base class helper method to read input decisions, loop over them create outputs and connect them, returns with outputHandles filled
diff --git a/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.h b/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.h
index 121e9009d0ea5d22210564aa0d7f29f54856fc43..a18bd505d6e84892d40e28b51cbc85a511252cd2 100644
--- a/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.h
+++ b/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.h
@@ -24,7 +24,7 @@
     InputMakerForRoI( const std::string& name, ISvcLocator* pSvcLocator );
     virtual ~ InputMakerForRoI(); 
     virtual StatusCode  initialize() override;
-    virtual StatusCode  execute_r(const EventContext&) const override;
+    virtual StatusCode  execute(const EventContext&) const override;
     virtual StatusCode  finalize() override;
 
   private: 
diff --git a/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.cxx b/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.cxx
index 5bdc223042b29986dccd3e666158147f862bedb7..332b3dd1692d94d51b956e1320f533e6d3e154df 100644
--- a/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.cxx
+++ b/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.cxx
@@ -45,7 +45,7 @@ StatusCode TriggerSummaryAlg::initialize()
   return StatusCode::SUCCESS;
 }
 
-StatusCode TriggerSummaryAlg::execute_r(const EventContext& context) const
+StatusCode TriggerSummaryAlg::execute(const EventContext& context) const
 {
   
   // that is certain input
diff --git a/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.h b/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.h
index 10f0f19d7add72905b68139048031a8c06ec3b53..e1e58dce8d2424457e1f6a97d0b65eeca52de3eb 100644
--- a/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.h
+++ b/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.h
@@ -26,7 +26,7 @@ class TriggerSummaryAlg : public ::AthReentrantAlgorithm {
   virtual ~TriggerSummaryAlg(); 
 
   virtual StatusCode  initialize() override;
-  virtual StatusCode  execute_r( const EventContext& context ) const override;
+  virtual StatusCode  execute( const EventContext& context ) const override;
   
  
  private: 
diff --git a/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.cxx b/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.cxx
index 5dc84ebea373fb5e730e0868dd3dc5d1238a9ae4..fa9c2a3a4b5402d3daebe77106c6ad2a705b849d 100644
--- a/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.cxx
+++ b/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.cxx
@@ -27,7 +27,7 @@ StatusCode CreateFullScanRoI::finalize()
   return StatusCode::SUCCESS;
 }
 
-StatusCode CreateFullScanRoI::execute_r(const EventContext& ctx) const
+StatusCode CreateFullScanRoI::execute(const EventContext& ctx) const
 {
   using namespace TrigCompositeUtils;
   SG::WriteHandle<TrigRoiDescriptorCollection> handle1 = createAndStoreNoAux(m_roisKey, ctx ); 
diff --git a/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.h b/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.h
index 884eec97ca479a306f23c6b8442baefeb6765459..7c2e0acda93f1cb65e5895c32202605d839d4ccd 100644
--- a/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.h
+++ b/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.h
@@ -20,7 +20,7 @@ public:
   virtual ~CreateFullScanRoI() override;
 
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r(const EventContext& context) const override;
+  virtual StatusCode execute(const EventContext& context) const override;
   virtual StatusCode finalize() override;
 
 private:
diff --git a/Trigger/TrigSteer/L1Decoder/src/L1Decoder.cxx b/Trigger/TrigSteer/L1Decoder/src/L1Decoder.cxx
index 69930d8318c3f2ae3e9d3b84fb4cfa7df5bf025b..7a48e1618f1bc5066457cfc076105810a3ed24a5 100644
--- a/Trigger/TrigSteer/L1Decoder/src/L1Decoder.cxx
+++ b/Trigger/TrigSteer/L1Decoder/src/L1Decoder.cxx
@@ -63,7 +63,7 @@ StatusCode L1Decoder::readConfiguration() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode L1Decoder::execute_r (const EventContext& ctx) const {
+StatusCode L1Decoder::execute (const EventContext& ctx) const {
   {
     auto timeStampHandle = SG::makeHandle( m_startStampKey, ctx );
     ATH_CHECK( timeStampHandle.record( std::make_unique<TrigTimeStamp>() ) );
diff --git a/Trigger/TrigSteer/L1Decoder/src/L1Decoder.h b/Trigger/TrigSteer/L1Decoder/src/L1Decoder.h
index dff2b0dcbcf6306a1ff9e5acba56a65de850e018..21d7b7791891fcb00b1957e9322f94dfaca66e21 100644
--- a/Trigger/TrigSteer/L1Decoder/src/L1Decoder.h
+++ b/Trigger/TrigSteer/L1Decoder/src/L1Decoder.h
@@ -30,7 +30,7 @@ public:
   L1Decoder(const std::string& name, ISvcLocator* pSvcLocator);
   virtual StatusCode initialize() override;
   virtual void handle(const Incident& incident) override;
-  virtual StatusCode execute_r (const EventContext& ctx) const override;
+  virtual StatusCode execute (const EventContext& ctx) const override;
   virtual StatusCode finalize() override;
 
 protected: // protected to support unit testing
diff --git a/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.cxx b/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.cxx
index afec96c42b8db34fbafece5ba3802b053f738280..85e0064e0d7fa450b94fd034192c78512b78cbf1 100644
--- a/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.cxx
+++ b/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.cxx
@@ -38,9 +38,9 @@ StatusCode HLTResultMTByteStreamDecoderAlg::finalize() {
 }
 
 // =============================================================================
-// Implementation of AthReentrantAlgorithm::execute_r
+// Implementation of AthReentrantAlgorithm::execute
 // =============================================================================
-StatusCode HLTResultMTByteStreamDecoderAlg::execute_r(const EventContext& eventContext) const {
+StatusCode HLTResultMTByteStreamDecoderAlg::execute(const EventContext& eventContext) const {
   ATH_MSG_DEBUG("Executing " << name());
 
   // Create and record the HLTResultMT object
diff --git a/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.h b/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.h
index 64e4b468ea581278362fe09194332f53fbfce26c..cf9b1eb5c114d3b0ed72210eac8ed8367676776a 100644
--- a/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.h
+++ b/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.h
@@ -25,7 +25,7 @@ public:
   // ------------------------- AthReentrantAlgorithm methods -------------------
   virtual StatusCode initialize() override;
   virtual StatusCode finalize() override;
-  virtual StatusCode execute_r(const EventContext& eventContext) const override;
+  virtual StatusCode execute(const EventContext& eventContext) const override;
 
 private:
   // ------------------------- Properties --------------------------------------
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx
index c1c18bdb09eb9bb93cbe415584ef37dba017f332..b39c0a242a603c7ca1177ca803032b366d252a70 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx
@@ -28,7 +28,7 @@ StatusCode DecisionSummaryMakerAlg::finalize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode DecisionSummaryMakerAlg::execute_r(const EventContext& context) const {
+StatusCode DecisionSummaryMakerAlg::execute(const EventContext& context) const {
   SG::WriteHandle<TrigCompositeUtils::DecisionContainer> outputHandle = TrigCompositeUtils::createAndStore( m_summaryKey, context );
   auto container = outputHandle.ptr();
 
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h
index 4fc76f6d72caa2c292145b18876789eaa6094ec5..ab6e7740a364448a9f8a45ac9320710742cd0499 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h
@@ -19,7 +19,7 @@ public:
   virtual ~DecisionSummaryMakerAlg() override;
 
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r(const EventContext& context) const override;
+  virtual StatusCode execute(const EventContext& context) const override;
   virtual StatusCode finalize() override;
 
 private:
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx
index f73e203cec8a921b94c7025882674e5a0a5d282f..17fae8a7e6be48423e159404ed0655add3a3022e 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx
@@ -19,6 +19,6 @@ StatusCode HLTResultMTMakerAlg::finalize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode HLTResultMTMakerAlg::execute_r(const EventContext& context) const {
+StatusCode HLTResultMTMakerAlg::execute(const EventContext& context) const {
   return m_resultMaker->makeResult(context);
 }
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h
index 3a53f49c3530fec4b484e5df2d2b08bd2f3f90a5..b5b4577f2dfb0de21fccb70c7a35f48fcc4413d0 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h
@@ -18,7 +18,7 @@ public:
   virtual ~HLTResultMTMakerAlg() override;
 
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r(const EventContext& context) const override;
+  virtual StatusCode execute(const EventContext& context) const override;
   virtual StatusCode finalize() override;
 
 private:
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx
index a4cbf6356c6ccbbc2d562e6990e30528aaa38119..ffa7506e9973c22abd9f7d70dbbf492d03eae9b0 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx
@@ -34,7 +34,7 @@ StatusCode TriggerEDMDeserialiserAlg::finalize()
   return StatusCode::SUCCESS;
 }
 
-StatusCode TriggerEDMDeserialiserAlg::execute_r(const EventContext& context) const
+StatusCode TriggerEDMDeserialiserAlg::execute(const EventContext& context) const
 {
 
   size_t  buffSize = m_initialSerialisationBufferSize;
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h
index b5dd0bd519e5550a42749907a31e6197b1e1d833..5b90c8094c48df5f5ba92cba0111549f6af2d5d1 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h
@@ -34,7 +34,7 @@ public:
   virtual ~TriggerEDMDeserialiserAlg() override;
 
   virtual StatusCode initialize() override;
-  virtual StatusCode execute_r(const EventContext& context) const override;
+  virtual StatusCode execute(const EventContext& context) const override;
   virtual StatusCode finalize() override;
 
 private:
diff --git a/Trigger/TrigSteer/TrigSteering/TrigSteering/TrigSteer.h b/Trigger/TrigSteer/TrigSteering/TrigSteering/TrigSteer.h
index 7d27e2fe44fc1dcaa15b35bb6befa9c8a120cd1e..0a5e47ea228f4515e3a2736e73fd9fc74d6ba566 100755
--- a/Trigger/TrigSteer/TrigSteering/TrigSteering/TrigSteer.h
+++ b/Trigger/TrigSteer/TrigSteering/TrigSteering/TrigSteer.h
@@ -33,7 +33,7 @@
 #include "TrigConfHLTData/HLTSequence.h"
 #include "TrigNavigation/Navigation.h"
 
-#include "AthenaBaseComps/AthAlgorithm.h"
+#include "AthenaBaseComps/AthLegacySequence.h"
 #include "GaudiKernel/ToolHandle.h"
 #include "GaudiKernel/ServiceHandle.h"
 #include "GaudiKernel/IIncidentListener.h"
@@ -101,7 +101,7 @@ namespace HLT {
       @author Nicolas Berger  <Nicolas.Berger@cern.ch>
       @author Tomasz Bold     <Tomasz.Bold@cern.ch>
    */
-   class TrigSteer : public AthAlgorithm,
+   class TrigSteer : public AthLegacySequence,
                      public Athena::TimeoutMaster,
                      public virtual ISequenceProvider,
                      public virtual IIncidentListener
diff --git a/Trigger/TrigSteer/TrigSteering/src/Sequence.cxx b/Trigger/TrigSteer/TrigSteering/src/Sequence.cxx
index 696e1d402f6dad01b70a83a8f435ed215f1abbba..9ca0d442a3b616acc178f227b9f12282e241f8a8 100755
--- a/Trigger/TrigSteer/TrigSteering/src/Sequence.cxx
+++ b/Trigger/TrigSteer/TrigSteering/src/Sequence.cxx
@@ -73,7 +73,7 @@ Sequence::Sequence(std::vector<unsigned int> inputTypes,
             return;
          }
       
-         const Algorithm* parentAlg = dynamic_cast<const Algorithm*>(ntool->parent()); // this is the way to get parent alg name (TrigSteer_L2/EF) ugh we need better way.
+         const Gaudi::Algorithm* parentAlg = dynamic_cast<const Gaudi::Algorithm*>(ntool->parent()); // this is the way to get parent alg name (TrigSteer_L2/EF) ugh we need better way.
          if ( !parentAlg ) {
             m_config->getMsgStream() << MSG::WARNING << "No parent algorithm for the sequence" << endmsg;
             return;
diff --git a/Trigger/TrigSteer/TrigSteering/src/SteeringChain.cxx b/Trigger/TrigSteer/TrigSteering/src/SteeringChain.cxx
index 28facadea11a37addd75dadf5d24e09edcbf80bd..b2d2b5f1fa9f8a778cf4393b1f059967d8927ce0 100644
--- a/Trigger/TrigSteer/TrigSteering/src/SteeringChain.cxx
+++ b/Trigger/TrigSteer/TrigSteering/src/SteeringChain.cxx
@@ -125,7 +125,7 @@ SteeringChain::SteeringChain( const TrigConf::HLTChain* configChain, ISequencePr
      m_config->getMsgStream() << MSG::WARNING << "Navigation tool not available" << endmsg;
      return;
    }
-   const Algorithm* parentAlg = dynamic_cast<const Algorithm*>(ntool->parent()); // this is the way to get parent alg name (TrigSteer_L2/EF) ugh we need better way.
+   const Gaudi::Algorithm* parentAlg = dynamic_cast<const Gaudi::Algorithm*>(ntool->parent()); // this is the way to get parent alg name (TrigSteer_L2/EF) ugh we need better way.
    if ( !parentAlg ) {
      m_config->getMsgStream() << MSG::WARNING << "Parent alg not available" << endmsg;
      return;
diff --git a/Trigger/TrigSteer/TrigSteering/src/TrigSteer.cxx b/Trigger/TrigSteer/TrigSteering/src/TrigSteer.cxx
index 07c4c97239b4f07f0378c3258470eec24b22cdd1..a18eeeaedb2b70c326c4863f7f81d41cab7d7f55 100755
--- a/Trigger/TrigSteer/TrigSteering/src/TrigSteer.cxx
+++ b/Trigger/TrigSteer/TrigSteering/src/TrigSteer.cxx
@@ -88,7 +88,7 @@ using namespace HLT;
 using namespace std;
 
 TrigSteer::TrigSteer(const std::string& name, ISvcLocator* pSvcLocator)
-  : AthAlgorithm(name, pSvcLocator),
+  : AthLegacySequence(name, pSvcLocator),
     m_config(0),
     m_stepForEB(0),
     m_configSvc("TrigConf::TrigConfigSvc/TrigConfigSvc", name),
@@ -417,12 +417,10 @@ StatusCode TrigSteer::initialize()
    }
 
 
-
-
- 
    ATH_MSG_DEBUG("initializing done");
 
-   return StatusCode::SUCCESS;
+   ATH_MSG_DEBUG("initializing subAlgs");
+   return AthLegacySequence::initialize();
 }
 
 
@@ -449,7 +447,7 @@ StatusCode TrigSteer::finalize()
 
    delete m_config; m_config=0;
 
-   return StatusCode::SUCCESS;
+   return AthLegacySequence::finalize();
 }
 
 
@@ -1023,7 +1021,7 @@ HLT::Algo* TrigSteer::getAlgo(std::string name)
   if (iter != m_algos.end())
     algo = iter->second;
   else {
-    Algorithm* algPointer;
+    Gaudi::Algorithm* algPointer;
     if (createSubAlgorithm(subAlg_type, subAlg_name, algPointer).isSuccess()) {
       algo = static_cast<HLT::Algo*>(algPointer);
       algo->setConfig(m_config);
@@ -1136,7 +1134,7 @@ HLT::Sequence* TrigSteer::createSequence(const TrigConf::HLTSequence& seq, const
  
    // get input TE types and sequences
    std::vector<unsigned int> inputTypes;
-   std::vector< Sequence* > inputSequences;
+   std::vector< HLT::Sequence* > inputSequences;
    for( TrigConf::HLTTriggerElement* inputTE : seq.inputTEs() ) {
 
       unsigned int inputId = inputTE->id();
@@ -1144,7 +1142,7 @@ HLT::Sequence* TrigSteer::createSequence(const TrigConf::HLTSequence& seq, const
       // make sure we have the sequences producing these inputTEs:
       if ( producedFirstAtLevel(inputId) == m_hltLevel ) {
 
-         Sequence* newseq = findSeqForOutputTeType( inputId );
+        HLT::Sequence* newseq = findSeqForOutputTeType( inputId );
          // if seq not NULL and not in vector already, save it:
          if (newseq && find(inputSequences.begin(), inputSequences.end(), newseq) == inputSequences.end() ) {
             inputSequences.push_back(newseq);
@@ -1160,7 +1158,7 @@ HLT::Sequence* TrigSteer::createSequence(const TrigConf::HLTSequence& seq, const
    // get topo_start_from TE types
    const TrigConf::HLTTriggerElement* hltTopoTE = seq.topoStartTE();
    std::vector<unsigned int> topoStartTypes;
-   Sequence * topoStartFromSequence = 0;
+   HLT::Sequence * topoStartFromSequence = 0;
    // only add an entry if pointer not NULL
    if (hltTopoTE) {
       topoStartTypes.push_back( hltTopoTE->id() );
@@ -1188,7 +1186,7 @@ HLT::Sequence* TrigSteer::createSequence(const TrigConf::HLTSequence& seq, const
    HLT::Sequence* newseq = new HLT::Sequence(inputTypes, outputType,
                                              firstAlgo, tailAlgos, m_config, topoStartTypes);
 
-   for (std::vector< Sequence* >::const_iterator it = inputSequences.begin();
+   for (std::vector< HLT::Sequence* >::const_iterator it = inputSequences.begin();
         it != inputSequences.end(); ++it) {
       newseq->m_previousSequences.push_back( *it );
    }
@@ -1238,7 +1236,8 @@ StatusCode TrigSteer::start()
 
   ATH_MSG_DEBUG("monitoring tools bookHists done " << m_monTools << " " << m_opiTools);
 
-  return StatusCode::SUCCESS;
+  return AthLegacySequence::start();
+  
 }
 
 
@@ -1281,7 +1280,7 @@ StatusCode TrigSteer::stop()
 
    ATH_MSG_DEBUG("monitoring tools finalHists done " << m_monTools << " " << m_opiTools);
 
-   return StatusCode::SUCCESS;
+   return AthLegacySequence::stop();
 }
 
 
diff --git a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.cxx b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.cxx
index c7e05ab604085e73c61bb917ce3e8de23ed4c671..e4c97ab6141cfc20d83d6abfd31af51f17683308 100644
--- a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.cxx
+++ b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.cxx
@@ -26,7 +26,7 @@ StatusCode EventViewCreatorAlgorithm::initialize() {
 }
 
 
-StatusCode EventViewCreatorAlgorithm::execute_r( const EventContext& context ) const {
+StatusCode EventViewCreatorAlgorithm::execute( const EventContext& context ) const {
 
   // create the output decisions, similar to inputs (copy basic links)
   std::vector< SG::WriteHandle<TrigCompositeUtils::DecisionContainer> > outputHandles;
@@ -43,7 +43,7 @@ StatusCode EventViewCreatorAlgorithm::execute_r( const EventContext& context ) c
     // auto viewVector = std::make_unique< ViewContainer >();
   auto contexts = std::vector<EventContext>( );
   unsigned int viewCounter = 0;
-  unsigned int conditionsRun = getContext().getExtension<Atlas::ExtendedEventContext>().conditionsRun();
+  unsigned int conditionsRun = context.getExtension<Atlas::ExtendedEventContext>().conditionsRun();
 
   //map all RoIs that are stored
   std::vector <ElementLink<TrigRoiDescriptorCollection> > RoIsFromDecision;
diff --git a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.h b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.h
index 515bc9030d16a810e2d699487ee4b32cd6ab81d1..0950e60efffb9aa30fd06aed9d0b509fd09eb82f 100644
--- a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.h
+++ b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.h
@@ -34,7 +34,7 @@ class EventViewCreatorAlgorithm : public ::InputMakerBase
     EventViewCreatorAlgorithm( const std::string& name, ISvcLocator* pSvcLocator );
     virtual ~EventViewCreatorAlgorithm();
     virtual StatusCode initialize() override;
-    virtual StatusCode execute_r(const EventContext&) const override;
+    virtual StatusCode execute(const EventContext&) const override;
     virtual StatusCode finalize() override { return StatusCode::SUCCESS; }
  protected:
 
diff --git a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.cxx b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.cxx
index a3646d8045a70b02408ccd6d15df02d5f82dbb54..c9ec14c5bb42cba252d63cb93a2c603cb027bc5e 100644
--- a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.cxx
+++ b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.cxx
@@ -26,14 +26,12 @@ StatusCode EventViewCreatorAlgorithmWithJets::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode EventViewCreatorAlgorithmWithJets::execute_r( const EventContext& context ) const {
+StatusCode EventViewCreatorAlgorithmWithJets::execute( const EventContext& context ) const {
  // create the output decisions, similar to inputs (copy basic links)
   std::vector< SG::WriteHandle<TrigCompositeUtils::DecisionContainer> > outputHandles;
   ATH_CHECK (decisionInputToOutput(context, outputHandles));
 
     // make the views
-
-    // make the views
   auto viewsHandle = SG::makeHandle( m_viewsKey ); 
   auto viewVector1 = std::make_unique< ViewContainer >();
   ATH_CHECK( viewsHandle.record(  std::move( viewVector1 ) ) );
@@ -42,7 +40,7 @@ StatusCode EventViewCreatorAlgorithmWithJets::execute_r( const EventContext& con
     //  auto viewVector = std::make_unique< ViewContainer >();
   auto contexts = std::vector<EventContext>( );
   unsigned int viewCounter = 0;
-  unsigned int conditionsRun = getContext().getExtension<Atlas::ExtendedEventContext>().conditionsRun();
+  unsigned int conditionsRun = context.getExtension<Atlas::ExtendedEventContext>().conditionsRun();
 
    //map all RoIs that are stored
   std::vector <ElementLink<TrigRoiDescriptorCollection> > RoIsFromDecision;
diff --git a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.h b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.h
index ff84d82709d468fccd032bdf2fdb76aaa2d09b2f..6d39520d6e56dada64fc554ee5c8404285ae2583 100644
--- a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.h
+++ b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.h
@@ -21,7 +21,7 @@ class EventViewCreatorAlgorithmWithJets : public EventViewCreatorAlgorithm {
     virtual ~EventViewCreatorAlgorithmWithJets();
 
     virtual StatusCode initialize() override;
-    virtual StatusCode execute_r(const EventContext&) const override;
+    virtual StatusCode execute(const EventContext&) const override;
 
  private:
 
diff --git a/Trigger/TrigSteer/ViewAlgs/src/MergeViews.cxx b/Trigger/TrigSteer/ViewAlgs/src/MergeViews.cxx
index bcb8ce19512f940c2b998a54ea6c01ae2ef88cd6..a930db5a5314aff108fd760c9cc5d906be172dc9 100644
--- a/Trigger/TrigSteer/ViewAlgs/src/MergeViews.cxx
+++ b/Trigger/TrigSteer/ViewAlgs/src/MergeViews.cxx
@@ -11,7 +11,7 @@ StatusCode MergeViews::initialize() {
   return StatusCode::SUCCESS;
 }
 
-StatusCode MergeViews::execute_r( const EventContext& context ) const {
+StatusCode MergeViews::execute( const EventContext& context ) const {
   auto viewsHandle = SG::makeHandle( m_viewsKey, context );
   const ViewContainer& viewsRef = *viewsHandle;
 
diff --git a/Trigger/TrigSteer/ViewAlgs/src/MergeViews.h b/Trigger/TrigSteer/ViewAlgs/src/MergeViews.h
index 51ccf3339f6cfc2665c6e11fcebd2d779e71aef6..d07e60f4b04d37413d8d02e7fdf0c7b338237666 100644
--- a/Trigger/TrigSteer/ViewAlgs/src/MergeViews.h
+++ b/Trigger/TrigSteer/ViewAlgs/src/MergeViews.h
@@ -9,7 +9,7 @@ class MergeViews : virtual public AthReentrantAlgorithm {
 public:
   MergeViews(const std::string& name, ISvcLocator* pSvcLocator);
   StatusCode initialize() override;
-  StatusCode execute_r( const EventContext& context ) const override;
+  StatusCode execute( const EventContext& context ) const override;
 private:
   SG::ReadHandleKey< ViewContainer > m_viewsKey { this, "Views", "Views", "Collection of views to read from" };  
   ToolHandleArray<IViewsMergerTool> m_mergingTools {this, "MergingTools", {}, "Merging tools used to perform the merging action" };
diff --git a/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.cxx b/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.cxx
index 58aba266704332970a150861afdd1740ac7caa62..b62dec32b329f8140dfb05bdc1dc41e15c060f08 100644
--- a/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.cxx
+++ b/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.cxx
@@ -34,7 +34,7 @@ StatusCode TestViewMerger::initialize() {
 }
 
 
-//StatusCode TestViewMerger::execute_r( const EventContext& ctx ) const {
+//StatusCode TestViewMerger::execute( const EventContext& ctx ) const {
 StatusCode TestViewMerger::execute(){
   //  auto viewsHandle = SG::makeHandle( m_viewsKey, ctx );
   auto viewsHandle = SG::makeHandle( m_viewsKey );
diff --git a/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.h b/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.h
index fde767a3c1605c90ae29a279e2dfb26521ef0de8..13c7b85b641ed3b7b739dd81c599665cbe2701bf 100644
--- a/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.h
+++ b/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.h
@@ -26,7 +26,7 @@ public:
   TestViewMerger( const std::string& name, ISvcLocator* pSvcLocator );
   StatusCode initialize();
   StatusCode execute();
-  //  StatusCode execute_r( const EventContext& ctx ) const;
+  //  StatusCode execute( const EventContext& ctx ) const;
 
 private:
   SG::ReadHandleKey< ViewContainer > m_viewsKey; // will be used in evt context
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation_topOptions.py b/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation_topOptions.py
index 945838b183d8a7dc5f69605a02b67f1c4263e07f..777d22b40f590021654157b68083596a2e9e4cd9 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation_topOptions.py
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation_topOptions.py
@@ -1,6 +1,5 @@
 include.block ("L1TopoSimulation/L1Simulation_topOptions.py")
 
-# gbl.AthenaServices.SetFatalHandler(438)
 svcMgr.CoreDumpSvc.FatalHandler = 438
 import traceback
 
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.cxx b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.cxx
index b3fd0d71f413ff878f87e8c40da6036379ce45ce..f0572ac9b0e3dc735f7f9969ab7224ff1b7f1722 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.cxx
@@ -52,7 +52,7 @@ LVL1::RoiB2TopoInputDataCnv::initialize()
 }
 
 StatusCode
-LVL1::RoiB2TopoInputDataCnv::execute_r (const EventContext& ctx) const
+LVL1::RoiB2TopoInputDataCnv::execute (const EventContext& ctx) const
 {  
    ATH_MSG_DEBUG ("Executing " << name() << "...");
    
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.h b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.h
index 98a1e46d94f4df7d672f4807edad36c56e483688..b3d947a2e47142bfd738d66543537a3179794217 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.h
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.h
@@ -35,7 +35,7 @@ namespace LVL1 {
       virtual ~RoiB2TopoInputDataCnv(); 
 
       // Athena algorithm's Hooks
-      virtual StatusCode  execute_r (const EventContext& ctx) const override;
+      virtual StatusCode  execute (const EventContext& ctx) const override;
       virtual StatusCode  initialize() override;
       //Finalize not overriden because no work is required
 
diff --git a/Trigger/TrigT1/TrigT1NSWSimTools/src/MMT_struct.cxx b/Trigger/TrigT1/TrigT1NSWSimTools/src/MMT_struct.cxx
index c845cd960d6e18344c1808c2d14d0de4bfa44ad8..a9255ece8fa498ba646a18807efd394f77bd8da2 100644
--- a/Trigger/TrigT1/TrigT1NSWSimTools/src/MMT_struct.cxx
+++ b/Trigger/TrigT1/TrigT1NSWSimTools/src/MMT_struct.cxx
@@ -835,7 +835,7 @@ void MMT_Parameters::fill_yzmod(){
         //gamma--do here if necessary...problematic if so
 
         //beta angle--rotation around the y axis; the x coordinate or phi taken care of in correction to slope road limits in x in constructor
-        //z is changed, and so y must be scaled (should it?): THIS SHIT DOESN'T WORK....
+        //z is changed, and so y must be scaled (should it?): THIS DOESN'T WORK....
         // 	zadd-=1.*x*sin(beta)/MMTStructConst;yadd+=yup*zadd/zflt/MMTStructConst;
         zadd-=tan(beta)*tan(theta)*sin(phi)*zflt/MMTStructConst;
         yadd-=tan(beta)*tan(theta)*sin(phi)*yflt/MMTStructConst;
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/python/MuonSetup.py b/Trigger/TrigValidation/TrigUpgradeTest/python/MuonSetup.py
index ab2ef56f89c2ec51a44ff51eac3579aa6235b4e4..b9ffce16245657d8b8ae3db06839a5cffe6f885c 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/python/MuonSetup.py
+++ b/Trigger/TrigValidation/TrigUpgradeTest/python/MuonSetup.py
@@ -4,6 +4,13 @@
 
 from AthenaCommon.Constants import VERBOSE,DEBUG, INFO
 
+### Output data name ###
+muFastInfo = "MuonL2SAInfo"
+muCombInfo = "MuonL2CBInfo"
+muEFSAInfo = "Muons"
+muL2ISInfo = "MuonL2ISInfo"
+TrackParticlesName = "xAODTracks"
+
 ### ==================== Data prepartion needed for the EF and L2 SA ==================== ###
 def makeMuonPrepDataAlgs():
 
@@ -174,25 +181,31 @@ def makeMuonPrepDataAlgs():
 
 # This def should be removed in the future. 
 # We have not yet integrated muon decoding tool, so this def is used now.
-def makeMuFastAlgs():
+def muFastRecoSequence( RoIs, OutputLevel=INFO ):
    
 
   from MuonRecExample.MuonRecFlags import muonRecFlags
   from AthenaCommon.AppMgr import ToolSvc
   from AthenaCommon.DetFlags import DetFlags
+  from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq
+
+  muFastRecoSequence = parOR("l2MuViewNode")
 
+  ### These configurations for decoding tools should be removed. ###
   ### CSC RDO data ###
   from MuonCSC_CnvTools.MuonCSC_CnvToolsConf import Muon__CscROD_Decoder
   CSCRodDecoder = Muon__CscROD_Decoder(name		= "CscROD_Decoder_L2SA",
                                        IsCosmics	= False,
-                                       IsOldCosmics 	= False )
+                                       IsOldCosmics 	= False,
+                                       OutputLevel      = OutputLevel )
   ToolSvc += CSCRodDecoder
 
 
   from MuonCSC_CnvTools.MuonCSC_CnvToolsConf import Muon__CSC_RawDataProviderTool
   MuonCscRawDataProviderTool = Muon__CSC_RawDataProviderTool(name        = "CSC_RawDataProviderTool_L2SA",
                                                              RdoLocation = "CSCRDO_L2SA",
-                                                             Decoder     = CSCRodDecoder )
+                                                             Decoder     = CSCRodDecoder,
+                                                             OutputLevel = OutputLevel )
   ToolSvc += MuonCscRawDataProviderTool
 
   from MuonCSC_CnvTools.MuonCSC_CnvToolsConf import Muon__CscRdoToCscPrepDataTool
@@ -200,35 +213,39 @@ def makeMuFastAlgs():
                                                           RawDataProviderTool = MuonCscRawDataProviderTool,
                                                           RDOContainer        = MuonCscRawDataProviderTool.RdoLocation,
                                                           OutputCollection    = "CSC_Measurements_L2SA",
-                                                          useBStoRdoTool      = True)
+                                                          useBStoRdoTool      = True,
+                                                          OutputLevel         = OutputLevel )
   ToolSvc += CscRdoToCscPrepDataTool
 
 
   from CscClusterization.CscClusterizationConf import CscThresholdClusterBuilderTool
   CscClusterBuilderTool = CscThresholdClusterBuilderTool(name        = "CscThesholdClusterBuilderTool_L2SA",
                                                          digit_key   = CscRdoToCscPrepDataTool.OutputCollection,
-                                                         cluster_key = "CSC_Clusters_L2SA" )
+                                                         cluster_key = "CSC_Clusters_L2SA",
+                                                         OutputLevel = OutputLevel )
 
   ToolSvc += CscClusterBuilderTool
 
   from TrigL2MuonSA.TrigL2MuonSAConf import TrigL2MuonSA__CscDataPreparator
-  L2CscDataPreparator = TrigL2MuonSA__CscDataPreparator(#OutputLevel = DEBUG,
-                                                        CscPrepDataProvider  = CscRdoToCscPrepDataTool,
+  L2CscDataPreparator = TrigL2MuonSA__CscDataPreparator(CscPrepDataProvider  = CscRdoToCscPrepDataTool,
                                                         CscClusterProvider   = CscClusterBuilderTool,
-                                                        CSCPrepDataContainer = CscClusterBuilderTool.cluster_key)
+                                                        CSCPrepDataContainer = CscClusterBuilderTool.cluster_key,
+                                                        OutputLevel          = OutputLevel )
   ToolSvc += L2CscDataPreparator
 
  
   ### MDT RDO data ###
   from MuonMDT_CnvTools.MuonMDT_CnvToolsConf import MdtROD_Decoder
-  MDTRodDecoder = MdtROD_Decoder(name	   = "MdtROD_Decoder_L2SA" )
+  MDTRodDecoder = MdtROD_Decoder(name	     = "MdtROD_Decoder_L2SA",
+                                 OutputLevel = OutputLevel )
 
   ToolSvc += MDTRodDecoder
 
   from MuonMDT_CnvTools.MuonMDT_CnvToolsConf import Muon__MDT_RawDataProviderTool
   MuonMdtRawDataProviderTool = Muon__MDT_RawDataProviderTool(name        = "MDT_RawDataProviderTool_L2SA",
                                                              RdoLocation = "MDTCSM_L2SA",
-                                                             Decoder     = MDTRodDecoder )
+                                                             Decoder     = MDTRodDecoder,
+                                                             OutputLevel = OutputLevel )
   ToolSvc += MuonMdtRawDataProviderTool
 
   from MuonMDT_CnvTools.MuonMDT_CnvToolsConf import Muon__MdtRdoToPrepDataTool
@@ -236,23 +253,25 @@ def makeMuFastAlgs():
                                                        #RawDataProviderTool = MuonMdtRawDataProviderTool,
                                                        #useBStoRdoTool      = True,
                                                        RDOContainer        = MuonMdtRawDataProviderTool.RdoLocation,
-                                                       OutputCollection    = "MDT_DriftCircles_L2SA")
+                                                       OutputCollection    = "MDT_DriftCircles_L2SA",
+                                                       OutputLevel         = OutputLevel )
   ToolSvc += MdtRdoToMdtPrepDataTool
 
  
   from TrigL2MuonSA.TrigL2MuonSAConf import TrigL2MuonSA__MdtDataPreparator
-  L2MdtDataPreparator = TrigL2MuonSA__MdtDataPreparator(#OutputLevel = DEBUG,
-                                                        DecodeBS = DetFlags.readRDOBS.MDT_on(),
+  L2MdtDataPreparator = TrigL2MuonSA__MdtDataPreparator(DecodeBS = DetFlags.readRDOBS.MDT_on(),
                                                         MdtPrepDataProvider  = MdtRdoToMdtPrepDataTool,
                                                         MDTPrepDataContainer = MdtRdoToMdtPrepDataTool.OutputCollection,
                                                         MDT_RawDataProvider  = MuonMdtRawDataProviderTool,
-                                                        MDTCSMContainer      = MuonMdtRawDataProviderTool.RdoLocation )
+                                                        MDTCSMContainer      = MuonMdtRawDataProviderTool.RdoLocation,
+                                                        OutputLevel          = OutputLevel )
   ToolSvc += L2MdtDataPreparator
   
 
   ### RPC RDO data ###
   from MuonRPC_CnvTools.MuonRPC_CnvToolsConf import Muon__RpcROD_Decoder
-  RPCRodDecoder = Muon__RpcROD_Decoder(name  = "RpcROD_Decoder_L2SA" )
+  RPCRodDecoder = Muon__RpcROD_Decoder(name        = "RpcROD_Decoder_L2SA",
+                                       OutputLevel = OutputLevel )
 
   ToolSvc += RPCRodDecoder
 
@@ -260,35 +279,39 @@ def makeMuFastAlgs():
   MuonRpcRawDataProviderTool = Muon__RPC_RawDataProviderTool(name        = "RPC_RawDataProviderTool_L2SA",
                                                              RdoLocation = "RPCPAD_L2SA",
                                                              RPCSec      = "RPC_SECTORLOGIC_L2SA",
-                                                             Decoder     = RPCRodDecoder )
+                                                             Decoder     = RPCRodDecoder,
+                                                             OutputLevel = OutputLevel )
   ToolSvc += MuonRpcRawDataProviderTool
 
   from MuonRPC_CnvTools.MuonRPC_CnvToolsConf import Muon__RpcRdoToPrepDataTool
   RpcRdoToRpcPrepDataTool = Muon__RpcRdoToPrepDataTool(name                    = "RpcRdoToPrepDataTool_L2SA",
                                                        OutputCollection        = MuonRpcRawDataProviderTool.RdoLocation,
                                                        TriggerOutputCollection = "RPC_Measurements_L2SA",
-                                                       InputCollection         = "RPC_triggerHits_L2SA")
+                                                       InputCollection         = "RPC_triggerHits_L2SA",
+                                                       OutputLevel             = OutputLevel )
   ToolSvc += RpcRdoToRpcPrepDataTool
 
   from TrigL2MuonSA.TrigL2MuonSAConf import TrigL2MuonSA__RpcDataPreparator
-  L2RpcDataPreparator = TrigL2MuonSA__RpcDataPreparator(#OutputLevel = DEBUG,
-                                                        RpcPrepDataProvider  = RpcRdoToRpcPrepDataTool,
+  L2RpcDataPreparator = TrigL2MuonSA__RpcDataPreparator(RpcPrepDataProvider  = RpcRdoToRpcPrepDataTool,
                                                         RpcPrepDataContainer = RpcRdoToRpcPrepDataTool.TriggerOutputCollection,
                                                         RpcRawDataProvider   = MuonRpcRawDataProviderTool,
-                                                        DecodeBS = DetFlags.readRDOBS.RPC_on() )
+                                                        DecodeBS             = DetFlags.readRDOBS.RPC_on(),
+                                                        OutputLevel          = OutputLevel )
   ToolSvc += L2RpcDataPreparator
 
 
   ### TGC RDO data ###
   from MuonTGC_CnvTools.MuonTGC_CnvToolsConf import Muon__TGC_RodDecoderReadout
-  TGCRodDecoder = Muon__TGC_RodDecoderReadout(name	    = "TGC_RodDecoderReadout_L2SA" )
+  TGCRodDecoder = Muon__TGC_RodDecoderReadout(name	  = "TGC_RodDecoderReadout_L2SA",
+                                              OutputLevel = OutputLevel )
 
   ToolSvc += TGCRodDecoder
 
   from MuonTGC_CnvTools.MuonTGC_CnvToolsConf import Muon__TGC_RawDataProviderTool
   MuonTgcRawDataProviderTool = Muon__TGC_RawDataProviderTool(name        = "TGC_RawDataProviderTool_L2SA",
                                                              RdoLocation = "TGCRDO_L2SA",
-                                                             Decoder     = TGCRodDecoder )
+                                                             Decoder     = TGCRodDecoder,
+                                                             OutputLevel = OutputLevel )
   ToolSvc += MuonTgcRawDataProviderTool
     
   from MuonTGC_CnvTools.MuonTGC_CnvToolsConf import Muon__TgcRdoToPrepDataTool
@@ -297,14 +320,15 @@ def makeMuFastAlgs():
                                                        RDOContainer         = MuonTgcRawDataProviderTool.RdoLocation,
                                                        OutputCollection     = "TGC_Measurements_L2SA",
                                                        OutputCoinCollection = "TrigT1CoinDataCollection_L2SA",
-                                                       useBStoRdoTool       = True)
+                                                       useBStoRdoTool       = True,
+                                                       OutputLevel = OutputLevel )
 
   ToolSvc += TgcRdoToTgcPrepDataTool
 
   from TrigL2MuonSA.TrigL2MuonSAConf import TrigL2MuonSA__TgcDataPreparator
-  L2TgcDataPreparator = TrigL2MuonSA__TgcDataPreparator(#OutputLevel          = DEBUG,
-                                                        TgcPrepDataProvider  = TgcRdoToTgcPrepDataTool,
-                                                        TGCPrepDataContainer = TgcRdoToTgcPrepDataTool.OutputCollection )
+  L2TgcDataPreparator = TrigL2MuonSA__TgcDataPreparator(TgcPrepDataProvider  = TgcRdoToTgcPrepDataTool,
+                                                        TGCPrepDataContainer = TgcRdoToTgcPrepDataTool.OutputCollection,
+                                                        OutputLevel          = OutputLevel )
   ToolSvc += L2TgcDataPreparator
 
 
@@ -320,11 +344,105 @@ def makeMuFastAlgs():
   MuFastDataPreparator.TGCDataPreparator = L2TgcDataPreparator
 
   muFastAlg.DataPreparator = MuFastDataPreparator
+  muFastAlg.OutputLevel    = OutputLevel
+  muFastAlg.OutputLevel = DEBUG
+  muFastAlg.RecMuonRoI = "RecMURoIs"
+  muFastAlg.MuRoIs = RoIs
+  muFastAlg.MuonL2SAInfo = muFastInfo
+  muFastAlg.MuonCalibrationStream = "MuonCalibrationStream"
+  muFastAlg.forID = "forID"
+  muFastAlg.forMS = "forMS"
+
+  muFastRecoSequence += muFastAlg
+  sequenceOut = muFastAlg.MuonL2SAInfo
+
+  return muFastRecoSequence, sequenceOut
+
+
+def muCombRecoSequence( RoIs, OutputLevel=INFO ):
+   
+
+  from MuonRecExample.MuonRecFlags import muonRecFlags
+  from AthenaCommon.AppMgr import ToolSvc
+  from AthenaCommon.DetFlags import DetFlags
+  from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq
+  import AthenaCommon.CfgMgr as CfgMgr
 
-  return muFastAlg
+  muCombRecoSequence = parOR("l2muCombViewNode")
+
+  ### Define input data of Inner Detector algorithms  ###
+  ### and Define EventViewNodes to run the algorithms ###
+  from TrigUpgradeTest.InDetSetup import makeInDetAlgs
+  (viewAlgs, eventAlgs) = makeInDetAlgs()
+
+  from TrigFastTrackFinder.TrigFastTrackFinder_Config import TrigFastTrackFinder_Muon
+  theFTF_Muon = TrigFastTrackFinder_Muon()
+  theFTF_Muon.OutputLevel = OutputLevel
+  theFTF_Muon.isRoI_Seeded = True
+  viewAlgs.append(theFTF_Muon)
+
+  ### A simple algorithm to confirm that data has been inherited from parent view ###
+  ### Required to satisfy data dependencies                                       ###
+  ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muFastViewDataVerifier")
+  ViewVerify.DataObjects = [('xAOD::L2StandAloneMuonContainer','StoreGateSvc+'+muFastInfo)]
+  viewAlgs.append(ViewVerify)
+
+  #TrackParticlesName = ""
+  for viewAlg in viewAlgs:
+      muCombRecoSequence += viewAlg
+      viewAlg.OutputLevel = OutputLevel
+      if viewAlg.properties().has_key("RoIs"):
+          viewAlg.RoIs = RoIs
+      if viewAlg.properties().has_key("roiCollectionName"):
+          viewAlg.roiCollectionName = RoIs
+      if viewAlg.name() == "InDetTrigTrackParticleCreatorAlg":
+          TrackParticlesName = viewAlg.TrackParticlesName
+
+  ### please read out TrigmuCombMTConfig file ###
+  ### and set up to run muCombMT algorithm    ###
+  from TrigmuComb.TrigmuCombMTConfig import TrigmuCombMTConfig
+  muCombAlg = TrigmuCombMTConfig("Muon", theFTF_Muon.getName())
+  muCombAlg.OutputLevel = OutputLevel
+  muCombAlg.L2StandAloneMuonContainerName = muFastInfo
+  muCombAlg.TrackParticlesContainerName = TrackParticlesName
+  muCombAlg.L2CombinedMuonContainerName = muCombInfo
+
+  muCombRecoSequence += muCombAlg
+  sequenceOut = muCombAlg.L2CombinedMuonContainerName
+
+  return muCombRecoSequence, eventAlgs, sequenceOut, TrackParticlesName
+
+
+def l2muisoRecoSequence( RoIs, OutputLevel=INFO ):
 
+  import AthenaCommon.CfgMgr as CfgMgr
+
+  from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq
+
+  l2muisoRecoSequence = parOR("l2muIsoViewNode")
+ 
+  ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muCombViewDataVerifier")
+  ViewVerify.DataObjects = [('xAOD::TrackParticleContainer' , 'StoreGateSvc+'+TrackParticlesName),
+                            ('xAOD::L2CombinedMuonContainer','StoreGateSvc+'+muCombInfo)]
+
+  l2muisoRecoSequence += ViewVerify
+
+  # set up algs
+  from TrigmuIso.TrigmuIsoConfig import TrigmuIsoMTConfig
+  trigL2muIso = TrigmuIsoMTConfig("TrigL2muIso")
+  trigL2muIso.OutputLevel = OutputLevel
+  trigL2muIso.MuonL2CBInfoName = muCombInfo
+  trigL2muIso.TrackParticlesName = TrackParticlesName
+  trigL2muIso.MuonL2ISInfoName = muL2ISInfo
+
+  l2muisoRecoSequence += trigL2muIso
+
+  sequenceOut = trigL2muIso.MuonL2ISInfoName
 
-def makeMuEFSAAlgs():
+  return l2muisoRecoSequence, sequenceOut
+
+
+def muEFSARecoSequence( RoIs, OutputLevel=INFO ):
 
   from MuonRecExample.MuonRecFlags import muonRecFlags
   from AthenaCommon.DetFlags import DetFlags
@@ -335,7 +453,10 @@ def makeMuEFSAAlgs():
 
   from AthenaCommon.CfgGetter import getPublicTool, getPublicToolClone
   from AthenaCommon import CfgMgr
-  
+  from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq
+
+  muEFSARecoSequence = parOR("efmsViewNode")
+ 
   efAlgs = [] 
   
   ### Provide Muon_PrepDataAlgorithms ###
@@ -347,9 +468,9 @@ def makeMuEFSAAlgs():
     efAlgs.append( viewAlg_MuonPRD )
    
   from TrkDetDescrSvc.TrkDetDescrSvcConf import Trk__TrackingVolumesSvc
-  ServiceMgr += Trk__TrackingVolumesSvc("TrackingVolumesSvc",BuildVolumesFromTagInfo = False)
+  ServiceMgr += Trk__TrackingVolumesSvc("TrackingVolumesSvc",BuildVolumesFromTagInfo = False, OutputLevel=OutputLevel )
   
-  theSegmentFinder = CfgGetter.getPublicToolClone("MuonSegmentFinder","MooSegmentFinder")
+  theSegmentFinder = CfgGetter.getPublicToolClone("MuonSegmentFinder","MooSegmentFinder", OutputLevel=OutputLevel )
   theSegmentFinder.DoSummary=True
   CfgGetter.getPublicTool("MuonLayerHoughTool").DoTruth=False
   theSegmentFinderAlg=CfgMgr.MooSegmentFinderAlg( "MuonSegmentMaker",
@@ -363,11 +484,12 @@ def makeMuEFSAAlgs():
                                                   UseTGCPriorBC = False,
                                                   UseTGCNextBC  = False,
                                                   doTGCClust = muonRecFlags.doTGCClusterSegmentFinding(),
-                                                  doRPCClust = muonRecFlags.doRPCClusterSegmentFinding(), OutputLevel=DEBUG )
+                                                  doRPCClust = muonRecFlags.doRPCClusterSegmentFinding(), OutputLevel=OutputLevel )
   
   
   
   theNCBSegmentFinderAlg=CfgMgr.MooSegmentFinderAlg( "MuonSegmentMaker_NCB",
+                                                     OutputLevel = OutputLevel,
                                                      SegmentFinder = getPublicToolClone("MooSegmentFinder_NCB","MuonSegmentFinder",
                                                                                         DoSummary=False,
                                                                                         Csc2dSegmentMaker = getPublicToolClone("Csc2dSegmentMaker_NCB","Csc2dSegmentMaker",
@@ -424,7 +546,7 @@ def makeMuEFSAAlgs():
   muonparticlecreator = getPublicToolClone("MuonParticleCreator", "TrackParticleCreatorTool", UseTrackSummaryTool=False, UseMuonSummaryTool=True, KeepAllPerigee=True)
   thecreatortool= getPublicToolClone("MuonCreatorTool_SA", "MuonCreatorTool", ScatteringAngleTool="", MuonSelectionTool="", FillTimingInformation=False, UseCaloCells=False, MakeSAMuons=True, MomentumBalanceTool="",  TrackParticleCreator=muonparticlecreator, OutputLevel=DEBUG)
   
-  themuoncreatoralg = CfgMgr.MuonCreatorAlg("MuonCreatorAlg", MuonCreatorTool=thecreatortool, CreateSAmuons=True, MakeClusters=False, TagMaps=[])
+  themuoncreatoralg = CfgMgr.MuonCreatorAlg("MuonCreatorAlg", MuonCreatorTool=thecreatortool, CreateSAmuons=True, MakeClusters=False, TagMaps=[], MuonContainerLocation=muEFSAInfo)
   
   #Algorithms to views
   efAlgs.append( theSegmentFinderAlg )
@@ -433,6 +555,15 @@ def makeMuEFSAAlgs():
   efAlgs.append( xAODTrackParticleCnvAlg )
   efAlgs.append( theMuonCandidateAlg )
   efAlgs.append( themuoncreatoralg )
+
+  # setup muEFMsonly algs
+  for efAlg in efAlgs:
+      if efAlg.properties().has_key("RoIs"):
+          efAlg.RoIs = RoIs
+      muEFSARecoSequence += efAlg
+  sequenceOut = themuoncreatoralg.MuonContainerLocation
+
   
-  return efAlgs
+  return muEFSARecoSequence, sequenceOut
+
 
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/python/muMenuDefs.py b/Trigger/TrigValidation/TrigUpgradeTest/python/muMenuDefs.py
index 162de5402c675ecb80e4e530b35e96bc8e40ac30..2621d948d4efe564c9806422393a60963f3fb395 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/python/muMenuDefs.py
+++ b/Trigger/TrigValidation/TrigUpgradeTest/python/muMenuDefs.py
@@ -59,55 +59,32 @@ from ViewAlgs.ViewAlgsConf import EventViewCreatorAlgorithm
 
 ServiceMgr.ToolSvc.TrigDataAccess.ApplyOffsetCorrection = False
 
-### Output data name ###
-muFastInfo = "MuonL2SAInfo"
-muCombInfo = "MuonL2CBInfo"
-muEFSAInfo = "Muons"
-muL2ISInfo = "MuonL2ISInfo"
-# get Track container name
-TrackParticlesName = ""
-from TrigUpgradeTest.InDetSetup import makeInDetAlgs
-(nameAlgs, evAlgs) = makeInDetAlgs()
-for nameAlg in nameAlgs:
-    if nameAlg.name() == "InDetTrigTrackParticleCreatorAlg":
-        TrackParticlesName = nameAlg.TrackParticlesName
- 
 
 ### ************* Step1  ************* ###
 
 def muFastStep():
 
     ### set the EVCreator ###
-    l2MuViewNode = parOR("l2MuViewNode")
-    
     l2MuViewsMaker = EventViewCreatorAlgorithm("l2MuViewsMaker", OutputLevel=DEBUG)
     l2MuViewsMaker.ViewFallThrough = True
     l2MuViewsMaker.RoIsLink = "initialRoI" # -||-
     l2MuViewsMaker.InViewRoIs = "MURoIs" # contract with the consumer
     l2MuViewsMaker.Views = "MUViewRoIs"
-    l2MuViewsMaker.ViewNodeName = l2MuViewNode.name()
 
-     ### set up muFast algs ###    
-    from TrigUpgradeTest.MuonSetup import makeMuFastAlgs
-    muFastAlg = makeMuFastAlgs()
-    muFastAlg.OutputLevel = DEBUG
-    muFastAlg.RecMuonRoI = "RecMURoIs"
-    muFastAlg.MuRoIs = l2MuViewsMaker.InViewRoIs 
-    muFastAlg.MuonL2SAInfo = muFastInfo 
-    muFastAlg.MuonCalibrationStream = "MuonCalibrationStream"
-    muFastAlg.forID = "forID"
-    muFastAlg.forMS = "forMS"
+    ### get muFast reco sequence ###    
+    from TrigUpgradeTest.MuonSetup import muFastRecoSequence
+    muFastRecoSequence, sequenceOut = muFastRecoSequence( l2MuViewsMaker.InViewRoIs, OutputLevel=DEBUG )
     
-    l2MuViewNode += muFastAlg
+    l2MuViewsMaker.ViewNodeName = muFastRecoSequence.name() 
     
     ### set up MuFastHypo ###
     from TrigMuonHypo.TrigMuonHypoConf import TrigMufastHypoAlg
     trigMufastHypo = TrigMufastHypoAlg("TrigL2MufastHypoAlg")
     trigMufastHypo.OutputLevel = DEBUG
-    trigMufastHypo.MuonL2SAInfoFromMuFastAlg = muFastInfo
+    trigMufastHypo.MuonL2SAInfoFromMuFastAlg = sequenceOut
     
     
-    l2muFastSequence = seqAND("l2muFastSequence", [ l2MuViewsMaker, l2MuViewNode ])
+    l2muFastSequence = seqAND("l2muFastSequence", [ l2MuViewsMaker, muFastRecoSequence ])
     
     
     from TrigMuonHypo.testTrigMuonHypoConfig import TrigMufastHypoToolFromName
@@ -123,58 +100,26 @@ def muFastStep():
 def muCombStep():
 
     ### set the EVCreator ###
-    l2muCombViewNode = parOR("l2muCombViewNode")
-    
     l2muCombViewsMaker = EventViewCreatorAlgorithm("l2muCombViewsMaker", OutputLevel=DEBUG)
     l2muCombViewsMaker.ViewFallThrough = True
     l2muCombViewsMaker.RoIsLink = "roi" # -||-
     l2muCombViewsMaker.InViewRoIs = "EMIDRoIs" # contract with the consumer
     l2muCombViewsMaker.Views = "EMCombViewRoIs"
-    l2muCombViewsMaker.ViewNodeName = l2muCombViewNode.name()
-    
-    ### Define input data of Inner Detector algorithms  ###
-    ### and Define EventViewNodes to run the algorithms ###
-    from TrigUpgradeTest.InDetSetup import makeInDetAlgs
-    (viewAlgs, eventAlgs) = makeInDetAlgs()
-    
-    from TrigFastTrackFinder.TrigFastTrackFinder_Config import TrigFastTrackFinder_Muon
-    theFTF_Muon = TrigFastTrackFinder_Muon()
-    theFTF_Muon.OutputLevel = DEBUG
-    theFTF_Muon.isRoI_Seeded = True
-    viewAlgs.append(theFTF_Muon)
-    
-    ### A simple algorithm to confirm that data has been inherited from parent view ###
-    ### Required to satisfy data dependencies                                       ###
-    ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muFastViewDataVerifier")
-    ViewVerify.DataObjects = [('xAOD::L2StandAloneMuonContainer','StoreGateSvc+'+muFastInfo)]
-    viewAlgs.append(ViewVerify)
-    
-    for viewAlg in viewAlgs:
-        l2muCombViewNode += viewAlg
-        if viewAlg.properties().has_key("RoIs"):
-            viewAlg.RoIs = l2muCombViewsMaker.InViewRoIs
-        if viewAlg.properties().has_key("roiCollectionName"):
-            viewAlg.roiCollectionName = l2muCombViewsMaker.InViewRoIs
-    
-    ### please read out TrigmuCombMTConfig file ###
-    ### and set up to run muCombMT algorithm    ###
-    from TrigmuComb.TrigmuCombMTConfig import TrigmuCombMTConfig
-    muCombAlg = TrigmuCombMTConfig("Muon", theFTF_Muon.getName())
-    muCombAlg.OutputLevel = DEBUG
-    muCombAlg.L2StandAloneMuonContainerName = muFastInfo
-    muCombAlg.TrackParticlesContainerName = TrackParticlesName
-    muCombAlg.L2CombinedMuonContainerName = muCombInfo
-    
-    l2muCombViewNode += muCombAlg
     
+    ### get muComb reco sequence ###    
+    from TrigUpgradeTest.MuonSetup import muCombRecoSequence
+    muCombRecoSequence, eventAlgs, sequenceOut, TrackParticlesName = muCombRecoSequence( l2muCombViewsMaker.InViewRoIs, OutputLevel=DEBUG )
+ 
+    l2muCombViewsMaker.ViewNodeName = muCombRecoSequence.name()
+   
     ### set up muCombHypo algorithm ###
     from TrigMuonHypo.TrigMuonHypoConf import TrigmuCombHypoAlg
     #trigmuCombHypo = TrigmuCombHypoAlg("L2muCombHypoAlg") # avoid to have "Comb" string in the name due to HLTCFConfig.py. 
     trigmuCombHypo = TrigmuCombHypoAlg("TrigL2MuCBHypoAlg")
     trigmuCombHypo.OutputLevel = DEBUG
-    trigmuCombHypo.MuonL2CBInfoFromMuCombAlg = muCombInfo 
+    trigmuCombHypo.MuonL2CBInfoFromMuCombAlg = sequenceOut
     
-    l2muCombSequence = seqAND("l2muCombSequence", eventAlgs + [l2muCombViewsMaker, l2muCombViewNode ] )
+    l2muCombSequence = seqAND("l2muCombSequence", eventAlgs + [l2muCombViewsMaker, muCombRecoSequence] )
     
     from TrigMuonHypo.testTrigMuonHypoConfig import TrigmuCombHypoToolFromName
     
@@ -189,30 +134,25 @@ def muCombStep():
 ###  EFMSonly step ###
 def muEFMSStep():
 
-    efmsViewNode = parOR("efmsViewNode")
-    
     efmsViewsMaker = EventViewCreatorAlgorithm("efmsViewsMaker", OutputLevel=DEBUG)
     efmsViewsMaker.ViewFallThrough = True
     efmsViewsMaker.RoIsLink = "initialRoI" # -||-
     efmsViewsMaker.InViewRoIs = "MUEFMSRoIs" # contract with the consumer
     efmsViewsMaker.Views = "MUEFMSViewRoIs"
-    efmsViewsMaker.ViewNodeName = efmsViewNode.name()
 
-    # setup muEFMsonly algs
-    from TrigUpgradeTest.MuonSetup import makeMuEFSAAlgs
-    efAlgs = makeMuEFSAAlgs()    
-    for efAlg in efAlgs:
-        if efAlg.properties().has_key("RoIs"):
-            efAlg.RoIs = efmsViewsMaker.InViewRoIs
-        efmsViewNode += efAlg
+    ### get EF reco sequence ###    
+    from TrigUpgradeTest.MuonSetup import muEFSARecoSequence
+    muEFMSRecoSequence, sequenceOut = muEFSARecoSequence( efmsViewsMaker.InViewRoIs, OutputLevel=DEBUG )
+ 
+    efmsViewsMaker.ViewNodeName = muEFMSRecoSequence.name()
     
     # setup MS-only hypo
     from TrigMuonHypo.TrigMuonHypoConf import TrigMuonEFMSonlyHypoAlg
     trigMuonEFMSHypo = TrigMuonEFMSonlyHypoAlg( "TrigMuonEFMSHypoAlg" )
     trigMuonEFMSHypo.OutputLevel = DEBUG
-    trigMuonEFMSHypo.MuonDecisions = muEFSAInfo
+    trigMuonEFMSHypo.MuonDecisions = sequenceOut
     
-    muonEFMSonlySequence = seqAND( "muonEFMSonlySequence", [efmsViewsMaker, efmsViewNode] )
+    muonEFMSonlySequence = seqAND( "muonEFMSonlySequence", [efmsViewsMaker, muEFMSRecoSequence] )
     
     from TrigMuonHypo.testTrigMuonHypoConfig import TrigMuonEFMSonlyHypoToolFromName
     
@@ -224,31 +164,26 @@ def muEFMSStep():
 ###  EFSA step ###
 def muEFSAStep():
 
-    efsaViewNode = parOR("efsaViewNode")
-    
     efsaViewsMaker = EventViewCreatorAlgorithm("efsaViewsMaker", OutputLevel=DEBUG)
     efsaViewsMaker.ViewFallThrough = True
     #efsaViewsMaker.RoIsLink = "initialRoI" # -||-
     efsaViewsMaker.RoIsLink = "roi" # -||-
     efsaViewsMaker.InViewRoIs = "MUEFSARoIs" # contract with the consumer
     efsaViewsMaker.Views = "MUEFSAViewRoIs"
-    efsaViewsMaker.ViewNodeName = efsaViewNode.name()
    
-    # setup muEFMsonly algs
-    from TrigUpgradeTest.MuonSetup import makeMuEFSAAlgs
-    efAlgs = makeMuEFSAAlgs()    
-    for efAlg in efAlgs:
-        if efAlg.properties().has_key("RoIs"):
-            efAlg.RoIs = efsaViewsMaker.InViewRoIs
-        efsaViewNode += efAlg
+    ### get EF reco sequence ###    
+    from TrigUpgradeTest.MuonSetup import muEFSARecoSequence
+    muEFSARecoSequence, sequenceOut = muEFSARecoSequence( efsaViewsMaker.InViewRoIs, OutputLevel=DEBUG )
+ 
+    efsaViewsMaker.ViewNodeName = muEFSARecoSequence.name()
     
     # setup EFSA hypo
     from TrigMuonHypo.TrigMuonHypoConf import TrigMuonEFMSonlyHypoAlg
     trigMuonEFSAHypo = TrigMuonEFMSonlyHypoAlg( "TrigMuonEFSAHypoAlg" )
     trigMuonEFSAHypo.OutputLevel = DEBUG
-    trigMuonEFSAHypo.MuonDecisions = muEFSAInfo
+    trigMuonEFSAHypo.MuonDecisions = sequenceOut
     
-    muonEFSAonlySequence = seqAND( "muonEFSAonlySequence", [efsaViewsMaker, efsaViewNode] )
+    muonEFSAonlySequence = seqAND( "muonEFSAonlySequence", [efsaViewsMaker, muEFSARecoSequence ] )
     
     from TrigMuonHypo.testTrigMuonHypoConfig import TrigMuonEFMSonlyHypoToolFromName
     
@@ -260,38 +195,26 @@ def muEFSAStep():
 ### l2Muiso step ###
 def muIsoStep():
 
-    l2muIsoViewNode = parOR("l2muIsoViewNode")
-    
     l2muIsoViewsMaker = EventViewCreatorAlgorithm("l2muIsoViewsMaker", OutputLevel=DEBUG)
     l2muIsoViewsMaker.ViewFallThrough = True
     l2muIsoViewsMaker.RoIsLink = "roi" # -||-
     l2muIsoViewsMaker.InViewRoIs = "MUIsoRoIs" # contract with the consumer
     l2muIsoViewsMaker.Views = "MUIsoViewRoIs"
-    l2muIsoViewsMaker.ViewNodeName = l2muIsoViewNode.name()
 
-    ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muCombViewDataVerifier")
-    ViewVerify.DataObjects = [('xAOD::TrackParticleContainer' , 'StoreGateSvc+'+TrackParticlesName),
-                              ('xAOD::L2CombinedMuonContainer','StoreGateSvc+'+muCombInfo)]
-    l2muIsoViewNode += ViewVerify 
+    ### get EF reco sequence ###    
+    from TrigUpgradeTest.MuonSetup import l2muisoRecoSequence
+    l2muisoRecoSequence, sequenceOut = l2muisoRecoSequence( l2muIsoViewsMaker.InViewRoIs, OutputLevel=DEBUG )
+ 
+    l2muIsoViewsMaker.ViewNodeName = l2muisoRecoSequence.name()
  
-    # set up algs    
-    from TrigmuIso.TrigmuIsoConfig import TrigmuIsoMTConfig
-    trigL2muIso = TrigmuIsoMTConfig("TrigL2muIso")
-    trigL2muIso.OutputLevel = DEBUG
-    trigL2muIso.MuonL2CBInfoName = muCombInfo
-    trigL2muIso.TrackParticlesName = TrackParticlesName
-    trigL2muIso.MuonL2ISInfoName = muL2ISInfo
-    
-    l2muIsoViewNode += trigL2muIso
-
     # set up hypo    
     from TrigMuonHypo.TrigMuonHypoConf import TrigMuisoHypoAlg
     trigmuIsoHypo = TrigMuisoHypoAlg("L2MuisoHypoAlg")
     trigmuIsoHypo.OutputLevel = DEBUG
-    trigmuIsoHypo.MuonL2ISInfoName = muL2ISInfo
+    trigmuIsoHypo.MuonL2ISInfoName = sequenceOut
     
     ### Define a Sequence to run for muIso ### 
-    l2muIsoSequence = seqAND("l2muIsoSequence", [ l2muIsoViewsMaker, l2muIsoViewNode ] )
+    l2muIsoSequence = seqAND("l2muIsoSequence", [ l2muIsoViewsMaker, l2muisoRecoSequence ] )
     
     from TrigMuonHypo.testTrigMuonHypoConfig import TrigMuisoHypoToolFromName
 
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/share/Calo.py b/Trigger/TrigValidation/TrigUpgradeTest/share/Calo.py
index bc444d4b249df89126738d518d9d7bafdbae7de7..1b18215d59fc82fd48fe721e9dc6cbb61ac7bf21 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/share/Calo.py
+++ b/Trigger/TrigValidation/TrigUpgradeTest/share/Calo.py
@@ -55,7 +55,7 @@ if TriggerFlags.doCalo:
   from TrigT2CaloEgamma.TrigT2CaloEgammaConfig import T2CaloEgamma_ReFastAlgo
   algo=T2CaloEgamma_ReFastAlgo("testReFastAlgo")
   # temporary fix for Tile
-  algo.ExtraInputs=[('TileEMScale','ConditionStore+TileEMScale')]
+  algo.ExtraInputs=[('TileEMScale','ConditionStore+TileEMScale'),('TileBadChannels','ConditionStore+TileBadChannels')]
   algo.OutputLevel=VERBOSE
 
   algo.RoIs="StoreGateSvc+EMRoIs"
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/share/mu.withViews.py b/Trigger/TrigValidation/TrigUpgradeTest/share/mu.withViews.py
index 154c7e86055a2eb7bf08365496d7e04a42c5e3ae..bbb34aa48762f09786816688b5f5cb38a8d2d36d 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/share/mu.withViews.py
+++ b/Trigger/TrigValidation/TrigUpgradeTest/share/mu.withViews.py
@@ -6,8 +6,6 @@
 
 include("TrigUpgradeTest/testHLT_MT.py") 
 
-from AthenaCommon.DetFlags import DetFlags
-
 TriggerFlags.doID   = False;
 TriggerFlags.doMuon = True;
 
@@ -24,24 +22,6 @@ if not 'doEFSA' in dir():
 if not 'doEFISO' in dir():
   doEFISO=True
 
-### workaround to prevent online trigger folders to be enabled ###
-if doL2CB or doL2ISO:
-  from InDetRecExample.InDetJobProperties import InDetFlags
-  InDetFlags.doCaloSeededBrem = False
-  InDetFlags.InDet25nsec = True 
-  InDetFlags.doPrimaryVertex3DFinding = False 
-  InDetFlags.doPrintConfigurables = False
-  InDetFlags.doResolveBackTracks = True 
-  InDetFlags.doSiSPSeededTrackFinder = True
-  InDetFlags.doTRTPhaseCalculation = True
-  InDetFlags.doTRTSeededTrackFinder = True
-  InDetFlags.doTruth = False
-  InDetFlags.init()
-  
-  from InDetRecExample.InDetKeys import InDetKeys
-
-### PixelLorentzAngleSvc and SCTLorentzAngleSvc ###
-include("InDetRecExample/InDetRecConditionsAccess.py")
 
 from AthenaCommon.AlgSequence import AlgSequence
 topSequence = AlgSequence()
@@ -64,10 +44,6 @@ from AthenaCommon.AppMgr import ServiceMgr
 ServiceMgr.StoreGateSvc=Service("StoreGateSvc") 
 ServiceMgr.StoreGateSvc.Dump=True 
  
-### for Control Flow ###
-from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq
-from DecisionHandling.DecisionHandlingConf import RoRSeqFilter, DumpDecisions
-
  
 from AthenaCommon.AlgScheduler import AlgScheduler
 AlgScheduler.CheckDependencies( True )
@@ -76,9 +52,6 @@ AlgScheduler.ShowDataDependencies( True )
 AlgScheduler.setDataLoaderAlg( 'SGInputLoader' )
 
 
-from AthenaCommon.CfgGetter import getPublicTool, getPublicToolClone
-from AthenaCommon import CfgMgr
-
 ### muon thresholds ###
 CTPToChainMapping = { "HLT_mu6" :  "L1_MU6",
                       "HLT_2mu6":  "L1_2MU4" }
@@ -115,26 +88,24 @@ def __mon(finalCollName, stepColls=[]):
 #               Setup the standard muon chain 
 # ===============================================================================================
 
-## Used the algorithms as Step2 "muComb step" ###
-viewAlgs = []
-if doL2CB:
-  # Only do setup of ID stuff if we run combined muon finding
-  from TrigUpgradeTest.InDetSetup import makeInDetAlgs
-  (viewAlgs, eventAlgs) = makeInDetAlgs()
-
-  from TrigFastTrackFinder.TrigFastTrackFinder_Config import TrigFastTrackFinder_Muon
-  theFTF = TrigFastTrackFinder_Muon()
-  theFTF.OutputLevel = DEBUG
-  theFTF.TracksName = "TrigFastTrackFinder_MuTracks"
-  theFTF.isRoI_Seeded = True
-  viewAlgs.append(theFTF)
-
-  ### A simple algorithm to confirm that data has been inherited from parent view ###
-  ### Required to satisfy data dependencies                                       ###
-  ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muFastViewDataVerifier")
-  ViewVerify.DataObjects = [('xAOD::L2StandAloneMuonContainer','StoreGateSvc+MuonL2SAInfo')]
-  viewAlgs.append(ViewVerify)
+### workaround to prevent online trigger folders to be enabled ###
+from AthenaCommon.DetFlags import DetFlags
+from InDetRecExample.InDetJobProperties import InDetFlags
+InDetFlags.doCaloSeededBrem = False
+InDetFlags.InDet25nsec = True 
+InDetFlags.doPrimaryVertex3DFinding = False 
+InDetFlags.doPrintConfigurables = False
+InDetFlags.doResolveBackTracks = True 
+InDetFlags.doSiSPSeededTrackFinder = True
+InDetFlags.doTRTPhaseCalculation = True
+InDetFlags.doTRTSeededTrackFinder = True
+InDetFlags.doTruth = False
+InDetFlags.init()
+
+from InDetRecExample.InDetKeys import InDetKeys
 
+### PixelLorentzAngleSvc and SCTLorentzAngleSvc ###
+include("InDetRecExample/InDetRecConditionsAccess.py")
 
 ### Load data from Muon detectors ###
 import MuonRecExample.MuonRecStandaloneOnlySetup
@@ -149,12 +120,20 @@ from RecExConfig.RecFlags import rec
 from AthenaCommon.AlgSequence import AthSequencer
 from ViewAlgs.ViewAlgsConf import EventViewCreatorAlgorithm
 
+svcMgr.ToolSvc.TrigDataAccess.ApplyOffsetCorrection = False
+
+### for Control Flow ###
+from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq
+from DecisionHandling.DecisionHandlingConf import RoRSeqFilter, DumpDecisions
+
+### for Cfg Getter and Manager ###
+from AthenaCommon.CfgGetter import getPublicTool, getPublicToolClone
+from AthenaCommon import CfgMgr
+
 
 ### ************* Step1  ************* ###
 if TriggerFlags.doMuon:
 
-  svcMgr.ToolSvc.TrigDataAccess.ApplyOffsetCorrection = False
-
   ### set up L1RoIsFilter ###
   filterL1RoIsAlg = RoRSeqFilter("filterL1RoIsAlg")
   filterL1RoIsAlg.Input = ["MURoIDecisions"]
@@ -163,9 +142,8 @@ if TriggerFlags.doMuon:
   filterL1RoIsAlg.OutputLevel = DEBUG
 
   if doL2SA:
-    ### set the EVCreator ###
-    l2MuViewNode = parOR("l2MuViewNode")
 
+    ### set the EVCreator ###
     l2MuViewsMaker = EventViewCreatorAlgorithm("l2MuViewsMaker", OutputLevel=DEBUG)
     l2MuViewsMaker.ViewFallThrough = True
     l2MuViewsMaker.InputMakerInputDecisions = filterL1RoIsAlg.Output 
@@ -173,26 +151,18 @@ if TriggerFlags.doMuon:
     l2MuViewsMaker.RoIsLink = "initialRoI" # -||-
     l2MuViewsMaker.InViewRoIs = "MURoIs" # contract with the consumer
     l2MuViewsMaker.Views = "MUViewRoIs"
-    l2MuViewsMaker.ViewNodeName = l2MuViewNode.name()
-
-    ### set up MuFastSteering ###
-    from TrigUpgradeTest.MuonSetup import makeMuFastAlgs
-    muFastAlg = makeMuFastAlgs()
-    muFastAlg.OutputLevel = DEBUG
-    muFastAlg.RecMuonRoI = "RecMURoIs"
-    muFastAlg.MuRoIs = l2MuViewsMaker.InViewRoIs 
-    muFastAlg.MuonL2SAInfo = "MuonL2SAInfo"
-    muFastAlg.MuonCalibrationStream = "MuonCalibrationStream"
-    muFastAlg.forID = "forID"
-    muFastAlg.forMS = "forMS"
-
-    l2MuViewNode += muFastAlg
- 
+
+    ### get muFast reco sequence ###
+    from TrigUpgradeTest.MuonSetup import muFastRecoSequence
+    muFastRecoSequence, muFastSequenceOut = muFastRecoSequence( l2MuViewsMaker.InViewRoIs, OutputLevel=DEBUG )
+
+    l2MuViewsMaker.ViewNodeName = muFastRecoSequence.name()
+
     ### set up MuFastHypo ###
     from TrigMuonHypo.TrigMuonHypoConfigMT import TrigMufastHypoConfig
     trigMufastHypo = TrigMufastHypoConfig("TrigL2MufastHypoAlg")
     trigMufastHypo.OutputLevel = DEBUG
-    trigMufastHypo.MuonL2SAInfoFromMuFastAlg = muFastAlg.MuonL2SAInfo
+    trigMufastHypo.MuonL2SAInfoFromMuFastAlg = muFastSequenceOut
     trigMufastHypo.HypoOutputDecisions = "L2MuonFastDecisions"
     trigMufastHypo.HypoInputDecisions = l2MuViewsMaker.InputMakerOutputDecisions[0]
     trigMufastHypo.HypoTools = [ trigMufastHypo.TrigMufastHypoToolFromName( "TrigL2MufastHypoTool", c ) for c in testChains ] 
@@ -201,14 +171,16 @@ if TriggerFlags.doMuon:
     muFastDecisionsDumper = DumpDecisions("muFastDecisionsDumper", OutputLevel=DEBUG, Decisions = trigMufastHypo.HypoOutputDecisions )
 
     ### make sequences ###
-    l2muFastSequence = seqAND("l2muFastSequence", [ l2MuViewsMaker, l2MuViewNode, trigMufastHypo ])
+    l2muFastSequence = seqAND("l2muFastSequence", [ l2MuViewsMaker, muFastRecoSequence, trigMufastHypo ])
 
+    ### make step ###
     muFastStep = stepSeq("muFastStep", filterL1RoIsAlg, [ l2muFastSequence,  muFastDecisionsDumper ] )
 
 
 ### ************* Step2  ************* ###
 
   if doL2CB:
+
     ### RoRSeqFilter step2 ###
     filterL2SAAlg = RoRSeqFilter("filterL2SAAlg")
     filterL2SAAlg.Input = [trigMufastHypo.HypoOutputDecisions]
@@ -217,41 +189,19 @@ if TriggerFlags.doMuon:
     filterL2SAAlg.OutputLevel = DEBUG
 
     ### set the EVCreator ###
-    l2muCombViewNode = parOR("l2muCombViewNode")
-
     l2muCombViewsMaker = EventViewCreatorAlgorithm("l2muCombViewsMaker", OutputLevel=DEBUG)
     l2muCombViewsMaker.ViewFallThrough = True
- 
     l2muCombViewsMaker.InputMakerInputDecisions = [ filterL2SAAlg.Output[0] ] # Output of TrigMufastHypo
     l2muCombViewsMaker.InputMakerOutputDecisions = [ "MUL2SADecisionsOutput" ] 
     l2muCombViewsMaker.RoIsLink = "roi" # -||-
     l2muCombViewsMaker.InViewRoIs = "MUTrkRoIs" # contract with the consumer
     l2muCombViewsMaker.Views = "MUTrkViewRoIs"
-    l2muCombViewsMaker.ViewNodeName = l2muCombViewNode.name()
-
-    ### Define input data of Inner Detector algorithms  ###
-    ### and Define EventViewNodes to run the algprithms ###
-    TrackParticlesName = ""
-    for viewAlg in viewAlgs:
-      l2muCombViewNode += viewAlg
-      if viewAlg.properties().has_key("RoIs"):
-        viewAlg.RoIs = l2muCombViewsMaker.InViewRoIs
-      if viewAlg.properties().has_key("roiCollectionName"):
-        viewAlg.roiCollectionName = l2muCombViewsMaker.InViewRoIs
-      if viewAlg.name() == "InDetTrigTrackParticleCreatorAlg":
-        TrackParticlesName = viewAlg.TrackParticlesName
-        viewAlg.TrackName = theFTF.TracksName
-
-    ### please read out TrigmuCombMTConfig file ###
-    ### and set up to run muCombMT algorithm    ###
-    from TrigmuComb.TrigmuCombMTConfig import TrigmuCombMTConfig
-    muCombAlg = TrigmuCombMTConfig("Muon", theFTF.getName())
-    muCombAlg.OutputLevel = DEBUG
-    muCombAlg.L2StandAloneMuonContainerName = muFastAlg.MuonL2SAInfo
-    muCombAlg.TrackParticlesContainerName = TrackParticlesName
-    muCombAlg.L2CombinedMuonContainerName = "MuonL2CBInfo"
-
-    l2muCombViewNode += muCombAlg
+
+    ### get muComb reco sequence ###
+    from TrigUpgradeTest.MuonSetup import muCombRecoSequence
+    muCombRecoSequence, eventAlgs, muCombSequenceOut, TrackParticlesName = muCombRecoSequence( l2muCombViewsMaker.InViewRoIs, OutputLevel=DEBUG )
+
+    l2muCombViewsMaker.ViewNodeName = muCombRecoSequence.name()
 
     ### set up muCombHypo algorithm ###
     from TrigMuonHypo.TrigMuonHypoConfigMT import TrigmuCombHypoConfig
@@ -259,15 +209,16 @@ if TriggerFlags.doMuon:
     trigmuCombHypo.OutputLevel = DEBUG 
     trigmuCombHypo.HypoOutputDecisions = "MuonL2CBDecisions"
     trigmuCombHypo.HypoInputDecisions = l2muCombViewsMaker.InputMakerOutputDecisions[0]
-    trigmuCombHypo.MuonL2CBInfoFromMuCombAlg = muCombAlg.L2CombinedMuonContainerName 
+    trigmuCombHypo.MuonL2CBInfoFromMuCombAlg = muCombSequenceOut
     trigmuCombHypo.HypoTools = [ trigmuCombHypo.TrigmuCombHypoToolFromName( "TrigL2muCombHypoTool", c ) for c in testChains ] 
   
     ### set the dumper ###
     muCombDecisionsDumper = DumpDecisions("muCombDecisionsDumper", OutputLevel=DEBUG, Decisions = trigmuCombHypo.HypoOutputDecisions )
- 
-    ### Define a Sequence to run for muComb ### 
-    l2muCombSequence = seqAND("l2muCombSequence", eventAlgs + [l2muCombViewsMaker, l2muCombViewNode, trigmuCombHypo ] )
 
+    ### make sequence ### 
+    l2muCombSequence = seqAND("l2muCombSequence", eventAlgs + [l2muCombViewsMaker, muCombRecoSequence, trigmuCombHypo ] )
+
+    ### make step ### 
     muCombStep = stepSeq("muCombStep", filterL2SAAlg, [ l2muCombSequence,  muCombDecisionsDumper ] )
 
 
@@ -288,8 +239,6 @@ if TriggerFlags.doMuon:
     filterEFSAAlg.OutputLevel = DEBUG
 
     ### set the EVCreator ###
-    efMuViewNode = parOR("efMuViewNode")
-
     efMuViewsMaker = EventViewCreatorAlgorithm("efMuViewsMaker", OutputLevel=DEBUG)
     efMuViewsMaker.ViewFallThrough = True
     # probably wrong input to the EVMaker
@@ -298,36 +247,35 @@ if TriggerFlags.doMuon:
     efMuViewsMaker.RoIsLink = "initialRoI" # -||-
     efMuViewsMaker.InViewRoIs = "MURoIs" # contract with the consumer
     efMuViewsMaker.Views = "EFMUViewRoIs"
-    efMuViewsMaker.ViewNodeName = efMuViewNode.name()
-
-    # setup muEFMsonly algs
-    from TrigUpgradeTest.MuonSetup import makeMuEFSAAlgs
-    efAlgs = makeMuEFSAAlgs()
-    muEFSAInfo = ""
-    for efAlg in efAlgs:
-      if efAlg.properties().has_key("RoIs"):
-        efAlg.RoIs = efMuViewsMaker.InViewRoIs
-      if efAlg.properties().has_key("MuonContainerLocation"):
-        muEFSAInfo = "Muons"
-        efAlg.MuonContainerLocation = muEFSAInfo
-      efMuViewNode += efAlg
+
+    ### get EF reco sequence ###
+    from TrigUpgradeTest.MuonSetup import muEFSARecoSequence
+    muEFMSRecoSequence, muEFSASequenceOut = muEFSARecoSequence( efMuViewsMaker.InViewRoIs, OutputLevel=DEBUG )
+ 
+    efMuViewsMaker.ViewNodeName = muEFMSRecoSequence.name()
 
     #Setup MS-only hypo
     from TrigMuonHypo.TrigMuonHypoConfigMT import TrigMuonEFMSonlyHypoConfig
     trigMuonEFSAHypo = TrigMuonEFMSonlyHypoConfig("TrigMuonEFSAHypoAlg")
     trigMuonEFSAHypo.OutputLevel = DEBUG
-    trigMuonEFSAHypo.MuonDecisions = muEFSAInfo
+    trigMuonEFSAHypo.MuonDecisions = muEFSASequenceOut
     trigMuonEFSAHypo.HypoOutputDecisions = "EFMuonSADecisions"
     trigMuonEFSAHypo.HypoInputDecisions = efMuViewsMaker.InputMakerOutputDecisions[0]
 
     trigMuonEFSAHypo.HypoTools = [ trigMuonEFSAHypo.TrigMuonEFMSonlyHypoToolFromName( "TrigMuonEFMSonlyHypoTool", c ) for c in testChains ] 
 
+    ### set the dumper ###
     muonEFSADecisionsDumper = DumpDecisions("muonEFSADecisionsDumper", OutputLevel=DEBUG, Decisions = trigMuonEFSAHypo.HypoOutputDecisions )
-    muEFSASequence = seqAND("muEFSASequence", [efMuViewsMaker, efMuViewNode, trigMuonEFSAHypo])
+
+    ### make sequence ### 
+    muEFSASequence = seqAND("muEFSASequence", [efMuViewsMaker, muEFMSRecoSequence, trigMuonEFSAHypo])
+
+    ### make step ### 
     muonEFSAStep = stepSeq("muonEFSAStep", filterEFSAAlg, [muEFSASequence, muonEFSADecisionsDumper])
 
 
   if doL2CB and doL2ISO:
+
     ### RoRSeqFilter step2 for muIso ###
     filterL2MuisoAlg = RoRSeqFilter("filterL2MuisoAlg")
     filterL2MuisoAlg.Input = [trigmuCombHypo.HypoOutputDecisions]
@@ -336,8 +284,6 @@ if TriggerFlags.doMuon:
     filterL2MuisoAlg.OutputLevel = DEBUG
     
     ### set the EVCreator ###    
-    l2muIsoViewNode = parOR("l2muIsoViewNode")
-
     l2muIsoViewsMaker = EventViewCreatorAlgorithm("l2muIsoViewsMaker", OutputLevel=DEBUG)
     l2muIsoViewsMaker.ViewFallThrough = True 
     l2muIsoViewsMaker.InputMakerInputDecisions = [ filterL2MuisoAlg.Output[0] ] # Output of TrigMufastHypo
@@ -345,30 +291,29 @@ if TriggerFlags.doMuon:
     l2muIsoViewsMaker.RoIsLink = "roi" # -||-
     l2muIsoViewsMaker.InViewRoIs = "MUIsoRoIs" # contract with the consumer
     l2muIsoViewsMaker.Views = "MUIsoViewRoIs"
-    l2muIsoViewsMaker.ViewNodeName = l2muIsoViewNode.name()
 
-    from TrigmuIso.TrigmuIsoConfig import TrigmuIsoMTConfig
-    trigL2muIso = TrigmuIsoMTConfig("L2muIso")
-    trigL2muIso.OutputLevel = DEBUG
-    trigL2muIso.MuonL2CBInfoName = muCombAlg.L2CombinedMuonContainerName
-    trigL2muIso.TrackParticlesName = TrackParticlesName
-    trigL2muIso.MuonL2ISInfoName = "MuonL2ISInfo"
+    ### get EF reco sequence ###
+    from TrigUpgradeTest.MuonSetup import l2muisoRecoSequence
+    l2muisoRecoSequence, l2muIsoSequenceOut = l2muisoRecoSequence( l2muIsoViewsMaker.InViewRoIs, OutputLevel=DEBUG )
 
-    l2muIsoViewNode += trigL2muIso
+    l2muIsoViewsMaker.ViewNodeName = l2muisoRecoSequence.name()
 
     from TrigMuonHypo.TrigMuonHypoConfigMT import TrigMuisoHypoConfig
     trigmuIsoHypo = TrigMuisoHypoConfig("TrigL2MuisoHypoAlg")
     trigmuIsoHypo.OutputLevel = DEBUG
-    trigmuIsoHypo.MuonL2ISInfoName = trigL2muIso.MuonL2ISInfoName
+    trigmuIsoHypo.MuonL2ISInfoName = l2muIsoSequenceOut
     trigmuIsoHypo.HypoOutputDecisions = "MuonL2IsoDecisions"
     trigmuIsoHypo.HypoInputDecisions = l2muIsoViewsMaker.InputMakerOutputDecisions[0]
     trigmuIsoHypo.HypoTools = [ trigmuIsoHypo.TrigMuisoHypoToolFromName( "TrigL2MuisoHypoTool", c ) for c in testChains ] 
 
     ### set the dumper ###
     muIsoDecisionsDumper = DumpDecisions("muIsoDecisionsDumper", OutputLevel=DEBUG, Decisions = trigmuIsoHypo.HypoOutputDecisions )
-    
-    ### Define a Sequence to run for muIso ### 
-    muIsoStep = seqAND("muIsoStep", [ filterL2MuisoAlg, l2muIsoViewsMaker, l2muIsoViewNode, trigmuIsoHypo, muIsoDecisionsDumper ] )
+
+    ### make sequence ### 
+    l2muIsoSequence = seqAND("l2muIsoSequence", [ l2muIsoViewsMaker, l2muisoRecoSequence, trigmuIsoHypo ])
+
+    ### make step ### 
+    l2muIsoStep = seqAND("l2muIsoStep", filterL2MuisoAlg, [ l2muIsoSequence, muIsoDecisionsDumper ] )
 
 
 # ===============================================================================================
@@ -395,8 +340,8 @@ def muonViewsMergers( name ):
   if doL2SA==True:
     muonViewsMerger.TrigCompositeContainer += [ filterL1RoIsAlg.Output[0], trigMufastHypo.HypoOutputDecisions ]
     muonViewsMerger.L2StandAloneMuonContainerViews = [ l2MuViewsMaker.Views ]
-    muonViewsMerger.L2StandAloneMuonContainerInViews = [ muFastAlg.MuonL2SAInfo ]
-    muonViewsMerger.L2StandAloneMuonContainer = [ muFastAlg.MuonL2SAInfo ]
+    muonViewsMerger.L2StandAloneMuonContainerInViews = [ muFastSequenceOut ]
+    muonViewsMerger.L2StandAloneMuonContainer = [ muFastSequenceOut ]
 
   if doL2CB==True:
     muonViewsMerger.TrigCompositeContainer += [ filterL2SAAlg.Output[0], trigmuCombHypo.HypoOutputDecisions ]
@@ -405,21 +350,20 @@ def muonViewsMergers( name ):
     muonViewsMerger.TrackParticleContainer = [ TrackParticlesName ]
 
     muonViewsMerger.L2CombinedMuonContainerViews = [ l2muCombViewsMaker.Views ]
-    muonViewsMerger.L2CombinedMuonContainerInViews = [ muCombAlg.L2CombinedMuonContainerName ]
-    muonViewsMerger.L2CombinedMuonContainer = [ muCombAlg.L2CombinedMuonContainerName ]
+    muonViewsMerger.L2CombinedMuonContainerInViews = [ muCombSequenceOut ]
+    muonViewsMerger.L2CombinedMuonContainer = [ muCombSequenceOut ]
 
   if doEFSA==True:
     muonViewsMerger.TrigCompositeContainer += [ filterEFSAAlg.Output[0], trigMuonEFSAHypo.HypoOutputDecisions ]
     muonViewsMerger.MuonContainerViews = [ efMuViewsMaker.Views ]
-    muonViewsMerger.MuonContainerInViews = [ muEFSAInfo ]
-    muonViewsMerger.MuonContainer = [ muEFSAInfo ]
+    muonViewsMerger.MuonContainerInViews = [ muEFSASequenceOut ]
+    muonViewsMerger.MuonContainer = [ muEFSASequenceOut ]
 
   if doL2CB==True and doL2ISO==True: # L2CB should be also executed with L2ISO
     muonViewsMerger.TrigCompositeContainer += [ filterL2MuisoAlg.Output[0], trigmuIsoHypo.HypoOutputDecisions ]
     muonViewsMerger.L2IsoMuonContainerViews = [ l2muIsoViewsMaker.Views ]
-    muonViewsMerger.L2IsoMuonContainerInViews = [ trigL2muIso.MuonL2ISInfoName ]
-    muonViewsMerger.L2IsoMuonContainer = [ trigL2muIso.MuonL2ISInfoName ]
-
+    muonViewsMerger.L2IsoMuonContainerInViews = [ l2muIsoSequenceOut ]
+    muonViewsMerger.L2IsoMuonContainer = [ l2muIsoSequenceOut ]
 
   return muonViewsMerger
 
@@ -449,22 +393,22 @@ def muonStreamESD( muonViewsMerger ):
   StreamESD.ItemList += [ "ROIB::RoIBResult#*" ]
 
   if doL2SA==True:
-    StreamESD.ItemList += [ "xAOD::L2StandAloneMuonContainer#"+muFastAlg.MuonL2SAInfo ]
-    StreamESD.ItemList += [ "xAOD::L2StandAloneMuonAuxContainer#"+muFastAlg.MuonL2SAInfo+"Aux." ]
+    StreamESD.ItemList += [ "xAOD::L2StandAloneMuonContainer#"+muFastSequenceOut ]
+    StreamESD.ItemList += [ "xAOD::L2StandAloneMuonAuxContainer#"+muFastSequenceOut+"Aux." ]
 
   if doL2CB==True:
     StreamESD.ItemList += [ "xAOD::TrackParticleContainer#"+TrackParticlesName,
-                            "xAOD::L2CombinedMuonContainer#"+muCombAlg.L2CombinedMuonContainerName ]
+                            "xAOD::L2CombinedMuonContainer#"+muCombSequenceOut ]
     StreamESD.ItemList += [ "xAOD::TrackParticleAuxContainer#"+TrackParticlesName+"Aux.",
-                            "xAOD::L2CombinedMuonAuxContainer#"+muCombAlg.L2CombinedMuonContainerName+"Aux." ]
+                            "xAOD::L2CombinedMuonAuxContainer#"+muCombSequenceOut+"Aux." ]
 
   if doEFSA==True:
-    StreamESD.ItemList += [ "xAOD::MuonContainer#"+muEFSAInfo ]
-    StreamESD.ItemList += [ "xAOD::MuonAuxContainer#"+muEFSAInfo+"Aux." ]
+    StreamESD.ItemList += [ "xAOD::MuonContainer#"+muEFSASequenceOut ]
+    StreamESD.ItemList += [ "xAOD::MuonAuxContainer#"+muEFSASequenceOut+"Aux." ]
 
   if doL2CB==True and doL2ISO==True:
-    StreamESD.ItemList += [ "xAOD::L2IsoMuonContainer#"+trigL2muIso.MuonL2ISInfoName ]
-    StreamESD.ItemList += [ "xAOD::L2IsoMuonAuxContainer#"+trigL2muIso.MuonL2ISInfoName+"Aux." ]
+    StreamESD.ItemList += [ "xAOD::L2IsoMuonContainer#"+l2muIsoSequenceOut ]
+    StreamESD.ItemList += [ "xAOD::L2IsoMuonAuxContainer#"+l2muIsoSequenceOut+"Aux." ]
 
   print "ESD file content "
   num = 0;
@@ -591,7 +535,7 @@ if TriggerFlags.doMuon==True and TriggerFlags.doID==True:
     summary1 = summarySteps("Step2", ["MuonL2CBDecisions"] )
     step1 = parOR("step1", [ muCombStep, summary1 ] )
     summary2 = summarySteps("Step3", ["MuonL2IsoDecisions"] )
-    step2 = parOR("step2", [ muIsoStep, summary2 ] )
+    step2 = parOR("step2", [ l2muIsoStep, summary2 ] )
     step0filter = parOR("step0filter", [ filterL1RoIsAlg ] )
     step1filter = parOR("step1filter", [ filterL2SAAlg ] )
     step2filter = parOR("step2filter", [ filterL2MuisoAlg] )
@@ -615,7 +559,7 @@ if TriggerFlags.doMuon==True and TriggerFlags.doID==True:
     summary1 = summarySteps("Step2", ["MuonL2CBDecisions"] )
     step1 = parOR("step1", [ muCombStep, summary1 ] )
     summary2 = summarySteps("Step3", ["EFMuonSADecisions", "MuonL2IsoDecisions"] )
-    step2 = parOR("step2", [ muonEFSAStep, muIsoStep, summary2 ] )
+    step2 = parOR("step2", [ muonEFSAStep, l2muIsoStep, summary2 ] )
     step0filter = parOR("step0filter", [ filterL1RoIsAlg ] )
     step1filter = parOR("step1filter", [ filterL2SAAlg ] )
     step2filter = parOR("step2filter", [ filterEFSAAlg, filterL2MuisoAlg] )
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/share/newJOtest.py b/Trigger/TrigValidation/TrigUpgradeTest/share/newJOtest.py
index 2ab9062bdeed244bf8972e9ca5cd58d8e187ecb0..7de8533cd38ed12bb0152889b8a7051961c20229 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/share/newJOtest.py
+++ b/Trigger/TrigValidation/TrigUpgradeTest/share/newJOtest.py
@@ -3,7 +3,7 @@
 #
 
 from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
-from AthenaConfiguration.AllConfigFlags import ConfigFlags
+from AthenaConfiguration.AllConfigFlags import ConfigFlags as flags
 from AthenaCommon.CFElements import parOR, seqOR, seqAND, stepSeq
 from AthenaCommon.AlgSequence import dumpMasterSequence
 from AthenaCommon.AppMgr import theApp
@@ -14,7 +14,7 @@ from AthenaCommon.Configurable import Configurable
 Configurable.configurableRun3Behavior=1
 
 
-flags = ConfigFlags
+
 setupMenu(flags)
 
 
@@ -30,33 +30,9 @@ flags.lock()
 from AthenaCommon.Constants import INFO,DEBUG
 acc = ComponentAccumulator()
 
-# make sure we run the right scheduler
-# need to move elsewhere
-
-nThreads=1
-
-from StoreGate.StoreGateConf import SG__HiveMgrSvc
-eventDataSvc = SG__HiveMgrSvc("EventDataSvc")
-eventDataSvc.NSlots = nThreads
-eventDataSvc.OutputLevel = DEBUG
-acc.addService( eventDataSvc )
-
-from SGComps.SGCompsConf import SGInputLoader
-inputLoader = SGInputLoader(DetStore = 'StoreGateSvc/DetectorStore',
-                            EvtStore = 'StoreGateSvc',
-                            ExtraInputs = [],
-                            ExtraOutputs = [],
-                            FailIfNoProxy = False,
-                            Load = [],
-                            NeededResources = [])
-
-acc.addEventAlgo( inputLoader)
-
 from ByteStreamCnvSvc.ByteStreamConfig import TrigBSReadCfg
 acc.merge(TrigBSReadCfg(flags ))
 
-#from AtlasGeoModel.GeoModelConfig import GeoModelCfg
-#acc.merge(GeoModelCfg(flags ))
 
 from TrigUpgradeTest.TriggerHistSvcConfig import TriggerHistSvcConfig
 acc.merge(TriggerHistSvcConfig(flags ))
@@ -66,22 +42,9 @@ from TriggerMenuMT.HLTMenuConfig.Menu.GenerateMenuMT_newJO import generateMenu
 from TriggerJobOpts.TriggerConfig import triggerRunCfg
 acc.merge( triggerRunCfg( flags, generateMenu ) )
 
-
-
-from EventInfoMgt.EventInfoMgtConf import TagInfoMgr
-tagInfoMgr = TagInfoMgr()
-tagInfoMgr.ExtraTagValuePairs    = ['AtlasRelease', 'Athena-22.0.1'] # this has to come from somewhere else
-acc.addService( tagInfoMgr )
-
-acc.getService("EventPersistencySvc").CnvServices += [ tagInfoMgr.getName() ]
-acc.getService("ProxyProviderSvc").ProviderNames  += [ tagInfoMgr.getName() ]
-acc.getService("IOVDbSvc").Folders += ['/TagInfo<metaOnly/>']
-
-
-
-# setup algorithm sequences here, need few additional components
+# TODO take care of merging RegSel, and remove it from here
 from RegionSelector.RegSelConfig import RegSelConfig
-rsc, regSel = RegSelConfig( ConfigFlags )
+rsc, regSel = RegSelConfig( flags )
 regSel.enableCalo=True
 regSel.enableID=False
 regSel.enablePixel = False
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.cxx b/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.cxx
index 0162c069eae0f400372796e2dcab9225bbe7d02d..73fae66a2c04cb923d8b435c48888e110cbfb85c 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.cxx
+++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.cxx
@@ -89,7 +89,7 @@ namespace HLTTest {
 
 
 
-  StatusCode TestComboHypoAlg::execute_r( const EventContext& context ) const {  
+  StatusCode TestComboHypoAlg::execute( const EventContext& context ) const {  
 
     ATH_MSG_DEBUG ("Executing " << name() << "...");
 
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.h b/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.h
index fcea988e91ee3f4dad5c2c18f3963a3589814ad1..b9dd34708198a4a750f0c559f1de38130cb11ae2 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.h
+++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.h
@@ -29,7 +29,7 @@ namespace HLTTest {
   //TestComboHypoAlg &operator=(const TestComboHypoAlg &alg); 
 
   StatusCode  initialize() override;
-  virtual StatusCode  execute_r( const EventContext& context ) const override;
+  virtual StatusCode  execute( const EventContext& context ) const override;
   //StatusCode  execute() override;
   StatusCode  finalize() override;
   
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.cxx b/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.cxx
index 8ba0e9a9dde8740ae5bb288ca2f950b6348d2c62..94b86c7dfa59afef4fd0b43da787a54b6971f267 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.cxx
+++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.cxx
@@ -27,7 +27,7 @@ namespace HLTTest {
   }
 
 
-  StatusCode TestHypoAlg::execute_r( const EventContext& context ) const {  
+  StatusCode TestHypoAlg::execute( const EventContext& context ) const {  
     ATH_MSG_DEBUG( "Executing " << name() << "..." );
     if ( m_recoInput.key().empty() ) {
       ATH_MSG_DEBUG( "No input configured, not producing the output" );
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.h b/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.h
index 17f3acd6bf34ae342433ed92f330537c0921dc29..07ec5d0e412251a55ce7c2b062f0cb9093f8fc68 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.h
+++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.h
@@ -28,7 +28,7 @@ namespace HLTTest {
     virtual ~TestHypoAlg(); 
 
     virtual StatusCode initialize() override;
-    virtual StatusCode execute_r( const EventContext& context ) const override;
+    virtual StatusCode execute( const EventContext& context ) const override;
     virtual StatusCode finalize() override;
 
   private:
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.cxx b/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.cxx
index 6fd708d8ad67a2516c1bb9107be89a51949b2b05..3d7b76d870f9b2df38d784cfebf4933b5fe119ef 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.cxx
+++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.cxx
@@ -34,7 +34,7 @@ namespace HLTTest {
   }
 
 
-  StatusCode TestInputMaker::execute_r( const EventContext& context ) const {  
+  StatusCode TestInputMaker::execute( const EventContext& context ) const {  
     ATH_MSG_DEBUG( "Executing " << name() << "..." );
  
     // call base class helper method to read input decisions, loop over them create outputs and connect them, returns with outputHandles filled
diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.h b/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.h
index 4b5ac1207313d5bdce42dfe4b6d363362ea02405..04c586d370e5c2ee038ad16d1d87c9318252cd2c 100644
--- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.h
+++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.h
@@ -29,7 +29,7 @@ namespace HLTTest {
     TestInputMaker( const std::string& name, ISvcLocator* pSvcLocator );
     virtual ~TestInputMaker(); 
     virtual StatusCode  initialize() override;
-    virtual StatusCode  execute_r(const EventContext&) const override;
+    virtual StatusCode  execute(const EventContext&) const override;
     virtual StatusCode  finalize() override;
 
   private: