diff --git a/AtlasTest/DatabaseTest/AthenaPoolMultiTest/share/AthenaPoolMultiTestEventSplit.ref b/AtlasTest/DatabaseTest/AthenaPoolMultiTest/share/AthenaPoolMultiTestEventSplit.ref
index f8c3563547790df0bf30ccc501d23053f4f18339..b9c19b351315047a481aa6bb3e30996c3006cdb7 100644
--- a/AtlasTest/DatabaseTest/AthenaPoolMultiTest/share/AthenaPoolMultiTestEventSplit.ref
+++ b/AtlasTest/DatabaseTest/AthenaPoolMultiTest/share/AthenaPoolMultiTestEventSplit.ref
@@ -41,7 +41,7 @@ DecisionSvc          INFO Inserting stream: Bad with no Algs
 Bad.BadTool          INFO Initializing Bad.BadTool - package version AthenaServices-00-00-00
 Bad.Bad_MakeEve...   INFO Initializing Bad.Bad_MakeEventStreamInfo - package version OutputStreamAthenaPool-00-00-00
 Bad                  INFO Found HelperTools = PrivateToolHandleArray(['MakeEventStreamInfo/Bad_MakeEventStreamInfo','xAODMaker::EventFormatStreamHelperTool/Bad_MakeEventFormat','xAODMaker::FileMetaDataCreatorTool/FileMetaDataCreatorTool','Athena::ThinningCacheTool/ThinningCacheTool_Bad'])
-Bad                  INFO Data output: AthenaPoolMultiTest_Missed.root
+Bad                  INFO Data output: AthenaPoolMultiTest_Bad.root
 Bad                  INFO I/O reinitialization...
 Stream2.FileMet...   INFO Invalid "/TagInfo" handle
 Stream1.FileMet...   INFO Invalid "/TagInfo" handle
@@ -297,18 +297,9 @@ Stream2              INFO Metadata records written: 8
 Stream1              INFO Metadata records written: 8
 Stream3              INFO Metadata records written: 6
 Others               INFO Metadata records written: 2
+Domain[ROOT_All]     INFO                           AthenaPoolMultiTest_Bad.root
+RootDatabase.open    INFO AthenaPoolMultiTest_Bad.root File version:62200
 Bad                  INFO Metadata records written: 1
-MetaData(EventS...  ERROR Every branch must have the same number of entries.
-MetaData(EventS...  ERROR Every branch must have the same number of entries.
-MetaData(xAOD::...  ERROR Every branch must have the same number of entries.
-MetaData(xAOD::...  ERROR Every branch must have the same number of entries.
-PersistencySvc::GlobalTransaction Error Could not commit the transaction for the database with
-PersistencySvc::GlobalTransaction Error FID = C7FBD6B6-27C3-D444-9C05-9696E650C80A
-PersistencySvc::GlobalTransaction Error PFN = AthenaPoolMultiTest_Missed.root
-PoolSvc             ERROR POOL commit failed 0x1c95f8d0
-PoolSvc             ERROR disconnect failed to commit 0x1c95f8d0
-PoolSvc             FATAL Cannot disconnect Stream: 4
-ServiceManager      ERROR Unable to stop Service: PoolSvc
 Splitter1            INFO in finalize()
 Splitter2            INFO in finalize()
 Splitter3            INFO in finalize()
diff --git a/AtlasTest/DatabaseTest/AthenaPoolMultiTest/share/EventSplit_jo.py b/AtlasTest/DatabaseTest/AthenaPoolMultiTest/share/EventSplit_jo.py
index ed96960dd342c6aee0983abc4150825771123dbc..8c71deb899166eb3a9d33924f2b5ecc89bd33291 100755
--- a/AtlasTest/DatabaseTest/AthenaPoolMultiTest/share/EventSplit_jo.py
+++ b/AtlasTest/DatabaseTest/AthenaPoolMultiTest/share/EventSplit_jo.py
@@ -106,7 +106,7 @@ Stream3.CheckNumberOfWrites = False
 Others  = AthenaPoolOutputStream( "Others", "AthenaPoolMultiTest_Missed.root", False, noTag=False )
 Others.CheckNumberOfWrites = False
 # Events that failed at least one filter
-Bad     = AthenaPoolOutputStream( "Bad", "AthenaPoolMultiTest_Missed.root", False, noTag=False )
+Bad     = AthenaPoolOutputStream( "Bad", "AthenaPoolMultiTest_Bad.root", False, noTag=False )
 Bad.CheckNumberOfWrites = False
 
 # Configure them using filter methods and itemlist
diff --git a/AtlasTest/DatabaseTest/AthenaPoolMultiTest/test/post_check_es.sh b/AtlasTest/DatabaseTest/AthenaPoolMultiTest/test/post_check_es.sh
index b8298b2583e668a25fd902bdece823acab1a0085..de777596c655ea785b1df5d92f511a3d4749f852 100755
--- a/AtlasTest/DatabaseTest/AthenaPoolMultiTest/test/post_check_es.sh
+++ b/AtlasTest/DatabaseTest/AthenaPoolMultiTest/test/post_check_es.sh
@@ -38,7 +38,8 @@ else
              grep -v 'PoolXMLFileCatalog' |\
              grep -v 'AthenaSealSvc' |\
              grep -v 'EventBookkeeper' |\
-             grep -v 'EventTagWriter' > ${joblog}.small
+             grep -v 'EventTagWriter' |\
+             grep -v 'Py:ConfigurableDb' > ${joblog}.small
 	joblog=${joblog}.small
 	if [ -r $reflog ]
 	    then
diff --git a/AtlasTest/DatabaseTest/AthenaPoolMultiTest/test/post_check_p.sh b/AtlasTest/DatabaseTest/AthenaPoolMultiTest/test/post_check_p.sh
index e9b6401300eb78b88a686b8dbe1519b0594bc6d2..26638bae3591be66c7e3b3a20977a3620210e758 100755
--- a/AtlasTest/DatabaseTest/AthenaPoolMultiTest/test/post_check_p.sh
+++ b/AtlasTest/DatabaseTest/AthenaPoolMultiTest/test/post_check_p.sh
@@ -40,7 +40,8 @@ else
              grep -v 'PoolXMLFileCatalog' |\
              grep -v 'AthenaSealSvc' |\
              grep -v 'EventBookkeeper' |\
-             grep -v 'EventTagWriter' > ${joblog}.small
+             grep -v 'EventTagWriter' |\
+             grep -v 'Py:ConfigurableDb' > ${joblog}.small
 	joblog=${joblog}.small
 	if [ -r $reflog ]
 	    then
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoRead.ref b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoRead.ref
index 2a14b1aa94cf79d81872661d22e3e5f32c58768a..788fa4e04aeb8bfb39a8a195a9209895f03e5995 100644
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoRead.ref
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoRead.ref
@@ -1,8 +1,5 @@
 TagInfoMgr          DEBUG initialize()
-TagInfoMgr          DEBUG OverrideEventInfoTags    'OverrideEventInfoTags':True
-TagInfoMgr          DEBUG TagInfoKey               'TagInfoKey':'ProcessingTags'
 TagInfoMgr          DEBUG ExtraTagValuePairs 
-TagInfoMgr          DEBUG  Value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
@@ -18,23 +15,21 @@ TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /L
 TagInfoMgr          DEBUG addTag - adding name/value pairs: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /LAR/Identifier/OnOffIdMap
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /TagInfo
-TagInfoMgr          DEBUG preLoadAddresses - add transient address for TagInfo to detector store
-TagInfoMgr          DEBUG preLoadAddresses - Found CLID: 61780915 key from ioa ProcessingTags
+TagInfoMgr          DEBUG in queryInterface()
+TagInfoMgr          DEBUG matched ITagInfoMgr
+TagInfoMgr          DEBUG adding IOV callback object to DetStore
+TagInfoMgr          DEBUG Registered IOV callback for TagInfo changes
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG matched ITagInfoMgr
 TagInfoMgr          DEBUG start()
 TagInfoMgr          DEBUG Registered checkTagInfo callback for  /TagInfo 
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginInputFile from EventSelector
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: First BeginRun incident - Event ID: [1,1:0] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [1,1:0] 
 TagInfoMgr          DEBUG handle: currentRun = 1
 TagInfoMgr          DEBUG Signaled begin run to IOVDbSvc [1,1:0]
-TagInfoMgr          DEBUG Retrieve tag info 
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -43,8 +38,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagA1 A1
@@ -58,20 +51,19 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
 TagInfoMgr          DEBUG TagD1 D1
+TagInfoMgr          DEBUG IOV minRange from IOVMetaData: {[1,0] - [3,0]}
 TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [3,0]}
 TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
@@ -81,16 +73,14 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG Retrieved tag info 
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 TagInfoMgr          DEBUG handle: TagInfo successfully processed by IOVDbSvc to register callback
-TagInfoMgr          DEBUG checkTagInfo: entering checkTagInfo
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo to save its contents
-TagInfoMgr          DEBUG checkTagInfo: saved TagInfo contents
-TagInfoMgr          DEBUG checkTagInfo: reset TagInfo
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateAddress
+TagInfoMgr          DEBUG IOV callback
+TagInfoMgr          DEBUG notifyListeners  (1 registered)
+TagInfoMgr          DEBUG checkTagInfo IOV callback
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -99,8 +89,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagA1 A1
@@ -114,16 +102,14 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
@@ -137,19 +123,41 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: secondary BeginRun incident - Event ID: [2,1:85] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [2,1:85] 
 TagInfoMgr          DEBUG handle: currentRun = 2
-TagInfoMgr          DEBUG handle - BeginRun: Retrieved TagInfo meta data from detStore
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG fillTagInfo: 
+TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
+TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
+TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
+TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagA1 A1
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag TagA1 A1
+TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagB1 B1
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag TagB1 B1
+TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagD1 D1
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag TagD1 D1
+TagInfoMgr          DEBUG fillTagInfo: print out tags before adding extra tags
+TagInfoMgr          DEBUG TagInfo tag: 
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: print out tags
+TagInfoMgr          DEBUG TagInfo tag: 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
@@ -163,5 +171,5 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG handle - BeginRun: Wrote TagInfo to MetaDataStore 
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 TagInfoMgr          DEBUG finalize()
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.ref b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.ref
index 141b2c137b2968f94f46048c5c688c38c879a179..856326134c3418efaf11e4ebf762d103792bf6cf 100644
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.ref
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.ref
@@ -1,8 +1,5 @@
 TagInfoMgr          DEBUG initialize()
-TagInfoMgr          DEBUG OverrideEventInfoTags    'OverrideEventInfoTags':True
-TagInfoMgr          DEBUG TagInfoKey               'TagInfoKey':'ProcessingTags'
 TagInfoMgr          DEBUG ExtraTagValuePairs 
-TagInfoMgr          DEBUG  Value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
@@ -49,10 +46,10 @@ TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /L
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /LAR/Identifier/LArTTCellMapAtlas
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /LAR/ElecCalibMC/fSampl
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /LAR/ElecCalibMC/uA2MeV
-TagInfoMgr          DEBUG preLoadAddresses - add transient address for TagInfo to detector store
-TagInfoMgr          DEBUG preLoadAddresses - Found CLID: 61780915 key from ioa ProcessingTags
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG matched ITagInfoMgr
+TagInfoMgr          DEBUG adding IOV callback object to DetStore
+TagInfoMgr          DEBUG Registered IOV callback for TagInfo changes
 EventInfoWriter     DEBUG EventInfoWriter::initialize()
 EventInfoWriter     DEBUG CreateDummyTags          'CreateDummyTags':False
 EventInfoWriter     DEBUG RemoveDummyTags          'RemoveDummyTags':False
@@ -64,15 +61,11 @@ EventInfoWriter     DEBUG EventInfoWriter::fillTagInfo()
 EventInfoWriter     DEBUG Called fillTagInfo
 TagInfoMgr          DEBUG start()
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: First BeginRun incident - Event ID: [1,1:0] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [1,1:0] 
 TagInfoMgr          DEBUG handle: currentRun = 1
 TagInfoMgr          DEBUG Signaled begin run to IOVDbSvc [1,1:0]
-TagInfoMgr          DEBUG Retrieve tag info 
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: det store does NOT contain AttrListColl for TagInfo
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: det store does NOT contain AttrListColl for TagInfo
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: Add in tags from EventInfo
 TagInfoMgr          DEBUG fillTagInfo: Event ID: [1,4294967296:0] 
@@ -83,17 +76,15 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from input event 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from input event 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
 TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
@@ -103,363 +94,318 @@ TagInfoMgr.IOVD...  DEBUG begin addPayload
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Added new payload for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG {[1,0] - [2,0]} iov size 0
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG Retrieved tag info 
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 TagInfoMgr          DEBUG handle: TagInfo successfully processed by IOVDbSvc to register callback
+TagInfoMgr          DEBUG updateAddress
+TagInfoMgr          DEBUG IOV callback
+TagInfoMgr          DEBUG notifyListeners  (1 registered)
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967296:0] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967297:5] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967298:10] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967299:15] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967300:20] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967301:25] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967302:30] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967303:35] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967304:40] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967305:45] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967306:50] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967307:55] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967308:60] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967309:65] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967310:70] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967311:75] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967312:80] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: secondary BeginRun incident - Event ID: [2,1:85] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [2,1:85] 
 TagInfoMgr          DEBUG handle: currentRun = 2
-TagInfoMgr          DEBUG handle - BeginRun: det store does NOT contain AttrListColl for TagInfo
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: det store does NOT contain AttrListColl for TagInfo
+TagInfoMgr          DEBUG fillTagInfo: 
+TagInfoMgr          DEBUG fillTagInfo: Add in tags from EventInfo
+TagInfoMgr          DEBUG fillTagInfo: Event ID: [2,1:85] 
+TagInfoMgr          DEBUG fillTagInfo: EventInfo/EventType has no tags
+TagInfoMgr          DEBUG fillTagInfo: Added EventInfo tags to TagInfo current/input
+TagInfoMgr          DEBUG fillTagInfo: print out tags before adding extra tags
+TagInfoMgr          DEBUG TagInfo tag: 
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
+TagInfoMgr          DEBUG fillTagInfo: print out tags
+TagInfoMgr          DEBUG TagInfo tag: 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from input event 
+TagInfoMgr          DEBUG entering fillMetaData
+TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
+TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
+TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
+TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
+TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
+TagInfoMgr.IOVD...  DEBUG begin registerFolder 
+TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
+TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer already in MetaDataStore for folder /TagInfo
+TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been registered 
+TagInfoMgr.IOVD...  DEBUG begin addPayload 
+TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
+TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,1:85] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,2:90] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,3:95] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,4:100] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,5:105] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,6:110] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,7:115] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,8:120] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::finalize()
 TagInfoMgr          DEBUG finalize()
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep2.ref b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep2.ref
index b4dd13c2dfc2a4701e9b53f05299406feb8ca4c8..2c32a16b010c72736ac1bd9afdd4b76c57a3a271 100644
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep2.ref
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep2.ref
@@ -1,8 +1,5 @@
 TagInfoMgr          DEBUG initialize()
-TagInfoMgr          DEBUG OverrideEventInfoTags    'OverrideEventInfoTags':True
-TagInfoMgr          DEBUG TagInfoKey               'TagInfoKey':'ProcessingTags'
 TagInfoMgr          DEBUG ExtraTagValuePairs 
-TagInfoMgr          DEBUG  Value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
@@ -18,10 +15,10 @@ TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /L
 TagInfoMgr          DEBUG addTag - adding name/value pairs: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /LAR/Identifier/OnOffIdMap
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /TagInfo
-TagInfoMgr          DEBUG preLoadAddresses - add transient address for TagInfo to detector store
-TagInfoMgr          DEBUG preLoadAddresses - Found CLID: 61780915 key from ioa ProcessingTags
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG matched ITagInfoMgr
+TagInfoMgr          DEBUG adding IOV callback object to DetStore
+TagInfoMgr          DEBUG Registered IOV callback for TagInfo changes
 EventInfoWriter     DEBUG EventInfoWriter::initialize()
 EventInfoWriter     DEBUG CreateDummyTags          'CreateDummyTags':False
 EventInfoWriter     DEBUG RemoveDummyTags          'RemoveDummyTags':False
@@ -35,15 +32,11 @@ TagInfoMgr          DEBUG start()
 TagInfoMgr          DEBUG Registered checkTagInfo callback for  /TagInfo 
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginInputFile from EventSelector
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: First BeginRun incident - Event ID: [1,1:0] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [1,1:0] 
 TagInfoMgr          DEBUG handle: currentRun = 1
 TagInfoMgr          DEBUG Signaled begin run to IOVDbSvc [1,1:0]
-TagInfoMgr          DEBUG Retrieve tag info 
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -52,8 +45,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: print out tags before adding extra tags
@@ -61,19 +52,18 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [2,0]}
-TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [2,0]
+TagInfoMgr          DEBUG IOV minRange from IOVMetaData: {[1,0] - [3,0]}
+TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [3,0]}
+TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
 TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
 TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer already in MetaDataStore for folder /TagInfo
@@ -81,16 +71,14 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG Retrieved tag info 
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 TagInfoMgr          DEBUG handle: TagInfo successfully processed by IOVDbSvc to register callback
-TagInfoMgr          DEBUG checkTagInfo: entering checkTagInfo
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo to save its contents
-TagInfoMgr          DEBUG checkTagInfo: saved TagInfo contents
-TagInfoMgr          DEBUG checkTagInfo: reset TagInfo
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateAddress
+TagInfoMgr          DEBUG IOV callback
+TagInfoMgr          DEBUG notifyListeners  (1 registered)
+TagInfoMgr          DEBUG checkTagInfo IOV callback
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -99,8 +87,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: print out tags before adding extra tags
@@ -108,19 +94,17 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [2,0]}
-TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [2,0]
+TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [3,0]}
+TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
 TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
 TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer already in MetaDataStore for folder /TagInfo
@@ -128,359 +112,267 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967296:0] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967297:5] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967298:10] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967299:15] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967300:20] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967301:25] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967302:30] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967303:35] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967304:40] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967305:45] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967306:50] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967307:55] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967308:60] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967309:65] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967310:70] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967311:75] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967312:80] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: secondary BeginRun incident - Event ID: [2,1:85] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [2,1:85] 
 TagInfoMgr          DEBUG handle: currentRun = 2
-TagInfoMgr          DEBUG handle - BeginRun: Retrieved TagInfo meta data from detStore
-TagInfoMgr          DEBUG entering fillMetaData
-TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
-TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
-TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
-TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-TagInfoMgr          DEBUG fillMetaData: run number is outside of previous IOVRange: 2 {[1,0] - [2,0]}. Reset range to run number.
-TagInfoMgr          DEBUG fillMetaData: start, stop: [2,0] [3,0]
-TagInfoMgr.IOVD...  DEBUG begin registerFolder 
-TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
-TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer already in MetaDataStore for folder /TagInfo
-TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been registered 
-TagInfoMgr.IOVD...  DEBUG begin addPayload 
-TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
-TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG handle - BeginRun: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG checkTagInfo: entering checkTagInfo
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo to save its contents
-TagInfoMgr          DEBUG checkTagInfo: saved TagInfo contents
-TagInfoMgr          DEBUG checkTagInfo: reset TagInfo
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -489,8 +381,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: print out tags before adding extra tags
@@ -498,18 +388,16 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 2 {[2,0] - [3,0]}
+TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 2 {[1,0] - [3,0]}
 TagInfoMgr          DEBUG fillMetaData: start, stop: [2,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
 TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
@@ -518,160 +406,126 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,1:85] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,2:90] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,3:95] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,4:100] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,5:105] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,6:110] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,7:115] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,8:120] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::finalize()
 TagInfoMgr          DEBUG finalize()
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep3.ref b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep3.ref
index 4ab1f9004a97f55277b160165cdee3eae1417d21..fe662641cad1d4f36ce5f793078fe51ba31268b2 100644
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep3.ref
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep3.ref
@@ -1,8 +1,5 @@
 TagInfoMgr          DEBUG initialize()
-TagInfoMgr          DEBUG OverrideEventInfoTags    'OverrideEventInfoTags':True
-TagInfoMgr          DEBUG TagInfoKey               'TagInfoKey':'ProcessingTags'
 TagInfoMgr          DEBUG ExtraTagValuePairs 
-TagInfoMgr          DEBUG  Value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
@@ -18,10 +15,10 @@ TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /L
 TagInfoMgr          DEBUG addTag - adding name/value pairs: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /LAR/Identifier/OnOffIdMap
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /TagInfo
-TagInfoMgr          DEBUG preLoadAddresses - add transient address for TagInfo to detector store
-TagInfoMgr          DEBUG preLoadAddresses - Found CLID: 61780915 key from ioa ProcessingTags
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG matched ITagInfoMgr
+TagInfoMgr          DEBUG adding IOV callback object to DetStore
+TagInfoMgr          DEBUG Registered IOV callback for TagInfo changes
 EventInfoWriter     DEBUG EventInfoWriter::initialize()
 EventInfoWriter     DEBUG CreateDummyTags          'CreateDummyTags':True
 EventInfoWriter     DEBUG RemoveDummyTags          'RemoveDummyTags':False
@@ -40,15 +37,11 @@ TagInfoMgr          DEBUG start()
 TagInfoMgr          DEBUG Registered checkTagInfo callback for  /TagInfo 
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginInputFile from EventSelector
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: First BeginRun incident - Event ID: [1,1:0] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [1,1:0] 
 TagInfoMgr          DEBUG handle: currentRun = 1
 TagInfoMgr          DEBUG Signaled begin run to IOVDbSvc [1,1:0]
-TagInfoMgr          DEBUG Retrieve tag info 
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -57,8 +50,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: print out tags before adding extra tags
@@ -66,25 +57,24 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagA1 A1
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagB1 B1
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagC1 C1
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagD1 D1
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
 TagInfoMgr          DEBUG TagC1 C1
 TagInfoMgr          DEBUG TagD1 D1
+TagInfoMgr          DEBUG IOV minRange from IOVMetaData: {[1,0] - [3,0]}
 TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [3,0]}
 TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
@@ -95,16 +85,14 @@ TagInfoMgr.IOVD...  DEBUG begin addPayload
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Added new payload for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG {[1,0] - [3,0]} iov size 0
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG Retrieved tag info 
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 TagInfoMgr          DEBUG handle: TagInfo successfully processed by IOVDbSvc to register callback
-TagInfoMgr          DEBUG checkTagInfo: entering checkTagInfo
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo to save its contents
-TagInfoMgr          DEBUG checkTagInfo: saved TagInfo contents
-TagInfoMgr          DEBUG checkTagInfo: reset TagInfo
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateAddress
+TagInfoMgr          DEBUG IOV callback
+TagInfoMgr          DEBUG notifyListeners  (1 registered)
+TagInfoMgr          DEBUG checkTagInfo IOV callback
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -113,8 +101,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: print out tags before adding extra tags
@@ -122,20 +108,18 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagA1 A1
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagB1 B1
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagC1 C1
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagD1 D1
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
@@ -150,20 +134,16 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967296:0] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -173,20 +153,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967297:5] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -196,20 +172,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967298:10] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -219,20 +191,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967299:15] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -242,20 +210,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967300:20] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -265,20 +229,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967301:25] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -288,20 +248,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967302:30] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -311,20 +267,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967303:35] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -334,20 +286,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967304:40] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -357,20 +305,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967305:45] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -380,20 +324,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967306:50] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -403,20 +343,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967307:55] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -426,20 +362,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967308:60] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -449,20 +381,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967309:65] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -472,20 +400,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967310:70] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -495,20 +419,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967311:75] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -518,20 +438,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967312:80] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -541,19 +457,39 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: secondary BeginRun incident - Event ID: [2,1:85] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [2,1:85] 
 TagInfoMgr          DEBUG handle: currentRun = 2
-TagInfoMgr          DEBUG handle - BeginRun: Retrieved TagInfo meta data from detStore
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG fillTagInfo: 
+TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
+TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
+TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
+TagInfoMgr          DEBUG fillTagInfo: print out tags before adding extra tags
+TagInfoMgr          DEBUG TagInfo tag: 
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagA1 A1
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagB1 B1
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagC1 C1
+TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagD1 D1
+TagInfoMgr          DEBUG fillTagInfo: print out tags
+TagInfoMgr          DEBUG TagInfo tag: 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
@@ -568,18 +504,16 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG handle - BeginRun: Wrote TagInfo to MetaDataStore 
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,1:85] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -589,20 +523,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,2:90] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -612,20 +542,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,3:95] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -635,20 +561,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,4:100] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -658,20 +580,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,5:105] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -681,20 +599,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,6:110] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -704,20 +618,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,7:115] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -727,20 +637,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,8:120] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -750,8 +656,6 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::finalize()
 TagInfoMgr          DEBUG finalize()
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep4.ref b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep4.ref
index a457690a430b97641b7cd0e58a0cc1357160e2c2..f208c7538871c9c2c7298516575c489c85b0144a 100644
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep4.ref
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep4.ref
@@ -1,8 +1,5 @@
 TagInfoMgr          DEBUG initialize()
-TagInfoMgr          DEBUG OverrideEventInfoTags    'OverrideEventInfoTags':True
-TagInfoMgr          DEBUG TagInfoKey               'TagInfoKey':'ProcessingTags'
 TagInfoMgr          DEBUG ExtraTagValuePairs 
-TagInfoMgr          DEBUG  Value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
@@ -18,10 +15,10 @@ TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /L
 TagInfoMgr          DEBUG addTag - adding name/value pairs: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /LAR/Identifier/OnOffIdMap
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /TagInfo
-TagInfoMgr          DEBUG preLoadAddresses - add transient address for TagInfo to detector store
-TagInfoMgr          DEBUG preLoadAddresses - Found CLID: 61780915 key from ioa ProcessingTags
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG matched ITagInfoMgr
+TagInfoMgr          DEBUG adding IOV callback object to DetStore
+TagInfoMgr          DEBUG Registered IOV callback for TagInfo changes
 EventInfoWriter     DEBUG EventInfoWriter::initialize()
 EventInfoWriter     DEBUG CreateDummyTags          'CreateDummyTags':False
 EventInfoWriter     DEBUG RemoveDummyTags          'RemoveDummyTags':False
@@ -35,15 +32,11 @@ TagInfoMgr          DEBUG start()
 TagInfoMgr          DEBUG Registered checkTagInfo callback for  /TagInfo 
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginInputFile from EventSelector
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: First BeginRun incident - Event ID: [1,1:0] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [1,1:0] 
 TagInfoMgr          DEBUG handle: currentRun = 1
 TagInfoMgr          DEBUG Signaled begin run to IOVDbSvc [1,1:0]
-TagInfoMgr          DEBUG Retrieve tag info 
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -52,8 +45,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagA1 A1
@@ -69,21 +60,20 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
 TagInfoMgr          DEBUG TagC1 C1
 TagInfoMgr          DEBUG TagD1 D1
+TagInfoMgr          DEBUG IOV minRange from IOVMetaData: {[1,0] - [3,0]}
 TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [3,0]}
 TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
@@ -93,16 +83,14 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG Retrieved tag info 
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 TagInfoMgr          DEBUG handle: TagInfo successfully processed by IOVDbSvc to register callback
-TagInfoMgr          DEBUG checkTagInfo: entering checkTagInfo
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo to save its contents
-TagInfoMgr          DEBUG checkTagInfo: saved TagInfo contents
-TagInfoMgr          DEBUG checkTagInfo: reset TagInfo
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateAddress
+TagInfoMgr          DEBUG IOV callback
+TagInfoMgr          DEBUG notifyListeners  (1 registered)
+TagInfoMgr          DEBUG checkTagInfo IOV callback
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -111,8 +99,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagA1 A1
@@ -128,16 +114,14 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
@@ -152,20 +136,16 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967296:0] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -175,24 +155,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967297:5] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -202,24 +178,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967298:10] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -229,24 +201,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967299:15] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -256,24 +224,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967300:20] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -283,24 +247,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967301:25] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -310,24 +270,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967302:30] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -337,24 +293,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967303:35] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -364,24 +316,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967304:40] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -391,24 +339,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967305:45] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -418,24 +362,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967306:50] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -445,24 +385,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967307:55] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -472,24 +408,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967308:60] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -499,24 +431,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967309:65] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -526,24 +454,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967310:70] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -553,24 +477,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967311:75] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -580,24 +500,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967312:80] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -607,49 +523,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: secondary BeginRun incident - Event ID: [2,1:85] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [2,1:85] 
 TagInfoMgr          DEBUG handle: currentRun = 2
-TagInfoMgr          DEBUG handle - BeginRun: Retrieved TagInfo meta data from detStore
-TagInfoMgr          DEBUG entering fillMetaData
-TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
-TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
-TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
-TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-TagInfoMgr          DEBUG TagA1 A1
-TagInfoMgr          DEBUG TagB1 B1
-TagInfoMgr          DEBUG TagC1 C1
-TagInfoMgr          DEBUG TagD1 D1
-TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 2 {[1,0] - [3,0]}
-TagInfoMgr          DEBUG fillMetaData: start, stop: [2,0] [3,0]
-TagInfoMgr.IOVD...  DEBUG begin registerFolder 
-TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
-TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer already in MetaDataStore for folder /TagInfo
-TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been registered 
-TagInfoMgr.IOVD...  DEBUG begin addPayload 
-TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
-TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG handle - BeginRun: Wrote TagInfo to MetaDataStore 
-EventInfoWriter     DEBUG EventInfoWriter::execute()
-EventInfoWriter     DEBUG Event ID: [2,1:85] 
-EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Create dummy tags, A2-D2
-TagInfoMgr          DEBUG addTag - adding name/value pairs: TagA1 A2
-TagInfoMgr          DEBUG addTag - adding name/value pairs: TagB1 B2
-TagInfoMgr          DEBUG addTag - adding name/value pairs: TagC1 C2
-TagInfoMgr          DEBUG addTag - adding name/value pairs: TagD1 D2
-EventInfoWriter     DEBUG execute: reset TagInfo proxy
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -658,8 +541,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagA1 A1
@@ -675,26 +556,20 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagA1 A2
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagB1 B2
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagC1 C2
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: TagD1 D2
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-TagInfoMgr          DEBUG TagA1 A2
-TagInfoMgr          DEBUG TagB1 B2
-TagInfoMgr          DEBUG TagC1 C2
-TagInfoMgr          DEBUG TagD1 D2
-TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 2 {[2,0] - [3,0]}
+TagInfoMgr          DEBUG TagA1 A1
+TagInfoMgr          DEBUG TagB1 B1
+TagInfoMgr          DEBUG TagC1 C1
+TagInfoMgr          DEBUG TagD1 D1
+TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 2 {[1,0] - [3,0]}
 TagInfoMgr          DEBUG fillMetaData: start, stop: [2,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
 TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
@@ -702,223 +577,196 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer already in MetaDataStore for fold
 TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been registered 
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
-TagInfoMgr.IOVD...  DEBUG Added new payload for folder /TagInfo
-TagInfoMgr.IOVD...  DEBUG {[2,0] - [3,0]} iov size 0
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-EventInfoWriter     DEBUG execute: retrieved TagInfo
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
+EventInfoWriter     DEBUG EventInfoWriter::execute()
+EventInfoWriter     DEBUG Event ID: [2,1:85] 
+EventInfoWriter     DEBUG Event type: user type McEvent
+EventInfoWriter     DEBUG Create dummy tags, A2-D2
+TagInfoMgr          DEBUG addTag - adding name/value pairs: TagA1 A2
+TagInfoMgr          DEBUG addTag - adding name/value pairs: TagB1 B2
+TagInfoMgr          DEBUG addTag - adding name/value pairs: TagC1 C2
+TagInfoMgr          DEBUG addTag - adding name/value pairs: TagD1 D2
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG     TagA1 A2
-EventInfoWriter     DEBUG     TagB1 B2
-EventInfoWriter     DEBUG     TagC1 C2
-EventInfoWriter     DEBUG     TagD1 D2
+EventInfoWriter     DEBUG     TagA1 A1
+EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
+EventInfoWriter     DEBUG     TagD1 D1
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,2:90] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG     TagA1 A2
-EventInfoWriter     DEBUG     TagB1 B2
-EventInfoWriter     DEBUG     TagC1 C2
-EventInfoWriter     DEBUG     TagD1 D2
+EventInfoWriter     DEBUG     TagA1 A1
+EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
+EventInfoWriter     DEBUG     TagD1 D1
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,3:95] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG     TagA1 A2
-EventInfoWriter     DEBUG     TagB1 B2
-EventInfoWriter     DEBUG     TagC1 C2
-EventInfoWriter     DEBUG     TagD1 D2
+EventInfoWriter     DEBUG     TagA1 A1
+EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
+EventInfoWriter     DEBUG     TagD1 D1
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,4:100] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG     TagA1 A2
-EventInfoWriter     DEBUG     TagB1 B2
-EventInfoWriter     DEBUG     TagC1 C2
-EventInfoWriter     DEBUG     TagD1 D2
+EventInfoWriter     DEBUG     TagA1 A1
+EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
+EventInfoWriter     DEBUG     TagD1 D1
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,5:105] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG     TagA1 A2
-EventInfoWriter     DEBUG     TagB1 B2
-EventInfoWriter     DEBUG     TagC1 C2
-EventInfoWriter     DEBUG     TagD1 D2
+EventInfoWriter     DEBUG     TagA1 A1
+EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
+EventInfoWriter     DEBUG     TagD1 D1
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,6:110] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG     TagA1 A2
-EventInfoWriter     DEBUG     TagB1 B2
-EventInfoWriter     DEBUG     TagC1 C2
-EventInfoWriter     DEBUG     TagD1 D2
+EventInfoWriter     DEBUG     TagA1 A1
+EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
+EventInfoWriter     DEBUG     TagD1 D1
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,7:115] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG     TagA1 A2
-EventInfoWriter     DEBUG     TagB1 B2
-EventInfoWriter     DEBUG     TagC1 C2
-EventInfoWriter     DEBUG     TagD1 D2
+EventInfoWriter     DEBUG     TagA1 A1
+EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
+EventInfoWriter     DEBUG     TagD1 D1
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,8:120] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-EventInfoWriter     DEBUG     TagA1 A2
-EventInfoWriter     DEBUG     TagB1 B2
-EventInfoWriter     DEBUG     TagC1 C2
-EventInfoWriter     DEBUG     TagD1 D2
+EventInfoWriter     DEBUG     TagA1 A1
+EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
+EventInfoWriter     DEBUG     TagD1 D1
 EventInfoWriter     DEBUG Input tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::finalize()
 TagInfoMgr          DEBUG finalize()
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep5.ref b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep5.ref
index f9a8ad301e17599c6049048018eca0f3b5b18145..f5e15563f0f57aad380a510da62fdff9caf89340 100644
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep5.ref
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWriteStep5.ref
@@ -1,8 +1,5 @@
 TagInfoMgr          DEBUG initialize()
-TagInfoMgr          DEBUG OverrideEventInfoTags    'OverrideEventInfoTags':True
-TagInfoMgr          DEBUG TagInfoKey               'TagInfoKey':'ProcessingTags'
 TagInfoMgr          DEBUG ExtraTagValuePairs 
-TagInfoMgr          DEBUG  Value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG in queryInterface()
@@ -18,10 +15,10 @@ TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /L
 TagInfoMgr          DEBUG addTag - adding name/value pairs: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /LAR/Identifier/OnOffIdMap
 TagInfoMgr          DEBUG removeTagFromInput - adding tag name to be removed: /TagInfo
-TagInfoMgr          DEBUG preLoadAddresses - add transient address for TagInfo to detector store
-TagInfoMgr          DEBUG preLoadAddresses - Found CLID: 61780915 key from ioa ProcessingTags
 TagInfoMgr          DEBUG in queryInterface()
 TagInfoMgr          DEBUG matched ITagInfoMgr
+TagInfoMgr          DEBUG adding IOV callback object to DetStore
+TagInfoMgr          DEBUG Registered IOV callback for TagInfo changes
 EventInfoWriter     DEBUG EventInfoWriter::initialize()
 EventInfoWriter     DEBUG CreateDummyTags          'CreateDummyTags':False
 EventInfoWriter     DEBUG RemoveDummyTags          'RemoveDummyTags':True
@@ -37,15 +34,11 @@ TagInfoMgr          DEBUG start()
 TagInfoMgr          DEBUG Registered checkTagInfo callback for  /TagInfo 
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginInputFile from EventSelector
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: First BeginRun incident - Event ID: [1,1:0] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [1,1:0] 
 TagInfoMgr          DEBUG handle: currentRun = 1
 TagInfoMgr          DEBUG Signaled begin run to IOVDbSvc [1,1:0]
-TagInfoMgr          DEBUG Retrieve tag info 
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG in queryInterface()
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -54,8 +47,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagA1 A1
@@ -71,22 +62,21 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
 TagInfoMgr          DEBUG TagD1 D1
-TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [2,0]}
-TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [2,0]
+TagInfoMgr          DEBUG IOV minRange from IOVMetaData: {[1,0] - [3,0]}
+TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [3,0]}
+TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
 TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
 TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer already in MetaDataStore for folder /TagInfo
@@ -94,17 +84,15 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Added new payload for folder /TagInfo
-TagInfoMgr.IOVD...  DEBUG {[1,0] - [2,0]} iov size 0
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG Retrieved tag info 
+TagInfoMgr.IOVD...  DEBUG {[1,0] - [3,0]} iov size 0
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 TagInfoMgr          DEBUG handle: TagInfo successfully processed by IOVDbSvc to register callback
-TagInfoMgr          DEBUG checkTagInfo: entering checkTagInfo
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo to save its contents
-TagInfoMgr          DEBUG checkTagInfo: saved TagInfo contents
-TagInfoMgr          DEBUG checkTagInfo: reset TagInfo
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateAddress
+TagInfoMgr          DEBUG IOV callback
+TagInfoMgr          DEBUG notifyListeners  (1 registered)
+TagInfoMgr          DEBUG checkTagInfo IOV callback
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -113,8 +101,6 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagA1 A1
@@ -130,22 +116,20 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
 TagInfoMgr          DEBUG TagD1 D1
-TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [2,0]}
-TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [2,0]
+TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 1 {[1,0] - [3,0]}
+TagInfoMgr          DEBUG fillMetaData: start, stop: [1,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
 TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
 TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer already in MetaDataStore for folder /TagInfo
@@ -153,20 +137,16 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967296:0] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -175,24 +155,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967297:5] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -201,24 +177,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967298:10] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -227,24 +199,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967299:15] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -253,24 +221,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967300:20] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -279,24 +243,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967301:25] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -305,24 +265,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967302:30] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -331,24 +287,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967303:35] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -357,24 +309,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967304:40] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -383,24 +331,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967305:45] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -409,24 +353,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967306:50] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -435,24 +375,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967307:55] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -461,24 +397,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967308:60] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -487,24 +419,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967309:65] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -513,24 +441,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967310:70] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -539,24 +463,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967311:75] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -565,24 +485,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [1,4294967312:80] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -591,43 +507,16 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
 EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 TagInfoMgr          DEBUG handle: entering handle(), incidence type BeginRun from AthenaEventLoopMgr
-TagInfoMgr          DEBUG handle: secondary BeginRun incident - Event ID: [2,1:85] 
+TagInfoMgr          DEBUG handle: BeginRun incident - Event ID: [2,1:85] 
 TagInfoMgr          DEBUG handle: currentRun = 2
-TagInfoMgr          DEBUG handle - BeginRun: Retrieved TagInfo meta data from detStore
-TagInfoMgr          DEBUG entering fillMetaData
-TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
-TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
-TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
-TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
-TagInfoMgr          DEBUG TagA1 A1
-TagInfoMgr          DEBUG TagB1 B1
-TagInfoMgr          DEBUG TagD1 D1
-TagInfoMgr          DEBUG fillMetaData: run number is outside of previous IOVRange: 2 {[1,0] - [2,0]}. Reset range to run number.
-TagInfoMgr          DEBUG fillMetaData: start, stop: [2,0] [3,0]
-TagInfoMgr.IOVD...  DEBUG begin registerFolder 
-TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
-TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer already in MetaDataStore for folder /TagInfo
-TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been registered 
-TagInfoMgr.IOVD...  DEBUG begin addPayload 
-TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
-TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG handle - BeginRun: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG checkTagInfo: entering checkTagInfo
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo to save its contents
-TagInfoMgr          DEBUG checkTagInfo: saved TagInfo contents
-TagInfoMgr          DEBUG checkTagInfo: reset TagInfo
-TagInfoMgr          DEBUG createObj: get TagInfo
-TagInfoMgr          DEBUG createObj: Retrieved TagInfo meta data from detStore. size 1
+TagInfoMgr          DEBUG updateTagInfo: getting /TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Retrieved TagInfo meta data from detStore. size 1
 TagInfoMgr          DEBUG fillTagInfo: 
 TagInfoMgr          DEBUG fillTagInfo: - tags coming from COOL file meta data
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
@@ -636,14 +525,14 @@ TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/ta
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo AtlasRelease Athena-22.0.21
-TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagA1 A1
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag TagA1 A1
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagB1 B1
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag TagB1 B1
+TagInfoMgr          DEBUG fillTagInfo: Did NOT add tag - on remove list: name/tag: TagC1 C1
+TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag TagC1 C1
 TagInfoMgr          DEBUG fillTagInfo: Added name/tag to TagInfo TagD1 D1
 TagInfoMgr          DEBUG fillTagInfo: Added value/tag to TagInfo as input tag TagD1 D1
 TagInfoMgr          DEBUG fillTagInfo: print out tags before adding extra tags
@@ -651,21 +540,19 @@ TagInfoMgr          DEBUG TagInfo tag:
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG fillTagInfo: Adding extra value/tag pair: AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG fillTagInfo: print out tags
 TagInfoMgr          DEBUG TagInfo tag: 
-TagInfoMgr          DEBUG createObj: Filled TagInfo from file meta data 
+TagInfoMgr          DEBUG updateTagInfo: Filled TagInfo from file meta data 
 TagInfoMgr          DEBUG entering fillMetaData
 TagInfoMgr          DEBUG fillMetaData: Adding value/tag pairs to file meta data: 
 TagInfoMgr          DEBUG /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 TagInfoMgr          DEBUG /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 TagInfoMgr          DEBUG /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-TagInfoMgr          DEBUG AtlasRelease Athena-22.0.21
 TagInfoMgr          DEBUG IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 TagInfoMgr          DEBUG TagA1 A1
 TagInfoMgr          DEBUG TagB1 B1
 TagInfoMgr          DEBUG TagD1 D1
-TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 2 {[2,0] - [3,0]}
+TagInfoMgr          DEBUG fillMetaData: run number is in previous IOVRange: 2 {[1,0] - [3,0]}
 TagInfoMgr          DEBUG fillMetaData: start, stop: [2,0] [3,0]
 TagInfoMgr.IOVD...  DEBUG begin registerFolder 
 TagInfoMgr.IOVD...  DEBUG begin getMetaDataContainer 
@@ -674,20 +561,16 @@ TagInfoMgr.IOVD...  DEBUG IOVMetaDataContainer  for folder /TagInfo has been reg
 TagInfoMgr.IOVD...  DEBUG begin addPayload 
 TagInfoMgr.IOVD...  DEBUG Retrieved IOVMetaDataContainer from MetaDataStore for folder /TagInfo
 TagInfoMgr.IOVD...  DEBUG Could not add new payload for folder /TagInfo (may be duplicate payload).
-TagInfoMgr          DEBUG createObj: Wrote TagInfo to MetaDataStore 
-TagInfoMgr          DEBUG createObj:  created new TagInfo object 
-TagInfoMgr          DEBUG checkTagInfo: retrieved TagInfo
+TagInfoMgr          DEBUG updateTagInfo: Wrote TagInfo to MetaDataStore 
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,1:85] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -696,23 +579,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,2:90] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -721,23 +601,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,3:95] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -746,23 +623,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,4:100] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -771,23 +645,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,5:105] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -796,23 +667,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,6:110] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -821,23 +689,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,7:115] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -846,23 +711,20 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::execute()
 EventInfoWriter     DEBUG Event ID: [2,8:120] 
 EventInfoWriter     DEBUG Event type: user type McEvent
-EventInfoWriter     DEBUG Retrieved TagInfo
-EventInfoWriter     DEBUG Tags from  TagInfo:
+EventInfoWriter     DEBUG Tags from TagInfoMgr:
 EventInfoWriter     DEBUG TagInfo tag: 
 EventInfoWriter     DEBUG Current tags: 
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
@@ -871,11 +733,10 @@ EventInfoWriter     DEBUG Input tags:
 EventInfoWriter     DEBUG     /LAR/Identifier/CalibIdMap LARIdentifierCalibIdMap-012
 EventInfoWriter     DEBUG     /LAR/Identifier/FebRodMap LARIdentifierFebRodMap-005
 EventInfoWriter     DEBUG     /LAR/Identifier/OnOffIdMap LARIdentifierOnOffIdMap-012
-EventInfoWriter     DEBUG     AtlasRelease Athena-22.0.21
 EventInfoWriter     DEBUG     IOVDbGlobalTag OFLCOND-SDR-BS7T-04-00
 EventInfoWriter     DEBUG     TagA1 A1
 EventInfoWriter     DEBUG     TagB1 B1
+EventInfoWriter     DEBUG     TagC1 C1
 EventInfoWriter     DEBUG     TagD1 D1
-EventInfoWriter     DEBUG Found Release version from TagInfo: Athena-22.0.21
 EventInfoWriter     DEBUG EventInfoWriter::finalize()
 TagInfoMgr          DEBUG finalize()
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoReader.cxx b/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoReader.cxx
index be979240aaa88c618b662be4e910aadbc15e2259..49dacf6e29767e3a3b15d9dd25b7b423385e0473 100755
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoReader.cxx
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoReader.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /**
@@ -9,9 +9,6 @@
  * geometry and conditions tags in EventInfo, checks tags on reading
  *
  * @author RD Schaffer <R.D.Schaffer@cern.ch>
- *
- * $Id: EventInfoReader.cxx,v 1.10 2007-04-07 17:48:49 schaffer Exp $
- *
  */
 
 #include "EventInfoReader.h"
@@ -20,16 +17,13 @@
 #include "EventInfo/EventInfo.h"
 #include "EventInfo/EventID.h"
 #include "EventInfo/EventType.h"
-#include "EventInfo/TagInfo.h"
-
-// GeoModel
-#include "GeoModelInterfaces/IGeoModelSvc.h"
 
 // Constructor with parameters:
 EventInfoReader::EventInfoReader(const std::string &name, 
 				 ISvcLocator *pSvcLocator) :
     AthAlgorithm(name,pSvcLocator),
-    m_geoModel("GeoModelSvc", name)
+    m_geoModel("GeoModelSvc", name),
+    m_tagInfoMgr("TagInfoMgr", name)
 {}
 
 // Initialize method:
@@ -37,6 +31,7 @@ StatusCode EventInfoReader::initialize()
 {
     ATH_MSG_INFO( "EventInfoReader::initialize()"  );
     ATH_CHECK( m_geoModel.retrieve() );
+    ATH_CHECK( m_tagInfoMgr.retrieve() );
     return StatusCode::SUCCESS;
 }
 
@@ -66,29 +61,13 @@ StatusCode EventInfoReader::execute()
 	ATH_MSG_DEBUG( name << " : " << tag );
     }
 
-
-
-    // Get TagInfo and add tags
-
-    TagInfo tagInfo_local;
-    const TagInfo* tagInfo = 0;
-    // Try to get tagInfo if there, otherwise create
-    if (detStore()->retrieve( tagInfo ).isFailure()) {
-	ATH_MSG_DEBUG("No TagInfo in DetectorStore - creating one" );
-	tagInfo = &tagInfo_local;
-    } 
-    else {
-	ATH_MSG_DEBUG("Retrieved TagInfo" );
-    } 
-
-    // Dump out contents of TagInfo
-    ATH_MSG_DEBUG("Tags from  TagInfo:" );
-    tagInfo->printTags(msg());
+    // Dump out Tags
+    ATH_MSG_DEBUG("Tags from TagInfoMgr:");
+    ATH_MSG_DEBUG( m_tagInfoMgr->dumpTagInfoToStr() );
     
     // Print out current Release version 
-    std::string releaseVersion;
-    tagInfo->findTag("AtlasRelease", releaseVersion);
-    ATH_MSG_DEBUG( "Found Release version from TagInfo: "  << releaseVersion  );
+    std::string releaseVersion = m_tagInfoMgr->findTag("AtlasRelease");
+    ATH_MSG_DEBUG("Found Release version from TagInfoMgr: " << releaseVersion);
 
     return StatusCode::SUCCESS;
 }
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoReader.h b/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoReader.h
index 410a6caf383318e9c30e155c1ae3ead49ea3e199..5fc889ba1682f1d6f2bfc645c3b8d61c778f81fe 100755
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoReader.h
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoReader.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef SRC_EVENTINFOREADER_H
@@ -12,9 +12,6 @@
  * geometry and conditions tags in EventInfo, checks tags on reading
  *
  * @author RD Schaffer <R.D.Schaffer@cern.ch>
- *
- * $Id: EventInfoReader.h,v 1.3 2005-03-16 14:54:02 schaffer Exp $
- *
  */
 
 /**
@@ -26,10 +23,13 @@
  */
 
 #include "GaudiKernel/ServiceHandle.h"
-
 #include "AthenaBaseComps/AthAlgorithm.h"
+
+#include "EventInfoMgt/ITagInfoMgr.h"
+// GeoModel
 #include "GeoModelInterfaces/IGeoModelSvc.h"
 
+
 class EventInfoReader : public AthAlgorithm {
 public:
 
@@ -65,6 +65,8 @@ private:
 private:
     /// Access to GeoModelSvc for tags
     ServiceHandle<IGeoModelSvc> m_geoModel;
+    /// Access to TagInfoMgr for tags
+    ServiceHandle<ITagInfoMgr> m_tagInfoMgr;
 };
 
 
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoWriter.cxx b/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoWriter.cxx
index c572d5bb30f786762ff53c1731b648f02bcb9c50..a884d857ddc262925f60153392f8a113f15c470d 100755
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoWriter.cxx
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoWriter.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /**
@@ -9,9 +9,6 @@
  * geometry and conditions tags in EventInfo, writes extra tags.
  *
  * @author RD Schaffer <R.D.Schaffer@cern.ch>
- *
- * $Id: EventInfoWriter.cxx,v 1.9 2009-04-29 07:49:45 schaffer Exp $
- *
  */
 
 //<<<<<< INCLUDES                                                       >>>>>>
@@ -22,7 +19,6 @@
 #include "EventInfo/EventInfo.h"
 #include "EventInfo/EventID.h"
 #include "EventInfo/EventType.h"
-#include "EventInfo/TagInfo.h"
 #include "EventInfoMgt/ITagInfoMgr.h"
 
 // Constructor with parameters:
@@ -116,54 +112,16 @@ StatusCode EventInfoWriter::execute()
         if (m_tagInfoMgr->addTag("TagD1", "D2").isFailure()) {
             ATH_MSG_WARNING("TagD1 NOT added");
 	} 
-
-ATH_MSG_DEBUG("execute: reset TagInfo proxy");
-
-        SG::DataProxy* tagInfoProxy = 
-            detStore()->proxy( ClassID_traits<TagInfo>::ID() );
-
-        if (0 == tagInfoProxy) {
-            ATH_MSG_ERROR("execute: Unable to retrieve TagInfo object with clid/key: " 
-                            << ClassID_traits<TagInfo>::ID());
-            return StatusCode::FAILURE;
-        }
-        // reset and retrieve
-        tagInfoProxy->reset();
-        const TagInfo* tagInfo = 0;
-        if (detStore()->retrieve( tagInfo ).isFailure() ) {
-            ATH_MSG_ERROR("execute: Could not retrieve TagInfo object from the detector store");      
-            return StatusCode::FAILURE;
-        }
-        else {
-            ATH_MSG_DEBUG("execute: retrieved TagInfo");
-        }
-
     }
 
-
-    // Get TagInfo and add tags
-
-    TagInfo tagInfo_local;
-    const TagInfo* tagInfo = 0;
-    // Try to get tagInfo if there, otherwise create
-    if (detStore()->retrieve( tagInfo ).isFailure()) {
-	ATH_MSG_DEBUG("No TagInfo in DetectorStore - creating one");
-	tagInfo = &tagInfo_local;
-    } 
-    else {
-	ATH_MSG_DEBUG("Retrieved TagInfo");
-    } 
-
-    // Dump out contents of TagInfo
-    ATH_MSG_DEBUG("Tags from  TagInfo:");
+    // Dump out Tags
+    ATH_MSG_DEBUG("Tags from TagInfoMgr:");
     MsgStream log(msgSvc(), name());
-    tagInfo->printTags(log);
+    m_tagInfoMgr->printTags(log);
     
     // Print out current Release version 
-    std::string releaseVersion;
-    tagInfo->findTag("AtlasRelease", releaseVersion);
-    ATH_MSG_DEBUG("Found Release version from TagInfo: " 
-	<< releaseVersion);
+    std::string releaseVersion = m_tagInfoMgr->findTag("AtlasRelease");
+    ATH_MSG_DEBUG("Found Release version from TagInfoMgr: " << releaseVersion);
 
     return StatusCode::SUCCESS;
 }
@@ -214,16 +172,4 @@ EventInfoWriter::fillTagInfo    () const
     }
         
     return StatusCode::SUCCESS;
-
 }
-
-
-
-StatusCode
-EventInfoWriter::checkTagInfo(IOVSVC_CALLBACK_ARGS)
-{
-    // Get the messaging service, print where you are
-    ATH_MSG_DEBUG("EventInfoWriter::checkTagInfo - called by IOVSvc");
-    return (fillTagInfo());
-}
-
diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoWriter.h b/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoWriter.h
index 33bf787ef2da11f573ee3a56fa9e0221e47116df..101bb27b01d3827b83787634e1f3d9d60a8dd10b 100755
--- a/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoWriter.h
+++ b/AtlasTest/DatabaseTest/AthenaPoolTest/src/EventInfoWriter.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef SRC_EVENTINFOWRITER_H
@@ -12,9 +12,6 @@
  * geometry and conditions tags in EventInfo, writes extra tags.
  *
  * @author RD Schaffer <R.D.Schaffer@cern.ch>
- *
- * $Id: EventInfoWriter.h,v 1.6 2009-04-29 07:49:45 schaffer Exp $
- *
  */
 
 /**
@@ -28,7 +25,6 @@
 
 //<<<<<< INCLUDES                                                       >>>>>>
 
-#include "AthenaKernel/IOVSvcDefs.h"
 #include "AthenaBaseComps/AthAlgorithm.h"
 
 //<<<<<< PUBLIC TYPES                                                   >>>>>>
@@ -53,9 +49,6 @@ public:
     /// Algorithm finalize at end of job
     virtual StatusCode finalize();
   
-    /// Callback method for TagInfo access
-    StatusCode         checkTagInfo(IOVSVC_CALLBACK_ARGS);
-
     ///////////////////////////////////////////////////////////////////
     // Private methods:
     ///////////////////////////////////////////////////////////////////
diff --git a/AtlasTest/TestTools/share/post.sh b/AtlasTest/TestTools/share/post.sh
index 7d3f9bee13db15a1448314c32de06017360d6f20..8837315c42b4ce3d384ab37b267f5a5de3827718 100755
--- a/AtlasTest/TestTools/share/post.sh
+++ b/AtlasTest/TestTools/share/post.sh
@@ -265,6 +265,12 @@ PP="$PP"'|MetaInputLoader *INFO ( address|.*is still valid for|.*and sid)'
 # Message useless for judging test success
 PP="$PP"'|^FileMgr +DEBUG Successfully registered handler for tech'
 
+# TagInfoMgr not longer a ConversionSvc
+# this line is gone
+PP="$PP"'|Added successfully Conversion service:TagInfoMgr'
+# this line moved around
+PP="$PP"'|Added successfully Conversion service:AthenaPoolCnvSvc'
+
 ########################################### END #####################################################
 
 # Always use default ignore list
@@ -305,6 +311,7 @@ else
            fi
        fi
 
+       echo "Reference log taken from: $reflog" 
        if [ -r $reflog ]; then
            jobdiff=${joblog}-todiff
            refdiff=`basename ${reflog}`-todiff
diff --git a/Calorimeter/CaloEvent/CaloEvent/CaloEnergyCluster.h b/Calorimeter/CaloEvent/CaloEvent/CaloEnergyCluster.h
index 67791a8919305f4c68f33888be6fe8cc6c7032b4..19d2f6b2c2c7145e705d77028efbc08e3ea9c742 100644
--- a/Calorimeter/CaloEvent/CaloEvent/CaloEnergyCluster.h
+++ b/Calorimeter/CaloEvent/CaloEvent/CaloEnergyCluster.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef CALOEVENT_CALOENERGYCLUSTER_H
@@ -136,6 +136,24 @@ class CaloEnergyCluster : public Navigable<CaloCellContainer,double>,
                            double weight,
                            size_t size_hint = 0);
 
+
+  /*! \brief Add a cell (very fast)
+   * 
+   *  \overload
+   * 
+   *  \param theContainer  input pointer to a \a CaloCellContainer (unchanged)
+   *  \param theIndex      input index of \a CaloCell in \a CaloCellConatiner 
+   *                       (unchanged)
+   *  \param sg            current event store instance
+   *  \param weight        signal weight asociated with this cell
+   *
+   *  client has to provide the correct (and valid) index.
+   *
+   *  The caller also guarantees that the cell is not already
+   *  in the cluster.
+   * 
+   *  The caller MUST update Kinematics by himself
+   */
   void addUniqueCellNoKine(const CaloCellContainer* theContainer,
                            index_type theIndex,
                            IProxyDict* sg,
@@ -143,6 +161,34 @@ class CaloEnergyCluster : public Navigable<CaloCellContainer,double>,
                            size_t size_hint = 0);
 
 
+  /*! \brief Add a cell (fastest)
+   * 
+   *  \overload
+   * 
+   *  \param theContainer  link pointing to some element of a \a CaloCellContainer (unchanged)
+   *                       The element index is ignored; this is only to
+   *                       identify the container.
+   *  \param theIndex      input index of \a CaloCell in \a CaloCellConatiner 
+   *                       (unchanged)
+   *  \param sg            current event store instance
+   *  \param weight        signal weight asociated with this cell
+   *
+   *  client has to provide the correct (and valid) index.
+   *
+   *  The caller also guarantees that the cell is not already
+   *  in the cluster.
+   *
+   *  Using this method avoids having to look up the container
+   *  in the event store.
+   * 
+   *  The caller MUST update Kinematics by himself
+   */
+  void addUniqueCellNoKine(const ElementLink<CaloCellContainer>& theContainer,
+                           index_type theIndex,
+                           double weight,
+                           size_t size_hint = 0);
+
+
   /*! \brief Reweight a cell with kinematic update
    *
    *  \param theCell input pointer to a \a CaloCell object (unchanged)
diff --git a/Calorimeter/CaloEvent/src/CaloEnergyCluster.cxx b/Calorimeter/CaloEvent/src/CaloEnergyCluster.cxx
index 2c3e5fe28933b3643d659de60bbaff0dd23da81a..3b471224eb56667ebf56aec022d70e9e6ddc458c 100644
--- a/Calorimeter/CaloEvent/src/CaloEnergyCluster.cxx
+++ b/Calorimeter/CaloEvent/src/CaloEnergyCluster.cxx
@@ -145,6 +145,18 @@ CaloEnergyCluster::addUniqueCellNoKine(const CaloCellContainer* theContainer,
 }
 
 
+void
+CaloEnergyCluster::addUniqueCellNoKine(const ElementLink<CaloCellContainer>& theContainer,
+                                       index_type theIndex,
+                                       double weight,
+                                       size_t size_hint)
+{
+  if ((int)theIndex < 0) abort();
+  ElementLink<CaloCellContainer> el (theContainer, theIndex);
+  this->insertElement(el,weight,size_hint);
+}
+
+
 void 
 CaloEnergyCluster::removeCell(/*CaloCellContainer::const_reference*/
 			      const CaloCell* theCell)
diff --git a/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_0087851_BPTX.py b/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_0087851_BPTX.py
index 4ecfba70b14fb0891b35759aa4e9a2d95557be35..8c2f043fb7e7369766e16f44da29f0adbad32c63 100644
--- a/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_0087851_BPTX.py
+++ b/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_0087851_BPTX.py
@@ -40,7 +40,7 @@ runArgs.trigStream = 'IDCosmic'
 runArgs.preExec = ['from RecExConfig.RecFlags  import rec','rec.doMonitoring=False','rec.doInDet=False','rec.doMuon=False','rec.doMuonCombined=False','rec.doEgamma=False','rec.doTau=False','rec.doTrigger=False','from LArROD.LArRODFlags import larRODFlags','larRODFlags.readDigits.set_Value_and_Lock(False)','doTopoClusterCBNT=True']
 
 # Configuration fragment for DPD.
-runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCommission/RecExCommissionRepro.py', 'RecExCommission/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py']
+runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCommission/RecExCommissionRepro.py', 'RecExCond/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py']
 
 runArgs.postExec = ['from CaloRec.CaloRecConf import CBNTAA_CaloCluster','theCBNT_CaloClusterTopo=CBNTAA_CaloCluster("CBNT_CaloClusterTopo")','theCBNT_CaloClusterTopo.MaxCaloCluster = 2000']
 
diff --git a/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_0091900_cosmics.py b/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_0091900_cosmics.py
index 64601c72a9cc5d7d34516c4c20b643e8f12a0b6a..ebbd3749985e400747ede1aaf6dfac843c4e626c 100644
--- a/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_0091900_cosmics.py
+++ b/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_0091900_cosmics.py
@@ -35,7 +35,7 @@ runArgs.trigStream = 'IDCosmic'
 runArgs.preExec = ['from RecExConfig.RecFlags  import rec','rec.doMonitoring=False','rec.doInDet=False','rec.doMuon=False','rec.doMuonCombined=False','rec.doEgamma=False','rec.doTau=False','rec.doTrigger=False','doTopoClusterCBNT=True','rec.doFloatingPointException=False']
 
 # Configuration fragment for DPD.
-runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCommission/RecExCommissionRepro.py', 'RecExCommission/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py']
+runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCommission/RecExCommissionRepro.py', 'RecExCond/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py']
 
 runArgs.postExec = ['from CaloRec.CaloRecConf import CBNTAA_CaloCluster','theCBNT_CaloClusterTopo=CBNTAA_CaloCluster("CBNT_CaloClusterTopo")','theCBNT_CaloClusterTopo.MaxCaloCluster = 2000']
 
diff --git a/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_MinBias.py b/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_MinBias.py
index 9909ad379f4211823f7fc668eca026fd022dac22..1155d1440061117d175383dc8d7f031c57c62317 100755
--- a/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_MinBias.py
+++ b/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_MinBias.py
@@ -36,7 +36,7 @@ runArgs.trigStream = 'MinBias'
 runArgs.preExec = ['from RecExConfig.RecFlags  import rec','rec.doMonitoring=False','rec.doInDet=False','rec.doMuon=False','rec.doMuonCombined=False','rec.doEgamma=False','rec.doTau=False','rec.doTrigger=False','from LArROD.LArRODFlags import larRODFlags','larRODFlags.readDigits.set_Value_and_Lock(False)','doTopoClusterCBNT=True']
 
 # Configuration fragment for DPD.
-runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCommission/RecExCommissionRepro.py', 'RecExCommission/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py']
+runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCommission/RecExCommissionRepro.py', 'RecExCond/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py']
 
 # Configuration fragment for DPD.
 #runArgs.postInclude = ['RecJobTransforms/reducedRegionSelectorPostConfig.py']
diff --git a/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_cosmics.py b/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_cosmics.py
index b24860976b101a02b0b3f68a18f2551aed336c78..09489ca70b20cf6b271bbf5ac18d8a9f239772b0 100755
--- a/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_cosmics.py
+++ b/Calorimeter/CaloExample/CaloRecEx/share/CaloRecEx_RTT_physics_cosmics.py
@@ -34,7 +34,7 @@ runArgs.preExec = ['from RecExConfig.RecFlags  import rec','rec.doMonitoring=Fal
 #runArgs.preExec = ['from RecExConfig.InputFilePeeker import inputFileSummary','inputFileSummary.stream_names=StreamESD']
 
 # Configuration fragment for DPD.
-runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCommission/RecExCommissionRepro.py', 'RecExCommission/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py']
+runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCommission/RecExCommissionRepro.py', 'RecExCond/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py']
 
 runArgs.postExec = ['from CaloRec.CaloRecConf import CBNTAA_CaloCluster','theCBNT_CaloClusterTopo=CBNTAA_CaloCluster("CBNT_CaloClusterTopo")','theCBNT_CaloClusterTopo.MaxCaloCluster = 2000']
 
diff --git a/Calorimeter/CaloExample/CaloTests/CMakeLists.txt b/Calorimeter/CaloExample/CaloTests/CMakeLists.txt
deleted file mode 100644
index 4b3ddcb9c00a2e57e04bbf1b1e7936f01a7c7bf3..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/CMakeLists.txt
+++ /dev/null
@@ -1,19 +0,0 @@
-# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-
-# Declare the package name:
-atlas_subdir( CaloTests )
-
-# External dependencies:
-find_package( AIDA )
-
-# Component(s) in the package:
-atlas_add_component( CaloTests
-                     src/*.cxx
-                     src/components/*.cxx
-                     INCLUDE_DIRS ${AIDA_INCLUDE_DIRS}
-                     LINK_LIBRARIES AtlasHepMCLib CaloDetDescrLib CaloIdentifier AthenaBaseComps StoreGateLib SGtests Identifier GaudiKernel CaloEvent CaloGeoHelpers CaloSimEvent AthenaKernel AtlasDetDescr GeneratorObjects LArIdentifier LArRawEvent LArRawUtilsLib LArSimEvent LArCablingLib )
-
-# Install files from the package:
-atlas_install_joboptions( share/*.py )
-atlas_install_runtime( test/CaloTests_TestConfiguration.xml share/*.C share/rttTest.css share/CaloTests_HistoComparison.txt share/*Checks.py )
-
diff --git a/Calorimeter/CaloExample/CaloTests/CaloTests/Analysis.h b/Calorimeter/CaloExample/CaloTests/CaloTests/Analysis.h
deleted file mode 100644
index 70360b0d4cb4e8c3032e1d6187f42bc815067ce9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/CaloTests/Analysis.h
+++ /dev/null
@@ -1,248 +0,0 @@
-/*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
-*/
-
-// TheAnalysis.h
-//
-
-#ifndef CALOTESTS_ANALYSIS_H
-#define CALOTESTS_ANALYSIS_H
-
-#include <string>
-
-// Gaudi includes
-
-#include "AthenaBaseComps/AthAlgorithm.h"
-#include "AIDA/IHistogram2D.h"
-#include "StoreGate/ReadHandleKey.h"
-#include "StoreGate/ReadHandleKeyArray.h"
-#include "Identifier/Identifier.h"
-#include "CaloIdentifier/CaloIdManager.h"
-#include "CaloIdentifier/LArID.h"
-#include "CaloIdentifier/CaloDM_ID.h"
-#include "CaloDetDescr/CaloDetDescrManager.h"
-#include "LArElecCalib/ILArfSampl.h"
-#include "GeneratorObjects/McEventCollection.h"
-#include "LArSimEvent/LArHitContainer.h"
-#include "CaloEvent/CaloCellContainer.h"
-#include "LArRawEvent/LArRawChannelContainer.h"
-#include "CaloEvent/CaloClusterContainer.h"
-#include "CaloSimEvent/CaloCalibrationHitContainer.h"
-#include "LArCabling/LArOnOffIdMapping.h"
-
-#include "GaudiKernel/ITHistSvc.h"
-#include "TH1.h"
-#include "TTree.h"
-
-class LArDetDescrManager ;
-class ITriggerTime;
-
-namespace MyAnalysis {
-
-  class Analysis : public AthAlgorithm {
-  public:
-    //Gaudi style constructor and execution methods
-    /** Standard Athena-Algorithm Constructor */
-    Analysis(const std::string& name, ISvcLocator* pSvcLocator);
-    /** Default Destructor */
-    ~Analysis();
-    
-    /** standard Athena-Algorithm method */
-    StatusCode          initialize();
-    /** standard Athena-Algorithm method */
-    StatusCode          execute();
-    /** standard Athena-Algorithm method */
-    StatusCode          finalize();
-    
-    bool CheckLArIdentifier(int,int,int,int);
-
-    bool CheckDMIdentifier(int,int,int,int,int);
- 
-  private:
-
-  //---------------------------------------------------
-  // Member variables
-  //---------------------------------------------------
-
-  ITHistSvc* m_thistSvc;
-  TH1D* m_hist_etraw_emb_s0;
-  TH1D* m_hist_etraw_emb_s1;
-  TH1D* m_hist_etraw_emb_s2;
-  TH1D* m_hist_etraw_emb_s3;
-  TH1D* m_hist_etraw_emec_s0;
-  TH1D* m_hist_etraw_emec_s1;
-  TH1D* m_hist_etraw_emec_s2;
-  TH1D* m_hist_etraw_emec_s3;
-  TH1D* m_hist_clusnoise;
-  TH1D* m_hist_clusnoise1;
-  TH1D* m_hist_clusnoise2;
-  TH1D* m_hist_clusnoise3;
-  TH1D* m_hist_ot;
-  TH1D* m_hist_ot_em;
-  TH1D* m_hist_ot_hec;
-  TH1D* m_hist_ot_fcal;
-  TH1D* m_hist_it;
-  TH1D* m_hist_it_em;
-  TH1D* m_hist_it_hec;
-  TH1D* m_hist_it_fcal;
-  TH1D* m_hist_hittime;
-  TH1D* m_hist_hitener;
-  TH1D* m_hist_nhitlar;
-  TH1D* m_hist_cal0;
-  TH1D* m_hist_cal1;
-  TH1D* m_hist_cal2;
-  TH1D* m_hist_cal3;
-
-  //---------------------------------------------------
-  // Parameters of this algorithm
-  //---------------------------------------------------
-  bool m_clusternoise;
-  bool m_check;
-  bool m_raw;
-  bool m_cluster;
-  bool m_cell;
-  bool m_hit;
-  bool m_calhit;
-  bool m_useTriggerTime;
-  bool m_doTruth;
-
-  SG::ReadHandleKey<McEventCollection> m_mcCollName { this, "MCColl", "GEN_AOD" };
-  SG::ReadHandleKeyArray<LArHitContainer> m_hitContainerNames { this, "HitContainers",
-                                                                {"LArHitEMB",
-                                                                 "LArHitEMEC",
-                                                                 "LArHitHEC",
-                                                                 "LArHitFCAL"} };
-  SG::ReadHandleKey<CaloCellContainer> m_caloCellName { this, "CaloCells", "AllCalo" };
-  SG::ReadHandleKey<LArRawChannelContainer> m_rawChannelName { this, "RawChannels", "LArRawChannels" };
-  SG::ReadHandleKeyArray<CaloCalibrationHitContainer> m_calibHitContainerNames
-    { this, "CalibHitContainers",
-      {"LArCalibrationHitActive",
-       "LArCalibrationHitDeadMaterial",
-       "LArCalibrationHitInactive",
-       "TileCalibHitActiveCell",
-       "TileCalibHitInactiveCell",
-       "TileCalibHitDeadMaterial"} };
-  SG::ReadHandleKey<CaloClusterContainer> m_cluster55Name { this, "Cluster55", "LArClusterEM" };
-  SG::ReadHandleKey<CaloClusterContainer> m_cluster55gamName { this, "Cluster55gam", "LArClusterEMgam" };
-  SG::ReadHandleKey<CaloClusterContainer> m_cluster35Name { this, "Cluster35", "LArClusterEM35" };
-  SG::ReadHandleKey<CaloClusterContainer> m_cluster35gamName { this, "Cluster35gam", "LArClusterEMgam35" };
-  SG::ReadHandleKey<CaloClusterContainer> m_cluster37Name { this, "Cluster37", "LArClusterEM37" };
-  SG::ReadHandleKey<CaloClusterContainer> m_cluster37gamName { this, "Cluster37gam", "LArClusterEMgam37" };
-    
-  int m_nevt;
-
-  SG::ReadCondHandleKey<LArOnOffIdMapping> m_cablingKey{this,"CablingKey","LArOnOffIdMap","SG Key of LArOnOffIdMapping object"};
-
-  StringProperty m_triggerTimeToolName;
-  ITriggerTime* m_triggerTimeTool;
-
-  Identifier m_id;
-  const LArEM_ID*        m_larem_id;
-  const CaloDM_ID*       m_calodm_id;
-
-  // list of cell energies
-  struct CellInfo {
-       int bec;
-       int sampling;
-       double eta;
-       double phi;
-       double Ehit;
-       double Thit;
-       double Eraw;
-       double Ecell;
-       Identifier identifier;
-   };
-   std::vector<CellInfo> m_CellListEM; 
-
-   double m_nt_e;
-   double m_nt_eta;
-   double m_nt_phi;
-   double m_nt_e0;
-   double m_nt_e1;
-   double m_nt_e2;
-   double m_nt_e3;
-   double m_nt_c0;
-   double m_nt_c1;
-   double m_nt_c2;
-   double m_nt_c3;
-   double m_nt_hb0;
-   double m_nt_hb1;
-   double m_nt_hb2;
-   double m_nt_hb3;
-   double m_nt_he0;
-   double m_nt_he1;
-   double m_nt_he2;
-   double m_nt_he3;
-   double m_nt_tb0;
-   double m_nt_tb1;
-   double m_nt_tb2;
-   double m_nt_tb3;
-   double m_nt_eclus;
-   double m_nt_eclus0;
-   double m_nt_eclus1;
-   double m_nt_eclus2;
-   double m_nt_eclus3;
-   double m_nt_etaclus;
-   double m_nt_phiclus;
-   double m_nt_etaclus551;
-   double m_nt_etaclus552;
-   double m_nt_eclus35;
-   double m_nt_eclus37;
-   double m_nt_eclus350;
-   double m_nt_eclus351;
-   double m_nt_eclus352;
-   double m_nt_eclus353;
-   double m_nt_etaclus35;
-   double m_nt_etaclus351;
-   double m_nt_etaclus352;
-   double m_nt_etaclus371;
-   double m_nt_etaclus372;
-   double m_nt_eclusg;
-   double m_nt_etaclusg551;
-   double m_nt_etaclusg552;
-   double m_nt_eclusg35;
-   double m_nt_etaclusg351;
-   double m_nt_etaclusg352;
-   double m_nt_eclusg37;
-   double m_nt_etaclusg371;
-   double m_nt_etaclusg372;
-   double m_nt_eActEM;
-   double m_nt_eActNonEM;
-   double m_nt_eActEscaped;
-   double m_nt_eActInvisible;
-   double m_nt_eInactEM;
-   double m_nt_eInactNonEM;
-   double m_nt_eInactEscaped;
-   double m_nt_eInactInvisible;
-   double m_nt_eDeadEM;
-   double m_nt_eDeadNonEM;
-   double m_nt_eDeadEscaped;
-   double m_nt_eDeadInvisible;
-   double m_nt_eTile;
-   double m_nt_edead_1_0;
-   double m_nt_edead_1_1_0;
-   double m_nt_edead_1_1_1;
-   double m_nt_edead_1_1_2;
-   double m_nt_edead_1_1_3;
-   double m_nt_edead_1_1_4;
-   double m_nt_edead_1_1_5;
-   double m_nt_edead_1_1_6;
-   double m_nt_edead_1_1_7;
-   double m_nt_edead_1_2_0;
-   double m_nt_edead_1_2_1;
-   double m_nt_edead_1_2_2;
-   double m_nt_edead_1_2_3;
-   double m_nt_edead_1_2_4;
-   double m_nt_edead_1_2_5;
-   double m_nt_edead_1_3;
-   double m_nt_eleak;
-   double m_xconv;
-   double m_yconv;
-   double m_zconv;
-   double m_xvert;
-   double m_yvert;
-   double m_zvert;
-   TTree* m_ntuple;
-  };
-} // end of namespace bracket
-#endif
diff --git a/Calorimeter/CaloExample/CaloTests/CaloTests/Analysis.h.02may03 b/Calorimeter/CaloExample/CaloTests/CaloTests/Analysis.h.02may03
deleted file mode 100644
index 55861b161bddfd25081a2d90ff40140ab7c4c47e..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/CaloTests/Analysis.h.02may03
+++ /dev/null
@@ -1,81 +0,0 @@
-// TheAnalysis.h
-//
-
-#ifndef _Analysis_Analysis_H
-#define _Analysis_Analysis_H
-
-#include <string>
-
-// Gaudi includes
-
-#include "GaudiKernel/Algorithm.h"
-#include "GaudiKernel/IHistogramSvc.h"
-#include "AIDA/IHistogram1D.h"
-#include "AIDA/IHistogram2D.h"
-#include "StoreGate/StoreGateSvc.h"
-
-namespace MyAnalysis {
-
-  class Analysis : public Algorithm {
-  public:
-    //Gaudi style constructor and execution methods
-    /** Standard Athena-Algorithm Constructor */
-    Analysis(const std::string& name, ISvcLocator* pSvcLocator);
-    /** Default Destructor */
-    ~Analysis();
-    
-    /** standard Athena-Algorithm method */
-    StatusCode          initialize();
-    /** standard Athena-Algorithm method */
-    StatusCode          execute();
-    /** standard Athena-Algorithm method */
-    StatusCode          finalize();
-  private:
-
-  //---------------------------------------------------
-  // Member variables
-  //---------------------------------------------------
-  /** The StoreGate Service */
-  StoreGateSvc* m_sgSvc;
-
-  IHistogram1D* m_hist_muon;
-  IHistogram1D* m_hist_elec;
-  IHistogram2D* m_hist_map;
-  IHistogram2D* m_hist_map0;
-  IHistogram2D* m_hist_map1;
-  IHistogram2D* m_hist_map2;
-  IHistogram2D* m_hist_map3;
-  IHistogram2D* m_hist_map4;
-  IHistogram2D* m_hist_map5;
-  IHistogram2D* m_hist_map6;
-  IHistogram2D* m_hist_map7;
-
-  IHistogram1D* m_hist_hit0;
-  IHistogram1D* m_hist_hit1;
-  IHistogram1D* m_hist_hit2;
-  IHistogram1D* m_hist_hit3;
-  IHistogram1D* m_hist_mbe;
-  IHistogram1D* m_hist_mbe2;
-  IHistogram1D* m_hist_mbe3;
-
-  IHistogram1D* m_hist_cl1;
-  IHistogram1D* m_hist_cl2;
-  IHistogram1D* m_hist_cl3;
-  IHistogram1D* m_hist_cl4;
-
-  IHistogram1D* m_hist_nbcl;
-  IHistogram2D* m_hist_clet;
-  IHistogram2D* m_hist_clet2;
-  IHistogram2D* m_hist_time;
-
-  //---------------------------------------------------
-  // Parameters of this algorithm
-  //---------------------------------------------------
-  double m_ptMuonMin;   // Minimun pt muon
-  double m_ptElecMin;   // Minimun pt muon
-
-  int m_nevt;
-
-  };
-} // end of namespace bracket
-#endif
diff --git a/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h b/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h
deleted file mode 100644
index 87ce33ecf6091615b0bb540d8a01b6cdc36c07c2..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h
+++ /dev/null
@@ -1,59 +0,0 @@
-/*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
-*/
-
-// TheAnalysis.h
-//
-
-#ifndef CALOTESTS_ANALYSISCAL_H
-#define CALOTESTS_ANALYSISCAL_H
-
-#include <string>
-
-// Gaudi includes
-
-#include "AthenaBaseComps/AthReentrantAlgorithm.h"
-#include "GaudiKernel/NTuple.h"
-#include "GaudiKernel/IHistogramSvc.h"
-#include "AIDA/IHistogram1D.h"
-#include "AIDA/IHistogram2D.h"
-#include "StoreGate/ReadHandleKey.h"
-#include "StoreGate/ReadHandleKeyArray.h"
-#include "Identifier/Identifier.h"
-#include "Identifier/IdContext.h"
-#include "GeneratorObjects/McEventCollection.h"
-#include "LArSimEvent/LArHitContainer.h"
-#include "CaloSimEvent/CaloCalibrationHitContainer.h"
-
-class LArDetDescrManager ;
-
-namespace MyAnalysisCal {
-
-  class AnalysisCal : public AthReentrantAlgorithm {
-  public:
-    //Gaudi style constructor and execution methods
-    /** Standard Athena-Algorithm Constructor */
-    AnalysisCal(const std::string& name, ISvcLocator* pSvcLocator);
-    /** Default Destructor */
-    virtual ~AnalysisCal();
-    
-    /** standard Athena-Algorithm method */
-    virtual StatusCode          initialize() override;
-    /** standard Athena-Algorithm method */
-    virtual StatusCode          execute(const EventContext& ctx) const override;
-    /** standard Athena-Algorithm method */
-    virtual StatusCode          finalize() override;
-  private:
-    SG::ReadHandleKey<McEventCollection> m_mcCollName { this, "MCColl", "GEN_AOD" };
-    SG::ReadHandleKeyArray<LArHitContainer> m_hitContainerNames { this, "HitContainers",
-                                                                  {"LArHitEMB",
-                                                                   "LArHitEMEC",
-                                                                   "LArHitHEC",
-                                                                   "LArHitFCAL"} };
-    SG::ReadHandleKeyArray<CaloCalibrationHitContainer> m_calibHitContainerNames { this, "CalibHitContainers",
-                                                                  {"LArCalibrationHitActive",
-                                                                   "LArCalibrationHitDeadMaterial",
-                                                                   "LArCalibrationHitInactive"} };
-  };
-} // end of namespace bracket
-#endif
diff --git a/Calorimeter/CaloExample/CaloTests/CaloTests/CreateHits.h b/Calorimeter/CaloExample/CaloTests/CaloTests/CreateHits.h
deleted file mode 100644
index 563c1a9166f41ef84866522acd1e5a3b5fdf1e55..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/CaloTests/CreateHits.h
+++ /dev/null
@@ -1,46 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#ifndef _Analysis_CreateHits_H
-#define _Analysis_CreateHits_H
-
-#include <string>
-
-// Gaudi includes
-
-#include "GaudiKernel/Algorithm.h"
-#include "StoreGate/StoreGateSvc.h"
-#include "CaloIdentifier/LArEM_ID.h"
-
-namespace CreateHits {
-
-  class CreateHits : public Algorithm {
-  public:
-    //Gaudi style constructor and execution methods
-    /** Standard Athena-Algorithm Constructor */
-    CreateHits(const std::string& name, ISvcLocator* pSvcLocator);
-    /** Default Destructor */
-    ~CreateHits();
-    
-    /** standard Athena-Algorithm method */
-    StatusCode          initialize();
-    /** standard Athena-Algorithm method */
-    StatusCode          execute();
-    /** standard Athena-Algorithm method */
-    StatusCode          finalize();
-  private:
-
-  //---------------------------------------------------
-  // Member variables
-  //---------------------------------------------------
-  /** The StoreGate Service */
-  StoreGateSvc* m_sgSvc;
-  StoreGateSvc* detStore;
-  const LArEM_ID*        m_larem_id;
-
-  int m_nevt;
-
-  };
-} // end of namespace bracket
-#endif
diff --git a/Calorimeter/CaloExample/CaloTests/doc/packagedoc.h b/Calorimeter/CaloExample/CaloTests/doc/packagedoc.h
deleted file mode 100644
index 15eec8e8c93fd4895cda164680c4c711d98edb89..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/doc/packagedoc.h
+++ /dev/null
@@ -1,13 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-/**
-
-@page CaloTests_page CaloTests Package
-
-This package is used to test (RTT) the full chain in the calorimeter (simulation -> digitization -> reconstruction)
-
-@author Karim Bernardet bernardet@cppm.in2p3.fr
-
-*/
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_DigCTB.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_DigCTB.py
deleted file mode 100644
index 33ab076b9aed211aa92677edc6a73c0f7a889b96..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_DigCTB.py
+++ /dev/null
@@ -1,2 +0,0 @@
-include("CaloDigEx/CaloDigCTB.py")
-#include("CaloDigCTB.py")
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_HistoComparison.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_HistoComparison.py
deleted file mode 100644
index cf7dcc466cfc4cf5d9b40fea9bc68210c1e33a70..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_HistoComparison.py
+++ /dev/null
@@ -1,482 +0,0 @@
-#!/usr/bin/env python
-
-import os,commands,sys,logging
-import ROOT
-
-class myHist:
-    def __init__(self,histName,histComment,histBins,histMinX,histMaxX,histFormula,histCondForm):
-        self.histName=histName
-        self.histComment=histComment
-        self.histMinX=histMinX
-        self.histMaxX=histMaxX
-        self.histFormula=histFormula
-        self.histCondForm=histCondForm
-        self.histBins=histBins
-        
-
-    def setHistName(self,name):
-        self.histName=name
-
-    def setHistComment(self,Comment):
-        self.histComment=Comment
-
-    def setHistFormula(self,form):
-        self.histFormula=form
-
-    def setHistCondForm(self,condform):
-        self.histCondForm=condform
-
-    def setHistName(self,minX):
-        self.HistMinx=minX
-
-    def setHistName(self,maxX):
-        self.histMaxX=maxX
-
-    def setHistBins(self,nbins):
-        self.histBins=nbins
-
-    def getHistName(self):
-        return self.histName
-
-    def getHistComment(self):
-        return self.histComment
-
-    def getHistMinX(self):
-        return self.histMinX
-
-    def getHistMaxX(self):
-        return self.histMaxX
-
-    def getHistBins(self):
-        return self.histBins
-
-    def getHistFormula(self):
-        return self.histFormula
-
-    def getHistCondForm(self):
-        return self.histCondForm
-    
-
-class HistosComparison:
-    def __init__(self,log,logLevel):
-        if log=='':
-            self.logger = logging.getLogger('HistosComparison')
-            hdlr = logging.FileHandler('HistosComparison.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-        self.filePar="filePar"
-    
-    def normH(self,m_hist):
-        if m_hist.GetEntries() != 0 :
-            scale = 1/m_hist.GetEntries()
-            m_hist.Scale(scale)
-        else:
-            self.logger.error("No entries in ",m_hist.GetTitle())
-
-    def getPar(self,name,par):
-        com="grep \"RTTParm_almostIdentical_"+name+"_"+par+"\"  "+self.filePar+ "| cut -d= -f2 | tail -n1"
-        print com
-        res,val=commands.getstatusoutput(com)
-        if val=="":
-            val="notfound"
-        if res!=0:
-            self.logger.error('Problem to get the par of '+name+' : '+max)
-            val="notfound"
-            
-        return val       
-    
-    def makeHist(self,ROOTntuple):
-
-        ROOT.gStyle.SetMarkerStyle(8)
-        ROOT.gStyle.SetStatW(0.4)
-        ROOT.gStyle.SetStatFontSize(0.12)
-        ROOT.gStyle.SetLabelSize(0.06)
-        ROOT.gStyle.SetOptStat(111110)
-        ROOT.gStyle.SetCanvasBorderMode(0)
-        ROOT.gStyle.SetPadBorderMode(0)
-        ROOT.gStyle.SetPadColor(0)
-        ROOT.gStyle.SetCanvasColor(0)
-        ROOT.gStyle.SetTitleColor(0)
-        ROOT.gStyle.SetStatColor(0)
-
-        # only 3 digits
-        ROOT.TGaxis.SetMaxDigits(3);
-
-        myCanvas = ROOT.TCanvas("myCanvas","Cluster",1)
-        myCanvas.Divide(2,8)
-
-        file=open('CaloTests_HistoComparison.txt','r')
-        hists=[]
-        n=0
-        for line in file:
-            i=+1
-            myCanvas.cd(n)
-            tmp=line.strip().split(',')
-
-            name2=""
-            for i in tmp[1]:
-                if i==' ':
-                    i='_'
-                if i=='(':
-                    i='z'
-                if i==')':
-                    i='z'
-                name2+=i
-
-            # check bin x
-            xmin=self.getPar(name2,"xmin")
-            if xmin=="notfound":
-                xmin=tmp[3]
-
-            xmax=self.getPar(name2,"xmax")
-            if xmax=="notfound":
-                xmax=tmp[4]
-            
-            print "XMIN =", xmin
-            print "XMAX =", xmax
-
-            
-            if len(tmp)==7:
-                h=myHist(tmp[0],tmp[1],tmp[2],xmin,xmax,tmp[5],tmp[6])
-            else:
-                h=myHist(tmp[0],tmp[1],tmp[2],xmin,xmax,tmp[5],'')
-            hists.append(h)
-        file.close()
-        
-        rootFile = ROOT.TFile(ROOTntuple,'READ')
-        mytree = ROOT.gDirectory.Get('CollectionTree')
-        mytree.UseCurrentStyle()
-
-        hfile = ROOT.TFile("Cluster.hist","RECREATE","Clusters hist")
-        for h in hists:
-            self.logger.debug(h.getHistName(),',',h.getHistComment(),',',h.getHistBins(),',',h.getHistMinX(),',',h.getHistBins(),',',h.getHistMaxX())
-            m_h = ROOT.TH1F(h.getHistName(),h.getHistComment(),int(h.getHistBins()),float(h.getHistMinX()),float(h.getHistMaxX()))
-            mytree.Draw(h.getHistFormula(),h.getHistCondForm())
-            mytree.Draw(h.getHistFormula()+'>>'+h.getHistName(),h.getHistCondForm())
-            self.normH(m_h)
-            hfile.Write()
-        
-        rootFile.Close()
-        
-    def getFilePar(self):
-        com="grep RTTINFO MYRTTINFOS.txt | cut -d= -f2 | tail -n1"
-        res,testName=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(testName)
-            return -1
-        
-        nTestName=''
-        for i in testName:
-            if i !=' ':
-                nTestName+=i;
-
-        filePar=nTestName+".par";
-        com="wget http://cern.ch/CaloRTT/"+filePar;
-        print com
-        res,out=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(out)
-            return -1
-        return filePar
-
-
-    def getFileRef(self):
-        com="grep RTTINFO MYRTTINFOS.txt | cut -d= -f2 | tail -n1"
-        res,testName=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(testName)
-            return -1
-        
-        nTestName=''
-        for i in testName:
-            if i !=' ':
-                nTestName+=i;
-
-        fileRef='ref'+nTestName+".hist"
-        com="wget http://cern.ch/CaloRTT/"+fileRef
-        res,out=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(out)
-            return -1
-        return fileRef
-
-    def initHTMLDraw(self):
-        f=open("DrawHistos.html","w")
-        f.write("<html><head><title>Draw</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head>")
-        f.write("<body>")
-        f.close();
-        
-    def closeHTMLDraw(self):
-        f=open("DrawHistos.html","a")
-        f.write("</body>")
-        f.write("</html>")
-
-
-    def initHTMLComparison(self):
-        f=open("Comparison.html","w")
-        f.write("<html><head><title>Draw</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head>")
-        f.write("<body>")
-        f.close();
-        
-    def closeHTMLComparison(self):
-        f=open("Comparison.html","a")
-        f.write("</body>")
-        f.write("</html>")
-
-    def Draw(self,histFile):
-        self.initHTMLDraw()
-        file = ROOT.TFile(histFile)
-        for i in file.GetListOfKeys():
-            self.DrawHisto(i.ReadObj())
-        file.Close()
-        self.closeHTMLDraw()
-
-
-    def DrawHisto(self,hist):
-        f=open("DrawHistos.html","a")
-
-        tmp=hist.GetTitle()
-        name=""
-        for i in tmp:
-            if i==' ':
-                i='_'
-            if i=='(':
-                i='z'
-            if i==')':
-                i='z'
-            name+=i
-
-        ROOT.gStyle.SetOptStat(ROOT.kFALSE)
-        can=ROOT.TCanvas()
- 
-        hist.Draw()
-
-        legend=ROOT.TLegend(0.7,0.7,0.89,0.85)
-        legend.SetTextFont(72)
-        legend.SetTextSize(0.04)
- 
-        legend.AddEntry(hist,"NEW","l")
-        legend.Draw()
- 
-        can.Modified()
-        can.Update()
-
-        epsname=name+".eps"
-        gifname=name+".gif"
-
-        can.SaveAs(epsname)
-
-        com1='pstopnm -ppm -xborder 0 -yborder 0 -portrait '+epsname
-        com2='ppmtogif '+epsname+'001.ppm >'+gifname
-        
-        os.system(com1)
-        os.system(com2)
-        
-        f.write("<CENTER><BR>")
-        f.write("Name : "+hist.GetTitle()+'<BR>')
-        f.write("<BR>")
-        f.write("<TABLE border=1>")
-        f.write("<TR>")
-        f.write("<TD>Entries</TD>")
-        f.write("<TD>"+str(hist.GetEntries())+'</TD>')
-        f.write("</TR>")      
-        f.write("<TR>")
-        f.write("<TD>Mean</TD>")
-        f.write("<TD>"+str(hist.GetMean())+'</TD>')
-        f.write("</TR>")        
-        f.write("<TR>")
-        f.write("<TD>RMS</TD>")
-        f.write('<TD>'+str(hist.GetRMS())+'</TD>')
-        f.write("</TR>")       
-        f.write("</TABLE>")       
-        f.write("<IMG SRC=\""+gifname+'\"><BR>')
-        f.write('<HR><BR>')
-        f.close()
-
-    def almostIdentical(self,hist,refhist,filePar):
-        f=open("Comparison.html","a")
-
-        tmp=hist.GetTitle()
-        name=""
-        for i in tmp:
-            if i==' ':
-                i='_'
-            if i=='(':
-                i='z'
-            if i==')':
-                i='z'
-            name+=i
-
-        ROOT.gStyle.SetOptStat(ROOT.kFALSE)
-        can=ROOT.TCanvas()
-
-        hist.SetLineColor(2)
-        hist.SetLineStyle(2)
-        hist.Draw()
-        if hist:
-            refhist.Draw("sames")
-        else:
-            refhist.Draw()
-
-        legend=ROOT.TLegend(0.7,0.7,0.89,0.85)
-        legend.SetTextFont(72)
-        legend.SetTextSize(0.04)
- 
-        legend.AddEntry(hist,"NEW","l")
-        legend.AddEntry(refhist,"REF","l");
-        legend.Draw()
- 
-        can.Modified()
-        can.Update()
-
-        epsname=name+".eps"
-        gifname=name+".gif"
-
-        can.SaveAs(epsname)
-
-        com1='pstopnm -ppm -xborder 0 -yborder 0 -portrait '+epsname
-        com2='ppmtogif '+epsname+'001.ppm >'+gifname
-        
-        os.system(com1)
-        os.system(com2)
-
-        restxt=open('Comparison.txt','a')
-        
-        f.write("<CENTER><BR>")
-        f.write("Name : "+hist.GetTitle()+'<BR>')
-        f.write("<BR>")
-        f.write("<TABLE border=1>")
-        f.write("<TR>")
-        f.write("<TD></TD>")
-        f.write("<TD>REF</TD>");
-        f.write("<TD>NEW</TD>")
-        f.write("</TR>")
-        
-        f.write("<TD>Entries</TD>")
-        f.write("<TD>"+str(refhist.GetEntries())+'</TD>')
-        f.write("<TD>"+str(hist.GetEntries())+'</TD>')
-        f.write("</TR>")      
-        f.write("<TR>")
-        f.write("<TD>Mean</TD>")
-        f.write("<TD>"+str(refhist.GetMean())+'</TD>')
-        f.write("<TD>"+str(hist.GetMean())+'</TD>')
-        f.write("</TR>")        
-        f.write("<TR>")
-        f.write("<TD>RMS</TD>")
-        f.write('<TD>'+str(refhist.GetRMS())+'</TD>')
-        f.write('<TD>'+str(hist.GetRMS())+'</TD>')
-        f.write("</TR>")       
-        f.write("</TABLE>")       
-        f.write("<IMG SRC=\""+gifname+'\"><BR>')
-
-        com="grep \"RTTParm_almostIdentical_"+name+ " \"  "+filePar+ "| cut -d= -f2 | tail -n1"
-        res,max=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error('Problem to the par of '+name+' : '+max)
-            return -1
-
-        dA=0.
-        A=0.
-        for k  in range(0,hist.GetNbinsX()+1):
-            dA += float(hist.GetBinContent(k) - refhist.GetBinContent(k))
-            A += hist.GetBinContent(k)
-
-        if (A > 0):
-            dA = dA / A;
-
-  
-        restxt.write('&Sigma;(|&Delta;A|)/&Sigma;A is '+str(dA)+' (cut is '+str(max)+')\n')
-        f.write("<BR>")
-        f.write('&Sigma;(|&Delta;A|)/&Sigma;A is '+str(dA)+' (cut is '+str(max)+')\n')
-        f.write("<BR>")
- 
-        if ( dA <= max ):
-            restxt.write("TEST OK\n")
-            restxt.write("###################################\n")
-            f.write("<font color=\"green\">TEST OK<BR></font>")
-            f.write("<HR>")
-            f.write("</CENTER><BR>")
-            f.close()
-            restxt.close()
-            return 0
-        else:
-            restxt.write("TEST FAILED\n")
-            restxt.write("###################################\n")
-            f.write("<font color=\"red\">TEST FAILED</font><BR>")
-            f.write("<HR>")
-            f.write("</CENTER><BR>")
-            f.close()
-            restxt.close()
-            return -1
-
-
-    def testHistogram(self,hists,refhists,compType,filePar):
-        self.logger.info('---- testHistogram '+str(hists.GetTitle())+' ----')
-        if compType == "almostIdentical":
-            res=self.almostIdentical(hists,refhists,filePar)
-            return res
-        else:
-            self.logger.error('Comp type not known')
-            return -1
-        return 0
-
-    def histComparison(self,hist,refhist,compType,filePar):
-        self.initHTMLComparison()
-        fhists = ROOT.TFile(hist); 
-        frefhists = ROOT.TFile(refhist);
-
-        if len(fhists.GetListOfKeys())!=len(frefhists.GetListOfKeys()):
-            self.logger.warning('the ref and new file doesnt contain the same number of histograms')
-            self.Draw('Cluster.hist')
-            return 0
-            
-        if len(fhists.GetListOfKeys())==0:
-            self.logger.error('No histograms in the new file')
-            return -1
-
-        failed=[]
-        hists=[]
-        refHists=[]
-        for i in fhists.GetListOfKeys():
-            hists.append(i.ReadObj())
-        for i in frefhists.GetListOfKeys():
-            refHists.append(i.ReadObj())
-
-        for k in range(1,len(hists)):
-            if self.testHistogram(hists[k],refHists[k],compType,filePar)!=0:
-                failed.append(hists[k].GetName())
-                self.logger.error(hists[k].GetTitle()+' FAILED')
-            else:
-                self.logger.info(hists[k].GetTitle()+' OK')
-            self.logger.info('---- testHistogram DONE ----')
-            self.closeHTMLComparison()  
-        if len(failed)==0:
-            return 0
-        else:
-            return -1
-            
-    def run(self):
-        self.filePar=self.getFilePar()
-        if self.filePar==-1:
-            self.logger.error('getFilePar() failed')
-            return -1
-        
-        self.makeHist('ntuple.root')
-
-        
-#        fileRef=self.getFileRef()
-#        if fileRef==-1:
-#            self.logger.warning('getFileRef() failed')
-#            self.logger.info('drawing the histos instead')
-        self.logger.info('Draw the histos')
-        self.Draw('Cluster.hist')
-        return 0
-        
-        res=self.histComparison('Cluster.hist',fileRef,"almostIdentical");
-        return res
-#a=HistosComparison(logging.INFO)
-#a.run()
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_HistoComparison.txt b/Calorimeter/CaloExample/CaloTests/share/CaloTests_HistoComparison.txt
deleted file mode 100755
index 17959c75f4aea5959b58c9212496e0da550b7f0c..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_HistoComparison.txt
+++ /dev/null
@@ -1,14 +0,0 @@
-m_h1,Cluster E (GeV),50,0.,1000.,cl_pt*cosh(cl_eta)/1000
-m_h2,Cluster E (GeV) - barrel,50,0.,1000.,cl_pt*cosh(cl_eta)/1000,abs(cl_eta)<1.475
-m_h3,Cluster E (GeV) - endcap,50,0.,1000.,cl_pt*cosh(cl_eta)/1000,abs(cl_eta)>=1.475
-m_h4,Cluster eta,40,-2.5,2.5,cl_eta
-m_h5,Cluster phi,25,-7.,7.,cl_phi
-m_h6,number of clusters,6,-.5,5.5,cl_n
-m_h7,E frac. in Presampler - barrel,50,0.,1.,cl_E_PreSamplerB/(cl_E_PreSamplerB+cl_E_EMB1+cl_E_EMB2+cl_E_EMB3),abs(cl_eta)<1.475
-m_h8,E frac. in 1st samp. - barrel,50,0.,1.,cl_E_EMB1/(cl_E_PreSamplerB+cl_E_EMB1+cl_E_EMB2+cl_E_EMB3),abs(cl_eta)<1.475
-m_h9,E frac. in 2nd samp. - barrel,50,0.,1.,cl_E_EMB2/(cl_E_PreSamplerB+cl_E_EMB1+cl_E_EMB2+cl_E_EMB3),abs(cl_eta)<1.475
-m_h10,E frac. in 3rd samp. - barrel,50,0.,.1,cl_E_EMB3/(cl_E_PreSamplerB+cl_E_EMB1+cl_E_EMB2+cl_E_EMB3),abs(cl_eta)<1.475
-m_h11,E frac. in Presampler - endcap,50,0.,1.,cl_E_PreSamplerE/(cl_E_PreSamplerE+cl_E_EME1+cl_E_EME2+cl_E_EME3),abs(cl_eta)>=1.475 && abs(cl_eta)<=1.8
-m_h12,E frac. in 1st samp. - endcap,50,0.,1.,cl_E_EME1/(cl_E_PreSamplerE+cl_E_EME1+cl_E_EME2+cl_E_EME3),abs(cl_eta)>=1.475
-m_h13,E frac. in 2nd samp. - endcap,50,0.,1.,cl_E_EME2/(cl_E_PreSamplerE+cl_E_EME1+cl_E_EME2+cl_E_EME3),abs(cl_eta)>=1.475
-m_h14,E frac. in 3rd samp. - endcap,50,0.,0.1,cl_E_EME3/(cl_E_PreSamplerE+cl_E_EME1+cl_E_EME2+cl_E_EME3),abs(cl_eta)>=1.475
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_misalign_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_misalign_singleE_50GeV.py
deleted file mode 100755
index b23285f5e1e18afe65cc77a5246722e3f3a5545e..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_misalign_singleE_50GeV.py
+++ /dev/null
@@ -1,40 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
- 
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_misalign_singlePhot_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_misalign_singlePhot_50GeV.py
deleted file mode 100644
index f6a8a63c4e7056fbbdc71b7d286b2bd49c246225..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_misalign_singlePhot_50GeV.py
+++ /dev/null
@@ -1,40 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_singleE_50GeV.py
deleted file mode 100755
index 9eaf856b6948f1844c3065cdcfaa0b1742b795b6..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_singleE_50GeV.py
+++ /dev/null
@@ -1,40 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_singleE_5GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_singleE_5GeV.py
deleted file mode 100755
index b23285f5e1e18afe65cc77a5246722e3f3a5545e..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Dig_singleE_5GeV.py
+++ /dev/null
@@ -1,40 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
- 
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singleChargedPi_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singleChargedPi_100GeV_eta-5+5.py
deleted file mode 100644
index 1fdca3c059d784871d1328036e22626fdc631b9f..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singleChargedPi_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,39 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singleE_100GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singleE_100GeV.py
deleted file mode 100755
index 16d31ec2d182b080d4f995661f9a6c1e1fd15d32..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singleE_100GeV.py
+++ /dev/null
@@ -1,41 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-jobproperties.AthenaCommonFlags.EvtMax=-1
-
-jobproperties.AthenaCommonFlags.PoolRDOOutput="Dig.pool.root"
-jobproperties.AthenaCommonFlags.PoolHitsInput=["Sim.pool.root"]
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singleE_50GeV.py
deleted file mode 100755
index 16d31ec2d182b080d4f995661f9a6c1e1fd15d32..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singleE_50GeV.py
+++ /dev/null
@@ -1,41 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-jobproperties.AthenaCommonFlags.EvtMax=-1
-
-jobproperties.AthenaCommonFlags.PoolRDOOutput="Dig.pool.root"
-jobproperties.AthenaCommonFlags.PoolHitsInput=["Sim.pool.root"]
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singlePhot_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singlePhot_50GeV.py
deleted file mode 100755
index 16d31ec2d182b080d4f995661f9a6c1e1fd15d32..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singlePhot_50GeV.py
+++ /dev/null
@@ -1,41 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-jobproperties.AthenaCommonFlags.EvtMax=-1
-
-jobproperties.AthenaCommonFlags.PoolRDOOutput="Dig.pool.root"
-jobproperties.AthenaCommonFlags.PoolHitsInput=["Sim.pool.root"]
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singlePi0_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singlePi0_100GeV_eta-5+5.py
deleted file mode 100644
index f6a8a63c4e7056fbbdc71b7d286b2bd49c246225..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_misalign_singlePi0_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,40 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleChargedPi_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleChargedPi_100GeV_eta-5+5.py
deleted file mode 100644
index 06efadcb82f6bcc74b4df9779f51ffc1d0de9ef9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleChargedPi_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,50 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#for specified input file
-#jobproperties.AthenaCommonFlags.PoolHitsInput.set_Value_and_Lock(['Hits.pool.root'])
-
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-# jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-20-00-01'
-jobproperties.Global.ConditionsTag='OFLCOND-MC12-SDR-06'
-	
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.SimLayout='ATLAS-GEO-20-00-01'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleE_100GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleE_100GeV.py
deleted file mode 100755
index 16d31ec2d182b080d4f995661f9a6c1e1fd15d32..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleE_100GeV.py
+++ /dev/null
@@ -1,41 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-jobproperties.AthenaCommonFlags.EvtMax=-1
-
-jobproperties.AthenaCommonFlags.PoolRDOOutput="Dig.pool.root"
-jobproperties.AthenaCommonFlags.PoolHitsInput=["Sim.pool.root"]
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleE_50GeV.py
deleted file mode 100644
index 06efadcb82f6bcc74b4df9779f51ffc1d0de9ef9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleE_50GeV.py
+++ /dev/null
@@ -1,50 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#for specified input file
-#jobproperties.AthenaCommonFlags.PoolHitsInput.set_Value_and_Lock(['Hits.pool.root'])
-
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-# jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-20-00-01'
-jobproperties.Global.ConditionsTag='OFLCOND-MC12-SDR-06'
-	
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.SimLayout='ATLAS-GEO-20-00-01'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleE_5GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleE_5GeV.py
deleted file mode 100644
index 06efadcb82f6bcc74b4df9779f51ffc1d0de9ef9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singleE_5GeV.py
+++ /dev/null
@@ -1,50 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#for specified input file
-#jobproperties.AthenaCommonFlags.PoolHitsInput.set_Value_and_Lock(['Hits.pool.root'])
-
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-# jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-20-00-01'
-jobproperties.Global.ConditionsTag='OFLCOND-MC12-SDR-06'
-	
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.SimLayout='ATLAS-GEO-20-00-01'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singlePhot_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singlePhot_50GeV.py
deleted file mode 100644
index 06efadcb82f6bcc74b4df9779f51ffc1d0de9ef9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singlePhot_50GeV.py
+++ /dev/null
@@ -1,50 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#for specified input file
-#jobproperties.AthenaCommonFlags.PoolHitsInput.set_Value_and_Lock(['Hits.pool.root'])
-
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-# jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-20-00-01'
-jobproperties.Global.ConditionsTag='OFLCOND-MC12-SDR-06'
-	
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.SimLayout='ATLAS-GEO-20-00-01'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singlePi0_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singlePi0_100GeV_eta-5+5.py
deleted file mode 100644
index 06efadcb82f6bcc74b4df9779f51ffc1d0de9ef9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Dig_singlePi0_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,50 +0,0 @@
-# This is the configuration file to run ATLAS Digitization
- 
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#for specified input file
-#jobproperties.AthenaCommonFlags.PoolHitsInput.set_Value_and_Lock(['Hits.pool.root'])
-
-#--------------------------------------------------------------
-# Digitiziation and Pileup configuration
-#--------------------------------------------------------------
-from Digitization.DigitizationFlags import jobproperties
-# jobproperties.Digitization.doMinimumBias=True
-# jobproperties.Digitization.numberOfCollisions=2.3
-# jobproperties.Digitization.minBiasInputCols=["", "", "" ]
-# jobproperties.Digitization.doCavern=True
-# jobproperties.Digitization.cavernInputCols=["",""]
-# jobproperties.Digitization.physicsList = 'QGSP_BERT'
-
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-20-00-01'
-jobproperties.Global.ConditionsTag='OFLCOND-MC12-SDR-06'
-	
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.SimLayout='ATLAS-GEO-20-00-01'
-
-#--------------------------------------------------------------------
-# DetFlags. Use to turn on/off individual subdetector or LVL1 trigger
-#--------------------------------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-DetFlags.LVL1_setOn()
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-include("Digitization/Digitization.py")
-
-
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singleChargedPi_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singleChargedPi_100GeV_eta-5+5.py
deleted file mode 100644
index 750d7ce839c8699c0424bf243a6eb2ab110aeb27..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singleChargedPi_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,49 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=False
-doWriteTAG=False
-doWriteAOD=False
-
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-doTopoClusterCBNT=True
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-01-00'
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Pi100GeV\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singleE_100GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singleE_100GeV.py
deleted file mode 100755
index 5e3346c16b1d913987a37ae872b6b988229e7ea9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singleE_100GeV.py
+++ /dev/null
@@ -1,45 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=False
-doWriteTAG=False
-doWriteAOD=False
-
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-
-doTopoClusterCBNT=True
-EvtMax=-1
-
-PoolRDOInput= ["Dig.pool.root"]
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-01-00'
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Electrons100GeVmis\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singleE_50GeV.py
deleted file mode 100755
index 7d3570fd3ec872f3fd715a87e6f6e8ee9d992b7f..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singleE_50GeV.py
+++ /dev/null
@@ -1,46 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=False
-doWriteTAG=False
-doWriteAOD=False
-
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-
-doTopoClusterCBNT=True
-
-EvtMax=-1
-
-PoolRDOInput= ["Dig.pool.root"]
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-01-00'
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Electrons50GeVmis\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singlePhot_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singlePhot_50GeV.py
deleted file mode 100755
index d48df871903f516c41c8c7c06c83ee877653590e..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singlePhot_50GeV.py
+++ /dev/null
@@ -1,48 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=True
-doWriteTAG=False
-doWriteAOD=True
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-
-doTopoClusterCBNT=True
-
-# number of event to process
-EvtMax=-1
-PoolRDOInput= ["Dig.pool.root"]
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-01-00'
-
-EvtMax=-1
-PoolRDOInput= ["Dig.pool.root"]
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Photons50GeVmis\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singlePi0_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singlePi0_100GeV_eta-5+5.py
deleted file mode 100644
index d0e2143ee45b1622a85c1cab50978464bffb7369..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_misalign_singlePi0_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,50 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=False
-doWriteTAG=False
-doWriteAOD=False
-
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-01-00'
-
-doTopoClusterCBNT=True
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Pi100GeV\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleChargedPi_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleChargedPi_100GeV_eta-5+5.py
deleted file mode 100644
index df16f7b23fdfae35c47e3f5cca57ed5407845405..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleChargedPi_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,147 +0,0 @@
-import os
-
-print ('Hostname :')
-os.system('hostname')
-print ('CPU infos :')
-os.system('cat /proc/cpuinfo')
-print ('MEM infos :')
-os.system('cat /proc/meminfo')
-
-
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-
-# readG3 and AllAlgs needs be set before the include, since several
-# secondary flags are configured according to that one
-#
-# readG3=True # true if read g3 data
-# AllAlgs = False # if false, all algorithms are switched off by defaults 
-# doiPatRec = False
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#jobproperties.AthenaCommonFlags.PoolRDOInput.set_Value_and_Lock(['RDO.pool.root'])
-
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-
-rec.readRDO.set_Value_and_Lock(True)
-rec.doWriteESD.set_Value_and_Lock(False)
-tuple_name = "ntuple.root"
-
-rec.AutoConfiguration=['everything']
-rec.doHist.set_Value_and_Lock(False)
-rec.doCBNT.set_Value_and_Lock(False)
-rec.doWriteTAGCOM.set_Value_and_Lock(False)
-rec.doWriteTAG.set_Value_and_Lock(False)
-rec.doWriteAOD.set_Value_and_Lock(False)
-rec.doAOD.set_Value_and_Lock(False)
-rec.doMonitoring.set_Value_and_Lock(False)
-rec.readAOD.set_Value_and_Lock(False)
-
-
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-rec.doEgamma=False
-
-recAlgs.doTrackRecordFilter=False
-rec.doTrigger=False
-
-doMuid=False
-muonRecFlags.doMoore=False
-muonRecFlags.doMuonboy=False
-recAlgs.doMuGirl=False
-doMuonIdCombined=False
-doMuonIdStandalone=False
-recAlgs.doMuTag=False
-
-
-# number of event to process
-athenaCommonFlags.EvtMax.set_Value_and_Lock(1000)
-#EvtMax=2
-
-recAlgs.doMissingET=False
-
-include ("RecExCond/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-
-#jobproperties.Global.DetDescrVersion="ATLAS-CSC-01-02-00"
-#jobproperties.Global.DetDescrVersion="ATLAS-GEO-02-01-00"
-#from AthenaCommon.GlobalFlags import globalflags
-#globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-02-01-00')
-
-
-# include my own algorithm(s)
-# include my own algorithm
-# UserAlgs=[ "MyPackage/MyAlgorithm_jobOptions.py" ] 
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-# D3PDMaker calo block
-
-from D3PDMakerCoreComps.MakerAlg import *
-from CaloD3PDMaker.ClusterD3PDObject import *
-from CaloD3PDMaker.CaloCellD3PDObject import *
-from CaloD3PDMaker.CaloInfoD3PDObject import *
-
-# switch off?? LArDigit JT. 09.10.2012
-# from CaloD3PDMaker.LArDigitD3PDObject import *
-
-from EventCommonD3PDMaker.EventInfoD3PDObject import *
-
-alg = MakerAlg("caloD3PD", topSequence, file = tuple_name , D3PDSvc = 'D3PD::RootD3PDSvc')
-alg += EventInfoD3PDObject (1)
-
-# alg += AllCaloCellD3PDObject (10)
-#alg += SelCaloCellD3PDObject (Param)
-# alg += EMCellD3PDObject (10)
-# alg += HECCellD3PDObject (10)
-# alg += FCALCellD3PDObject (10)
-# alg += TileCellD3PDObject (10)
-
-alg += CaloInfoD3PDObject (1)
-
-alg += ClusterD3PDObject (2)
-
-# switch off LArDigitObj JT 09.10.2012
-#alg += LArDigitD3PDObject (2)
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-print 'BEGIN_RTTINFO = Pi100GeV'
-import os
-com="echo \"BEGIN_RTTINFO = Pi100GeV\">&MYRTTINFOS.txt"
-os.system(com)
-
-from PerfMonComps.PerfMonFlags import jobproperties
-jobproperties.PerfMonFlags.doMonitoring = True
-
-from PerfMonComps.JobOptCfg import PerfMonSvc
-svcMgr += PerfMonSvc()
-
-jobproperties.PerfMonFlags.doDetailedMonitoring = True
-
-import os
-os.system('get_files perfmon.py')
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleE_100GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleE_100GeV.py
deleted file mode 100755
index b0a77302aa471f8d98136d3132ab1aabeb03fefc..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleE_100GeV.py
+++ /dev/null
@@ -1,45 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=False
-doWriteTAG=False
-doWriteAOD=False
-
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-
-EvtMax=-1
-
-PoolRDOInput= ["Dig.pool.root"]
-doTopoClusterCBNT=True
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-00-00'
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Electrons100GeV\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleE_50GeV.py
deleted file mode 100755
index b15f24cefec439d4ebbd1e81b2f1407b42332010..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleE_50GeV.py
+++ /dev/null
@@ -1,147 +0,0 @@
-import os
-
-print ('Hostname :')
-os.system('hostname')
-print ('CPU infos :')
-os.system('cat /proc/cpuinfo')
-print ('MEM infos :')
-os.system('cat /proc/meminfo')
-
-
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-
-# readG3 and AllAlgs needs be set before the include, since several
-# secondary flags are configured according to that one
-#
-# readG3=True # true if read g3 data
-# AllAlgs = False # if false, all algorithms are switched off by defaults 
-# doiPatRec = False
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#jobproperties.AthenaCommonFlags.PoolRDOInput.set_Value_and_Lock(['RDO.pool.root'])
-
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-
-rec.readRDO.set_Value_and_Lock(True)
-rec.doWriteESD.set_Value_and_Lock(False)
-tuple_name = "ntuple.root"
-
-rec.AutoConfiguration=['everything']
-rec.doHist.set_Value_and_Lock(False)
-rec.doCBNT.set_Value_and_Lock(False)
-rec.doWriteTAGCOM.set_Value_and_Lock(False)
-rec.doWriteTAG.set_Value_and_Lock(False)
-rec.doWriteAOD.set_Value_and_Lock(False)
-rec.doAOD.set_Value_and_Lock(False)
-rec.doMonitoring.set_Value_and_Lock(False)
-rec.readAOD.set_Value_and_Lock(False)
-
-
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-rec.doEgamma=False
-
-recAlgs.doTrackRecordFilter=False
-rec.doTrigger=False
-
-doMuid=False
-muonRecFlags.doMoore=False
-muonRecFlags.doMuonboy=False
-recAlgs.doMuGirl=False
-doMuonIdCombined=False
-doMuonIdStandalone=False
-recAlgs.doMuTag=False
-
-
-# number of event to process
-athenaCommonFlags.EvtMax.set_Value_and_Lock(1000)
-#EvtMax=2
-
-recAlgs.doMissingET=False
-
-include ("RecExCond/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-
-#jobproperties.Global.DetDescrVersion="ATLAS-CSC-01-02-00"
-#jobproperties.Global.DetDescrVersion="ATLAS-GEO-02-01-00"
-#from AthenaCommon.GlobalFlags import globalflags
-#globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-02-01-00')
-
-
-# include my own algorithm(s)
-# include my own algorithm
-# UserAlgs=[ "MyPackage/MyAlgorithm_jobOptions.py" ] 
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-# D3PDMaker calo block
-
-from D3PDMakerCoreComps.MakerAlg import *
-from CaloD3PDMaker.ClusterD3PDObject import *
-from CaloD3PDMaker.CaloCellD3PDObject import *
-from CaloD3PDMaker.CaloInfoD3PDObject import *
-
-# switch off?? LArDigit JT. 09.10.2012
-# from CaloD3PDMaker.LArDigitD3PDObject import *
-
-from EventCommonD3PDMaker.EventInfoD3PDObject import *
-
-alg = MakerAlg("caloD3PD", topSequence, file = tuple_name , D3PDSvc = 'D3PD::RootD3PDSvc')
-alg += EventInfoD3PDObject (1)
-
-# alg += AllCaloCellD3PDObject (10)
-#alg += SelCaloCellD3PDObject (Param)
-# alg += EMCellD3PDObject (10)
-# alg += HECCellD3PDObject (10)
-# alg += FCALCellD3PDObject (10)
-# alg += TileCellD3PDObject (10)
-
-alg += CaloInfoD3PDObject (1)
-
-alg += ClusterD3PDObject (2)
-
-# switch off LArDigitObj JT 09.10.2012
-#alg += LArDigitD3PDObject (2)
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-print 'BEGIN_RTTINFO = Electrons50GeV'
-import os
-com="echo \"BEGIN_RTTINFO = Electrons50GeV\">&MYRTTINFOS.txt"
-os.system(com)
-
-from PerfMonComps.PerfMonFlags import jobproperties
-jobproperties.PerfMonFlags.doMonitoring = True
-
-from PerfMonComps.JobOptCfg import PerfMonSvc
-svcMgr += PerfMonSvc()
-
-jobproperties.PerfMonFlags.doDetailedMonitoring = True
-
-import os
-os.system('get_files perfmon.py')
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleE_5GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleE_5GeV.py
deleted file mode 100755
index 05bd4d63a5ceb0f64225994159e215fd07d4ce08..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singleE_5GeV.py
+++ /dev/null
@@ -1,147 +0,0 @@
-import os
-
-print ('Hostname :')
-os.system('hostname')
-print ('CPU infos :')
-os.system('cat /proc/cpuinfo')
-print ('MEM infos :')
-os.system('cat /proc/meminfo')
-
-
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-
-# readG3 and AllAlgs needs be set before the include, since several
-# secondary flags are configured according to that one
-#
-# readG3=True # true if read g3 data
-# AllAlgs = False # if false, all algorithms are switched off by defaults 
-# doiPatRec = False
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#jobproperties.AthenaCommonFlags.PoolRDOInput.set_Value_and_Lock(['RDO.pool.root'])
-
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-
-rec.readRDO.set_Value_and_Lock(True)
-rec.doWriteESD.set_Value_and_Lock(False)
-tuple_name = "ntuple.root"
-
-rec.AutoConfiguration=['everything']
-rec.doHist.set_Value_and_Lock(False)
-rec.doCBNT.set_Value_and_Lock(False)
-rec.doWriteTAGCOM.set_Value_and_Lock(False)
-rec.doWriteTAG.set_Value_and_Lock(False)
-rec.doWriteAOD.set_Value_and_Lock(False)
-rec.doAOD.set_Value_and_Lock(False)
-rec.doMonitoring.set_Value_and_Lock(False)
-rec.readAOD.set_Value_and_Lock(False)
-
-
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-rec.doEgamma=False
-
-recAlgs.doTrackRecordFilter=False
-rec.doTrigger=False
-
-doMuid=False
-muonRecFlags.doMoore=False
-muonRecFlags.doMuonboy=False
-recAlgs.doMuGirl=False
-doMuonIdCombined=False
-doMuonIdStandalone=False
-recAlgs.doMuTag=False
-
-
-# number of event to process
-athenaCommonFlags.EvtMax.set_Value_and_Lock(1000)
-#EvtMax=2
-
-recAlgs.doMissingET=False
-
-include ("RecExCond/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-
-#jobproperties.Global.DetDescrVersion="ATLAS-CSC-01-02-00"
-#jobproperties.Global.DetDescrVersion="ATLAS-GEO-02-01-00"
-#from AthenaCommon.GlobalFlags import globalflags
-#globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-02-01-00')
-
-
-# include my own algorithm(s)
-# include my own algorithm
-# UserAlgs=[ "MyPackage/MyAlgorithm_jobOptions.py" ] 
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-# D3PDMaker calo block
-
-from D3PDMakerCoreComps.MakerAlg import *
-from CaloD3PDMaker.ClusterD3PDObject import *
-from CaloD3PDMaker.CaloCellD3PDObject import *
-from CaloD3PDMaker.CaloInfoD3PDObject import *
-
-# switch off?? LArDigit JT. 09.10.2012
-# from CaloD3PDMaker.LArDigitD3PDObject import *
-
-from EventCommonD3PDMaker.EventInfoD3PDObject import *
-
-alg = MakerAlg("caloD3PD", topSequence, file = tuple_name , D3PDSvc = 'D3PD::RootD3PDSvc')
-alg += EventInfoD3PDObject (1)
-
-# alg += AllCaloCellD3PDObject (10)
-#alg += SelCaloCellD3PDObject (Param)
-# alg += EMCellD3PDObject (10)
-# alg += HECCellD3PDObject (10)
-# alg += FCALCellD3PDObject (10)
-# alg += TileCellD3PDObject (10)
-
-alg += CaloInfoD3PDObject (1)
-
-alg += ClusterD3PDObject (2)
-
-# switch off LArDigitObj JT 09.10.2012
-#alg += LArDigitD3PDObject (2)
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-print 'BEGIN_RTTINFO = Electrons5GeV'
-import os
-com="echo \"BEGIN_RTTINFO = Electrons5GeV\">&MYRTTINFOS.txt"
-os.system(com)
-
-from PerfMonComps.PerfMonFlags import jobproperties
-jobproperties.PerfMonFlags.doMonitoring = True
-
-from PerfMonComps.JobOptCfg import PerfMonSvc
-svcMgr += PerfMonSvc()
-
-jobproperties.PerfMonFlags.doDetailedMonitoring = True
-
-import os
-os.system('get_files perfmon.py')
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singlePhot_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singlePhot_50GeV.py
deleted file mode 100755
index 78e95c18dcc4dfcb3c1c63c4e9b4cf3f416e68e5..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singlePhot_50GeV.py
+++ /dev/null
@@ -1,147 +0,0 @@
-import os
-
-print ('Hostname :')
-os.system('hostname')
-print ('CPU infos :')
-os.system('cat /proc/cpuinfo')
-print ('MEM infos :')
-os.system('cat /proc/meminfo')
-
-
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-
-# readG3 and AllAlgs needs be set before the include, since several
-# secondary flags are configured according to that one
-#
-# readG3=True # true if read g3 data
-# AllAlgs = False # if false, all algorithms are switched off by defaults 
-# doiPatRec = False
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#jobproperties.AthenaCommonFlags.PoolRDOInput.set_Value_and_Lock(['RDO.pool.root'])
-
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-
-rec.readRDO.set_Value_and_Lock(True)
-rec.doWriteESD.set_Value_and_Lock(False)
-tuple_name = "ntuple.root"
-
-rec.AutoConfiguration=['everything']
-rec.doHist.set_Value_and_Lock(False)
-rec.doCBNT.set_Value_and_Lock(False)
-rec.doWriteTAGCOM.set_Value_and_Lock(False)
-rec.doWriteTAG.set_Value_and_Lock(False)
-rec.doWriteAOD.set_Value_and_Lock(False)
-rec.doAOD.set_Value_and_Lock(False)
-rec.doMonitoring.set_Value_and_Lock(False)
-rec.readAOD.set_Value_and_Lock(False)
-
-
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-rec.doEgamma=False
-
-recAlgs.doTrackRecordFilter=False
-rec.doTrigger=False
-
-doMuid=False
-muonRecFlags.doMoore=False
-muonRecFlags.doMuonboy=False
-recAlgs.doMuGirl=False
-doMuonIdCombined=False
-doMuonIdStandalone=False
-recAlgs.doMuTag=False
-
-
-# number of event to process
-athenaCommonFlags.EvtMax.set_Value_and_Lock(1000)
-#EvtMax=2
-
-recAlgs.doMissingET=False
-
-include ("RecExCond/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-
-#jobproperties.Global.DetDescrVersion="ATLAS-CSC-01-02-00"
-#jobproperties.Global.DetDescrVersion="ATLAS-GEO-02-01-00"
-#from AthenaCommon.GlobalFlags import globalflags
-#globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-02-01-00')
-
-
-# include my own algorithm(s)
-# include my own algorithm
-# UserAlgs=[ "MyPackage/MyAlgorithm_jobOptions.py" ] 
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-# D3PDMaker calo block
-
-from D3PDMakerCoreComps.MakerAlg import *
-from CaloD3PDMaker.ClusterD3PDObject import *
-from CaloD3PDMaker.CaloCellD3PDObject import *
-from CaloD3PDMaker.CaloInfoD3PDObject import *
-
-# switch off?? LArDigit JT. 09.10.2012
-# from CaloD3PDMaker.LArDigitD3PDObject import *
-
-from EventCommonD3PDMaker.EventInfoD3PDObject import *
-
-alg = MakerAlg("caloD3PD", topSequence, file = tuple_name , D3PDSvc = 'D3PD::RootD3PDSvc')
-alg += EventInfoD3PDObject (1)
-
-# alg += AllCaloCellD3PDObject (10)
-#alg += SelCaloCellD3PDObject (Param)
-# alg += EMCellD3PDObject (10)
-# alg += HECCellD3PDObject (10)
-# alg += FCALCellD3PDObject (10)
-# alg += TileCellD3PDObject (10)
-
-alg += CaloInfoD3PDObject (1)
-
-alg += ClusterD3PDObject (2)
-
-# switch off LArDigitObj JT 09.10.2012
-#alg += LArDigitD3PDObject (2)
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-print 'BEGIN_RTTINFO = Photons50GeV'
-import os
-com="echo \"BEGIN_RTTINFO = Photons50GeV\">&MYRTTINFOS.txt"
-os.system(com)
-
-from PerfMonComps.PerfMonFlags import jobproperties
-jobproperties.PerfMonFlags.doMonitoring = True
-
-from PerfMonComps.JobOptCfg import PerfMonSvc
-svcMgr += PerfMonSvc()
-
-jobproperties.PerfMonFlags.doDetailedMonitoring = True
-
-import os
-os.system('get_files perfmon.py')
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singlePi0_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singlePi0_100GeV_eta-5+5.py
deleted file mode 100644
index df16f7b23fdfae35c47e3f5cca57ed5407845405..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Rec_singlePi0_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,147 +0,0 @@
-import os
-
-print ('Hostname :')
-os.system('hostname')
-print ('CPU infos :')
-os.system('cat /proc/cpuinfo')
-print ('MEM infos :')
-os.system('cat /proc/meminfo')
-
-
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-
-# readG3 and AllAlgs needs be set before the include, since several
-# secondary flags are configured according to that one
-#
-# readG3=True # true if read g3 data
-# AllAlgs = False # if false, all algorithms are switched off by defaults 
-# doiPatRec = False
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-#for RTT test only : the input file is in the chain store or in the fallback directory
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-#jobproperties.AthenaCommonFlags.PoolRDOInput.set_Value_and_Lock(['RDO.pool.root'])
-
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-
-rec.readRDO.set_Value_and_Lock(True)
-rec.doWriteESD.set_Value_and_Lock(False)
-tuple_name = "ntuple.root"
-
-rec.AutoConfiguration=['everything']
-rec.doHist.set_Value_and_Lock(False)
-rec.doCBNT.set_Value_and_Lock(False)
-rec.doWriteTAGCOM.set_Value_and_Lock(False)
-rec.doWriteTAG.set_Value_and_Lock(False)
-rec.doWriteAOD.set_Value_and_Lock(False)
-rec.doAOD.set_Value_and_Lock(False)
-rec.doMonitoring.set_Value_and_Lock(False)
-rec.readAOD.set_Value_and_Lock(False)
-
-
-from RecExConfig.RecAlgsFlags import recAlgs
-from MuonRecExample.MuonRecFlags import muonRecFlags
-rec.doEgamma=False
-
-recAlgs.doTrackRecordFilter=False
-rec.doTrigger=False
-
-doMuid=False
-muonRecFlags.doMoore=False
-muonRecFlags.doMuonboy=False
-recAlgs.doMuGirl=False
-doMuonIdCombined=False
-doMuonIdStandalone=False
-recAlgs.doMuTag=False
-
-
-# number of event to process
-athenaCommonFlags.EvtMax.set_Value_and_Lock(1000)
-#EvtMax=2
-
-recAlgs.doMissingET=False
-
-include ("RecExCond/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-
-#jobproperties.Global.DetDescrVersion="ATLAS-CSC-01-02-00"
-#jobproperties.Global.DetDescrVersion="ATLAS-GEO-02-01-00"
-#from AthenaCommon.GlobalFlags import globalflags
-#globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-02-01-00')
-
-
-# include my own algorithm(s)
-# include my own algorithm
-# UserAlgs=[ "MyPackage/MyAlgorithm_jobOptions.py" ] 
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-# D3PDMaker calo block
-
-from D3PDMakerCoreComps.MakerAlg import *
-from CaloD3PDMaker.ClusterD3PDObject import *
-from CaloD3PDMaker.CaloCellD3PDObject import *
-from CaloD3PDMaker.CaloInfoD3PDObject import *
-
-# switch off?? LArDigit JT. 09.10.2012
-# from CaloD3PDMaker.LArDigitD3PDObject import *
-
-from EventCommonD3PDMaker.EventInfoD3PDObject import *
-
-alg = MakerAlg("caloD3PD", topSequence, file = tuple_name , D3PDSvc = 'D3PD::RootD3PDSvc')
-alg += EventInfoD3PDObject (1)
-
-# alg += AllCaloCellD3PDObject (10)
-#alg += SelCaloCellD3PDObject (Param)
-# alg += EMCellD3PDObject (10)
-# alg += HECCellD3PDObject (10)
-# alg += FCALCellD3PDObject (10)
-# alg += TileCellD3PDObject (10)
-
-alg += CaloInfoD3PDObject (1)
-
-alg += ClusterD3PDObject (2)
-
-# switch off LArDigitObj JT 09.10.2012
-#alg += LArDigitD3PDObject (2)
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-print 'BEGIN_RTTINFO = Pi100GeV'
-import os
-com="echo \"BEGIN_RTTINFO = Pi100GeV\">&MYRTTINFOS.txt"
-os.system(com)
-
-from PerfMonComps.PerfMonFlags import jobproperties
-jobproperties.PerfMonFlags.doMonitoring = True
-
-from PerfMonComps.JobOptCfg import PerfMonSvc
-svcMgr += PerfMonSvc()
-
-jobproperties.PerfMonFlags.doDetailedMonitoring = True
-
-import os
-os.system('get_files perfmon.py')
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singleChargedPi_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singleChargedPi_100GeV_eta-5+5.py
deleted file mode 100644
index c703728fb10a29301c18a162e78a74dea8646072..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singleChargedPi_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,73 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOn()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-01-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 211',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -5.0 5.0',
-             'phi: flat  0 6.28318',
-             'e: constant 100000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singleE_100GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singleE_100GeV.py
deleted file mode 100755
index f9265d4d35ef716d2a255872d081c775de755c8e..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singleE_100GeV.py
+++ /dev/null
@@ -1,70 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolHitsOutput='Sim.pool.root'
-athenaCommonFlags.EvtMax =200
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-01-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 11',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 100000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singleE_50GeV.py
deleted file mode 100755
index 33025d66fa8514b7b7340fa9f242694149658633..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singleE_50GeV.py
+++ /dev/null
@@ -1,70 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolHitsOutput='Sim.pool.root'
-athenaCommonFlags.EvtMax =200
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-01-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 11',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 50000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singlePhot_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singlePhot_50GeV.py
deleted file mode 100755
index 4a9398c85274c052bf935ec3424a4b7a7dada6db..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singlePhot_50GeV.py
+++ /dev/null
@@ -1,69 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolHitsOutput='Sim.pool.root'
-athenaCommonFlags.EvtMax =200
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-01-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 22',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 50000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singlePi0_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singlePi0_100GeV_eta-5+5.py
deleted file mode 100644
index f57a95021efa88698b5d87d417e539adb2e5fc38..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_misalign_singlePi0_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,69 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOn()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-01-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 111',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -5.0 5.0',
-             'phi: flat  0 6.28318',
-             'e: constant 100000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleChargedPi_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleChargedPi_100GeV_eta-5+5.py
deleted file mode 100644
index bc107232916233cc5142812980dd86a0542d4c91..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleChargedPi_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,79 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOn()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-#mc11
-#globalflags.ConditionsTag = 'OFLCOND-SDR-BS7T-05-07'
-#mc12
-globalflags.ConditionsTag = 'OFLCOND-MC12-SDR-06'
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-16-00-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 211',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -5.0 5.0',
-             'phi: flat  0 6.28318',
-             'e: constant 100000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleE_100GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleE_100GeV.py
deleted file mode 100755
index d46b5247c233e914b43589516923577db7e1d5a1..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleE_100GeV.py
+++ /dev/null
@@ -1,74 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolHitsOutput='Sim.pool.root'
-athenaCommonFlags.EvtMax =200
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-00-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 11',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 100000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleE_50GeV.py
deleted file mode 100755
index 21f7ba66926a32e85cc1fe2d5b3a2e20593b2c57..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleE_50GeV.py
+++ /dev/null
@@ -1,79 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-#mc11
-#globalflags.ConditionsTag = 'OFLCOND-SDR-BS7T-05-07'
-#mc12
-globalflags.ConditionsTag = 'OFLCOND-MC12-SDR-06'
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-16-00-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 11',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 50000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleE_5GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleE_5GeV.py
deleted file mode 100755
index 01d085f35b9f6ada150f2f0c13407d9ffe78b6ea..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singleE_5GeV.py
+++ /dev/null
@@ -1,79 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-#mc11
-#globalflags.ConditionsTag = 'OFLCOND-SDR-BS7T-05-07'
-#mc12
-globalflags.ConditionsTag = 'OFLCOND-MC12-SDR-06'
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-16-00-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 11',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 5000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singlePhot_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singlePhot_50GeV.py
deleted file mode 100755
index c937d3dddf482fb74c52be52a45212c332f341aa..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singlePhot_50GeV.py
+++ /dev/null
@@ -1,79 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-#mc11
-#globalflags.ConditionsTag = 'OFLCOND-SDR-BS7T-05-07'
-#mc12
-globalflags.ConditionsTag = 'OFLCOND-MC12-SDR-06'
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-16-00-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 22',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 50000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singlePi0_100GeV_eta-5+5.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singlePi0_100GeV_eta-5+5.py
deleted file mode 100644
index 58f868a982e7c7c5d0cf303f650d1ffb54e9d39a..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_FullChain_Sim_singlePi0_100GeV_eta-5+5.py
+++ /dev/null
@@ -1,79 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOn()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-#mc11
-#globalflags.ConditionsTag = 'OFLCOND-SDR-BS7T-05-07'
-#mc12
-globalflags.ConditionsTag = 'OFLCOND-MC12-SDR-06'
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolHitsInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-16-00-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 111',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -5.0 5.0',
-             'phi: flat  0 6.28318',
-             'e: constant 100000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_misalign_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_misalign_singleE_50GeV.py
deleted file mode 100755
index 811ee67d63bcd586ae5c1fb075dbe9534258e3b3..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_misalign_singleE_50GeV.py
+++ /dev/null
@@ -1,50 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=False
-doWriteTAG=False
-doWriteAOD=False
-
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-
-doTopoClusterCBNT=True
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-01-00'
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Electrons50GeVmis\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_misalign_singlePhot_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_misalign_singlePhot_50GeV.py
deleted file mode 100755
index d8db5092a31af850c3576355db2ffaa963bfc5f4..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_misalign_singlePhot_50GeV.py
+++ /dev/null
@@ -1,44 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=True
-doWriteTAG=False
-doWriteAOD=True
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-
-doTopoClusterCBNT=True
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-01-00'
-
-EvtMax=-1
-PoolRDOInput= ["Dig.pool.root"]
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Photons50GeVmis\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_singleE_50GeV.py
deleted file mode 100755
index 42029a4038d0b981e509de97466998d5702fa0a5..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_singleE_50GeV.py
+++ /dev/null
@@ -1,51 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=False
-doWriteTAG=False
-doWriteAOD=False
-
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-CBNTAthenaAware=True
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-
-doTopoClusterCBNT=True
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-00-00'
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Electrons50GeV\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_singleE_5GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_singleE_5GeV.py
deleted file mode 100755
index e4b7d06a27d65f3a4cf7bb4130c6e7f166910950..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Rec_singleE_5GeV.py
+++ /dev/null
@@ -1,50 +0,0 @@
-#example of personal topOptions
-#
-# to use it  
-# athena >! athena.log
-#  ( myTopOptions.py is defaulted through jobOptions.py soft link)
-# 
-# see RecExCommon/RecExCommon_flags.py for more available flags
-#
-from RecExConfig.RecFlags import rec
-rec.doEgamma=False
-
-doWriteESD=False
-doWriteTAG=False
-doWriteAOD=False
-
-doTrackRecordFilter=False
-doTrigger=False
-doAOD=False
-doAODLVL1=False
-
-#--------------------------------------------------------------
-# AthenaCommon configuration
-#--------------------------------------------------------------
-from AthenaCommon.AthenaCommonFlags import jobproperties
-#for RTT test only : the input file is in the chain store or in the fallback directory 
-jobproperties.AthenaCommonFlags.PoolRDOInput=jobproperties.AthenaCommonFlags.FilesInput.get_Value()
-
-
-doTopoClusterCBNT=True
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-# Flags that are defined in python are best set here
-# switch off ID and muons
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-from AthenaCommon.GlobalFlags import jobproperties
-jobproperties.Global.DetDescrVersion='ATLAS-GEO-06-00-00'
-
-# main jobOption
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-#print memory usage for all events (in case of memory leak crash)
-#CBNT_Audit.nEventPrintMem=999999
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-import os
-com="echo \"BEGIN_RTTINFO = Electrons5GeV\">&MYRTTINFOS.txt"
-os.system(com)
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_misalign_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_misalign_singleE_50GeV.py
deleted file mode 100755
index e67e45862cbcbe5e3ca73ef2dd60260b2698b6b5..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_misalign_singleE_50GeV.py
+++ /dev/null
@@ -1,70 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-01-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 11',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 50000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_misalign_singlePhot_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_misalign_singlePhot_50GeV.py
deleted file mode 100755
index a83a22714ad6826fc64f6768b59d718d9560a6d1..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_misalign_singlePhot_50GeV.py
+++ /dev/null
@@ -1,68 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-01-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 22',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 50000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_singleE_50GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_singleE_50GeV.py
deleted file mode 100755
index 63b98c35a12c9e20aa4160dbb8a43ab3d10552c8..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_singleE_50GeV.py
+++ /dev/null
@@ -1,69 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-00-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 11',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 50000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_singleE_5GeV.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_singleE_5GeV.py
deleted file mode 100755
index 44c5bb7cbd3a9c18fec958f408b349c137bacd99..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_RTT_Sim_singleE_5GeV.py
+++ /dev/null
@@ -1,73 +0,0 @@
-#==============================================================
-#
-# Job options file for Geant4 Simulations
-#
-# Atlas simulation 
-#
-#==============================================================
-
-## Algorithm sequence
-from AthenaCommon.AlgSequence import AlgSequence
-topSeq = AlgSequence()
-
-#--- Detector flags -------------------------------------------
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.Calo_setOn()
-DetFlags.Muon_setOff()
-DetFlags.Truth_setOn()
-
-#---- Global conditions tag -----------------------------------
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.ConditionsTag = 'OFLCOND-SIM-BS7T-00'
-
-#--- AthenaCommon flags -----------------------------------------
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-athenaCommonFlags.PoolEvgenInput.set_Off()
-
-#--- Simulation -----------------------------------------
-from G4AtlasApps.SimFlags import SimFlags
-#bugs 73445 Comment #10
-SimFlags.load_atlas_flags()
-#SimFlags.SimLayout='ATLAS-GEO-06-00-00'
-
-SimFlags.EventFilter.set_On()
-
-# - uses single particle generator
-import AthenaCommon.AtlasUnixGeneratorJob
-spgorders = ['pdgcode: constant 11',
-             'vertX: constant 0.0',
-             'vertY: constant 0.0',
-             'vertZ: constant 0.0',
-             't: constant 0.0',
-             'eta: flat -3.0 3.0',
-             'phi: flat  0 6.28318',
-             'e: constant 5000']
-from ParticleGenerator.ParticleGeneratorConf import ParticleGenerator
-topSeq += ParticleGenerator()
-topSeq.ParticleGenerator.orders = sorted(spgorders)
-from AthenaServices.AthenaServicesConf import AtRanluxGenSvc
-ServiceMgr += AtRanluxGenSvc()
-ServiceMgr.AtRanluxGenSvc.Seeds = ["SINGLE 2040160768 443921183"]
-
-#---  Output printout level ----------------------------------- 
-#output threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL)
-#you can override this for individual modules if necessary
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel = 3
-
-
-#######################################################################
-
-include("G4AtlasApps/G4Atlas.flat.configuration.py")
-
-## Populate alg sequence
-from AthenaCommon.CfgGetter import getAlgorithm
-topSeq += getAlgorithm("G4AtlasAlg",tryDefaultConfigurable=True)
-
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-
-
-
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_SimCTB.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_SimCTB.py
deleted file mode 100644
index 1bdfc2b45b658d775fb9da2b03789f65c6fb7d4f..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_SimCTB.py
+++ /dev/null
@@ -1,2 +0,0 @@
-include("CaloSimEx/CaloSimCTB.py")
-#include("CaloSimCTB.py")
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_Truth.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_Truth.py
deleted file mode 100644
index ad2577b3c5f5fe10c0a677d003e81731aeeecadd..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_Truth.py
+++ /dev/null
@@ -1,700 +0,0 @@
-#!/usr/bin/python
-
-import os,commands,sys,logging
-import ROOT
-import time,math,cmath
-
-class CaloTests_Truth:
-    def __init__(self,log,logLevel):
-        if log=='':
-            self.logger = logging.getLogger('CaloTests_Truth')
-            hdlr = logging.FileHandler('CaloTests_Truth.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-            
-    def getFilePar(self):
-        com="grep RTTINFO MYRTTINFOS.txt | cut -d= -f2 | tail -n1"
-        res,testName=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(testName)
-            return -1
-        
-        nTestName=''
-        for i in testName:
-            if i !=' ':
-                nTestName+=i;
-
-        filePar=nTestName+".par";
-        com="wget http://cern.ch/CaloRTT/"+filePar
-        res,out=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(out)
-            return -1
-        return filePar
-
-    def initHTML(self):
-        f=open("CaloTests_Truth.html","w")
-        f.write("<html><head><title>Truth</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head>")
-        f.write("<body>")
-        f.close()
-
-
-        f=open("CaloTests_Truth.txt","w")
-        f.close()
-        
-    def closeHTML(self):
-        f=open("CaloTests_Truth.html","a")
-        f.write("</body>")
-        f.write("</html>")
-
-    def mysign(self,val):
-        if val<0.:
-            return -1
-        else:
-            return 1
-
-    def saveHisto(self,hist,filePar,opt):
-        html= open('CaloTests_Truth.html','a')
-
-        txt= open("CaloTests_Truth.txt","a");
-
-        tmp=hist.GetTitle()
-        name=""
-        for i in tmp:
-            if i==' ':
-                i='_'
-            if i=='(':
-                i='z'
-            if i==')':
-                i='z'
-            name+=i
-
-        com='grep RTTParm_truth_'+name+ ' '+filePar +' | cut -d= -f2 | tail -n1'
-
-        res,max=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error('Problem to the par of '+name+' : '+max)
-            return -1
-
-        can=ROOT.TCanvas()
-        # only 3 digits
-        ROOT.TGaxis.SetMaxDigits(3)
-        
-        hist.SetLineColor(2)
-        hist.SetLineStyle(2)
-        hist.Draw(opt)
-
-        txt.write("################################\n");
-        txt.write("Name : "+str(hist.GetTitle())+'\n')
-        txt.write("Mean = "+str(hist.GetMean())+'\n')
-        txt.write("RMS = "+str(hist.GetRMS())+'\n')
-
-        try:
-            float(max)
-        except:
-            max=0
-
-        isOk=0
-        if math.fabs(float(hist.GetMean())) > float(max):
-            isOk=-1
-            txt.write("TEST FAILED (lim = "+str(max)+')\n')
-        else:
-            txt.write("TEST OK (lim = "+str(max)+')\n')
-
-        can.Modified()
-        can.Update()
-
-        epsname=name+".eps"
-        gifname=name+".gif"
-
-        can.SaveAs(epsname)
-
-        com1='pstopnm -ppm -xborder 0 -yborder 0 -portrait '+epsname
-        com2='ppmtogif '+epsname+'001.ppm >'+gifname
-        
-        os.system(com1)
-        os.system(com2)
-        
-        html.write("<CENTER><BR>")
-        html.write("<BR>")
-        html.write("<IMG SRC=\""+gifname+'\"><BR>');
-        html.write("<HR>")
-
-        if isOk == -1 :
-            html.write("<BR>")
-            html.write("<CENTER><font color=red>TEST FAILED (lim = "+str(max)+")</font></CENTER>")
-        else:
-            html.write("<BR>")
-            html.write("<CENTER><font color=green>TEST OK (lim = "+str(max)+")</font></CENTER>")
-            html.write("<BR>")
-        html.write("<HR>")
-        
-        html.close()
-        txt.close()
-
-        return isOk
-
-    def doElectrons(self,filePar):
-        self.initHTML()
-        
-        #f = ROOT.TFile('ntuple.root')
-        #f.cd('CollectionTree')
-        #mytree=ROOT.gDirectory.Get('CollectionTree')
-
-        ##################################
-        #os.system('ls data/*root.* > ntuples.txt')
-        os.system('ls ntuple.root > ntuples.txt')
-        
-        f=open('ntuples.txt','r')
-        lines=f.readlines()
-        f.close()
-
-        chain = ROOT.TChain('CollectionTree')
-
-        for li in lines:
-            chain.Add('./'+li.strip())
-
-        mytree=chain
-        #################################
-
-        m_drmin  = ROOT.TH1F("m_drmin","drmin",100,-0.2,0.2)
-        m_h1   = ROOT.TH1F("m_h1","Energy resolution",100,-0.25,0.25)
-        m_h1.SetXTitle("(E_{t}(reco)-E_{t}(true))/E_{t}(true)")
-
-        m_h2   = ROOT.TH1F("m_h2","Phi resolution",100,-0.01,0.01)
-        m_h2.SetXTitle("#Phi resolution (rad)")
-
-        m_h3   = ROOT.TH1F("m_h3","Eta resolution in the barrel",100,-0.01,0.01)
-        m_h3.SetXTitle("#eta resolution")
-        
-        m_h4   = ROOT.TH1F("m_h4","Eta resolution in the endcap",100,-0.01,0.01)
-        m_h4.SetXTitle("#eta resolution")
-
-        m_h5   = ROOT.TH1F("m_h5","Efficiency vs eta",50,-3,3)  
-        m_h5.SetXTitle("#eta")
-
-        m_tmp1   = ROOT.TH1F("m_tmp1","EtaGen",50,-3,3)
-        m_tmp2  = ROOT.TH1F("m_tmp2","cl_eta",50,-3,3) 
-
-        entries=mytree.GetEntriesFast()
-
-        for jentry in xrange( entries ):
-            ientry=mytree.LoadTree( jentry )
-            if ientry < 0 :
-                break
-
-            nb=mytree.GetEntry(jentry)
-            if nb<=0:
-                continue
-            
-            nEvent = int(mytree.IEvent)
-            if nEvent<0:
-                continue
-
-            indEle=[]
-            iele=0
-            for ipart in range(0,mytree.NPar):
-                if abs((mytree.Type)[ipart])==11 and (mytree.GenStat)[ipart]==1 and (mytree.KMothNt)[ipart]==-1:
-                    indEle.append(ipart)
-                    m_tmp2.Fill((mytree.EtaGen)[indEle[iele]])
-
-                    iele+=1
-
-                    if iele>1:
-                        logger.info('two many electrons')
-                        return -1
-
-            nele=iele
-
-            # a quel cluster correspond quel electron ?
-            # je tourne sur ts les clusters de l ev
-            for ic in range(0,mytree.cl_nc): 
-                etacl = (mytree.cl_eta)[ic]
-                phicl = (mytree.cl_phi)[ic]
-                etcl  = (mytree.cl_et)[ic]
-
-                m_drmin.Fill((mytree.ZV)[0]);
-                etae = (mytree.EtaGen)[indEle[0]];
-                if math.fabs((mytree.cl_eta)[ic])>1.475 :
-                    etaclcor = cmath.asinh(cmath.sinh((mytree.cl_eta)[ic])*(1-(mytree.ZV)[mytree.IVPrimary]/(self.mysign((mytree.cl_eta)[ic])*3800.0)))
-                    phiclcor = (mytree.cl_phi)[ic]+(0.3*3800.0*(-(mytree.Type)[indEle[0]]/11.0)*self.mysign((mytree.cl_eta)[ic]))/((mytree.cl_et)[ic]*cmath.sinh((mytree.cl_eta)[ic]))
-                    m_h4.Fill((etaclcor-etae).real)
-                else:
-                    etaclcor = cmath.asinh(cmath.sinh((mytree.cl_eta)[ic])-(mytree.ZV)[mytree.IVPrimary]/1600.0)
-                    m_h3.Fill((etaclcor-etae).real)
-                    phiclcor = (mytree.cl_phi)[ic]+(0.3*1600.0*(-(mytree.Type)[indEle[0]]/11.0)/(mytree.cl_et)[ic])
-
-                phie = (mytree.PhiGen)[indEle[0]]
-                ete  = (mytree.PtGen)[indEle[0]]
-                
-                try:
-                    m_h2.Fill(phiclcor.real-phie)
-                except:
-                    m_h2.Fill(phiclcor-phie)
-                m_h1.Fill((etcl-ete)/ete)
-
-                m_tmp1.Fill(etae)
-
-        ROOT.gStyle.SetOptFit(1011)
-
-        m_h1.Fit("gaus")
-        m_h2.Fit("gaus")
-        m_h3.Fit("gaus")
-        m_h4.Fit("gaus")
-    		    
-        res1=self.saveHisto(m_h1,filePar,'')
-        res2=self.saveHisto(m_h2,filePar,'')
-        res3=self.saveHisto(m_h3,filePar,'')
-        res4=self.saveHisto(m_h4,filePar,'')
-        m_h5.Divide(m_tmp1,m_tmp2,1,1,"B")
-        
-	res5=self.saveHisto(m_h5,filePar,"E")
-
-        if res1==-1 or res2==-1 or res3==-1 or res4==-1 or res5==-1: 
-            return -1
-        else:
-            return 0
-            
-    def doTop(self,filePar):
-        self.initHTML()
-        
-        f = ROOT.TFile('ntuple.root')
-        #f.cd('CollectionTree')
-        mytree=ROOT.gDirectory.Get('CollectionTree')
-
-        m_drmin  = ROOT.TH1F("m_drmin","drmin",100,-0.2,0.2)
-        m_h1   = ROOT.TH1F("m_h1","Energy resolution",100,-0.25,0.25)
-        m_h1.SetXTitle("(E_{t}(reco)-E_{t}(true))/E_{t}(true)")
-
-        m_h2   = ROOT.TH1F("m_h2","Phi resolution",100,-0.01,0.01)
-        m_h2.SetXTitle("#Phi resolution (rad)")
-
-        m_h3   = ROOT.TH1F("m_h3","Eta resolution in the barrel",100,-0.01,0.01)
-        m_h3.SetXTitle("#eta resolution")
-        
-        m_h4   = ROOT.TH1F("m_h4","Eta resolution in the endcap",100,-0.01,0.01)
-        m_h4.SetXTitle("#eta resolution")
-
-        m_h5   = ROOT.TH1F("m_h5","Efficiency vs eta",50,-3,3)  
-        m_h5.SetXTitle("#eta")
-
-        m_tmp1   = ROOT.TH1F("m_tmp1","EtaGen",50,-3,3)
-        m_tmp2  = ROOT.TH1F("m_tmp2","cl_eta",50,-3,3) 
-
-        entries=mytree.GetEntriesFast()
-
-        for jentry in xrange( entries ):
-            ientry=mytree.LoadTree( jentry )
-            if ientry < 0 :
-                break
-
-            nb=mytree.GetEntry(jentry)
-            if nb<=0:
-                continue
-            
-            nEvent = int(mytree.IEvent)
-            if nEvent<0:
-                continue
-
-            indEle=[]
-            iele=0
-            for ipart in range(0,mytree.NPar):
-                if  abs((mytree.Type)[ipart])==11 and abs((mytree.Type)[(mytree.KMothNt)[ipart]])==24 :
-			#indEle[iele]=ipart
-                        indEle.append(ipart)
-			m_tmp2.Fill((mytree.EtaGen)[indEle[iele]])
-			iele=+1
-                        if iele>4:
-                            logger.info('two many electrons')
-                            return -1
-
-            nele=iele
-
-            # a quel cluster correspond quel electron ?
-            # je tourne sur ts les clusters de l ev
-            for ic in range(0,mytree.cl_nc): 
-                drmin = 9999.
-                im    = 0
-
-                # pour un cluster donne je tourne sur tous les electrons primaires trouves precedemment et je minimise dr pour savoir celui qui est le plus pres du cluster 
-                for iele in range(0,nele):
-                    deta = (mytree.EtaGen)[indEle[iele]] - (mytree.cl_eta)[ic];
-                    dphi = (mytree.PhiGen)[indEle[iele]] - (mytree.cl_phi)[ic];
-                    
-                    if dphi > math.pi: 
-                        dphi = math.fabs(dphi) - 2.*math.pi
-                    dr = math.sqrt(dphi*dphi + deta*deta)
-
-                    if dr < drmin:
-                        drmin = dr
-                        im    = iele
-
-                # l'electron matchant le cluster a l'indice im
-
-                m_drmin.Fill(drmin);
-
-                if drmin < 0.1  : 
-                    etacl = (mytree.cl_eta)[ic]
-                    phicl = (mytree.cl_phi)[ic]
-                    etcl  = (mytree.cl_et)[ic]
-                    etae = (mytree.EtaGen)[indEle[im]]
-                    if math.fabs((mytree.cl_eta)[ic])>1.475 :
-                        etaclcor = cmath.asinh(cmath.sinh((mytree.cl_eta)[ic])*(1-(mytree.ZV)[mytree.IVPrimary]/(self.mysign((mytree.cl_eta)[ic])*3800.0)));
-                        phiclcor = (mytree.cl_phi)[ic]+(0.3*3800*(-(mytree.Type)[indEle[im]]/11.0)*self.mysign((mytree.cl_eta)[ic]))/((mytree.cl_et)[ic]*cmath.sinh((mytree.cl_eta)[ic]));
-                        m_h4.Fill((etaclcor-etae).real)
-                    else:
-                        etaclcor = cmath.asinh(cmath.sinh((mytree.cl_eta)[ic])-(mytree.ZV)[mytree.IVPrimary]/1600.0)
-                        phiclcor = (mytree.cl_phi)[ic]+(0.3*1600.0*(-(mytree.Type)[indEle[im]]/11.0)/(mytree.cl_et)[ic])
-                        m_h3.Fill((etaclcor-etae).real)
-
-                    phie = (mytree.PhiGen)[indEle[im]]
-                    ete  = (mytree.PtGen)[indEle[im]]
-
-                    try:
-                        m_h2.Fill(phiclcor.real-phie)
-                    except:
-                        m_h2.Fill(phiclcor-phie)
-                    m_h1.Fill((etcl-ete)/ete)	 
-                    m_tmp1.Fill(etae)
-
-
-        ROOT.gStyle.SetOptFit(1011)
-
-        m_h1.Fit("gaus")
-        m_h2.Fit("gaus")
-        m_h3.Fit("gaus")
-        m_h4.Fit("gaus")
-    		    
-        res1=self.saveHisto(m_h1,filePar,'')
-        res2=self.saveHisto(m_h2,filePar,'')
-        res3=self.saveHisto(m_h3,filePar,'')
-        res4=self.saveHisto(m_h4,filePar,'')
-        m_h5.Divide(m_tmp1,m_tmp2,1,1,"B")
-        
-	res5=self.saveHisto(m_h5,filePar,"E")
-
-        if res1==-1 or res2==-1 or res3==-1 or res4==-1 or res5==-1: 
-            return -1
-        else:
-            return 0
-    
-    def doPhotons(self,filePar):
-        self.initHTML()
-        
-        #f = ROOT.TFile('ntuple.root')
-        #f.cd('CollectionTree')
-        #mytree=ROOT.gDirectory.Get('CollectionTree')
-
-        ##################################
-        #os.system('ls photons/*root* > ntuples.txt')
-        os.system('ls ntuple.root > ntuples.txt')
-        f=open('ntuples.txt','r')
-        lines=f.readlines()
-        f.close()
-
-        chain = ROOT.TChain('CollectionTree')
-
-        for li in lines:
-            chain.Add('./'+li.strip())
-
-        mytree=chain
-        #################################
-
-        m_drmin  = ROOT.TH1F("m_drmin","drmin",100,-0.2,0.2)
-        m_h1   = ROOT.TH1F("m_h1","Energy resolution",100,-0.25,0.25)
-        m_h1.SetXTitle("(E_{t}(reco)-E_{t}(true))/E_{t}(true)")
-
-        m_h2   = ROOT.TH1F("m_h2","Phi resolution",100,-0.01,0.01)
-        m_h2.SetXTitle("#Phi resolution (rad)")
-
-        m_h3   = ROOT.TH1F("m_h3","Eta resolution in the barrel",100,-0.01,0.01)
-        m_h3.SetXTitle("#eta resolution")
-        
-        m_h4   = ROOT.TH1F("m_h4","Eta resolution in the endcap",100,-0.01,0.01)
-        m_h4.SetXTitle("#eta resolution")
-
-        m_h5   = ROOT.TH1F("m_h5","Efficiency vs eta",50,-3,3)  
-        m_h5.SetXTitle("#eta")
-
-        m_tmp1   = ROOT.TH1F("m_tmp1","EtaGen",50,-3,3)
-        m_tmp2  = ROOT.TH1F("m_tmp2","cl_eta",50,-3,3) 
-
-        entries=mytree.GetEntriesFast()
-
-        for jentry in xrange( entries ):
-            ientry=mytree.LoadTree( jentry )
-            if ientry < 0 :
-                break
-            nb=mytree.GetEntry(jentry)
-            if nb<=0:
-                continue          
-            nEvent = int(mytree.IEvent)
-            if nEvent<0:
-                continue
-            dRmin = 999.
-            TheNearestCluster = -1
-
-            #print int(mytree.IEvent),int(mytree.cl_nc),len(mytree.PtGen)
-            if mytree.cl_nc==0 or len(mytree.PtGen)==0:
-                continue
-            for i in range(0,int(mytree.cl_nc)):
-                #print 'i=',i
-                dphi = 1000.
-                deta = 1000.
-	       
-                # resolution in energy
-                val=((mytree.cl_et)[i]-(mytree.PtGen)[0])/(mytree.PtGen)[0]
-                
-                m_h1.Fill(val)        
-                # resolution in phi
-                if  (mytree.cl_phi)[i]-(mytree.PhiGen)[0] < 6: 
-                    dphi =((mytree.cl_phi)[i]-(mytree.PhiGen)[0])
-                    m_h2.Fill(dphi)
-
-                # resolution in eta barrel corrected by the z vertex spread
-                deta=0.
-                if  math.fabs((mytree.EtaGen)[0])<1.475:
-                    deta =(mytree.cl_eta)[i]-cmath.asinh(cmath.sinh((mytree.EtaGen)[0])+(mytree.ZV)[mytree.IVPrimary]/1600.)
-                    m_h3.Fill(deta.real)
-                elif math.fabs((mytree.EtaGen)[0])>= 1.475 :
-                    deta = (mytree.cl_eta)[i]-cmath.asinh(cmath.sinh((mytree.EtaGen)[0])/(1-self.mysign((mytree.EtaGen)[0])*(mytree.ZV)[mytree.IVPrimary]/3800.))
-                    
-                    m_h4.Fill(deta.real)
-		
-                if (math.fabs(dphi) > math.pi):
-                    dphi = 2.0*math.pi - math.fabs(dphi)
-                dR = math.sqrt(deta.real*deta.real+dphi*dphi)
-                if dR < dRmin:
-                    dRmin = dR
-                    TheNearestCluster = i
-	      
-	    
-            m_tmp2.Fill((mytree.EtaGen)[0])
-            if TheNearestCluster >= 0 and dRmin < 0.1:
-                m_tmp1.Fill((mytree.EtaGen)[0])
-
-        ROOT.gStyle.SetOptFit(1011)
-
-        m_h1.Fit("gaus")
-        m_h2.Fit("gaus")
-        m_h3.Fit("gaus")
-        m_h4.Fit("gaus")
-    		    
-        res1=self.saveHisto(m_h1,filePar,'')
-        res2=self.saveHisto(m_h2,filePar,'')
-        res3=self.saveHisto(m_h3,filePar,'')
-        res4=self.saveHisto(m_h4,filePar,'')
-        m_h5.Divide(m_tmp1,m_tmp2,1,1,"B")
-        
-	res5=self.saveHisto(m_h5,filePar,"E")
-
-        if res1==-1 or res2==-1 or res3==-1 or res4==-1 or res5==-1: 
-            return -1
-        else:
-            return 0
-
-    def doPions(self,filePar):
-        self.initHTML()
-        
-        #f = ROOT.TFile('ntuple.root')
-        #f.cd('CollectionTree')
-        #mytree=ROOT.gDirectory.Get('CollectionTree')
-
-        ##################################
-        #os.system('ls pions/*root* > ntuples.txt')
-        os.system('ls ntuple.root > ntuples.txt')
-        f=open('ntuples.txt','r')
-        lines=f.readlines()
-        f.close()
-
-        chain = ROOT.TChain('CollectionTree')
-
-        for li in lines:
-            chain.Add('./'+li.strip())
-
-        mytree=chain
-        #################################
-
-        m_drmin  = ROOT.TH1F("m_drmin","drmin",100,-0.2,0.2)
-        m_h1   = ROOT.TH1F("m_h1","Energy resolution",100,-0.5,0.5)
-        m_h1.SetXTitle("(p_{t}(reco)-p_{t}(true))/p_{t}(true)")
-
-        m_h2   = ROOT.TH1F("m_h2","Phi resolution",100,-0.08,0.08)
-        m_h2.SetXTitle("#Phi resolution (rad)")
-
-        m_h3   = ROOT.TH1F("m_h3","Eta resolution in the barrel",100,-0.1,0.1)
-        m_h3.SetXTitle("#eta resolution")
-        
-        m_h4   = ROOT.TH1F("m_h4","Eta resolution in the endcap",100,-0.1,0.1)
-        m_h4.SetXTitle("#eta resolution")
-
-        m_h5   = ROOT.TH1F("m_h5","Efficiency vs eta",50,-3,3)  
-        m_h5.SetXTitle("#eta")
-
-        m_tmp1   = ROOT.TH1F("m_tmp1","EtaGen",50,-3,3)
-        m_tmp2  = ROOT.TH1F("m_tmp2","cl_eta",50,-3,3) 
-
-        entries=mytree.GetEntriesFast()
-
-        for jentry in xrange( entries ):
-            ientry=mytree.LoadTree( jentry )
-            if ientry < 0 :
-                break
-
-            nb=mytree.GetEntry(jentry)
-            if nb<=0:
-                continue
-            
-            nEvent = int(mytree.IEvent)
-            if nEvent<0:
-                continue
-
-#            print 'nevent=',nEvent
-
-            indPi=[]
-            ipi=0
-
-#            print ' mytree.NPar=',mytree.NPar
-
-            for ipart in range(0,mytree.NPar):
-                if  (mytree.KMothNt)[ipart]<0 and (abs((mytree.Type)[ipart])==111 or abs((mytree.Type)[ipart])==211) :
-#                    print ' mother=',(mytree.KMothNt)[ipart]
-#                    print ' (mytree.Type)[ipart]=',(mytree.Type)[ipart]
-                    indPi.append(ipart)
-                    m_tmp2.Fill((mytree.EtaGen)[indPi[ipi]])
-                    ipi=ipi+1
-                    if ipi>4:
-                        logger.info('two many pions')
-                        return -1
-
-#            print 'ipi=',ipi
-
-            if ipi>0:
-#                print ' pion type=', abs((mytree.Type)[indPi[0]])
-#                print ' # of ConeH1TowerJets=', mytree.Cone7H1TowerJetsjetNum
-#                print ' # of ConeH1TopoJets=', mytree.Cone7H1TopoJetsjetNum
-                if abs((mytree.Type)[indPi[0]])==111:
-                    ncl=0
-#                    print ' mytree.cl_nc=',mytree.cl_nc
-                    for ic in range(0,mytree.cl_nc): 
-                        etacl = (mytree.cl_eta)[ic]
-                        phicl = (mytree.cl_phi)[ic]
-                        etcl  = (mytree.cl_et)[ic]
-                        ncl = ncl +1
-#                        print ' cluster etcl,etacl,phicl=',etcl,etacl,phicl
-#                        print ' gen et,etacl,phicl=',(mytree.PtGen)[0],(mytree.EtaGen)[0],(mytree.PhiGen)[0]
-                        
-                        etae = (mytree.EtaGen)[indPi[0]]
-                        if math.fabs((mytree.cl_eta)[ic])>1.475 :
-                            m_h4.Fill(etacl-etae)                   
-                        else:
-                            m_h3.Fill(etacl-etae)
-                        
-                        phie = (mytree.PhiGen)[indPi[0]]
-                        ete  = (mytree.PtGen)[indPi[0]]
-
-                        try:
-                            m_h2.Fill(phicl.real-phie)
-                        except:
-                            m_h2.Fill(phicl-phie)
-
-                        m_h1.Fill((etcl-ete)/ete)	 
-                        m_tmp1.Fill(etae)
- 
-#                        print ' nclusters=',ncl
-
-                if abs((mytree.Type)[indPi[0]])==211 and mytree.Cone7H1TowerJetsjetNum>0 :
-#                if abs((mytree.Type)[indPi[0]])==211 and mytree.Cone7H1TopoJetsjetNum>0 :
-
-#                    print ' number of jets =', mytree.Cone7H1TopoJetsjetNum
-#                    print ' jet and topo gen e =',(mytree.jetEtCone7H1TopoJets)[0],(mytree.PtGen)[indPi[0]]
-#                    print ' jet and gen eta=',(mytree.jetEtaCone7H1TopoJets)[0],(mytree.EtaGen)[0]
-#                    print ' jet and gen phi=',(mytree.jetPhiCone7H1TopoJets)[0],(mytree.PhiGen)[0]
-
-#                    etajet = (mytree.jetEtaCone7H1TopoJets)[0]
-#                    phijet = (mytree.jetPhiCone7H1TopoJets)[0]
-#                    etjet  = (mytree.jetEtCone7H1TopoJets)[0]
-
-                    etajet = (mytree.jetEtaCone7H1TowerJets)[0]
-                    phijet = (mytree.jetPhiCone7H1TowerJets)[0]
-                    etjet  = (mytree.jetEtCone7H1TowerJets)[0]
-
-                    etae = (mytree.EtaGen)[indPi[0]]
-                    if abs(etajet)>1.475 :
-                        m_h4.Fill(etajet-etae)   
-                    else:
-                        m_h3.Fill(etajet-etae)
-                        
-                    phie = (mytree.PhiGen)[indPi[0]]
-                    ete  = (mytree.PtGen)[indPi[0]]
-                        
-                    try:
-                        m_h2.Fill(phijet.real-phie)
-                    except:
-                        m_h2.Fill(phijet-phie)
-                        
-                    m_h1.Fill((etjet-ete)/ete)	 
-                    m_tmp1.Fill(etae)
-        
-        ROOT.gStyle.SetOptFit(1011)
-
-        m_h1.Fit("gaus")
-        m_h2.Fit("gaus")
-        m_h3.Fit("gaus")
-        m_h4.Fit("gaus")
-    		    
-        res1=self.saveHisto(m_h1,filePar,'')
-        res2=self.saveHisto(m_h2,filePar,'')
-        res3=self.saveHisto(m_h3,filePar,'')
-        res4=self.saveHisto(m_h4,filePar,'')
-        m_h5.Divide(m_tmp1,m_tmp2,1,1,"B")
-        
-	res5=self.saveHisto(m_h5,filePar,"E")
-
-        if res1==-1 or res2==-1 or res3==-1 or res4==-1 or res5==-1: 
-            return -1
-        else:
-            return 0
-
-
-    def run(self):
-
-        ROOT.gROOT.Reset()
-        ROOT.gStyle.SetStatW(0.19)
-        ROOT.gStyle.SetStatFontSize(0.03)
-        ROOT.gStyle.SetOptStat(111110)
-
-        filePar=self.getFilePar()
-        if filePar==-1:
-            self.logger.error('getFilePar() failed')
-            return
-
-        
-        if filePar.find('Photons')>=0:
-            return self.doPhotons(filePar)
-            
-        if filePar.find('Electrons')>=0:
-            return self.doElectrons(filePar)
-            
-        if filePar.find('Top')>=0 or filePar.find('top')>=0:
-            return self.doTop(filePar)
-
-        if filePar.find('Pi')>=0:
-            return self.doPions(filePar)
-
-        # if filePar.find('Zee')>=0:
-        #    return self.doZee(filePar)
-
-        # if filePar.find('H2e2mu')>=0:
-        #    return self.doH2e2mu(filePar)
-
-        
-            
-
-
-#a=Truth(logging.INFO)
-#a.run()
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_check.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_check.py
deleted file mode 100644
index 75780be1cfe1944d9aaa0dcfaac7455895e4428a..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_check.py
+++ /dev/null
@@ -1,166 +0,0 @@
-#!/usr/bin/env python
-
-import os,commands,sys,logging
-import traceback,imp
-
-########################################################
-import CaloTests_HistoComparison
-import CaloTests_Truth
-import CaloTests_extractRec
-import CaloTests_checkAODESDcontent
-import CaloTests_memleak
-import addHTML
-########################################################
-
-logLevel=logging.INFO
-logger = logging.getLogger('CaloTests_check')
-hdlr = logging.FileHandler('CaloTests_check.log',"w")
-formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-hdlr.setFormatter(formatter)
-logger.addHandler(hdlr)
-logger.setLevel(logLevel)
-
-com = "cat env.log|grep AtlasVersion | cut -d= -f2| tail -n1"
-res,release=commands.getstatusoutput(com)
-
-
-com = "cat env.log|grep AtlasArea | cut -d= -f2| tail -n1"
-res,branch=commands.getstatusoutput(com)
-
-
-
-com="grep RTTINFO MYRTTINFOS.txt | cut -d= -f2 | tail -n1 | awk '{print $1}'"
-res,testName=commands.getstatusoutput(com)
-if res!=0 :
-    self.logger.error(testName.strip())
-    sys.exit(1)
-
-
-
-name=testName+'Checks.py';
-mod = imp.load_source("tests",name)
-import tests
-
-
-file = open('./checks.html','w')
-txt='<html><head><title>RTT results for '+testName.strip()+'</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head><body><center><h1>RTT results for '+testName.strip()+'</h1></center>'
-txt+='<br><br><br><br>'
-txt+='<center>'+'Branch : '+branch+'<br>'
-txt+='Release : '+release+'<br><br><br>'
-
-if tests.doHistoComparison==True:
-    txt+='<a href="DrawHistos.html">Histograms</a>'
-
-if tests.doTruth==True:
-    txt+='<br><a href="CaloTests_Truth.html">Truth plots</a>'
-
-if tests.docheckAODESDcontent==True:
-    txt+='<br><a href="ESDAOD.log">ESD and AOD dump (in some cases)</a>'
-
-if tests.doaddPlotElectronicNoise==True:
-    txt+='<br><a href="ElectronicNoise.html">Electronic noise</a>'
-
-txt+='</center></body></html>'
-file.write(txt)
-file.close()
-
-logger.info('============= CHECKS BEGIN =================')
-
- 
-# Comparison plots
-if tests.doHistoComparison:
-    logger.info('---- Histograms comparison ----')
-    try: 
-       a=CaloTests_HistoComparison.HistosComparison(logger,logging.info)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of CaloTests_HistoComparison failed')
-       res=10
-    if res==0:
-        logger.info('Histograms comparison done successfully')
-    else:
-        logger.info('Histograms comparison failed')
-
-# Truth
-if tests.doTruth:
-    logger.info('---- CaloTests_Truth ----')
-    try:
-       a=CaloTests_Truth.CaloTests_Truth(logger,logging.INFO)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of CaloTests_Truth failed')
-       res=10
-
-    if res==0:
-        logger.info('CaloTests_Truth done successfully')
-    else:
-        logger.info('CaloTests_Truth failed')
-
-# CPU time
-if tests.doextractRec:
-    logger.info('---- CPU time ----')
-    try: 
-       a=CaloTests_extractRec.CaloTests_extractRec(logger,logging.INFO)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of CaloTests_extractRec failed')
-       res=10
-
-    if res==0:
-        logger.info('CaloTests_extractRec done successfully')
-    else:
-        logger.info('CaloTests_extractRec failed')
-
-# Memory leaks
-if tests.doMemLeak:
-    logger.info('---- Memory leak ----')
-    try:
-       a=CaloTests_memleak.CaloTests_memleak(logger,logging.INFO)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of CaloTests_memleak failed')
-       res=10
-
-    if res==0:
-        logger.info('CaloTests_memLeak done successfully')
-    else:
-        logger.info('CaloTests_memLeak failed')
-
-# AOD, ESD size
-if tests.docheckAODESDcontent:
-    logger.info('---- checks of AOD, ESD ----')
-    try:
-       a=CaloTests_checkAODESDcontent.CaloTests_checkAODESDcontent(logger,logging.INFO)
-       res=a.run()
-    except:
-      traceback.print_exc()
-      logger.error('execution of CaloTests_checkAODESDcontent failed')
-      res=10
-
-    if res==0:
-        logger.info('CaloTests_checkAODESDcontent done successfully')
-    else:
-        logger.info('CaloTests_checkAODESDcontent failed')
-
-# add extra plots
-if tests.doaddPlotElectronicNoise==True:
-    logger.info('---- add plot of Electronic Noise ----')
-    try:
-       a=addHTML.addHTML(logger,logging.INFO,'plotAllCaloNoise13','ElectronicNoise')
-       res=a.run()
-    except:
-      traceback.print_exc()
-      logger.error('execution of addPlotElectronicNoise failed')
-      res=10
-
-    if res==0:
-        logger.info('addPlotElectronicNoise done successfully')
-    else:
-        logger.info('addPlotElectronicNoise failed')        
-
-
-logger.info('============= CHECKS END =================')
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_checkAODESDcontent.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_checkAODESDcontent.py
deleted file mode 100644
index 0c1077227c9078e3131147f200ff41e7076cab19..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_checkAODESDcontent.py
+++ /dev/null
@@ -1,77 +0,0 @@
-#!/usr/bin/python
-
-import commands,sys,os,logging
-
-class CaloTests_checkAODESDcontent:
-    def __init__(self,log,logLevel):
-        if log=='':
-            self.logger = logging.getLogger('AODESD')
-            hdlr = logging.FileHandler('checkAODESD.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-
-    def run(self):
-        res1,output=commands.getstatusoutput("./checkFile.py ESD.pool.root >& ESDAOD.log")
-        if res1!=0:
-            self.logger.error('problem to run checkFile.py on ESD.pool.root')
-        res2,output=commands.getstatusoutput("./checkFile.py AOD.pool.root >> ESDAOD.log")
-        if res2!=0:
-            self.logger.error('problem to run checkFile.py on AOD.pool.root')
-
-        if res1!=0 and res2!=0:
-            self.logger.error('no files to check')
-            return -1
-        
-        com = "cat MYRTTINFOS.txt" + "|grep BEGIN_RTTINFO | cut -d= -f2| tail -n1"
-        res,testName=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error(testName)
-            return -1
-        reflog='ref'+testName.strip()+'AODESD.log'
-
-        com='wget http://cern.ch/CaloRTT/'+reflog
-        res,out=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error(out)
-            return -1
-
-        try:
-            f=open(log,'r')
-            fclose(log)
-        except:
-            self.logger.error(log+' not found')
-            return -1
-        
-
-        keysList=[]
-        file = open(reflog,'r')
-        for line in file:
-            t=line.split()
-            if len(t)==8 and t[1]=='kb' and t[3]=='kb' and t[5]=='kb':
-                keysList.append(t[7])
-        file.close()
-
-        for k in keysList:
-            com1='grep '+k+' '+log+' | grep -v Tree'
-            res1,out1=commands.getstatusoutput(com1)
-            if res1!=0:
-                self.logger.warning(k+' NOT FOUND')
-                continue
-            tmpNew=out1.split()
-
-            com2='grep '+k+' '+reflog+' | grep -v Tree'
-            res2,out2=commands.getstatusoutput(com2)
-            if res2!=0:
-                continue
-            tmpRef=out2.split()
-
-            if float(tmpNew[4]) > float(tmpRef[4]):
-                self.logger.warning(k +' is higher : '+'NEW='+tmpNew[4]+'/'+'REF='+tmpRef[4]+' (kb)')
-                
-        return 0
-        
-    
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_extractRec.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_extractRec.py
deleted file mode 100644
index af6c491579bb87894d552d0ebf11da59eea12b38..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_extractRec.py
+++ /dev/null
@@ -1,510 +0,0 @@
-#!/usr/bin/env python
-
-
-import os, sys, commands,getopt, datetime
-import stat,logging
-
-
-class CaloTests_extractRec:
-
-    def __init__(self,log,logLevel):   
-
-        
-        self.loggerAlert = logging.getLogger('Alert')
-        self.hdlrAlert = logging.FileHandler('Alert.txt',"w")
-        formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-        self.hdlrAlert.setFormatter(formatter)
-        self.loggerAlert.addHandler(self.hdlrAlert)
-        self.loggerAlert.setLevel(logLevel)
-
-        if log=='':
-            self.loggerInfo = logging.getLogger('Info')
-            self.hdlrInfo = logging.FileHandler('Info.txt',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            self.hdlrInfo.setFormatter(formatter)
-            self.loggerInfo.addHandler(self.hdlrInfo)
-            self.loggerInfo.setLevel(logLevel)
-        else:
-            self.loggerInfo = log
-        
-        self.tests=["Photons_calib0_csc11_007062_singlepart_gamma_E50","Electrons_calib0_csc11_007070_singlepart_e_E5","Photons_calib0_csc11_007080_singlepart_gamma_E5","Photons_calib0_csc11_007085_singlepart_gamma_E500","top_calib1_csc11_005200_T1_McAtNlo_Jimmy","Electrons_calib1_csc11_007061_singlepart_e_E100","Photons_calib1_csc11_007063_singlepart_gamma_E100"]
-        
-        # from auditors svc
-        self.CaloList=['LAr37ClusterMaker','LAr33ClusterMake','LArSWClusterMaker','LAr35ClusterMaker','CBNT_TileCell','CaloSWClusterMaker','CBNT_CaloCluster','CBNT_CaloCluster37','CBNT_CaloInfo','CBNT_CaloCluster35','CaloCellMaker','CaloTopoClusterMaker','TruthCone4Jets','TruthConeJets','CBNT_LArCell','CaloCell2TopoClusterMapper','EMTopoClusterMaker','TruthKtJets','TowerMaker','KtJets','ConeJets','Cone4Jets','METAlg']
-        # from personal chronosvc
-        self.extraCaloList=['CmbTowerBldr.TileCmbTwrBldr','CaloCellMaker_CaloCellContainerChecke','CaloCellMaker_CaloCellContainerFinali','CmbTowerBldr.FCalCmbTwrBldr','CaloCellMaker_LArCellBuilderLAr','CaloCellMaker_TileCellBuilder','CmbTowerBldr.LArCmbTwrBldr','TowerMaker.LArTowerBuilder','CmbTowerBldr.LArCmbTwrBldrChronoCellLoop','CmbTowerBldr.LArCmbTwrBldrChronobuild','TowerMaker.LArTowerBuilderChronobuild','TowerMaker.LArTowerBuilderChronoCellLoop']
-        self.debugLevel=0
-        # in sec
-        self.diffTime=0.05
-        
-        #self.emails=['bernardet@cppm.in2p3.fr']
-        self.emails=[]
-        self.wwwemails="http://cern.ch/CaloRTT/CaloRecEx_mails2.txt"
-        self.testName="CaloRecEx"
-        # if type = 1 use of the list above for the algo
-        self.type=0
-        self.typePerso=0
-        # Size of RDO.pool.root = XXX ko         
-
-
-        # release, time info
-        self.release=""
-        self.branch=""
-        self.date=""
-
-        self.mailSubjectProblem=""
-        self.mailSubjectReport=""
-        #self.switchoffRTTpart=True
-        #####################
-        self.alertMess=""
-        self.alertMessOk=False
-        self.alertReportOk=True
-        self.checkFile=0
-
-
-
-            
-####  CPU Time
-
-    def extractCPUTimeInitializeAll(self,file,type):
-
-        tmp=[]
-        if type !=1:
-            com="grep \"Time User\" " + file + " | grep initi"
-
-            self.loggerInfo.debug(com)
-        
-            res=commands.getoutput(com)
-            tmp= res.splitlines() 
-        else:
-            for i in self.CaloList:
-                com="grep \"Time User\" " + file + " | grep \"\<" +i+":initi\""
-                self.loggerInfo.debug(com)
-                res=commands.getoutput(com)
-                tmp += res.splitlines()
-            
-        return tmp
-            
-    def extractCPUTimeInitializeAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep initi" + " | grep  " + algo +" | awk '{print $7" "$8}' "
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-    def extractCPUTimeExecuteAll(self,file,type):
-    
-        tmp=[]
-        if type !=1:
-            com="grep \"Time User\" " + file + " | grep execute"
-
-            self.loggerInfo.debug(com)
-        
-            res=commands.getoutput(com)    
-            tmp= res.splitlines() 
-        else:
-            for i in self.CaloList:
-                com="grep \"Time User\" " + file + " | grep \"\<" +i
-                self.loggerInfo.debug(com)
-                res=commands.getoutput(com)
-                tmp += res.splitlines()
-
-        return tmp
-
-# pour les algo perso, ajouter un espace apres le nom de l algo pour le grep sinon pb en cas de noms du genre : AlgoPerso,AlgoPerso2 ...
-
-
-    def extractCPUTimeExecutePersoAll(self,file,type):
-    
-        tmp=[]
-        if type !=1:
-            com="grep \"Time User\" " + file + " | grep -v execute| grep -v initialize | grep -v finalize"
-
-            self.loggerInfo.debug(com)
-        
-            res=commands.getoutput(com)    
-            tmp= res.splitlines() 
-        else:
-            for i in self.extraCaloList:
-                com="grep \"Time User\" " + file + " | grep '" +i+" '" 
-                self.loggerInfo.debug(com)
-                res=commands.getoutput(com)
-                tmp += res.splitlines()
-
-        return tmp
-
-
-    def extractCPUTimeExecuteAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep  '\<" + algo +"' | awk '{print $7" "$8}' "
-        self.loggerInfo.debug(com)
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-    def extractCPUTimeExecutePersoAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep  '\<" + algo +" ' | awk '{print $7" "$8}' "
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)
-
-        self.loggerInfo.debug(res)
-
-        res2= res.splitlines() 
-        return res2
-
-
-    def extractNbEventsExecuteAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep  '\<" + algo +"'| cut -d\# -f 2 | cut -d = -f 2 "
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-    def extractNbEventsExecutePersoAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep  '\<" + algo +" '| cut -d\# -f 2 | cut -d = -f 2 "
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-
-    def getNbEvents(self,file):
-
-        com="grep \"INFO Total Virtual memory\" " + file +" | wc -l"
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-    def compareCPUTimeInitialize(self,file,reffile,type):
-        # 
-        CPUTimeRef=[]
-        alg=[]
-        CPUTimeRef=self.extractCPUTimeInitializeAll(reffile,type)
-        for i in CPUTimeRef:
-            t=i.lstrip()
-            tmp=t.split(" ")
-            alg.append(tmp[0])
-        #print alg
-        for j in alg:
-            tref=self.extractCPUTimeInitializeAlgo(reffile,str(j))
-            tnew=self.extractCPUTimeInitializeAlgo(file,str(j))
-            if len(tnew)==0:
-                    mess=j+" not found in " + file
-                    self.loggerInfo.info(mess)
-                    continue
-
-            #print j,tref,tnew
-            trefUnity=self.CPUTimeUnity(str(tref[0]))
-            tnewUnity=self.CPUTimeUnity(str(tnew[0]))
-            #print j,trefUnity,tnewUnity
-            ttnew=tnew[0].split('[')
-            ttref=tref[0].split('[')
-            ttref2=self.convertCPUTime(float(ttref[0]),trefUnity)      
-            ttnew2=self.convertCPUTime(float(ttnew[0]),tnewUnity)
-            #print j,ttref2,ttnew2
-            if ttnew2-ttref2 > self.diffTime:
-                mess="WARNING : "+j+" REF : "+str(ttref[0])+self.CPUTimeUnity(str(tref[0]))+" NOW : "+str(ttnew[0])+self.CPUTimeUnity(str(tnew[0]))
-                self.loggerInfo.info(mess)
-                self.loggerAlert.info(mess)
-            else:
-                mess="GOOD : "+j+" REF : "+str(ttref[0])+self.CPUTimeUnity(str(tref[0]))+" NOW : "+str(ttnew[0])+self.CPUTimeUnity(str(tref[0]))
-                self.loggerInfo.info(mess)
-            
-            
-        return
-
-      
-    def convertCPUTime(self,time,unity):
-       
-        if unity=="min":
-            return time*60
-        elif unity=="ms": 
-            return time*0.001
-        elif unity=="us":
-            return time*0.000001
-        else:
-            return time
-
-    def CPUTimeUnity(self,string):
-        
-        tmp=string.split('[')
-        tmp2=tmp[1].split(']')
-        return tmp2[0]
-
-    def compareCPUTimeExecute(self,file,reffile,type):
-        # 
-        CPUTimeRef=[]
-        alg=[]
-        CPUTimeRef=self.extractCPUTimeExecuteAll(reffile,type)
-        for i in CPUTimeRef:
-            t=i.lstrip()
-            tmp=t.split(" ")
-            alg.append(tmp[0])
-        for j in alg: 
-                tref=self.extractCPUTimeExecuteAlgo(reffile,str(j))
-                nbEvtRef=self.extractNbEventsExecuteAlgo(reffile,str(j))
-                tnew=self.extractCPUTimeExecuteAlgo(file,str(j))
-                nbEvtNew=self.extractNbEventsExecuteAlgo(file,str(j))
-                #print j," ", tref,"  ",tnew
-                #print 'KARIM2 ',j," ",nbEvtRef ,"  ",nbEvtNew
-                if len(tnew)==0:
-                    mess=j+" not found in " + file
-                    self.loggerInfo.info(mess)
-                    continue
-                
-                # convert en secondes
-                trefUnity=self.CPUTimeUnity(str(tref[0]))
-                tnewUnity=self.CPUTimeUnity(str(tnew[0]))
-                ttnew=tnew[0].split('[')
-                ttref=tref[0].split('[')
-                ttref2=self.convertCPUTime(float(ttref[0]),trefUnity)      
-                ttnew2=self.convertCPUTime(float(ttnew[0]),tnewUnity)
-
-                if int(nbEvtRef[0])>0:
-                    normtref=float(ttref2)/float(nbEvtRef[0])
-                else:
-                    self.loggerInfo.warning("Ref "+j+" "+nbEvtRef[0])
-                if int(nbEvtNew[0])>0:
-                    normtnew=float(ttnew2)/float(nbEvtNew[0])
-                else:
-                    self.loggerInfo.warning("New "+j+" "+nbEvtNew[0])
-
-                if int(nbEvtRef[0])>0 and int(nbEvtNew[0])>0: 
-                    if normtnew-normtref > self.diffTime:
-                        mess="WARNING : "+j+" REF : "+str(normtref)+" s "+" NOW : "+str(normtnew)+" s "+ "  (per event)"
-                        self.loggerInfo.info(mess)
-                        # alert
-                        self.loggerAlert.info(mess)
-                    else:
-                        mess="GOOD : "+j+" REF : "+str(normtref)+" s "+" NOW : "+str(normtnew)+" s"+" (per event)"
-                        self.loggerInfo.info(mess)
-                else:
-                   mess="WARNING : can not check "+j
-                   self.loggerInfo.info(mess) 
-        return
-
-
-    def compareCPUTimeExecutePerso(self,file,reffile,type):
-        # 
-        CPUTimeRef=[]
-        alg=[]
-        #CPUTimeRef=self.extractCPUTimeExecutePersoAll(reffile,type)
-        CPUTimeRef=self.extractCPUTimeExecutePersoAll(file,type)
-        
-        for i in CPUTimeRef:
-            t=i.lstrip()
-            tmp=t.split(" ")
-            alg.append(tmp[0])
-        for j in alg: 
-                tref=self.extractCPUTimeExecutePersoAlgo(reffile,str(j))
-                
-                nbEvtRef=self.extractNbEventsExecutePersoAlgo(reffile,str(j))
-                tnew=self.extractCPUTimeExecutePersoAlgo(file,str(j))
-                nbEvtNew=self.extractNbEventsExecutePersoAlgo(file,str(j))
-                isok=1
-                if len(tnew)==0:
-                    mess=j+" not found in " + file
-                    self.loggerInfo.info(mess)
-                    tmp=tref[0].split('[')
-                    mess=j+" REF : "+str(tmp[0])+self.CPUTimeUnity(str(tref[0]))
-                    self.loggerInfo.info(mess)
-                    isok=0
-                if len(tref)==0:
-                    mess=j+" not found in " + reffile
-                    self.loggerInfo.info(mess)
-                    tmp=tnew[0].split('[')
-                    mess=j+ " NEW : "+str(tmp[0])+self.CPUTimeUnity(str(tnew[0]))
-                    self.loggerInfo.info(mess)
-                    isok=0
-
-                if isok==0:
-                    continue
-                    
-                # print j," ", tref,"  ",tnew
-                # print j," ",nbEvtRefb ,"  ",nbEvtNewb
-                
-                # convert en secondes
-                trefUnity=self.CPUTimeUnity(str(tref[0]))
-                tnewUnity=self.CPUTimeUnity(str(tnew[0]))
-                ttnew=tnew[0].split('[')
-                ttref=tref[0].split('[')
-                ttref2=self.convertCPUTime(float(ttref[0]),trefUnity)      
-                ttnew2=self.convertCPUTime(float(ttnew[0]),tnewUnity)
-                normtref=float(ttref2)/float(nbEvtRef[0])
-                normtnew=float(ttnew2)/float(nbEvtNew[0])
-            
-                if normtnew - normtref > self.diffTime:
-                    mess="WARNING : "+j+" REF : "+str(normtref)+" s "+" NOW : "+str(normtnew)+" s "+ "  (per event)"
-                    self.loggerInfo.info(mess)
-                    self.loggerAlert.info(mess)
-                else:
-                    mess="GOOD : "+j+" REF : "+str(normtref)+" s "+" NOW : "+str(normtnew)+" s"+" (per event)"
-                    self.loggerInfo.info(mess)
-        return
-
-    def logExtract(self,file,chain):
-
-        com="egrep \""+chain + "\"  "  + file
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-
-    def extractLog(self,log):
-
-
-        com="wc -l "+log +" | awk '{print $1}'"
-        res=commands.getoutput(com)    
-        res2=res.splitlines()
-        nbAllLines=int(res2[0])
-
-        #print nbAllLines
-        
-        com="grep ^BEGIN_RTTINFO "+log
-        res=commands.getoutput(com)    
-        res2=res.splitlines()
-        
-        names=[]
-        for i in res2:
-            name=i.split('=')
-            name[1]=name[1].strip()
-            names.append(name[1])
-            
-        for i in range(len(names)):
-            #print i,names[i]
-            #com="grep -n BEGIN_RTTINFO="+names[i]+" "+log+" | cut -d: -f1"
-            com="grep -n \"^BEGIN_RTTINFO = "+names[i]+"\" "+log+"| cut -d: -f1"
-            n1=commands.getoutput(com)
-            try:
-                #com="grep -n BEGIN_RTTINFO="+names[i+1]+" "+log+" | cut -d: -f1"
-                com="grep -n \"^BEGIN_RTTINFO = "+names[i+1]+"\" "+log+"| cut -d: -f1"
-                
-                n2=commands.getoutput(com)
-            except:
-                n2=nbAllLines
-            
-            nblines=int(n2)-int(n1)-1
-            #print nblines
-            newlog='./'+names[i]+".log"
-            #com="grep -A"+str(nblines)+" BEGIN_RTTINFO="+names[i]+" "+log +" >"+newlog
-            com="grep -A"+str(nblines)+" \"^BEGIN_RTTINFO = "+names[i]+"\" "+log +" >"+newlog
-            os.system(com)
-        return names
-
-
-###########
-
-    def run(self):
-        log=commands.getoutput("ls Calo*Ex_RTT*_log")
-        names=self.extractLog(log)
-	
-        print names
-
-        for test in names:
-            com="rm "+"./resultats.txt"
-            commands.getoutput(com)    
-
-            com = "cat MYRTTINFOS.txt|grep BEGIN_RTTINFO | cut -d= -f2| tail -n1"
-            jobopt=commands.getoutput(com)
-            self.loggerInfo.info('Test name : '+jobopt)
-            found=0
-            for opt in self.tests:
-                if opt==jobopt.strip():
-                    found=1
-                    break	
-
-            if found==0:
-                self.loggerInfo.info("test not in dict !!!")
-                return -1
-
-            self.reflog='ref'+jobopt.strip()+'.log'
-            com='wget http://cern.ch/CaloRTT/'+self.reflog
-            print com
-            os.system(com)
-
-            try:
-                file = open(self.reflog)
-                file.close()
-            except IOError:
-                self.loggerInfo.info(self.reflog+' not found')
-                return -1
-
-            # date
-            self.date=str(datetime.datetime.now().strftime("%Y-%m-%d %X"))
-            self.loggerInfo.info(self.date)
-
-            com = "cat env.log|grep AtlasVersion | cut -d= -f2| tail -n1"
-            self.release=commands.getoutput(com)
-            self.branch="Dev"
-
-            self.mailSubjectProblem="\"[RTT test, "+jobopt+","+self.branch+","+self.release+"]:CaloTests_extractRec problem \""
-            self.mailSubjectReport="\"[RTT test, "+jobopt+","+self.branch+","+self.release+"]:CaloTests_extractRec report \""
-
-            mess="Reference log = " + self.reflog
-            self.loggerInfo.info(mess)
-            mess="Log to check = "+log
-            self.loggerInfo.info(mess)
-
-     
-            self.loggerInfo.info("********************************")
-            self.loggerInfo.info("CHECK STATUSCODE")
-            
-            res=self.logExtract(log,"\|*\| lib*")
-            for i in res:
-                self.loggerInfo.info(str(i))     
-            self.loggerInfo.info("********************************")
-
-
-            ## self.loggerInfo.info("********************************")
-##             self.loggerInfo.info("CHECK WARNING")
-            
-##             res=self.logExtract(log," WARNING ")
-##             for i in res:
-##                 self.loggerInfo.info(str(i))     
-##             self.loggerInfo.info("********************************")
-            
-            
-##             self.loggerInfo.info("********************************")
-##             self.loggerInfo.info("CHECK ERROR")
-##             res=self.logExtract(log," ERROR ")
-##             for i in res:
-##                 self.loggerInfo.info(str(i))     
-##             self.loggerInfo.info("********************************")
-            
-
-            
-            self.loggerInfo.info("********************************")
-            
-            self.loggerInfo.info("CHECK INITIALIZE TIME")
-            
-            self.compareCPUTimeInitialize(log,self.reflog,self.type)
-            
-            self.loggerInfo.info("********************************")
-            
-            self.loggerInfo.info("CHECK EXECUTE TIME")
-            
-            self.compareCPUTimeExecute(log,self.reflog,self.type)
-            self.compareCPUTimeExecutePerso(log,self.reflog,self.typePerso)
-            
-            self.loggerInfo.info("********************************")
-
-            return 0
-#a=extractRec()
-#a.run()
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_memleak.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_memleak.py
deleted file mode 100644
index 588e25146448fe3f5c08dc30bbec89151d06740e..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_memleak.py
+++ /dev/null
@@ -1,45 +0,0 @@
-#!/usr/bin/python
-
-import commands,sys,os,logging
-
-
-class CaloTests_memleak:
-    def __init__(self,log,logLevel):
-        if log=='':
-            self.logger = logging.getLogger('CaloTests_memleak')
-            hdlr = logging.FileHandler('CaloTests_memleak.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-
-    def run(self):
-
-        log=commands.getoutput("ls Calo*RTT*_log")
-        try:
-            f=open(log,'r')
-            f.close()
-        except:
-            self.logger.error(log+' not found')
-            return -1
-        
-        com='grep \"only second half of the job\" '+log+'| grep INFO'
-        res,out=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error(out)
-            return -1
-
-        tmp=out.split('only second half of the job:')
-        tmp2=tmp[1].strip().split('MByte/event')
-        if float(tmp2[0].strip())>0.1:
-            self.logger.warning('MEM LEAK ! :'+tmp[1].strip())
-            return -1
-        return 0
-        
-    
-                
-#a=memleak('',logging.INFO)
-#a.run()
-    
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_noise.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_noise.py
deleted file mode 100644
index 2e0a52951b3b10005ab4e4c25b816d857d8aa026..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_noise.py
+++ /dev/null
@@ -1,74 +0,0 @@
-
-import commands
-
-res=commands.getoutput('ls CaloTests_GeomTag*.txt')
-
-f = open(res)
-THE_GEOMETRY=f.readlines()
-f.close()
-
-print "The geometry is ", THE_GEOMETRY[0]
-
-
-
-AllAlgs = False # if false, all algorithms ae switched off by defaults
-
-
-
-
-from AthenaCommon.GlobalFlags import GlobalFlags
-GlobalFlags.Luminosity.set_zero() # or set_high()
-
-EvtMax=1
-doNameAuditor=False
-
-doWriteESD = False
-doWriteAOD = False
-doWriteTAG = False
-doAOD = False
-doTruth = True
-doCaloNoise = True
-doCaloTopoCluster = True
-doTopoClusterCBNT = True
-doTrigger=False
-doPerfMon=False
-
-doMoore=False
-doMuonboy=False
-
-RootNtupleOutput='ntuple_elecnoise.root'
-
-include ("RecExCommon/RecExCommon_flags.py")
-
-
-
-from CaloRec.CaloTopoClusterFlags import jobproperties
-jobproperties.CaloTopoClusterFlags.doTopoClusterLocalCalib.set_Value(True)
-
-# switch off useless detectors
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-jobproperties.Global.DetDescrVersion=THE_GEOMETRY[0]
-
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-EventSelector.InputCollections = [ "Dig.pool.root" ]
-
-from CaloRec.CaloRecConf import CaloTopoClusterMaker, CaloTopoClusterSplitter
-
-TopoMaker = CaloTopoClusterMaker("TopoMaker")
-TopoMaker.NeighborThresholdOnEorAbsEinSigma =    -1
-TopoMaker.SeedThresholdOnEorAbsEinSigma  =    -1
-
-TopoSplitter = CaloTopoClusterSplitter("TopoSplitter")
-TopoSplitter.EnergyCut = 100*GeV
-TopoSplitter.ShareBorderCells = False
-
-
-theCBNT_CaloClusterTopo = CBNTAA_CaloCluster( "CBNT_CaloClusterTopo" )
-theCBNT_CaloClusterTopo.AddCellDetails = TRUE
-theCBNT_CaloClusterTopo.MaxCell = 200000
-theCBNT_CaloClusterTopo.Suffix = "_topo"
-theCBNT_CaloClusterTopo.UseLink=TRUE
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_plotAllCaloNoise13.C b/Calorimeter/CaloExample/CaloTests/share/CaloTests_plotAllCaloNoise13.C
deleted file mode 100644
index 37028a7440111ef644817f9fc7280775493269aa..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_plotAllCaloNoise13.C
+++ /dev/null
@@ -1,217 +0,0 @@
-void CaloTests_plotAllCaloNoise13(char * fname = "ntuple_elecnoise.root", int iMode=0) {
-
-  ifstream ifile(fname,ios::in);
-      
-      if ( ifile.fail() )
-	{
-	  std::cout << fname << " not found !" << std::endl;
-	  continue;
-	}
-      ifile.close();
-
-
-  TFile * f = new TFile(fname);
-  TCanvas * c0 = new TCanvas();
-  gPad->SetLogy();
-  gPad->SetGridx();
-  gPad->SetGridy();
-  TTree *allCaloNoises = (TTree *)f->Get("CollectionTree");
-  allCaloNoises->SetMarkerSize(0.7);
-  gStyle->SetOptTitle(0);
-  gStyle->SetOptStat(0);
-  TH2F *base;
-  if ( iMode == 0 ) {
-    //    base = new TH2F("base","base",100,-5,5.,1000,2.,3000.);
-    base = new TH2F("base","base",100,-5,5.,1000,1.,1000.);
-    base->SetYTitle("Electronics Noise (MeV)");
-  }
-  else if (iMode == 1 ) {
-    base = new TH2F("base","base",100,-5,5.,1000,1.,40000.);
-    base->SetYTitle("Pile-Up Noise (MeV)");  
-  }
-  else {
-    base = new TH2F("base","base",100,-5,5.,1000,1e4,1e9);
-    base->SetYTitle("Cell Volume (mm^{3})");  
-  }
-  base->SetXTitle("#eta");
-  base->Draw();
-  TLegend * tla;
-  if ( iMode != 2 ) 
-    tla = new TLegend(0.1,0.1,0.2,0.4);
-  else
-    tla = new TLegend(0.1,0.5,0.2,0.9);
-  tla->SetFillColor(10);
-  tla->SetBorderSize(1);
-  TLegend * tlb;
-  if ( iMode == 0 ) 
-    tlb = new TLegend(0.8,0.1,0.9,0.4);
-  else if ( iMode == 1) 
-    tlb = new TLegend(0.8,0.4-4./7.*0.3,0.9,0.4);
-  else
-    tlb = new TLegend(0.8,0.5,0.9,0.9);
-  tlb->SetFillColor(10);
-  tlb->SetBorderSize(1);
-  c0->Modified();
-  c0->Update();
-  float iColor=45,dColor=8;
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(20);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>fcal1","cell_calo_topo==2&&cell_samp_topo==1&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>fcal1","cell_calo_topo==2&&cell_samp_topo==1&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>fcal1","cell_calo_topo==2&&cell_samp_topo==1&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tla->AddEntry(fcal1,"FCal1","p");
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(21);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>fcal2","cell_calo_topo==2&&cell_samp_topo==2&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>fcal2","cell_calo_topo==2&&cell_samp_topo==2&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>fcal2","cell_calo_topo==2&&cell_samp_topo==2&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tla->AddEntry(fcal2,"FCal2","p");
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(22);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>fcal3","cell_calo_topo==2&&cell_samp_topo==3&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>fcal3","cell_calo_topo==2&&cell_samp_topo==3&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>fcal3","cell_calo_topo==2&&cell_samp_topo==3&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tla->AddEntry(fcal3,"FCal3","p");
-  iColor = 65;
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(20);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>hec1","cell_calo_topo==1&&cell_samp_topo==0&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>hec1","cell_calo_topo==1&&cell_samp_topo==0&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>hec1","cell_calo_topo==1&&cell_samp_topo==0&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tla->AddEntry(hec1,"HEC1","p");
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(21);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>hec2","cell_calo_topo==1&&cell_samp_topo==1&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>hec2","cell_calo_topo==1&&cell_samp_topo==1&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>hec2","cell_calo_topo==1&&cell_samp_topo==1&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tla->AddEntry(hec2,"HEC2","p");
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(22);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>hec3","cell_calo_topo==1&&cell_samp_topo==2&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>hec3","cell_calo_topo==1&&cell_samp_topo==2&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>hec3","cell_calo_topo==1&&cell_samp_topo==2&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tla->AddEntry(hec3,"HEC3","p");
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(23);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>hec4","cell_calo_topo==1&&cell_samp_topo==3&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>hec4","cell_calo_topo==1&&cell_samp_topo==3&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>hec4","cell_calo_topo==1&&cell_samp_topo==3&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tla->AddEntry(hec4,"HEC4","p");
-  iColor = 55;
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(20);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>em0","cell_calo_topo==0&&cell_samp_topo==0&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>em0","cell_calo_topo==0&&cell_samp_topo==0&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>em0","cell_calo_topo==0&&cell_samp_topo==0&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tlb->AddEntry(em0,"PS","p");
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(21);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>em1","cell_calo_topo==0&&cell_samp_topo==1&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>em1","cell_calo_topo==0&&cell_samp_topo==1&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>em1","cell_calo_topo==0&&cell_samp_topo==1&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tlb->AddEntry(em1,"EM1","p");
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(22);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>em2","cell_calo_topo==0&&cell_samp_topo==2&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>em2","cell_calo_topo==0&&cell_samp_topo==2&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>em2","cell_calo_topo==0&&cell_samp_topo==2&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tlb->AddEntry(em2,"EM2","p");
-  allCaloNoises->SetMarkerColor(iColor+=dColor);
-  allCaloNoises->SetMarkerStyle(23);
-  if ( iMode == 0 ) 
-    allCaloNoises->Draw("cellnoise_topo:celleta_topo>>em3","cell_calo_topo==0&&cell_samp_topo==3&&cell_iphi_topo==0","same");
-  else if ( iMode == 1 ) 
-    allCaloNoises->Draw("sqrt(pow(celltotnoise_topo,2)-pow(cellnoise_topo,2)):celleta_topo>>em3","cell_calo_topo==0&&cell_samp_topo==3&&cell_iphi_topo==0","same");
-  else 
-    allCaloNoises->Draw("cellvol_topo:celleta_topo>>em3","cell_calo_topo==0&&cell_samp_topo==3&&cell_iphi_topo==0","same");
-  c0->Modified();
-  c0->Update();
-  tlb->AddEntry(em3,"EM3","p");
-  if ( iMode != 1) {
-    iColor = 75;
-    allCaloNoises->SetMarkerColor(iColor+=dColor);
-    allCaloNoises->SetMarkerStyle(20);
-    if ( iMode == 0 )
-      allCaloNoises->Draw("cellnoise_topo:celleta_topo>>tile1","cell_calo_topo==3&&cell_samp_topo==0&&cell_ireg_topo<3&&cell_iphi_topo==0","same");
-    else
-      allCaloNoises->Draw("cellvol_topo:celleta_topo>>tile1","cell_calo_topo==3&&cell_samp_topo==0&&cell_ireg_topo<3&&cell_iphi_topo==0","same");
-    c0->Modified();
-    c0->Update();
-    tlb->AddEntry(tile1,"Tile1","p");
-    allCaloNoises->SetMarkerColor(iColor+=dColor);
-    allCaloNoises->SetMarkerStyle(21);
-    if ( iMode == 0 )
-      allCaloNoises->Draw("cellnoise_topo:celleta_topo>>tile2","cell_calo_topo==3&&cell_samp_topo==1&&cell_ireg_topo<3&&cell_iphi_topo==0","same");
-    else
-      allCaloNoises->Draw("cellvol_topo:celleta_topo>>tile2","cell_calo_topo==3&&cell_samp_topo==1&&cell_ireg_topo<3&&cell_iphi_topo==0","same");
-    c0->Modified();
-    c0->Update();
-    tlb->AddEntry(tile2,"Tile2","p");
-    allCaloNoises->SetMarkerColor(iColor+=dColor);
-    allCaloNoises->SetMarkerStyle(22);
-    if ( iMode == 0 )
-      allCaloNoises->Draw("cellnoise_topo:celleta_topo>>tile3","cell_calo_topo==3&&cell_samp_topo==2&&cell_ireg_topo<3&&cell_iphi_topo==0","same");
-    else
-      allCaloNoises->Draw("cellvol_topo:celleta_topo>>tile3","cell_calo_topo==3&&cell_samp_topo==2&&cell_ireg_topo<3&&cell_iphi_topo==0","same");
-    c0->Modified();
-    c0->Update();
-    tlb->AddEntry(tile3,"Tile3","p");
-  }
-  tla->Draw();
-  tlb->Draw();
-
-  TString name="plotAllCaloNoise13.gif";
-  c0 -> SaveAs(name);
-
-}
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_runMacros2.C b/Calorimeter/CaloExample/CaloTests/share/CaloTests_runMacros2.C
deleted file mode 100644
index eab050fa2ae52bdbc15b6acd12193ac771fb58d8..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_runMacros2.C
+++ /dev/null
@@ -1,21 +0,0 @@
-
-#include "TSystem.h"
-
-void CaloTests_runMacros2()
-{
-  int nbTests=2;
-  string macros[]={"CaloTests_runPython2.C","CaloTests_plotAllCaloNoise13.C"};
-
-  ofstream chkfile("CaloTests_runMacros2.txt",ios::out);	
-  
-
-  for(int i=0;i<nbTests;i++)
-    {
-      string com;
-      chkfile << "Run " << macros[i] << std::endl;
-      com="root.exe -b -q "+macros[i];
-      gSystem->Exec(com.c_str());
-      chkfile << "Run " << macros[i] << " Done." << std::endl;
-    }
-  chkfile.close();
-}
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_runPython2.C b/Calorimeter/CaloExample/CaloTests/share/CaloTests_runPython2.C
deleted file mode 100644
index 34cc1d1703036826cadfc1df67ebe92417d57457..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_runPython2.C
+++ /dev/null
@@ -1,26 +0,0 @@
-
-#include "TSystem.h"
-
-void CaloTests_runPython2()
-{
-  int nbTests=1;
-  string macros[]={"CaloTests_check.py"};
-
-  ofstream chkfile("CaloTests_runPython2.txt",ios::out);	
-
- 
-  std::cout << "LD_LIBRARY_PATH is " << gSystem->Getenv("LD_LIBRARY_PATH") << std::endl;
-
-  std::cout << "PATH is " << gSystem->Getenv("PATH") << std::endl;
-
-
-  for(int i=0;i<nbTests;i++)
-    {
-      string com;
-      chkfile << "Run " << macros[i] << std::endl;
-      com="python "+macros[i];
-      gSystem->Exec(com.c_str());
-      chkfile << "Run " << macros[i] << " Done." << std::endl;
-    }
-  chkfile.close();
-}
diff --git a/Calorimeter/CaloExample/CaloTests/share/CaloTests_testnoise.py b/Calorimeter/CaloExample/CaloTests/share/CaloTests_testnoise.py
deleted file mode 100644
index 4fe841ae1ce25d2876a7f576976542859e08f975..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/CaloTests_testnoise.py
+++ /dev/null
@@ -1,101 +0,0 @@
-###############################################################
-#
-# Job options file to run Digitization
-#
-#==============================================================
-from AthenaCommon.DetFlags import DetFlags
-from AthenaCommon.GlobalFlags import GlobalFlags
-GlobalFlags.DetGeo.set_atlas()
-GlobalFlags.Luminosity.set_zero()
-GlobalFlags.DataSource.set_geant4() 
-DetFlags.detdescr.all_setOn()
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-DetFlags.readRDOPool.LAr_setOn()
-DetFlags.makeRIO.LAr_setOn()
-
-
-include( "PartPropSvc/PartPropSvc.py" )
-
-
-from AthenaCommon.AppMgr import ServiceMgr
-import AthenaPoolCnvSvc.ReadAthenaPool
-#ServiceMgr.EventSelector.InputCollections = [ "/afs/cern.ch/atlas/offline/data/testfile/calib1_csc11.007234.singlepart_mu200.simul.HITS.v12000301_tid003123._00001.pool.root" ]
-#
-ServiceMgr.EventSelector.InputCollections = [ "castor:/castor/cern.ch/grid/atlas/dq2/valid3_mc12/HITS/valid3_mc12.007063.singlepart_gamma_E100.simul.HITS.v13001001_tid011905/HITS.011905._00082.pool.root.1" ]
-
-# the Tile, LAr and Calo detector description package
-DetDescrVersion = "ATLAS-CSC-01-00-00" 
-
-include( "DetDescrDictionary/DetDescrDictionaryDict_joboptions.py" )
-include ("AtlasGeoModel/SetGeometryVersion.py")
-include( "AtlasGeoModel/GeoModelInit.py" )
-include( "TileConditions/TileConditions_jobOptions.py" )
-include( "CaloIdCnv/CaloIdCnv_joboptions.py" )
-include( "TileIdCnv/TileIdCnv_jobOptions.py" )
-include( "LArDetMgrDetDescrCnv/LArDetMgrDetDescrCnv_joboptions.py" )
-
-
-#force alignment to use ideal one
-IOVDbSvc = Service( "IOVDbSvc" )
-IOVDbSvc.GlobalTag="OFLCOND-CSC-00-00-00"
-
-
-
-from AthenaCommon.AlgSequence import AlgSequence 
-topSequence = AlgSequence()
-
- 	
-
-from CaloTests.CaloTestsConf import MyAnalysis__Analysis
-topSequence += MyAnalysis__Analysis()
-
-Analysis=MyAnalysis__Analysis("Analysis")
-
-
-Analysis.LoopRaw = FALSE
-Analysis.Check = FALSE
-Analysis.LoopHit = TRUE
-Analysis.LoopCalHit = FALSE
-Analysis.LoopCluster = FALSE
-Analysis.LoopCell = FALSE
-Analysis.UseTriggerTime = FALSE;
-# Analysis.TriggerTimeToolName = "CosmicTriggerTimeTool"
-
-#--------------------------------------------------------------
-# Set output level threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL )
-#--------------------------------------------------------------
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel      = VERBOSE
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-THistSvc = Service ( "THistSvc" )
-THistSvc.Output  = ["file1 DATAFILE='test.root' OPT='RECREATE'"];
-
-
-#--------------------------------------------------------------
-# Event related parameters
-#--------------------------------------------------------------
-# Number of events to be processed (default is 10)
-theApp.EvtMax = -1
-theApp.EvtSel = "EventSelector"
-
-# Use auditors
-theApp.Dlls += [ "GaudiAud" ]
-#
-# write out a summary of the time spent
-#
-theAuditorSvc = AuditorSvc()
-theAuditorSvc.Auditors  += [ "ChronoAuditor"]
-theAuditorSvc.Auditors  += [ "MemStatAuditor" ]
-MemStatAuditor = theAuditorSvc.auditor( "MemStatAuditor" )
-MemStatAuditor.OutputLevel = INFO
-
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.infoLimit  = 100000000
-MessageSvc.OutputLevel = INFO
-
-#StoreGateSvc=Service("StoreGateSvc");
-#StoreGateSvc.dump=TRUE
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/DrawHists.py b/Calorimeter/CaloExample/CaloTests/share/DrawHists.py
deleted file mode 100755
index d9bb9e5f63a7faa41291113436f1ab8eeb6de973..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/DrawHists.py
+++ /dev/null
@@ -1,230 +0,0 @@
-#!/usr/bin/env python
-
-import os,commands,sys,logging
-import ROOT
-
-class myHist:
-    def __init__(self,histName,histComment,histBins,histMinX,histMaxX,histFormula,histCondForm):
-        self.histName=histName
-        self.histComment=histComment
-        self.histMinX=histMinX
-        self.histMaxX=histMaxX
-        self.histFormula=histFormula
-        self.histCondForm=histCondForm
-        self.histBins=histBins
-        
-
-    def setHistName(self,name):
-        self.histName=name
-
-    def setHistComment(self,Comment):
-        self.histComment=Comment
-
-    def setHistFormula(self,form):
-        self.histFormula=form
-
-    def setHistCondForm(self,condform):
-        self.histCondForm=condform
-
-    def setHistName(self,minX):
-        self.HistMinx=minX
-
-    def setHistName(self,maxX):
-        self.histMaxX=maxX
-
-    def setHistBins(self,nbins):
-        self.histBins=nbins
-
-    def getHistName(self):
-        return self.histName
-
-    def getHistComment(self):
-        return self.histComment
-
-    def getHistMinX(self):
-        return self.histMinX
-
-    def getHistMaxX(self):
-        return self.histMaxX
-
-    def getHistBins(self):
-        return self.histBins
-
-    def getHistFormula(self):
-        return self.histFormula
-
-    def getHistCondForm(self):
-        return self.histCondForm
-
-
-class DrawHists:
-    def __init__(self,log,logLevel):
-        if log=='':
-            self.logger = logging.getLogger('DrawHists')
-            hdlr = logging.FileHandler('DrawHists.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-    
-    def normH(self,m_hist):
-        if m_hist.GetEntries() != 0 :
-            scale = 1/m_hist.GetEntries()
-            m_hist.Scale(scale)
-        else:
-            self.logger.error("No entries in ",m_hist.GetTitle())
-            
-    
-    def makeHist(self,ROOTntuple):
-
-        ROOT.gStyle.SetMarkerStyle(8)
-        ROOT.gStyle.SetStatW(0.4)
-        ROOT.gStyle.SetStatFontSize(0.12)
-        ROOT.gStyle.SetLabelSize(0.06)
-        ROOT.gStyle.SetOptStat(111110)
-        ROOT.gStyle.SetCanvasBorderMode(0)
-        ROOT.gStyle.SetPadBorderMode(0)
-        ROOT.gStyle.SetPadColor(0)
-        ROOT.gStyle.SetCanvasColor(0)
-        ROOT.gStyle.SetTitleColor(0)
-        ROOT.gStyle.SetStatColor(0)
-
-        # only 3 digits
-        ROOT.TGaxis.SetMaxDigits(3);
-
-        myCanvas = ROOT.TCanvas("myCanvas","Cluster",1)
-        myCanvas.Divide(2,8)
-
-        file=open('DrawHists.txt','r')
-        hists=[]
-        n=0
-        for line in file:
-            i=+1
-            myCanvas.cd(n)
-            tmp=line.strip().split(',')
-            if len(tmp)==7:
-                h=myHist(tmp[0],tmp[1],tmp[2],tmp[3],tmp[4],tmp[5],tmp[6])
-            else:
-                h=myHist(tmp[0],tmp[1],tmp[2],tmp[3],tmp[4],tmp[5],'')
-            hists.append(h)
-        file.close()
-        
-        rootFile = ROOT.TFile(ROOTntuple,'READ')
-        mytree = ROOT.gDirectory.Get('m_ntuple')
-        mytree.UseCurrentStyle()
-
-        hfile = ROOT.TFile("Cluster.hist","RECREATE","Clusters hist")
-        for h in hists:
-            #self.logger.debug(h.getHistName(),',',h.getHistComment(),',',h.getHistBins(),',',h.getHistMinX(),',',h.getHistBins(),',',h.getHistMaxX())
-            m_h = ROOT.TH1F(h.getHistName(),h.getHistComment(),int(h.getHistBins()),float(h.getHistMinX()),float(h.getHistMaxX()))
-            mytree.Draw(h.getHistFormula(),h.getHistCondForm())
-            mytree.Draw(h.getHistFormula()+'>>'+h.getHistName(),h.getHistCondForm())
-            self.normH(m_h)
-            hfile.Write()
-        
-        rootFile.Close()
-        
-    def initHTMLDraw(self):
-        f=open("DrawHistos.html","w")
-        f.write("<html><head><title>Draw</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head>")
-        f.write("<body>")
-        f.close();
-        
-    def closeHTMLDraw(self):
-        f=open("DrawHistos.html","a")
-        f.write("</body>")
-        f.write("</html>")
-
-
-
-    def Draw(self,histFile):
-        self.initHTMLDraw()
-        file = ROOT.TFile(histFile)
-        for i in file.GetListOfKeys():
-            self.DrawHisto(i.ReadObj())
-        file.Close()
-        self.closeHTMLDraw()
-
-    def Draw2(self,histFile):
-
-        file = ROOT.TFile(histFile)
-        mytree = ROOT.gDirectory.Get('analysis')
-        
-        for i in mytree.GetListOfKeys():
-           self.DrawHisto(i.ReadObj()) 
-        file.Close()
-       
-
-    def DrawHisto(self,hist):
-        f=open("DrawHistos.html","a")
-
-        tmp=hist.GetTitle()
-        name=""
-        for i in tmp:
-            if i==' ':
-                i='_'
-            if i=='(':
-                i='z'
-            if i==')':
-                i='z'
-            name+=i
-
-        ROOT.gStyle.SetOptStat(ROOT.kFALSE)
-        can=ROOT.TCanvas()
- 
-        hist.Draw()
-
-        legend=ROOT.TLegend(0.7,0.7,0.89,0.85)
-        legend.SetTextFont(72)
-        legend.SetTextSize(0.04)
- 
-        legend.AddEntry(hist,"NEW","l")
-        legend.Draw()
- 
-        can.Modified()
-        can.Update()
-
-        epsname=name+".eps"
-        gifname=name+".gif"
-
-        can.SaveAs(epsname)
-
-        com1='pstopnm -ppm -xborder 0 -yborder 0 -portrait '+epsname
-        com2='ppmtogif '+epsname+'001.ppm >'+gifname
-        
-        os.system(com1)
-        os.system(com2)
-        
-        f.write("<CENTER><BR>")
-        f.write("Name : "+hist.GetTitle()+'<BR>')
-        f.write("<BR>")
-        f.write("<TABLE border=1>")
-        f.write("<TR>")
-        f.write("<TD>Entries</TD>")
-        f.write("<TD>"+str(hist.GetEntries())+'</TD>')
-        f.write("</TR>")      
-        f.write("<TR>")
-        f.write("<TD>Mean</TD>")
-        f.write("<TD>"+str(hist.GetMean())+'</TD>')
-        f.write("</TR>")        
-        f.write("<TR>")
-        f.write("<TD>RMS</TD>")
-        f.write('<TD>'+str(hist.GetRMS())+'</TD>')
-        f.write("</TR>")       
-        f.write("</TABLE>")       
-        f.write("<IMG SRC=\""+gifname+'\"><BR>')
-        f.write('<HR><BR>')
-        f.close()
-            
-    def run(self):
-        #self.makeHist('test.root')
-        #res=self.Draw("Cluster.hist");
-        res=self.Draw2("test.root");
-        
-        return res
-
-    
-a=DrawHists("",logging.INFO)
-a.run()
diff --git a/Calorimeter/CaloExample/CaloTests/share/DrawHists.txt b/Calorimeter/CaloExample/CaloTests/share/DrawHists.txt
deleted file mode 100644
index 5fe1fd8007efa3f7668821524f4772182a1f0a14..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/DrawHists.txt
+++ /dev/null
@@ -1 +0,0 @@
-m_h1,eta,40,-2.5,2.5,eta
\ No newline at end of file
diff --git a/Calorimeter/CaloExample/CaloTests/share/Electrons100GeVChecks.py b/Calorimeter/CaloExample/CaloTests/share/Electrons100GeVChecks.py
deleted file mode 100644
index a4a30cde27430f73b8d6803aee8e79d98962d6d9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/Electrons100GeVChecks.py
+++ /dev/null
@@ -1,10 +0,0 @@
-
-doHistoComparison=True
-doTruth=True
-doMemLeak=True
-doextractRec=False
-docheckAODESDcontent=False
-docheckAODESDcontentAOD=False
-docheckAODESDcontentESD=False
-doaddPlotElectronicNoise=False
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/Electrons100GeVmisChecks.py b/Calorimeter/CaloExample/CaloTests/share/Electrons100GeVmisChecks.py
deleted file mode 100644
index a4a30cde27430f73b8d6803aee8e79d98962d6d9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/Electrons100GeVmisChecks.py
+++ /dev/null
@@ -1,10 +0,0 @@
-
-doHistoComparison=True
-doTruth=True
-doMemLeak=True
-doextractRec=False
-docheckAODESDcontent=False
-docheckAODESDcontentAOD=False
-docheckAODESDcontentESD=False
-doaddPlotElectronicNoise=False
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/Electrons50GeVChecks.py b/Calorimeter/CaloExample/CaloTests/share/Electrons50GeVChecks.py
deleted file mode 100644
index dbf8b9b2c01c598ea27e0d6e517428865c79fecb..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/Electrons50GeVChecks.py
+++ /dev/null
@@ -1,10 +0,0 @@
-
-doHistoComparison=True
-doTruth=False
-doMemLeak=True
-doextractRec=False
-docheckAODESDcontent=False
-docheckAODESDcontentAOD=False
-docheckAODESDcontentESD=False
-doaddPlotElectronicNoise=False
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/Electrons50GeVmisChecks.py b/Calorimeter/CaloExample/CaloTests/share/Electrons50GeVmisChecks.py
deleted file mode 100644
index dbf8b9b2c01c598ea27e0d6e517428865c79fecb..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/Electrons50GeVmisChecks.py
+++ /dev/null
@@ -1,10 +0,0 @@
-
-doHistoComparison=True
-doTruth=False
-doMemLeak=True
-doextractRec=False
-docheckAODESDcontent=False
-docheckAODESDcontentAOD=False
-docheckAODESDcontentESD=False
-doaddPlotElectronicNoise=False
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/Electrons5GeVChecks.py b/Calorimeter/CaloExample/CaloTests/share/Electrons5GeVChecks.py
deleted file mode 100644
index dbf8b9b2c01c598ea27e0d6e517428865c79fecb..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/Electrons5GeVChecks.py
+++ /dev/null
@@ -1,10 +0,0 @@
-
-doHistoComparison=True
-doTruth=False
-doMemLeak=True
-doextractRec=False
-docheckAODESDcontent=False
-docheckAODESDcontentAOD=False
-docheckAODESDcontentESD=False
-doaddPlotElectronicNoise=False
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/HistoComparison.py b/Calorimeter/CaloExample/CaloTests/share/HistoComparison.py
deleted file mode 100755
index 1fe7632dde3a78eb324691a29681c1cb2924859b..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/HistoComparison.py
+++ /dev/null
@@ -1,481 +0,0 @@
-#!/usr/bin/env python
-
-import os,commands,sys,logging
-import ROOT
-
-class myHist:
-    def __init__(self,histName,histComment,histBins,histMinX,histMaxX,histFormula,histCondForm):
-        self.histName=histName
-        self.histComment=histComment
-        self.histMinX=histMinX
-        self.histMaxX=histMaxX
-        self.histFormula=histFormula
-        self.histCondForm=histCondForm
-        self.histBins=histBins
-        
-
-    def setHistName(self,name):
-        self.histName=name
-
-    def setHistComment(self,Comment):
-        self.histComment=Comment
-
-    def setHistFormula(self,form):
-        self.histFormula=form
-
-    def setHistCondForm(self,condform):
-        self.histCondForm=condform
-
-    def setHistName(self,minX):
-        self.HistMinx=minX
-
-    def setHistName(self,maxX):
-        self.histMaxX=maxX
-
-    def setHistBins(self,nbins):
-        self.histBins=nbins
-
-    def getHistName(self):
-        return self.histName
-
-    def getHistComment(self):
-        return self.histComment
-
-    def getHistMinX(self):
-        return self.histMinX
-
-    def getHistMaxX(self):
-        return self.histMaxX
-
-    def getHistBins(self):
-        return self.histBins
-
-    def getHistFormula(self):
-        return self.histFormula
-
-    def getHistCondForm(self):
-        return self.histCondForm
-    
-
-class HistosComparison:
-    def __init__(self,log,logLevel):
-        if log=='':
-            self.logger = logging.getLogger('HistosComparison')
-            hdlr = logging.FileHandler('HistosComparison.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-        self.filePar="filePar"
-    
-    def normH(self,m_hist):
-        if m_hist.GetEntries() != 0 :
-            scale = 1/m_hist.GetEntries()
-            m_hist.Scale(scale)
-        else:
-            self.logger.error("No entries in ",m_hist.GetTitle())
-
-    def getPar(self,name,par):
-        com="grep \"RTTParm_almostIdentical_"+name+"_"+par+"\"  "+self.filePar+ "| cut -d= -f2 | tail -n1"
-        print com
-        res,val=commands.getstatusoutput(com)
-        if val=="":
-            val="notfound"
-        if res!=0:
-            self.logger.error('Problem to get the par of '+name+' : '+max)
-            val="notfound"
-            
-        return val       
-    
-    def makeHist(self,ROOTntuple):
-
-        ROOT.gStyle.SetMarkerStyle(8)
-        ROOT.gStyle.SetStatW(0.4)
-        ROOT.gStyle.SetStatFontSize(0.12)
-        ROOT.gStyle.SetLabelSize(0.06)
-        ROOT.gStyle.SetOptStat(111110)
-        ROOT.gStyle.SetCanvasBorderMode(0)
-        ROOT.gStyle.SetPadBorderMode(0)
-        ROOT.gStyle.SetPadColor(0)
-        ROOT.gStyle.SetCanvasColor(0)
-        ROOT.gStyle.SetTitleColor(0)
-        ROOT.gStyle.SetStatColor(0)
-
-        # only 3 digits
-        ROOT.TGaxis.SetMaxDigits(3);
-
-        myCanvas = ROOT.TCanvas("myCanvas","Cluster",1)
-        myCanvas.Divide(2,8)
-
-        file=open('HistoComparison.txt','r')
-        hists=[]
-        n=0
-        for line in file:
-            i=+1
-            myCanvas.cd(n)
-            tmp=line.strip().split(',')
-
-            name2=""
-            for i in tmp[1]:
-                if i==' ':
-                    i='_'
-                if i=='(':
-                    i='z'
-                if i==')':
-                    i='z'
-                name2+=i
-
-            # check bin x
-            xmin=self.getPar(name2,"xmin")
-            if xmin=="notfound":
-                xmin=tmp[3]
-
-            xmax=self.getPar(name2,"xmax")
-            if xmax=="notfound":
-                xmax=tmp[4]
-            
-            print "XMIN =", xmin
-            print "XMAX =", xmax
-
-            
-            if len(tmp)==7:
-                h=myHist(tmp[0],tmp[1],tmp[2],xmin,xmax,tmp[5],tmp[6])
-            else:
-                h=myHist(tmp[0],tmp[1],tmp[2],xmin,xmax,tmp[5],'')
-            hists.append(h)
-        file.close()
-        
-        rootFile = ROOT.TFile(ROOTntuple,'READ')
-        mytree = ROOT.gDirectory.Get('CollectionTree')
-        mytree.UseCurrentStyle()
-
-        hfile = ROOT.TFile("Cluster.hist","RECREATE","Clusters hist")
-        for h in hists:
-            self.logger.debug(h.getHistName(),',',h.getHistComment(),',',h.getHistBins(),',',h.getHistMinX(),',',h.getHistBins(),',',h.getHistMaxX())
-            m_h = ROOT.TH1F(h.getHistName(),h.getHistComment(),int(h.getHistBins()),float(h.getHistMinX()),float(h.getHistMaxX()))
-            mytree.Draw(h.getHistFormula(),h.getHistCondForm())
-            mytree.Draw(h.getHistFormula()+'>>'+h.getHistName(),h.getHistCondForm())
-            self.normH(m_h)
-            hfile.Write()
-        
-        rootFile.Close()
-        
-    def getFilePar(self):
-        com="grep RTTINFO MYRTTINFOS.txt | cut -d= -f2 | tail -n1"
-        res,testName=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(testName)
-            return -1
-        
-        nTestName=''
-        for i in testName:
-            if i !=' ':
-                nTestName+=i;
-
-        filePar=nTestName+".par";
-        com="wget http://cern.ch/CaloRTT/"+filePar;
-        print com
-        res,out=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(out)
-            return -1
-        return filePar
-
-
-    def getFileRef(self):
-        com="grep RTTINFO MYRTTINFOS.txt | cut -d= -f2 | tail -n1"
-        res,testName=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(testName)
-            return -1
-        
-        nTestName=''
-        for i in testName:
-            if i !=' ':
-                nTestName+=i;
-
-        fileRef='ref'+nTestName+".hist"
-        com="wget http://cern.ch/CaloRTT/"+fileRef
-        res,out=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(out)
-            return -1
-        return fileRef
-
-    def initHTMLDraw(self):
-        f=open("DrawHistos.html","w")
-        f.write("<html><head><title>Draw</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head>")
-        f.write("<body>")
-        f.close();
-        
-    def closeHTMLDraw(self):
-        f=open("DrawHistos.html","a")
-        f.write("</body>")
-        f.write("</html>")
-
-
-    def initHTMLComparison(self):
-        f=open("Comparison.html","w")
-        f.write("<html><head><title>Draw</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head>")
-        f.write("<body>")
-        f.close();
-        
-    def closeHTMLComparison(self):
-        f=open("Comparison.html","a")
-        f.write("</body>")
-        f.write("</html>")
-
-    def Draw(self,histFile):
-        self.initHTMLDraw()
-        file = ROOT.TFile(histFile)
-        for i in file.GetListOfKeys():
-            self.DrawHisto(i.ReadObj())
-        file.Close()
-        self.closeHTMLDraw()
-
-
-    def DrawHisto(self,hist):
-        f=open("DrawHistos.html","a")
-
-        tmp=hist.GetTitle()
-        name=""
-        for i in tmp:
-            if i==' ':
-                i='_'
-            if i=='(':
-                i='z'
-            if i==')':
-                i='z'
-            name+=i
-
-        ROOT.gStyle.SetOptStat(ROOT.kFALSE)
-        can=ROOT.TCanvas()
- 
-        hist.Draw()
-
-        legend=ROOT.TLegend(0.7,0.7,0.89,0.85)
-        legend.SetTextFont(72)
-        legend.SetTextSize(0.04)
- 
-        legend.AddEntry(hist,"NEW","l")
-        legend.Draw()
- 
-        can.Modified()
-        can.Update()
-
-        epsname=name+".eps"
-        gifname=name+".gif"
-
-        can.SaveAs(epsname)
-
-        com1='pstopnm -ppm -xborder 0 -yborder 0 -portrait '+epsname
-        com2='ppmtogif '+epsname+'001.ppm >'+gifname
-        
-        os.system(com1)
-        os.system(com2)
-        
-        f.write("<CENTER><BR>")
-        f.write("Name : "+hist.GetTitle()+'<BR>')
-        f.write("<BR>")
-        f.write("<TABLE border=1>")
-        f.write("<TR>")
-        f.write("<TD>Entries</TD>")
-        f.write("<TD>"+str(hist.GetEntries())+'</TD>')
-        f.write("</TR>")      
-        f.write("<TR>")
-        f.write("<TD>Mean</TD>")
-        f.write("<TD>"+str(hist.GetMean())+'</TD>')
-        f.write("</TR>")        
-        f.write("<TR>")
-        f.write("<TD>RMS</TD>")
-        f.write('<TD>'+str(hist.GetRMS())+'</TD>')
-        f.write("</TR>")       
-        f.write("</TABLE>")       
-        f.write("<IMG SRC=\""+gifname+'\"><BR>')
-        f.write('<HR><BR>')
-        f.close()
-
-    def almostIdentical(self,hist,refhist,filePar):
-        f=open("Comparison.html","a")
-
-        tmp=hist.GetTitle()
-        name=""
-        for i in tmp:
-            if i==' ':
-                i='_'
-            if i=='(':
-                i='z'
-            if i==')':
-                i='z'
-            name+=i
-
-        ROOT.gStyle.SetOptStat(ROOT.kFALSE)
-        can=ROOT.TCanvas()
-
-        hist.SetLineColor(2)
-        hist.SetLineStyle(2)
-        hist.Draw()
-        if hist:
-            refhist.Draw("sames")
-        else:
-            refhist.Draw()
-
-        legend=ROOT.TLegend(0.7,0.7,0.89,0.85)
-        legend.SetTextFont(72)
-        legend.SetTextSize(0.04)
- 
-        legend.AddEntry(hist,"NEW","l")
-        legend.AddEntry(refhist,"REF","l");
-        legend.Draw()
- 
-        can.Modified()
-        can.Update()
-
-        epsname=name+".eps"
-        gifname=name+".gif"
-
-        can.SaveAs(epsname)
-
-        com1='pstopnm -ppm -xborder 0 -yborder 0 -portrait '+epsname
-        com2='ppmtogif '+epsname+'001.ppm >'+gifname
-        
-        os.system(com1)
-        os.system(com2)
-
-        restxt=open('Comparison.txt','a')
-        
-        f.write("<CENTER><BR>")
-        f.write("Name : "+hist.GetTitle()+'<BR>')
-        f.write("<BR>")
-        f.write("<TABLE border=1>")
-        f.write("<TR>")
-        f.write("<TD></TD>")
-        f.write("<TD>REF</TD>");
-        f.write("<TD>NEW</TD>")
-        f.write("</TR>")
-        
-        f.write("<TD>Entries</TD>")
-        f.write("<TD>"+str(refhist.GetEntries())+'</TD>')
-        f.write("<TD>"+str(hist.GetEntries())+'</TD>')
-        f.write("</TR>")      
-        f.write("<TR>")
-        f.write("<TD>Mean</TD>")
-        f.write("<TD>"+str(refhist.GetMean())+'</TD>')
-        f.write("<TD>"+str(hist.GetMean())+'</TD>')
-        f.write("</TR>")        
-        f.write("<TR>")
-        f.write("<TD>RMS</TD>")
-        f.write('<TD>'+str(refhist.GetRMS())+'</TD>')
-        f.write('<TD>'+str(hist.GetRMS())+'</TD>')
-        f.write("</TR>")       
-        f.write("</TABLE>")       
-        f.write("<IMG SRC=\""+gifname+'\"><BR>')
-
-        com="grep \"RTTParm_almostIdentical_"+name+ " \"  "+filePar+ "| cut -d= -f2 | tail -n1"
-        res,max=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error('Problem to the par of '+name+' : '+max)
-            return -1
-
-        dA=0.
-        A=0.
-        for k  in range(0,hist.GetNbinsX()+1):
-            dA += float(hist.GetBinContent(k) - refhist.GetBinContent(k))
-            A += hist.GetBinContent(k)
-
-        if (A > 0):
-            dA = dA / A;
-
-  
-        restxt.write('&Sigma;(|&Delta;A|)/&Sigma;A is '+str(dA)+' (cut is '+str(max)+')\n')
-        f.write("<BR>")
-        f.write('&Sigma;(|&Delta;A|)/&Sigma;A is '+str(dA)+' (cut is '+str(max)+')\n')
-        f.write("<BR>")
- 
-        if ( dA <= max ):
-            restxt.write("TEST OK\n")
-            restxt.write("###################################\n")
-            f.write("<font color=\"green\">TEST OK<BR></font>")
-            f.write("<HR>")
-            f.write("</CENTER><BR>")
-            f.close()
-            restxt.close()
-            return 0
-        else:
-            restxt.write("TEST FAILED\n")
-            restxt.write("###################################\n")
-            f.write("<font color=\"red\">TEST FAILED</font><BR>")
-            f.write("<HR>")
-            f.write("</CENTER><BR>")
-            f.close()
-            restxt.close()
-            return -1
-
-
-    def testHistogram(self,hists,refhists,compType,filePar):
-        self.logger.info('---- testHistogram '+str(hists.GetTitle())+' ----')
-        if compType == "almostIdentical":
-            res=self.almostIdentical(hists,refhists,filePar)
-            return res
-        else:
-            self.logger.error('Comp type not known')
-            return -1
-        return 0
-
-    def histComparison(self,hist,refhist,compType,filePar):
-        self.initHTMLComparison()
-        fhists = ROOT.TFile(hist); 
-        frefhists = ROOT.TFile(refhist);
-
-        if len(fhists.GetListOfKeys())!=len(frefhists.GetListOfKeys()):
-            self.logger.warning('the ref and new file doesnt contain the same number of histograms')
-            self.Draw('Cluster.hist')
-            return 0
-            
-        if len(fhists.GetListOfKeys())==0:
-            self.logger.error('No histograms in the new file')
-            return -1
-
-        failed=[]
-        hists=[]
-        refHists=[]
-        for i in fhists.GetListOfKeys():
-            hists.append(i.ReadObj())
-        for i in frefhists.GetListOfKeys():
-            refHists.append(i.ReadObj())
-
-        for k in range(1,len(hists)):
-            if self.testHistogram(hists[k],refHists[k],compType,filePar)!=0:
-                failed.append(hists[k].GetName())
-                self.logger.error(hists[k].GetTitle()+' FAILED')
-            else:
-                self.logger.info(hists[k].GetTitle()+' OK')
-            self.logger.info('---- testHistogram DONE ----')
-            self.closeHTMLComparison()  
-        if len(failed)==0:
-            return 0
-        else:
-            return -1
-            
-    def run(self):
-        self.filePar=self.getFilePar()
-        if self.filePar==-1:
-            self.logger.error('getFilePar() failed')
-            return -1
-        
-        self.makeHist('ntuple.root')
-
-        
-        fileRef=self.getFileRef()
-        if fileRef==-1:
-            self.logger.warning('getFileRef() failed')
-            self.logger.info('drawing the histos instead')
-            self.Draw('Cluster.hist')
-            return 0
-        
-        res=self.histComparison('Cluster.hist',fileRef,"almostIdentical");
-        return res
-#a=HistosComparison(logging.INFO)
-#a.run()
diff --git a/Calorimeter/CaloExample/CaloTests/share/HistoComparison.txt b/Calorimeter/CaloExample/CaloTests/share/HistoComparison.txt
deleted file mode 100755
index ae390019addb9c80f2b6ee0ceda5e9c2ed5b3afc..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/HistoComparison.txt
+++ /dev/null
@@ -1,32 +0,0 @@
-m_h1,Cluster E (GeV),50,0.,1000.,cl_et*cosh(cl_eta)/1000
-m_h2,Cluster E (GeV) - barrel,50,0.,1000.,cl_et*cosh(cl_eta)/1000,abs(cl_eta)<1.475
-m_h3,Cluster E (GeV) - endcap,50,0.,1000.,cl_et*cosh(cl_eta)/1000,abs(cl_eta)>=1.475
-m_h4,Cluster eta,40,-2.5,2.5,cl_eta
-m_h5,Cluster phi,25,-7.,7.,cl_phi
-m_h6,number of clusters,6,-.5,5.5,cl_nc
-m_h7,E frac. in Presampler - barrel,50,0.,1.,cl_eemb0/(cl_eemb0+cl_eemb1+cl_eemb2+cl_eemb3),abs(cl_eta)<1.475
-m_h8,E frac. in 1st samp. - barrel,50,0.,1.,cl_eemb1/(cl_eemb0+cl_eemb1+cl_eemb2+cl_eemb3),abs(cl_eta)<1.475
-m_h9,E frac. in 2nd samp. - barrel,50,0.,1.,cl_eemb2/(cl_eemb0+cl_eemb1+cl_eemb2+cl_eemb3),abs(cl_eta)<1.475
-m_h10,E frac. in 3rd samp. - barrel,50,0.,.1,cl_eemb3/(cl_eemb0+cl_eemb1+cl_eemb2+cl_eemb3),abs(cl_eta)<1.475
-m_h11,E frac. in Presampler - endcap,50,0.,1.,cl_eeme0/(cl_eeme0+cl_eeme1+cl_eeme2+cl_eeme3),abs(cl_eta)>=1.475 && abs(cl_eta)<=1.8
-m_h12,E frac. in 1st samp. - endcap,50,0.,1.,cl_eeme1/(cl_eeme0+cl_eeme1+cl_eeme2+cl_eeme3),abs(cl_eta)>=1.475
-m_h13,E frac. in 2nd samp. - endcap,50,0.,1.,cl_eeme2/(cl_eeme0+cl_eeme1+cl_eeme2+cl_eeme3),abs(cl_eta)>=1.475
-m_h14,E frac. in 3rd samp. - endcap,50,0.,0.1,cl_eeme3/(cl_eeme0+cl_eeme1+cl_eeme2+cl_eeme3),abs(cl_eta)>=1.475
-m_h28,cl_m1_eta_topoEM430,40,-2.5,2.5,cl_m1_eta_topoEM430
-m_h29,cl_m1_phi_topoEM430,40,-3.2,3.2,cl_m1_phi_topoEM430
-m_h30,cl_m2_r_topoEM430,40,0,10000,cl_m2_r_topoEM430
-m_h31,cl_m2_lambda_topoEM430,40,0,250000,cl_m2_lambda_topoEM430
-m_h32,cl_delta_phi_topoEM430,40,-2.,2,cl_delta_phi_topoEM430
-m_h33,cl_delta_theta_topoEM430,40,-0.4,0.4,cl_delta_theta_topoEM430
-m_h34,cl_delta_alpha_topoEM430,40,0.,1.,cl_delta_alpha_topoEM430
-m_h35,cl_center_x_topoEM430,40,-2000.,2000.,cl_center_x_topoEM430
-m_h36,cl_center_y_topoEM430,40,-2000.,2000.,cl_center_y_topoEM430
-m_h37,cl_center_z_topoEM430,40,-4500.,4500.,cl_center_z_topoEM430
-m_h38,cl_center_lambda_topoEM430,40,0.,1000.,cl_center_lambda_topoEM430
-m_h39,cl_lateral_topoEM430,40,0.,1.,cl_lateral_topoEM430
-m_h40,cl_longitudinal_topoEM430,40,0.,1.,cl_longitudinal_topoEM430
-m_h41,cl_eng_frac_em_topoEM430,40,0.,1.,cl_eng_frac_em_topoEM430
-m_h42,cl_eng_frac_max_topoEM430,40,0.,1.,cl_eng_frac_max_topoEM430
-m_h43,cl_eng_frac_core_topoEM430,40,0.,1.,cl_eng_frac_core_topoEM430
-m_h44,cl_m1_dens_topoEM430,40,0.,0.5,cl_m1_dens_topoEM430
-m_h45,cl_m2_dens_topoEM430,40,0.,0.2,cl_m2_dens_topoEM430
diff --git a/Calorimeter/CaloExample/CaloTests/share/Photons50GeVChecks.py b/Calorimeter/CaloExample/CaloTests/share/Photons50GeVChecks.py
deleted file mode 100644
index d7072ea8a91dd369b8d52008f634db6414b73ea5..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/Photons50GeVChecks.py
+++ /dev/null
@@ -1,10 +0,0 @@
-
-doHistoComparison=True
-doTruth=False
-doMemLeak=True
-doextractRec=False
-docheckAODESDcontent=True
-docheckAODESDcontentAOD=True
-docheckAODESDcontentESD=True
-doaddPlotElectronicNoise=True
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/Photons50GeVmisChecks.py b/Calorimeter/CaloExample/CaloTests/share/Photons50GeVmisChecks.py
deleted file mode 100644
index d7072ea8a91dd369b8d52008f634db6414b73ea5..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/Photons50GeVmisChecks.py
+++ /dev/null
@@ -1,10 +0,0 @@
-
-doHistoComparison=True
-doTruth=False
-doMemLeak=True
-doextractRec=False
-docheckAODESDcontent=True
-docheckAODESDcontentAOD=True
-docheckAODESDcontentESD=True
-doaddPlotElectronicNoise=True
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/Pi100GeVChecks.py b/Calorimeter/CaloExample/CaloTests/share/Pi100GeVChecks.py
deleted file mode 100644
index dbf8b9b2c01c598ea27e0d6e517428865c79fecb..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/Pi100GeVChecks.py
+++ /dev/null
@@ -1,10 +0,0 @@
-
-doHistoComparison=True
-doTruth=False
-doMemLeak=True
-doextractRec=False
-docheckAODESDcontent=False
-docheckAODESDcontentAOD=False
-docheckAODESDcontentESD=False
-doaddPlotElectronicNoise=False
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/Truth.py b/Calorimeter/CaloExample/CaloTests/share/Truth.py
deleted file mode 100755
index b45380558ba7458ca7c362bbd9420f5a5bfd572f..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/Truth.py
+++ /dev/null
@@ -1,696 +0,0 @@
-#!/usr/bin/python
-
-import os,commands,sys,logging
-import ROOT
-import time,math,cmath
-
-class Truth:
-    def __init__(self,log,logLevel):
-        if log=='':
-            self.logger = logging.getLogger('Truth')
-            hdlr = logging.FileHandler('Truth.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-            
-    def getFilePar(self):
-        com="grep RTTINFO MYRTTINFOS.txt | cut -d= -f2 | tail -n1"
-        res,testName=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(testName)
-            return -1
-        
-        nTestName=''
-        for i in testName:
-            if i !=' ':
-                nTestName+=i;
-
-        filePar=nTestName+".par";
-        com="wget http://cern.ch/CaloRTT/"+filePar
-        res,out=commands.getstatusoutput(com)
-        if res!=0 :
-            self.logger.error(out)
-            return -1
-        return filePar
-
-    def initHTML(self):
-        f=open("Truth.html","w")
-        f.write("<html><head><title>Truth</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head>")
-        f.write("<body>")
-        f.close()
-
-
-        f=open("Truth.txt","w")
-        f.close()
-        
-    def closeHTML(self):
-        f=open("Truth.html","a")
-        f.write("</body>")
-        f.write("</html>")
-
-    def mysign(self,val):
-        if val<0.:
-            return -1
-        else:
-            return 1
-
-    def saveHisto(self,hist,filePar,opt):
-        html= open('Truth.html','a')
-
-        txt= open("Truth.txt","a");
-
-        tmp=hist.GetTitle()
-        name=""
-        for i in tmp:
-            if i==' ':
-                i='_'
-            if i=='(':
-                i='z'
-            if i==')':
-                i='z'
-            name+=i
-
-        com='grep RTTParm_truth_'+name+ ' '+filePar +' | cut -d= -f2 | tail -n1'
-
-        res,max=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error('Problem to the par of '+name+' : '+max)
-            return -1
-
-        can=ROOT.TCanvas()
-        # only 3 digits
-        ROOT.TGaxis.SetMaxDigits(3)
-        
-        hist.SetLineColor(2)
-        hist.SetLineStyle(2)
-        hist.Draw(opt)
-
-        txt.write("################################\n");
-        txt.write("Name : "+str(hist.GetTitle())+'\n')
-        txt.write("Mean = "+str(hist.GetMean())+'\n')
-        txt.write("RMS = "+str(hist.GetRMS())+'\n')
-
-        try:
-            float(max)
-        except:
-            max=0
-
-        isOk=0
-        if math.fabs(float(hist.GetMean())) > float(max):
-            isOk=-1
-            txt.write("TEST FAILED (lim = "+str(max)+')\n')
-        else:
-            txt.write("TEST OK (lim = "+str(max)+')\n')
-
-        can.Modified()
-        can.Update()
-
-        epsname=name+".eps"
-        gifname=name+".gif"
-
-        can.SaveAs(epsname)
-
-        com1='pstopnm -ppm -xborder 0 -yborder 0 -portrait '+epsname
-        com2='ppmtogif '+epsname+'001.ppm >'+gifname
-        
-        os.system(com1)
-        os.system(com2)
-        
-        html.write("<CENTER><BR>")
-        html.write("<BR>")
-        html.write("<IMG SRC=\""+gifname+'\"><BR>');
-        html.write("<HR>")
-
-        if isOk == -1 :
-            html.write("<BR>")
-            html.write("<CENTER><font color=red>TEST FAILED (lim = "+str(max)+")</font></CENTER>")
-        else:
-            html.write("<BR>")
-            html.write("<CENTER><font color=green>TEST OK (lim = "+str(max)+")</font></CENTER>")
-            html.write("<BR>")
-        html.write("<HR>")
-        
-        html.close()
-        txt.close()
-
-        return isOk
-
-    def doElectrons(self,filePar):
-        self.initHTML()
-        
-        #f = ROOT.TFile('ntuple.root')
-        #f.cd('CollectionTree')
-        #mytree=ROOT.gDirectory.Get('CollectionTree')
-
-        ##################################
-        #os.system('ls data/*root.* > ntuples.txt')
-        os.system('ls ntuple.root > ntuples.txt')
-        
-        f=open('ntuples.txt','r')
-        lines=f.readlines()
-        f.close()
-
-        chain = ROOT.TChain('CollectionTree')
-
-        for li in lines:
-            chain.Add('./'+li.strip())
-
-        mytree=chain
-        #################################
-
-        m_drmin  = ROOT.TH1F("m_drmin","drmin",100,-0.2,0.2)
-        m_h1   = ROOT.TH1F("m_h1","Energy resolution",100,-0.25,0.25)
-        m_h1.SetXTitle("(E_{t}(reco)-E_{t}(true))/E_{t}(true)")
-
-        m_h2   = ROOT.TH1F("m_h2","Phi resolution",100,-0.01,0.01)
-        m_h2.SetXTitle("#Phi resolution (rad)")
-
-        m_h3   = ROOT.TH1F("m_h3","Eta resolution in the barrel",100,-0.01,0.01)
-        m_h3.SetXTitle("#eta resolution")
-        
-        m_h4   = ROOT.TH1F("m_h4","Eta resolution in the endcap",100,-0.01,0.01)
-        m_h4.SetXTitle("#eta resolution")
-
-        m_h5   = ROOT.TH1F("m_h5","Efficiency vs eta",50,-3,3)  
-        m_h5.SetXTitle("#eta")
-
-        m_tmp1   = ROOT.TH1F("m_tmp1","EtaGen",50,-3,3)
-        m_tmp2  = ROOT.TH1F("m_tmp2","cl_eta",50,-3,3) 
-
-        entries=mytree.GetEntriesFast()
-
-        for jentry in xrange( entries ):
-            ientry=mytree.LoadTree( jentry )
-            if ientry < 0 :
-                break
-
-            nb=mytree.GetEntry(jentry)
-            if nb<=0:
-                continue
-            
-            nEvent = int(mytree.IEvent)
-            if nEvent<0:
-                continue
-
-            indEle=[]
-            iele=0
-            for ipart in range(0,mytree.NPar):
-                if abs((mytree.Type)[ipart])==11 and (mytree.GenStat)[ipart]==1 and (mytree.KMothNt)[ipart]==-1:
-                    indEle.append(ipart)
-                    m_tmp2.Fill((mytree.EtaGen)[indEle[iele]])
-
-                    iele+=1
-
-                    if iele>1:
-                        logger.info('two many electrons')
-                        return -1
-
-            nele=iele
-
-            # a quel cluster correspond quel electron ?
-            # je tourne sur ts les clusters de l ev
-            for ic in range(0,mytree.cl_nc): 
-                etacl = (mytree.cl_eta)[ic]
-                phicl = (mytree.cl_phi)[ic]
-                etcl  = (mytree.cl_et)[ic]
-
-                m_drmin.Fill((mytree.ZV)[0]);
-                etae = (mytree.EtaGen)[indEle[0]];
-                if math.fabs((mytree.cl_eta)[ic])>1.475 :
-                    etaclcor = cmath.asinh(cmath.sinh((mytree.cl_eta)[ic])*(1-(mytree.ZV)[mytree.IVPrimary]/(self.mysign((mytree.cl_eta)[ic])*3800.0)))
-                    phiclcor = (mytree.cl_phi)[ic]+(0.3*3800.0*(-(mytree.Type)[indEle[0]]/11.0)*self.mysign((mytree.cl_eta)[ic]))/((mytree.cl_et)[ic]*cmath.sinh((mytree.cl_eta)[ic]))
-                    m_h4.Fill((etaclcor-etae).real)
-                else:
-                    etaclcor = cmath.asinh(cmath.sinh((mytree.cl_eta)[ic])-(mytree.ZV)[mytree.IVPrimary]/1600.0)
-                    m_h3.Fill((etaclcor-etae).real)
-                    phiclcor = (mytree.cl_phi)[ic]+(0.3*1600.0*(-(mytree.Type)[indEle[0]]/11.0)/(mytree.cl_et)[ic])
-
-                phie = (mytree.PhiGen)[indEle[0]]
-                ete  = (mytree.PtGen)[indEle[0]]
-                
-                try:
-                    m_h2.Fill(phiclcor.real-phie)
-                except:
-                    m_h2.Fill(phiclcor-phie)
-                m_h1.Fill((etcl-ete)/ete)
-
-                m_tmp1.Fill(etae)
-
-        ROOT.gStyle.SetOptFit(1011)
-
-        m_h1.Fit("gaus")
-        m_h2.Fit("gaus")
-        m_h3.Fit("gaus")
-        m_h4.Fit("gaus")
-    		    
-        res1=self.saveHisto(m_h1,filePar,'')
-        res2=self.saveHisto(m_h2,filePar,'')
-        res3=self.saveHisto(m_h3,filePar,'')
-        res4=self.saveHisto(m_h4,filePar,'')
-        m_h5.Divide(m_tmp1,m_tmp2,1,1,"B")
-        
-	res5=self.saveHisto(m_h5,filePar,"E")
-
-        if res1==-1 or res2==-1 or res3==-1 or res4==-1 or res5==-1: 
-            return -1
-        else:
-            return 0
-            
-    def doTop(self,filePar):
-        self.initHTML()
-        
-        f = ROOT.TFile('ntuple.root')
-        #f.cd('CollectionTree')
-        mytree=ROOT.gDirectory.Get('CollectionTree')
-
-        m_drmin  = ROOT.TH1F("m_drmin","drmin",100,-0.2,0.2)
-        m_h1   = ROOT.TH1F("m_h1","Energy resolution",100,-0.25,0.25)
-        m_h1.SetXTitle("(E_{t}(reco)-E_{t}(true))/E_{t}(true)")
-
-        m_h2   = ROOT.TH1F("m_h2","Phi resolution",100,-0.01,0.01)
-        m_h2.SetXTitle("#Phi resolution (rad)")
-
-        m_h3   = ROOT.TH1F("m_h3","Eta resolution in the barrel",100,-0.01,0.01)
-        m_h3.SetXTitle("#eta resolution")
-        
-        m_h4   = ROOT.TH1F("m_h4","Eta resolution in the endcap",100,-0.01,0.01)
-        m_h4.SetXTitle("#eta resolution")
-
-        m_h5   = ROOT.TH1F("m_h5","Efficiency vs eta",50,-3,3)  
-        m_h5.SetXTitle("#eta")
-
-        m_tmp1   = ROOT.TH1F("m_tmp1","EtaGen",50,-3,3)
-        m_tmp2  = ROOT.TH1F("m_tmp2","cl_eta",50,-3,3) 
-
-        entries=mytree.GetEntriesFast()
-
-        for jentry in xrange( entries ):
-            ientry=mytree.LoadTree( jentry )
-            if ientry < 0 :
-                break
-
-            nb=mytree.GetEntry(jentry)
-            if nb<=0:
-                continue
-            
-            nEvent = int(mytree.IEvent)
-            if nEvent<0:
-                continue
-
-            indEle=[]
-            iele=0
-            for ipart in range(0,mytree.NPar):
-                if  abs((mytree.Type)[ipart])==11 and abs((mytree.Type)[(mytree.KMothNt)[ipart]])==24 :
-			#indEle[iele]=ipart
-                        indEle.append(ipart)
-			m_tmp2.Fill((mytree.EtaGen)[indEle[iele]])
-			iele=+1
-                        if iele>4:
-                            logger.info('two many electrons')
-                            return -1
-
-            nele=iele
-
-            # a quel cluster correspond quel electron ?
-            # je tourne sur ts les clusters de l ev
-            for ic in range(0,mytree.cl_nc): 
-                drmin = 9999.
-                im    = 0
-
-                # pour un cluster donne je tourne sur tous les electrons primaires trouves precedemment et je minimise dr pour savoir celui qui est le plus pres du cluster 
-                for iele in range(0,nele):
-                    deta = (mytree.EtaGen)[indEle[iele]] - (mytree.cl_eta)[ic];
-                    dphi = (mytree.PhiGen)[indEle[iele]] - (mytree.cl_phi)[ic];
-                    
-                    if dphi > math.pi: 
-                        dphi = math.fabs(dphi) - 2.*math.pi
-                    dr = math.sqrt(dphi*dphi + deta*deta)
-
-                    if dr < drmin:
-                        drmin = dr
-                        im    = iele
-
-                # l'electron matchant le cluster a l'indice im
-
-                m_drmin.Fill(drmin);
-
-                if drmin < 0.1  : 
-                    etacl = (mytree.cl_eta)[ic]
-                    phicl = (mytree.cl_phi)[ic]
-                    etcl  = (mytree.cl_et)[ic]
-                    etae = (mytree.EtaGen)[indEle[im]]
-                    if math.fabs((mytree.cl_eta)[ic])>1.475 :
-                        etaclcor = cmath.asinh(cmath.sinh((mytree.cl_eta)[ic])*(1-(mytree.ZV)[mytree.IVPrimary]/(self.mysign((mytree.cl_eta)[ic])*3800.0)));
-                        phiclcor = (mytree.cl_phi)[ic]+(0.3*3800*(-(mytree.Type)[indEle[im]]/11.0)*self.mysign((mytree.cl_eta)[ic]))/((mytree.cl_et)[ic]*cmath.sinh((mytree.cl_eta)[ic]));
-                        m_h4.Fill((etaclcor-etae).real)
-                    else:
-                        etaclcor = cmath.asinh(cmath.sinh((mytree.cl_eta)[ic])-(mytree.ZV)[mytree.IVPrimary]/1600.0)
-                        phiclcor = (mytree.cl_phi)[ic]+(0.3*1600.0*(-(mytree.Type)[indEle[im]]/11.0)/(mytree.cl_et)[ic])
-                        m_h3.Fill((etaclcor-etae).real)
-
-                    phie = (mytree.PhiGen)[indEle[im]]
-                    ete  = (mytree.PtGen)[indEle[im]]
-
-                    try:
-                        m_h2.Fill(phiclcor.real-phie)
-                    except:
-                        m_h2.Fill(phiclcor-phie)
-                    m_h1.Fill((etcl-ete)/ete)	 
-                    m_tmp1.Fill(etae)
-
-
-        ROOT.gStyle.SetOptFit(1011)
-
-        m_h1.Fit("gaus")
-        m_h2.Fit("gaus")
-        m_h3.Fit("gaus")
-        m_h4.Fit("gaus")
-    		    
-        res1=self.saveHisto(m_h1,filePar,'')
-        res2=self.saveHisto(m_h2,filePar,'')
-        res3=self.saveHisto(m_h3,filePar,'')
-        res4=self.saveHisto(m_h4,filePar,'')
-        m_h5.Divide(m_tmp1,m_tmp2,1,1,"B")
-        
-	res5=self.saveHisto(m_h5,filePar,"E")
-
-        if res1==-1 or res2==-1 or res3==-1 or res4==-1 or res5==-1: 
-            return -1
-        else:
-            return 0
-    
-    def doPhotons(self,filePar):
-        self.initHTML()
-        
-        #f = ROOT.TFile('ntuple.root')
-        #f.cd('CollectionTree')
-        #mytree=ROOT.gDirectory.Get('CollectionTree')
-
-        ##################################
-        #os.system('ls photons/*root* > ntuples.txt')
-        os.system('ls ntuple.root > ntuples.txt')
-        f=open('ntuples.txt','r')
-        lines=f.readlines()
-        f.close()
-
-        chain = ROOT.TChain('CollectionTree')
-
-        for li in lines:
-            chain.Add('./'+li.strip())
-
-        mytree=chain
-        #################################
-
-        m_drmin  = ROOT.TH1F("m_drmin","drmin",100,-0.2,0.2)
-        m_h1   = ROOT.TH1F("m_h1","Energy resolution",100,-0.25,0.25)
-        m_h1.SetXTitle("(E_{t}(reco)-E_{t}(true))/E_{t}(true)")
-
-        m_h2   = ROOT.TH1F("m_h2","Phi resolution",100,-0.01,0.01)
-        m_h2.SetXTitle("#Phi resolution (rad)")
-
-        m_h3   = ROOT.TH1F("m_h3","Eta resolution in the barrel",100,-0.01,0.01)
-        m_h3.SetXTitle("#eta resolution")
-        
-        m_h4   = ROOT.TH1F("m_h4","Eta resolution in the endcap",100,-0.01,0.01)
-        m_h4.SetXTitle("#eta resolution")
-
-        m_h5   = ROOT.TH1F("m_h5","Efficiency vs eta",50,-3,3)  
-        m_h5.SetXTitle("#eta")
-
-        m_tmp1   = ROOT.TH1F("m_tmp1","EtaGen",50,-3,3)
-        m_tmp2  = ROOT.TH1F("m_tmp2","cl_eta",50,-3,3) 
-
-        entries=mytree.GetEntriesFast()
-
-        for jentry in xrange( entries ):
-            ientry=mytree.LoadTree( jentry )
-            if ientry < 0 :
-                break
-            nb=mytree.GetEntry(jentry)
-            if nb<=0:
-                continue          
-            nEvent = int(mytree.IEvent)
-            if nEvent<0:
-                continue
-            dRmin = 999.
-            TheNearestCluster = -1
-
-            #print int(mytree.IEvent),int(mytree.cl_nc),len(mytree.PtGen)
-            if mytree.cl_nc==0 or len(mytree.PtGen)==0:
-                continue
-            for i in range(0,int(mytree.cl_nc)):
-                #print 'i=',i
-                dphi = 1000.
-                deta = 1000.
-	       
-                # resolution in energy
-                val=((mytree.cl_et)[i]-(mytree.PtGen)[0])/(mytree.PtGen)[0]
-                
-                m_h1.Fill(val)        
-                # resolution in phi
-                if  (mytree.cl_phi)[i]-(mytree.PhiGen)[0] < 6: 
-                    dphi =((mytree.cl_phi)[i]-(mytree.PhiGen)[0])
-                    m_h2.Fill(dphi)
-
-                # resolution in eta barrel corrected by the z vertex spread
-                deta=0.
-                if  math.fabs((mytree.EtaGen)[0])<1.475:
-                    deta =(mytree.cl_eta)[i]-cmath.asinh(cmath.sinh((mytree.EtaGen)[0])+(mytree.ZV)[mytree.IVPrimary]/1600.)
-                    m_h3.Fill(deta.real)
-                elif math.fabs((mytree.EtaGen)[0])>= 1.475 :
-                    deta = (mytree.cl_eta)[i]-cmath.asinh(cmath.sinh((mytree.EtaGen)[0])/(1-self.mysign((mytree.EtaGen)[0])*(mytree.ZV)[mytree.IVPrimary]/3800.))
-                    
-                    m_h4.Fill(deta.real)
-		
-                if (math.fabs(dphi) > math.pi):
-                    dphi = 2.0*math.pi - math.fabs(dphi)
-                dR = math.sqrt(deta.real*deta.real+dphi*dphi)
-                if dR < dRmin:
-                    dRmin = dR
-                    TheNearestCluster = i
-	      
-	    
-            m_tmp2.Fill((mytree.EtaGen)[0])
-            if TheNearestCluster >= 0 and dRmin < 0.1:
-                m_tmp1.Fill((mytree.EtaGen)[0])
-
-        ROOT.gStyle.SetOptFit(1011)
-
-        m_h1.Fit("gaus")
-        m_h2.Fit("gaus")
-        m_h3.Fit("gaus")
-        m_h4.Fit("gaus")
-    		    
-        res1=self.saveHisto(m_h1,filePar,'')
-        res2=self.saveHisto(m_h2,filePar,'')
-        res3=self.saveHisto(m_h3,filePar,'')
-        res4=self.saveHisto(m_h4,filePar,'')
-        m_h5.Divide(m_tmp1,m_tmp2,1,1,"B")
-        
-	res5=self.saveHisto(m_h5,filePar,"E")
-
-        if res1==-1 or res2==-1 or res3==-1 or res4==-1 or res5==-1: 
-            return -1
-        else:
-            return 0
-
-    def doPions(self,filePar):
-        self.initHTML()
-        
-        #f = ROOT.TFile('ntuple.root')
-        #f.cd('CollectionTree')
-        #mytree=ROOT.gDirectory.Get('CollectionTree')
-
-        ##################################
-        #os.system('ls pions/*root* > ntuples.txt')
-        os.system('ls ntuple.root > ntuples.txt')
-        f=open('ntuples.txt','r')
-        lines=f.readlines()
-        f.close()
-
-        chain = ROOT.TChain('CollectionTree')
-
-        for li in lines:
-            chain.Add('./'+li.strip())
-
-        mytree=chain
-        #################################
-
-        m_drmin  = ROOT.TH1F("m_drmin","drmin",100,-0.2,0.2)
-        m_h1   = ROOT.TH1F("m_h1","Energy resolution",100,-0.5,0.5)
-        m_h1.SetXTitle("(p_{t}(reco)-p_{t}(true))/p_{t}(true)")
-
-        m_h2   = ROOT.TH1F("m_h2","Phi resolution",100,-0.08,0.08)
-        m_h2.SetXTitle("#Phi resolution (rad)")
-
-        m_h3   = ROOT.TH1F("m_h3","Eta resolution in the barrel",100,-0.1,0.1)
-        m_h3.SetXTitle("#eta resolution")
-        
-        m_h4   = ROOT.TH1F("m_h4","Eta resolution in the endcap",100,-0.1,0.1)
-        m_h4.SetXTitle("#eta resolution")
-
-        m_h5   = ROOT.TH1F("m_h5","Efficiency vs eta",50,-3,3)  
-        m_h5.SetXTitle("#eta")
-
-        m_tmp1   = ROOT.TH1F("m_tmp1","EtaGen",50,-3,3)
-        m_tmp2  = ROOT.TH1F("m_tmp2","cl_eta",50,-3,3) 
-
-        entries=mytree.GetEntriesFast()
-
-        for jentry in xrange( entries ):
-            ientry=mytree.LoadTree( jentry )
-            if ientry < 0 :
-                break
-
-            nb=mytree.GetEntry(jentry)
-            if nb<=0:
-                continue
-            
-            nEvent = int(mytree.IEvent)
-            if nEvent<0:
-                continue
-
-#            print 'nevent=',nEvent
-
-            indPi=[]
-            ipi=0
-
-#            print ' mytree.NPar=',mytree.NPar
-
-            for ipart in range(0,mytree.NPar):
-                if  (mytree.KMothNt)[ipart]<0 and (abs((mytree.Type)[ipart])==111 or abs((mytree.Type)[ipart])==211) :
-#                    print ' mother=',(mytree.KMothNt)[ipart]
-#                    print ' (mytree.Type)[ipart]=',(mytree.Type)[ipart]
-                    indPi.append(ipart)
-                    m_tmp2.Fill((mytree.EtaGen)[indPi[ipi]])
-                    ipi=ipi+1
-                    if ipi>4:
-                        logger.info('two many pions')
-                        return -1
-
-#            print 'ipi=',ipi
-
-            if ipi>0:
-#                print ' pion type=', abs((mytree.Type)[indPi[0]])
-#                print ' # of ConeH1TowerJets=', mytree.Cone7H1TowerJetsjetNum
-#                print ' # of ConeH1TopoJets=', mytree.Cone7H1TopoJetsjetNum
-                if abs((mytree.Type)[indPi[0]])==111:
-                    ncl=0
-#                    print ' mytree.cl_nc=',mytree.cl_nc
-                    for ic in range(0,mytree.cl_nc): 
-                        etacl = (mytree.cl_eta)[ic]
-                        phicl = (mytree.cl_phi)[ic]
-                        etcl  = (mytree.cl_et)[ic]
-                        ncl = ncl +1
-#                        print ' cluster etcl,etacl,phicl=',etcl,etacl,phicl
-#                        print ' gen et,etacl,phicl=',(mytree.PtGen)[0],(mytree.EtaGen)[0],(mytree.PhiGen)[0]
-                        
-                        etae = (mytree.EtaGen)[indPi[0]]
-                        if math.fabs((mytree.cl_eta)[ic])>1.475 :
-                            m_h4.Fill(etacl-etae)                   
-                        else:
-                            m_h3.Fill(etacl-etae)
-                        
-                        phie = (mytree.PhiGen)[indPi[0]]
-                        ete  = (mytree.PtGen)[indPi[0]]
-
-                        try:
-                            m_h2.Fill(phicl.real-phie)
-                        except:
-                            m_h2.Fill(phicl-phie)
-
-                        m_h1.Fill((etcl-ete)/ete)	 
-                        m_tmp1.Fill(etae)
- 
-#                        print ' nclusters=',ncl
-
-#                if abs((mytree.Type)[indPi[0]])==211 and mytree.Cone7H1TowerJetsjetNum>0 :
-                if abs((mytree.Type)[indPi[0]])==211 and mytree.Cone7H1TopoJetsjetNum>0 :
-
-#                    print ' number of jets =', mytree.Cone7H1TopoJetsjetNum
-#                    print ' jet and topo gen e =',(mytree.jetEtCone7H1TopoJets)[0],(mytree.PtGen)[indPi[0]]
-#                    print ' jet and gen eta=',(mytree.jetEtaCone7H1TopoJets)[0],(mytree.EtaGen)[0]
-#                    print ' jet and gen phi=',(mytree.jetPhiCone7H1TopoJets)[0],(mytree.PhiGen)[0]
-                        
-                    etajet = (mytree.jetEtaCone7H1TopoJets)[0]
-                    phijet = (mytree.jetPhiCone7H1TopoJets)[0]
-                    etjet  = (mytree.jetEtCone7H1TopoJets)[0]
-                    
-                    etae = (mytree.EtaGen)[indPi[0]]
-                    if abs(etajet)>1.475 :
-                        m_h4.Fill(etajet-etae)   
-                    else:
-                        m_h3.Fill(etajet-etae)
-                        
-                    phie = (mytree.PhiGen)[indPi[0]]
-                    ete  = (mytree.PtGen)[indPi[0]]
-                        
-                    try:
-                        m_h2.Fill(phijet.real-phie)
-                    except:
-                        m_h2.Fill(phijet-phie)
-                        
-                    m_h1.Fill((etjet-ete)/ete)	 
-                    m_tmp1.Fill(etae)
-        
-        ROOT.gStyle.SetOptFit(1011)
-
-        m_h1.Fit("gaus")
-        m_h2.Fit("gaus")
-        m_h3.Fit("gaus")
-        m_h4.Fit("gaus")
-    		    
-        res1=self.saveHisto(m_h1,filePar,'')
-        res2=self.saveHisto(m_h2,filePar,'')
-        res3=self.saveHisto(m_h3,filePar,'')
-        res4=self.saveHisto(m_h4,filePar,'')
-        m_h5.Divide(m_tmp1,m_tmp2,1,1,"B")
-        
-	res5=self.saveHisto(m_h5,filePar,"E")
-
-        if res1==-1 or res2==-1 or res3==-1 or res4==-1 or res5==-1: 
-            return -1
-        else:
-            return 0
-
-
-    def run(self):
-
-        ROOT.gROOT.Reset()
-        ROOT.gStyle.SetStatW(0.19)
-        ROOT.gStyle.SetStatFontSize(0.03)
-        ROOT.gStyle.SetOptStat(111110)
-
-        filePar=self.getFilePar()
-        if filePar==-1:
-            self.logger.error('getFilePar() failed')
-            return
-
-        
-        if filePar.find('Photons')>=0:
-            return self.doPhotons(filePar)
-            
-        if filePar.find('Electrons')>=0:
-            return self.doElectrons(filePar)
-            
-        if filePar.find('Top')>=0 or filePar.find('top')>=0:
-            return self.doTop(filePar)
-
-        if filePar.find('Pi')>=0:
-            return self.doPions(filePar)
-
-        # if filePar.find('Zee')>=0:
-        #    return self.doZee(filePar)
-
-        # if filePar.find('H2e2mu')>=0:
-        #    return self.doH2e2mu(filePar)
-
-        
-            
-
-
-#a=Truth(logging.INFO)
-#a.run()
diff --git a/Calorimeter/CaloExample/CaloTests/share/addHTML.py b/Calorimeter/CaloExample/CaloTests/share/addHTML.py
deleted file mode 100755
index af862a3e473daee5ed9a16c5e8e86b593ed2213b..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/addHTML.py
+++ /dev/null
@@ -1,34 +0,0 @@
-#!/usr/bin/python
-
-import commands,sys,os,logging
-
-
-class addHTML:
-    def __init__(self,log,logLevel,plotname,filename):
-        self.filename=filename
-        self.plotname=plotname
-        if log=='':
-            self.logger = logging.getLogger('addHTML')
-            hdlr = logging.FileHandler('addHTML.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-            
-    def run(self):
-
-       
-        file = open('./'+self.filename+'.html','w')
-        txt='<html><head><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head><body>'
-        txt+='<br><br><br><br>'
-        txt+='<img src=\"'+self.plotname+'.gif\">'+'</center></body></html>'
-        file.write(txt)
-        file.close()
-
-    
-        
-#a=addHTML('',logging.INFO,'plotAllCaloNoise13','ElectronicNoise')
-#a.run()
-    
diff --git a/Calorimeter/CaloExample/CaloTests/share/check.py b/Calorimeter/CaloExample/CaloTests/share/check.py
deleted file mode 100755
index 9bf69beda68589a242c155df25115d95611ac4c1..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/check.py
+++ /dev/null
@@ -1,166 +0,0 @@
-#!/usr/bin/env python
-
-import os,commands,sys,logging
-import traceback,imp
-
-########################################################
-import HistoComparison
-import Truth
-import extractRec
-import checkAODESDcontent
-import memleak
-import addHTML
-########################################################
-
-logLevel=logging.INFO
-logger = logging.getLogger('check')
-hdlr = logging.FileHandler('check.log',"w")
-formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-hdlr.setFormatter(formatter)
-logger.addHandler(hdlr)
-logger.setLevel(logLevel)
-
-com = "cat env.log|grep AtlasVersion | cut -d= -f2| tail -n1"
-res,release=commands.getstatusoutput(com)
-
-
-com = "cat env.log|grep AtlasArea | cut -d= -f2| tail -n1"
-res,branch=commands.getstatusoutput(com)
-
-
-
-com="grep RTTINFO MYRTTINFOS.txt | cut -d= -f2 | tail -n1 | awk '{print $1}'"
-res,testName=commands.getstatusoutput(com)
-if res!=0 :
-    self.logger.error(testName.strip())
-    sys.exit(1)
-
-
-
-name=testName+'Checks.py';
-mod = imp.load_source("tests",name)
-import tests
-
-
-file = open('./checks.html','w')
-txt='<html><head><title>RTT results for '+testName.strip()+'</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head><body><center><h1>RTT results for '+testName.strip()+'</h1></center>'
-txt+='<br><br><br><br>'
-txt+='<center>'+'Branch : '+branch+'<br>'
-txt+='Release : '+release+'<br><br><br>'
-
-if tests.doHistoComparison==True:
-    txt+='<a href="DrawHistos.html">Histograms</a>'
-
-if tests.doTruth==True:
-    txt+='<br><a href="Truth.html">Truth plots</a>'
-
-if tests.docheckAODESDcontent==True:
-    txt+='<br><a href="ESDAOD.log">ESD and AOD dump (in some cases)</a>'
-
-if tests.doaddPlotElectronicNoise==True:
-    txt+='<br><a href="ElectronicNoise.html">Electronic noise</a>'
-
-txt+='</center></body></html>'
-file.write(txt)
-file.close()
-
-logger.info('============= CHECKS BEGIN =================')
-
- 
-# Comparison plots
-if tests.doHistoComparison:
-    logger.info('---- Histograms comparison ----')
-    try: 
-       a=HistoComparison.HistosComparison(logger,logging.info)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of HistoComparison failed')
-       res=10
-    if res==0:
-        logger.info('Histograms comparison done successfully')
-    else:
-        logger.info('Histograms comparison failed')
-
-# Truth
-if tests.doTruth:
-    logger.info('---- Truth ----')
-    try:
-       a=Truth.Truth(logger,logging.INFO)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of Truth failed')
-       res=10
-
-    if res==0:
-        logger.info('Truth done successfully')
-    else:
-        logger.info('Truth failed')
-
-# CPU time
-if tests.doextractRec:
-    logger.info('---- CPU time ----')
-    try: 
-       a=extractRec.extractRec(logger,logging.INFO)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of extractRec failed')
-       res=10
-
-    if res==0:
-        logger.info('extractRec done successfully')
-    else:
-        logger.info('extractRec failed')
-
-# Memory leaks
-if tests.doMemLeak:
-    logger.info('---- Memory leak ----')
-    try:
-       a=memleak.memleak(logger,logging.INFO)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of memleak failed')
-       res=10
-
-    if res==0:
-        logger.info('MemLeak done successfully')
-    else:
-        logger.info('MemLeak failed')
-
-# AOD, ESD size
-if tests.docheckAODESDcontent:
-    logger.info('---- checks of AOD, ESD ----')
-    try:
-       a=checkAODESDcontent.checkAODESDcontent(logger,logging.INFO)
-       res=a.run()
-    except:
-      traceback.print_exc()
-      logger.error('execution of checkAODESDcontent failed')
-      res=10
-
-    if res==0:
-        logger.info('checkAODESDcontent done successfully')
-    else:
-        logger.info('checkAODESDcontent failed')
-
-# add extra plots
-if tests.doaddPlotElectronicNoise==True:
-    logger.info('---- add plot of Electronic Noise ----')
-    try:
-       a=addHTML.addHTML(logger,logging.INFO,'plotAllCaloNoise13','ElectronicNoise')
-       res=a.run()
-    except:
-      traceback.print_exc()
-      logger.error('execution of addPlotElectronicNoise failed')
-      res=10
-
-    if res==0:
-        logger.info('addPlotElectronicNoise done successfully')
-    else:
-        logger.info('addPlotElectronicNoise failed')        
-
-
-logger.info('============= CHECKS END =================')
diff --git a/Calorimeter/CaloExample/CaloTests/share/checkAODESDcontent.py b/Calorimeter/CaloExample/CaloTests/share/checkAODESDcontent.py
deleted file mode 100755
index 397e14a6a62aaca6c1fedeeddfc939f604d76200..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/checkAODESDcontent.py
+++ /dev/null
@@ -1,77 +0,0 @@
-#!/usr/bin/python
-
-import commands,sys,os,logging
-
-class checkAODESDcontent:
-    def __init__(self,log,logLevel):
-        if log=='':
-            self.logger = logging.getLogger('AODESD')
-            hdlr = logging.FileHandler('checkAODESD.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-
-    def run(self):
-        res1,output=commands.getstatusoutput("./checkFile.py ESD.pool.root >& ESDAOD.log")
-        if res1!=0:
-            self.logger.error('problem to run checkFile.py on ESD.pool.root')
-        res2,output=commands.getstatusoutput("./checkFile.py AOD.pool.root >> ESDAOD.log")
-        if res2!=0:
-            self.logger.error('problem to run checkFile.py on AOD.pool.root')
-
-        if res1!=0 and res2!=0:
-            self.logger.error('no files to check')
-            return -1
-        
-        com = "cat MYRTTINFOS.txt" + "|grep BEGIN_RTTINFO | cut -d= -f2| tail -n1"
-        res,testName=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error(testName)
-            return -1
-        reflog='ref'+testName.strip()+'AODESD.log'
-
-        com='wget http://cern.ch/CaloRTT/'+reflog
-        res,out=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error(out)
-            return -1
-
-        try:
-            f=open(log,'r')
-            fclose(log)
-        except:
-            self.logger.error(log+' not found')
-            return -1
-        
-
-        keysList=[]
-        file = open(reflog,'r')
-        for line in file:
-            t=line.split()
-            if len(t)==8 and t[1]=='kb' and t[3]=='kb' and t[5]=='kb':
-                keysList.append(t[7])
-        file.close()
-
-        for k in keysList:
-            com1='grep '+k+' '+log+' | grep -v Tree'
-            res1,out1=commands.getstatusoutput(com1)
-            if res1!=0:
-                self.logger.warning(k+' NOT FOUND')
-                continue
-            tmpNew=out1.split()
-
-            com2='grep '+k+' '+reflog+' | grep -v Tree'
-            res2,out2=commands.getstatusoutput(com2)
-            if res2!=0:
-                continue
-            tmpRef=out2.split()
-
-            if float(tmpNew[4]) > float(tmpRef[4]):
-                self.logger.warning(k +' is higher : '+'NEW='+tmpNew[4]+'/'+'REF='+tmpRef[4]+' (kb)')
-                
-        return 0
-        
-    
diff --git a/Calorimeter/CaloExample/CaloTests/share/checkT.py b/Calorimeter/CaloExample/CaloTests/share/checkT.py
deleted file mode 100755
index dcd9be46f0606747ad97752b1b009b2f4bf067f7..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/checkT.py
+++ /dev/null
@@ -1,166 +0,0 @@
-#!/usr/bin/env python
-
-import os,commands,sys,logging
-import traceback,imp
-
-########################################################
-import HistoComparison
-import Truth
-import extractRec
-import checkAODESDcontent
-import memleak
-import addHTML
-########################################################
-
-logLevel=logging.INFO
-logger = logging.getLogger('checkT')
-hdlr = logging.FileHandler('checkT.log',"w")
-formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-hdlr.setFormatter(formatter)
-logger.addHandler(hdlr)
-logger.setLevel(logLevel)
-
-com = "cat env.log|grep AtlasVersion | cut -d= -f2| tail -n1"
-res,release=commands.getstatusoutput(com)
-
-
-com = "cat env.log|grep AtlasArea | cut -d= -f2| tail -n1"
-res,branch=commands.getstatusoutput(com)
-
-
-
-com="grep RTTINFO MYRTTINFOS.txt | cut -d= -f2 | tail -n1 | awk '{print $1}'"
-res,testName=commands.getstatusoutput(com)
-if res!=0 :
-    self.logger.error(testName.strip())
-    sys.exit(1)
-
-
-
-name=testName+'Checks.py';
-mod = imp.load_source("tests",name)
-import tests
-
-
-file = open('./checks.html','w')
-txt='<html><head><title>RTT results for '+testName.strip()+'</title><link rel=\"StyleSheet\" href=\"rtt.css\" type=\"text/css\" /><meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\"><meta http-equiv=\"Content-Language\" content=\"en\"></head><body><center><h1>RTT results for '+testName.strip()+'</h1></center>'
-txt+='<br><br><br><br>'
-txt+='<center>'+'Branch : '+branch+'<br>'
-txt+='Release : '+release+'<br><br><br>'
-
-if tests.doHistoComparison==True:
-    txt+='<a href="DrawHistos.html">Histograms</a>'
-
-if tests.doTruth==True:
-    txt+='<br><a href="Truth.html">Truth plots</a>'
-
-if tests.docheckAODESDcontent==True:
-    txt+='<br><a href="ESDAOD.log">ESD and AOD dump (in some cases)</a>'
-
-if tests.doaddPlotElectronicNoise==True:
-    txt+='<br><a href="ElectronicNoise.html">Electronic noise</a>'
-
-txt+='</center></body></html>'
-file.write(txt)
-file.close()
-
-logger.info('============= CHECKS BEGIN =================')
-
- 
-# Comparison plots
-if tests.doHistoComparison:
-    logger.info('---- Histograms comparison ----')
-    try: 
-       a=HistoComparison.HistosComparison(logger,logging.info)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of HistoComparison failed')
-       res=10
-    if res==0:
-        logger.info('Histograms comparison done successfully')
-    else:
-        logger.info('Histograms comparison failed')
-
-# Truth
-if tests.doTruth:
-    logger.info('---- Truth ----')
-    try:
-       a=Truth.Truth(logger,logging.INFO)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of Truth failed')
-       res=10
-
-    if res==0:
-        logger.info('Truth done successfully')
-    else:
-        logger.info('Truth failed')
-
-# CPU time
-if tests.doextractRec:
-    logger.info('---- CPU time ----')
-    try: 
-       a=extractRec.extractRec(logger,logging.INFO)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of extractRec failed')
-       res=10
-
-    if res==0:
-        logger.info('extractRec done successfully')
-    else:
-        logger.info('extractRec failed')
-
-# Memory leaks
-if tests.doMemLeak:
-    logger.info('---- Memory leak ----')
-    try:
-       a=memleak.memleak(logger,logging.INFO)
-       res=a.run()
-    except:
-       traceback.print_exc()
-       logger.error('execution of memleak failed')
-       res=10
-
-    if res==0:
-        logger.info('MemLeak done successfully')
-    else:
-        logger.info('MemLeak failed')
-
-# AOD, ESD size
-if tests.docheckAODESDcontent:
-    logger.info('---- checks of AOD, ESD ----')
-    try:
-       a=checkAODESDcontent.checkAODESDcontent(logger,logging.INFO)
-       res=a.run()
-    except:
-      traceback.print_exc()
-      logger.error('execution of checkAODESDcontent failed')
-      res=10
-
-    if res==0:
-        logger.info('checkAODESDcontent done successfully')
-    else:
-        logger.info('checkAODESDcontent failed')
-
-# add extra plots
-if tests.doaddPlotElectronicNoise==True:
-    logger.info('---- add plot of Electronic Noise ----')
-    try:
-       a=addHTML.addHTML(logger,logging.INFO,'plotAllCaloNoise13','ElectronicNoise')
-       res=a.run()
-    except:
-      traceback.print_exc()
-      logger.error('execution of addPlotElectronicNoise failed')
-      res=10
-
-    if res==0:
-        logger.info('addPlotElectronicNoise done successfully')
-    else:
-        logger.info('addPlotElectronicNoise failed')        
-
-
-logger.info('============= CHECKS END =================')
diff --git a/Calorimeter/CaloExample/CaloTests/share/extractRec.py b/Calorimeter/CaloExample/CaloTests/share/extractRec.py
deleted file mode 100755
index 4064db3fa8abfab510c4b474dba195db2c5b39a1..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/extractRec.py
+++ /dev/null
@@ -1,510 +0,0 @@
-#!/usr/bin/env python
-
-
-import os, sys, commands,getopt, datetime
-import stat,logging
-
-
-class extractRec:
-
-    def __init__(self,log,logLevel):   
-
-        
-        self.loggerAlert = logging.getLogger('Alert')
-        self.hdlrAlert = logging.FileHandler('Alert.txt',"w")
-        formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-        self.hdlrAlert.setFormatter(formatter)
-        self.loggerAlert.addHandler(self.hdlrAlert)
-        self.loggerAlert.setLevel(logLevel)
-
-        if log=='':
-            self.loggerInfo = logging.getLogger('Info')
-            self.hdlrInfo = logging.FileHandler('Info.txt',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            self.hdlrInfo.setFormatter(formatter)
-            self.loggerInfo.addHandler(self.hdlrInfo)
-            self.loggerInfo.setLevel(logLevel)
-        else:
-            self.loggerInfo = log
-        
-        self.tests=["Photons_calib0_csc11_007062_singlepart_gamma_E50","Electrons_calib0_csc11_007070_singlepart_e_E5","Photons_calib0_csc11_007080_singlepart_gamma_E5","Photons_calib0_csc11_007085_singlepart_gamma_E500","top_calib1_csc11_005200_T1_McAtNlo_Jimmy","Electrons_calib1_csc11_007061_singlepart_e_E100","Photons_calib1_csc11_007063_singlepart_gamma_E100"]
-        
-        # from auditors svc
-        self.CaloList=['LAr37ClusterMaker','LAr33ClusterMake','LArSWClusterMaker','LAr35ClusterMaker','CBNT_TileCell','CaloSWClusterMaker','CBNT_CaloCluster','CBNT_CaloCluster37','CBNT_CaloInfo','CBNT_CaloCluster35','CaloCellMaker','CaloTopoClusterMaker','TruthCone4Jets','TruthConeJets','CBNT_LArCell','CaloCell2TopoClusterMapper','EMTopoClusterMaker','TruthKtJets','TowerMaker','KtJets','ConeJets','Cone4Jets','METAlg']
-        # from personal chronosvc
-        self.extraCaloList=['CmbTowerBldr.TileCmbTwrBldr','CaloCellMaker_CaloCellContainerChecke','CaloCellMaker_CaloCellContainerFinali','CmbTowerBldr.FCalCmbTwrBldr','CaloCellMaker_LArCellBuilderLAr','CaloCellMaker_TileCellBuilder','CmbTowerBldr.LArCmbTwrBldr','TowerMaker.LArTowerBuilder','CmbTowerBldr.LArCmbTwrBldrChronoCellLoop','CmbTowerBldr.LArCmbTwrBldrChronobuild','TowerMaker.LArTowerBuilderChronobuild','TowerMaker.LArTowerBuilderChronoCellLoop']
-        self.debugLevel=0
-        # in sec
-        self.diffTime=0.05
-        
-        #self.emails=['bernardet@cppm.in2p3.fr']
-        self.emails=[]
-        self.wwwemails="http://cern.ch/CaloRTT/CaloRecEx_mails2.txt"
-        self.testName="CaloRecEx"
-        # if type = 1 use of the list above for the algo
-        self.type=0
-        self.typePerso=0
-        # Size of RDO.pool.root = XXX ko         
-
-
-        # release, time info
-        self.release=""
-        self.branch=""
-        self.date=""
-
-        self.mailSubjectProblem=""
-        self.mailSubjectReport=""
-        #self.switchoffRTTpart=True
-        #####################
-        self.alertMess=""
-        self.alertMessOk=False
-        self.alertReportOk=True
-        self.checkFile=0
-
-
-
-            
-####  CPU Time
-
-    def extractCPUTimeInitializeAll(self,file,type):
-
-        tmp=[]
-        if type !=1:
-            com="grep \"Time User\" " + file + " | grep initi"
-
-            self.loggerInfo.debug(com)
-        
-            res=commands.getoutput(com)
-            tmp= res.splitlines() 
-        else:
-            for i in self.CaloList:
-                com="grep \"Time User\" " + file + " | grep \"\<" +i+":initi\""
-                self.loggerInfo.debug(com)
-                res=commands.getoutput(com)
-                tmp += res.splitlines()
-            
-        return tmp
-            
-    def extractCPUTimeInitializeAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep initi" + " | grep  " + algo +" | awk '{print $7" "$8}' "
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-    def extractCPUTimeExecuteAll(self,file,type):
-    
-        tmp=[]
-        if type !=1:
-            com="grep \"Time User\" " + file + " | grep execute"
-
-            self.loggerInfo.debug(com)
-        
-            res=commands.getoutput(com)    
-            tmp= res.splitlines() 
-        else:
-            for i in self.CaloList:
-                com="grep \"Time User\" " + file + " | grep \"\<" +i
-                self.loggerInfo.debug(com)
-                res=commands.getoutput(com)
-                tmp += res.splitlines()
-
-        return tmp
-
-# pour les algo perso, ajouter un espace apres le nom de l algo pour le grep sinon pb en cas de noms du genre : AlgoPerso,AlgoPerso2 ...
-
-
-    def extractCPUTimeExecutePersoAll(self,file,type):
-    
-        tmp=[]
-        if type !=1:
-            com="grep \"Time User\" " + file + " | grep -v execute| grep -v initialize | grep -v finalize"
-
-            self.loggerInfo.debug(com)
-        
-            res=commands.getoutput(com)    
-            tmp= res.splitlines() 
-        else:
-            for i in self.extraCaloList:
-                com="grep \"Time User\" " + file + " | grep '" +i+" '" 
-                self.loggerInfo.debug(com)
-                res=commands.getoutput(com)
-                tmp += res.splitlines()
-
-        return tmp
-
-
-    def extractCPUTimeExecuteAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep  '\<" + algo +"' | awk '{print $7" "$8}' "
-        self.loggerInfo.debug(com)
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-    def extractCPUTimeExecutePersoAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep  '\<" + algo +" ' | awk '{print $7" "$8}' "
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)
-
-        self.loggerInfo.debug(res)
-
-        res2= res.splitlines() 
-        return res2
-
-
-    def extractNbEventsExecuteAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep  '\<" + algo +"'| cut -d\# -f 2 | cut -d = -f 2 "
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-    def extractNbEventsExecutePersoAlgo(self,file, algo):
-
-        com="grep \"Time User\" " + file + " | grep  '\<" + algo +" '| cut -d\# -f 2 | cut -d = -f 2 "
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-
-    def getNbEvents(self,file):
-
-        com="grep \"INFO Total Virtual memory\" " + file +" | wc -l"
-
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-    def compareCPUTimeInitialize(self,file,reffile,type):
-        # 
-        CPUTimeRef=[]
-        alg=[]
-        CPUTimeRef=self.extractCPUTimeInitializeAll(reffile,type)
-        for i in CPUTimeRef:
-            t=i.lstrip()
-            tmp=t.split(" ")
-            alg.append(tmp[0])
-        #print alg
-        for j in alg:
-            tref=self.extractCPUTimeInitializeAlgo(reffile,str(j))
-            tnew=self.extractCPUTimeInitializeAlgo(file,str(j))
-            if len(tnew)==0:
-                    mess=j+" not found in " + file
-                    self.loggerInfo.info(mess)
-                    continue
-
-            #print j,tref,tnew
-            trefUnity=self.CPUTimeUnity(str(tref[0]))
-            tnewUnity=self.CPUTimeUnity(str(tnew[0]))
-            #print j,trefUnity,tnewUnity
-            ttnew=tnew[0].split('[')
-            ttref=tref[0].split('[')
-            ttref2=self.convertCPUTime(float(ttref[0]),trefUnity)      
-            ttnew2=self.convertCPUTime(float(ttnew[0]),tnewUnity)
-            #print j,ttref2,ttnew2
-            if ttnew2-ttref2 > self.diffTime:
-                mess="WARNING : "+j+" REF : "+str(ttref[0])+self.CPUTimeUnity(str(tref[0]))+" NOW : "+str(ttnew[0])+self.CPUTimeUnity(str(tnew[0]))
-                self.loggerInfo.info(mess)
-                self.loggerAlert.info(mess)
-            else:
-                mess="GOOD : "+j+" REF : "+str(ttref[0])+self.CPUTimeUnity(str(tref[0]))+" NOW : "+str(ttnew[0])+self.CPUTimeUnity(str(tref[0]))
-                self.loggerInfo.info(mess)
-            
-            
-        return
-
-      
-    def convertCPUTime(self,time,unity):
-       
-        if unity=="min":
-            return time*60
-        elif unity=="ms": 
-            return time*0.001
-        elif unity=="us":
-            return time*0.000001
-        else:
-            return time
-
-    def CPUTimeUnity(self,string):
-        
-        tmp=string.split('[')
-        tmp2=tmp[1].split(']')
-        return tmp2[0]
-
-    def compareCPUTimeExecute(self,file,reffile,type):
-        # 
-        CPUTimeRef=[]
-        alg=[]
-        CPUTimeRef=self.extractCPUTimeExecuteAll(reffile,type)
-        for i in CPUTimeRef:
-            t=i.lstrip()
-            tmp=t.split(" ")
-            alg.append(tmp[0])
-        for j in alg: 
-                tref=self.extractCPUTimeExecuteAlgo(reffile,str(j))
-                nbEvtRef=self.extractNbEventsExecuteAlgo(reffile,str(j))
-                tnew=self.extractCPUTimeExecuteAlgo(file,str(j))
-                nbEvtNew=self.extractNbEventsExecuteAlgo(file,str(j))
-                #print j," ", tref,"  ",tnew
-                #print 'KARIM2 ',j," ",nbEvtRef ,"  ",nbEvtNew
-                if len(tnew)==0:
-                    mess=j+" not found in " + file
-                    self.loggerInfo.info(mess)
-                    continue
-                
-                # convert en secondes
-                trefUnity=self.CPUTimeUnity(str(tref[0]))
-                tnewUnity=self.CPUTimeUnity(str(tnew[0]))
-                ttnew=tnew[0].split('[')
-                ttref=tref[0].split('[')
-                ttref2=self.convertCPUTime(float(ttref[0]),trefUnity)      
-                ttnew2=self.convertCPUTime(float(ttnew[0]),tnewUnity)
-
-                if int(nbEvtRef[0])>0:
-                    normtref=float(ttref2)/float(nbEvtRef[0])
-                else:
-                    self.loggerInfo.warning("Ref "+j+" "+nbEvtRef[0])
-                if int(nbEvtNew[0])>0:
-                    normtnew=float(ttnew2)/float(nbEvtNew[0])
-                else:
-                    self.loggerInfo.warning("New "+j+" "+nbEvtNew[0])
-
-                if int(nbEvtRef[0])>0 and int(nbEvtNew[0])>0: 
-                    if normtnew-normtref > self.diffTime:
-                        mess="WARNING : "+j+" REF : "+str(normtref)+" s "+" NOW : "+str(normtnew)+" s "+ "  (per event)"
-                        self.loggerInfo.info(mess)
-                        # alert
-                        self.loggerAlert.info(mess)
-                    else:
-                        mess="GOOD : "+j+" REF : "+str(normtref)+" s "+" NOW : "+str(normtnew)+" s"+" (per event)"
-                        self.loggerInfo.info(mess)
-                else:
-                   mess="WARNING : can not check "+j
-                   self.loggerInfo.info(mess) 
-        return
-
-
-    def compareCPUTimeExecutePerso(self,file,reffile,type):
-        # 
-        CPUTimeRef=[]
-        alg=[]
-        #CPUTimeRef=self.extractCPUTimeExecutePersoAll(reffile,type)
-        CPUTimeRef=self.extractCPUTimeExecutePersoAll(file,type)
-        
-        for i in CPUTimeRef:
-            t=i.lstrip()
-            tmp=t.split(" ")
-            alg.append(tmp[0])
-        for j in alg: 
-                tref=self.extractCPUTimeExecutePersoAlgo(reffile,str(j))
-                
-                nbEvtRef=self.extractNbEventsExecutePersoAlgo(reffile,str(j))
-                tnew=self.extractCPUTimeExecutePersoAlgo(file,str(j))
-                nbEvtNew=self.extractNbEventsExecutePersoAlgo(file,str(j))
-                isok=1
-                if len(tnew)==0:
-                    mess=j+" not found in " + file
-                    self.loggerInfo.info(mess)
-                    tmp=tref[0].split('[')
-                    mess=j+" REF : "+str(tmp[0])+self.CPUTimeUnity(str(tref[0]))
-                    self.loggerInfo.info(mess)
-                    isok=0
-                if len(tref)==0:
-                    mess=j+" not found in " + reffile
-                    self.loggerInfo.info(mess)
-                    tmp=tnew[0].split('[')
-                    mess=j+ " NEW : "+str(tmp[0])+self.CPUTimeUnity(str(tnew[0]))
-                    self.loggerInfo.info(mess)
-                    isok=0
-
-                if isok==0:
-                    continue
-                    
-                # print j," ", tref,"  ",tnew
-                # print j," ",nbEvtRefb ,"  ",nbEvtNewb
-                
-                # convert en secondes
-                trefUnity=self.CPUTimeUnity(str(tref[0]))
-                tnewUnity=self.CPUTimeUnity(str(tnew[0]))
-                ttnew=tnew[0].split('[')
-                ttref=tref[0].split('[')
-                ttref2=self.convertCPUTime(float(ttref[0]),trefUnity)      
-                ttnew2=self.convertCPUTime(float(ttnew[0]),tnewUnity)
-                normtref=float(ttref2)/float(nbEvtRef[0])
-                normtnew=float(ttnew2)/float(nbEvtNew[0])
-            
-                if normtnew - normtref > self.diffTime:
-                    mess="WARNING : "+j+" REF : "+str(normtref)+" s "+" NOW : "+str(normtnew)+" s "+ "  (per event)"
-                    self.loggerInfo.info(mess)
-                    self.loggerAlert.info(mess)
-                else:
-                    mess="GOOD : "+j+" REF : "+str(normtref)+" s "+" NOW : "+str(normtnew)+" s"+" (per event)"
-                    self.loggerInfo.info(mess)
-        return
-
-    def logExtract(self,file,chain):
-
-        com="egrep \""+chain + "\"  "  + file
-        self.loggerInfo.debug(com)
-        
-        res=commands.getoutput(com)    
-        res2= res.splitlines() 
-        return res2
-
-
-    def extractLog(self,log):
-
-
-        com="wc -l "+log +" | awk '{print $1}'"
-        res=commands.getoutput(com)    
-        res2=res.splitlines()
-        nbAllLines=int(res2[0])
-
-        #print nbAllLines
-        
-        com="grep ^BEGIN_RTTINFO "+log
-        res=commands.getoutput(com)    
-        res2=res.splitlines()
-        
-        names=[]
-        for i in res2:
-            name=i.split('=')
-            name[1]=name[1].strip()
-            names.append(name[1])
-            
-        for i in range(len(names)):
-            #print i,names[i]
-            #com="grep -n BEGIN_RTTINFO="+names[i]+" "+log+" | cut -d: -f1"
-            com="grep -n \"^BEGIN_RTTINFO = "+names[i]+"\" "+log+"| cut -d: -f1"
-            n1=commands.getoutput(com)
-            try:
-                #com="grep -n BEGIN_RTTINFO="+names[i+1]+" "+log+" | cut -d: -f1"
-                com="grep -n \"^BEGIN_RTTINFO = "+names[i+1]+"\" "+log+"| cut -d: -f1"
-                
-                n2=commands.getoutput(com)
-            except:
-                n2=nbAllLines
-            
-            nblines=int(n2)-int(n1)-1
-            #print nblines
-            newlog='./'+names[i]+".log"
-            #com="grep -A"+str(nblines)+" BEGIN_RTTINFO="+names[i]+" "+log +" >"+newlog
-            com="grep -A"+str(nblines)+" \"^BEGIN_RTTINFO = "+names[i]+"\" "+log +" >"+newlog
-            os.system(com)
-        return names
-
-
-###########
-
-    def run(self):
-        log=commands.getoutput("ls Calo*Ex_RTT*_log")
-        names=self.extractLog(log)
-	
-        print names
-
-        for test in names:
-            com="rm "+"./resultats.txt"
-            commands.getoutput(com)    
-
-            com = "cat MYRTTINFOS.txt|grep BEGIN_RTTINFO | cut -d= -f2| tail -n1"
-            jobopt=commands.getoutput(com)
-            self.loggerInfo.info('Test name : '+jobopt)
-            found=0
-            for opt in self.tests:
-                if opt==jobopt.strip():
-                    found=1
-                    break	
-
-            if found==0:
-                self.loggerInfo.info("test not in dict !!!")
-                return -1
-
-            self.reflog='ref'+jobopt.strip()+'.log'
-            com='wget http://cern.ch/CaloRTT/'+self.reflog
-            print com
-            os.system(com)
-
-            try:
-                file = open(self.reflog)
-                file.close()
-            except IOError:
-                self.loggerInfo.info(self.reflog+' not found')
-                return -1
-
-            # date
-            self.date=str(datetime.datetime.now().strftime("%Y-%m-%d %X"))
-            self.loggerInfo.info(self.date)
-
-            com = "cat env.log|grep AtlasVersion | cut -d= -f2| tail -n1"
-            self.release=commands.getoutput(com)
-            self.branch="Dev"
-
-            self.mailSubjectProblem="\"[RTT test, "+jobopt+","+self.branch+","+self.release+"] : extractRec problem \""
-            self.mailSubjectReport="\"[RTT test, "+jobopt+","+self.branch+","+self.release+"] : extractRec report \""
-
-            mess="Reference log = " + self.reflog
-            self.loggerInfo.info(mess)
-            mess="Log to check = "+log
-            self.loggerInfo.info(mess)
-
-     
-            self.loggerInfo.info("********************************")
-            self.loggerInfo.info("CHECK STATUSCODE")
-            
-            res=self.logExtract(log,"\|*\| lib*")
-            for i in res:
-                self.loggerInfo.info(str(i))     
-            self.loggerInfo.info("********************************")
-
-
-            ## self.loggerInfo.info("********************************")
-##             self.loggerInfo.info("CHECK WARNING")
-            
-##             res=self.logExtract(log," WARNING ")
-##             for i in res:
-##                 self.loggerInfo.info(str(i))     
-##             self.loggerInfo.info("********************************")
-            
-            
-##             self.loggerInfo.info("********************************")
-##             self.loggerInfo.info("CHECK ERROR")
-##             res=self.logExtract(log," ERROR ")
-##             for i in res:
-##                 self.loggerInfo.info(str(i))     
-##             self.loggerInfo.info("********************************")
-            
-
-            
-            self.loggerInfo.info("********************************")
-            
-            self.loggerInfo.info("CHECK INITIALIZE TIME")
-            
-            self.compareCPUTimeInitialize(log,self.reflog,self.type)
-            
-            self.loggerInfo.info("********************************")
-            
-            self.loggerInfo.info("CHECK EXECUTE TIME")
-            
-            self.compareCPUTimeExecute(log,self.reflog,self.type)
-            self.compareCPUTimeExecutePerso(log,self.reflog,self.typePerso)
-            
-            self.loggerInfo.info("********************************")
-
-            return 0
-#a=extractRec()
-#a.run()
diff --git a/Calorimeter/CaloExample/CaloTests/share/memleak.py b/Calorimeter/CaloExample/CaloTests/share/memleak.py
deleted file mode 100755
index ad335a76199b67069ffe86543e5e4fd4ae3bae8d..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/memleak.py
+++ /dev/null
@@ -1,45 +0,0 @@
-#!/usr/bin/python
-
-import commands,sys,os,logging
-
-
-class memleak:
-    def __init__(self,log,logLevel):
-        if log=='':
-            self.logger = logging.getLogger('memleak')
-            hdlr = logging.FileHandler('memleak.log',"w")
-            formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
-            hdlr.setFormatter(formatter)
-            self.logger.addHandler(hdlr)
-            self.logger.setLevel(logLevel)
-        else:
-            self.logger = log
-
-    def run(self):
-
-        log=commands.getoutput("ls Calo*RTT*_log")
-        try:
-            f=open(log,'r')
-            f.close()
-        except:
-            self.logger.error(log+' not found')
-            return -1
-        
-        com='grep \"only second half of the job\" '+log+'| grep INFO'
-        res,out=commands.getstatusoutput(com)
-        if res!=0:
-            self.logger.error(out)
-            return -1
-
-        tmp=out.split('only second half of the job:')
-        tmp2=tmp[1].strip().split('MByte/event')
-        if float(tmp2[0].strip())>0.1:
-            self.logger.warning('MEM LEAK ! :'+tmp[1].strip())
-            return -1
-        return 0
-        
-    
-                
-#a=memleak('',logging.INFO)
-#a.run()
-    
diff --git a/Calorimeter/CaloExample/CaloTests/share/rttTest.css b/Calorimeter/CaloExample/CaloTests/share/rttTest.css
deleted file mode 100755
index 544477ef82f4032d26c624ff12cd8bbf167c060f..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/rttTest.css
+++ /dev/null
@@ -1,1308 +0,0 @@
-
-
-/*	-----------------------------------------------------------
-	STYLE
-	Appearance: margins, fonts, colors
-	-----------------------------------------------------------	*/
-
-/*	-----------------------------------------------------------
-	General elements
-	-----------------------------------------------------------	*/
-	
-/* HTML elements */
-
-html body {
-	line-height:1.55em;
-	font-family:"Lucida Grande", verdana, lucida, helvetica, sans-serif;
-	background-color:#f8f8f8;
-	margin:10;
-	padding:0;
-	font-size:x-small;
-	voice-family:"\"}\""; 
-	voice-family:inherit;
-	font-size:small;
-}
-html>body {
-	font-size:small;	
-}
-
-/* be kind to netscape 4 that doesn't understand inheritance */
-body, p, li, ul, ol, dl, dt, dd, acronym, h1, h2, h3, h4, h5, h6 {
-	background-color:transparent;
-}
-p {
-	margin:1em 0 0 0;
-}
-table {
-	border-collapse:separate;
-}
-strong, b {
-	font-weight:bold;
-}
-hr {
-	color:#9E9E70;
-	background-color:#9E9E70;
-	height:1px;
-	border:none;
-}
-pre, code, tt {
-	font-size:100%;
-	line-height:1.4em;
-	color:#7A4707;
-}
-pre {
-	margin-top:1em;
-	margin-bottom:1em;
-}
-
-/* Text */
-
-h1, h2, h3, h4, h5, h6 {
-	font-family:"Lucida Grande", helvetica, lucida, verdana, sans-serif;
-	line-height:104%;
-	padding:0;
-	margin:1em 0 0.1em 0;
-}
-h1 {
-	font-size:210%;
-	color:#e24628;
-	margin:0 0 0.1em 0;
-}
-h2 {
-	font-size:145%;
-	display:block;
-	background-color:#F3EDE7;
-	color:#900;
-	padding:0.2em 0.7em;
-	margin:1em -0.7em 0.15em -0.7em;
-	height:auto;
-}
-h3 { font-size:140%; color:#900;}
-h4 { font-size:125%; color:#900;}
-h5 { font-size:110%; color:#900;}
-h6 { font-size:95%; color:#900;}
-
-/* Links */
-
-:link:focus,
-:visited:focus,
-:link,
-:visited,
-:link:active,
-:visited:active {
-	text-decoration:none;
-	color:#1e5bbd;
-	background-color:transparent;
-}
-:link:hover,
-:visited:hover {
-	text-decoration:underline;
-	background-color:#b4d5ff;
-	color:#1559B3;
-}
-a:link img,
-a:visited img,
-a:hover img,
-a:active img {
-	background-color:transparent;
-}
-th a:link,
-th a:visited {
-	font-weight:bold;
-}
-
-/* sorting of table columns */
-/* not yet finalized for tables in topic text */
-
-th.twikiSortedAscendingCol a:link,
-th.twikiSortedAscendingCol a:visited {
-	border-top:1px solid #999; /* a neutral color that should work on light and dark backgrounds */
-}
-th.twikiSortedAscendingCol a:hover,
-th.twikiSortedAscendingCol a:hover {
-	text-decoration:none;
-	border-top:0;
-	border-bottom:1px solid #999;
-}
-th.twikiSortedDescendingCol a:link,
-th.twikiSortedDescendingCol a:visited,
-th.twikiSortedDescendingCol a:link,
-th.twikiSortedDescendingCol a:visited {
-	border-bottom:1px solid #999;
-}
-th.twikiSortedDescendingCol a:hover,
-th.twikiSortedDescendingCol a:hover {
-	text-decoration:none;
-	border-bottom:0;
-	border-top:1px solid #999;
-}
-
-/* Forms */
-
-form { 
-	display:inline;
-	margin:0;
-	padding:0;
-}
-textarea {
-	font-family:monospace;
-	font-size:100%;
-	margin:0.25em 0;
-}
-input, select {
-	font-family:verdana,arial,sans-serif;
-	padding:1px;
-	/*background-color:#E8F1F9;*/
-}
-select {
-	padding:0;
-	font-size:100%;
-}
-fieldset {
-	border:1px solid #22638c;
-	padding-left:1em;
-}
-legend {
-	padding: 0.2em 1em;
-	color:#8490A1; /* .twikiGrayText value */
-	font-size:95%;
-	border:1px solid #8490A1; /* .twikiGrayText value */
-	background-color:#f8f8f8;
-}
-label {
-	margin-left:0.5em;
-	font-size:95%;
-	line-height:125%;
-}
-
-/*	-----------------------------------------------------------
-	TWiki specific elements
-	-----------------------------------------------------------	*/
-
-.twikiMiddleContainer {}
-.twikiMain {
-	padding:0 3.5em;
-	background-color:white;
-	border-width:1px;
-	border-style:solid;
-	border-color:#ddd #ddd #ddd #ddd;
-}
-
-/* Top bar */
-
-.twikiTopBar {
-	background-color:transparent;
-}
-.twikiTopBar ul li a:link,
-.twikiTopBar ul li a:visited {
-	padding:0.25em 0.85em;
-	text-decoration:none;
-	float:left;
-	color:white;
-	font-weight:bold;
-	background-color:transparent/*#98A2B0*/;
-	margin-right:1px;
-}
-.twikiTopBar ul li a:hover {
-	background-color:#b4d5ff;
-	color:#1559B3;
-	text-decoration:underline;
-}
-.twikiTopBarContents {
-	margin:0;
-	padding:5px 2em 5px 1em; /* right padding same as .twikiViewPage .twikiMain */
-}
-
-/* Left bar */
-
-.twikiLeftBar {
-	border-top:1px solid #ddd;
-	color:#800;
-	overflow:hidden;
-	line-height:1.3em;
-}
-.twikiWebIndicator {
-	font-size:95%;
-	line-height:1.4em;
-	padding:0.3em 0;
-	background-color:#efefef; /* color variable WEBBGGCOLOR is set in twiki.pattern.tmpl */
-	color:black;
-	text-align:center;
-	border-bottom:2px solid white;
-}
-.twikiLeftBarContents {
-	font-size:95%;
-	font-weight:normal;
-	margin:0;
-	padding:1em 0 1.7em 1em;
-	width:auto;
-	border-top:3px solid #22638C;
-}
-.twikiLeftBar ul {
-	padding:0;
-	margin:0;
-}
-.twikiLeftBar strong a:link,
-.twikiLeftBar strong a:visited {
-	font-weight:bold;
-}
-.twikiLeftBar li {
-	display:block;
-	list-style:none;
-	width:100%;
-}
-.twikiLeftBar li a {
-	display:block;
-	width:98%;
-	padding-right:2%;
-}
-html>body .twikiLeftBar li a {
-	width:auto;
-}
-.twikiLeftBar hr {
-	color:#ccc;
-	background-color:#ccc;
-	height:1px;
-	border:none;
-}
-.twikiLeftBarPersonal {
-	margin:-0.5em -1px -0.5em -1em;
-	margin-top:1.5em;
-	padding:0.25em 0 0.5em 1em;
-	background-color:#DFEDFD;
-	border-top:1px solid #ccc;
-	border-bottom:1px solid #ccc;
-}
-.twikiLeftBarPersonal p {
-	margin:0.5em 0 0 0;
-}
-.twikiLeftBarPersonal a:visited {
-	color:#666;
-}
-
-/* Bottom bar */
-
-.twikiBottomBar {
-	padding-bottom:1em;
-}
-.twikiBottomBarContents {
-	padding:0.5em 2.5em 1.5em 0.5em;
-	font-size:90%;
-	line-height:140%;
-}
-
-/* Topic text */
-
-.twikiTopic {
-	padding-bottom:1.5em;
-	background-color:transparent;
-}
-.twikiTopic table {
-	width:auto;
-}
-.twikiTopic table th a:link,
-.twikiTopic table th a:visited {
-	text-decoration:none;
-}
-.twikiTopic ul {
-	margin-top:0;
-	line-height:130%;
-}
-.twikiTopic a:link {
-	text-decoration:underline;
-}
-.twikiTopic a:visited {
-	text-decoration:underline;
-	color:#666;
-}
-.twikiTopic h1 a:link,
-.twikiTopic h1 a:visited,
-.twikiTopic h2 a:link,
-.twikiTopic h2 a:visited {
-	text-decoration:none;
-	color:#1559B3;
-	border:none;
-	font-weight:bold;
-}
-.twikiTopic a:hover {
-	color:#1559B3;
-}
-
-/**	----------------------------------
-*	Attachments table, form
-*	---------------------------------- */
-
-.twikiAttachments,
-.twikiForm {
-	margin:2em 0;
-}
-.twikiAttachments table,
-.twikiForm table {
-	border-collapse:collapse;
-	padding:0px;
-	border-spacing:0px;
-	empty-cells:show;
-	border:0px;
-	font-size:90%;
-	color:#888e9c;
-	background-color:white;
-	border-top:1px solid #ccc;
-	border-right:1px solid #ccc;
-	border-left:1px solid #ccc;
-}
-.twikiAttachments table {
-	background-color:white;
-	line-height:1.4em;
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:100%;
-}
-.twikiAttachments th,
-.twikiForm th,
-.twikiAttachments th,
-.twikiForm th {
-	padding:0.2em 0.6em;
-	height:2.5em;
-	border-color:#ccc;
-	border-left:1px solid #ccc;
-	border-bottom:1px solid #ccc;
-	background-color:white;
-	vertical-align:middle;
-}
-.twikiAttachments th.twikiFirstCol,
-.twikiForm th.twikiFirstCol {
-	border-left:none;
-	width:0px;
-}
-/* don't show any of those ugly sort icons */
-.twikiAttachments th img,
-.twikiAttachments th a:link img,
-.twikiAttachments th a:visited img {
-	display:none;
-}
-.twikiAttachments td,
-.twikiForm td {
-	border:0px;
-	border-bottom:1px solid #ccc;
-	padding:0.2em 0.6em;
-	background-color:white;
-	height:1.4em;
-	text-align:left;
-	vertical-align:top;
-}
-/*
-.twikiAttachments td {
-   white-space:nowrap;
-}
-*/
-.twikiAttachments td.twikiFirstCol,
-.twikiForm td.twikiFirstCol {
-	border-left:none;
-}
-.twikiAttachments p,
-.twikiForm p {
-	display:none;
-}
-.twikiAttachments th a:link,
-.twikiAttachments th a:visited,
-.twikiForm th a:link,
-.twikiForm th a:visited {
-	color:#1559B3;
-	border-color:#345;
-	text-decoration:none;
-}
-.twikiAttachments th font,
-.twikiForm th font {
-	color:#1559B3;
-}
-.twikiAttachments th a:hover,
-.twikiForm th a:hover {
-	text-decoration:underline;
-	background-color:transparent;
-	border-color:#345;
-}
-.twikiAttachments td a:link,
-.twikiAttachments td a:visited,
-.twikiForm td a:link,
-.twikiForm td a:visited {
-	font-weight: normal;
-}
-.twikiAttachments th.twikiSortedAscendingCol,
-.twikiAttachments th.twikiSortedDescendingCol {
-	background-color:#DADADA;
-}
-.twikiAttachments th.twikiSortedAscendingCol a:link,
-.twikiAttachments th.twikiSortedAscendingCol a:visited,
-.twikiAttachments th.twikiSortedDescendingCol a:link,
-.twikiAttachments th.twikiSortedDescendingCol a:visited {
-	color:#345;
-}
-.twikiAttachments th.twikiSortedAscendingCol a:hover,
-.twikiAttachments th.twikiSortedDescendingCol a:hover {
-	text-decoration:none;
-	background-color:transparent;
-}
-
-/* twikiTopicAction: actions buttons at bottom of page */
-
-/* If someone has enough insight or time to spare, please
-create a div based solution instead of tables */
-
-.twikiTopicAction {
-	margin:2em 0 3em 0;
-	background-color:#22638c; /* for Explorer 5.x so the whole row is blue */
-}
-.twikiTopicAction table,
-table.twikiTopicAction {
-	padding:0px;
-	border-spacing:0px;
-	border-collapse:collapse;
-	empty-cells:show;
-	border:0px;
-	font-size:95%;
-	color:white;
-	width:inherit;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:100%;
-}
-.twikiTopicAction a:link,
-.twikiTopicAction a:visited {
-	color:white;
-	border-bottom:1px solid #698FA8;
-	text-decoration:none;
-	font-weight:bold;
-}
-.twikiTopicAction a:hover {
-	color:#1559B3;
-	border-bottom:1px solid #b4d5ff;
-}
-.twikiTopicAction tr {
-	background-color:#22638c;
-}
-.twikiTopicAction th {
-	border:none;
-}
-.twikiTopicAction td {
-	height:2em;
-	border:none;
-	padding:0.3em 1em;
-	vertical-align:middle;
-	text-align:left;
-}
-.twikiTopicAction td.twikiCancelCol {
-	text-align:left;
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:20%;
-}
-.twikiTopicAction td.twikiSubmitCol {
-	text-align:center;
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:40%;
-}
-.twikiTopicAction .twikiSubmitOptions {
-	background-color:#D4E6FC;
-	border:1px solid #B6C6D9;
-	margin:0.25em 0;
-}
-.twikiTopicAction td.twikiAddCol {
-	text-align:right;
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:20%;
-}
-.twikiTopicAction a:hover {
-	color:#1559B3;
-	border-bottom:1px solid #b4d5ff;
-}
-.twikiTopicActionSecondary {
-	padding:0.15em 0.5em 0.15em 1em;
-	background-color:white;
-}
-.twikiTopicActionHelp,
-.twikiTopicAction .twikiTopicActionHelp {
-	background-color:white;
-	padding:0;
-}
-.twikiTopicActionSecondary,
-.twikiTopicAction .twikiTopicActionSecondary {
-	background-color:#DFEDFD;
-	color:#22638c;
-	border-top:1px solid #bbb;
-}
-.twikiTopicActionSecondary td.twikiSubmitCol {
-	text-align:left;
-}
-.twikiTopicActionSecondary a:link,
-.twikiTopicActionSecondary a:visited {
-	color:#1e5bbd;
-	border-bottom:1px solid #A3BCF1;
-	text-decoration:none;
-}
-.twikiTopicActionSecondary a:hover {
-	color:#1e5bbd;
-	border-bottom:1px solid #b4d5ff;
-}
-.twikiTopicActionHelp a:link,
-.twikiTopicActionHelp a:visited  {
-	border-bottom:0px;
-}
-.twikiTopicAction .twikiSeparator {
-	display:inline;
-	color:white;
-}
-.twikiTopicAction input,
-.twikiTopicAction label {
-	font-size:100%;
-}
-
-/**	----------------------------------
-*	TOC
-*	---------------------------------- */
-
-.twikiToc {
-	display:block;
-	font-size:95%;
-	line-height:1.6em;
-	margin:1em 0 2em 0;
-	padding:0.3em 0 0.6em 0;
-	border-top:1px solid;
-	border-bottom:1px solid;
-	border-color:#ddd;
-}
-
-.twikiToc ul {
-	list-style:outside;
-	padding:0 0 0 0.5em;
-	margin:0;
-	/* list style image ref in twiki.pattern.tmpl */
-	/*list-style-image:url(/twiki/pub/TWiki/PatternSkin/i_arrow_down.gif);*/
-}
-.twikiToc li {
-	margin-left:2em;
-}
-.twikiToc .twikiTocTitle {
-	margin:0;
-	padding:0;
-	font-weight:bold;
-	color:#666;
-}
-.twikiToc a:link,
-.twikiToc a:visited {
-	text-decoration:none;
-	color:#1e5bbd;
-	border:0;
-}
-.twikiToc a:hover {
-	text-decoration:underline;
-}
-.twikiToc li a {
-	display:block;	
-	width:100%;
-}
-html>body .twikiToc li a {
-	width:auto;
-}
-
-/* Topic info */
-
-.twikiTopicInfo {
-	margin:0.5em 0 0 0;
-}
-
-/* Revision info */
-
-.twikiRevInfo {
-	display:block;
-	font-size:95%;
-}
-.twikiRevInfo em,
-.twikiRevInfo i {
-	font-style:normal;
-}
-
-/* Footer */
-
-.twikiTopicFooter {
-	display:block;
-	margin-top:1em;
-	padding-bottom:2em;
-}
-
-/* Homepath */
-
-.twikiHomePath {
-	font-size:90%;
-}
-.twikiHomePath a:hover {
-	text-decoration:underline;
-}
-
-/* Tool bar at top of topic */
-
-.twikiToolBar {
-	display:block;
-	padding:0.3em 0 1em 0;
-	margin-left:-0.55em; /* same amount as button padding */
-	margin-bottom:0.5em;
-}
-.twikiToolBar p {
-	clear:both;
-	height:0;
-	display:none;
-}
-.twikiToolBar ul {
-	display:inline;
-	padding:0;
-	margin:0;
-	float:left;
-	font-size:95%;
-}
-.twikiToolBar ul li {
-	display:inline;
-	color:#8490A1; /* .twikiGrayText value */
-	font-weight:bold;
-	background-color:transparent;
-}
-.twikiToolBar ul li s,
-.twikiToolBar ul li strike {
-	padding:0 0.55em;
-	float:left;
-}
-.twikiToolBar ul li a:link,
-.twikiToolBar ul li a:visited {
-	padding:0 0.55em;
-	float:left;
-	text-decoration:none;
-	color:#8490A1; /* .twikiGrayText value */
-	font-weight:bold;
-}
-.twikiToolBar ul li a:hover {
-	background-color:#b4d5ff;
-	color:#1559B3;
-	text-decoration:none;
-}
-.twikiToolBar .twikiRevInfo {
-	text-align:right;
-}
-.twikiToolbarElem {
-	margin-left:0.7em;
-}
-
-/* page nav:top to, to bottom */
-
-.twikiPageNav {
-	font-size:95%;
-	font-weight:bold;
-	margin-left:1em;
-	margin-bottom:1em;
-}
-
-/* Moved message */
-
-.twikiMoved {}
-
-/* search box */
-
-.twikiSearchBox {
-	color:#8490A1; /* .twikiGrayText value */
-}
-.twikiSearchBox td {
-	height:50px;
-	vertical-align:middle;
-	background-color:transparent;
-	text-align:right;
-}
-.twikiSearchBox input {
-	border:1px solid #ccc;
-}
-
-/* table used in various places */
-
-.twikiVersatileTable table {
-	width:auto;
-	padding:0px;
-	border-spacing:0px;
-	border-collapse:collapse;
-	empty-cells:show;
-	border:0px;
-	border:1px solid #ccc;
-	margin-top:1em;
-	font-size:95%;
-}
-.twikiVersatileTable th,
-.twikiVersatileTable td {
-	vertical-align:top;
-	border:0px;
-	border-top:1px solid #ccc;
-}
-.twikiVersatileTable td {
-	padding:0.2em 0.5em;
-	background-color:#F5F7FD;
-}
-.twikiVersatileTable th {
-	padding:0.5em 0.5em;
-	vertical-align:top;
-	font-weight:bold;
-	background-color:#E0E9F7;
-}
-.twikiVersatileTable .twikiMainCol {
-	background-color:white;
-}
-.twikiVersatileTable .twikiOldCol {
-	background-color:#E9E9E9;
-}
-.twikiVersatileTable input {
-	background-color:white;
-}
-.twikiVersatileTable input.twikiCheckbox {
-	background-color:transparent;
-}
-
-/*	-----------------------------------------------------------
-	Other styles
-	-----------------------------------------------------------	*/
-
-.twikiSeparator {
-	font-family:Arial,sans-serif;
-}
-.twikiHelp ul {
-	margin-top:0;
-	margin-bottom:0;
-}
-.twikiSubmit,
-.twikiButton {
-	font-size:90%;
-	font-weight:normal;
-	padding:0;
-	margin:0 0.15em;
-}
-.twikiSubmit {
-	color:#041D3A;
-	background-color:#f2f2f2;
-	border-top:1px solid #fff;
-	border-right:1px solid #333;
-	border-bottom:1px solid #333;
-	border-left:1px solid #fff;
-}
-.twikiButton {
-	color:#05264D;
-	background-color:#f2f2f2;
-	border:1px solid #aaa;
-}
-.twikiCheckbox,
-.twikiRadioButton {
-	border:none;
-	background-color:transparent;
-}
-.twikiTopic .twikiSubmit { /* topic submit button */
-	background-color:#E8F1F9;
-}
-.twikiSecondary { }
-.twikiTertiary {
-	background-color:#B9D6FA;
-}
-.twikiCancel { /* cancel button */
-	background-color:#eee;
-}
-.twikiBroadcastMessage {
-	background-color:#ff0;
-	color:black;
-	padding:0.2em 0.7em;
-	margin:0 -0.7em 0.5em -0.7em;
-}
-.twikiBroadcastMessage b,
-.twikiBroadcastMessage strong {
-	color:#f00;
-}
-.twikiAlert {
-	color:#f00;
-}
-.twikiGrayText,
-.twikiHelpCol {
-	color:#8490A1;
-}
-.twikiGrayText a:link,
-.twikiGrayText a:visited,
-.twikiHelpCol a:link,
-.twikiHelpCol a:visited {
-	color:#8490A1; /* .twikiGrayText value */
-	text-decoration:underline;
-}
-.twikiGrayText a:hover,
-.twikiHelpCol a:hover{
-	color:#1559B3;
-}
-.twikiSmall {
-	font-size:85%;
-}
-.twikiNew { }
-.twikiSummary {
-	font-size:85%;
-	line-height:1.3em;
-}
-.twikiNewLink {
-	background-color:transparent;
-}
-
-/*	-----------------------------------------------------------
-	Search results
-	styles and overridden styles used in search.pattern.tmpl
-	-----------------------------------------------------------	*/
-	
-.twikiSearchResults {}
-.twikiSearchResultsHeader,
-.twikiSearchString {
-	padding:0.2em 0.7em 0.2em 0.7em;
-	margin:0.15em -0.7em 0.25em -0.7em;
-	font-weight:bold;
-	background-color:#F3EDE7;
-	border-bottom:1px solid #ccc;
-}
-.twikiSearchString {
-	background-color:transparent;
-	margin-bottom:1em;
-	border-bottom:0px;
-}
-.twikiSearchResults table {
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:100%;
-}
-.twikiSearchResults .twikiTopRow {
-	padding-top:0.2em;
-}
-.twikiSearchResults .twikiBottomRow {
-	padding-bottom:0.25em;
-	border-bottom:1px solid #ddd;
-}
-.twikiSearchResults .twikiAlert {
-	color:#f00;
-	font-weight:bold;
-}
-.twikiSearchResults .twikiSummary .twikiAlert {
-	color:#900;
-	font-weight:normal;
-}
-.twikiSearchResults .twikiNew b {
-	font-weight:normal;
-}
-.twikiSearchResultCount {
-	margin:0.5em 0 2em 0;
-	font-size:95%;
-}
-.twikiViewPage .twikiSearchResultsBegin { /* for changes template with noheader="on" */
-	height:1px;
-	border-bottom:1px solid #ddd;
-}
-
-/* Search results in book view format */
-
-.twikiBookViewList .twikiSearchResultsHeader {
-	margin-bottom:1em;
-}
-.twikiBookViewList .twikiTopRow {
-	padding:0.2em 0.7em 0.2em 0.7em;
-	margin:2.5em -0.7em 0.15em -0.7em;
-	background-color:#22638c;
-	color:#ccc;
-}
-.twikiBookViewList .twikiTopRow a:link, 
-.twikiBookViewList .twikiTopRow a:visited {
-	color:white;
-}
-.twikiBookViewList .twikiTopRow a:hover {
-	color:#1e5bbd;
-}
-.twikiBookViewList .twikiBottomRow {
-	font-size:100%;
-	padding:1em 0;
-	border-color:#ddd;
-}
-.twikiBookViewList .twikiBottomRow {
-	width:auto;
-}
-.twikiBookViewList .twikiSearchResultCount {
-	color:#22638c;
-}
-
-
-/*	-----------------------------------------------------------
-	View
-	styles and overridden styles used in twiki.pattern.tmpl and view.pattern.tmpl
-	-----------------------------------------------------------	*/
-
-.twikiViewPage .twikiMain {
-	padding-right:2em;
-}
-.twikiViewPage .twikiAttachments,
-.twikiViewPage .twikiForm,
-.twikiPreviewPage .twikiAttachments,
-.twikiPreviewPage .twikiForm {
-	background-color:#f1f1f1;
-	padding:2em;
-	border-top:1px solid #bbb;
-	margin-top:0;
-	margin-bottom:0em;
-}
-.twikiViewPage .twikiTopicAction,
-.twikiDiffPage .twikiTopicAction {
-	margin:0 0 1.5em 0;
-	padding:0.5em 2em 0.6em 2em;
-	border:none;
-	font-size:95%;
-	line-height:1.5em;
-	color:white;
-	font-weight:normal;
-	background-color:#98A2B0;
-}
-.twikiViewPage .twikiTopicAction a:link,
-.twikiViewPage .twikiTopicAction a:visited,
-.twikiDiffPage .twikiTopicAction a:link,
-.twikiDiffPage .twikiTopicAction a:visited {
-	border-bottom:1px solid #ccc;
-	text-decoration:none;
-	font-weight:bold;
-	color:white;
-}
-.twikiViewPage .twikiTopicAction a:hover,
-.twikiDiffPage .twikiTopicAction a:hover {
-	text-decoration:none;
-	border-bottom:1px solid #b4d5ff;
-	color:#1559B3;
-}
-.twikiViewPage .twikiTopicAction a:active,
-.twikiDiffPage .twikiTopicAction a:active {
-	color:white;
-}
-
-/*	-----------------------------------------------------------
-	Pages that are not view
-	-----------------------------------------------------------	*/
-
-.twikiNoViewPage .twikiMain {
-	padding-top:2.5em;
-	padding-bottom:2em;
-}
-.twikiNoViewPage h1 {
-	font-size:170%; /* as big as h2 in topic */
-}
-.twikiNoViewPage .twikiMain {
-	border-top:0px;
-}
-
-/*	-----------------------------------------------------------
-	Edit
-	styles and overridden styles used in edit.pattern.tmpl
-	-----------------------------------------------------------	*/
-
-.twikiEditPage .twikiFormHolder { /* constrains the width of the textarea */
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:100%;
-}
-.twikiEditPage textarea {
-	background-color:#FCFAF7;
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:100%;
-}
-.twikiEditPage .twikiHelp {
-	margin-top:2em;
-	border-top:1px solid #ccc;
-}
-.twikiEditPage .twikiHelp code {
-	color:#900;
-}
-.twikiEditPage table.twikiChangeFormButtonHolder {
-	margin-bottom:0.5em;
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:100%;
-}
-.twikiChangeFormButton {
-	padding:0;
-	margin:0;
-	color:#888;
-	font-size:90%;
-	background-color:transparent;
-	border:none;
-}
-.twikiEditPage .twikiEditForm {
-	margin-top:1.5em;
-}
-.twikiEditPage .twikiEditForm table {
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:100%;
-}
-.twikiEditPage .twikiEditForm th {
-	border-left:none;
-	background-color:#E0E9F7; /*#EFEDEA;*/
-	padding-left:1em;
-	color:black;
-}
-.twikiEditPage .twikiEditForm td {
-	border-left:1px solid #ddd;
-	padding-right:1em;
-	padding-left:0.5em;
-	background-color:#F5F7FD; /*#E8F1F9;*/
-	vertical-align:middle;
-}
-.twikiEditPage .twikiEditForm input,
-.twikiEditPage .twikiEditForm select {
-	font-size:100%;
-}
-.twikiEditPage .twikiEditFormTextField {
-	width:auto;
-}
-.twikiEditPage .twikiSig {
-	margin:0.5em 0;
-}
-.twikiEditPage .twikiSig input {
-	background-color:#EFEDEA;
-	border:1px solid #ddd;
-	padding:2px;
-	width:25em;
-	font-family:monospace;
-	font-size:100%;
-}
-.twikiEditPage .twikiTopicAction {
-	margin-top:0;
-}
-
-/*	-----------------------------------------------------------
-	Preview
-	styles and overridden styles used in preview.pattern.tmpl
-	-----------------------------------------------------------	*/
-	
-.twikiPreviewPage .twikiMain {
-	background-color:transparent;
-}
-.twikiPreviewPage .twikiTopic {
-	padding-top:1.5em;
-}
-.twikiPreviewPage .twikiPreviewArea {
-	background-color:white;
-	border:1px solid #22638c;
-	margin:1em -2em 0 -2em;
-	padding:0 2em 1em 2em;
-}
-.twikiPreviewPage .twikiHelp ul {
-	margin-top:0;
-}
-.twikiPreviewPage .twikiTopic h1 {
-	font-size:210%; /* restore original size */
-}
-	
-/*	-----------------------------------------------------------
-	Attach
-	styles and overridden styles used in attach.pattern.tmpl
-	-----------------------------------------------------------	*/
-
-.twikiAttachPage .twikiVersatileTable table {
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:100%;	
-}
-.twikiAttachPage .twikiVersatileTable th,
-.twikiAttachPage .twikiVersatileTable td {
-	padding:0.7em 1em 0.7em 1.25em;
-}
-.twikiAttachPage .twikiVersatileTable th {
-	text-align:left;
-	width:12em;
-	padding-left:1em;
-}
-.twikiAttachPage .twikiVersatileTable td.twikiHelpCol {
-	width:17em;
-}
-.twikiAttachPage .twikiTopicAction {
-	margin:2em 0 1em 0;
-}
-.twikiAttachPage .twikiHelp {
-	margin:2em 0 3em 0;
-}
-.twikiAttachPage .twikiHelp ul {
-	padding:0;
-	margin:1em 0 0 0;
-}
-.twikiAttachPage .twikiHelp ul li {
-	list-style:none;
-	line-height:150%;
-}
-.twikiAttachPage .twikiPrevious .twikiAttachments table {
-	width:auto;
-	color:black;
-}
-.twikiAttachPage .twikiTopic {
-	padding-bottom:0;
-}
-
-/*	-----------------------------------------------------------
-	ChangeForm
-	styles and overridden styles used in attach.pattern.tmpl
-	-----------------------------------------------------------	*/
-
-.twikiChangeFormPage .twikiVersatileTable table {
-	width:auto;
-}
-.twikiChangeFormPage .twikiVersatileTable th {
-	text-align:left;
-	padding:0.25em 1em;
-}
-.twikiChangeFormPage .twikiVersatileTable td {
-	padding:1em;
-}
-.twikiChangeFormPage .twikiVersatileTable ul {
-	margin:0;
-	padding:0;
-}
-.twikiChangeFormPage .twikiVersatileTable li {
-	list-style:inside;
-	margin:0;
-	padding:0;
-}
-
-/*	-----------------------------------------------------------
-	Rename
-	styles and overridden styles used in rename.pattern.tmpl
-	-----------------------------------------------------------	*/
-	
-.twikiRenamePage .twikiVersatileTable {
-	margin-bottom:3em;
-}
-.twikiRenamePage .twikiVersatileTable table {
-	width:auto;
-	voice-family: "\"}\""; /* hide the following for Explorer 5.x */
-	voice-family:inherit;
-	width:100%;	
-}
-.twikiRenamePage .twikiVersatileTable th {
-	text-align:right;
-	padding-left:2em;
-}
-.twikiRenamePage .twikiVersatileTable td {
-	padding:0.5em 0.5em;
-}
-.twikiRenamePage .twikiVersatileTable .twikiHelpCol {
-	width:22em;
-}
-.twikiRenamePage .twikiVersatileTable th.lastRow,
-.twikiRenamePage .twikiVersatileTable td.lastRow {
-	border-top:none;
-}
-.twikiRenamePage .twikiHelp {
-	margin:1em 0 1em 0;
-	padding:0.25em 0 0.5em 0;
-}
-.twikiRenamePage .twikiTopicActionSecondary {
-	margin:1.5em 0;
-}
-
-/*	-----------------------------------------------------------
-	Diff
-	styles and overridden styles used in rdiff.pattern.tmpl
-	-----------------------------------------------------------	*/
-
-.twikiDiffPage table {
-	width:auto;
-}
-.twikiDiffPage .twikiSearchResultsHeader {
-	border-bottom:0;
-}
-.twikiDiffPage .twikiSearchResults {
-	padding-bottom:3em;
-}
-.twikiDiffPage .twikiDiffTable th,
-.twikiDiffPage .twikiDiffTable td {
-	padding:0.1em;
-}
-
-/* Deleted */
-
-.twikiDiffPage .twikiDiffDeletedHeader {
-	background-color:#FF3000;
-	color:white;
-	padding-left:1em;
-}
-.twikiDiffPage .twikiDiffDeletedMarker {
-	background-color:#FF3000;
-}
-.twikiDiffPage .twikiDiffDeletedText {
-	background-color:#FFEAE5;
-}
-
-/* Added */
-
-.twikiDiffPage .twikiDiffAddedHeader {
-	background-color:#3DB234;
-	color:white;
-	padding-left:1em;
-}
-.twikiDiffPage .twikiDiffAddedMarker {
-	background-color:#3DB234;
-}
-.twikiDiffPage .twikiDiffAddedText {
-	background-color:#EBF7EA;
-}
-
-/* Changed */
-
-.twikiDiffPage th.twikiDiffChangedHeader,
-.twikiDiffPage td.twikiDiffChangedHeader {
-	background-color:#98A2B0;
-	color:white;
-	padding-left:1em;
-	text-align:center;
-}
-.twikiDiffPage .twikiDiffChangedText {}
-
-/* Unchanged */
-
-.twikiDiffPage .twikiDiffUnchangedText {}
-.twikiDiffPage .twikiDiffUnchangedTextContents { }
-.twikiDiffPage .twikiDiffLineNumberHeader {
-	margin:2em 0;
-	background-color:#ddd;
-}
-
-/*	-----------------------------------------------------------
-	Print
-	styles and overridden styles used in print.pattern.tmpl
-	-----------------------------------------------------------	*/
-	
-.twikiPrintPage .twikiMain {
-	border-left:0;
-	border-top:0;
-	padding-top:2em;
-}
-.twikiPrintPage h2 {
-	border-bottom:1px solid #900;
-}
-.twikiPrintPage .twikiAttachments,
-.twikiPrintPage .twikiForm {
-	background-color:#ddd;
-}
-
-/*	-----------------------------------------------------------
-	Plain
-	styles and overridden styles used in plain.pattern.tmpl
-	-----------------------------------------------------------	*/
-	
-.twikiPlainPage .twikiMain {
-	padding-top:2.5em;
-	padding-bottom:2em;
-}
\ No newline at end of file
diff --git a/Calorimeter/CaloExample/CaloTests/share/runMacros2T.C b/Calorimeter/CaloExample/CaloTests/share/runMacros2T.C
deleted file mode 100755
index 183cd12b0ab0699e5ae449f8a8f379ed2afb9d94..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/runMacros2T.C
+++ /dev/null
@@ -1,21 +0,0 @@
-
-#include "TSystem.h"
-
-void runMacros2T()
-{
-  int nbTests=2;
-  string macros[]={"runPython2T.C","CaloTests_plotAllCaloNoise13.C"};
-
-  ofstream chkfile("runMacros2T.txt",ios::out);	
-  
-
-  for(int i=0;i<nbTests;i++)
-    {
-      string com;
-      chkfile << "Run " << macros[i] << std::endl;
-      com="root.exe -b -q "+macros[i];
-      gSystem->Exec(com.c_str());
-      chkfile << "Run " << macros[i] << " Done." << std::endl;
-    }
-  chkfile.close();
-}
diff --git a/Calorimeter/CaloExample/CaloTests/share/runMacros2Test.C b/Calorimeter/CaloExample/CaloTests/share/runMacros2Test.C
deleted file mode 100755
index e346f7b26f772779f6909b2df5ef897a94d1b623..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/runMacros2Test.C
+++ /dev/null
@@ -1,22 +0,0 @@
-
-#include "TSystem.h"
-
-// conflicts with runMacros2 from CaloRecEx
-void runMacros2Test()
-{
-  int nbTests=2;
-  string macros[]={"runPython2.C","CaloTests_plotAllCaloNoise13.C"};
-
-  ofstream chkfile("runMacros2.txt",ios::out);	
-  
-
-  for(int i=0;i<nbTests;i++)
-    {
-      string com;
-      chkfile << "Run " << macros[i] << std::endl;
-      com="root.exe -b -q "+macros[i];
-      gSystem->Exec(com.c_str());
-      chkfile << "Run " << macros[i] << " Done." << std::endl;
-    }
-  chkfile.close();
-}
diff --git a/Calorimeter/CaloExample/CaloTests/share/runPython2T.C b/Calorimeter/CaloExample/CaloTests/share/runPython2T.C
deleted file mode 100755
index 906f048dbd435e3946a266ec5ff704053ec91b29..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/runPython2T.C
+++ /dev/null
@@ -1,26 +0,0 @@
-
-#include "TSystem.h"
-
-void runPython2T()
-{
-  int nbTests=1;
-  string macros[]={"checkT.py"};
-
-  ofstream chkfile("runPython2T.txt",ios::out);	
-
- 
-  std::cout << "LD_LIBRARY_PATH is " << gSystem->Getenv("LD_LIBRARY_PATH") << std::endl;
-
-  std::cout << "PATH is " << gSystem->Getenv("PATH") << std::endl;
-
-
-  for(int i=0;i<nbTests;i++)
-    {
-      string com;
-      chkfile << "Run " << macros[i] << std::endl;
-      com="python "+macros[i];
-      gSystem->Exec(com.c_str());
-      chkfile << "Run " << macros[i] << " Done." << std::endl;
-    }
-  chkfile.close();
-}
diff --git a/Calorimeter/CaloExample/CaloTests/share/runPython2Test.C b/Calorimeter/CaloExample/CaloTests/share/runPython2Test.C
deleted file mode 100755
index 99554df559129c8c58fb304606da12f0a3efb961..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/runPython2Test.C
+++ /dev/null
@@ -1,27 +0,0 @@
-
-#include "TSystem.h"
-
-// conflicts with runPython2 from CaloRecEx
-void runPython2()
-{
-  int nbTests=1;
-  string macros[]={"check.py"};
-
-  ofstream chkfile("runPython2.txt",ios::out);	
-
- 
-  std::cout << "LD_LIBRARY_PATH is " << gSystem->Getenv("LD_LIBRARY_PATH") << std::endl;
-
-  std::cout << "PATH is " << gSystem->Getenv("PATH") << std::endl;
-
-
-  for(int i=0;i<nbTests;i++)
-    {
-      string com;
-      chkfile << "Run " << macros[i] << std::endl;
-      com="python "+macros[i];
-      gSystem->Exec(com.c_str());
-      chkfile << "Run " << macros[i] << " Done." << std::endl;
-    }
-  chkfile.close();
-}
diff --git a/Calorimeter/CaloExample/CaloTests/share/test_noise.py b/Calorimeter/CaloExample/CaloTests/share/test_noise.py
deleted file mode 100644
index b309d7a39e587890da18d3c1229b6503da0235b4..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/test_noise.py
+++ /dev/null
@@ -1,100 +0,0 @@
-###############################################################
-#
-# Job options file to run Digitization
-#
-#==============================================================
-from AthenaCommon.DetFlags import DetFlags
-from AthenaCommon.GlobalFlags import GlobalFlags
-GlobalFlags.DetGeo.set_atlas()
-GlobalFlags.Luminosity.set_zero()
-GlobalFlags.DataSource.set_geant4() 
-DetFlags.detdescr.all_setOn()
-DetFlags.ID_setOff()
-DetFlags.Muon_setOff()
-
-DetFlags.readRDOPool.LAr_setOn()
-DetFlags.makeRIO.LAr_setOn()
-
-
-include( "PartPropSvc/PartPropSvc.py" )
-
-
-from AthenaCommon.AppMgr import ServiceMgr
-import AthenaPoolCnvSvc.ReadAthenaPool
-ServiceMgr.EventSelector.InputCollections = [ "/afs/cern.ch/atlas/offline/data/testfile/calib1_csc11.007234.singlepart_mu200.simul.HITS.v12000301_tid003123._00001.pool.root" ]
-
-
-# the Tile, LAr and Calo detector description package
-DetDescrVersion = "ATLAS-CSC-01-02-00" 
-
-include( "DetDescrDictionary/DetDescrDictionaryDict_joboptions.py" )
-include ("AtlasGeoModel/SetGeometryVersion.py")
-include( "AtlasGeoModel/GeoModelInit.py" )
-include( "TileConditions/TileConditions_jobOptions.py" )
-include( "CaloIdCnv/CaloIdCnv_joboptions.py" )
-include( "TileIdCnv/TileIdCnv_jobOptions.py" )
-include( "LArDetMgrDetDescrCnv/LArDetMgrDetDescrCnv_joboptions.py" )
-
-
-#force alignment to use ideal one
-IOVDbSvc = Service( "IOVDbSvc" )
-IOVDbSvc.GlobalTag="OFLCOND-CSC-00-00-00"
-
-
-
-from AthenaCommon.AlgSequence import AlgSequence 
-topSequence = AlgSequence()
-
- 	
-
-from MyAnalysis.MyAnalysisConf import MyAnalysis__Analysis
-topSequence += MyAnalysis__Analysis()
-
-Analysis=MyAnalysis__Analysis("Analysis")
-
-
-Analysis.LoopRaw = FALSE
-Analysis.Check = FALSE
-Analysis.LoopHit = TRUE
-Analysis.LoopCalHit = FALSE
-Analysis.LoopCluster = FALSE
-Analysis.LoopCell = FALSE
-Analysis.UseTriggerTime = FALSE;
-# Analysis.TriggerTimeToolName = "CosmicTriggerTimeTool"
-
-#--------------------------------------------------------------
-# Set output level threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL )
-#--------------------------------------------------------------
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.OutputLevel      = VERBOSE
-MessageSvc.Format = "% F%40W%S%7W%R%T %0W%M"
-
-THistSvc = Service ( "THistSvc" )
-THistSvc.Output  = ["file1 DATAFILE='test.root' OPT='RECREATE'"];
-
-
-#--------------------------------------------------------------
-# Event related parameters
-#--------------------------------------------------------------
-# Number of events to be processed (default is 10)
-theApp.EvtMax = 1
-theApp.EvtSel = "EventSelector"
-
-# Use auditors
-theApp.Dlls += [ "GaudiAud" ]
-#
-# write out a summary of the time spent
-#
-theAuditorSvc = AuditorSvc()
-theAuditorSvc.Auditors  += [ "ChronoAuditor"]
-theAuditorSvc.Auditors  += [ "MemStatAuditor" ]
-MemStatAuditor = theAuditorSvc.auditor( "MemStatAuditor" )
-MemStatAuditor.OutputLevel = INFO
-
-MessageSvc = Service( "MessageSvc" )
-MessageSvc.infoLimit  = 100000000
-MessageSvc.OutputLevel = VERBOSE
-
-#StoreGateSvc=Service("StoreGateSvc");
-#StoreGateSvc.dump=TRUE
-
diff --git a/Calorimeter/CaloExample/CaloTests/share/updatejo.sh b/Calorimeter/CaloExample/CaloTests/share/updatejo.sh
deleted file mode 100755
index 880f733a82f1a821d66ae5e88c6ff86d514b4d91..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/share/updatejo.sh
+++ /dev/null
@@ -1,8 +0,0 @@
-#!/bin/bash
-
-for jo in $(ls CaloTests*Dig*py)
-do
-echo "doing $jo"
-sed "s/#DetFlags.LVL1_setOff()/DetFlags.LVL1_setOff()/g" $jo > tmp
-mv tmp $jo
-done
diff --git a/Calorimeter/CaloExample/CaloTests/src/CreateHits.cxx.test b/Calorimeter/CaloExample/CaloTests/src/CreateHits.cxx.test
deleted file mode 100644
index ef5d33b8907b0da4e11b25c149bd5774777628e4..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/src/CreateHits.cxx.test
+++ /dev/null
@@ -1,120 +0,0 @@
-#include "MyAnalysis/CreateHits.h"
-#include "Gaudi/Property.h"
-#include "GaudiKernel/MsgStream.h"
-#include "GaudiKernel/NTuple.h"
-
-#include "LArSimEvent/LArHit.h"
-#include "LArSimEvent/LArHitContainer.h"
-#include "Identifier/Identifier.h"
-#include "CaloIdentifier/CaloIdManager.h"
-
-
-
-namespace CreateHits {
-
-  //Constructor
-  CreateHits::CreateHits(const std::string& name, ISvcLocator* pSvcLocator):
-    Algorithm(name,pSvcLocator){
-  }
-  
-  //__________________________________________________________________________
-  //Destructor
-  CreateHits::~CreateHits()
-  {
-    MsgStream log( messageService(), name() ) ;
-    log << MSG::DEBUG << "CreateHits destructor called" << endmsg;
-  }
-  //__________________________________________________________________________
-  StatusCode CreateHits::initialize()
-  {
-    
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG <<"CreateHits initialize()" << endmsg;
-    StatusCode sc;
-
-    // Get the StoreGateSvc
-    sc = service("StoreGateSvc", m_sgSvc);
-    if (sc.isFailure()) {
-      log << MSG::ALWAYS << "No StoreGate!!!!!!!" << endmsg;
-      return StatusCode::FAILURE;
-    }
-
-    sc = service ( "DetectorStore" , detStore ) ;
-    if (sc.isFailure()) 
-    {
-      log    << MSG::ERROR
-             << "Unable to access pointer to DetectorStore"
-             << endmsg;
-      return StatusCode::FAILURE;
-    }
-
-
-  //retrieve ID helpers
-    const DataHandle<CaloIdManager> caloIdMgr;
-    sc = detStore->retrieve(caloIdMgr);
-    if (sc.isFailure()) {
-       log << MSG::ERROR
-           << "Unable to retrieve CaloIdManager from DetectoreStore"
-           << endmsg; 
-      return StatusCode::FAILURE;
-    }   
-    m_larem_id   = caloIdMgr->getEM_ID();
-
-    m_nevt=0;
-
-
-    return StatusCode::SUCCESS; 
-  }
-  //__________________________________________________________________________
-  StatusCode CreateHits::finalize()
-  {
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG <<"CreateHits finalize()" << endmsg;
-    return StatusCode::SUCCESS; 
-  }
-  
-  //__________________________________________________________________________
-  StatusCode CreateHits::execute()
-  {
-    //.............................................
-    
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG << "CreateHits execute()" << endmsg;
-    StatusCode sc;
-
-    LArHitContainer * HitContainer = new LArHitContainer();
-    if (!HitContainer) {
-       log << MSG::ERROR << "cannot crete Hit container " << endmsg;
-       return StatusCode::FAILURE;
-    }
-   
-    sc = m_sgSvc->record(HitContainer,"LArHitEMB");
-    if (sc.isFailure()) {
-      log << MSG::ERROR << "cannot record hit container in storegate " << endmsg;
-      return StatusCode::FAILURE;
-    }
-
-// loop over hits to create
-    for(int i=0;i<60;i++) {
-       int bec=1;
-       int sampling=2;
-       int region=0;
-       int eta=10;
-       int phi=i;
-       double energy=10000.;
-       double time=0.5*(((double)i) - 30.);
-       Identifier id = m_larem_id->channel_id(bec,sampling,region,eta,phi);
-       LArHit * hit = new LArHit(id,energy,time);
-       HitContainer->push_back(hit);
-    }
-
-    sc = m_sgSvc->setConst(HitContainer);
-    if (sc.isFailure()) {
-      log << MSG::ERROR << "cannot lock hit container " << endmsg;
-      return StatusCode::FAILURE;
-    }
-
-    return StatusCode::SUCCESS;
- }
- 
-} // end of namespace bracket
diff --git a/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx b/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx
deleted file mode 100644
index bbafed3e8f5f69a018b1bcd826f27368980872f4..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx
+++ /dev/null
@@ -1,1445 +0,0 @@
-/*
-  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "CaloTests/Analysis.h"
-#include "Gaudi/Property.h"
-#include "GaudiKernel/MsgStream.h"
-#include "GaudiKernel/NTuple.h"
-
-#include "AtlasDetDescr/AtlasDetectorID.h"
-#include "CaloDetDescr/CaloDetDescrElement.h"
-#include "CaloIdentifier/LArID.h"
-#include "Identifier/Identifier.h"
-#include "Identifier/IdentifierHash.h"
-
-#include "LArSimEvent/LArHit.h"
-#include "LArSimEvent/LArHitContainer.h"
-#include "CaloSimEvent/CaloCalibrationHit.h"
-#include "CaloSimEvent/CaloCalibrationHitContainer.h"
-#include "CaloEvent/CaloCell.h"
-#include "CaloEvent/CaloCellContainer.h"
-#include "CaloGeoHelpers/CaloSampling.h"
-#include "CaloEvent/CaloCluster.h"
-#include "CaloEvent/CaloClusterContainer.h"
-#include "LArRawEvent/LArRawChannel.h"
-#include "LArRawEvent/LArRawChannelContainer.h"
-#include "LArRawUtils/LArRawDetSelector.h"
-#include "LArIdentifier/LArOnlineID.h"
-#include "GeneratorObjects/McEventCollection.h"
-#include "StoreGate/ReadHandle.h"
-#include "AtlasHepMC/GenEvent.h"
-#include "AtlasHepMC/GenParticle.h"
-
-#include "GaudiKernel/IToolSvc.h"
-#include "GaudiKernel/ListItem.h"
-#include "AthenaKernel/ITriggerTime.h"
-
-
-
-
-namespace MyAnalysis {
-
-  //Constructor
-  Analysis:: Analysis(const std::string& name, ISvcLocator* pSvcLocator):
-    AthAlgorithm(name,pSvcLocator),
-    m_thistSvc(nullptr),
-    m_hist_etraw_emb_s0(nullptr),
-    m_hist_etraw_emb_s1(nullptr),
-    m_hist_etraw_emb_s2(nullptr),
-    m_hist_etraw_emb_s3(nullptr),
-    m_hist_etraw_emec_s0(nullptr),
-    m_hist_etraw_emec_s1(nullptr),
-    m_hist_etraw_emec_s2(nullptr),
-    m_hist_etraw_emec_s3(nullptr),
-    m_hist_clusnoise(nullptr),
-    m_hist_clusnoise1(nullptr),
-    m_hist_clusnoise2(nullptr),
-    m_hist_clusnoise3(nullptr),
-    m_hist_ot(nullptr),
-    m_hist_ot_em(nullptr),
-    m_hist_ot_hec(nullptr),
-    m_hist_ot_fcal(nullptr),
-    m_hist_it(nullptr),
-    m_hist_it_em(nullptr),
-    m_hist_it_hec(nullptr),
-    m_hist_it_fcal(nullptr),
-    m_hist_hittime(nullptr),
-    m_hist_hitener(nullptr),
-    m_hist_nhitlar(nullptr),
-    m_hist_cal0(nullptr),
-    m_hist_cal1(nullptr),
-    m_hist_cal2(nullptr),
-    m_hist_cal3(nullptr),
-    m_triggerTimeTool(nullptr),
-    m_larem_id(nullptr),
-    m_calodm_id(nullptr),
-    m_ntuple(nullptr)
-  {
-
-    m_clusternoise=false;
-    m_raw=false;
-    m_check=false;
-    m_cell=false;
-    m_hit=true;
-    m_calhit=false;
-    m_cluster=false;
-    m_useTriggerTime    = false;
-    m_doTruth=true;
-
-    m_nevt = 0;
-    m_nt_e = 0;
-    m_nt_eta = 0;
-    m_nt_phi = 0;
-    m_nt_e0 = 0;
-    m_nt_e1 = 0;
-    m_nt_e2 = 0;
-    m_nt_e3 = 0;
-    m_nt_c0 = 0;
-    m_nt_c1 = 0;
-    m_nt_c2 = 0;
-    m_nt_c3 = 0;
-    m_nt_hb0 = 0;
-    m_nt_hb1 = 0;
-    m_nt_hb2 = 0;
-    m_nt_hb3 = 0;
-    m_nt_he0 = 0;
-    m_nt_he1 = 0;
-    m_nt_he2 = 0;
-    m_nt_he3 = 0;
-    m_nt_tb0 = 0;
-    m_nt_tb1 = 0;
-    m_nt_tb2 = 0;
-    m_nt_tb3 = 0;
-    m_nt_eclus = 0;
-    m_nt_eclus0 = 0;
-    m_nt_eclus1 = 0;
-    m_nt_eclus2 = 0;
-    m_nt_eclus3 = 0;
-    m_nt_etaclus = 0;
-    m_nt_phiclus = 0;
-    m_nt_etaclus551 = 0;
-    m_nt_etaclus552 = 0;
-    m_nt_eclus35 = 0;
-    m_nt_eclus37 = 0;
-    m_nt_eclus350 = 0;
-    m_nt_eclus351 = 0;
-    m_nt_eclus352 = 0;
-    m_nt_eclus353 = 0;
-    m_nt_etaclus35 = 0;
-    m_nt_etaclus351 = 0;
-    m_nt_etaclus352 = 0;
-    m_nt_etaclus371 = 0;
-    m_nt_etaclus372 = 0;
-    m_nt_eclusg = 0;
-    m_nt_etaclusg551 = 0;
-    m_nt_etaclusg552 = 0;
-    m_nt_eclusg35 = 0;
-    m_nt_etaclusg351 = 0;
-    m_nt_etaclusg352 = 0;
-    m_nt_eclusg37 = 0;
-    m_nt_etaclusg371 = 0;
-    m_nt_etaclusg372 = 0;
-    m_nt_eActEM = 0;
-    m_nt_eActNonEM = 0;
-    m_nt_eActEscaped = 0;
-    m_nt_eActInvisible = 0;
-    m_nt_eInactEM = 0;
-    m_nt_eInactNonEM = 0;
-    m_nt_eInactEscaped = 0;
-    m_nt_eInactInvisible = 0;
-    m_nt_eDeadEM = 0;
-    m_nt_eDeadNonEM = 0;
-    m_nt_eDeadEscaped = 0;
-    m_nt_eDeadInvisible = 0;
-    m_nt_eTile = 0;
-    m_nt_edead_1_0 = 0;
-    m_nt_edead_1_1_0 = 0;
-    m_nt_edead_1_1_1 = 0;
-    m_nt_edead_1_1_2 = 0;
-    m_nt_edead_1_1_3 = 0;
-    m_nt_edead_1_1_4 = 0;
-    m_nt_edead_1_1_5 = 0;
-    m_nt_edead_1_1_6 = 0;
-    m_nt_edead_1_1_7 = 0;
-    m_nt_edead_1_2_0 = 0;
-    m_nt_edead_1_2_1 = 0;
-    m_nt_edead_1_2_2 = 0;
-    m_nt_edead_1_2_3 = 0;
-    m_nt_edead_1_2_4 = 0;
-    m_nt_edead_1_2_5 = 0;
-    m_nt_edead_1_3 = 0;
-    m_nt_eleak = 0;
-    m_xconv = 0;
-    m_yconv = 0;
-    m_zconv = 0;
-    m_xvert = 0;
-    m_yvert = 0;
-    m_zvert = 0;
-    
-
-    declareProperty("ClusterNoise",m_clusternoise);
-    declareProperty("Check",m_check);
-    declareProperty("LoopRaw",m_raw);
-    declareProperty("LoopHit",m_hit);
-    declareProperty("LoopCalHit",m_calhit);
-    declareProperty("LoopCell",m_cell);
-    declareProperty("LoopCluster",m_cluster);
-    declareProperty("UseTriggerTime",m_useTriggerTime);
-    declareProperty("TriggerTimeToolName",m_triggerTimeToolName);
-    declareProperty("DoTruth",m_doTruth);
-
-  }
-  
-  //__________________________________________________________________________
-  //Destructor
-  Analysis::~Analysis()
-  {
-    ATH_MSG_DEBUG( "Analysis destructor called"  );
-  }
-  //__________________________________________________________________________
-  StatusCode Analysis::initialize()
-  {
-    
-    ATH_MSG_DEBUG("Analysis initialize()"  );
-
-    //retrieve ID helpers 
-    const CaloIdManager* mgr = nullptr;
-    ATH_CHECK( detStore()->retrieve( mgr ) );
-    m_larem_id   = mgr->getEM_ID();
-    m_calodm_id  = mgr->getDM_ID();
-
-//  retrieve CaloDetDescrMgr 
-    const CaloDetDescrManager* calodetdescrmgr = nullptr;
-    ATH_CHECK( detStore()->retrieve(calodetdescrmgr) );
-
-// initialize hit list
-    if (m_check) {
-       int ncellem=m_larem_id->channel_hash_max();
-       CellInfo cell0;
-       cell0.bec=0;
-       cell0.sampling=0;
-       cell0.eta=0.; 
-       cell0.phi=0.; 
-       cell0.Ehit=-9999.;
-       cell0.Thit=-9999.;
-       cell0.Eraw=-9999.;
-       cell0.Ecell=-9999.;
-       cell0.identifier=0;
-       m_CellListEM.resize(ncellem,cell0);
-
-       const CaloDetDescrElement* calodde=nullptr;
-       for (int i=0;i<ncellem;i++){
-         IdentifierHash idHash=i;
-         Identifier id=m_larem_id->channel_id(idHash);
-         int BvsEC=abs(m_larem_id->barrel_ec(id));
-         int calotype;
-         if (BvsEC == 1) calotype=0;
-         else calotype=1;
-
-         CellInfo mycell;
-         mycell.bec=calotype;
-         mycell.sampling= m_larem_id->sampling(id);
-         calodde = calodetdescrmgr->get_element(id);
-         mycell.eta=calodde->eta();
-         mycell.phi=calodde->phi();
-         mycell.Ehit=-9999.;
-         mycell.Thit=-9999.;
-         mycell.Eraw=-9999.;
-         mycell.Ecell=-9999.;
-         mycell.identifier=id;
-         m_CellListEM[idHash]=mycell;
-       }
-    }   // m_check
-
-    ATH_CHECK( m_cablingKey.initialize() );
-    ATH_CHECK( service("THistSvc",m_thistSvc) );
-    ATH_MSG_INFO( " retrieved THistSvc" );
-
-    StatusCode sc;
-    m_hist_etraw_emb_s0 = new TH1D("m_hist_etraw_emb_s0","E EMB S0",4000,-100.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_etraw_emb_s0",m_hist_etraw_emb_s0);
-    m_hist_etraw_emb_s1 =  new TH1D("m_hist_etraw_emb_s1","E EMB S1",4000,-100.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_etraw_emb_s1",m_hist_etraw_emb_s1);
-    m_hist_etraw_emb_s2 =  new TH1D("m_hist_etraw_emb_s2","E EMB S2",4000,-100.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_etraw_emb_s2",m_hist_etraw_emb_s2);
-    m_hist_etraw_emb_s3 = new TH1D("m_hist_etraw_emb_s3","E EMB S3",4000,-100.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_etraw_emb_s3",m_hist_etraw_emb_s3);
-    m_hist_etraw_emec_s0 = new TH1D("m_hist_etraw_emec_s0","E EMEC S0",4000,-400.,400.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_etraw_emec_s0",m_hist_etraw_emec_s0);
-    m_hist_etraw_emec_s1 = new TH1D("m_hist_etraw_emec_s1","E EMEC S1",4000,-100.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_etraw_emec_s1",m_hist_etraw_emec_s1);
-    m_hist_etraw_emec_s2 = new TH1D("m_hist_etraw_emec_s2","E EMEC S2",4000,-100.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_etraw_emec_s2",m_hist_etraw_emec_s2);
-    m_hist_etraw_emec_s3 = new TH1D("m_hist_etraw_emec_s3","E EMEC S3",4000,-100.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_etraw_emec_s3",m_hist_etraw_emec_s3);
-
-    m_hist_clusnoise = new TH1D("m_hist_clusnoise","Et in 5*3 EMB",400,-2000.,2000.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_clusnoise",m_hist_clusnoise);
-    m_hist_clusnoise1 = new TH1D("m_hist_clusnoise1","Et in 5*3 0-0.5",400,-2000.,2000.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_clusnoise1",m_hist_clusnoise1);
-    m_hist_clusnoise2 = new TH1D("m_hist_clusnoise2","Et in 5*3 0.5-1.",400,-2000.,2000.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_clusnoise2",m_hist_clusnoise2);
-    m_hist_clusnoise3 = new TH1D("m_hist_clusnoise3","Et in 5*3 1-1.4",400,-2000.,2000.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_clusnoise3",m_hist_clusnoise3);
-
-    m_hist_ot = new TH1D("m_hist_ot","E OT Larhit ",2000,0.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_ot",m_hist_ot);
-    m_hist_ot_em = new TH1D("m_hist_ot_em","E EM OT Larhit ",2000,0.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_ot_em",m_hist_ot_em);
-    m_hist_ot_hec = new TH1D("m_hist_ot_hec","E HEC OT Larhit ",2000,0.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_ot_hec",m_hist_ot_hec);
-    m_hist_ot_fcal = new TH1D("m_hist_ot_fcal","E FCAL OT Larhit ",2000,0.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_ot_fcal",m_hist_ot_fcal);
-    m_hist_it = new TH1D("m_hist_it","E IT Larhit ",2000,0.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_it",m_hist_it);
-    m_hist_it_em = new TH1D("m_hist_it_em","E EM IT Larhit ",2000,0.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_it_em",m_hist_it_em);
-    m_hist_it_hec = new TH1D("m_hist_it_hec","E HEC IT Larhit ",2000,0.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_it_hec",m_hist_it_hec);
-    m_hist_it_fcal = new TH1D("m_hist_it_fcal","E FCAL IT Larhit ",2000,0.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_it_fcal",m_hist_it_fcal);
-
-
-    m_hist_hittime = new TH1D("m_hist_hittime","Hit time",200,0.,200.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_hittime",m_hist_hittime);
-    m_hist_hitener = new TH1D("m_hist_hitener","Hit Ener",500,0.,100.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_hitener",m_hist_hitener);
-    m_hist_nhitlar = new TH1D("m_hist_nhitlar","Nhits LAr",1000,0.,100000.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_nhitlar",m_hist_nhitlar);
-
-    m_hist_cal0 =  new TH1D("m_hist_cal0","Energy EM ",100,0.,10000.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_cal0",m_hist_cal0);
-    m_hist_cal1 = new TH1D("m_hist_cal1","Energy NonEM ",100,0.,10000.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_cal1",m_hist_cal1);
-    m_hist_cal2 = new TH1D("m_hist_cal2","Energy Invisible ",100,0.,10000.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_cal2",m_hist_cal2);
-    m_hist_cal3 = new TH1D("m_hist_cal3","Energy Escaped ",100,0.,10000.);
-    sc = m_thistSvc->regHist("/file1/analysis/m_hist_cal3",m_hist_cal3);
-
-    m_ntuple = new TTree("m_ntuple","my ntuple");
-    m_ntuple->Branch("etrue",&m_nt_e,"etrue/D");
-    m_ntuple->Branch("eta",&m_nt_eta,"eta/D");
-    m_ntuple->Branch("phi",&m_nt_phi,"phi/D");
-    m_ntuple->Branch("eraw0",&m_nt_e0,"eraw0/D");
-    m_ntuple->Branch("eraw1",&m_nt_e1,"eraw1/D");
-    m_ntuple->Branch("eraw2",&m_nt_e2,"eraw2/D");
-    m_ntuple->Branch("eraw3",&m_nt_e3,"eraw3/D");
-    m_ntuple->Branch("ecell0",&m_nt_c0,"ecell0/D");
-    m_ntuple->Branch("ecell1",&m_nt_c1,"ecell1/D");
-    m_ntuple->Branch("ecell2",&m_nt_c2,"ecell2/D");
-    m_ntuple->Branch("ecell3",&m_nt_c3,"ecell3/D");
-    m_ntuple->Branch("ehitb0",&m_nt_hb0,"ehitb0/D");
-    m_ntuple->Branch("ehitb1",&m_nt_hb1,"ehitb1/D");
-    m_ntuple->Branch("ehitb2",&m_nt_hb2,"ehitb2/D");
-    m_ntuple->Branch("ehitb3",&m_nt_hb3,"ehitb3/D");
-    m_ntuple->Branch("ehite0",&m_nt_he0,"ehite0/D");
-    m_ntuple->Branch("ehite1",&m_nt_he1,"ehite1/D");
-    m_ntuple->Branch("ehite2",&m_nt_he2,"ehite2/D");
-    m_ntuple->Branch("ehite3",&m_nt_he3,"ehite3/D");
-    m_ntuple->Branch("timeb0",&m_nt_tb0,"timeb0/D");
-    m_ntuple->Branch("timeb1",&m_nt_tb1,"timeb1/D");
-    m_ntuple->Branch("timeb2",&m_nt_tb2,"timeb2/D");
-    m_ntuple->Branch("timeb3",&m_nt_tb3,"timeb3/D");
-    m_ntuple->Branch("eclus",&m_nt_eclus,"eclus/D");
-    m_ntuple->Branch("eclus0",&m_nt_eclus0,"eclus0/D");
-    m_ntuple->Branch("eclus1",&m_nt_eclus1,"eclus1/D");
-    m_ntuple->Branch("eclus2",&m_nt_eclus2,"eclus2/D");
-    m_ntuple->Branch("eclus3",&m_nt_eclus3,"eclus3/D");
-    m_ntuple->Branch("etaclus",&m_nt_etaclus,"etaclus/D");
-    m_ntuple->Branch("phiclus",&m_nt_phiclus,"phiclus/D");
-    m_ntuple->Branch("etaclus551",&m_nt_etaclus551,"etaclus551/D");
-    m_ntuple->Branch("etaclus552",&m_nt_etaclus552,"etaclus552/D");
-    m_ntuple->Branch("eclus35",&m_nt_eclus35,"eclus35/D");
-    m_ntuple->Branch("eclus350",&m_nt_eclus350,"eclus350/D");
-    m_ntuple->Branch("eclus351",&m_nt_eclus351,"eclus351/D");
-    m_ntuple->Branch("eclus352",&m_nt_eclus352,"eclus352/D");
-    m_ntuple->Branch("eclus353",&m_nt_eclus353,"eclus353/D");
-    m_ntuple->Branch("etaclus35",&m_nt_etaclus35,"etaclus35/D");
-    m_ntuple->Branch("etaclus351",&m_nt_etaclus351,"etaclus351/D");
-    m_ntuple->Branch("etaclus352",&m_nt_etaclus352,"etaclus352/D");
-    m_ntuple->Branch("eclus37",&m_nt_eclus37,"eclus37/D");
-    m_ntuple->Branch("etaclus371",&m_nt_etaclus371,"etaclus371/D");
-    m_ntuple->Branch("etaclus372",&m_nt_etaclus372,"etaclus372/D");
-    m_ntuple->Branch("eclusg",&m_nt_eclusg,"eclusg/D");
-    m_ntuple->Branch("etaclusg551",&m_nt_etaclusg551,"etaclusg551/D");
-    m_ntuple->Branch("etaclusg552",&m_nt_etaclusg552,"etaclusg552/D");
-    m_ntuple->Branch("eclusg35",&m_nt_eclusg35,"eclusg35/D");
-    m_ntuple->Branch("etaclusg351",&m_nt_etaclusg351,"etaclusg351/D");
-    m_ntuple->Branch("etaclusg352",&m_nt_etaclusg352,"etaclusg352/D");
-    m_ntuple->Branch("eclusg37",&m_nt_eclusg37,"eclusg37/D");
-    m_ntuple->Branch("etaclusg371",&m_nt_etaclusg371,"etaclusg371/D");
-    m_ntuple->Branch("etaclusg372",&m_nt_etaclusg372,"etaclusg372/D");
-    m_ntuple->Branch("eActEM",&m_nt_eActEM,"eActEM/D");
-    m_ntuple->Branch("eActNonEM",&m_nt_eActNonEM,"eActNonEM/D");
-    m_ntuple->Branch("eActInvisible",&m_nt_eActInvisible,"eActInvisible/D");
-    m_ntuple->Branch("eActEscaped",&m_nt_eActEscaped,"eActEscaped/D");
-    m_ntuple->Branch("eInactEM",&m_nt_eInactEM,"eInactEM/D");
-    m_ntuple->Branch("eInactNonEM",&m_nt_eInactNonEM,"eInactNonEM/D");
-    m_ntuple->Branch("eInactInvisible",&m_nt_eInactInvisible,"eInactInvisible/D");
-    m_ntuple->Branch("eInactEscaped",&m_nt_eInactEscaped,"eInactEscaped/D");
-    m_ntuple->Branch("eDeadEM",&m_nt_eDeadEM,"eDeadEM/D");
-    m_ntuple->Branch("eDeadNonEM",&m_nt_eDeadNonEM,"eDeadNonEM/D");
-    m_ntuple->Branch("eDeadInvisible",&m_nt_eDeadInvisible,"eDeadInvisible/D");
-    m_ntuple->Branch("eDeadEscaped",&m_nt_eDeadEscaped,"eDeadEscaped/D");
-    m_ntuple->Branch("eTileCal",&m_nt_eTile,"eTileCal/D");
-    m_ntuple->Branch("edead_1_0",&m_nt_edead_1_0,"edead_1_0/D");
-    m_ntuple->Branch("edead_1_1_0",&m_nt_edead_1_1_0,"edead_1_1_0/D");
-    m_ntuple->Branch("edead_1_1_1",&m_nt_edead_1_1_1,"edead_1_1_1/D");
-    m_ntuple->Branch("edead_1_1_2",&m_nt_edead_1_1_2,"edead_1_1_2/D");
-    m_ntuple->Branch("edead_1_1_3",&m_nt_edead_1_1_3,"edead_1_1_3/D");
-    m_ntuple->Branch("edead_1_1_4",&m_nt_edead_1_1_4,"edead_1_1_4/D");
-    m_ntuple->Branch("edead_1_1_5",&m_nt_edead_1_1_5,"edead_1_1_5/D");
-    m_ntuple->Branch("edead_1_1_6",&m_nt_edead_1_1_6,"edead_1_1_6/D");
-    m_ntuple->Branch("edead_1_1_7",&m_nt_edead_1_1_7,"edead_1_1_7/D");
-    m_ntuple->Branch("edead_1_2_0",&m_nt_edead_1_2_0,"edead_1_2_0/D");
-    m_ntuple->Branch("edead_1_2_1",&m_nt_edead_1_2_1,"edead_1_2_1/D");
-    m_ntuple->Branch("edead_1_2_2",&m_nt_edead_1_2_2,"edead_1_2_2/D");
-    m_ntuple->Branch("edead_1_2_3",&m_nt_edead_1_2_3,"edead_1_2_3/D");
-    m_ntuple->Branch("edead_1_2_4",&m_nt_edead_1_2_4,"edead_1_2_4/D");
-    m_ntuple->Branch("edead_1_2_5",&m_nt_edead_1_2_5,"edead_1_2_5/D");
-    m_ntuple->Branch("edead_1_3",&m_nt_edead_1_3,"edead_1_3/D");
-    m_ntuple->Branch("eleak",&m_nt_eleak,"eleak/D");
-    m_ntuple->Branch("xconv",&m_xconv,"xconv/D");
-    m_ntuple->Branch("yconv",&m_yconv,"yconv/D");
-    m_ntuple->Branch("zconv",&m_zconv,"zconv/D");
-    m_ntuple->Branch("xvert",&m_xvert,"xvert/D");
-    m_ntuple->Branch("yvert",&m_yvert,"yvert/D");
-    m_ntuple->Branch("zvert",&m_zvert,"zvert/D");
-   
-    sc = m_thistSvc->regTree("/file1/analysis",m_ntuple);
-   
-    ATH_MSG_INFO( " histos booked and registred "  );
-    ATH_MSG_INFO("size of LArHit " << sizeof(LArHit)  );
-
-
-  if (m_useTriggerTime) {
-
-     IToolSvc* p_toolSvc = nullptr;
-     sc = service("ToolSvc", p_toolSvc);
-     IAlgTool* algtool;
- 
-     ListItem theTool(m_triggerTimeToolName.value());
-     sc = p_toolSvc->retrieveTool(theTool.type(), theTool.name(),algtool);
-     if (sc.isFailure()) {
-       ATH_MSG_ERROR( "Unable to find tool for " << m_triggerTimeToolName.value()  );
-        m_triggerTimeTool = nullptr;
-     }
-     else {
-        m_triggerTimeTool=dynamic_cast<ITriggerTime*>(algtool);
-        ATH_MSG_INFO( "retrieved TriggerTime tool: "
-                      << m_triggerTimeToolName.value()  );
-     }
-  }
-
-
-    m_nevt=0;
-
-    ATH_CHECK( m_mcCollName.initialize() );
-    ATH_CHECK( m_hitContainerNames.initialize (m_hit) );
-    ATH_CHECK( m_caloCellName.initialize (m_cell) );
-    ATH_CHECK( m_rawChannelName.initialize (m_raw) );
-    ATH_CHECK( m_calibHitContainerNames.initialize (m_calhit) );
-    ATH_CHECK( m_cluster55Name.initialize (m_cluster) );
-    ATH_CHECK( m_cluster55gamName.initialize (m_cluster) );
-    ATH_CHECK( m_cluster35Name.initialize (m_cluster) );
-    ATH_CHECK( m_cluster35gamName.initialize (m_cluster) );
-    ATH_CHECK( m_cluster37Name.initialize (m_cluster) );
-    ATH_CHECK( m_cluster37gamName.initialize (m_cluster) );
-
-    return StatusCode::SUCCESS; 
-  }
-  //__________________________________________________________________________
-  StatusCode Analysis::finalize()
-  {
-    ATH_MSG_DEBUG("Analysis finalize()"  );
-    return StatusCode::SUCCESS; 
-  }
-  
-  //__________________________________________________________________________
-  StatusCode Analysis::execute()
-  {
-    const EventContext& ctx = getContext();
-
-    //.............................................
-    
-    ATH_MSG_DEBUG( "Analysis execute()"  );
-
-//    m_lar_dd_man = LArDetDescrManager::instance();
-//    const AtlasDetectorID* atlasID = m_lar_dd_man->get_em_id();
-    m_id = m_larem_id->lar_em();
-
-
-   m_nevt++;
-
-   if (m_nevt==-1) {
-    std::cout << "retrieving fsampl from detStore " << std::endl;
-    const ILArfSampl*    dd_fSampl = nullptr;
-    ATH_CHECK( detStore()->retrieve(dd_fSampl) );
-
-    int ncell=m_CellListEM.size();
-    std::cout << " start loop over cells " << std::endl;
-    for (int i=0;i<ncell;i++) {
-       Identifier id= m_CellListEM[i].identifier;
-       int isamp=m_larem_id->sampling(id);
-       int ieta=m_larem_id->eta(id);
-       int region=m_larem_id->region(id);
-       int iphi=m_larem_id->phi(id);       
-       int BvsEC=m_larem_id->barrel_ec(id);
-       if (BvsEC > 0 && iphi==0) {
-           float SF= dd_fSampl->FSAMPL(id);
-           std::cout << "** sampling fraction " << BvsEC << " " <<
-             isamp <<  " " << region <<
-             " " << ieta << " " << SF << std::endl;
-       }
-    }
-   }
-
-
-   if ((m_nevt%100)==1)
-     ATH_MSG_INFO( " ***** Event " << m_nevt  );
-
-// reset E list to 0
-   if (m_check) {
-    int ncell=m_CellListEM.size();
-    for(int i=0;i<ncell;i++) {
-       m_CellListEM[i].Ehit=0.;
-       m_CellListEM[i].Thit=0.;
-       m_CellListEM[i].Eraw=-9999.;
-       m_CellListEM[i].Ecell=-9999.;
-    }
-   }
-
-// get trigger time
-   double trigtime=0;
-   if (m_useTriggerTime && m_triggerTimeTool) {
-     trigtime = m_triggerTimeTool->time();
-     std::cout  << "Trigger time used : " << trigtime << std::endl;
-   }
-  
-
-// Loop over LAr hits
-
-  double etot_hit_b[4] = {0.,0.,0.,0.};
-  double etot_hit_e[4] = {0.,0.,0.,0.};
-  double hit_max_e[4] = {0.,0.,0.,0.};
-  double time_max_cell[4]  = {0.,0.,0.,0.};
-  int nhit_tot=0;
-  int nhit_ot=0;
-  if (m_hit) {
-    for (const SG::ReadHandleKey<LArHitContainer>& k : m_hitContainerNames) {
-      SG::ReadHandle<LArHitContainer> hit_container (k, ctx);
-      int ihit = 0;
-      for (const LArHit* hit : *hit_container) {
-        ihit++;
-        nhit_tot++;
-        m_hist_hittime->Fill(hit->time());
-        m_hist_hitener->Fill(hit->energy());
-        if (hit->time() > 2.5) {
-//          if (hit->time() > 25.) {
-          m_hist_ot->Fill(hit->energy());
-          nhit_ot++;
-          if (m_larem_id->is_lar_em(hit->cellID()))
-            m_hist_ot_em->Fill(hit->energy());
-          if (m_larem_id->is_lar_hec(hit->cellID()))
-            m_hist_ot_hec->Fill(hit->energy());
-          if (m_larem_id->is_lar_fcal(hit->cellID()))
-            m_hist_ot_fcal->Fill(hit->energy());
-        } else {
-          m_hist_it->Fill(hit->energy());
-          if (m_larem_id->is_lar_em(hit->cellID()))
-            m_hist_it_em->Fill(hit->energy());
-          if (m_larem_id->is_lar_hec(hit->cellID()))
-            m_hist_it_hec->Fill(hit->energy());
-          if (m_larem_id->is_lar_fcal(hit->cellID()))
-            m_hist_it_fcal->Fill(hit->energy());
-        }
-        Identifier cellID=hit->cellID();
-        if (m_larem_id->is_lar_em(cellID)) {
-// fill list
-          if (m_check) {
-            IdentifierHash idHash=0;
-            idHash = m_larem_id->channel_hash(cellID);
-            double hit_time = hit->time() - trigtime;
-            if (std::fabs(hit_time)<25.) {
-              m_CellListEM[idHash].Ehit += hit->energy();
-              m_CellListEM[idHash].Thit += hit->energy()*hit_time;
-            }
-          }
-          int sampl = m_larem_id->sampling(cellID);
-// barrel vs EndCap
-          if (abs(m_larem_id->barrel_ec(cellID))==1) {
-            etot_hit_b[sampl]+=hit->energy();
-            if (hit->energy() > hit_max_e[sampl]) {
-              hit_max_e[sampl]=hit->energy();
-              time_max_cell[sampl]=hit->time();
-            }
-          }
-          else
-            etot_hit_e[sampl]+=hit->energy();
-
-          if (std::fabs(hit->energy())>1000.)  {
-            ATH_MSG_INFO( " Hit  " << m_larem_id->show_to_string(cellID)
-                          << " ieta/iphi/isampl/E/t " << m_larem_id->eta(cellID) 
-                          << " " << m_larem_id->phi(cellID) << " " << 
-                          m_larem_id->sampling(cellID) << " " << hit->energy() 
-                          << " " << hit->time()  );
-          }
-        }     // lar_em
-      }        // loop over hits
-      ATH_MSG_DEBUG( " number of hits found " << ihit  );
-    }             // loop over hit containers
-//   log << MSG::INFO << " Total number of LAr hits " << nhit_tot << " "
-//                  << nhit_ot << endmsg;
-   double xhit = (double) nhit_tot;
-   m_hist_nhitlar->Fill(xhit);
- }    //  m_hit true
-
-//   std::cout << " EtotPS " << etot_hit_b[0] << std::endl;
- 
-// tmp
-//   if (nhit_tot==0) return StatusCode::SUCCESS;
-
-
-// loop over generated particles
-
-      SG::ReadHandle<McEventCollection> mcCollptr (m_mcCollName);
-      double e_true=0.;
-      double eta_true=-999.;
-      double phi_true=-999.;
-      int nn=0;
-      if (m_doTruth) {
-         McEventCollection::const_iterator itr;
-         for (itr = mcCollptr->begin(); itr!=mcCollptr->end(); ++itr) 
-         {
-          HepMC::GenEvent::particle_const_iterator itrPart;
-          for (itrPart = (*itr)->particles_begin(); itrPart!=(*itr)->particles_end(); ++itrPart )
-          {
-          HepMC::GenParticle *part=*itrPart;
-           if(  (abs(part->pdg_id())==11 || part->pdg_id()==22 || part->pdg_id()==13
-                || (abs(part->pdg_id())==211) )
-                && part->momentum().e()> 5000.)
-           {
-             nn++;
-             if (nn==1) {
-               e_true = part->momentum().e();
-               eta_true = part->momentum().pseudoRapidity();
-               phi_true = part->momentum().phi();
-               ATH_MSG_INFO( " true particle found " << part->pdg_id() << " " <<
-                             e_true << " " << eta_true << " " << phi_true  );
-               HepMC::GenVertex* vertex = part->end_vertex();
-               if (vertex) {
-                  m_xconv = vertex->position().x();
-                  m_yconv = vertex->position().y();
-                  m_zconv = vertex->position().z();
-               }
-               else {
-                  m_xconv=9999.;
-                  m_yconv=9999.;
-                  m_zconv=9999.;
-               }
-               vertex = part->production_vertex();
-               if (vertex) { 
-                  m_xvert = vertex->position().x();
-                  m_yvert = vertex->position().y();
-                  m_zvert = vertex->position().z();
-               }
-               else {
-                  m_xvert=9999.;
-                  m_yvert=9999.;
-                  m_zvert=9999.;
-               }
-             }
-
-  
-           } // e or gamma found
-          }  // loop over particle
-         }   // loop over mcCollptr
-      }    // doTruth
-
-
-// Loop over CaloCells
-  double etot_cell[4]={0.,0.,0.,0.};
-  if (m_cell) {
-    SG::ReadHandle<CaloCellContainer> cell_container (m_caloCellName, ctx);
-    for (const CaloCell* cell : *cell_container) {
-      Identifier cellID = cell->ID();
-      double energy=  cell->energy();
-      // fill list
-      if (m_larem_id->is_lar_em(cellID)) {
-        if (m_check) {
-          IdentifierHash idHash=0;
-          idHash = m_larem_id->channel_hash(cellID);
-          m_CellListEM[idHash].Ecell = energy;
-        }
-        int sampl=m_larem_id->sampling(cellID);
-        etot_cell[sampl]+=energy;
-      }
-      if (fabs(energy)>1000.) {
-        double eta = cell->eta();
-        double phi = cell->phi();
-        double eta0 = cell->caloDDE()->eta_raw();
-        double phi0 = cell->caloDDE()->phi_raw();
-        ATH_MSG_INFO( "Cell " << m_larem_id->show_to_string(cellID)
-                      << " eta/phi/energy " << eta << " " << eta0 << " " << phi << " "
-                      << phi0 << " " << energy  );
-      }
-      int sampling = cell->caloDDE()->getSampling();
-      if (sampling==CaloCell_ID::TileGap3) std::cout << "   *** found tile gap cells in cell list" << std::endl;
-
-    }
-  }     // m_cell
-//
-  
-  SG::ReadCondHandle<LArOnOffIdMapping> cablingHdl{m_cablingKey};
-  const LArOnOffIdMapping* cabling{*cablingHdl};
-
-  double etot_raw[4]={0.,0.,0.,0.};
-  if (m_raw && cabling) {
-// Loop over LArRawChannel
-    int nraw=0;
-    SG::ReadHandle<LArRawChannelContainer> rawchannel_container(m_rawChannelName, ctx);
-    ATH_MSG_INFO( "*** Stat loop over LArRawChannel in Myanalysis"  );
-    LArRawDetSelector  selObj;
-    selObj.setDet(m_id);
-    for (const LArRawChannel& hit : *rawchannel_container) {
-       nraw++;
-       if (!selObj.select(&hit)) continue; 
-       double energy=(double)hit.energy();  //  energy in MeV from RawChannel
-
-       const HWIdentifier ch_id = hit.channelID();
-       Identifier  cellID =
-        cabling->cnvToIdentifier(ch_id);
-// fill list
-       if (m_larem_id->is_lar_em(cellID)) {
-        if (m_check) {
-         IdentifierHash idHash=0;
-         idHash = m_larem_id->channel_hash(cellID);
-         m_CellListEM[idHash].Eraw = energy;
-        }
-        int sampl=m_larem_id->sampling(cellID);
-//GU only barrel
-//        if (abs(m_larem_id->barrel_ec(cellID))==1) {
-          etot_raw[sampl]+=energy;
-//        }
-       }
-
-       if (std::fabs(energy)>10000. && m_larem_id->is_lar_em(cellID) ) {
-        double time=(double)hit.time();      // time in ps from RawChannel
-        double chi2=(double)hit.quality();   // chi2 from RawChannel
-        ATH_MSG_INFO( " RawChannel ieta/iphi/isampl/E/t" 
-                      << " " << m_larem_id->eta(cellID)
-                      << " " << m_larem_id->phi(cellID) 
-                      << " " << m_larem_id->sampling(cellID) 
-                      << " " << energy << " " << time << " " << chi2  );
-       }
-
-
-    }
-    ATH_MSG_INFO( "number of EM raw Channels " << nraw  );
-
-  }  
-// loop over Calibration Hits
-
-  double etot_cal=0;
-  double eTile=0;
-  double ecal[4]={0.,0.,0.,0.};
-  double eAct[4]={0.,0.,0.,0.};
-  double eInact[4]={0.,0.,0.,0.};
-  double eDead[4]={0.,0.,0.,0.};
-  double edead_1_0 =0;
-  double edead_1_1_0=0;
-  double edead_1_1_1=0;
-  double edead_1_1_2=0;
-  double edead_1_1_3=0;
-  double edead_1_1_4=0;
-  double edead_1_1_5=0;
-  double edead_1_1_6=0;
-  double edead_1_1_7=0;
-  double edead_1_2_0=0;
-  double edead_1_2_1=0;
-  double edead_1_2_2=0;
-  double edead_1_2_3=0;
-  double edead_1_2_4=0;
-  double edead_1_2_5=0;
-  double edead_1_3 = 0;
-  double eleak = 0.;
-
-
-  if (m_calhit)  {
-    ATH_MSG_INFO( "CalibrationHitContainer.size " 
-                  << m_calibHitContainerNames.size()  );
-    for (const SG::ReadHandleKey<CaloCalibrationHitContainer>& k : m_calibHitContainerNames)
-    {
-      SG::ReadHandle<CaloCalibrationHitContainer> calocalibrationhit_container(k, ctx);
-      int ihit = 0;
-      for (const CaloCalibrationHit* calibhit : *calocalibrationhit_container)
-      {
-          ihit++;
-          nhit_tot++;
-          etot_cal = etot_cal + calibhit->energyTotal();
-          ecal[0]=ecal[0] + calibhit->energyEM();
-          ecal[1]=ecal[1] + calibhit->energyNonEM();
-          ecal[2]=ecal[2] + calibhit->energyInvisible();
-          ecal[3]=ecal[3] + calibhit->energyEscaped();
-          if (k.key() == "LArCalibrationHitActive") {
-            eAct[0]  += calibhit->energyEM();
-            eAct[1]  += calibhit->energyNonEM();
-            eAct[2]  += calibhit->energyInvisible();
-            eAct[3]  += calibhit->energyEscaped();
-          }
-          if (k.key() == "LArCalibrationHitInactive") {
-            eInact[0]  += calibhit->energyEM();
-            eInact[1]  += calibhit->energyNonEM();
-            eInact[2]  += calibhit->energyInvisible();
-            eInact[3]  += calibhit->energyEscaped();
-          }
-          if (k.key() == "LArCalibrationHitDeadMaterial") {
-            eDead[0]  += calibhit->energyEM();
-            eDead[1]  += calibhit->energyNonEM();
-            eDead[2]  += calibhit->energyInvisible();
-            eDead[3]  += calibhit->energyEscaped();
-          }
-          if (k.key() == "TileCalibHitActiveCell" ||
-              k.key() == "TileCalibHitInactiveCell")
-          {
-            eTile+= calibhit->energyTotal();
-          }
-          Identifier id = calibhit->cellID();
-          if (m_larem_id->is_lar_em(id) && abs(m_larem_id->barrel_ec(id))==1) {
-             int is = m_larem_id->sampling(id);
-             int ir = m_larem_id->region(id);
-             int ie = m_larem_id->eta(id);
-             int ip = m_larem_id->phi(id);
-             if (!CheckLArIdentifier(is,ir,ie,ip)) {
-               std::cout << "Bad LAr identifier " << is << " " << ir << " " <<ie << " " << ip << std::endl;
-             }
-          }
-
-// escaped energy => leakage
-          eleak += calibhit->energyEscaped();
-
-          if (calibhit->energyEscaped() > 0.) {
-            std::cout << " Escaped energy found Identifier= " << m_larem_id->show_to_string(id) << "  Energy = " << calibhit->energyEscaped() << std::endl;
-          }
-
-//          if (iHitContainer==1) {
-//             std::cout << " DM identifier lar? " << m_calodm_id->is_lar_dm(id)  << " " << m_calodm_id->is_lar(id)
-//             << " Tile? " << m_calodm_id->is_tile_dm(id)  << " " << m_calodm_id->is_tile(id)
-//             << " pos_neg " << m_calodm_id->pos_neg_z(id) 
-//             << " type    " << m_calodm_id->dmat(id)
-//             << " sampling " << m_calodm_id->sampling(id)
-//             << " region   " << m_calodm_id->region(id) 
-//             << " eta      " << m_calodm_id->eta(id)
-//             << " phi      " << m_calodm_id->phi(id)  << std::endl;
-//          }
-        
-
-// tile DM => leakage
-          if (m_calodm_id->is_tile_dm(id) ) 
-            eleak += (calibhit->energyEM()+calibhit->energyNonEM()+calibhit->energyInvisible());
-
-          if (m_calodm_id->is_lar_dm(id) ) {
-             int it = m_calodm_id->dmat(id);
-             int is = m_calodm_id->sampling(id);
-             int ir = m_calodm_id->region(id);
-             int ie = m_calodm_id->eta(id);
-             int ip = m_calodm_id->phi(id);
-             if (!CheckDMIdentifier(it,is,ir,ie,ip)) {
-               std::cout << "Bad DM identifier " << it << " " << is << " " << ir << " " <<ie << " " << ip << std::endl;
-             }
-             if (it==1 && is==0) edead_1_0 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==1 && ir==0) edead_1_1_0 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==1 && ir==1) edead_1_1_1 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==1 && ir==2) edead_1_1_2 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==1 && ir==3) edead_1_1_3 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==1 && ir==4) edead_1_1_4 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==1 && ir==5) edead_1_1_5 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==1 && ir==6) edead_1_1_6 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==1 && ir==7) edead_1_1_7 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==2 && ir==0) edead_1_2_0 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==2 && ir==1) edead_1_2_1 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==2 && ir==2) edead_1_2_2 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==2 && ir==3) edead_1_2_3 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==2 && ir==4) edead_1_2_4 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==2 && ir==5) edead_1_2_5 += (calibhit->energyEM()+calibhit->energyNonEM());
-             if (it==1 && is==3) edead_1_3 += (calibhit->energyEM()+calibhit->energyNonEM());
-
-//LAr DM sampling0/region0 && sampling2 => leakage
-             if (it==1 && is==0 && ir==0) 
-               eleak += (calibhit->energyEM()+calibhit->energyNonEM()+calibhit->energyInvisible());
-             if (it==1 && is==2)
-                eleak += (calibhit->energyEM()+calibhit->energyNonEM()+calibhit->energyInvisible());
-             
-          }
-        }     // loop over hits
-    }         // loop over calo calibration hit containers
-    ATH_MSG_INFO( "Etot calibration hits " << etot_cal    
-                  << " " << ecal[0] << " " << ecal[1] << " " << ecal[2] << " " << ecal[3]
-                  );
-    m_hist_cal0->Fill(ecal[0]);
-    m_hist_cal1->Fill(ecal[1]);
-    m_hist_cal2->Fill(ecal[2]);
-    m_hist_cal3->Fill(ecal[3]);
-  }   // m_calhit true
-
-
-// loop over cells and compare energies
-
-  if (m_check) {
-   int ncell=m_CellListEM.size();
-   for (int i=0;i<ncell;i++) {
-    double ehit=m_CellListEM[i].Ehit; 
-    double thit=m_CellListEM[i].Thit;
-    double eraw=m_CellListEM[i].Eraw; 
-    double ecell=m_CellListEM[i].Ecell; 
-    int sampling=m_CellListEM[i].sampling;
-    int calotype=m_CellListEM[i].bec;
-    double eta=fabs(m_CellListEM[i].eta);
-    if ((ehit > 10000. || eraw > 60000.) && calotype==0)  {    // 20 MeV cut
-      ATH_MSG_INFO( "calo/samp/eta " << calotype << " " << sampling << " " << eta
-                    << " energies Hit/Raw/Cell " << ehit << " " << eraw << " " << ecell << " " << thit  );
-    }   // cut on Ehit
-//    double et = eraw/cosh(eta);
-    if (ehit < 0.0001) {  // no true energy in this cell
-     if (sampling==0) {
-      if (calotype==0) m_hist_etraw_emb_s0->Fill(eraw);
-      else             m_hist_etraw_emec_s0->Fill(eraw);
-     }
-     if (sampling==1) {
-      if (calotype==0) m_hist_etraw_emb_s1->Fill(eraw);
-      else             m_hist_etraw_emec_s1->Fill(eraw);
-     }
-     if (sampling==2) {
-      if (calotype==0) m_hist_etraw_emb_s2->Fill(eraw);
-      else             m_hist_etraw_emec_s2->Fill(eraw);
-     }
-     if (sampling==3) {
-      if (calotype==0) m_hist_etraw_emb_s3->Fill(eraw);
-      else             m_hist_etraw_emec_s3->Fill(eraw);
-     }
-    }
-
-   }      // loop over cells
-  }
-
-// build pseudo cluster 3*5 in middle, 1*1 in strip and presampler
-
-  if (m_clusternoise) {
-  std::cout << "start loop over pseudo clusters " << std::endl;
-  for (int iside=-1;iside<=1;iside+=2) {
-   for (int ieta=1;ieta<56;ieta++) {
-    for (int iphi=0;iphi<255;iphi++) {
-     double eta=0.025*((double)ieta);
-     double sume=0;
-     int ireg=0;
-     int sampling;
-
-// sampling 2
-     sampling=2;
-     for (int jeta=ieta-1;jeta<=ieta+1;jeta++) {
-      for (int jphi=iphi-2;jphi<=iphi+2;jphi++) {
-       int kphi=jphi;
-       if (jphi>255) kphi=jphi-255;
-       if (jphi<0) kphi=jphi+255;
-// build identifier and find hash id
-       Identifier myid = m_larem_id->channel_id(iside,sampling,ireg,jeta,kphi);
-       IdentifierHash hid = m_larem_id->channel_hash(myid);
-       if (/*hid>=0 &&*/ hid < m_CellListEM.size())
-         sume+=m_CellListEM[hid].Ecell;
-      }
-     }
-// sampling 1
-     sampling=1;
-     int ietas1=ieta*8;
-     int ietas2=ietas1+8;
-     int jphi=iphi/4; 
-     for (int jeta=ietas1;jeta<ietas2;jeta++) {
-      Identifier myid = m_larem_id->channel_id(iside,sampling,ireg,jeta,jphi);
-      IdentifierHash hid = m_larem_id->channel_hash(myid);
-      if (/*hid>=0 &&*/ hid < m_CellListEM.size())
-         sume+=m_CellListEM[hid].Ecell;
-     }
-// sampling 0
-     sampling=0;
-     int jeta=ieta;
-     jphi=iphi/4;
-     Identifier myid = m_larem_id->channel_id(iside,sampling,ireg,jeta,jphi);
-     IdentifierHash hid = m_larem_id->channel_hash(myid);
-     if (/*hid>=0 &&*/ hid < m_CellListEM.size())
-       sume+=m_CellListEM[hid].Ecell;
-
-// goes to Et
-     sume = sume/cosh(eta);
-
-     m_hist_clusnoise->Fill(sume);
-     if (eta<0.5) m_hist_clusnoise1->Fill(sume);
-     else if(eta<1.0) m_hist_clusnoise2->Fill(sume);
-     else m_hist_clusnoise3->Fill(sume);
- 
-    }
-    std::cout << "end loop over phi" << std::endl;
-   }
-  }
-  }  // m_clusternoise
-    
-
-// check cluster
-
-  m_nt_eclus=0.;
-  m_nt_eclus0 = 0;                                        
-  m_nt_eclus1 = 0.;
-  m_nt_eclus2 = 0.;
-  m_nt_eclus3 = 0.;
-  m_nt_etaclus = 0.;
-  m_nt_phiclus = 0.;
-  m_nt_eclus35 = 0.,
-  m_nt_eclus37 = 0.,
-  m_nt_etaclus35 = 0.;
-  m_nt_etaclus351 = 0.;
-  m_nt_eclusg=0;
-  m_nt_eclusg35=0;
-  m_nt_eclusg37=0;
-  if (m_cluster) {
-// 5x5
-    {
-      SG::ReadHandle<CaloClusterContainer> cluster_container (m_cluster55Name, ctx);
-      ATH_MSG_INFO( " start loop over clusters "  );
-      for (const CaloCluster* clus : *cluster_container) {
-//       clus->print();
-         ATH_MSG_INFO( " **** Cluster E   " << clus->energy() << "  Et=" 
-                       << clus->et() << " " 
-                       << " eta/phi " << clus->eta() << " " << clus->phi() 
-                       << " phi2nd " << clus->phiSample(CaloSampling::EMB2)  );
-         m_nt_eclus=clus->energy();
-         m_nt_eclus0 = clus->eSample(CaloSampling::PreSamplerB);
-         m_nt_eclus1 = clus->eSample(CaloSampling::EMB1);
-         m_nt_eclus2 = clus->eSample(CaloSampling::EMB2);
-         m_nt_eclus3 = clus->eSample(CaloSampling::EMB3);
-         m_nt_etaclus = clus->eta();
-         m_nt_phiclus = clus->phi();
-         if (std::fabs(m_nt_etaclus)<1.475) {
-           m_nt_etaclus551 = clus->etaSample(CaloSampling::EMB1);
-           m_nt_etaclus552 = clus->etaSample(CaloSampling::EMB2);
-         } else {
-           m_nt_etaclus551 = clus->etaSample(CaloSampling::EME1);
-           m_nt_etaclus552 = clus->etaSample(CaloSampling::EME2);
-         }
-
-// for clusters in the crack, loop over the cells
-        std::cout << " * start loop over cells " << std::endl;
-        if (std::fabs(m_nt_etaclus)>1.45 && std::fabs(m_nt_etaclus)<1.55) {
-           CaloCluster::cell_iterator cellIter    = clus->cell_begin();
-           CaloCluster::cell_iterator cellIterEnd = clus->cell_end();
-           for( ;cellIter!=cellIterEnd;cellIter++) {
-             const CaloCell* cell = (*cellIter);
-             int sampling = cell->caloDDE()->getSampling();
-             std::cout << " sampling " << sampling << std::endl;
-             if (sampling==CaloCell_ID::TileGap3) std::cout << "   *** found tile gap " << std::endl;
-           }
-        }
-
-      }
-    }
-// 5x5 photons
-    {   
-      SG::ReadHandle<CaloClusterContainer> cluster_container (m_cluster55gamName, ctx);
-      ATH_MSG_INFO( " start loop over gamma 5x5 clusters "  );
-      for (const CaloCluster* clus : *cluster_container) {
-//       clus->print();
-         m_nt_eclusg = clus->energy();
-         ATH_MSG_INFO( " **** Cluster E   " << clus->energy() << "  Et="
-                       << clus->et() << " " 
-                       << " eta/phi " << clus->eta() << " " << clus->phi()  
-                       << " phi2nd " << clus->phiSample(CaloSampling::EMB2)  );
-          if (std::fabs(clus->eta())<1.475) {
-           m_nt_etaclusg551 =  clus->etaSample(CaloSampling::EMB1);
-           m_nt_etaclusg552 =  clus->etaSample(CaloSampling::EMB2);
-          } else {
-           m_nt_etaclusg551 =  clus->etaSample(CaloSampling::EME1);
-           m_nt_etaclusg552 =  clus->etaSample(CaloSampling::EME2);
-          } 
-      }
-    }
-
-// 3x5
-    {   
-      SG::ReadHandle<CaloClusterContainer> cluster_container (m_cluster35Name, ctx);
-      ATH_MSG_INFO( " start loop over clusters "  );
-      for (const CaloCluster* clus : *cluster_container) {
-       ATH_MSG_INFO( " **** Cluster E35 " << clus->energy() << "  Et=" 
-                     << clus->et() << " " 
-                     << " eta/phi " << clus->eta() << " " << clus->phi()  );
-       m_nt_eclus35 = clus->energy();
-       m_nt_eclus350 = clus->eSample(CaloSampling::PreSamplerB);
-       m_nt_eclus351 = clus->eSample(CaloSampling::EMB1);
-       m_nt_eclus352 = clus->eSample(CaloSampling::EMB2);
-       m_nt_eclus353 = clus->eSample(CaloSampling::EMB3);
-       m_nt_etaclus35 = clus->eta();
-       if (std::fabs(m_nt_etaclus35)<1.475) {
-        m_nt_etaclus351 = clus->etaSample(CaloSampling::EMB1);
-        m_nt_etaclus352 = clus->etaSample(CaloSampling::EMB2);
-       } else {
-        m_nt_etaclus351 = clus->etaSample(CaloSampling::EME1);
-        m_nt_etaclus352 = clus->etaSample(CaloSampling::EME2);
-       }
-      }
-    }
-
-// 3x5 photons
-    {  
-      SG::ReadHandle<CaloClusterContainer> cluster_container (m_cluster35gamName, ctx);
-      ATH_MSG_INFO( " start loop over clusters "  );
-      for (const CaloCluster* clus : *cluster_container) {
-       ATH_MSG_INFO( " **** Cluster E35 " << clus->energy() << "  Et="
-                     << clus->et() << " "
-                     << " eta/phi " << clus->eta() << " " << clus->phi()  );
-       m_nt_eclusg35 = clus->energy();
-       if (std::fabs(clus->eta())<1.475) {
-        m_nt_etaclusg351 = clus->etaSample(CaloSampling::EMB1);
-        m_nt_etaclusg352 = clus->etaSample(CaloSampling::EMB2);
-        std::cout << " etaclusg351 " << m_nt_etaclusg351 << std::endl;
-       } else {
-        m_nt_etaclusg351 = clus->etaSample(CaloSampling::EME1);
-        m_nt_etaclusg352 = clus->etaSample(CaloSampling::EME2);
-       }
-      }
-    }
-
-// 3x7
-    {   
-      SG::ReadHandle<CaloClusterContainer> cluster_container (m_cluster37Name, ctx);
-      ATH_MSG_INFO( " start loop over clusters "  );
-      for (const CaloCluster* clus : *cluster_container) {
-       ATH_MSG_INFO( " **** Cluster E37 " << clus->energy() << "  Et=" 
-                     << clus->et() << " " 
-                     << " eta/phi " << clus->eta() << " " << clus->phi()  );
-        m_nt_eclus37 = clus->energy();
-        if (std::fabs(clus->eta())<1.475) {
-          m_nt_etaclus371 = clus->etaSample(CaloSampling::EMB1);
-          m_nt_etaclus372 = clus->etaSample(CaloSampling::EMB2);
-        } else {
-          m_nt_etaclus371 = clus->etaSample(CaloSampling::EME1);
-          m_nt_etaclus372 = clus->etaSample(CaloSampling::EME2);
-        }
-
-      }
-    }
-
-// 3x7 gam
-    {
-      SG::ReadHandle<CaloClusterContainer> cluster_container (m_cluster37gamName, ctx);
-      ATH_MSG_INFO( " start loop over clusters "  );
-      for (const CaloCluster* clus : *cluster_container) {
-       ATH_MSG_INFO( " **** Cluster E37 " << clus->energy() << "  Et="
-                     << clus->et() << " "
-                     << " eta/phi " << clus->eta() << " " << clus->phi()  );
-        m_nt_eclusg37 = clus->energy();
-        if (std::fabs(clus->eta())<1.475) {
-          m_nt_etaclusg371 = clus->etaSample(CaloSampling::EMB1);
-          m_nt_etaclusg372 = clus->etaSample(CaloSampling::EMB2);
-        } else {
-          m_nt_etaclusg371 = clus->etaSample(CaloSampling::EME1);
-          m_nt_etaclusg372 = clus->etaSample(CaloSampling::EME2);
-        }
-
-      }
-    }
-
-  }     // m_cluster
-
-
-// fill ntuple
-
-  m_nt_e=e_true;
-  m_nt_eta=eta_true;
-  m_nt_phi=phi_true;
-  m_nt_e0=etot_raw[0];
-  m_nt_e1=etot_raw[1];
-  m_nt_e2=etot_raw[2];
-  m_nt_e3=etot_raw[3];
-  m_nt_c0=etot_cell[0];
-  m_nt_c1=etot_cell[1];
-  m_nt_c2=etot_cell[2];
-  m_nt_c3=etot_cell[3];
-  m_nt_hb0=etot_hit_b[0];
-  m_nt_hb1=etot_hit_b[1];
-  m_nt_hb2=etot_hit_b[2];
-  m_nt_hb3=etot_hit_b[3];
-  m_nt_he0=etot_hit_e[0];
-  m_nt_he1=etot_hit_e[1];
-  m_nt_he2=etot_hit_e[2];
-  m_nt_he3=etot_hit_e[3];
-  m_nt_tb0=time_max_cell[0];
-  m_nt_tb1=time_max_cell[1];
-  m_nt_tb2=time_max_cell[2];
-  m_nt_tb3=time_max_cell[3];
-
-  m_nt_eActEM = eAct[0];
-  m_nt_eActNonEM = eAct[1];
-  m_nt_eActInvisible = eAct[2];
-  m_nt_eActEscaped = eAct[3];
-  m_nt_eInactEM = eInact[0];
-  m_nt_eInactNonEM = eInact[1];
-  m_nt_eInactInvisible = eInact[2];
-  m_nt_eInactEscaped = eInact[3];
-  m_nt_eDeadEM = eDead[0];
-  m_nt_eDeadNonEM = eDead[1];
-  m_nt_eDeadInvisible = eDead[2];
-  m_nt_eDeadEscaped = eDead[3];
-  m_nt_eTile = eTile;
-
-  m_nt_edead_1_0 = edead_1_0;
-  m_nt_edead_1_1_0 = edead_1_1_0;
-  m_nt_edead_1_1_1 = edead_1_1_1;
-  m_nt_edead_1_1_2 = edead_1_1_2;
-  m_nt_edead_1_1_3 = edead_1_1_3;
-  m_nt_edead_1_1_4 = edead_1_1_4;
-  m_nt_edead_1_1_5 = edead_1_1_5;
-  m_nt_edead_1_1_6 = edead_1_1_6;
-  m_nt_edead_1_1_7 = edead_1_1_7;
-  m_nt_edead_1_2_0 = edead_1_2_0;
-  m_nt_edead_1_2_1 = edead_1_2_1;
-  m_nt_edead_1_2_2 = edead_1_2_2;
-  m_nt_edead_1_2_3 = edead_1_2_3;
-  m_nt_edead_1_2_4 = edead_1_2_4;
-  m_nt_edead_1_2_5 = edead_1_2_5;
-  m_nt_edead_1_3 = edead_1_3;
-  m_nt_eleak = eleak;
-
-
-  m_ntuple->Fill();
-
-  return StatusCode::SUCCESS;
- }
-
-bool Analysis::CheckLArIdentifier(int sampling, int region, int eta, int phi)
-{
-  if (sampling<0 || sampling >3) return false;
-  if (sampling==0) {
-    if (region!=0) return false;
-    if (eta<0 || eta>60) return false;
-    if (phi<0 || phi>63) return false;
-  }
-  if (sampling==1) {
-    if (region<0 || region >1) return false;
-    if (region==0) {
-       if (eta<1 || eta>447) return false;
-       if (phi<0 || phi>63) return false;
-    }
-    if (region==1) {
-       if (eta<0 || eta>2) return false;
-       if (phi<0 || phi>255) return false;
-    }
-  }
-  if (sampling==2) {
-    if (region<0 || region >1) return false;
-    if (region==0) {
-        if (eta<0 || eta>55) return false;
-        if (phi<0 || phi>255) return false;
-     }
-     if (region==1) {
-        if (eta!=0) return false;
-        if (phi<0 || phi>255) return false;
-     }
-  }
-  if (sampling==3) {
-     if (region !=0) return false;
-     if (eta<0 || eta>26) return false;
-     if (phi<0 || phi>255) return false;
-  }
-  return true;
-}
-
-
-bool Analysis::CheckDMIdentifier(int type, int sampling, int region, int eta, int phi)
-{
-
- if (type <1 || type > 2) return false;
- if (type==1) { 
-    if (sampling<0 || sampling>3) return false;
-     if (sampling==0) {
-        if (region <0 || region >5) return false;
-        if (phi<0 || phi>63) return false;
-        if (eta<0 || eta>49) return false;
-     }
-    if (sampling==1) {
-       if (region<0 || region>7) return false;
-       if (phi<0 || phi>63) return false;
-       if (region==0) {
-         if (eta<0 || eta>14) return false;
-       }
-       if (region==1) {
-         if (eta<0 || eta>14) return false;
-       }
-       if (region==2) {
-         if (eta<0 || eta>15) return false;
-       }
-       if (region==3) {
-// valid range goes up to eta=1.6 in bin of 0.1 => etamax=15
-          if (eta<0 || eta>15) return false;
-       }
-       if (region==4) {
-          if (eta !=0) return false;
-       }
-       if (region==5) {
-         if (eta<0 || eta>2) return false;
-       }
-       if (region==6) {
-         if (eta<0 || eta>18) return false;
-       }
-       if (region==7) {
-         if (eta<0 || eta>17) return false;
-       }
-    }
-    if (sampling==2) {
-       if (region <0 || region>5  ) return false;
-       if (phi<0 || phi>63) return false;
-       if (region==0){
-          if (eta<0 || eta>9) return false;
-       }
-       if (region==2) {
-          if (eta<0 || eta>4) return false;
-       }
-       if (region==3) {
-         if (eta<0 || eta>17) return false;
-       }
-       if (region==4) {
-         if (eta<0 || eta>17) return false;
-       }
-       if (region==5) {
-         if (eta<0 || eta>6) return false;
-       }
-    }
-    if (sampling==3) {
-      if (region<0 || region>2) return false;
-      if (region==0) {
-        if (eta<0 || eta>32) return false;
-        if (phi<0 || phi>63) return false;
-      }
-      if (region==1) {
-        if (eta<0 || eta>14) return false;
-        if (phi<0 || phi>63) return false;
-      }
-      if (region==2) {
-        if (eta !=0) return false;
-        if (phi !=0) return false;
-      }
-    }
- }  
- if (type==2) {
-    if (sampling<0 || sampling >3) return false;
-    if (sampling==0) {
-      if (region<0 || region>5) return false;
-      if (region==0) {
-         if (eta !=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==1) {
-         if (eta !=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==2) {
-         if (eta<0 || eta>9) return false;
-         if (phi<0 || phi>31) return false;
-      }
-      if (region==3) {
-         if (eta<0 || eta>3) return false;
-         if (phi<0 || phi>31) return false;
-      }
-      if (region==4) {
-         if (eta!=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==5) {
-         if (eta<0 || eta > 19) return false;
-         if (phi<0 || phi>63) return false;
-      }
-   }
-   if (sampling==1) {
-     if (region<0 || region>5) return false;
-      if (region==0) {
-         if (eta !=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==1) {
-         if (eta !=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==2) {
-         if (eta<0 || eta>9) return false;
-         if (phi<0 || phi>31) return false;
-      }
-      if (region==3) {
-         if (eta<0 || eta>3) return false;
-         if (phi<0 || phi>31) return false;
-      }
-      if (region==4) {
-         if (eta!=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==5) {
-         if (eta<0 || eta > 19) return false;
-         if (phi<0 || phi>63) return false;
-      }
-   }
-   if (sampling==2) {
-     if (region<0 || region>5) return false;
-      if (region==0) {
-         if (eta !=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==1) {
-         if (eta !=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==2) {
-         if (eta<0 || eta>9) return false;
-         if (phi<0 || phi>31) return false;
-      }
-      if (region==3) {
-         if (eta<0 || eta>3) return false;
-         if (phi<0 || phi>31) return false;
-      }
-      if (region==4) {
-         if (eta!=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==5) {
-         if (eta<0 || eta > 19) return false;
-         if (phi<0 || phi>63) return false;
-      }
-   }
-   if (sampling==3) {
-    if (region<0 || region>5) return false;
-      if (region==0) {
-         if (eta !=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==1) {
-         if (eta !=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==2) {
-         if (eta<0 || eta>9) return false;
-         if (phi<0 || phi>31) return false;
-      }
-      if (region==3) {
-         if (eta<0 || eta>3) return false;
-         if (phi<0 || phi>31) return false;
-      }
-      if (region==4) {
-         if (eta!=0) return false;
-         if (phi<0 || phi>63) return false;
-      }
-      if (region==5) {
-         if (eta<0 || eta > 19) return false;
-         if (phi<0 || phi>63) return false;
-      }
-   }
-
- } 
- return true;
-} 
-
-} // end of namespace bracket
diff --git a/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx.createLarHits b/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx.createLarHits
deleted file mode 100644
index c9bbdb1baa814c4965d69d998c173587c53457d9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx.createLarHits
+++ /dev/null
@@ -1,161 +0,0 @@
-#include "MyAnalysis/Analysis.h"
-#include "GaudiKernel/MsgStream.h"
-#include "GaudiKernel/IHistogramSvc.h"
-#include "AIDA/IHistogram1D.h"
-#include "LArSimEvent/LArHit.h"
-#include "LArSimEvent/LArHitContainer.h"
-#include "LArRawEvent/LArRawChannel.h"
-#include "LArRawEvent/LArRawChannelContainer.h"
-
-
-
-
-namespace MyAnalysis {
-
-  //Constructor
-  Analysis:: Analysis(const std::string& name, ISvcLocator* pSvcLocator):
-    Algorithm(name,pSvcLocator){
-
-  }
-  
-  //__________________________________________________________________________
-  //Destructor
-  Analysis::~Analysis()
-  {
-    MsgStream log( messageService(), name() ) ;
-    log << MSG::DEBUG << "Analysis destructor called" << endmsg;
-  }
-  //__________________________________________________________________________
-  StatusCode Analysis::initialize()
-  {
-    
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG <<"Analysis initialize()" << endmsg;
-
-    // Get the StoreGateSvc
-    if (service("StoreGateSvc", m_sgSvc).isFailure()) {
-      log << MSG::ALWAYS << "No StoreGate!!!!!!!" << endmsg;
-    }
-
-     m_nevt=0;
-
-    return StatusCode::SUCCESS; 
-  }
-  //__________________________________________________________________________
-  StatusCode Analysis::finalize()
-  {
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG <<"Analysis finalize()" << endmsg;
-    return StatusCode::SUCCESS; 
-  }
-  
-  //__________________________________________________________________________
-  StatusCode Analysis::execute()
-  {
-    //.............................................
-    
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG << "Analysis execute()" << endmsg;
-
-
-   m_nevt++;
-
-   log << MSG::INFO << " ***** Event " << m_nevt << endmsg;
-
-// Loop over LAr hits
-
-  std::vector <std::string> m_HitContainer;
-
-  log << MSG::INFO <<"size of LArHit " << sizeof(LArHit) << endmsg;
-  log << MSG::INFO <<"size of LArRaw " << sizeof(LArRawChannel) << endmsg;
-  log << MSG::INFO <<"size of int    " << sizeof(int) << endmsg;
-  log << MSG::INFO <<"size of float  " << sizeof(float) << endmsg;
-  log << MSG::INFO <<"size of double " << sizeof(double) << endmsg;
-  log << MSG::INFO <<"size of Indentifier " << sizeof(Identifier) << endmsg;
-
-  Identifier my_identifier;
-
-  m_HitContainer.push_back("LArHitEMB");
-  m_HitContainer.push_back("LArHitEMEC");
-  m_HitContainer.push_back("LArHitHEC");
-  m_HitContainer.push_back("LArHitFCAL");
-  unsigned int iHitContainer;
-  log << MSG::INFO << "m_HitContainer.size " << m_HitContainer.size() << endmsg;
-  for (iHitContainer=0;iHitContainer<m_HitContainer.size();iHitContainer++)
-  {
-    const LArHitContainer* hit_container ;
-    if(m_sgSvc->retrieve(hit_container,m_HitContainer[iHitContainer])
-      .isFailure()) {
-      log << MSG::INFO << " cannot retrieve hit container " << endmsg;
-    }  else
-    {
-       int ihit = 0;
-       LArHitContainer::const_iterator hititer;
-       for(hititer=hit_container->begin();
-           hititer != hit_container->end();hititer++)
-       {
-          ihit++;
-          LArHit* hit = (*hititer);
-          if (ihit==1) my_identifier = hit->cellID();
-          if (hit->energy() > 1.0) {
-    //         log << MSG::INFO << hit->energy() << " " 
-    //                          << hit->time()   << " " 
-    //                          << hit->cellID() << endmsg;
-          }
-       }
-     log << MSG::INFO << " number of hits found " << ihit << endmsg;
-    }
-  }
-
-  return StatusCode::SUCCESS;
-
-  int i;
-  double energy=1.0;
-  double time=0.;
-  LArHitContainer* mycontainer = new LArHitContainer();
-  LArHit* newhit;
-  if (m_sgSvc->record(mycontainer,"testLArHit").isFailure()) {
-   log << MSG::INFO << "failed to record testLArHit" << endmsg;
-   return StatusCode::FAILURE;
-  }
-  int Nbhits = 1000000;
-  log << MSG::INFO << " *** before creating " << Nbhits << endmsg;
-  int id = getpid();
-  char str[256];
-  sprintf(str,"cat /proc/%d/status | grep VmSize | awk '{print($2)}' \n",id);
-  std::cout << "vmSize" << std::endl;
-  system(str);
-  for (i=0;i<Nbhits;i++) {
-    energy+=0.011;
-    time+=0.025;
-    newhit = new LArHit(my_identifier,energy,time);
-    mycontainer->push_back(newhit);
-  }
-  log << MSG::INFO << " *** after  creating " << Nbhits << endmsg;
-  std::cout << "vmSize" << std::endl;
-  system(str);
-
-
-// LarRawChannel
-
-  LArRawChannelCollection* rawcontainer = new LArRawChannelCollection();
-  LArRawChannel* rawchannel;
-  if (m_sgSvc->record(rawcontainer,"testLArRaw").isFailure()) {
-     log << MSG::INFO << "failed to record testLArRaw" << endmsg;
-     return StatusCode::FAILURE;
-  }
-  log << MSG::INFO << " *** before creating Raw" << Nbhits << endmsg; 
-  std::cout << "vmSize" << std::endl;
-  system(str);
-  for (i=0;i<Nbhits;i++) {
-      rawchannel = new LArRawChannel();
-      rawcontainer->push_back(rawchannel);
-  }
-  log << MSG::INFO << " *** after  creating " << Nbhits << endmsg;
-  std::cout << "vmSize" << std::endl;
-  system(str);
-
-  return StatusCode::SUCCESS;
- }
- 
-} // end of namespace bracket
diff --git a/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx.read b/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx.read
deleted file mode 100644
index 389b508a33d9808614a60c06f46831c102b3833b..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx.read
+++ /dev/null
@@ -1,404 +0,0 @@
-#include "MyAnalysis/Analysis.h"
-#include "GaudiKernel/MsgStream.h"
-#include "GaudiKernel/IHistogramSvc.h"
-#include "AIDA/IHistogram1D.h"
-
-#include "AtlasDetDescr/AtlasDetectorID.h"
-#include "CaloDetDescr/CaloDetDescrElement.h"
-#include "LArIdentifier/LArID.h"
-#include "Identifier/Identifier.h"
-#include "Identifier/IdentifierHash.h"
-#include "Identifier/IdContext.h"
-#include "LArDetDescr/LArDetDescriptor.h"
-#include "LArDetDescr/LArDetDescrManager.h"
-
-#include "LArSimEvent/LArHit.h"
-#include "LArSimEvent/LArHitContainer.h"
-#include "LArRecEvent/LArCell.h"
-#include "LArRecEvent/LArCellContainer.h"
-#include "LArRecEvent/LArCluster.h"
-#include "LArRecEvent/LArClusterContainer.h"
-#include "LArRawEvent/LArRawChannel.h"
-#include "LArRawEvent/LArRawChannelContainer.h"
-#include "LArRawUtils/LArRawDetSelector.h"
-
-
-
-
-namespace MyAnalysis {
-
-  //Constructor
-  Analysis:: Analysis(const std::string& name, ISvcLocator* pSvcLocator):
-    Algorithm(name,pSvcLocator){
-
-  }
-  
-  //__________________________________________________________________________
-  //Destructor
-  Analysis::~Analysis()
-  {
-    MsgStream log( messageService(), name() ) ;
-    log << MSG::DEBUG << "Analysis destructor called" << endmsg;
-  }
-  //__________________________________________________________________________
-  StatusCode Analysis::initialize()
-  {
-    
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG <<"Analysis initialize()" << endmsg;
-
-    // Get the StoreGateSvc
-    if (service("StoreGateSvc", m_sgSvc).isFailure()) {
-      log << MSG::ALWAYS << "No StoreGate!!!!!!!" << endmsg;
-    }
-
-// Book histos
-    m_hist_celle = 
-     histoSvc()->book("/stat/athena/",2001,"Cell energy",500,0.,2.);
-    m_hist_map  =
-     histoSvc()->book("/stat/athena/",2003,"phi vs eta cells",10,-2.5,2.5,10,0.,6.283185);
-    m_hist_map0  =
-     histoSvc()->book("/stat/athena/",2004,"phi vs eta samp0",10,-2.5,2.5,10,0.,6.283185);
-    m_hist_map1  =
-     histoSvc()->book("/stat/athena/",2005,"phi vs eta samp1",10,-2.5,2.5,10,0.,6.283185);
-    m_hist_map2  =
-     histoSvc()->book("/stat/athena/",2006,"phi vs eta samp2",10,-2.5,2.5,10,0.,6.283185);
-    m_hist_map3  =
-     histoSvc()->book("/stat/athena/",2007,"phi vs eta samp3",10,-2.5,2.5,10,0.,6.283185);
-    m_hist_map4  =
-     histoSvc()->book("/stat/athena/",2008,"phi vs eta samp0 EC",10,-2.5,2.5,10,0.,6.283185);
-    m_hist_map5  =
-     histoSvc()->book("/stat/athena/",2009,"phi vs eta samp1 EC",10,-2.5,2.5,10,0.,6.283185);
-    m_hist_map6  =
-     histoSvc()->book("/stat/athena/",2010,"phi vs eta samp2 EC",10,-2.5,2.5,10,0.,6.283185);
-    m_hist_map7  =
-     histoSvc()->book("/stat/athena/",2011,"phi vs eta samp3 EC",10,-2.5,2.5,10,0.,6.283185);
-
-     m_hist_rawe =
-     histoSvc()->book("/stat/athena/",2100,"Raw Channel Energy",500,0.,2.);
- 
-     m_hist_hit0 =
-      histoSvc()->book("/stat/athena/",2900,"Nhits EMB",100,0.,5000.);
-     m_hist_hit1 =
-      histoSvc()->book("/stat/athena/",2901,"Nhits EMEC",100,0.,5000.);
-     m_hist_hit2 =
-      histoSvc()->book("/stat/athena/",2902,"Nhits HEC",100,0.,5000.);
-     m_hist_hit3 =
-      histoSvc()->book("/stat/athena/",2903,"Nhits FCAL",100,0.,5000.);
-     m_hist_mbe=
-       histoSvc()->book("/stat/athena/",2999,"Hit E",500,0.,2.);
-     m_hist_mbe2=
-       histoSvc()->book("/stat/athena/",2998,"Hit E cut 0.1",100,0.,2.);
-     m_hist_mbe3=
-       histoSvc()->book("/stat/athena/",2997,"Hit E cut 0.4",100,0.,2.);
-
-     m_hist_b0=
-      histoSvc()->book("/stat/athena/",3000,"Cell/hit b0",10,0.,1.5,100,0.,20.);
-     m_hist_b1=
-      histoSvc()->book("/stat/athena/",3001,"Cell/hit b1",10,0.,1.5,100,0.,20.);
-     m_hist_b2=
-      histoSvc()->book("/stat/athena/",3002,"Cell/hit b2",10,0.,1.5,100,0.,20.);
-     m_hist_b3=
-      histoSvc()->book("/stat/athena/",3003,"Cell/hit b3",10,0.,1.5,100,0.,20.);
-     m_hist_e0=
-      histoSvc()->book("/stat/athena/",3100,"Cell/hit e0",10,1.2,2.5,100,0.,50.);
-     m_hist_e1=
-      histoSvc()->book("/stat/athena/",3101,"Cell/hit e1",10,1.2,2.5,100,0.,50.);
-     m_hist_e2=
-      histoSvc()->book("/stat/athena/",3102,"Cell/hit e2",10,1.2,2.5,100,0.,50.);
-     m_hist_e3=
-      histoSvc()->book("/stat/athena/",3103,"Cell/hit e3",10,1.2,2.5,100,0.,50.);
-
-     m_hist_noib0 =
-      histoSvc()->book("/stat/athena/",4000,"Cell noise b0",100,-0.3,0.3);
-     m_hist_noib1 =
-      histoSvc()->book("/stat/athena/",4001,"Cell noise b0",100,-0.3,0.3);
-     m_hist_noib2 =
-      histoSvc()->book("/stat/athena/",4002,"Cell noise b2",100,-0.3,0.3);
-     m_hist_noib3 =
-      histoSvc()->book("/stat/athena/",4003,"Cell noise b3",100,-0.3,0.3);
-     m_hist_noie0 =
-      histoSvc()->book("/stat/athena/",4100,"Cell noise b0",100,-0.3,0.3);
-     m_hist_noie1 =
-      histoSvc()->book("/stat/athena/",4101,"Cell noise b0",100,-0.3,0.3);
-     m_hist_noie2 =
-      histoSvc()->book("/stat/athena/",4102,"Cell noise b2",100,-0.3,0.3);
-     m_hist_noie3 =
-      histoSvc()->book("/stat/athena/",4103,"Cell noise b3",100,-0.3,0.3);
-
-     m_lar_dd_man = LArDetDescrManager::instance();
-     const AtlasDetectorID* atlasId = m_lar_dd_man->get_em_id();
-     m_id = atlasId->lar_em();
-
-// initialize hit list
-     std::vector <CaloDetDescrElement*>::const_iterator itrDDE,  itrEndDDE;
-     int m_ncellem=m_lar_dd_man->em_element_size();
-     CellInfo cell0;
-     cell0.bec=0;
-     cell0.sampling=0;
-     cell0.eta=0.; 
-     cell0.phi=0.; 
-     cell0.Ehit=-9999.;
-     cell0.Eraw=-9999.;
-     cell0.Ecell=-9999.;
-     CellListEM.resize(m_ncellem,cell0);
-
-     itrDDE    = m_lar_dd_man->em_element_begin();
-     itrEndDDE = m_lar_dd_man->em_element_end();
-     m_idContext = m_lar_dd_man->get_em_id()->channel_context();
-     for (;itrDDE!=itrEndDDE;++itrDDE){
-       CaloDetDescrElement* caloDDE = (*itrDDE);
-       if (caloDDE==0) {
-          std::cout << "hole detected calo num EM " << std::endl;
-          continue;
-       }
-       IdentifierHash idHash=0;
-       Identifier id=caloDDE->identify() ;
-       int iOK= atlasId->get_hash(id,idHash,&m_idContext);
-       if (iOK!=0) {
-          std::cout << " calodde: cannot make hash from "
-                    << atlasId->show_to_string(id) << std::endl;
-       }
-       else {
-          int BvsEC=abs(m_lar_dd_man->get_em_id()->barrel_ec(id));
-          int calotype;
-          if (BvsEC == 1) calotype=0;
-          else calotype=1;
-
-          CellInfo mycell;
-          mycell.bec=calotype;
-          mycell.sampling= m_lar_dd_man->get_em_id()->sampling(id);
-          mycell.eta=caloDDE->eta();
-          mycell.phi=caloDDE->phi();
-          mycell.Ehit=-9999.;
-          mycell.Eraw=-9999.;
-          mycell.Ecell=-9999.;
-          CellListEM[idHash]=mycell;
-       }
-     }        
-
-
-     m_nevt=0;
-
-    return StatusCode::SUCCESS; 
-  }
-  //__________________________________________________________________________
-  StatusCode Analysis::finalize()
-  {
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG <<"Analysis finalize()" << endmsg;
-    return StatusCode::SUCCESS; 
-  }
-  
-  //__________________________________________________________________________
-  StatusCode Analysis::execute()
-  {
-    //.............................................
-    
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG << "Analysis execute()" << endmsg;
-
-
-   m_nevt++;
-   const AtlasDetectorID* atlasID = m_lar_dd_man->get_em_id();
-
-   log << MSG::INFO << " ***** Event " << m_nevt << endmsg;
-
-// reset E list to 0
-   int ncell=CellListEM.size();
-   int i;
-   for(i=0;i<ncell;i++) {
-       CellListEM[i].Ehit=-9999.;
-       CellListEM[i].Eraw=-9999.;
-       CellListEM[i].Ecell=-9999.;
-   }
-
-// Loop over LArCells
-  const LArCellContainer* cell_container;
-  if(m_sgSvc->retrieve(cell_container,"LArEM").isFailure())
-  {
-    log << MSG::INFO
-        << " Could not get pointer to Cell Container " 
-        << endmsg;
-  } else
-  {
-   LArCellContainer::const_iterator first_cell = cell_container->begin();
-   LArCellContainer::const_iterator end_cell   = cell_container->end();
-   log << MSG::INFO << "*** Stat loop over LArCells in Myanalysis" << endmsg;
-   for (; first_cell != end_cell; ++first_cell)
-   {
-       Identifier cellID = (*first_cell)->ID();
-       double eta = (*first_cell)->eta();
-       double phi = (*first_cell)->phi();
-       double et  = (*first_cell)->et();
-       double energy=  (*first_cell)->energy();
-       m_hist_celle->fill(energy);
-       m_hist_map->fill(eta,phi,et);
-       int isamp=CaloSampling::getSampling(**first_cell);
-       if (isamp==0) m_hist_map0->fill(eta,phi,et);
-       if (isamp==1) m_hist_map1->fill(eta,phi,et);
-       if (isamp==2) m_hist_map2->fill(eta,phi,et);
-       if (isamp==3) m_hist_map3->fill(eta,phi,et);
-       if (isamp==4) m_hist_map4->fill(eta,phi,et);
-       if (isamp==5) m_hist_map5->fill(eta,phi,et);
-       if (isamp==6) m_hist_map6->fill(eta,phi,et);
-       if (isamp==7) m_hist_map7->fill(eta,phi,et);
-// fill list
-       if (atlasID->is_lar_em(cellID)) {
-        IdentifierHash idHash=0;
-        int iOK= atlasID->get_hash(cellID,idHash,&m_idContext);
-        if (iOK==0) CellListEM[idHash].Ecell = energy;
-       }
-   }
-  } 
-//
-// Loop over LArRawChannel
-  const LArRawChannelContainer* rawchannel_container;
-  if(m_sgSvc->retrieve(rawchannel_container,"LArRawChannels").isFailure())
-  {
-    log << MSG::INFO
-        << " Could not get  LArRawChannel container"
-        << endmsg;
-  } else
-  {
-   log << MSG::INFO 
-       << "*** Stat loop over LArRawChannel in Myanalysis" << endmsg;
-   LArRawDetSelector  selObj(rawchannel_container) ;
-   selObj.setDet(m_id);
-   LArRawDetSelector::const_iterator f_cell =
-                                 selObj.begin();
-   LArRawDetSelector::const_iterator l_cell =
-                                 selObj.end();
-   for (; f_cell != l_cell; ++f_cell)
-   {
-     const LArRawChannel* hit = (*f_cell) ;
-     double energy=hit->energy();            //  energy in MeV from RawChannem
-     m_hist_rawe->fill(energy);
-
-     LArSignalChannelID ch_id = hit->channelID();
-     ILArSignalChannelService * cablingService =
-        LArCablingService::getInstance();
-     Identifier  cellID =
-        cablingService->cnvToIdentifier(ch_id);
-// fill list
-     if (atlasID->is_lar_em(cellID)) {
-        IdentifierHash idHash=0;
-        int iOK= atlasID->get_hash(cellID,idHash,&m_idContext);
-        if (iOK==0) CellListEM[idHash].Eraw = energy;
-     }
-
-   }
-  }
-
-
-// Loop over LAr hits
-
-  std::vector <std::string> m_HitContainer;
-
-  m_HitContainer.push_back("LArHitEMB");
-  m_HitContainer.push_back("LArHitEMEC");
-//  m_HitContainer.push_back("LArHitHEC");
-//  m_HitContainer.push_back("LArHitFCAL");
-  unsigned int iHitContainer;
-  log << MSG::INFO << "m_HitContainer.size " << m_HitContainer.size() << endmsg;
-  for (iHitContainer=0;iHitContainer<m_HitContainer.size();iHitContainer++)
-  {
-    const LArHitContainer* hit_container ;
-    if(m_sgSvc->retrieve(hit_container,m_HitContainer[iHitContainer])
-      .isFailure()) {
-      log << MSG::INFO << " cannot retrieve hit container " << endmsg;
-    }  else
-    {
-       int ihit = 0;
-       LArHitContainer::const_iterator hititer;
-       for(hititer=hit_container->begin();
-           hititer != hit_container->end();hititer++)
-       {
-          ihit++;
-          LArHit* hit = (*hititer);
-          m_hist_mbe->fill(hit->energy());
-          if (hit->energy()>0.0001) m_hist_mbe2->fill(hit->energy());
-          if (hit->energy()>0.0004) m_hist_mbe3->fill(hit->energy());
-// fill list
-          Identifier cellID=hit->cellID();
-          if (atlasID->is_lar_em(cellID)) {
-           IdentifierHash idHash=0;
-           int iOK= atlasID->get_hash(cellID,idHash,&m_idContext);
-           if (iOK==0) CellListEM[idHash].Ehit = hit->energy();
-          }
-       }
-     log << MSG::INFO << " number of hits found " << ihit << endmsg;
-     double xhit = (double) ihit;
-     if (iHitContainer==0) m_hist_hit0->fill(xhit);
-     if (iHitContainer==1) m_hist_hit1->fill(xhit);
-     if (iHitContainer==2) m_hist_hit2->fill(xhit);
-     if (iHitContainer==3) m_hist_hit3->fill(xhit);
-    }
-  }
-
-// loop over cell and compare energies
-
-  ncell=CellListEM.size();
-  for (i=0;i<ncell;i++) {
-    double ehit=CellListEM[i].Ehit; 
-    double eraw=CellListEM[i].Eraw; 
-    double ecell=CellListEM[i].Ecell; 
-    int sampling=CellListEM[i].sampling;
-    int calotype=CellListEM[i].bec;
-    double eta=fabs(CellListEM[i].eta);
-    if (ehit > 100.)  {    // 100 MeV cut
-//    if (eraw>-999. || ehit >-999. || ecell > -999. ) {
-     std::cout << "calo/samp " << calotype << " " << sampling 
-     << " energies " << ehit << " " << eraw << " " << ecell << std::endl;
-     if (ehit > 0.001) {
-      if(calotype==0) {
-       if (sampling==0) m_hist_b0->fill(eta,ecell/ehit);
-       if (sampling==1) m_hist_b1->fill(eta,ecell/ehit);
-       if (sampling==2) m_hist_b2->fill(eta,ecell/ehit);
-       if (sampling==3) m_hist_b3->fill(eta,ecell/ehit);
-      }else {
-       if (sampling==0) m_hist_e0->fill(eta,ecell/ehit);
-       if (sampling==1) m_hist_e1->fill(eta,ecell/ehit);
-       if (sampling==2) m_hist_e2->fill(eta,ecell/ehit);
-       if (sampling==3) m_hist_e3->fill(eta,ecell/ehit);
-      }  // barrel vs EC
-     }   // cut on Ehit
-
-     if (ehit < -999.) {    // cell with no hit => only noise
-      if(calotype==0) {
-       if (sampling==0) m_hist_noib0->fill(ecell);
-       if (sampling==1) m_hist_noib1->fill(ecell);
-       if (sampling==2) m_hist_noib2->fill(ecell);
-       if (sampling==3) m_hist_noib3->fill(ecell);
-      }else {
-       if (sampling==0) m_hist_noie0->fill(ecell);
-       if (sampling==1) m_hist_noie1->fill(ecell);
-       if (sampling==2) m_hist_noie2->fill(ecell);
-       if (sampling==3) m_hist_noie3->fill(ecell);
-      }  // barrel vs EC
-     }
-    }    // cut on OR of energies
-  }      // loop over cells
-
-// check cluster
-
-  const LArClusterContainer* cluster_container;
-  if(m_sgSvc->retrieve(cluster_container,"LArClusterEM")
-      .isFailure()) {
-      log << MSG::INFO << " cannot retrieve cluster container " << endmsg;
-  }  
-  else
-  {   
-    LArClusterContainer::const_iterator clus_iter;
-    for(clus_iter=cluster_container->begin();
-        clus_iter != cluster_container->end();clus_iter++)
-    {
-       LArCluster* clus = (*clus_iter);
-       std::cout << " **** Cluster Et " << clus->et() << std::endl;
-    }
-  }
-
-  return StatusCode::SUCCESS;
- }
- 
-} // end of namespace bracket
diff --git a/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx.save b/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx.save
deleted file mode 100644
index 4e16eb9f6e924f0db69847ea9dfd72f02eff1fa8..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/src/MyAnalysis.cxx.save
+++ /dev/null
@@ -1,192 +0,0 @@
-#include "MyAnalysis/Analysis.h"
-#include "GaudiKernel/MsgStream.h"
-
-#include "AtlasDetDescr/AtlasDetectorID.h"
-#include "CaloDetDescr/CaloDetDescrElement.h"
-#include "LArIdentifier/LArID.h"
-#include "Identifier/Identifier.h"
-#include "Identifier/IdentifierHash.h"
-#include "Identifier/IdContext.h"
-#include "LArDetDescr/LArDetDescriptor.h"
-#include "LArDetDescr/LArDetDescrManager.h"
-
-#include "LArSimEvent/LArHit.h"
-#include "LArSimEvent/LArHitContainer.h"
-#include "LArRecEvent/LArCell.h"
-#include "LArRecEvent/LArCellContainer.h"
-#include "LArRecEvent/LArCluster.h"
-#include "LArRecEvent/LArClusterContainer.h"
-#include "LArRawEvent/LArRawChannel.h"
-#include "LArRawEvent/LArRawChannelContainer.h"
-#include "LArRawUtils/LArRawDetSelector.h"
-
-
-
-
-namespace MyAnalysis {
-
-  //Constructor
-  Analysis:: Analysis(const std::string& name, ISvcLocator* pSvcLocator):
-    Algorithm(name,pSvcLocator){
-
-  }
-  
-  //__________________________________________________________________________
-  //Destructor
-  Analysis::~Analysis()
-  {
-    MsgStream log( messageService(), name() ) ;
-    log << MSG::DEBUG << "Analysis destructor called" << endmsg;
-  }
-  //__________________________________________________________________________
-  StatusCode Analysis::initialize()
-  {
-    
-    MsgStream log( messageService(), name() );
-    log << MSG::INFO <<"Analysis initialize()" << endmsg;
-
-    // Get the StoreGateSvc
-    if (service("StoreGateSvc", m_sgSvc).isFailure()) {
-      log << MSG::ALWAYS << "No StoreGate!!!!!!!" << endmsg;
-    }
-
-     m_lar_dd_man = LArDetDescrManager::instance();
-     const AtlasDetectorID* atlasId = m_lar_dd_man->get_em_id();
-     m_id = atlasId->lar_em();
-
-     log << MSG::INFO << " end of initialization" << endmsg;
-
-     m_nevt=0;
-
-    return StatusCode::SUCCESS; 
-  }
-  //__________________________________________________________________________
-  StatusCode Analysis::finalize()
-  {
-    MsgStream log( messageService(), name() );
-    log << MSG::DEBUG <<"Analysis finalize()" << endmsg;
-    return StatusCode::SUCCESS; 
-  }
-  
-  //__________________________________________________________________________
-  StatusCode Analysis::execute()
-  {
-    //.............................................
-    
-    MsgStream log( messageService(), name() );
-    log << MSG::INFO << "Analysis execute()" << endmsg;
-
-
-   m_nevt++;
-
-   log << MSG::INFO << " ***** Event " << m_nevt << endmsg;
-
-// Loop over LArCells
-  int nc=0;
-  const LArCellContainer* cell_container;
-  if(m_sgSvc->retrieve(cell_container,"LArEM").isFailure())
-  {
-    log << MSG::INFO
-        << " Could not get pointer to Cell Container " 
-        << endmsg;
-  } else
-  {
-   LArCellContainer::const_iterator first_cell = cell_container->begin();
-   LArCellContainer::const_iterator end_cell   = cell_container->end();
-   log << MSG::INFO << "*** Start loop over LArCells in Myanalysis" << endmsg;
-   for (; first_cell != end_cell; ++first_cell)
-   {
-       nc++;
-       Identifier cellID = (*first_cell)->ID();
-       double eta = (*first_cell)->eta();
-       double phi = (*first_cell)->phi();
-       double et  = (*first_cell)->et();
-       double energy=  (*first_cell)->energy();
-   }
-  } 
-  log << MSG::INFO << " === Number of Cells " << nc << endmsg;
-//
-// Loop over LArRawChannel
-  int nraw=0;
-  const LArRawChannelContainer* rawchannel_container;
-  if(m_sgSvc->retrieve(rawchannel_container,"LArRawChannels").isFailure())
-  {
-    log << MSG::INFO
-        << " Could not get  LArRawChannel container"
-        << endmsg;
-  } else
-  {
-   log << MSG::INFO 
-       << "*** Start loop over LArRawChannel in Myanalysis" << endmsg;
-   LArRawDetSelector  selObj(rawchannel_container) ;
-   selObj.setDet(m_id);
-   LArRawDetSelector::const_iterator f_cell =
-                                 selObj.begin();
-   LArRawDetSelector::const_iterator l_cell =
-                                 selObj.end();
-   for (; f_cell != l_cell; ++f_cell)
-   {
-     const LArRawChannel* hit = (*f_cell) ;
-     double energy=hit->energy();            //  energy in MeV from RawChannem
-     nraw++;
-   }
-  }
-  log << MSG::INFO << " == Number Raw Channels " << nraw << endmsg;
-
-
-// Loop over LAr hits
-  int nh=0;
-  std::vector <std::string> m_HitContainer;
- 
-  m_HitContainer.push_back("LArHitEMB");
-  m_HitContainer.push_back("LArHitEMEC");
-  m_HitContainer.push_back("LArHitHEC");
-  m_HitContainer.push_back("LArHitFCAL");
-  unsigned int iHitContainer;
-  log << MSG::INFO << "m_HitContainer.size " << m_HitContainer.size() << endmsg;
-  for (iHitContainer=0;iHitContainer<m_HitContainer.size();iHitContainer++)
-  {
-    const LArHitContainer* hit_container ;
-    if(m_sgSvc->retrieve(hit_container,m_HitContainer[iHitContainer])
-      .isFailure()) {
-      log << MSG::INFO << " cannot retrieve hit container " << endmsg;
-    }  else
-    {
-       int ihit = 0;
-       LArHitContainer::const_iterator hititer;
-       for(hititer=hit_container->begin();
-           hititer != hit_container->end();hititer++)
-       {
-          nh++;
-          ihit++;
-          LArHit* hit = (*hititer);
-       }
-     log << MSG::INFO << " number of hits found " << ihit << endmsg;
-     double xhit = (double) ihit;
-    }
-  }
-
-  log << MSG::INFO << " == Number of hits " << nh << endmsg;
-
-// check cluster
-
-  const LArClusterContainer* cluster_container;
-  if(m_sgSvc->retrieve(cluster_container,"LArClusterEM")
-      .isFailure()) {
-      log << MSG::INFO << " cannot retrieve cluster container " << endmsg;
-  }  
-  else
-  {   
-    LArClusterContainer::const_iterator clus_iter;
-    for(clus_iter=cluster_container->begin();
-        clus_iter != cluster_container->end();clus_iter++)
-    {
-       LArCluster* clus = (*clus_iter);
-       std::cout << " **** Cluster Et " << clus->et() << std::endl;
-    }
-  }
-
-  return StatusCode::SUCCESS;
- }
- 
-} // end of namespace bracket
diff --git a/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx b/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx
deleted file mode 100644
index c869448e2b44b033cca6513c5eed427d44fc0462..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx
+++ /dev/null
@@ -1,116 +0,0 @@
-/*
-  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "CaloTests/AnalysisCal.h"
-#include "Gaudi/Property.h"
-#include "GaudiKernel/MsgStream.h"
-#include "GaudiKernel/NTuple.h"
-
-#include "LArSimEvent/LArHit.h"
-#include "LArSimEvent/LArHitContainer.h"
-#include "CaloSimEvent/CaloCalibrationHit.h"
-#include "CaloSimEvent/CaloCalibrationHitContainer.h"
-#include "GeneratorObjects/McEventCollection.h"
-#include "StoreGate/ReadHandle.h"
-#include "AtlasHepMC/GenEvent.h"
-#include "AtlasHepMC/GenParticle.h"
-
-
-
-
-namespace MyAnalysisCal {
-
-  //Constructor
-  AnalysisCal::AnalysisCal(const std::string& name, ISvcLocator* pSvcLocator):
-    AthReentrantAlgorithm(name,pSvcLocator)
-    //m_nevt(0)
-  {
-  }
-  
-  //__________________________________________________________________________
-  //Destructor
-  AnalysisCal::~AnalysisCal()
-  {
-    ATH_MSG_DEBUG( "AnalysisCal destructor called"  );
-  }
-  //__________________________________________________________________________
-  StatusCode AnalysisCal::initialize()
-  {
-    ATH_MSG_DEBUG("Analysiscal initialize()"  );
-    ATH_CHECK( m_mcCollName.initialize() );
-    ATH_CHECK( m_hitContainerNames.initialize() );
-    ATH_CHECK( m_calibHitContainerNames.initialize() );
-    return StatusCode::SUCCESS; 
-  }
-  //__________________________________________________________________________
-  StatusCode AnalysisCal::finalize()
-  {
-    ATH_MSG_DEBUG("AnalysisCal finalize()"  );
-    return StatusCode::SUCCESS; 
-  }
-  
-  //__________________________________________________________________________
-  StatusCode AnalysisCal::execute (const EventContext& ctx) const
-  {
-    //.............................................
-    
-    ATH_MSG_DEBUG( "AnalysisCal execute()"  );
-
-// loop over generated particles
-
-      SG::ReadHandle<McEventCollection> mcCollptr (m_mcCollName, ctx);
-      double e_true=0.;
-      double eta_true=-999.;
-      double phi_true=-999.;
-      {
-       McEventCollection::const_iterator itr;
-       for (itr = mcCollptr->begin(); itr!=mcCollptr->end(); ++itr) {
-        for (auto part: **itr )
-       {
-         if(  (std::abs(part->pdg_id())==11 || part->pdg_id()==22)&& part->momentum().e()> 5000.)
-         {
-          e_true = part->momentum().e();
-          eta_true = part->momentum().pseudoRapidity();
-          phi_true = part->momentum().phi();
-          ATH_MSG_INFO( " true particle found " << part->pdg_id() << " " <<e_true << " " << eta_true << " " << phi_true  );
-  
-         } // e or gamma found
-        }  // loop over particle
-       }   // loop over mcCollptr
-      }
-
-// Loop over LAr hits
-
-  int nhit_tot=0;
-  double etot_hit=0.;
-  for (const SG::ReadHandleKey<LArHitContainer>& k : m_hitContainerNames) {
-    SG::ReadHandle<LArHitContainer> hit_container (k, ctx);
-    for (const LArHit* hit : *hit_container) {
-      etot_hit += hit->energy();
-      nhit_tot++;
-    }
-  }
-  ATH_MSG_INFO( " Total number of LAr hits " << nhit_tot  );
-  ATH_MSG_INFO( " Etot LAr hits            " << etot_hit  );
-
-
-// loop over Calibration Hits
-
-  double etot_cal=0;
-  nhit_tot=0;
-  for (const SG::ReadHandleKey<CaloCalibrationHitContainer>& k : m_calibHitContainerNames)
-  {
-    SG::ReadHandle<CaloCalibrationHitContainer> calocalibrationhit_container (k, ctx);
-    for (const CaloCalibrationHit* calibhit : *calocalibrationhit_container) {
-      nhit_tot++;
-      etot_cal = etot_cal + calibhit->energyTotal();
-    }
-  }
-  ATH_MSG_INFO( " Total number of calibration hits " << nhit_tot  );
-  ATH_MSG_INFO( " Etot calibration hits            " << etot_cal  );
-
-  return StatusCode::SUCCESS;
- }
- 
-} // end of namespace bracket
diff --git a/Calorimeter/CaloExample/CaloTests/src/components/CaloTests_entries.cxx b/Calorimeter/CaloExample/CaloTests/src/components/CaloTests_entries.cxx
deleted file mode 100644
index fcd1ff7b2e06b3094b6c83bcb3ec8683f807c7e9..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/src/components/CaloTests_entries.cxx
+++ /dev/null
@@ -1,7 +0,0 @@
-#include "CaloTests/Analysis.h"
-#include "CaloTests/AnalysisCal.h"
-
-
-DECLARE_COMPONENT( MyAnalysis::Analysis )
-DECLARE_COMPONENT( MyAnalysisCal::AnalysisCal )
-
diff --git a/Calorimeter/CaloExample/CaloTests/test/CaloTests_TestConfiguration.xml b/Calorimeter/CaloExample/CaloTests/test/CaloTests_TestConfiguration.xml
deleted file mode 100755
index ecc7dcaf47177e550f11a761d7aa7ba9a26ec4a2..0000000000000000000000000000000000000000
--- a/Calorimeter/CaloExample/CaloTests/test/CaloTests_TestConfiguration.xml
+++ /dev/null
@@ -1,483 +0,0 @@
-<?xml version="1.0"?>
-<!DOCTYPE unifiedTestConfiguration SYSTEM "http://www.hep.ucl.ac.uk/atlas/AtlasTesting/DTD/unifiedTestConfiguration.dtd">
-
-<unifiedTestConfiguration>
-
-<atn/>   
-   <kv/>		
-
-   <rtt xmlns="http://www.hep.ucl.ac.uk/atlas/AtlasTesting/rtt">
-
-<rttContactPerson>Emmanuel Le Guirriec</rttContactPerson>
-<mailto>guirriec@cern.ch,toth@cppm.in2p3.fr</mailto>
-
-      <jobList>
-<classification>
-     <displayClass>OfflineValidation</displayClass>
-<displayProcess>Reco</displayProcess>
-     <displayComponent>Det-LAr</displayComponent>
-</classification>
-
-<chain>
-	 <!-- TOP CHAIN -->	 
-         <chainName>CaloTests_RTT_FullChain_singlePi0_100GeV_eta-5+5</chainName>         
-         <sequential> 
-         
-         <!-- SIMULATION -->
-	 <chainElement> 
-	        <athena userJobId="FullChain_Sim_singlePi0_100GeV_eta">
-                <doc>single Pi0 100GeV,See CaloTests_GeomTag*txt for the used geometry,https://twiki.cern.ch/twiki/bin/view/Atlas/CaloIntegration</doc>
-		<displayName>CaloTests_RTT_FullChain_Sim_singlePi0_100GeV_eta-5+5</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=20;jp.AthenaCommonFlags.PoolHitsOutput="Chain.Sim_singlePi0_100GeV_eta-5+5.pool.root"
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Sim_singlePi0_100GeV_eta-5+5.py</options>
-	        <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue> 
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Sim_singlePi0_100GeV_eta-5+5.pool.root</chainfileout>
-         </chainElement>  
-
-         <!-- DIGITIZATION -->
-         <chainElement>	
-	        <athena userJobId="FullChain_Dig_singlePi0_100GeV_eta">
-                <doc>single Pi0 100GeV,See CaloTests_GeomTag*txt for the used geometry,https://twiki.cern.ch/twiki/bin/view/Atlas/CaloIntegration</doc>
-		<displayName>CaloTests_RTT_FullChain_Dig_singlePi0_100GeV_eta-5+5</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=-1;jp.AthenaCommonFlags.PoolRDOOutput="Chain.Dig_singlePi0_100GeV_eta-5+5.pool.root"
-                </commandLineFlags> 	        
-                <options>CaloTests_RTT_FullChain_Dig_singlePi0_100GeV_eta-5+5.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info>
-		 <dc2 />
-                 <chaindatasetName>Chain.Sim_singlePi0_100GeV_eta-5+5.pool.root</chaindatasetName>
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Sim_singlePi0_100GeV_eta-5+5.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Dig_singlePi0_100GeV_eta-5+5.pool.root</chainfileout>
-          </chainElement>
-
-         <!-- RECONSTRUCTION -->
-	  <chainElement>	
-	        <athena userJobId="FullChain_Rec_singlePi0_100GeV_eta">
-                <doc>single Pi0 100GeV,See CaloTests_GeomTag*txt for the used geometry,https://twiki.cern.ch/twiki/bin/view/Atlas/CaloIntegration</doc>
-		<displayName>CaloTests_RTT_FullChain_Rec_singlePi0_100GeV_eta-5+5</displayName>
-                <commandLineFlags>
-	        jp.AthenaCommonFlags.EvtMax=-1;
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Rec_singlePi0_100GeV_eta-5+5.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info> 
-                 <dc2 />
-                 <chaindatasetName>Chain.Dig_singlePi0_100GeV_eta-5+5.pool.root</chaindatasetName>           
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Dig_singlePi0_100GeV_eta-5+5.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-
-                <testToRemove>
-                <jobGroupName>RTT:Top</jobGroupName>
-                <testidentifier>CheckFileRunner0</testidentifier>
-                </testToRemove>
-
-		<athenaCommonFlags/>
-                </athena>
-          </chainElement>   
-          </sequential>
-
-</chain>
-
-<chain>
-	 <!-- TOP CHAIN -->	 
-         <chainName>CaloTests_RTT_FullChain_singleChargedPi_100GeV_eta-5+5</chainName>         
-         <sequential> 
-         
-         <!-- SIMULATION -->
-	 <chainElement> 
-	        <athena userJobId="FullChain_Sim_singleChargedPi_100GeV_eta">
-                <doc>single charged Pi 100GeV,See CaloTests_GeomTag*txt for the used geometry,https://twiki.cern.ch/twiki/bin/view/Atlas/CaloIntegration</doc>
-		<displayName>CaloTests_RTT_FullChain_Sim_singleChargedPi_100GeV_eta-5+5</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=20;jp.AthenaCommonFlags.PoolHitsOutput="Chain.Sim_singleChargedPi_100GeV_eta-5+5.pool.root"
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Sim_singlePi0_100GeV_eta-5+5.py</options>
-	        <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue> 
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Sim_singleChargedPi_100GeV_eta-5+5.pool.root</chainfileout>
-         </chainElement>  
-
-         <!-- DIGITIZATION -->
-         <chainElement>	
-	        <athena userJobId="FullChain_Dig_singleChargedPi_100GeV_eta">
-                <doc>single Pi0 100GeV,See CaloTests_GeomTag*txt for the used geometry,https://twiki.cern.ch/twiki/bin/view/Atlas/CaloIntegration</doc>
-		<displayName>CaloTests_RTT_FullChain_Dig_singleChargedPi_100GeV_eta-5+5</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=-1;jp.AthenaCommonFlags.PoolRDOOutput="Chain.Dig_singleChargedPi_100GeV_eta-5+5.pool.root"
-                </commandLineFlags> 	        
-                <options>CaloTests_RTT_FullChain_Dig_singlePi0_100GeV_eta-5+5.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info>
-		 <dc2 />
-                 <chaindatasetName>Chain.Sim_singleChargedPi_100GeV_eta-5+5.pool.root</chaindatasetName>
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Sim_singleChargedPi_100GeV_eta-5+5.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Dig_singleChargedPi_100GeV_eta-5+5.pool.root</chainfileout>
-          </chainElement>
-
-         <!-- RECONSTRUCTION -->
-	  <chainElement>	
-	        <athena userJobId="FullChain_Rec_singleChargedPi_100GeV_eta">
-                <doc>single Charged Pi 100GeV,See CaloTests_GeomTag*txt for the used geometry,https://twiki.cern.ch/twiki/bin/view/Atlas/CaloIntegration</doc>
-		<displayName>CaloTests_RTT_FullChain_Rec_singleChargedPi_100GeV_eta-5+5</displayName>
-                <commandLineFlags>
-	        jp.AthenaCommonFlags.EvtMax=-1;
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Rec_singleChargedPi_100GeV_eta-5+5.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info> 
-                 <dc2 />
-                 <chaindatasetName>Chain.Dig_singleChargedPi_100GeV_eta-5+5.pool.root</chaindatasetName>           
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Dig_singleChargedPi_100GeV_eta-5+5.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-
-                <testToRemove>
-                <jobGroupName>RTT:Top</jobGroupName>
-                <testidentifier>CheckFileRunner0</testidentifier>
-                </testToRemove>
-
-
-		<athenaCommonFlags/>
-                </athena>
-          </chainElement>   
-          </sequential>
-
-</chain>
-
-<chain>
-	 <!-- TOP CHAIN -->	 
-         <chainName>CaloTests_RTT_FullChain_singleE_5GeV</chainName>         
-         <sequential> 
-         
-         <!-- SIMULATION -->
-	 <chainElement> 
-	        <athena userJobId="FullChain_Sim_singleE_5GeV">
-                <doc>single electrons 5GeV,See CaloTests_GeomTag*txt for the used geometry,https://twiki.cern.ch/twiki/bin/view/Atlas/CaloIntegration</doc>
-		<displayName>CaloTests_RTT_FullChain_Sim_singleE_5GeV</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=20;jp.AthenaCommonFlags.PoolHitsOutput="Chain.Sim_singleE_5GeV.pool.root"
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Sim_singleE_5GeV.py</options>
-	        <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue> 
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Sim_singleE_5GeV.pool.root</chainfileout>
-         </chainElement>  
-
-         <!-- DIGITIZATION -->
-         <chainElement>	
-	        <athena userJobId="FullChain_Dig_singleE_5GeV">
-                <doc>Dig_singleE_5GeV</doc>
-		<displayName>CaloTests_RTT_FullChain_Dig_singleE_5GeV</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=-1;jp.AthenaCommonFlags.PoolRDOOutput="Chain.Dig_singleE_5GeV.pool.root"
-                </commandLineFlags> 	        
-                <options>CaloTests_RTT_FullChain_Dig_singleE_5GeV.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info>
-		 <dc2 />
-                 <chaindatasetName>Chain.Sim_singleE_5GeV.pool.root</chaindatasetName>
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Sim_singleE_5GeV.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Dig_singleE_5GeV.pool.root</chainfileout>
-          </chainElement>
-
-         <!-- RECONSTRUCTION -->
-	  <chainElement>	
-	        <athena userJobId="FullChain_Rec_singleE_5GeV">
-                <doc>Rec_singleE_5GeV</doc>
-		<displayName>CaloTests_RTT_FullChain_Rec_singleE_5GeV</displayName>
-                <commandLineFlags>
-	        jp.AthenaCommonFlags.EvtMax=-1;
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Rec_singleE_5GeV.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info> 
-                 <dc2 />
-                 <chaindatasetName>Chain.Dig_singleE_5GeV.pool.root</chaindatasetName>           
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Dig_singleE_5GeV.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-
-                <testToRemove>
-                <jobGroupName>RTT:Top</jobGroupName>
-                <testidentifier>CheckFileRunner0</testidentifier>
-                </testToRemove>
-
-		<athenaCommonFlags/>
-                </athena>
-          </chainElement>   
-          </sequential>
-
-</chain>
-
-<chain>
-	 <!-- TOP CHAIN -->	 
-         <chainName>CaloTests_RTT_FullChain_singleE_50GeV</chainName>         
-         <sequential> 
-         
-         <!-- SIMULATION -->
-	 <chainElement>                
-	       <athena userJobId="FullChain_Sim_singleE_50GeV"> 
-                <doc>single electrons 50GeV,See CaloTests_GeomTag*txt for the used geometry,https://twiki.cern.ch/twiki/bin/view/Atlas/CaloIntegration</doc>
-		<displayName>CaloTests_RTT_FullChain_Sim_singleE_50GeV</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=20;jp.AthenaCommonFlags.PoolHitsOutput="Chain.Sim_singleE_50GeV.pool.root"
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Sim_singleE_50GeV.py</options>
-	        <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Sim_singleE_50GeV.pool.root</chainfileout>
-         </chainElement>  
-
-         <!-- DIGITIZATION -->
-         <chainElement>
-	 	<athena userJobId="FullChain_Dig_singleE_50GeV">
-                <doc>Dig_singleE_5GeV</doc>
-		<displayName>CaloTests_RTT_FullChain_Dig_singleE_50GeV</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=-1;jp.AthenaCommonFlags.PoolRDOOutput="Chain.Dig_singleE_50GeV.pool.root"
-                </commandLineFlags> 	        
-                <options>CaloTests_RTT_FullChain_Dig_singleE_50GeV.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info>
-		 <dc2 />
-                 <chaindatasetName>Chain.Sim_singleE_50GeV.pool.root</chaindatasetName>
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Sim_singleE_50GeV.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Dig_singleE_50GeV.pool.root</chainfileout>
-          </chainElement>
-
-         <!-- RECONSTRUCTION -->
-	  <chainElement>	
-	 	<athena userJobId="FullChain_Rec_singleE_50GeV">
-                <doc>Rec_singleE_50GeV</doc>
-		<displayName>CaloTests_RTT_FullChain_Rec_singleE_50GeV</displayName>
-                <commandLineFlags>
-	        jp.AthenaCommonFlags.EvtMax=-1;
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Rec_singleE_50GeV.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info> 
-                 <dc2 />
-                 <chaindatasetName>Chain.Dig_singleE_50GeV.pool.root</chaindatasetName>           
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Dig_singleE_50GeV.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-
-
-                <testToRemove>
-                <jobGroupName>RTT:Top</jobGroupName>
-                <testidentifier>CheckFileRunner0</testidentifier>
-                </testToRemove>
-
-
-		<athenaCommonFlags/>
-                </athena>
-          </chainElement>   
-          </sequential>
-
-</chain>
-
-<chain>
-	 <!-- TOP CHAIN -->	 
-         <chainName>CaloTests_RTT_FullChain_singlePhot_50GeV</chainName>         
-         <sequential> 
-         
-         <!-- SIMULATION -->
-	 <chainElement>                
-	        <athena userJobId="FullChain_Sim_singlePhot_50GeV">
-                <doc>single electrons 50GeV,See CaloTests_GeomTag*txt for the used geometry,https://twiki.cern.ch/twiki/bin/view/Atlas/CaloIntegration</doc>
-		<displayName>CaloTests_RTT_FullChain_Sim_singlePhot_50GeV</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=20;jp.AthenaCommonFlags.PoolHitsOutput="Chain.Sim_singlePhot_50GeV.pool.root"
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Sim_singlePhot_50GeV.py</options>
-	        <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue> 
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Sim_singlePhot_50GeV.pool.root</chainfileout>
-         </chainElement>  
-
-         <!-- DIGITIZATION -->
-         <chainElement>	
-		<athena userJobId="FullChain_Dig_singlePhot_50GeV">
-                <doc>Dig_singleE_5GeV</doc>
-		<displayName>CaloTests_RTT_FullChain_Dig_singlePhot_50GeV</displayName>
-                <commandLineFlags>
-                jp.AthenaCommonFlags.EvtMax=-1;jp.AthenaCommonFlags.PoolRDOOutput="Chain.Dig_singlePhot_50GeV.pool.root"
-                </commandLineFlags> 	        
-                <options>CaloTests_RTT_FullChain_Dig_singlePhot_50GeV.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info>
-		 <dc2 />
-                 <chaindatasetName>Chain.Sim_singlePhot_50GeV.pool.root</chaindatasetName>
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Sim_singlePhot_50GeV.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-		<athenaCommonFlags/>
-                </athena>
-                <chainfileout>Chain.Dig_singlePhot_50GeV.pool.root</chainfileout>
-          </chainElement>
-
-         <!-- RECONSTRUCTION -->
-	  <chainElement>	
-		<athena userJobId="FullChain_Rec_singlePhot_50GeV">
-                <doc>Rec_singlePhot_50GeV</doc>
-		<displayName>CaloTests_RTT_FullChain_Rec_singlePhot_50GeV</displayName>
-                <commandLineFlags>
-	        jp.AthenaCommonFlags.EvtMax=-1;
-                </commandLineFlags>
-                <options>CaloTests_RTT_FullChain_Rec_singlePhot_50GeV.py</options>
-                <package>Calorimeter/CaloExample/CaloTests</package>
-                <group>CaloTestsAANT</group>
-		<queue>medium</queue>
-                <chaindataset_info> 
-                 <dc2 />
-                 <chaindatasetName>Chain.Dig_singlePhot_50GeV.pool.root</chaindatasetName>           
-		 <!-- If the file on the previous line is not in the chain store, then use the following fallback file. -->
-                 <dataset_info>
-                     <dc2 />
-                     <datasetName>/afs/cern.ch/atlas/project/lar/calo_data/rtt/fallback/Chain.Dig_singlePhot_50GeV.pool.root</datasetName>
-                 </dataset_info>
-                </chaindataset_info>
-
-                <testToRemove>
-                <jobGroupName>RTT:Top</jobGroupName>
-                <testidentifier>CheckFileRunner0</testidentifier>
-                </testToRemove>
-
-
-		<athenaCommonFlags/>
-                </athena>
-          </chainElement> 
-          </sequential>
-</chain>
-
-      </jobList>
-      
-      <jobGroups>
-        
-
-<jobGroup name="CaloTestsAANT" parent="RTT:Athena">
-               <keepFilePattern>*.root</keepFilePattern>
-               <keepFilePattern>*.hist</keepFilePattern>
-               <keepFilePattern>*.ps</keepFilePattern>
-               <keepFilePattern>*.txt</keepFilePattern>
-               <keepFilePattern>*.gif</keepFilePattern>
-               <keepFilePattern>*.html</keepFilePattern>
-               <keepFilePattern>*.log</keepFilePattern>
-               <keepFilePattern>rtt.css</keepFilePattern>
-               <keepFilePattern displayColor="green">checks.html</keepFilePattern>
-
-               <auxFilePattern>CaloTests*.C</auxFilePattern>
-               <auxFilePattern>CaloTests_runMacro*.C</auxFilePattern>
-               <auxFilePattern>CaloTests_runPython2.C</auxFilePattern>
-               <auxFilePattern>rtt.css</auxFilePattern>
-               <auxFilePattern>CaloTests_HistoComparison.txt</auxFilePattern>
-               <auxFilePattern>CaloTests_check.py</auxFilePattern>
-               <auxFilePattern>CaloTests_HistoComparison.py</auxFilePattern>
-               <auxFilePattern>CaloTests_Truth.py</auxFilePattern>
-               <auxFilePattern>CaloTests_memleak.py</auxFilePattern>
-               <auxFilePattern>CaloTests_checkAODESDcontent.py</auxFilePattern>
-               <auxFilePattern>CaloTests_extractRec.py</auxFilePattern>
-<auxFilePattern>checkFile.py</auxFilePattern>
-            <auxFilePattern>*Checks.py</auxFilePattern> 
-                <auxFilePattern>addHTML.py </auxFilePattern>                                                                
-   <action>
-            <modulename>RttLibraryTools</modulename>
-            <testname>ROOTMacroRunner</testname>
-            <arg>
-               <argname>macro</argname>
-               <argvalue>CaloTests_runMacros2.C</argvalue>
-            </arg>
-         </action>
-
-
-
-  </jobGroup>    
-
-
-
-      </jobGroups>
-   </rtt>
-
-</unifiedTestConfiguration>
-
diff --git a/Calorimeter/CaloLocalHadCalib/src/GetLCDeadMaterialTree.cxx b/Calorimeter/CaloLocalHadCalib/src/GetLCDeadMaterialTree.cxx
index f66783db12c45e7ecd8cabd7e4eed77dcd205e92..b6e7a34868067f71a50387ee2ba41ad77a646d9b 100644
--- a/Calorimeter/CaloLocalHadCalib/src/GetLCDeadMaterialTree.cxx
+++ b/Calorimeter/CaloLocalHadCalib/src/GetLCDeadMaterialTree.cxx
@@ -222,8 +222,12 @@ StatusCode GetLCDeadMaterialTree::execute()
   ******************************************** */
   const McEventCollection* truthEvent=nullptr;
   ATH_CHECK( evtStore()->retrieve(truthEvent, "TruthEvent") );
+#ifdef HEPMC3
+  HepMC::ConstGenParticlePtr gen  = truthEvent->at(0)->particles().front();
+#else
   HepMC::GenEvent::particle_const_iterator pit  = truthEvent->at(0)->particles_begin();
   const HepMC::GenParticle * gen  = *pit;
+#endif
 
   double mc_eta = gen->momentum().pseudoRapidity();
   double mc_phi = gen->momentum().phi();
diff --git a/Calorimeter/CaloLocalHadCalib/src/GetLCSinglePionsPerf.cxx b/Calorimeter/CaloLocalHadCalib/src/GetLCSinglePionsPerf.cxx
index 5f576ea4470c0024a09512e0d1ac86f3d415778d..02428e9727cc282f55d09a43765fa1d5b848a75b 100644
--- a/Calorimeter/CaloLocalHadCalib/src/GetLCSinglePionsPerf.cxx
+++ b/Calorimeter/CaloLocalHadCalib/src/GetLCSinglePionsPerf.cxx
@@ -679,6 +679,13 @@ StatusCode GetLCSinglePionsPerf::execute()
   ******************************************** */
   const McEventCollection* truthEvent=nullptr;
   ATH_CHECK( evtStore()->retrieve(truthEvent, "TruthEvent") );
+#ifdef HEPMC3
+  if( truthEvent->at(0)->particles().empty() ){
+    ATH_MSG_ERROR( "No particles in McEventCollection" );
+    return StatusCode::FAILURE;
+  }
+   HepMC::ConstGenParticlePtr gen=truthEvent->at(0)->particles().front();
+#else  
   if( truthEvent->at(0)->particles_empty() ){
     ATH_MSG_ERROR( "No particles in McEventCollection" );
     return StatusCode::FAILURE;
@@ -686,6 +693,7 @@ StatusCode GetLCSinglePionsPerf::execute()
   // primary particle info
   HepMC::GenEvent::particle_const_iterator pit  = truthEvent->at(0)->particles_begin();
   const HepMC::GenParticle *gen = (*pit);
+#endif
   m_mc_eta = gen->momentum().pseudoRapidity();
   m_mc_phi = gen->momentum().phi();
   m_mc_ener = gen->momentum().e();
diff --git a/Calorimeter/CaloRec/share/CaloCellContainerAliasAlg_test.ref b/Calorimeter/CaloRec/share/CaloCellContainerAliasAlg_test.ref
index 850bef3e9c1a3ec0a94088aa12750ab91f7d1c92..68602482510f2efe45745aae82cb21dd3dfcb9ea 100644
--- a/Calorimeter/CaloRec/share/CaloCellContainerAliasAlg_test.ref
+++ b/Calorimeter/CaloRec/share/CaloCellContainerAliasAlg_test.ref
@@ -1,338 +1,340 @@
-Py:ConfigurableDb    INFO Read module info for 5545 configurables from 11 genConfDb files
-Py:ConfigurableDb    INFO No duplicates have been found: that's good !
 Py:AutoConfigFlags    INFO Obtaining metadata of auto-configuration by peeking into /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root
 Py:MetaReader        INFO Current mode used: peeker
 Py:MetaReader        INFO Current filenames: ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root']
 Py:MetaReader        INFO MetaReader is called with the parameter "unique_tag_info_values" set to True. This is a workaround to remove all duplicate values from "/TagInfo" key
-Py:Athena            INFO using release [WorkDir-22.0.12] [x86_64-centos7-gcc8-opt] [atlas-master-acas-c/9345ae20609] -- built on [2020-03-29T1758]
+Py:Athena            INFO using release [WorkDir-22.0.22] [x86_64-centos7-gcc8-opt] [MainServiceMsgFormat/f665cad] -- built on [2020-12-03T1657]
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v33r1)
-                                          running on spar0103.usatlas.bnl.gov on Sun Mar 29 18:35:13 2020
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on pcaz001 on Thu Dec  3 17:18:09 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-CoreDumpSvc          INFO install f-a-t-a-l handler... (flag = 438)
-CoreDumpSvc          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
-ClassIDSvc           INFO  getRegistryEntries: read 16636 CLIDRegistry entries for module ALL
-PoolSvc              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
-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-ai.cern.ch:8000/atlr)(serverurl=http://frontier-atlas.lcg.triumf.ca:3128/ATLAS_frontier)(serverurl=http://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
-DBReplicaSvc         INFO Total of 1 servers found for host spar0103.usatlas.bnl.gov [ATLF ]
-PoolSvc              INFO Successfully setup replica sorting algorithm
-PoolSvc              INFO Setting up APR FileCatalog and Streams
-PoolSvc              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
-IOVDbSvc             INFO Opened read transaction for POOL PersistencySvc
-IOVDbSvc             INFO Only 5 POOL conditions files will be open at once
-IOVDbSvc             INFO Cache alignment will be done in 3 slices
-IOVDbSvc             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
-IOVDbSvc             INFO Initialised with 2 connections and 3 folders
-IOVDbSvc             INFO Service IOVDbSvc initialised successfully
-MetaDataSvc          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
-AthenaPoolCnvSvc     INFO Initializing AthenaPoolCnvSvc - package version AthenaPoolCnvSvc-00-00-00
-MetaDataSvc          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
-ClassIDSvc           INFO  getRegistryEntries: read 1419 CLIDRegistry entries for module ALL
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
-IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-IOVDbSvc             INFO Added taginfo remove for /LAR/Align
-IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
-IOVDbSvc             INFO Added taginfo remove for /LAR/LArCellPositionShift
-ClassIDSvc           INFO  getRegistryEntries: read 53 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 18 CLIDRegistry entries for module ALL
-GeoModelSvc          INFO Explicitly initializing DetDescrCnvSvc
-DetDescrCnvSvc       INFO  initializing 
-DetDescrCnvSvc       INFO Found DetectorStore service
-DetDescrCnvSvc       INFO  filling proxies for detector managers 
-DetDescrCnvSvc       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
-GeoModelSvc::RD...WARNING  Getting PixTBMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting PixTBMaterials with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMaterials with default tag
-EventPersistenc...   INFO Added successfully Conversion service:McCnvSvc
-EventPersistenc...   INFO Added successfully Conversion service:DetDescrCnvSvc
-LArElectrodeIDD...   INFO in createObj: creating a LArElectrodeID helper object in the detector store
-IdDictDetDescrCnv    INFO in initialize
-IdDictDetDescrCnv    INFO in createObj: creating a IdDictManager object in the detector store
-IdDictDetDescrCnv    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
-IdDictDetDescrCnv    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
-IdDictDetDescrCnv    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Found id dicts:
-IdDictDetDescrCnv    INFO Using dictionary tag: null
-IdDictDetDescrCnv    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
-LArElectrodeID       INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineIDDetD...   INFO in createObj: creating a LArHVLineID helper object in the detector store
-LArHVLineID          INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineID          INFO  => initialize_from_dictionary(dict_mgr) =0
-LArHVLineID          INFO Register_dict_tag of LArHighVoltage is OK
-LArHVLineID          INFO setDictVersion of LArHighVoltage is OK
-LArHVLineID          INFO [initLevelsFromDict] m_dict OK ... 
-LArHVLineID          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
-LArHVLineID          INFO [init_hashes()] > Hvline_size= 5008
-GeoModelSvc.LAr...   INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
-GeoModelSvc.LAr...   INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
-GeoModelSvc.LAr...   INFO LAr Geometry Options:
-GeoModelSvc.LAr...   INFO   Sagging           = false
-GeoModelSvc.LAr...   INFO   Barrel            = ON
-GeoModelSvc.LAr...   INFO   Endcap            = ON
-BarrelConstruction   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
-BarrelConstruction   INFO   Makes detailed absorber sandwich  ? 1 1
-BarrelConstruction   INFO   Use sagging in geometry  ? 0
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Pos::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Pos::OuterWheel
-ClassIDSvc           INFO  getRegistryEntries: read 2899 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a TileTBID helper object in the detector store
-TileTBID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-EndcapDMConstru...   INFO Start building EC electronics geometry
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Neg::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Neg::OuterWheel
-EndcapDMConstru...   INFO Start building EC electronics geometry
-GeoModelSvc          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 25964Kb 	 Time = 0.64S
-GeoModelSvc.Til...   INFO  Entering TileDetectorTool::create()
-TileDddbManager      INFO m_tag = ATLAS-R2-2016-01-00-01
-TileDddbManager      INFO n_tiglob = 5
-TileDddbManager      INFO n_timod = 320
-TileDddbManager      INFO n_cuts = 9
-TileDddbManager      INFO n_saddle = 1
-TileDddbManager      INFO n_tilb = 21
-TileDddbManager      INFO n_tileSwitches = 1
-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/TileNeighbour_reduced.txt
-TileHWIDDetDesc...   INFO in createObj: creating a TileHWID helper object in the detector store
-TileHWID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-ClassIDSvc           INFO  getRegistryEntries: read 55 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_ID helper object in the detector store
-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCal2DNeighbors-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsNext-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-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.
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-GeoModelSvc.Til...   INFO  U-shape parameter from database is: 1
-GeoModelSvc.Til...   INFO  Glue parameter from database is: 1
-GeoModelSvc.Til...   INFO  Cs Tube parameter from database is: 0
-GeoModelSvc.Til...   INFO  Entering TileAtlasFactory::create()
-GeoModelSvc.Til...   INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
-GeoModelSvc.Til...   INFO  => New BFingerLengthPos 430.5
-GeoModelSvc.Til...   INFO  => New BFingerLengthNeg 420.5
-GeoModelSvc.Til...   INFO  Positioning barrel with translation 0
-GeoModelSvc.Til...   INFO  Positioning positive barrel finger with translation 3035.25
-GeoModelSvc.Til...   INFO  Positioning negative barrel finger with translation -3030.25
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel with translation 4854.75
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
-GeoModelSvc.Til...   INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning positive ITC with translation 3405
-GeoModelSvc.Til...   INFO  Positioning positive Gap with translation 3552
-GeoModelSvc.Til...   INFO  Positioning positive Crack with translation 3536
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel with translation ztrans -4854.75
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
-GeoModelSvc.Til...   INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning negative ITC with translation -3405
-GeoModelSvc.Til...   INFO  Positioning negative Gap with translation -3552
-GeoModelSvc.Til...   INFO  Positioning negative Crack with translation -3536
-GeoModelSvc.Til...   INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
-TileDetDescrMan...   INFO Entering create_elements()
-GeoModelSvc          INFO GeoModelSvc.TileDetectorTool	 SZ= 4524Kb 	 Time = 0.2S
-ClassIDSvc           INFO  getRegistryEntries: read 66 CLIDRegistry entries for module ALL
-AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 6536 CLIDRegistry entries for module ALL
-CondInputLoader      INFO Initializing CondInputLoader...
-CondInputLoader      INFO Adding base classes:
+CoreDumpSvc                                          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
+ClassIDSvc                                           INFO  getRegistryEntries: read 18422 CLIDRegistry entries for module ALL
+TagInfoMgr                                           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
+IOVDbSvc                                             INFO Only 5 POOL conditions files will be open at once
+IOVDbSvc                                             INFO Cache alignment will be done in 3 slices
+IOVDbSvc                                             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
+IOVDbSvc                                             INFO Initialised with 2 connections and 3 folders
+IOVDbSvc                                             INFO Service IOVDbSvc initialised successfully
+IOVDbSvc                                             INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+MetaDataSvc                                          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
+PoolSvc                                              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
+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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
+DBReplicaSvc                                         INFO Total of 10 servers found for host pcaz001.dyndns.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                                              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
+DbSession                                            INFO     Open     DbSession    
+Domain[ROOT_All]                                     INFO >   Access   DbDomain     READ      [ROOT_All] 
+MetaDataSvc                                          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
+OutputStreamSequencerSvc                             INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+ClassIDSvc                                           INFO  getRegistryEntries: read 1178 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVSvc                                               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool                                    INFO IOVRanges will be checked at every Event
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Align
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/LArCellPositionShift
+ClassIDSvc                                           INFO  getRegistryEntries: read 273 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 20 CLIDRegistry entries for module ALL
+DetDescrCnvSvc                                       INFO  initializing 
+DetDescrCnvSvc                                       INFO Found DetectorStore service
+DetDescrCnvSvc                                       INFO  filling proxies for detector managers 
+DetDescrCnvSvc                                       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMaterials with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMaterials with default tag
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileDetectorTool::create()
+TileDddbManager                                      INFO m_tag = ATLAS-R2-2016-01-00-01
+TileDddbManager                                      INFO n_tiglob = 5
+TileDddbManager                                      INFO n_timod = 320
+TileDddbManager                                      INFO n_cuts = 9
+TileDddbManager                                      INFO n_saddle = 1
+TileDddbManager                                      INFO n_tilb = 21
+TileDddbManager                                      INFO n_tileSwitches = 1
+EventPersistencySvc                                  INFO Added successfully Conversion service:McCnvSvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:DetDescrCnvSvc
+ClassIDSvc                                           INFO  getRegistryEntries: read 2522 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TileID helper object in the detector store
+IdDictDetDescrCnv                                    INFO in initialize
+IdDictDetDescrCnv                                    INFO in createObj: creating a IdDictManager object in the detector store
+IdDictDetDescrCnv                                    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
+IdDictDetDescrCnv                                    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
+IdDictDetDescrCnv                                    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Found id dicts:
+IdDictDetDescrCnv                                    INFO Using dictionary tag: null
+IdDictDetDescrCnv                                    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+TileNeighbour                                        INFO Reading file  /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileNeighbour_reduced.txt
+TileHWIDDetDescrCnv                                  INFO in createObj: creating a TileHWID helper object in the detector store
+TileHWID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+ClassIDSvc                                           INFO  getRegistryEntries: read 219 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal2DNeighbors-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsNext-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsPrev-April2011.txt
+CaloIDHelper_IDDetDescrCnv                           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.
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+GeoModelSvc.TileDetectorTool                         INFO  U-shape parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Glue parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Cs Tube parameter from database is: 0
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileAtlasFactory::create()
+GeoModelSvc.TileDetectorTool                         INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthPos 430.5
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthNeg 420.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning barrel with translation 0
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive barrel finger with translation 3035.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative barrel finger with translation -3030.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel with translation 4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ITC with translation 3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Gap with translation 3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Crack with translation 3536
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel with translation ztrans -4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ITC with translation -3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Gap with translation -3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Crack with translation -3536
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
+TileDetDescrManager                                  INFO Entering create_elements()
+GeoModelSvc                                          INFO GeoModelSvc.TileDetectorTool	 SZ= 16888Kb 	 Time = 0.48S
+LArElectrodeIDDetDescrCnv                            INFO in createObj: creating a LArElectrodeID helper object in the detector store
+LArElectrodeID                                       INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineIDDetDescrCnv                               INFO in createObj: creating a LArHVLineID helper object in the detector store
+LArHVLineID                                          INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineID                                          INFO  => initialize_from_dictionary(dict_mgr) =0
+LArHVLineID                                          INFO Register_dict_tag of LArHighVoltage is OK
+LArHVLineID                                          INFO setDictVersion of LArHighVoltage is OK
+LArHVLineID                                          INFO [initLevelsFromDict] m_dict OK ... 
+LArHVLineID                                          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
+LArHVLineID                                          INFO [init_hashes()] > Hvline_size= 5008
+GeoModelSvc.LArDetectorToolNV                        INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
+GeoModelSvc.LArDetectorToolNV                        INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
+GeoModelSvc.LArDetectorToolNV                        INFO LAr Geometry Options:
+GeoModelSvc.LArDetectorToolNV                        INFO   Sagging           = false
+GeoModelSvc.LArDetectorToolNV                        INFO   Barrel            = ON
+GeoModelSvc.LArDetectorToolNV                        INFO   Endcap            = ON
+BarrelConstruction                                   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
+BarrelConstruction                                   INFO   Makes detailed absorber sandwich  ? 1 1
+BarrelConstruction                                   INFO   Use sagging in geometry  ? 0
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::OuterWheel
+ClassIDSvc                                           INFO  getRegistryEntries: read 287 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TileTBID helper object in the detector store
+TileTBID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::OuterWheel
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+GeoModelSvc                                          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 21268Kb 	 Time = 0.53S
+ClassIDSvc                                           INFO  getRegistryEntries: read 67 CLIDRegistry entries for module ALL
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.TileDetectorTool
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.LArDetectorToolNV
+AthenaEventLoopMgr                                   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 5023 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO Initializing CondInputLoader...
+CondInputLoader                                      INFO Adding base classes:
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' )   ->
-CondInputLoader      INFO Will create WriteCondHandle dependencies for the following DataObjects:
+CondInputLoader                                      INFO Will create WriteCondHandle dependencies for the following DataObjects:
     +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' ) 
-ClassIDSvc           INFO  getRegistryEntries: read 3246 CLIDRegistry entries for module ALL
-PyComponentMgr       INFO Initializing PyComponentMgr...
-CreateDataAlg        INFO Initializing CreateDataAlg...
-ClassIDSvc           INFO  getRegistryEntries: read 104 CLIDRegistry entries for module ALL
-CheckAliasAlg        INFO Initializing CheckAliasAlg...
-EventSelector        INFO  Enter McEventSelector Initialization 
-AthenaEventLoopMgr   INFO Setup EventSelector service EventSelector
-ApplicationMgr       INFO Application Manager Initialized successfully
-ApplicationMgr    SUCCESS ****************************** Algorithm Sequence ****************************
-ApplicationMgr    SUCCESS AthSequencer/AthMasterSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthAlgEvtSeq
-ApplicationMgr    SUCCESS           AthSequencer/AthBeginSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg1
-ApplicationMgr    SUCCESS           AthSequencer/AthAllAlgSeq
-ApplicationMgr    SUCCESS                AthSequencer/AthCondSeq
-ApplicationMgr    SUCCESS                     CondInputLoader/CondInputLoader
-ApplicationMgr    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
-ApplicationMgr    SUCCESS                AthSequencer/AthAlgSeq
-ApplicationMgr    SUCCESS                     PyAthena::Alg/CreateDataAlg
-ApplicationMgr    SUCCESS                     CaloCellContainerAliasAlg/aliasAlg
-ApplicationMgr    SUCCESS                     PyAthena::Alg/CheckAliasAlg
-ApplicationMgr    SUCCESS           AthSequencer/AthEndSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg2
-ApplicationMgr    SUCCESS      AthSequencer/AthOutSeq
-ApplicationMgr    SUCCESS ******************************************************************************
-CondInputLoader      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
-ApplicationMgr       INFO Application Manager Started successfully
-AthenaEventLoopMgr   INFO   ===>>>  start of run 284500    <<<===
-EventPersistenc...   INFO Added successfully Conversion service:TagInfoMgr
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-EventPersistenc...   INFO Added successfully Conversion service:AthenaPoolCnvSvc
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root File version:52200
-CaloMgrDetDescrCnv   INFO in createObj: creating a Calo Detector Manager object in the detector store
-CaloIdMgrDetDes...   INFO in createObj: creating a CaloDescrManager object in the detector store
-ClassIDSvc           INFO  getRegistryEntries: read 193 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloDM_ID helper object in the detector store
-CaloDM_ID            INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
-CaloLVL1_ID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a TTOnlineID helper object in the detector store
-TTOnlineID           INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/TileSuperCellNeighbour.txt
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIdMgrDetDes...   INFO  Finished 
-CaloIdMgrDetDes...   INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
-LArOnlineIDDetD...   INFO in createObj: creating a LArOnlineID helper object in the detector store
-LArOnlineID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArOnOffMappingAlg   INFO Done reading online/offline identifier mapping
-LArOnOffMappingAlg   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
-LArOnOffMappingAlg   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
+ClassIDSvc                                           INFO  getRegistryEntries: read 3730 CLIDRegistry entries for module ALL
+PyComponentMgr                                       INFO Initializing PyComponentMgr...
+CreateDataAlg                                        INFO Initializing CreateDataAlg...
+ClassIDSvc                                           INFO  getRegistryEntries: read 108 CLIDRegistry entries for module ALL
+CheckAliasAlg                                        INFO Initializing CheckAliasAlg...
+EventSelector                                        INFO  Enter McEventSelector Initialization 
+AthenaEventLoopMgr                                   INFO Setup EventSelector service EventSelector
+ApplicationMgr                                       INFO Application Manager Initialized successfully
+ApplicationMgr                                    SUCCESS ****************************** Algorithm Sequence ****************************
+ApplicationMgr                                    SUCCESS AthSequencer/AthMasterSeq
+ApplicationMgr                                    SUCCESS      AthSequencer/AthAlgEvtSeq
+ApplicationMgr                                    SUCCESS           AthSequencer/AthBeginSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg1
+ApplicationMgr                                    SUCCESS           AthSequencer/AthAllAlgSeq
+ApplicationMgr                                    SUCCESS                AthSequencer/AthCondSeq
+ApplicationMgr                                    SUCCESS                     CondInputLoader/CondInputLoader
+ApplicationMgr                                    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
+ApplicationMgr                                    SUCCESS                AthSequencer/AthAlgSeq
+ApplicationMgr                                    SUCCESS                     PyAthena::Alg/CreateDataAlg
+ApplicationMgr                                    SUCCESS                     CaloCellContainerAliasAlg/aliasAlg
+ApplicationMgr                                    SUCCESS                     PyAthena::Alg/CheckAliasAlg
+ApplicationMgr                                    SUCCESS           AthSequencer/AthEndSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg2
+ApplicationMgr                                    SUCCESS      AthSequencer/AthOutSeq
+ApplicationMgr                                    SUCCESS ******************************************************************************
+CondInputLoader                                      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
+ApplicationMgr                                       INFO Application Manager Started successfully
+AthenaEventLoopMgr                                   INFO   ===>>>  start of run 284500    <<<===
+EventPersistencySvc                                  INFO Added successfully Conversion service:TagInfoMgr
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Opened read transaction for POOL PersistencySvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:AthenaPoolCnvSvc
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root File version:52200
+CaloMgrDetDescrCnv                                   INFO in createObj: creating a Calo Detector Manager object in the detector store
+CaloIdMgrDetDescrCnv                                 INFO in createObj: creating a CaloDescrManager object in the detector store
+ClassIDSvc                                           INFO  getRegistryEntries: read 196 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloDM_ID helper object in the detector store
+CaloDM_ID                                            INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
+CaloLVL1_ID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TTOnlineID helper object in the detector store
+TTOnlineID                                           INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsPrevNew-April2014.txt
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileSuperCellNeighbour.txt
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIdMgrDetDescrCnv                                 INFO  Finished 
+CaloIdMgrDetDescrCnv                                 INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
+LArOnlineIDDetDescrCnv                               INFO in createObj: creating a LArOnlineID helper object in the detector store
+LArOnlineID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArOnOffMappingAlg                                   INFO Done reading online/offline identifier mapping
+LArOnOffMappingAlg                                   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
+LArOnOffMappingAlg                                   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
 Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
 Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_ostream<char,char_traits<char> >!
 Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
 Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_stringbuf<char,char_traits<char>,allocator<char> >!
 Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
 Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent GaudiPython::CallbackStreamBuf!
-AthDictLoaderSvc     INFO in initialize...
-AthDictLoaderSvc     INFO acquired Dso-registry
-ClassIDSvc           INFO  getRegistryEntries: read 289 CLIDRegistry entries for module ALL
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
-/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 >   Deaccess DbDomain     READ      [ROOT_All] 
-ApplicationMgr       INFO Application Manager Stopped successfully
-IncidentProcAlg1     INFO Finalize
-CondInputLoader      INFO Finalizing CondInputLoader...
-CreateDataAlg        INFO Finalizing CreateDataAlg...
-CheckAliasAlg        INFO Finalizing CheckAliasAlg...
-IncidentProcAlg2     INFO Finalize
-AthDictLoaderSvc     INFO in finalize...
-EventSelector        INFO finalize
-PyComponentMgr       INFO Finalizing PyComponentMgr...
-ToolSvc              INFO Removing all tools created by ToolSvc
-IOVDbFolder          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     1.96 ))s
-IOVDbFolder          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     1.70 ))s
-IOVDbFolder          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     1.12 ))s
-IOVDbSvc             INFO  bytes in ((      4.78 ))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: 3 ReadTime: ((     4.78 ))s
-IdDictDetDescrCnv    INFO in finalize
-*****Chrono*****     INFO ****************************************************************************************************
-*****Chrono*****     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
-*****Chrono*****     INFO ****************************************************************************************************
-cObjR_ALL            INFO Time User   : Tot=  300 [ms] Ave/Min/Max=  150(+-  150)/    0/  300 [ms] #=  2
-cObj_ALL             INFO Time User   : Tot=  330 [ms] Ave/Min/Max=  110(+-  149)/    0/  320 [ms] #=  3
-ChronoStatSvc        INFO Time User   : Tot= 34.5  [s]                                             #=  1
-*****Chrono*****     INFO ****************************************************************************************************
-ChronoStatSvc.f...   INFO  Service finalized successfully 
-ApplicationMgr       INFO Application Manager Finalized successfully
-ApplicationMgr       INFO Application Manager Terminated successfully
+AthDictLoaderSvc                                     INFO in initialize...
+AthDictLoaderSvc                                     INFO acquired Dso-registry
+ClassIDSvc                                           INFO  getRegistryEntries: read 241 CLIDRegistry entries for module ALL
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
+Domain[ROOT_All]                                     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
+ApplicationMgr                                       INFO Application Manager Stopped successfully
+IncidentProcAlg1                                     INFO Finalize
+CondInputLoader                                      INFO Finalizing CondInputLoader...
+CreateDataAlg                                        INFO Finalizing CreateDataAlg...
+CheckAliasAlg                                        INFO Finalizing CheckAliasAlg...
+IncidentProcAlg2                                     INFO Finalize
+AthDictLoaderSvc                                     INFO in finalize...
+EventSelector                                        INFO finalize
+PyComponentMgr                                       INFO Finalizing PyComponentMgr...
+IdDictDetDescrCnv                                    INFO in finalize
+IOVDbFolder                                          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.05 ))s
+IOVDbFolder                                          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     0.01 ))s
+IOVDbSvc                                             INFO  bytes in ((      0.09 ))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: 3 ReadTime: ((     0.09 ))s
+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= 0.62  [s] Ave/Min/Max=    0.31(+-     0.3)/    0.01/    0.61  [s] #=  2
+cObj_ALL                                             INFO Time User   : Tot= 0.67  [s] Ave/Min/Max=   0.223(+-   0.295)/       0/    0.64  [s] #=  3
+ChronoStatSvc                                        INFO Time User   : Tot= 44.8  [s]  #=  1
+*****Chrono*****                                     INFO ****************************************************************************************************
+ChronoStatSvc.finalize()                             INFO  Service finalized successfully 
+ApplicationMgr                                       INFO Application Manager Finalized successfully
+ApplicationMgr                                       INFO Application Manager Terminated successfully
diff --git a/Calorimeter/CaloRec/share/CaloThinCellsByClusterAlg_test.ref b/Calorimeter/CaloRec/share/CaloThinCellsByClusterAlg_test.ref
index 15cd1168be860a84582dedca1ca610c3d0c0fda1..c95376f64083c61fffd8ef9d38b79defa3478eed 100644
--- a/Calorimeter/CaloRec/share/CaloThinCellsByClusterAlg_test.ref
+++ b/Calorimeter/CaloRec/share/CaloThinCellsByClusterAlg_test.ref
@@ -1,340 +1,342 @@
-Py:ConfigurableDb    INFO Read module info for 5545 configurables from 11 genConfDb files
-Py:ConfigurableDb    INFO No duplicates have been found: that's good !
 Py:AutoConfigFlags    INFO Obtaining metadata of auto-configuration by peeking into /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root
 Py:MetaReader        INFO Current mode used: peeker
 Py:MetaReader        INFO Current filenames: ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root']
 Py:MetaReader        INFO MetaReader is called with the parameter "unique_tag_info_values" set to True. This is a workaround to remove all duplicate values from "/TagInfo" key
-Py:Athena            INFO using release [WorkDir-22.0.12] [x86_64-centos7-gcc8-opt] [atlas-master-acas-c/9345ae20609] -- built on [2020-03-29T1758]
+Py:Athena            INFO using release [WorkDir-22.0.22] [x86_64-centos7-gcc8-opt] [MainServiceMsgFormat/f665cad] -- built on [2020-12-03T1657]
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v33r1)
-                                          running on spar0103.usatlas.bnl.gov on Sun Mar 29 18:29:22 2020
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on pcaz001 on Thu Dec  3 17:24:28 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-CoreDumpSvc          INFO install f-a-t-a-l handler... (flag = 438)
-CoreDumpSvc          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
-ClassIDSvc           INFO  getRegistryEntries: read 16636 CLIDRegistry entries for module ALL
-PoolSvc              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
-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-ai.cern.ch:8000/atlr)(serverurl=http://frontier-atlas.lcg.triumf.ca:3128/ATLAS_frontier)(serverurl=http://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
-DBReplicaSvc         INFO Total of 1 servers found for host spar0103.usatlas.bnl.gov [ATLF ]
-PoolSvc              INFO Successfully setup replica sorting algorithm
-PoolSvc              INFO Setting up APR FileCatalog and Streams
-PoolSvc              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
-IOVDbSvc             INFO Opened read transaction for POOL PersistencySvc
-IOVDbSvc             INFO Only 5 POOL conditions files will be open at once
-IOVDbSvc             INFO Cache alignment will be done in 3 slices
-IOVDbSvc             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
-IOVDbSvc             INFO Initialised with 2 connections and 3 folders
-IOVDbSvc             INFO Service IOVDbSvc initialised successfully
-MetaDataSvc          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
-AthenaPoolCnvSvc     INFO Initializing AthenaPoolCnvSvc - package version AthenaPoolCnvSvc-00-00-00
-MetaDataSvc          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
-ClassIDSvc           INFO  getRegistryEntries: read 1419 CLIDRegistry entries for module ALL
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
-IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-IOVDbSvc             INFO Added taginfo remove for /LAR/Align
-IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
-IOVDbSvc             INFO Added taginfo remove for /LAR/LArCellPositionShift
-ClassIDSvc           INFO  getRegistryEntries: read 53 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 18 CLIDRegistry entries for module ALL
-GeoModelSvc          INFO Explicitly initializing DetDescrCnvSvc
-DetDescrCnvSvc       INFO  initializing 
-DetDescrCnvSvc       INFO Found DetectorStore service
-DetDescrCnvSvc       INFO  filling proxies for detector managers 
-DetDescrCnvSvc       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
-GeoModelSvc::RD...WARNING  Getting PixTBMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting PixTBMaterials with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMaterials with default tag
-EventPersistenc...   INFO Added successfully Conversion service:McCnvSvc
-EventPersistenc...   INFO Added successfully Conversion service:DetDescrCnvSvc
-LArElectrodeIDD...   INFO in createObj: creating a LArElectrodeID helper object in the detector store
-IdDictDetDescrCnv    INFO in initialize
-IdDictDetDescrCnv    INFO in createObj: creating a IdDictManager object in the detector store
-IdDictDetDescrCnv    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
-IdDictDetDescrCnv    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
-IdDictDetDescrCnv    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Found id dicts:
-IdDictDetDescrCnv    INFO Using dictionary tag: null
-IdDictDetDescrCnv    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
-LArElectrodeID       INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineIDDetD...   INFO in createObj: creating a LArHVLineID helper object in the detector store
-LArHVLineID          INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineID          INFO  => initialize_from_dictionary(dict_mgr) =0
-LArHVLineID          INFO Register_dict_tag of LArHighVoltage is OK
-LArHVLineID          INFO setDictVersion of LArHighVoltage is OK
-LArHVLineID          INFO [initLevelsFromDict] m_dict OK ... 
-LArHVLineID          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
-LArHVLineID          INFO [init_hashes()] > Hvline_size= 5008
-GeoModelSvc.LAr...   INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
-GeoModelSvc.LAr...   INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
-GeoModelSvc.LAr...   INFO LAr Geometry Options:
-GeoModelSvc.LAr...   INFO   Sagging           = false
-GeoModelSvc.LAr...   INFO   Barrel            = ON
-GeoModelSvc.LAr...   INFO   Endcap            = ON
-BarrelConstruction   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
-BarrelConstruction   INFO   Makes detailed absorber sandwich  ? 1 1
-BarrelConstruction   INFO   Use sagging in geometry  ? 0
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Pos::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Pos::OuterWheel
-ClassIDSvc           INFO  getRegistryEntries: read 2899 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a TileTBID helper object in the detector store
-TileTBID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-EndcapDMConstru...   INFO Start building EC electronics geometry
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Neg::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Neg::OuterWheel
-EndcapDMConstru...   INFO Start building EC electronics geometry
-GeoModelSvc          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 25968Kb 	 Time = 0.64S
-GeoModelSvc.Til...   INFO  Entering TileDetectorTool::create()
-TileDddbManager      INFO m_tag = ATLAS-R2-2016-01-00-01
-TileDddbManager      INFO n_tiglob = 5
-TileDddbManager      INFO n_timod = 320
-TileDddbManager      INFO n_cuts = 9
-TileDddbManager      INFO n_saddle = 1
-TileDddbManager      INFO n_tilb = 21
-TileDddbManager      INFO n_tileSwitches = 1
-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/TileNeighbour_reduced.txt
-TileHWIDDetDesc...   INFO in createObj: creating a TileHWID helper object in the detector store
-TileHWID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-ClassIDSvc           INFO  getRegistryEntries: read 55 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_ID helper object in the detector store
-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCal2DNeighbors-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsNext-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-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.
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-GeoModelSvc.Til...   INFO  U-shape parameter from database is: 1
-GeoModelSvc.Til...   INFO  Glue parameter from database is: 1
-GeoModelSvc.Til...   INFO  Cs Tube parameter from database is: 0
-GeoModelSvc.Til...   INFO  Entering TileAtlasFactory::create()
-GeoModelSvc.Til...   INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
-GeoModelSvc.Til...   INFO  => New BFingerLengthPos 430.5
-GeoModelSvc.Til...   INFO  => New BFingerLengthNeg 420.5
-GeoModelSvc.Til...   INFO  Positioning barrel with translation 0
-GeoModelSvc.Til...   INFO  Positioning positive barrel finger with translation 3035.25
-GeoModelSvc.Til...   INFO  Positioning negative barrel finger with translation -3030.25
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel with translation 4854.75
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
-GeoModelSvc.Til...   INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning positive ITC with translation 3405
-GeoModelSvc.Til...   INFO  Positioning positive Gap with translation 3552
-GeoModelSvc.Til...   INFO  Positioning positive Crack with translation 3536
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel with translation ztrans -4854.75
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
-GeoModelSvc.Til...   INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning negative ITC with translation -3405
-GeoModelSvc.Til...   INFO  Positioning negative Gap with translation -3552
-GeoModelSvc.Til...   INFO  Positioning negative Crack with translation -3536
-GeoModelSvc.Til...   INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
-TileDetDescrMan...   INFO Entering create_elements()
-GeoModelSvc          INFO GeoModelSvc.TileDetectorTool	 SZ= 4524Kb 	 Time = 0.2S
-ClassIDSvc           INFO  getRegistryEntries: read 66 CLIDRegistry entries for module ALL
-AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 6536 CLIDRegistry entries for module ALL
-CondInputLoader      INFO Initializing CondInputLoader...
-CondInputLoader      INFO Adding base classes:
+CoreDumpSvc                                          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
+ClassIDSvc                                           INFO  getRegistryEntries: read 18788 CLIDRegistry entries for module ALL
+TagInfoMgr                                           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
+IOVDbSvc                                             INFO Only 5 POOL conditions files will be open at once
+IOVDbSvc                                             INFO Cache alignment will be done in 3 slices
+IOVDbSvc                                             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
+IOVDbSvc                                             INFO Initialised with 2 connections and 3 folders
+IOVDbSvc                                             INFO Service IOVDbSvc initialised successfully
+IOVDbSvc                                             INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+MetaDataSvc                                          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
+PoolSvc                                              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
+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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
+DBReplicaSvc                                         INFO Total of 10 servers found for host pcaz001.dyndns.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                                              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
+DbSession                                            INFO     Open     DbSession    
+Domain[ROOT_All]                                     INFO >   Access   DbDomain     READ      [ROOT_All] 
+MetaDataSvc                                          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
+OutputStreamSequencerSvc                             INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+ClassIDSvc                                           INFO  getRegistryEntries: read 1178 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVSvc                                               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool                                    INFO IOVRanges will be checked at every Event
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Align
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/LArCellPositionShift
+ClassIDSvc                                           INFO  getRegistryEntries: read 273 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 20 CLIDRegistry entries for module ALL
+DetDescrCnvSvc                                       INFO  initializing 
+DetDescrCnvSvc                                       INFO Found DetectorStore service
+DetDescrCnvSvc                                       INFO  filling proxies for detector managers 
+DetDescrCnvSvc                                       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMaterials with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMaterials with default tag
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileDetectorTool::create()
+TileDddbManager                                      INFO m_tag = ATLAS-R2-2016-01-00-01
+TileDddbManager                                      INFO n_tiglob = 5
+TileDddbManager                                      INFO n_timod = 320
+TileDddbManager                                      INFO n_cuts = 9
+TileDddbManager                                      INFO n_saddle = 1
+TileDddbManager                                      INFO n_tilb = 21
+TileDddbManager                                      INFO n_tileSwitches = 1
+EventPersistencySvc                                  INFO Added successfully Conversion service:McCnvSvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:DetDescrCnvSvc
+ClassIDSvc                                           INFO  getRegistryEntries: read 2522 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TileID helper object in the detector store
+IdDictDetDescrCnv                                    INFO in initialize
+IdDictDetDescrCnv                                    INFO in createObj: creating a IdDictManager object in the detector store
+IdDictDetDescrCnv                                    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
+IdDictDetDescrCnv                                    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
+IdDictDetDescrCnv                                    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Found id dicts:
+IdDictDetDescrCnv                                    INFO Using dictionary tag: null
+IdDictDetDescrCnv                                    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+TileNeighbour                                        INFO Reading file  /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileNeighbour_reduced.txt
+TileHWIDDetDescrCnv                                  INFO in createObj: creating a TileHWID helper object in the detector store
+TileHWID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+ClassIDSvc                                           INFO  getRegistryEntries: read 219 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal2DNeighbors-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsNext-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsPrev-April2011.txt
+CaloIDHelper_IDDetDescrCnv                           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.
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+GeoModelSvc.TileDetectorTool                         INFO  U-shape parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Glue parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Cs Tube parameter from database is: 0
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileAtlasFactory::create()
+GeoModelSvc.TileDetectorTool                         INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthPos 430.5
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthNeg 420.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning barrel with translation 0
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive barrel finger with translation 3035.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative barrel finger with translation -3030.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel with translation 4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ITC with translation 3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Gap with translation 3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Crack with translation 3536
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel with translation ztrans -4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ITC with translation -3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Gap with translation -3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Crack with translation -3536
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
+TileDetDescrManager                                  INFO Entering create_elements()
+GeoModelSvc                                          INFO GeoModelSvc.TileDetectorTool	 SZ= 16888Kb 	 Time = 0.46S
+LArElectrodeIDDetDescrCnv                            INFO in createObj: creating a LArElectrodeID helper object in the detector store
+LArElectrodeID                                       INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineIDDetDescrCnv                               INFO in createObj: creating a LArHVLineID helper object in the detector store
+LArHVLineID                                          INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineID                                          INFO  => initialize_from_dictionary(dict_mgr) =0
+LArHVLineID                                          INFO Register_dict_tag of LArHighVoltage is OK
+LArHVLineID                                          INFO setDictVersion of LArHighVoltage is OK
+LArHVLineID                                          INFO [initLevelsFromDict] m_dict OK ... 
+LArHVLineID                                          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
+LArHVLineID                                          INFO [init_hashes()] > Hvline_size= 5008
+GeoModelSvc.LArDetectorToolNV                        INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
+GeoModelSvc.LArDetectorToolNV                        INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
+GeoModelSvc.LArDetectorToolNV                        INFO LAr Geometry Options:
+GeoModelSvc.LArDetectorToolNV                        INFO   Sagging           = false
+GeoModelSvc.LArDetectorToolNV                        INFO   Barrel            = ON
+GeoModelSvc.LArDetectorToolNV                        INFO   Endcap            = ON
+BarrelConstruction                                   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
+BarrelConstruction                                   INFO   Makes detailed absorber sandwich  ? 1 1
+BarrelConstruction                                   INFO   Use sagging in geometry  ? 0
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::OuterWheel
+ClassIDSvc                                           INFO  getRegistryEntries: read 287 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TileTBID helper object in the detector store
+TileTBID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::OuterWheel
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+GeoModelSvc                                          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 21272Kb 	 Time = 0.69S
+ClassIDSvc                                           INFO  getRegistryEntries: read 67 CLIDRegistry entries for module ALL
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.TileDetectorTool
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.LArDetectorToolNV
+AthenaEventLoopMgr                                   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 4821 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO Initializing CondInputLoader...
+CondInputLoader                                      INFO Adding base classes:
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' )   ->
-CondInputLoader      INFO Will create WriteCondHandle dependencies for the following DataObjects:
+CondInputLoader                                      INFO Will create WriteCondHandle dependencies for the following DataObjects:
     +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' ) 
-ClassIDSvc           INFO  getRegistryEntries: read 3246 CLIDRegistry entries for module ALL
-PyComponentMgr       INFO Initializing PyComponentMgr...
-CreateDataAlg        INFO Initializing CreateDataAlg...
-CheckThinningAlg     INFO Initializing CheckThinningAlg...
-EventSelector        INFO  Enter McEventSelector Initialization 
-AthenaEventLoopMgr   INFO Setup EventSelector service EventSelector
-ApplicationMgr       INFO Application Manager Initialized successfully
-ApplicationMgr    SUCCESS ****************************** Algorithm Sequence ****************************
-ApplicationMgr    SUCCESS AthSequencer/AthMasterSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthAlgEvtSeq
-ApplicationMgr    SUCCESS           AthSequencer/AthBeginSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg1
-ApplicationMgr    SUCCESS           AthSequencer/AthAllAlgSeq
-ApplicationMgr    SUCCESS                AthSequencer/AthCondSeq
-ApplicationMgr    SUCCESS                     CondInputLoader/CondInputLoader
-ApplicationMgr    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
-ApplicationMgr    SUCCESS                AthSequencer/AthAlgSeq
-ApplicationMgr    SUCCESS                     PyAthena::Alg/CreateDataAlg
-ApplicationMgr    SUCCESS                     CaloThinCellsByClusterAlg/thinAlg
-ApplicationMgr    SUCCESS                     PyAthena::Alg/CheckThinningAlg
-ApplicationMgr    SUCCESS           AthSequencer/AthEndSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg2
-ApplicationMgr    SUCCESS      AthSequencer/AthOutSeq
-ApplicationMgr    SUCCESS ******************************************************************************
-ClassIDSvc           INFO  getRegistryEntries: read 104 CLIDRegistry entries for module ALL
-CondInputLoader      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
-ApplicationMgr       INFO Application Manager Started successfully
-AthenaEventLoopMgr   INFO   ===>>>  start of run 284500    <<<===
-EventPersistenc...   INFO Added successfully Conversion service:TagInfoMgr
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-EventPersistenc...   INFO Added successfully Conversion service:AthenaPoolCnvSvc
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root File version:52200
-CaloMgrDetDescrCnv   INFO in createObj: creating a Calo Detector Manager object in the detector store
-CaloIdMgrDetDes...   INFO in createObj: creating a CaloDescrManager object in the detector store
-ClassIDSvc           INFO  getRegistryEntries: read 193 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloDM_ID helper object in the detector store
-CaloDM_ID            INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
-CaloLVL1_ID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a TTOnlineID helper object in the detector store
-TTOnlineID           INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/TileSuperCellNeighbour.txt
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIdMgrDetDes...   INFO  Finished 
-CaloIdMgrDetDes...   INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
-LArOnlineIDDetD...   INFO in createObj: creating a LArOnlineID helper object in the detector store
-LArOnlineID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArOnOffMappingAlg   INFO Done reading online/offline identifier mapping
-LArOnOffMappingAlg   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
-LArOnOffMappingAlg   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
+ClassIDSvc                                           INFO  getRegistryEntries: read 3730 CLIDRegistry entries for module ALL
+PyComponentMgr                                       INFO Initializing PyComponentMgr...
+CreateDataAlg                                        INFO Initializing CreateDataAlg...
+CheckThinningAlg                                     INFO Initializing CheckThinningAlg...
+EventSelector                                        INFO  Enter McEventSelector Initialization 
+AthenaEventLoopMgr                                   INFO Setup EventSelector service EventSelector
+ApplicationMgr                                       INFO Application Manager Initialized successfully
+ApplicationMgr                                    SUCCESS ****************************** Algorithm Sequence ****************************
+ApplicationMgr                                    SUCCESS AthSequencer/AthMasterSeq
+ApplicationMgr                                    SUCCESS      AthSequencer/AthAlgEvtSeq
+ApplicationMgr                                    SUCCESS           AthSequencer/AthBeginSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg1
+ApplicationMgr                                    SUCCESS           AthSequencer/AthAllAlgSeq
+ApplicationMgr                                    SUCCESS                AthSequencer/AthCondSeq
+ApplicationMgr                                    SUCCESS                     CondInputLoader/CondInputLoader
+ApplicationMgr                                    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
+ApplicationMgr                                    SUCCESS                AthSequencer/AthAlgSeq
+ApplicationMgr                                    SUCCESS                     PyAthena::Alg/CreateDataAlg
+ApplicationMgr                                    SUCCESS                     CaloThinCellsByClusterAlg/thinAlg
+ApplicationMgr                                    SUCCESS                     PyAthena::Alg/CheckThinningAlg
+ApplicationMgr                                    SUCCESS           AthSequencer/AthEndSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg2
+ApplicationMgr                                    SUCCESS      AthSequencer/AthOutSeq
+ApplicationMgr                                    SUCCESS ******************************************************************************
+ClassIDSvc                                           INFO  getRegistryEntries: read 105 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
+ApplicationMgr                                       INFO Application Manager Started successfully
+AthenaEventLoopMgr                                   INFO   ===>>>  start of run 284500    <<<===
+EventPersistencySvc                                  INFO Added successfully Conversion service:TagInfoMgr
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Opened read transaction for POOL PersistencySvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:AthenaPoolCnvSvc
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root File version:52200
+CaloMgrDetDescrCnv                                   INFO in createObj: creating a Calo Detector Manager object in the detector store
+CaloIdMgrDetDescrCnv                                 INFO in createObj: creating a CaloDescrManager object in the detector store
+ClassIDSvc                                           INFO  getRegistryEntries: read 196 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloDM_ID helper object in the detector store
+CaloDM_ID                                            INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
+CaloLVL1_ID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TTOnlineID helper object in the detector store
+TTOnlineID                                           INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsPrevNew-April2014.txt
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileSuperCellNeighbour.txt
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIdMgrDetDescrCnv                                 INFO  Finished 
+CaloIdMgrDetDescrCnv                                 INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
+LArOnlineIDDetDescrCnv                               INFO in createObj: creating a LArOnlineID helper object in the detector store
+LArOnlineID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArOnOffMappingAlg                                   INFO Done reading online/offline identifier mapping
+LArOnOffMappingAlg                                   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
+LArOnOffMappingAlg                                   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
 Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
 Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_ostream<char,char_traits<char> >!
 Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
 Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_stringbuf<char,char_traits<char>,allocator<char> >!
 Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
 Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent GaudiPython::CallbackStreamBuf!
-AthDictLoaderSvc     INFO in initialize...
-AthDictLoaderSvc     INFO acquired Dso-registry
-ClassIDSvc           INFO  getRegistryEntries: read 231 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 161 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 224 CLIDRegistry entries for module ALL
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
-/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 >   Deaccess DbDomain     READ      [ROOT_All] 
-ApplicationMgr       INFO Application Manager Stopped successfully
-IncidentProcAlg1     INFO Finalize
-CondInputLoader      INFO Finalizing CondInputLoader...
-CreateDataAlg        INFO Finalizing CreateDataAlg...
-CheckThinningAlg     INFO Finalizing CheckThinningAlg...
-IncidentProcAlg2     INFO Finalize
-AthDictLoaderSvc     INFO in finalize...
-EventSelector        INFO finalize
-PyComponentMgr       INFO Finalizing PyComponentMgr...
-ToolSvc              INFO Removing all tools created by ToolSvc
-IOVDbFolder          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     1.73 ))s
-IOVDbFolder          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     1.46 ))s
-IOVDbFolder          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     1.11 ))s
-IOVDbSvc             INFO  bytes in ((      4.30 ))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: 3 ReadTime: ((     4.30 ))s
-IdDictDetDescrCnv    INFO in finalize
-*****Chrono*****     INFO ****************************************************************************************************
-*****Chrono*****     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
-*****Chrono*****     INFO ****************************************************************************************************
-cObjR_ALL            INFO Time User   : Tot=  310 [ms] Ave/Min/Max=  155(+-  145)/   10/  300 [ms] #=  2
-cObj_ALL             INFO Time User   : Tot=  340 [ms] Ave/Min/Max=  113(+-  146)/    0/  320 [ms] #=  3
-ChronoStatSvc        INFO Time User   : Tot= 42.9  [s]                                             #=  1
-*****Chrono*****     INFO ****************************************************************************************************
-ChronoStatSvc.f...   INFO  Service finalized successfully 
-ApplicationMgr       INFO Application Manager Finalized successfully
-ApplicationMgr       INFO Application Manager Terminated successfully
+AthDictLoaderSvc                                     INFO in initialize...
+AthDictLoaderSvc                                     INFO acquired Dso-registry
+ClassIDSvc                                           INFO  getRegistryEntries: read 182 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 142 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 43 CLIDRegistry entries for module ALL
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
+Domain[ROOT_All]                                     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
+ApplicationMgr                                       INFO Application Manager Stopped successfully
+IncidentProcAlg1                                     INFO Finalize
+CondInputLoader                                      INFO Finalizing CondInputLoader...
+CreateDataAlg                                        INFO Finalizing CreateDataAlg...
+CheckThinningAlg                                     INFO Finalizing CheckThinningAlg...
+IncidentProcAlg2                                     INFO Finalize
+AthDictLoaderSvc                                     INFO in finalize...
+EventSelector                                        INFO finalize
+PyComponentMgr                                       INFO Finalizing PyComponentMgr...
+IdDictDetDescrCnv                                    INFO in finalize
+IOVDbFolder                                          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     0.01 ))s
+IOVDbSvc                                             INFO  bytes in ((      0.07 ))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: 3 ReadTime: ((     0.07 ))s
+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=  280 [ms] Ave/Min/Max=     140(+-     140)/       0/     280 [ms] #=  2
+cObj_ALL                                             INFO Time User   : Tot=  310 [ms] Ave/Min/Max=     103(+-     139)/       0/     300 [ms] #=  3
+ChronoStatSvc                                        INFO Time User   : Tot= 21.4  [s]  #=  1
+*****Chrono*****                                     INFO ****************************************************************************************************
+ChronoStatSvc.finalize()                             INFO  Service finalized successfully 
+ApplicationMgr                                       INFO Application Manager Finalized successfully
+ApplicationMgr                                       INFO Application Manager Terminated successfully
diff --git a/Calorimeter/CaloRec/share/CaloThinCellsBySamplingAlg_test.ref b/Calorimeter/CaloRec/share/CaloThinCellsBySamplingAlg_test.ref
index 09dd51f6a0d96dd4a233ecea2dac3a467144c0f8..f1ed180710646303942050364eb2542b8b603300 100644
--- a/Calorimeter/CaloRec/share/CaloThinCellsBySamplingAlg_test.ref
+++ b/Calorimeter/CaloRec/share/CaloThinCellsBySamplingAlg_test.ref
@@ -1,339 +1,341 @@
-Py:ConfigurableDb    INFO Read module info for 5545 configurables from 11 genConfDb files
-Py:ConfigurableDb    INFO No duplicates have been found: that's good !
 Py:AutoConfigFlags    INFO Obtaining metadata of auto-configuration by peeking into /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root
 Py:MetaReader        INFO Current mode used: peeker
 Py:MetaReader        INFO Current filenames: ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root']
 Py:MetaReader        INFO MetaReader is called with the parameter "unique_tag_info_values" set to True. This is a workaround to remove all duplicate values from "/TagInfo" key
-Py:Athena            INFO using release [WorkDir-22.0.12] [x86_64-centos7-gcc8-opt] [atlas-master-acas-c/9345ae20609] -- built on [2020-03-29T1758]
+Py:Athena            INFO using release [WorkDir-22.0.22] [x86_64-centos7-gcc8-opt] [MainServiceMsgFormat/f665cad] -- built on [2020-12-03T1657]
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v33r1)
-                                          running on spar0103.usatlas.bnl.gov on Sun Mar 29 18:32:41 2020
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on pcaz001 on Thu Dec  3 17:22:51 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-CoreDumpSvc          INFO install f-a-t-a-l handler... (flag = 438)
-CoreDumpSvc          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
-ClassIDSvc           INFO  getRegistryEntries: read 16636 CLIDRegistry entries for module ALL
-PoolSvc              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
-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-ai.cern.ch:8000/atlr)(serverurl=http://frontier-atlas.lcg.triumf.ca:3128/ATLAS_frontier)(serverurl=http://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
-DBReplicaSvc         INFO Total of 1 servers found for host spar0103.usatlas.bnl.gov [ATLF ]
-PoolSvc              INFO Successfully setup replica sorting algorithm
-PoolSvc              INFO Setting up APR FileCatalog and Streams
-PoolSvc              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
-IOVDbSvc             INFO Opened read transaction for POOL PersistencySvc
-IOVDbSvc             INFO Only 5 POOL conditions files will be open at once
-IOVDbSvc             INFO Cache alignment will be done in 3 slices
-IOVDbSvc             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
-IOVDbSvc             INFO Initialised with 2 connections and 3 folders
-IOVDbSvc             INFO Service IOVDbSvc initialised successfully
-MetaDataSvc          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
-AthenaPoolCnvSvc     INFO Initializing AthenaPoolCnvSvc - package version AthenaPoolCnvSvc-00-00-00
-MetaDataSvc          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
-ClassIDSvc           INFO  getRegistryEntries: read 1419 CLIDRegistry entries for module ALL
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
-IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-IOVDbSvc             INFO Added taginfo remove for /LAR/Align
-IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
-IOVDbSvc             INFO Added taginfo remove for /LAR/LArCellPositionShift
-ClassIDSvc           INFO  getRegistryEntries: read 53 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 18 CLIDRegistry entries for module ALL
-GeoModelSvc          INFO Explicitly initializing DetDescrCnvSvc
-DetDescrCnvSvc       INFO  initializing 
-DetDescrCnvSvc       INFO Found DetectorStore service
-DetDescrCnvSvc       INFO  filling proxies for detector managers 
-DetDescrCnvSvc       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
-GeoModelSvc::RD...WARNING  Getting PixTBMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting PixTBMaterials with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMaterials with default tag
-EventPersistenc...   INFO Added successfully Conversion service:McCnvSvc
-EventPersistenc...   INFO Added successfully Conversion service:DetDescrCnvSvc
-LArElectrodeIDD...   INFO in createObj: creating a LArElectrodeID helper object in the detector store
-IdDictDetDescrCnv    INFO in initialize
-IdDictDetDescrCnv    INFO in createObj: creating a IdDictManager object in the detector store
-IdDictDetDescrCnv    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
-IdDictDetDescrCnv    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
-IdDictDetDescrCnv    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Found id dicts:
-IdDictDetDescrCnv    INFO Using dictionary tag: null
-IdDictDetDescrCnv    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
-LArElectrodeID       INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineIDDetD...   INFO in createObj: creating a LArHVLineID helper object in the detector store
-LArHVLineID          INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineID          INFO  => initialize_from_dictionary(dict_mgr) =0
-LArHVLineID          INFO Register_dict_tag of LArHighVoltage is OK
-LArHVLineID          INFO setDictVersion of LArHighVoltage is OK
-LArHVLineID          INFO [initLevelsFromDict] m_dict OK ... 
-LArHVLineID          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
-LArHVLineID          INFO [init_hashes()] > Hvline_size= 5008
-GeoModelSvc.LAr...   INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
-GeoModelSvc.LAr...   INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
-GeoModelSvc.LAr...   INFO LAr Geometry Options:
-GeoModelSvc.LAr...   INFO   Sagging           = false
-GeoModelSvc.LAr...   INFO   Barrel            = ON
-GeoModelSvc.LAr...   INFO   Endcap            = ON
-BarrelConstruction   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
-BarrelConstruction   INFO   Makes detailed absorber sandwich  ? 1 1
-BarrelConstruction   INFO   Use sagging in geometry  ? 0
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Pos::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Pos::OuterWheel
-ClassIDSvc           INFO  getRegistryEntries: read 2899 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a TileTBID helper object in the detector store
-TileTBID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-EndcapDMConstru...   INFO Start building EC electronics geometry
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Neg::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Neg::OuterWheel
-EndcapDMConstru...   INFO Start building EC electronics geometry
-GeoModelSvc          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 25968Kb 	 Time = 0.66S
-GeoModelSvc.Til...   INFO  Entering TileDetectorTool::create()
-TileDddbManager      INFO m_tag = ATLAS-R2-2016-01-00-01
-TileDddbManager      INFO n_tiglob = 5
-TileDddbManager      INFO n_timod = 320
-TileDddbManager      INFO n_cuts = 9
-TileDddbManager      INFO n_saddle = 1
-TileDddbManager      INFO n_tilb = 21
-TileDddbManager      INFO n_tileSwitches = 1
-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/TileNeighbour_reduced.txt
-TileHWIDDetDesc...   INFO in createObj: creating a TileHWID helper object in the detector store
-TileHWID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-ClassIDSvc           INFO  getRegistryEntries: read 55 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_ID helper object in the detector store
-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCal2DNeighbors-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsNext-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-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.
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-GeoModelSvc.Til...   INFO  U-shape parameter from database is: 1
-GeoModelSvc.Til...   INFO  Glue parameter from database is: 1
-GeoModelSvc.Til...   INFO  Cs Tube parameter from database is: 0
-GeoModelSvc.Til...   INFO  Entering TileAtlasFactory::create()
-GeoModelSvc.Til...   INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
-GeoModelSvc.Til...   INFO  => New BFingerLengthPos 430.5
-GeoModelSvc.Til...   INFO  => New BFingerLengthNeg 420.5
-GeoModelSvc.Til...   INFO  Positioning barrel with translation 0
-GeoModelSvc.Til...   INFO  Positioning positive barrel finger with translation 3035.25
-GeoModelSvc.Til...   INFO  Positioning negative barrel finger with translation -3030.25
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel with translation 4854.75
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
-GeoModelSvc.Til...   INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning positive ITC with translation 3405
-GeoModelSvc.Til...   INFO  Positioning positive Gap with translation 3552
-GeoModelSvc.Til...   INFO  Positioning positive Crack with translation 3536
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel with translation ztrans -4854.75
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
-GeoModelSvc.Til...   INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning negative ITC with translation -3405
-GeoModelSvc.Til...   INFO  Positioning negative Gap with translation -3552
-GeoModelSvc.Til...   INFO  Positioning negative Crack with translation -3536
-GeoModelSvc.Til...   INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
-TileDetDescrMan...   INFO Entering create_elements()
-GeoModelSvc          INFO GeoModelSvc.TileDetectorTool	 SZ= 4524Kb 	 Time = 0.18S
-ClassIDSvc           INFO  getRegistryEntries: read 66 CLIDRegistry entries for module ALL
-AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 6536 CLIDRegistry entries for module ALL
-CondInputLoader      INFO Initializing CondInputLoader...
-CondInputLoader      INFO Adding base classes:
+CoreDumpSvc                                          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
+ClassIDSvc                                           INFO  getRegistryEntries: read 18422 CLIDRegistry entries for module ALL
+TagInfoMgr                                           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
+IOVDbSvc                                             INFO Only 5 POOL conditions files will be open at once
+IOVDbSvc                                             INFO Cache alignment will be done in 3 slices
+IOVDbSvc                                             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
+IOVDbSvc                                             INFO Initialised with 2 connections and 3 folders
+IOVDbSvc                                             INFO Service IOVDbSvc initialised successfully
+IOVDbSvc                                             INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+MetaDataSvc                                          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
+PoolSvc                                              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
+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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
+DBReplicaSvc                                         INFO Total of 10 servers found for host pcaz001.dyndns.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                                              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
+DbSession                                            INFO     Open     DbSession    
+Domain[ROOT_All]                                     INFO >   Access   DbDomain     READ      [ROOT_All] 
+MetaDataSvc                                          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
+OutputStreamSequencerSvc                             INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+ClassIDSvc                                           INFO  getRegistryEntries: read 1178 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVSvc                                               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool                                    INFO IOVRanges will be checked at every Event
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Align
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/LArCellPositionShift
+ClassIDSvc                                           INFO  getRegistryEntries: read 273 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 20 CLIDRegistry entries for module ALL
+DetDescrCnvSvc                                       INFO  initializing 
+DetDescrCnvSvc                                       INFO Found DetectorStore service
+DetDescrCnvSvc                                       INFO  filling proxies for detector managers 
+DetDescrCnvSvc                                       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMaterials with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMaterials with default tag
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileDetectorTool::create()
+TileDddbManager                                      INFO m_tag = ATLAS-R2-2016-01-00-01
+TileDddbManager                                      INFO n_tiglob = 5
+TileDddbManager                                      INFO n_timod = 320
+TileDddbManager                                      INFO n_cuts = 9
+TileDddbManager                                      INFO n_saddle = 1
+TileDddbManager                                      INFO n_tilb = 21
+TileDddbManager                                      INFO n_tileSwitches = 1
+EventPersistencySvc                                  INFO Added successfully Conversion service:McCnvSvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:DetDescrCnvSvc
+ClassIDSvc                                           INFO  getRegistryEntries: read 2522 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TileID helper object in the detector store
+IdDictDetDescrCnv                                    INFO in initialize
+IdDictDetDescrCnv                                    INFO in createObj: creating a IdDictManager object in the detector store
+IdDictDetDescrCnv                                    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
+IdDictDetDescrCnv                                    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
+IdDictDetDescrCnv                                    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Found id dicts:
+IdDictDetDescrCnv                                    INFO Using dictionary tag: null
+IdDictDetDescrCnv                                    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+TileNeighbour                                        INFO Reading file  /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileNeighbour_reduced.txt
+TileHWIDDetDescrCnv                                  INFO in createObj: creating a TileHWID helper object in the detector store
+TileHWID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+ClassIDSvc                                           INFO  getRegistryEntries: read 219 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal2DNeighbors-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsNext-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsPrev-April2011.txt
+CaloIDHelper_IDDetDescrCnv                           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.
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+GeoModelSvc.TileDetectorTool                         INFO  U-shape parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Glue parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Cs Tube parameter from database is: 0
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileAtlasFactory::create()
+GeoModelSvc.TileDetectorTool                         INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthPos 430.5
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthNeg 420.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning barrel with translation 0
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive barrel finger with translation 3035.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative barrel finger with translation -3030.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel with translation 4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ITC with translation 3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Gap with translation 3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Crack with translation 3536
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel with translation ztrans -4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ITC with translation -3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Gap with translation -3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Crack with translation -3536
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
+TileDetDescrManager                                  INFO Entering create_elements()
+GeoModelSvc                                          INFO GeoModelSvc.TileDetectorTool	 SZ= 16972Kb 	 Time = 0.23S
+LArElectrodeIDDetDescrCnv                            INFO in createObj: creating a LArElectrodeID helper object in the detector store
+LArElectrodeID                                       INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineIDDetDescrCnv                               INFO in createObj: creating a LArHVLineID helper object in the detector store
+LArHVLineID                                          INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineID                                          INFO  => initialize_from_dictionary(dict_mgr) =0
+LArHVLineID                                          INFO Register_dict_tag of LArHighVoltage is OK
+LArHVLineID                                          INFO setDictVersion of LArHighVoltage is OK
+LArHVLineID                                          INFO [initLevelsFromDict] m_dict OK ... 
+LArHVLineID                                          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
+LArHVLineID                                          INFO [init_hashes()] > Hvline_size= 5008
+GeoModelSvc.LArDetectorToolNV                        INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
+GeoModelSvc.LArDetectorToolNV                        INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
+GeoModelSvc.LArDetectorToolNV                        INFO LAr Geometry Options:
+GeoModelSvc.LArDetectorToolNV                        INFO   Sagging           = false
+GeoModelSvc.LArDetectorToolNV                        INFO   Barrel            = ON
+GeoModelSvc.LArDetectorToolNV                        INFO   Endcap            = ON
+BarrelConstruction                                   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
+BarrelConstruction                                   INFO   Makes detailed absorber sandwich  ? 1 1
+BarrelConstruction                                   INFO   Use sagging in geometry  ? 0
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::OuterWheel
+ClassIDSvc                                           INFO  getRegistryEntries: read 287 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TileTBID helper object in the detector store
+TileTBID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::OuterWheel
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+GeoModelSvc                                          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 21272Kb 	 Time = 0.64S
+ClassIDSvc                                           INFO  getRegistryEntries: read 67 CLIDRegistry entries for module ALL
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.TileDetectorTool
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.LArDetectorToolNV
+AthenaEventLoopMgr                                   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 5023 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO Initializing CondInputLoader...
+CondInputLoader                                      INFO Adding base classes:
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' )   ->
-CondInputLoader      INFO Will create WriteCondHandle dependencies for the following DataObjects:
+CondInputLoader                                      INFO Will create WriteCondHandle dependencies for the following DataObjects:
     +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' ) 
-ClassIDSvc           INFO  getRegistryEntries: read 3246 CLIDRegistry entries for module ALL
-PyComponentMgr       INFO Initializing PyComponentMgr...
-CreateDataAlg        INFO Initializing CreateDataAlg...
-CheckThinningAlg     INFO Initializing CheckThinningAlg...
-EventSelector        INFO  Enter McEventSelector Initialization 
-AthenaEventLoopMgr   INFO Setup EventSelector service EventSelector
-ApplicationMgr       INFO Application Manager Initialized successfully
-ApplicationMgr    SUCCESS ****************************** Algorithm Sequence ****************************
-ApplicationMgr    SUCCESS AthSequencer/AthMasterSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthAlgEvtSeq
-ApplicationMgr    SUCCESS           AthSequencer/AthBeginSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg1
-ApplicationMgr    SUCCESS           AthSequencer/AthAllAlgSeq
-ApplicationMgr    SUCCESS                AthSequencer/AthCondSeq
-ApplicationMgr    SUCCESS                     CondInputLoader/CondInputLoader
-ApplicationMgr    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
-ApplicationMgr    SUCCESS                AthSequencer/AthAlgSeq
-ApplicationMgr    SUCCESS                     PyAthena::Alg/CreateDataAlg
-ApplicationMgr    SUCCESS                     CaloThinCellsBySamplingAlg/thinAlg
-ApplicationMgr    SUCCESS                     PyAthena::Alg/CheckThinningAlg
-ApplicationMgr    SUCCESS           AthSequencer/AthEndSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg2
-ApplicationMgr    SUCCESS      AthSequencer/AthOutSeq
-ApplicationMgr    SUCCESS ******************************************************************************
-ClassIDSvc           INFO  getRegistryEntries: read 104 CLIDRegistry entries for module ALL
-CondInputLoader      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
-ApplicationMgr       INFO Application Manager Started successfully
-AthenaEventLoopMgr   INFO   ===>>>  start of run 284500    <<<===
-EventPersistenc...   INFO Added successfully Conversion service:TagInfoMgr
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-EventPersistenc...   INFO Added successfully Conversion service:AthenaPoolCnvSvc
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root File version:52200
-CaloMgrDetDescrCnv   INFO in createObj: creating a Calo Detector Manager object in the detector store
-CaloIdMgrDetDes...   INFO in createObj: creating a CaloDescrManager object in the detector store
-ClassIDSvc           INFO  getRegistryEntries: read 193 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloDM_ID helper object in the detector store
-CaloDM_ID            INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
-CaloLVL1_ID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a TTOnlineID helper object in the detector store
-TTOnlineID           INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-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_Athena_x86_64-centos7-gcc8-opt/2020-03-26T2139/Athena/22.0.12/InstallArea/x86_64-centos7-gcc8-opt/share/TileSuperCellNeighbour.txt
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIdMgrDetDes...   INFO  Finished 
-CaloIdMgrDetDes...   INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
-LArOnlineIDDetD...   INFO in createObj: creating a LArOnlineID helper object in the detector store
-LArOnlineID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArOnOffMappingAlg   INFO Done reading online/offline identifier mapping
-LArOnOffMappingAlg   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
-LArOnOffMappingAlg   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
+ClassIDSvc                                           INFO  getRegistryEntries: read 3730 CLIDRegistry entries for module ALL
+PyComponentMgr                                       INFO Initializing PyComponentMgr...
+CreateDataAlg                                        INFO Initializing CreateDataAlg...
+CheckThinningAlg                                     INFO Initializing CheckThinningAlg...
+EventSelector                                        INFO  Enter McEventSelector Initialization 
+AthenaEventLoopMgr                                   INFO Setup EventSelector service EventSelector
+ApplicationMgr                                       INFO Application Manager Initialized successfully
+ApplicationMgr                                    SUCCESS ****************************** Algorithm Sequence ****************************
+ApplicationMgr                                    SUCCESS AthSequencer/AthMasterSeq
+ApplicationMgr                                    SUCCESS      AthSequencer/AthAlgEvtSeq
+ApplicationMgr                                    SUCCESS           AthSequencer/AthBeginSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg1
+ApplicationMgr                                    SUCCESS           AthSequencer/AthAllAlgSeq
+ApplicationMgr                                    SUCCESS                AthSequencer/AthCondSeq
+ApplicationMgr                                    SUCCESS                     CondInputLoader/CondInputLoader
+ApplicationMgr                                    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
+ApplicationMgr                                    SUCCESS                AthSequencer/AthAlgSeq
+ApplicationMgr                                    SUCCESS                     PyAthena::Alg/CreateDataAlg
+ApplicationMgr                                    SUCCESS                     CaloThinCellsBySamplingAlg/thinAlg
+ApplicationMgr                                    SUCCESS                     PyAthena::Alg/CheckThinningAlg
+ApplicationMgr                                    SUCCESS           AthSequencer/AthEndSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg2
+ApplicationMgr                                    SUCCESS      AthSequencer/AthOutSeq
+ApplicationMgr                                    SUCCESS ******************************************************************************
+ClassIDSvc                                           INFO  getRegistryEntries: read 108 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
+ApplicationMgr                                       INFO Application Manager Started successfully
+AthenaEventLoopMgr                                   INFO   ===>>>  start of run 284500    <<<===
+EventPersistencySvc                                  INFO Added successfully Conversion service:TagInfoMgr
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Opened read transaction for POOL PersistencySvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:AthenaPoolCnvSvc
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root File version:52200
+CaloMgrDetDescrCnv                                   INFO in createObj: creating a Calo Detector Manager object in the detector store
+CaloIdMgrDetDescrCnv                                 INFO in createObj: creating a CaloDescrManager object in the detector store
+ClassIDSvc                                           INFO  getRegistryEntries: read 196 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloDM_ID helper object in the detector store
+CaloDM_ID                                            INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
+CaloLVL1_ID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TTOnlineID helper object in the detector store
+TTOnlineID                                           INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsPrevNew-April2014.txt
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileSuperCellNeighbour.txt
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIdMgrDetDescrCnv                                 INFO  Finished 
+CaloIdMgrDetDescrCnv                                 INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
+LArOnlineIDDetDescrCnv                               INFO in createObj: creating a LArOnlineID helper object in the detector store
+LArOnlineID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArOnOffMappingAlg                                   INFO Done reading online/offline identifier mapping
+LArOnOffMappingAlg                                   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
+LArOnOffMappingAlg                                   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
 Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
 Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_ostream<char,char_traits<char> >!
 Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
 Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_stringbuf<char,char_traits<char>,allocator<char> >!
 Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
 Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent GaudiPython::CallbackStreamBuf!
-AthDictLoaderSvc     INFO in initialize...
-AthDictLoaderSvc     INFO acquired Dso-registry
-ClassIDSvc           INFO  getRegistryEntries: read 231 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 161 CLIDRegistry entries for module ALL
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
-/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 >   Deaccess DbDomain     READ      [ROOT_All] 
-ApplicationMgr       INFO Application Manager Stopped successfully
-IncidentProcAlg1     INFO Finalize
-CondInputLoader      INFO Finalizing CondInputLoader...
-CreateDataAlg        INFO Finalizing CreateDataAlg...
-CheckThinningAlg     INFO Finalizing CheckThinningAlg...
-IncidentProcAlg2     INFO Finalize
-AthDictLoaderSvc     INFO in finalize...
-EventSelector        INFO finalize
-PyComponentMgr       INFO Finalizing PyComponentMgr...
-ToolSvc              INFO Removing all tools created by ToolSvc
-IOVDbFolder          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     1.81 ))s
-IOVDbFolder          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     1.32 ))s
-IOVDbFolder          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     1.11 ))s
-IOVDbSvc             INFO  bytes in ((      4.24 ))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: 3 ReadTime: ((     4.24 ))s
-IdDictDetDescrCnv    INFO in finalize
-*****Chrono*****     INFO ****************************************************************************************************
-*****Chrono*****     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
-*****Chrono*****     INFO ****************************************************************************************************
-cObjR_ALL            INFO Time User   : Tot=  300 [ms] Ave/Min/Max=  150(+-  140)/   10/  290 [ms] #=  2
-cObj_ALL             INFO Time User   : Tot=  340 [ms] Ave/Min/Max=  113(+-  140)/    0/  310 [ms] #=  3
-ChronoStatSvc        INFO Time User   : Tot= 39.5  [s]                                             #=  1
-*****Chrono*****     INFO ****************************************************************************************************
-ChronoStatSvc.f...   INFO  Service finalized successfully 
-ApplicationMgr       INFO Application Manager Finalized successfully
-ApplicationMgr       INFO Application Manager Terminated successfully
+AthDictLoaderSvc                                     INFO in initialize...
+AthDictLoaderSvc                                     INFO acquired Dso-registry
+ClassIDSvc                                           INFO  getRegistryEntries: read 182 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 163 CLIDRegistry entries for module ALL
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
+Domain[ROOT_All]                                     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
+ApplicationMgr                                       INFO Application Manager Stopped successfully
+IncidentProcAlg1                                     INFO Finalize
+CondInputLoader                                      INFO Finalizing CondInputLoader...
+CreateDataAlg                                        INFO Finalizing CreateDataAlg...
+CheckThinningAlg                                     INFO Finalizing CheckThinningAlg...
+IncidentProcAlg2                                     INFO Finalize
+AthDictLoaderSvc                                     INFO in finalize...
+EventSelector                                        INFO finalize
+PyComponentMgr                                       INFO Finalizing PyComponentMgr...
+IdDictDetDescrCnv                                    INFO in finalize
+IOVDbFolder                                          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     0.02 ))s
+IOVDbSvc                                             INFO  bytes in ((      0.08 ))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: 3 ReadTime: ((     0.08 ))s
+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=  370 [ms] Ave/Min/Max=     185(+-     175)/      10/     360 [ms] #=  2
+cObj_ALL                                             INFO Time User   : Tot=  400 [ms] Ave/Min/Max=     133(+-     175)/       0/     380 [ms] #=  3
+ChronoStatSvc                                        INFO Time User   : Tot= 49.8  [s]  #=  1
+*****Chrono*****                                     INFO ****************************************************************************************************
+ChronoStatSvc.finalize()                             INFO  Service finalized successfully 
+ApplicationMgr                                       INFO Application Manager Finalized successfully
+ApplicationMgr                                       INFO Application Manager Terminated successfully
diff --git a/Calorimeter/CaloRec/share/ToolConstantsCondAlg_test.ref b/Calorimeter/CaloRec/share/ToolConstantsCondAlg_test.ref
index 48047219529956980b209341fd523ade5eebfb83..d5028726654fca79c30071cf5a3e0f308baba83a 100644
--- a/Calorimeter/CaloRec/share/ToolConstantsCondAlg_test.ref
+++ b/Calorimeter/CaloRec/share/ToolConstantsCondAlg_test.ref
@@ -4,92 +4,95 @@ Py:MetaReader        INFO Current filenames: ['/cvmfs/atlas-nightlies.cern.ch/re
 Py:MetaReader        INFO MetaReader is called with the parameter "unique_tag_info_values" set to True. This is a workaround to remove all duplicate values from "/TagInfo" key
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v34r0)
-                                          running on aibuild028.cern.ch on Tue Oct  6 19:13:20 2020
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on pcaz001 on Thu Dec  3 17:25:04 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-CoreDumpSvc          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
-AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 23732 CLIDRegistry entries for module ALL
-CondInputLoader      INFO Initializing CondInputLoader...
-IOVDbSvc             INFO Only 5 POOL conditions files will be open at once
-IOVDbSvc             INFO Cache alignment will be done in 3 slices
-IOVDbSvc             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
-IOVDbSvc             INFO Initialised with 2 connections and 1 folders
-IOVDbSvc             INFO Service IOVDbSvc initialised successfully
-MetaDataSvc          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
-PoolSvc              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
-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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-10-05T2101/Athena/22.0.19/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
-DBReplicaSvc         INFO Total of 10 servers found for host aibuild028.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              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
-MetaDataSvc          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
-OutputStreamSeq...   INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
-CondProxyProvider    INFO Initializing CondProxyProvider - package version EventSelectorAthenaPool-00-00-00
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] BC292F26-AE73-9041-BF5C-BCE6C5C651EC
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000079.gen.COND/cond09_mc.000079.gen.COND._0002.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000079.gen.COND/cond09_mc.000079.gen.COND._0002.pool.root File version:53413
-ClassIDSvc           INFO  getRegistryEntries: read 1569 CLIDRegistry entries for module ALL
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
-IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-IOVDbSvc             INFO Added taginfo remove for /LAR/CellCorrOfl/deadOTX
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] BC292F26-AE73-9041-BF5C-BCE6C5C651EC
-Domain[ROOT_All]     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
-EventPersistenc...   INFO Added successfully Conversion service:McCnvSvc
-EventPersistenc...   INFO Added successfully Conversion service:TagInfoMgr
-EventPersistenc...   INFO Added successfully Conversion service:AthenaPoolCnvSvc
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] BC292F26-AE73-9041-BF5C-BCE6C5C651EC
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000079.gen.COND/cond09_mc.000079.gen.COND._0002.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000079.gen.COND/cond09_mc.000079.gen.COND._0002.pool.root File version:53413
-ClassIDSvc           INFO  getRegistryEntries: read 112 CLIDRegistry entries for module ALL
-CondInputLoader      INFO Adding base classes:
+CoreDumpSvc                                          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
+AthenaEventLoopMgr                                   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 23790 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO Initializing CondInputLoader...
+IOVDbSvc                                             INFO Only 5 POOL conditions files will be open at once
+IOVDbSvc                                             INFO Cache alignment will be done in 3 slices
+IOVDbSvc                                             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
+IOVDbSvc                                             INFO Initialised with 2 connections and 1 folders
+IOVDbSvc                                             INFO Service IOVDbSvc initialised successfully
+IOVDbSvc                                             INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+TagInfoMgr                                           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
+MetaDataSvc                                          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
+PoolSvc                                              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
+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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
+DBReplicaSvc                                         INFO Total of 10 servers found for host pcaz001.dyndns.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                                              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
+DbSession                                            INFO     Open     DbSession    
+Domain[ROOT_All]                                     INFO >   Access   DbDomain     READ      [ROOT_All] 
+MetaDataSvc                                          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
+OutputStreamSequencerSvc                             INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+CondProxyProvider                                    INFO Initializing CondProxyProvider - package version EventSelectorAthenaPool-00-00-00
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] BC292F26-AE73-9041-BF5C-BCE6C5C651EC
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000079.gen.COND/cond09_mc.000079.gen.COND._0002.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000079.gen.COND/cond09_mc.000079.gen.COND._0002.pool.root File version:53413
+ClassIDSvc                                           INFO  getRegistryEntries: read 1566 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVSvc                                               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool                                    INFO IOVRanges will be checked at every Event
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/CellCorrOfl/deadOTX
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] BC292F26-AE73-9041-BF5C-BCE6C5C651EC
+Domain[ROOT_All]                                     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
+EventPersistencySvc                                  INFO Added successfully Conversion service:McCnvSvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:TagInfoMgr
+EventPersistencySvc                                  INFO Added successfully Conversion service:AthenaPoolCnvSvc
+DbSession                                            INFO     Open     DbSession    
+Domain[ROOT_All]                                     INFO >   Access   DbDomain     READ      [ROOT_All] 
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] BC292F26-AE73-9041-BF5C-BCE6C5C651EC
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000079.gen.COND/cond09_mc.000079.gen.COND._0002.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000079.gen.COND/cond09_mc.000079.gen.COND._0002.pool.root File version:53413
+ClassIDSvc                                           INFO  getRegistryEntries: read 112 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO Adding base classes:
   +  ( 'CondAttrListCollection' , 'ConditionStore+/LAR/CellCorrOfl/deadOTX' )   ->
-CondInputLoader      INFO Will create WriteCondHandle dependencies for the following DataObjects:
+CondInputLoader                                      INFO Will create WriteCondHandle dependencies for the following DataObjects:
     +  ( 'CondAttrListCollection' , 'ConditionStore+/LAR/CellCorrOfl/deadOTX' ) 
-EventSelector        INFO  Enter McEventSelector Initialization 
-AthenaEventLoopMgr   INFO Setup EventSelector service EventSelector
-ApplicationMgr       INFO Application Manager Initialized successfully
-ApplicationMgr    SUCCESS ****************************** Algorithm Sequence ****************************
-ApplicationMgr    SUCCESS AthSequencer/AthMasterSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthAlgEvtSeq
-ApplicationMgr    SUCCESS           AthSequencer/AthBeginSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg1
-ApplicationMgr    SUCCESS           AthSequencer/AthAllAlgSeq
-ApplicationMgr    SUCCESS                AthSequencer/AthCondSeq
-ApplicationMgr    SUCCESS                     CondInputLoader/CondInputLoader
-ApplicationMgr    SUCCESS                     ToolConstantsCondAlg/ToolConstantsCondAlg_deadOTXCorrCtes
-ApplicationMgr    SUCCESS                     ToolConstantsCondAlg/ToolConstantsCondAlg_CaloSwClusterCorrections.rfac-v5
-ApplicationMgr    SUCCESS                AthSequencer/AthAlgSeq
-ApplicationMgr    SUCCESS                     CaloClusterCorrDumper/dumper1
-ApplicationMgr    SUCCESS           AthSequencer/AthEndSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg2
-ApplicationMgr    SUCCESS      AthSequencer/AthOutSeq
-ApplicationMgr    SUCCESS ******************************************************************************
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/LAR/CellCorrOfl/deadOTX'
-ApplicationMgr       INFO Application Manager Started successfully
-AthenaEventLoopMgr   INFO   ===>>>  start of run 284500    <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARCellCorrOflDeadOTX-000-00 for folder /LAR/CellCorrOfl/deadOTX
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-IOVDbSvc             INFO Opened read transaction for POOL PersistencySvc
-dumper1              INFO dumper.energyCalibrationTypes = [0, 0, 0, -1]
+EventSelector                                        INFO  Enter McEventSelector Initialization 
+AthenaEventLoopMgr                                   INFO Setup EventSelector service EventSelector
+ApplicationMgr                                       INFO Application Manager Initialized successfully
+ApplicationMgr                                    SUCCESS ****************************** Algorithm Sequence ****************************
+ApplicationMgr                                    SUCCESS AthSequencer/AthMasterSeq
+ApplicationMgr                                    SUCCESS      AthSequencer/AthAlgEvtSeq
+ApplicationMgr                                    SUCCESS           AthSequencer/AthBeginSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg1
+ApplicationMgr                                    SUCCESS           AthSequencer/AthAllAlgSeq
+ApplicationMgr                                    SUCCESS                AthSequencer/AthCondSeq
+ApplicationMgr                                    SUCCESS                     CondInputLoader/CondInputLoader
+ApplicationMgr                                    SUCCESS                     ToolConstantsCondAlg/ToolConstantsCondAlg_deadOTXCorrCtes
+ApplicationMgr                                    SUCCESS                     ToolConstantsCondAlg/ToolConstantsCondAlg_CaloSwClusterCorrections.rfac-v5
+ApplicationMgr                                    SUCCESS                AthSequencer/AthAlgSeq
+ApplicationMgr                                    SUCCESS                     CaloClusterCorrDumper/dumper1
+ApplicationMgr                                    SUCCESS           AthSequencer/AthEndSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg2
+ApplicationMgr                                    SUCCESS      AthSequencer/AthOutSeq
+ApplicationMgr                                    SUCCESS ******************************************************************************
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/LAR/CellCorrOfl/deadOTX'
+ApplicationMgr                                       INFO Application Manager Started successfully
+AthenaEventLoopMgr                                   INFO   ===>>>  start of run 284500    <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARCellCorrOflDeadOTX-000-00 for folder /LAR/CellCorrOfl/deadOTX
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Opened read transaction for POOL PersistencySvc
+dumper1                                              INFO dumper.energyCalibrationTypes = [0, 0, 0, -1]
 dumper.energyCalibrations = [2, 0.9959, 0.07493, -0.1599, 2, 2, 0.9962, 0.04997, -0.1839, 2, 2, 0.9984, 0.0143, -0.9648, 2]
 dumper.etaCalibrationSizes = [14, 14, 13, 0]
 dumper.etaCalibrations = [1.024, 1.024, 1.023, 1.023, 1.025, 1.024, 1.023, 1.023, 1.024, 1.025, 1.024, 1.024, 1.024, 1.022, 1.022, 1.022, 1.022, 1.023, 1.023, 1.024, 1.023, 1.018, 1.022, 1.019, 1.024, 1.02, 1.017, 0.9819, 0.9922, 0.9909, 0.9935, 0.995, 0.9944, 0.9955, 0.9944, 0.9913, 0.9928, 0.9925, 0.9956, 0.9933, 0.9928]
@@ -97,7 +100,7 @@ dumper.isDummy = 0
 dumper.order = 0
 
 
-dumper1              INFO dumper.ele35.correction = [
+dumper1                                              INFO dumper.ele35.correction = [
     [0.003125, 0.71115],
     [0.009375, 0.857506],
     [0.015625, 0.92062],
@@ -2541,27 +2544,27 @@ dumper.gam55.order = 150
 dumper.gam55.region = 4
 
 
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] BC292F26-AE73-9041-BF5C-BCE6C5C651EC
-Domain[ROOT_All]     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
-ApplicationMgr       INFO Application Manager Stopped successfully
-IncidentProcAlg1     INFO Finalize
-CondInputLoader      INFO Finalizing CondInputLoader...
-IncidentProcAlg2     INFO Finalize
-EventSelector        INFO finalize
-IOVDbFolder          INFO Folder /LAR/CellCorrOfl/deadOTX (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/705 ((     0.07 ))s
-IOVDbSvc             INFO  bytes in ((      0.07 ))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: 1 ReadTime: ((     0.07 ))s
-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=   10 [ms] Ave/Min/Max=    3.33(+-    4.71)/       0/      10 [ms] #=  3
-cObj_ALL             INFO Time User   : Tot=   60 [ms] Ave/Min/Max=      20(+-    21.6)/       0/      50 [ms] #=  3
-ChronoStatSvc        INFO Time User   : Tot= 0.74  [s]  #=  1
-*****Chrono*****     INFO ****************************************************************************************************
-ChronoStatSvc.f...   INFO  Service finalized successfully 
-ApplicationMgr       INFO Application Manager Finalized successfully
-ApplicationMgr       INFO Application Manager Terminated successfully
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] BC292F26-AE73-9041-BF5C-BCE6C5C651EC
+Domain[ROOT_All]                                     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
+ApplicationMgr                                       INFO Application Manager Stopped successfully
+IncidentProcAlg1                                     INFO Finalize
+CondInputLoader                                      INFO Finalizing CondInputLoader...
+IncidentProcAlg2                                     INFO Finalize
+EventSelector                                        INFO finalize
+IOVDbFolder                                          INFO Folder /LAR/CellCorrOfl/deadOTX (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/705 ((     0.04 ))s
+IOVDbSvc                                             INFO  bytes in ((      0.04 ))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: 1 ReadTime: ((     0.04 ))s
+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=    0 [us] Ave/Min/Max=       0(+-       0)/       0/       0 [us] #=  3
+cObj_ALL                                             INFO Time User   : Tot=   40 [ms] Ave/Min/Max=    13.3(+-    12.5)/       0/      30 [ms] #=  3
+ChronoStatSvc                                        INFO Time User   : Tot= 1.05  [s]  #=  1
+*****Chrono*****                                     INFO ****************************************************************************************************
+ChronoStatSvc.finalize()                             INFO  Service finalized successfully 
+ApplicationMgr                                       INFO Application Manager Finalized successfully
+ApplicationMgr                                       INFO Application Manager Terminated successfully
diff --git a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx
index b25a6edfb302b183f69f21a21b2ca0273ce701bb..bc7e48bae2f8f088da5315c389feb21a12096e1b 100644
--- a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx
+++ b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx
@@ -155,6 +155,9 @@ StatusCode CaloTopoTowerAlg::execute (const EventContext& ctx) const
      return StatusCode::SUCCESS;
   }
 
+  // EL to the container, to allow making other ELs quickly.
+  ElementLink<CaloCellContainer> theCellsEL (m_cellContainerKey.key(), 0, ctx);
+
   ///+++ pick up CaloCell2ClusterMap from StoreGate
   const CaloClusterContainer* clusterContainer = nullptr;
   
@@ -312,7 +315,7 @@ StatusCode CaloTopoTowerAlg::execute (const EventContext& ctx) const
               energyTower += cellEnergy;
               numberOfClustersInTower++;           
 
-              newTower->addUniqueCellNoKine(theCells.cptr(),globalIndex,weight, 10);
+              newTower->addUniqueCellNoKine(theCellsEL,globalIndex,weight, 10);
             
               // now that we found the cell in at least one cluster above threshold, stop looking at associated clusters
               ATH_MSG_VERBOSE( " -- Found at least one cluster passing cuts. 'break'"  );
diff --git a/Calorimeter/CaloTools/share/CaloEstimatedGainTool_test.ref b/Calorimeter/CaloTools/share/CaloEstimatedGainTool_test.ref
index fa8d0a388960640132d7ac05f140eaa24597e289..ff4efe58efd5c676daa991e2c74377e7b94437a6 100644
--- a/Calorimeter/CaloTools/share/CaloEstimatedGainTool_test.ref
+++ b/Calorimeter/CaloTools/share/CaloEstimatedGainTool_test.ref
@@ -1,243 +1,247 @@
 Py:AutoConfigFlags    INFO Obtaining metadata of auto-configuration by peeking into /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root
 Py:MetaReader        INFO Current mode used: peeker
+Py:MetaReader        INFO Current filenames: ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root']
 Py:MetaReader        INFO MetaReader is called with the parameter "unique_tag_info_values" set to True. This is a workaround to remove all duplicate values from "/TagInfo" key
-Py:Athena            INFO using release [WorkDir-22.0.7] [x86_64-centos7-gcc8-opt] [atlas-work3/e0befe65d8e8] -- built on [2019-10-19T2025]
+Py:Athena            INFO using release [WorkDir-22.0.22] [x86_64-centos7-gcc8-opt] [MainServiceMsgFormat/f665cad] -- built on [2020-12-03T1657]
 Py:TileCablingSvc    INFO Forcing RUN2 (2014-2017) cabling for run 284500 with geometry ATLAS-R2-2016-01-00-01
 Py:TileInfoLoaderCfg    INFO Adjusting TileInfo to return cell noise for Opt.Filter without iterations
 Py:TileCablingSvc    INFO Forcing RUN2 (2014-2017) cabling for run 284500 with geometry ATLAS-R2-2016-01-00-01
 Py:TileCablingSvc    INFO Forcing RUN2 (2014-2017) cabling for run 284500 with geometry ATLAS-R2-2016-01-00-01
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v32r2)
-                                          running on lxplus743.cern.ch on Sun Oct 20 00:21:37 2019
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on pcaz001 on Thu Dec  3 17:48:44 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-Py:ConfigurableDb    INFO Read module info for 5590 configurables from 44 genConfDb files
-Py:ConfigurableDb    INFO No duplicates have been found: that's good !
-CoreDumpSvc          INFO install f-a-t-a-l handler... (flag = 438)
-CoreDumpSvc          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
-ClassIDSvc           INFO  getRegistryEntries: read 16428 CLIDRegistry entries for module ALL
-PoolSvc              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
-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/2019-10-18T2130/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
-DBReplicaSvc         INFO Total of 10 servers found for host lxplus743.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              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
-IOVDbSvc             INFO Opened read transaction for POOL PersistencySvc
-IOVDbSvc             INFO Only 5 POOL conditions files will be open at once
-IOVDbSvc             INFO Cache alignment will be done in 3 slices
-IOVDbSvc             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
-IOVDbSvc             INFO Initialised with 3 connections and 18 folders
-IOVDbSvc             INFO Service IOVDbSvc initialised successfully
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
-IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
-ClassIDSvc           INFO  getRegistryEntries: read 937 CLIDRegistry entries for module ALL
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_TILE/OFLP200
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-IOVDbSvc             INFO Disconnecting from COOLOFL_TILE/OFLP200
-IOVDbSvc             INFO Added taginfo remove for /LAR/Align
-IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/CalibIdMap
-IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/FebRodMap
-IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/CES
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/CIS/FIT/LIN
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/CIS/FIT/NLN
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/EMS
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/FIBER
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/LIN
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/NLN
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/NOISE/SAMPLE
-IOVDbSvc             INFO Added taginfo remove for /LAR/LArCellPositionShift
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/DAC2uA
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/HVScaleCorr
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/MphysOverMcal
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/Ramp
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/uA2MeV
-ClassIDSvc           INFO  getRegistryEntries: read 18 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 1868 CLIDRegistry entries for module ALL
-GeoModelSvc          INFO Explicitly initializing DetDescrCnvSvc
-DetDescrCnvSvc       INFO  initializing 
-DetDescrCnvSvc       INFO Found DetectorStore service
-DetDescrCnvSvc       INFO  filling proxies for detector managers 
-DetDescrCnvSvc       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
-GeoModelSvc::RD...WARNING  Getting PixTBMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting PixTBMaterials with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMaterials with default tag
-EventPersistenc...   INFO Added successfully Conversion service:DetDescrCnvSvc
-LArElectrodeIDD...   INFO in createObj: creating a LArElectrodeID helper object in the detector store
-IdDictDetDescrCnv    INFO in initialize
-IdDictDetDescrCnv    INFO in createObj: creating a IdDictManager object in the detector store
-IdDictDetDescrCnv    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
-IdDictDetDescrCnv    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
-IdDictDetDescrCnv    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Found id dicts:
-IdDictDetDescrCnv    INFO Using dictionary tag: null
-IdDictDetDescrCnv    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
-LArElectrodeID       INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineIDDetD...   INFO in createObj: creating a LArHVLineID helper object in the detector store
-LArHVLineID          INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineID          INFO  => initialize_from_dictionary(dict_mgr) =0
-LArHVLineID          INFO Register_dict_tag of LArHighVoltage is OK
-LArHVLineID          INFO setDictVersion of LArHighVoltage is OK
-LArHVLineID          INFO [initLevelsFromDict] m_dict OK ... 
-LArHVLineID          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
-LArHVLineID          INFO [init_hashes()] > Hvline_size= 5008
-GeoModelSvc.LAr...   INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
-GeoModelSvc.LAr...   INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
-GeoModelSvc.LAr...   INFO LAr Geometry Options:
-GeoModelSvc.LAr...   INFO   Sagging           = false
-GeoModelSvc.LAr...   INFO   Barrel            = ON
-GeoModelSvc.LAr...   INFO   Endcap            = ON
-BarrelConstruction   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
-BarrelConstruction   INFO   Makes detailed absorber sandwich  ? 1 1
-BarrelConstruction   INFO   Use sagging in geometry  ? 0
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Pos::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Pos::OuterWheel
-ClassIDSvc           INFO  getRegistryEntries: read 2850 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a TileTBID helper object in the detector store
-TileTBID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-EndcapDMConstru...   INFO Start building EC electronics geometry
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Neg::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Neg::OuterWheel
-EndcapDMConstru...   INFO Start building EC electronics geometry
-GeoModelSvc          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 25632Kb 	 Time = 0.66S
-GeoModelSvc.Til...   INFO  Entering TileDetectorTool::create()
-TileDddbManager      INFO m_tag = ATLAS-R2-2016-01-00-01
-TileDddbManager      INFO n_tiglob = 5
-TileDddbManager      INFO n_timod = 320
-TileDddbManager      INFO n_cuts = 9
-TileDddbManager      INFO n_saddle = 1
-TileDddbManager      INFO n_tilb = 21
-TileDddbManager      INFO n_tileSwitches = 1
-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/2019-10-18T2130/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-opt/share/TileNeighbour_reduced.txt
-TileHWIDDetDesc...   INFO in createObj: creating a TileHWID helper object in the detector store
-TileHWID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-ClassIDSvc           INFO  getRegistryEntries: read 55 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_ID helper object in the detector store
-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/2019-10-18T2130/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-opt/share/FCal2DNeighbors-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2019-10-18T2130/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsNext-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2019-10-18T2130/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-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.
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-GeoModelSvc.Til...   INFO  U-shape parameter from database is: 1
-GeoModelSvc.Til...   INFO  Glue parameter from database is: 1
-GeoModelSvc.Til...   INFO  Cs Tube parameter from database is: 0
-GeoModelSvc.Til...   INFO  Entering TileAtlasFactory::create()
-GeoModelSvc.Til...   INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
-GeoModelSvc.Til...   INFO  => New BFingerLengthPos 430.5
-GeoModelSvc.Til...   INFO  => New BFingerLengthNeg 420.5
-GeoModelSvc.Til...   INFO  Positioning barrel with translation 0
-GeoModelSvc.Til...   INFO  Positioning positive barrel finger with translation 3035.25
-GeoModelSvc.Til...   INFO  Positioning negative barrel finger with translation -3030.25
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel with translation 4854.75
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
-GeoModelSvc.Til...   INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning positive ITC with translation 3405
-GeoModelSvc.Til...   INFO  Positioning positive Gap with translation 3552
-GeoModelSvc.Til...   INFO  Positioning positive Crack with translation 3536
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel with translation ztrans -4854.75
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
-GeoModelSvc.Til...   INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning negative ITC with translation -3405
-GeoModelSvc.Til...   INFO  Positioning negative Gap with translation -3552
-GeoModelSvc.Til...   INFO  Positioning negative Crack with translation -3536
-GeoModelSvc.Til...   INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
-TileDetDescrMan...   INFO Entering create_elements()
-GeoModelSvc          INFO GeoModelSvc.TileDetectorTool	 SZ= 4124Kb 	 Time = 0.22S
-ClassIDSvc           INFO  getRegistryEntries: read 66 CLIDRegistry entries for module ALL
-TileInfoLoader       INFO Changing TTL1 calib from 4.1 to 6.9
-TileInfoLoader       INFO Changing TTL1 noise sigma from 2.5 to 2.8
-CaloIDHelper_ID...   INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
-CaloLVL1_ID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-TileCablingSvc       INFO RUN2 ATLAS geometry flag detected for geometry: ATLAS-R2-2016-01-00-01
-TileCablingSvc       INFO Cabling for RUN2 (2014-2017) ATLAS geometry is set via jobOptions 
-TileCablingSvc       INFO Setting Cabling type to 4
-AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 4939 CLIDRegistry entries for module ALL
-CondInputLoader      INFO Initializing CondInputLoader...
-CondInputLoader      INFO Adding base classes:
+CoreDumpSvc                                          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
+ClassIDSvc                                           INFO  getRegistryEntries: read 18497 CLIDRegistry entries for module ALL
+TagInfoMgr                                           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
+IOVDbSvc                                             INFO Only 5 POOL conditions files will be open at once
+IOVDbSvc                                             INFO Cache alignment will be done in 3 slices
+IOVDbSvc                                             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
+IOVDbSvc                                             INFO Initialised with 3 connections and 18 folders
+IOVDbSvc                                             INFO Service IOVDbSvc initialised successfully
+IOVDbSvc                                             INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+MetaDataSvc                                          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
+PoolSvc                                              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
+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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
+DBReplicaSvc                                         INFO Total of 10 servers found for host pcaz001.dyndns.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                                              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
+DbSession                                            INFO     Open     DbSession    
+Domain[ROOT_All]                                     INFO >   Access   DbDomain     READ      [ROOT_All] 
+MetaDataSvc                                          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
+OutputStreamSequencerSvc                             INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+ClassIDSvc                                           INFO  getRegistryEntries: read 1178 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVSvc                                               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool                                    INFO IOVRanges will be checked at every Event
+ClassIDSvc                                           INFO  getRegistryEntries: read 273 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_TILE/OFLP200
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_TILE/OFLP200
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Align
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Identifier/CalibIdMap
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Identifier/FebRodMap
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/CES
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/CIS/FIT/LIN
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/CIS/FIT/NLN
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/EMS
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/FIBER
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/LIN
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/NLN
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/NOISE/SAMPLE
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/LArCellPositionShift
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/DAC2uA
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/HVScaleCorr
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/MphysOverMcal
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/Ramp
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/uA2MeV
+ClassIDSvc                                           INFO  getRegistryEntries: read 20 CLIDRegistry entries for module ALL
+DetDescrCnvSvc                                       INFO  initializing 
+DetDescrCnvSvc                                       INFO Found DetectorStore service
+DetDescrCnvSvc                                       INFO  filling proxies for detector managers 
+DetDescrCnvSvc                                       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMaterials with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMaterials with default tag
+EventPersistencySvc                                  INFO Added successfully Conversion service:DetDescrCnvSvc
+LArElectrodeIDDetDescrCnv                            INFO in createObj: creating a LArElectrodeID helper object in the detector store
+IdDictDetDescrCnv                                    INFO in initialize
+IdDictDetDescrCnv                                    INFO in createObj: creating a IdDictManager object in the detector store
+IdDictDetDescrCnv                                    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
+IdDictDetDescrCnv                                    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
+IdDictDetDescrCnv                                    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Found id dicts:
+IdDictDetDescrCnv                                    INFO Using dictionary tag: null
+IdDictDetDescrCnv                                    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
+LArElectrodeID                                       INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineIDDetDescrCnv                               INFO in createObj: creating a LArHVLineID helper object in the detector store
+LArHVLineID                                          INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineID                                          INFO  => initialize_from_dictionary(dict_mgr) =0
+LArHVLineID                                          INFO Register_dict_tag of LArHighVoltage is OK
+LArHVLineID                                          INFO setDictVersion of LArHighVoltage is OK
+LArHVLineID                                          INFO [initLevelsFromDict] m_dict OK ... 
+LArHVLineID                                          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
+LArHVLineID                                          INFO [init_hashes()] > Hvline_size= 5008
+GeoModelSvc.LArDetectorToolNV                        INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
+GeoModelSvc.LArDetectorToolNV                        INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
+GeoModelSvc.LArDetectorToolNV                        INFO LAr Geometry Options:
+GeoModelSvc.LArDetectorToolNV                        INFO   Sagging           = false
+GeoModelSvc.LArDetectorToolNV                        INFO   Barrel            = ON
+GeoModelSvc.LArDetectorToolNV                        INFO   Endcap            = ON
+BarrelConstruction                                   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
+BarrelConstruction                                   INFO   Makes detailed absorber sandwich  ? 1 1
+BarrelConstruction                                   INFO   Use sagging in geometry  ? 0
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::OuterWheel
+ClassIDSvc                                           INFO  getRegistryEntries: read 2863 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TileTBID helper object in the detector store
+TileTBID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::OuterWheel
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+GeoModelSvc                                          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 25604Kb 	 Time = 1.01S
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileDetectorTool::create()
+TileDddbManager                                      INFO m_tag = ATLAS-R2-2016-01-00-01
+TileDddbManager                                      INFO n_tiglob = 5
+TileDddbManager                                      INFO n_timod = 320
+TileDddbManager                                      INFO n_cuts = 9
+TileDddbManager                                      INFO n_saddle = 1
+TileDddbManager                                      INFO n_tilb = 21
+TileDddbManager                                      INFO n_tileSwitches = 1
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileNeighbour_reduced.txt
+TileHWIDDetDescrCnv                                  INFO in createObj: creating a TileHWID helper object in the detector store
+TileHWID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+ClassIDSvc                                           INFO  getRegistryEntries: read 55 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal2DNeighbors-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsNext-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsPrev-April2011.txt
+CaloIDHelper_IDDetDescrCnv                           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.
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+GeoModelSvc.TileDetectorTool                         INFO  U-shape parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Glue parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Cs Tube parameter from database is: 0
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileAtlasFactory::create()
+GeoModelSvc.TileDetectorTool                         INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthPos 430.5
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthNeg 420.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning barrel with translation 0
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive barrel finger with translation 3035.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative barrel finger with translation -3030.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel with translation 4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ITC with translation 3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Gap with translation 3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Crack with translation 3536
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel with translation ztrans -4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ITC with translation -3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Gap with translation -3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Crack with translation -3536
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
+TileDetDescrManager                                  INFO Entering create_elements()
+GeoModelSvc                                          INFO GeoModelSvc.TileDetectorTool	 SZ= 4532Kb 	 Time = 0.35S
+ClassIDSvc                                           INFO  getRegistryEntries: read 67 CLIDRegistry entries for module ALL
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.LArDetectorToolNV
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.TileDetectorTool
+TileInfoLoader                                       INFO Changing TTL1 calib from 4.1 to 6.9
+TileInfoLoader                                       INFO Changing TTL1 noise sigma from 2.5 to 2.8
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
+CaloLVL1_ID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+TileCablingSvc                                       INFO RUN2 ATLAS geometry flag detected for geometry: ATLAS-R2-2016-01-00-01
+TileCablingSvc                                       INFO Cabling for RUN2 (2014-2017) ATLAS geometry is set via jobOptions 
+TileCablingSvc                                       INFO Setting Cabling type to 4
+AthenaEventLoopMgr                                   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 5023 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO Initializing CondInputLoader...
+CondInputLoader                                      INFO Adding base classes:
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/CalibIdMap' )   ->
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/FebRodMap' )   ->
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' )   ->
@@ -254,7 +258,7 @@ CondInputLoader      INFO Adding base classes:
   +  ( 'LArMphysOverMcalMC' , 'ConditionStore+LArMphysOverMcal' )   -> ILArMphysOverMcal (128308807)
   +  ( 'LArRampMC' , 'ConditionStore+LArRamp' )   -> ILArRamp (8123)
   +  ( 'LAruA2MeVMC' , 'ConditionStore+LAruA2MeV' )   -> ILAruA2MeV (154639332)
-CondInputLoader      INFO Will create WriteCondHandle dependencies for the following DataObjects:
+CondInputLoader                                      INFO Will create WriteCondHandle dependencies for the following DataObjects:
     +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/CalibIdMap' ) 
     +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/FebRodMap' ) 
     +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' ) 
@@ -276,223 +280,226 @@ CondInputLoader      INFO Will create WriteCondHandle dependencies for the follo
     +  ( 'LArMphysOverMcalMC' , 'ConditionStore+LArMphysOverMcal' ) 
     +  ( 'LArRampMC' , 'ConditionStore+LArRamp' ) 
     +  ( 'LAruA2MeVMC' , 'ConditionStore+LAruA2MeV' ) 
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCisLin) for folder: "/TILE/OFL02/CALIB/CIS/FIT/LIN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCisNln) for folder: "/TILE/OFL02/CALIB/CIS/FIT/NLN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasLin) for folder: "/TILE/OFL02/CALIB/LAS/LIN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasNln) for folder: "/TILE/OFL02/CALIB/LAS/NLN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasFib) for folder: "/TILE/OFL02/CALIB/LAS/FIBER"
-TileEMScaleCondAlg   INFO ProxyOflLasFib is set up and can be used
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCes) for folder: "/TILE/OFL02/CALIB/CES"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflEms) for folder: "/TILE/OFL02/CALIB/EMS"
-TileEMScaleCondAlg   INFO Undoing online calibration is not requested, since OnlCacheUnit= 'OnlCacheUnit':Invalid
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlCis) for folder: "/TILE/OFL02/CALIB/CIS/FIT/LIN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlLas) for folder: "/TILE/OFL02/CALIB/LAS/LIN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlCes) for folder: "/TILE/OFL02/CALIB/CES"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlEms) for folder: "/TILE/OFL02/CALIB/EMS"
-TileSampleNoise...   INFO Creating TileCondProxyCool(TileSampleNoiseCondAlg.TileCondProxyCool_NoiseSample) for folder: "/TILE/OFL02/NOISE/SAMPLE"
-LArOnlineIDDetD...   INFO in createObj: creating a LArOnlineID helper object in the detector store
-LArOnlineID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-PyComponentMgr       INFO Initializing PyComponentMgr...
-TestAlg              INFO Initializing TestAlg...
-ClassIDSvc           INFO  getRegistryEntries: read 1131 CLIDRegistry entries for module ALL
-HistogramPersis...WARNING Histograms saving not required.
-ApplicationMgr       INFO Application Manager Initialized successfully
-ApplicationMgr    SUCCESS ****************************** Algorithm Sequence ****************************
-ApplicationMgr    SUCCESS AthSequencer/AthMasterSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthAlgEvtSeq
-ApplicationMgr    SUCCESS           AthSequencer/AthBeginSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg1
-ApplicationMgr    SUCCESS           AthSequencer/AthAllAlgSeq
-ApplicationMgr    SUCCESS                AthSequencer/AthCondSeq
-ApplicationMgr    SUCCESS                     CondInputLoader/CondInputLoader
-ApplicationMgr    SUCCESS                     LArFebRodMappingAlg/LArFebRodMappingAlg
-ApplicationMgr    SUCCESS                     LArCalibLineMappingAlg/LArCalibLineMappingAlg
-ApplicationMgr    SUCCESS                     TileEMScaleCondAlg/TileEMScaleCondAlg
-ApplicationMgr    SUCCESS                     TileCalibCondAlg<TileCalibDrawerFlt>/TileSampleNoiseCondAlg
-ApplicationMgr    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
-ApplicationMgr    SUCCESS                     LArMCSymCondAlg/LArMCSymCondAlg
-ApplicationMgr    SUCCESS                     LArSymConditionsAlg<LArRampMC, LArRampSym>/LArSymConditionsAlg<LArRampMC, LArRampSym>
-ApplicationMgr    SUCCESS                     LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>/LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>
-ApplicationMgr    SUCCESS                     LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>/LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>
-ApplicationMgr    SUCCESS                     LArSymConditionsAlg<LArMphysOverMcalMC, LArMphysOverMcalSym>/LArSymConditionsAlg<LArMphysOverMcalMC, LArMphysOverMcalSym>
-ApplicationMgr    SUCCESS                     LArADC2MeVCondAlg/LArADC2MeVCondAlg
-ApplicationMgr    SUCCESS                AthSequencer/AthAlgSeq
-ApplicationMgr    SUCCESS                     PyAthena::Alg/TestAlg
-ApplicationMgr    SUCCESS           AthSequencer/AthEndSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg2
-ApplicationMgr    SUCCESS      AthSequencer/AthOutSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthRegSeq
-ApplicationMgr    SUCCESS ******************************************************************************
-CondInputLoader      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/CalibIdMap'
-CondInputLoader      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/FebRodMap'
-CondInputLoader      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CES'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CIS/FIT/LIN'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CIS/FIT/NLN'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/EMS'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/FIBER'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/LIN'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/NLN'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/NOISE/SAMPLE'
-CondInputLoader      INFO created CondCont<LArDAC2uAMC> with key 'ConditionStore+LArDAC2uA'
-CondInputLoader      INFO created CondCont<LArHVScaleCorrComplete> with key 'ConditionStore+LArHVScaleCorr'
-CondInputLoader      INFO created CondCont<LArMphysOverMcalMC> with key 'ConditionStore+LArMphysOverMcal'
-CondInputLoader      INFO created CondCont<LArRampMC> with key 'ConditionStore+LArRamp'
-CondInputLoader      INFO created CondCont<LAruA2MeVMC> with key 'ConditionStore+LAruA2MeV'
-ApplicationMgr       INFO Application Manager Started successfully
-AthenaEventLoopMgr   INFO   ===>>>  start of run 1    <<<===
-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
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCDAC2uA-IOVDEP-00 for folder /LAR/ElecCalibMC/DAC2uA
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCHVScaleCorr-IOVDEP-01 for folder /LAR/ElecCalibMC/HVScaleCorr
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCMphysOverMcal-CSC02-I for folder /LAR/ElecCalibMC/MphysOverMcal
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCRamp-IOVDEP-00 for folder /LAR/ElecCalibMC/Ramp
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCuA2MeV-IOVDEP-00 for folder /LAR/ElecCalibMC/uA2MeV
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-AthenaPoolCnvSvc     INFO Initializing AthenaPoolCnvSvc - package version AthenaPoolCnvSvc-00-00-00
-EventPersistenc...   INFO Added successfully Conversion service:AthenaPoolCnvSvc
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8A720FEC-E1F7-E511-AB56-02163E010D43
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0002.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0002.pool.root File version:52200
-CaloMgrDetDescrCnv   INFO in createObj: creating a Calo Detector Manager object in the detector store
-CaloIdMgrDetDes...   INFO in createObj: creating a CaloDescrManager object in the detector store
-ClassIDSvc           INFO  getRegistryEntries: read 544 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloDM_ID helper object in the detector store
-CaloDM_ID            INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a TTOnlineID helper object in the detector store
-TTOnlineID           INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
-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/2019-10-18T2130/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2019-10-18T2130/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2019-10-18T2130/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-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/2019-10-18T2130/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-opt/share/TileSuperCellNeighbour.txt
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIdMgrDetDes...   INFO  Finished 
-CaloIdMgrDetDes...   INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #1, run #1 0 events processed so far  <<<===
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_TILE/OFLP200
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCes-SIM-07 for folder /TILE/OFL02/CALIB/CES
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCisFitLin-COM-00 for folder /TILE/OFL02/CALIB/CIS/FIT/LIN
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCisFitNln-COM-00 for folder /TILE/OFL02/CALIB/CIS/FIT/NLN
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibEms-COM-00 for folder /TILE/OFL02/CALIB/EMS
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasFiber-000-00 for folder /TILE/OFL02/CALIB/LAS/FIBER
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasLin-COM-00 for folder /TILE/OFL02/CALIB/LAS/LIN
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasNln-COM-00 for folder /TILE/OFL02/CALIB/LAS/NLN
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02NoiseSample-TwoGauss-21 for folder /TILE/OFL02/NOISE/SAMPLE
-IOVDbSvc             INFO Disconnecting from COOLOFL_TILE/OFLP200
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 64ADE389-CABD-DD11-8D4C-000423D950B0
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000001.gen.COND/cond08_mc.000001.gen.COND._0053.pool.root
+TileEMScaleCondAlg.TileCondProxyCool_OflCisLin       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCisLin) for folder: "/TILE/OFL02/CALIB/CIS/FIT/LIN"
+TileEMScaleCondAlg.TileCondProxyCool_OflCisNln       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCisNln) for folder: "/TILE/OFL02/CALIB/CIS/FIT/NLN"
+TileEMScaleCondAlg.TileCondProxyCool_OflLasLin       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasLin) for folder: "/TILE/OFL02/CALIB/LAS/LIN"
+TileEMScaleCondAlg.TileCondProxyCool_OflLasNln       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasNln) for folder: "/TILE/OFL02/CALIB/LAS/NLN"
+TileEMScaleCondAlg.TileCondProxyCool_OflLasFib       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasFib) for folder: "/TILE/OFL02/CALIB/LAS/FIBER"
+TileEMScaleCondAlg                                   INFO ProxyOflLasFib is set up and can be used
+TileEMScaleCondAlg.TileCondProxyCool_OflCes          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCes) for folder: "/TILE/OFL02/CALIB/CES"
+TileEMScaleCondAlg.TileCondProxyCool_OflEms          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflEms) for folder: "/TILE/OFL02/CALIB/EMS"
+TileEMScaleCondAlg                                   INFO Undoing online calibration is not requested, since OnlCacheUnit= 'OnlCacheUnit':'Invalid'
+TileEMScaleCondAlg.TileCondProxyCool_OnlCis          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlCis) for folder: "/TILE/OFL02/CALIB/CIS/FIT/LIN"
+TileEMScaleCondAlg.TileCondProxyCool_OnlLas          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlLas) for folder: "/TILE/OFL02/CALIB/LAS/LIN"
+TileEMScaleCondAlg.TileCondProxyCool_OnlCes          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlCes) for folder: "/TILE/OFL02/CALIB/CES"
+TileEMScaleCondAlg.TileCondProxyCool_OnlEms          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlEms) for folder: "/TILE/OFL02/CALIB/EMS"
+TileSampleNoiseCon...TileCondProxyCool_NoiseSample   INFO Creating TileCondProxyCool(TileSampleNoiseCondAlg.TileCondProxyCool_NoiseSample) for folder: "/TILE/OFL02/NOISE/SAMPLE"
+LArOnlineIDDetDescrCnv                               INFO in createObj: creating a LArOnlineID helper object in the detector store
+LArOnlineID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+PyComponentMgr                                       INFO Initializing PyComponentMgr...
+TestAlg                                              INFO Initializing TestAlg...
+ClassIDSvc                                           INFO  getRegistryEntries: read 1097 CLIDRegistry entries for module ALL
+ApplicationMgr                                       INFO Application Manager Initialized successfully
+ApplicationMgr                                    SUCCESS ****************************** Algorithm Sequence ****************************
+ApplicationMgr                                    SUCCESS AthSequencer/AthMasterSeq
+ApplicationMgr                                    SUCCESS      AthSequencer/AthAlgEvtSeq
+ApplicationMgr                                    SUCCESS           AthSequencer/AthBeginSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg1
+ApplicationMgr                                    SUCCESS           AthSequencer/AthAllAlgSeq
+ApplicationMgr                                    SUCCESS                AthSequencer/AthCondSeq
+ApplicationMgr                                    SUCCESS                     CondInputLoader/CondInputLoader
+ApplicationMgr                                    SUCCESS                     LArFebRodMappingAlg/LArFebRodMappingAlg
+ApplicationMgr                                    SUCCESS                     LArCalibLineMappingAlg/LArCalibLineMappingAlg
+ApplicationMgr                                    SUCCESS                     TileEMScaleCondAlg/TileEMScaleCondAlg
+ApplicationMgr                                    SUCCESS                     TileCalibCondAlg<TileCalibDrawerFlt>/TileSampleNoiseCondAlg
+ApplicationMgr                                    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
+ApplicationMgr                                    SUCCESS                     LArMCSymCondAlg/LArMCSymCondAlg
+ApplicationMgr                                    SUCCESS                     LArSymConditionsAlg<LArRampMC, LArRampSym>/LArSymConditionsAlg<LArRampMC, LArRampSym>
+ApplicationMgr                                    SUCCESS                     LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>/LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>
+ApplicationMgr                                    SUCCESS                     LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>/LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>
+ApplicationMgr                                    SUCCESS                     LArSymConditionsAlg<LArMphysOverMcalMC, LArMphysOverMcalSym>/LArSymConditionsAlg<LArMphysOverMcalMC, LArMphysOverMcalSym>
+ApplicationMgr                                    SUCCESS                     LArADC2MeVCondAlg/LArADC2MeVCondAlg
+ApplicationMgr                                    SUCCESS                AthSequencer/AthAlgSeq
+ApplicationMgr                                    SUCCESS                     PyAthena::Alg/TestAlg
+ApplicationMgr                                    SUCCESS           AthSequencer/AthEndSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg2
+ApplicationMgr                                    SUCCESS      AthSequencer/AthOutSeq
+ApplicationMgr                                    SUCCESS ******************************************************************************
+CondInputLoader                                      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/CalibIdMap'
+CondInputLoader                                      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/FebRodMap'
+CondInputLoader                                      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CES'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CIS/FIT/LIN'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CIS/FIT/NLN'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/EMS'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/FIBER'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/LIN'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/NLN'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/NOISE/SAMPLE'
+CondInputLoader                                      INFO created CondCont<LArDAC2uAMC> with key 'ConditionStore+LArDAC2uA'
+CondInputLoader                                      INFO created CondCont<LArHVScaleCorrComplete> with key 'ConditionStore+LArHVScaleCorr'
+CondInputLoader                                      INFO created CondCont<LArMphysOverMcalMC> with key 'ConditionStore+LArMphysOverMcal'
+CondInputLoader                                      INFO created CondCont<LArRampMC> with key 'ConditionStore+LArRamp'
+CondInputLoader                                      INFO created CondCont<LAruA2MeVMC> with key 'ConditionStore+LAruA2MeV'
+ApplicationMgr                                       INFO Application Manager Started successfully
+AthenaEventLoopMgr                                   INFO   ===>>>  start of run 1    <<<===
+EventPersistencySvc                                  INFO Added successfully Conversion service:TagInfoMgr
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCDAC2uA-IOVDEP-00 for folder /LAR/ElecCalibMC/DAC2uA
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCHVScaleCorr-IOVDEP-01 for folder /LAR/ElecCalibMC/HVScaleCorr
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCMphysOverMcal-CSC02-I for folder /LAR/ElecCalibMC/MphysOverMcal
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCRamp-IOVDEP-00 for folder /LAR/ElecCalibMC/Ramp
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCuA2MeV-IOVDEP-00 for folder /LAR/ElecCalibMC/uA2MeV
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Opened read transaction for POOL PersistencySvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:AthenaPoolCnvSvc
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8A720FEC-E1F7-E511-AB56-02163E010D43
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0002.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0002.pool.root File version:52200
+CaloMgrDetDescrCnv                                   INFO in createObj: creating a Calo Detector Manager object in the detector store
+CaloIdMgrDetDescrCnv                                 INFO in createObj: creating a CaloDescrManager object in the detector store
+ClassIDSvc                                           INFO  getRegistryEntries: read 196 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloDM_ID helper object in the detector store
+CaloDM_ID                                            INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TTOnlineID helper object in the detector store
+TTOnlineID                                           INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsPrevNew-April2014.txt
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileSuperCellNeighbour.txt
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIdMgrDetDescrCnv                                 INFO  Finished 
+CaloIdMgrDetDescrCnv                                 INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #1, run #1 0 events processed so far  <<<===
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_TILE/OFLP200
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCes-SIM-07 for folder /TILE/OFL02/CALIB/CES
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCisFitLin-COM-00 for folder /TILE/OFL02/CALIB/CIS/FIT/LIN
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCisFitNln-COM-00 for folder /TILE/OFL02/CALIB/CIS/FIT/NLN
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibEms-COM-00 for folder /TILE/OFL02/CALIB/EMS
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasFiber-000-00 for folder /TILE/OFL02/CALIB/LAS/FIBER
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasLin-COM-00 for folder /TILE/OFL02/CALIB/LAS/LIN
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasNln-COM-00 for folder /TILE/OFL02/CALIB/LAS/NLN
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02NoiseSample-TwoGauss-21 for folder /TILE/OFL02/NOISE/SAMPLE
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_TILE/OFLP200
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 64ADE389-CABD-DD11-8D4C-000423D950B0
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000001.gen.COND/cond08_mc.000001.gen.COND._0053.pool.root
 Warning in <TClass::Init>: no dictionary for class DataHeader_p2 is available
 Warning in <TClass::Init>: no dictionary for class DataHeaderElement_p2 is available
 Warning in <TClass::Init>: no dictionary for class PoolToken_p1 is available
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000001.gen.COND/cond08_mc.000001.gen.COND._0053.pool.root File version:51800
-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] 8A720FEC-E1F7-E511-AB56-02163E010D43
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/comcond/comcond.000004.lar_conditions.recon.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0044.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/comcond/comcond.000004.lar_conditions.recon.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0044.pool.root File version:51400
-/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
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 64ADE389-CABD-DD11-8D4C-000423D950B0
-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] 7C42BC12-BD96-E011-B8EC-003048F0E01C
-LArFebRodMappin...   INFO Done reading Feb/Rod mapping. Found 1524 Febs and 762 Rods
-LArFebRodMappin...   INFO recorded new LArFebRodMap with range {[0,l:0] - [INVALID]} into Conditions Store
-LArCalibLineMap...   INFO Done reading readout/calibration line mapping.
-LArCalibLineMap...   INFO recorded new LArCalibLineMap with range {[0,l:0] - [INVALID]} into Conditions Store
-LArOnOffMappingAlg   INFO Done reading online/offline identifier mapping
-LArOnOffMappingAlg   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
-LArOnOffMappingAlg   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
-LArMCSymCondAlg      INFO recorded new LArMCSym with range {[0,l:0] - [INVALID]} into Conditions Store
-LArSymCondition...   INFO recorded new LArRampSym with range {[0,l:0] - [240000,l:0]} into Conditions Store
-LArSymCondition...   INFO recorded new LArDAC2uASym with range {[0,l:0] - [240001,l:0]} into Conditions Store
-LArSymCondition...   INFO recorded new LAruA2MeVSym with range {[0,l:0] - [240000,l:0]} into Conditions Store
-LArSymCondition...   INFO recorded new LArMphysOverMcalSym with range {[0,l:0] - [INVALID]} into Conditions Store
-LArADC2MeVCondAlg    INFO IOV of ADC2MeV object is {[0,t:0,l:0] - [222500,l:0]}
-LArADC2MeVCondAlg    INFO Working with a ramp polynom of degree 3
-AthDictLoaderSvc     INFO in initialize...
-AthDictLoaderSvc     INFO acquired Dso-registry
-ClassIDSvc           INFO  getRegistryEntries: read 958 CLIDRegistry entries for module ALL
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000001.gen.COND/cond08_mc.000001.gen.COND._0053.pool.root File version:51800
+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-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 8A720FEC-E1F7-E511-AB56-02163E010D43
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/comcond/comcond.000004.lar_conditions.recon.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0044.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/comcond/comcond.000004.lar_conditions.recon.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0044.pool.root File version:51400
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   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
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 64ADE389-CABD-DD11-8D4C-000423D950B0
+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-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 7C42BC12-BD96-E011-B8EC-003048F0E01C
+LArFebRodMappingAlg                                  INFO Done reading Feb/Rod mapping. Found 1524 Febs and 762 Rods
+LArFebRodMappingAlg                                  INFO recorded new LArFebRodMap with range {[0,l:0] - [INVALID]} into Conditions Store
+LArCalibLineMappingAlg                               INFO Done reading readout/calibration line mapping.
+LArCalibLineMappingAlg                               INFO recorded new LArCalibLineMap with range {[0,l:0] - [INVALID]} into Conditions Store
+LArOnOffMappingAlg                                   INFO Done reading online/offline identifier mapping
+LArOnOffMappingAlg                                   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
+LArOnOffMappingAlg                                   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
+LArMCSymCondAlg                                      INFO recorded new LArMCSym with range {[0,l:0] - [INVALID]} into Conditions Store
+LArSymConditionsAlg<LArRampMC, LArRampSym>           INFO recorded new LArRampSym with range {[0,t:0,l:0] - [240000,l:0]} into Conditions Store
+LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>       INFO recorded new LArDAC2uASym with range {[0,t:0,l:0] - [240001,l:0]} into Conditions Store
+LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>       INFO recorded new LAruA2MeVSym with range {[0,t:0,l:0] - [240000,l:0]} into Conditions Store
+LArSymConditionsAlg<LA...lMC, LArMphysOverMcalSym>   INFO recorded new LArMphysOverMcalSym with range {[0,t:0,l:0] - [INVALID]} into Conditions Store
+LArADC2MeVCondAlg                                    INFO IOV of ADC2MeV object is {[0,t:0,l:0] - [222500,l:0]}
+LArADC2MeVCondAlg                                    INFO Working with a ramp polynom of degree 3
+Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
+Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_ostream<char,char_traits<char> >!
+Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
+Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_stringbuf<char,char_traits<char>,allocator<char> >!
+Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
+Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent GaudiPython::CallbackStreamBuf!
+AthDictLoaderSvc                                     INFO in initialize...
+AthDictLoaderSvc                                     INFO acquired Dso-registry
+ClassIDSvc                                           INFO  getRegistryEntries: read 1100 CLIDRegistry entries for module ALL
 Py:TestAlg           INFO finished
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #1, run #1 1 events processed so far  <<<===
-/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] 303FCBD8-653E-DD11-ABBD-000423D99862
-/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...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662
-Domain[ROOT_All]     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
-ApplicationMgr       INFO Application Manager Stopped successfully
-IncidentProcAlg1     INFO Finalize
-CondInputLoader      INFO Finalizing CondInputLoader...
-TestAlg              INFO Finalizing TestAlg...
-IncidentProcAlg2     INFO Finalize
-AthDictLoaderSvc     INFO in finalize...
-PyComponentMgr       INFO Finalizing PyComponentMgr...
-ToolSvc              INFO Removing all tools created by ToolSvc
-IOVDbFolder          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.07 ))s
-IOVDbFolder          INFO Folder /LAR/Identifier/CalibIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/1520148 ((     0.13 ))s
-IOVDbFolder          INFO Folder /LAR/Identifier/FebRodMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/6100 ((     0.30 ))s
-IOVDbFolder          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     0.45 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/CES (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/103344 ((     0.11 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/CIS/FIT/LIN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/80 ((     0.07 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/CIS/FIT/NLN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/80 ((     0.06 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/EMS (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/92 ((     0.05 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/LAS/FIBER (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/940 ((     0.06 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/LAS/LIN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/72 ((     0.05 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/LAS/NLN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/76 ((     0.05 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/NOISE/SAMPLE (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/641476 ((     0.13 ))s
-IOVDbFolder          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     0.05 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/DAC2uA (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.04 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/HVScaleCorr (PoolRefColl) db-read 1/1 objs/chan/bytes 12/12/1980 ((     0.04 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/MphysOverMcal (PoolRefColl) db-read 1/1 objs/chan/bytes 3/3/516 ((     0.04 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/Ramp (PoolRefColl) db-read 1/1 objs/chan/bytes 3/3/489 ((     0.04 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/uA2MeV (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/165 ((     0.04 ))s
-IOVDbSvc             INFO  bytes in ((      1.79 ))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: 10 ReadTime: ((     1.19 ))s
-IOVDbSvc             INFO Connection COOLOFL_TILE/OFLP200 : nConnect: 2 nFolders: 8 ReadTime: ((     0.60 ))s
-IdDictDetDescrCnv    INFO in finalize
-*****Chrono*****     INFO ****************************************************************************************************
-*****Chrono*****     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
-*****Chrono*****     INFO ****************************************************************************************************
-cObjR_ALL            INFO Time User   : Tot=  380 [ms] Ave/Min/Max= 17.3(+- 68.4)/    0/  330 [ms] #= 22
-cObj_ALL             INFO Time User   : Tot=  0.5  [s] Ave/Min/Max=0.0278(+-0.0815)/    0/ 0.35  [s] #= 18
-ChronoStatSvc        INFO Time User   : Tot= 8.71  [s]                                             #=  1
-*****Chrono*****     INFO ****************************************************************************************************
-ChronoStatSvc.f...   INFO  Service finalized successfully 
-ApplicationMgr       INFO Application Manager Finalized successfully
-ApplicationMgr       INFO Application Manager Terminated successfully
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #1, run #1 1 events processed so far  <<<===
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 303FCBD8-653E-DD11-ABBD-000423D99862
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] D27D07D4-C135-E011-84A9-003048F0E01E
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
+ApplicationMgr                                       INFO Application Manager Stopped successfully
+IncidentProcAlg1                                     INFO Finalize
+CondInputLoader                                      INFO Finalizing CondInputLoader...
+TestAlg                                              INFO Finalizing TestAlg...
+IncidentProcAlg2                                     INFO Finalize
+AthDictLoaderSvc                                     INFO in finalize...
+PyComponentMgr                                       INFO Finalizing PyComponentMgr...
+IdDictDetDescrCnv                                    INFO in finalize
+IOVDbFolder                                          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /LAR/Identifier/CalibIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/1520148 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/Identifier/FebRodMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/6100 ((     0.01 ))s
+IOVDbFolder                                          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/CES (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/103344 ((     0.06 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/CIS/FIT/LIN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/80 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/CIS/FIT/NLN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/80 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/EMS (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/92 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/LAS/FIBER (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/940 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/LAS/LIN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/72 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/LAS/NLN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/76 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/NOISE/SAMPLE (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/641476 ((     0.05 ))s
+IOVDbFolder                                          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/DAC2uA (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/HVScaleCorr (PoolRefColl) db-read 1/1 objs/chan/bytes 12/12/1980 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/MphysOverMcal (PoolRefColl) db-read 1/1 objs/chan/bytes 3/3/516 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/Ramp (PoolRefColl) db-read 1/1 objs/chan/bytes 3/3/489 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/uA2MeV (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/165 ((     0.02 ))s
+IOVDbSvc                                             INFO  bytes in ((      0.55 ))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: 10 ReadTime: ((     0.22 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_TILE/OFLP200 : nConnect: 2 nFolders: 8 ReadTime: ((     0.32 ))s
+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= 0.82  [s] Ave/Min/Max=  0.0373(+-   0.128)/       0/    0.61  [s] #= 22
+cObj_ALL                                             INFO Time User   : Tot= 1.03  [s] Ave/Min/Max=  0.0572(+-   0.153)/       0/    0.65  [s] #= 18
+ChronoStatSvc                                        INFO Time User   : Tot= 27.5  [s]  #=  1
+*****Chrono*****                                     INFO ****************************************************************************************************
+ChronoStatSvc.finalize()                             INFO  Service finalized successfully 
+ApplicationMgr                                       INFO Application Manager Finalized successfully
+ApplicationMgr                                       INFO Application Manager Terminated successfully
diff --git a/Calorimeter/CaloUtils/CaloUtils/CaloTowerBuilderTool.h b/Calorimeter/CaloUtils/CaloUtils/CaloTowerBuilderTool.h
index 5553571ae5673a06d75e9f8647d5ef931bea470f..bd361a2b4b8826fde4566cffa6ea74dbe0026105 100644
--- a/Calorimeter/CaloUtils/CaloUtils/CaloTowerBuilderTool.h
+++ b/Calorimeter/CaloUtils/CaloUtils/CaloTowerBuilderTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef CALOREC_CALOTOWERBUILDERTOOL_H
@@ -107,15 +107,12 @@ private:
 
   virtual StatusCode checkSetup(MsgStream& log);
   void addTower (const CaloTowerStore::tower_iterator tower_it,
-                 const CaloCellContainer* cells,
-                 IProxyDict* sg,
+                 const ElementLink<CaloCellContainer>& cellsEL,
                  CaloTower* tower) const;
   void iterateFull (CaloTowerContainer* towers,
-                    const CaloCellContainer* cells,
-                    IProxyDict* sg) const;
+                    const ElementLink<CaloCellContainer>& cellsEL) const;
   void iterateSubSeg (CaloTowerContainer* towers,
-                      const CaloCellContainer* cells,
-                      IProxyDict* sg,
+                      const ElementLink<CaloCellContainer>& cellsEL,
                       const CaloTowerSeg::SubSeg* subseg) const;
 
 
diff --git a/Calorimeter/CaloUtils/src/CaloTopoTowerBuilderTool.cxx b/Calorimeter/CaloUtils/src/CaloTopoTowerBuilderTool.cxx
index 77180f903dcd2b0439811df7ec4dd550811f34b4..9ba135cf120ca0dc3de18fbc3a13767dc7d5132b 100644
--- a/Calorimeter/CaloUtils/src/CaloTopoTowerBuilderTool.cxx
+++ b/Calorimeter/CaloUtils/src/CaloTopoTowerBuilderTool.cxx
@@ -85,6 +85,9 @@ StatusCode CaloTopoTowerBuilderTool::execute(CaloTopoTowerContainer* theTowers,
     msg(MSG::WARNING) << "  .. no CaloTopoTowers are made " << endmsg;
     return StatusCode::SUCCESS;
   }
+
+  const ElementLink<CaloCellContainer> CellsEL (*Cells, 0);
+
   const CaloCell2ClusterMap*  cellToClusterMap=theTowers->GetCellToClusterMap();
   bool delete_cellToClusterMap=false;
   if(cellToClusterMap==nullptr  ){
@@ -274,7 +277,7 @@ StatusCode CaloTopoTowerBuilderTool::execute(CaloTopoTowerContainer* theTowers,
 		energyTower += cellEnergy;
 		numberOfClustersInTower++;
 		
-		newTower->addUniqueCellNoKine(Cells,globalIndex,weight, 10);
+		newTower->addUniqueCellNoKine(CellsEL,globalIndex,weight, 10);
 		
 		// now that we found the cell in at least one cluster above threshold, stop looking at associated clusters
 		ATH_MSG_VERBOSE(" -- Found at least one cluster passing cuts. 'break'");
diff --git a/Calorimeter/CaloUtils/src/CaloTowerBuilderTool.cxx b/Calorimeter/CaloUtils/src/CaloTowerBuilderTool.cxx
index 780313ae9b71eed219b88ff5532f89e16a23dd9e..60a6ff739993c89b4e513898f98d4b85d13b1c1c 100644
--- a/Calorimeter/CaloUtils/src/CaloTowerBuilderTool.cxx
+++ b/Calorimeter/CaloUtils/src/CaloTowerBuilderTool.cxx
@@ -63,14 +63,14 @@ StatusCode CaloTowerBuilderTool::initializeTool() {
 inline
 void
 CaloTowerBuilderTool::addTower (const CaloTowerStore::tower_iterator tower_it,
-                                const CaloCellContainer* cells,
-                                IProxyDict* sg,
+                                const ElementLink<CaloCellContainer>& cellsEL,
                                 CaloTower* tower) const
 {
   CaloTowerStore::cell_iterator firstC = tower_it.firstCell();
   CaloTowerStore::cell_iterator lastC = tower_it.lastCell();
   int ts = tower_it.size();
   double wsumE = tower->getBasicEnergy(); // this is not 0 since some towers already have cells from other calos.
+  const CaloCellContainer* cells = cellsEL.getDataPtr();
   for (; firstC != lastC; ++firstC) {
 
     unsigned int ci = firstC.hash();
@@ -82,7 +82,7 @@ CaloTowerBuilderTool::addTower (const CaloTowerStore::tower_iterator tower_it,
     // get weights
     if (cellPtr) {
       wsumE += weightC * cellPtr->e();					// Summ up weighted energies .
-      tower->addUniqueCellNoKine(cells, cndx, sg, weightC, ts); // add cells to tower.
+      tower->addUniqueCellNoKine(cellsEL, cndx, weightC, ts); // add cells to tower.
     }
     /* for debugging em+hec
        if (t==5214) std::cout<<"N14\tc:"<<ci<<"\tw:"<<weightC<<"\te:"<<cellPtr->e()<<"\teta:"<<cellPtr->eta()<<"\td:"<<cellPtr->caloDDE()<<std::endl;
@@ -97,8 +97,7 @@ CaloTowerBuilderTool::addTower (const CaloTowerStore::tower_iterator tower_it,
 inline
 void
 CaloTowerBuilderTool::iterateFull (CaloTowerContainer* towers,
-                                   const CaloCellContainer* cells,
-                                   IProxyDict* sg) const
+                                   const ElementLink<CaloCellContainer>& cellsEL) const
 {
   size_t sz = towers->size();
   assert(m_cellStore.size() ==  sz);
@@ -106,7 +105,7 @@ CaloTowerBuilderTool::iterateFull (CaloTowerContainer* towers,
 
   for (unsigned int t = 0; t < sz; ++t, ++tower_it) {
     CaloTower* aTower = towers->getTower(t);
-    addTower (tower_it, cells, sg, aTower);
+    addTower (tower_it, cellsEL, aTower);
   }
 }
 
@@ -114,8 +113,7 @@ CaloTowerBuilderTool::iterateFull (CaloTowerContainer* towers,
 inline
 void
 CaloTowerBuilderTool::iterateSubSeg (CaloTowerContainer* towers,
-                                     const CaloCellContainer* cells,
-                                     IProxyDict* sg,
+                                     const ElementLink<CaloCellContainer>& cellsEL,
                                      const CaloTowerSeg::SubSeg* subseg) const
 {
   size_t sz = towers->size();
@@ -125,7 +123,7 @@ CaloTowerBuilderTool::iterateSubSeg (CaloTowerContainer* towers,
 #if 0
   for (unsigned int t = 0; t < sz; ++t, ++tower_it) {
     CaloTower* aTower = towers->getTower(tower_it.itower());
-    addTower (tower_it, cells, aTower);
+    addTower (tower_it, cellsEL, aTower);
   }
 #endif
   // This loop was originally written as above.  However, if we increment
@@ -136,7 +134,7 @@ CaloTowerBuilderTool::iterateSubSeg (CaloTowerContainer* towers,
   unsigned int t = 0;
   while (true) {
     CaloTower* aTower = towers->getTower(tower_it.itower());
-    addTower (tower_it, cells, sg, aTower);
+    addTower (tower_it, cellsEL, aTower);
     ++t;
     if (t >= sz) break;
     ++tower_it;
@@ -181,11 +179,11 @@ CaloTowerBuilderTool::execute(CaloTowerContainer* theTowers,
     }
   }
 
-  IProxyDict* sg = SG::CurrentEventStore::store();
+  const ElementLink<CaloCellContainer> cellsEL (*theCells, 0);
   if (subseg)
-    iterateSubSeg (theTowers, theCells, sg, subseg);
+    iterateSubSeg (theTowers, cellsEL, subseg);
   else
-    iterateFull (theTowers, theCells, sg);
+    iterateFull (theTowers, cellsEL);
 
   for (unsigned int i = 0; i < m_caloIndices.size(); i++) {
     theTowers->setCalo(m_caloIndices[i]);
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/DecorKeyHelpers.h b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/DecorKeyHelpers.h
index 75ddb7fefd8577a8185d9f2fe044ce613f8f3eff..349c710ae2e7881fff9bf32277eeea6c5d85d2bd 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/DecorKeyHelpers.h
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/DecorKeyHelpers.h
@@ -18,7 +18,7 @@ inline std::string contKeyFromKey (const std::string& key)
 {
   const auto split = key.rfind ('.');
   if (split == std::string::npos)
-    throw std::runtime_error ("decor key does not contain a .: " + key);
+    return key;
   return key.substr (0, split);
 }
 
@@ -26,9 +26,10 @@ inline std::string decorKeyFromKey (const std::string& key)
 {
   const auto split = key.rfind ('.');
   if (split == std::string::npos)
-    throw std::runtime_error ("decor key does not contain a .: " + key);
+    return "";
   return key.substr (split + 1);
 }
+
 }
 
 #endif
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandle.h b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandle.h
index 6184d1dc8c6d83d1ff284943c7aa3fa116a2c00c..ef69de9eac3fd6a4da9ebddd117ff2e2104c6a75 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandle.h
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandle.h
@@ -22,7 +22,7 @@
 #include "AsgDataHandles/ReadDecorHandleKey.h"
 #include "AsgDataHandles/ReadHandle.h"
 #include "AsgDataHandles/DecorKeyHelpers.h"
-// #include "AthContainers/AuxElement.h"
+#include "AthContainers/AuxElement.h"
 // #include "GaudiKernel/EventContext.h"
 // #include <type_traits>
 
@@ -72,21 +72,21 @@ public:
   explicit ReadDecorHandle (const ReadDecorHandleKey<T>& key);
 
 
-//   /**
-//    * @brief Constructor from a ReadDecorHandleKey and an explicit event context.
-//    * @param key The key object holding the clid/key.
-//    * @param ctx The event context.
-//    *
-//    * This will raise an exception if the StoreGate key is blank,
-//    * or if the event store cannot be found.
-//    *
-//    * If the default event store has been requested, then the thread-specific
-//    * store from the event context will be used.
-//    */
-//   explicit ReadDecorHandle (const ReadDecorHandleKey<T>& key,
-//                             const EventContext& ctx);
+  /**
+   * @brief Constructor from a ReadDecorHandleKey and an explicit event context.
+   * @param key The key object holding the clid/key.
+   * @param ctx The event context.
+   *
+   * This will raise an exception if the StoreGate key is blank,
+   * or if the event store cannot be found.
+   *
+   * If the default event store has been requested, then the thread-specific
+   * store from the event context will be used.
+   */
+  explicit ReadDecorHandle (const ReadDecorHandleKey<T>& key,
+                            const EventContext& ctx);
+
 
-  
 //   /**
 //    * @brief Copy constructor.
 //    */
@@ -147,11 +147,11 @@ public:
 //   getDataArray();
 
 
-//   /**
-//    * @brief Test to see if this variable exists in the store,
-//    *        for the referenced object.
-//    */
-//   bool isAvailable();
+  /**
+   * @brief Test to see if this variable exists in the store,
+   *        for the referenced object.
+   */
+  bool isAvailable();
 
 
 //   /**
@@ -159,6 +159,12 @@ public:
 //    */
 //   SG::auxid_t auxid() const;
 
+
+  /**
+   * @brief Return the name of the decoration alias (CONT.DECOR).
+   */
+  std::string decorKey() const;
+
   
 private:
   /** 
@@ -187,6 +193,10 @@ private:
   const SG::AuxVectorData* vectorData();
 
 
+  /// Name of the decoration alias.
+  std::string m_decorKey;
+
+
   /// Accessor for the aux data item.
   accessor_t m_acc;
 };
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandle.icc b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandle.icc
index eda87fd6121d2851c16520f487fee145f5c107c3..429fdb4636deab1dcdcee31c4fc40513c3cbda27 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandle.icc
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandle.icc
@@ -21,30 +21,32 @@ namespace SG {
  */
 template <class T, class D>
 ReadDecorHandle<T, D>::ReadDecorHandle (const ReadDecorHandleKey<T>& key)
-  : Base (key),
+  : Base (key.contHandleKey()),
+    m_decorKey (key.key()),
     m_acc (SG::decorKeyFromKey (key.key()))
 {
 }
 
 
-// /**
-//  * @brief Constructor from a ReadDecorHandleKey and an explicit event context.
-//  * @param key The key object holding the clid/key.
-//  * @param ctx The event context.
-//  *
-//  * This will raise an exception if the StoreGate key is blank,
-//  * or if the event store cannot be found.
-//  *
-//  * If the default event store has been requested, then the thread-specific
-//  * store from the event context will be used.
-//  */
-// template <class T, class D>
-// ReadDecorHandle<T, D>::ReadDecorHandle (const ReadDecorHandleKey<T>& key,
-//                                         const EventContext& ctx)
-//   : Base (key, ctx),
-//     m_acc (SG::decorKeyFromKey (key.key()))
-// {
-// }
+/**
+ * @brief Constructor from a ReadDecorHandleKey and an explicit event context.
+ * @param key The key object holding the clid/key.
+ * @param ctx The event context.
+ *
+ * This will raise an exception if the StoreGate key is blank,
+ * or if the event store cannot be found.
+ *
+ * If the default event store has been requested, then the thread-specific
+ * store from the event context will be used.
+ */
+template <class T, class D>
+ReadDecorHandle<T, D>::ReadDecorHandle (const ReadDecorHandleKey<T>& key,
+                                        const EventContext& ctx)
+  : Base (key.contHandleKey(), ctx),
+    m_decorKey (key.key()),
+    m_acc (SG::decorKeyFromKey (key.key()))
+{
+}
 
 
 // /**
@@ -53,6 +55,7 @@ ReadDecorHandle<T, D>::ReadDecorHandle (const ReadDecorHandleKey<T>& key)
 // template <class T, class D>
 // ReadDecorHandle<T, D>::ReadDecorHandle (const ReadDecorHandle& rhs)
 //   : Base (rhs),
+//     m_decorKey (rhs.m_decorKey),
 //     m_acc (rhs.m_acc)
 // {
 // }
@@ -64,6 +67,7 @@ ReadDecorHandle<T, D>::ReadDecorHandle (const ReadDecorHandleKey<T>& key)
 // template <class T, class D>
 // ReadDecorHandle<T, D>::ReadDecorHandle (ReadDecorHandle&& rhs)
 //   : Base (std::move (rhs)),
+//     m_decorKey (std::move (rhs.m_decorKey)),
 //     m_acc (std::move (rhs.m_acc))
 // {
 // }
@@ -77,6 +81,7 @@ ReadDecorHandle<T, D>::ReadDecorHandle (const ReadDecorHandleKey<T>& key)
 // {
 //   if (this != &rhs) {
 //     *static_cast<Base*>(this) = rhs;
+//     m_decorKey = rhs.m_decorKey;
 //     m_acc = rhs.m_acc;
 //   }
 //   return *this;
@@ -91,6 +96,7 @@ ReadDecorHandle<T, D>::ReadDecorHandle (const ReadDecorHandleKey<T>& key)
 // {
 //   if (this != &rhs) {
 //     *static_cast<Base*>(this) = std::move (rhs);
+//     m_decorKey = std::move (rhs.m_decorKey);
 //     m_acc = std::move (rhs.m_acc);
 //   }
 //   return *this;
@@ -106,9 +112,10 @@ ReadDecorHandle<T, D>::ReadDecorHandle (const ReadDecorHandleKey<T>& key)
  * Const method; the handle does not change as a result of this.
  */
 template <class T, class D>
+inline
 bool ReadDecorHandle<T, D>::isPresent() const
 {
-  return this->isPresent_impl (contKeyFromKey (this->key()));
+  return Base::isPresent();
 }
 
 
@@ -154,17 +161,17 @@ ReadDecorHandle<T, D>::operator() (size_t i)
 // }
 
 
-// /**
-//  * @brief Test to see if this variable exists in the store,
-//  *        for the referenced object.
-//  */
-// template <class T, class D>
-// inline
-// bool ReadDecorHandle<T, D>::isAvailable()
-// {
-//   const SG::AuxVectorData* vec = this->vectorData();
-//   return vec && vec->isAvailable (m_acc.auxid());
-// }
+/**
+ * @brief Test to see if this variable exists in the store,
+ *        for the referenced object.
+ */
+template <class T, class D>
+inline
+bool ReadDecorHandle<T, D>::isAvailable()
+{
+  const SG::AuxVectorData* vec = this->vectorData();
+  return vec && vec->isAvailable (m_acc.auxid());
+}
 
 
 // /**
@@ -178,6 +185,17 @@ ReadDecorHandle<T, D>::operator() (size_t i)
 // }
 
 
+/**
+ * @brief Return the name of the decoration alias (CONT.DECOR).
+ */
+template <class T, class D>
+inline
+std::string ReadDecorHandle<T, D>::decorKey() const
+{
+  return m_decorKey;
+}
+
+
 /** 
  * @brief Return the referenced object as a @c SG::AuxVectorData.
  *        Specialization for the case of a standalone object
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandleKey.h b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandleKey.h
index 83402156e06c845113995d7477bdad8e0d90d8de..ecdd8b19b45ae1925a984f5876e5864c1502526c 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandleKey.h
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandleKey.h
@@ -49,17 +49,17 @@ public:
 //   typedef typename SG::TopBase<T>::type topbase_t;
 
 
-//   /**
-//    * @brief Constructor.
-//    * @param key The StoreGate key for the object.
-//    * @param storeName Name to use for the store, if it's not encoded in sgkey.
-//    *
-//    * The provided key may actually start with the name of the store,
-//    * separated by a "+":  "MyStore+Obj".  If no "+" is present
-//    * the store named by @c storeName is used.
-//    */
-//   ReadDecorHandleKey (const std::string& key = "",
-//                       const std::string& storeName = StoreID::storeName(StoreID::EVENT_STORE));
+  /**
+   * @brief Constructor.
+   * @param key The StoreGate key for the object.
+   * @param storeName Name to use for the store, if it's not encoded in sgkey.
+   *
+   * The provided key may actually start with the name of the store,
+   * separated by a "+":  "MyStore+Obj".  If no "+" is present
+   * the store named by @c storeName is used.
+   */
+  ReadDecorHandleKey (const std::string& key = "");
+                      // const std::string& storeName = StoreID::storeName(StoreID::EVENT_STORE));
 
 
   /**
@@ -81,9 +81,30 @@ public:
                       const K& key = {},
                       const std::string& doc = "");
 
-  
-  /// Can get this from the base class.
-  using Base::operator=;
+
+  /**
+   * @brief Change the key of the object to which we're referring.
+   * @param sgkey The StoreGate key for the object.
+   * 
+   * The provided key may actually start with the name of the store,
+   * separated by a "+":  "MyStore+Obj".  If no "+" is present,
+   * the store is not changed.
+   */
+  ReadDecorHandleKey& operator= (const std::string& sgkey);
+
+
+  /**
+   * @brief Change the key of the object to which we're referring.
+   * @param sgkey The StoreGate key for the object.
+   * 
+   * The provided key may actually start with the name of the store,
+   * separated by a "+":  "MyStore+Obj".  If no "+" is present
+   * the store is not changed.  A key name that starts with a slash
+   * is interpreted as a hierarchical key name, not an empty store name.
+   *
+   * Returns failure the key string format is bad.
+   */
+  virtual StatusCode assign (const std::string& sgkey) override;
 
 
 //   /**
@@ -92,6 +113,27 @@ public:
 //    * Overridden here to return the CLID for @c T instead of @c topbase_t.
 //    */
 //   CLID clid() const;
+
+
+  /**
+   * @brief If this object is used as a property, then this should be called
+   *        during the initialize phase.  It will fail if the requested
+   *        StoreGate service cannot be found or if the key is blank.
+   * @param used If false, then this handle is not to be used.
+   *             Instead of normal initialization, the key will be cleared.
+   */
+  StatusCode initialize (bool used = true);
+
+
+  /**
+   * @brief Return the handle key for the container.
+   */
+  const ReadHandleKey<T>& contHandleKey() const;
+
+
+private:
+  /// The container handle.
+  ReadHandleKey<T> m_contHandleKey;
 };
 
 
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandleKey.icc b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandleKey.icc
index 457db4d3ade831a0fbe13d13f07c9f4228d61c54..c71902c5e2ec724c26ccd488a46db86be5ebc4c9 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandleKey.icc
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadDecorHandleKey.icc
@@ -10,26 +10,30 @@
  *        ReadDecorHandle is made.
  */
 
+#include <AsgDataHandles/DecorKeyHelpers.h>
+
 
 namespace SG {
 
 
-// /**
-//  * @brief Constructor.
-//  * @param key The StoreGate key for the object.
-//  * @param storeName Name to use for the store, if it's not encoded in sgkey.
-//  *
-//  * The provided key may actually start with the name of the store,
-//  * separated by a "+":  "MyStore+Obj".  If no "+" is present
-//  * the store named by @c storeName is used.
-//  */
-// template <class T>
-// inline
-// ReadDecorHandleKey<T>::ReadDecorHandleKey (const std::string& key /*= ""*/,
-//                                            const std::string& storeName /*= StoreID::storeName(StoreID::EVENT_STORE)*/)
-//   : Base (ClassID_traits<topbase_t>::ID(), key, storeName)
-// {
-// }
+/**
+ * @brief Constructor.
+ * @param key The StoreGate key for the object.
+ * @param storeName Name to use for the store, if it's not encoded in sgkey.
+ *
+ * The provided key may actually start with the name of the store,
+ * separated by a "+":  "MyStore+Obj".  If no "+" is present
+ * the store named by @c storeName is used.
+ */
+template <class T>
+inline
+ReadDecorHandleKey<T>::ReadDecorHandleKey (const std::string& key /*= ""*/)
+                                          //  const std::string& storeName /*= StoreID::storeName(StoreID::EVENT_STORE)*/)
+  // : Base (ClassID_traits<topbase_t>::ID(), key, storeName),
+  : Base (key),
+    m_contHandleKey (contKeyFromKey (key)/*, storeName*/)
+{
+}
 
 
 /**
@@ -52,8 +56,48 @@ ReadDecorHandleKey<T>::ReadDecorHandleKey( OWNER* owner,
                                            const std::string& name,
                                            const K& key /*={}*/,
                                            const std::string& doc /*=""*/)
-  : Base (owner, name, key, doc)
+  : Base (key),
+    m_contHandleKey (contKeyFromKey (key)/*, StoreID::storeName(StoreID::EVENT_STORE) */)
+{
+  owner->declareProperty(name, *this, doc);
+}
+
+
+/**
+ * @brief Change the key of the object to which we're referring.
+ * @param sgkey The StoreGate key for the object.
+ * 
+ * The provided key may actually start with the name of the store,
+ * separated by a "+":  "MyStore+Obj".  If no "+" is present,
+ * the store is not changed.
+ */
+template <class T>
+ReadDecorHandleKey<T>&
+ReadDecorHandleKey<T>::operator= (const std::string& sgkey)
 {
+  m_contHandleKey = contKeyFromKey (sgkey);
+  Base::operator= (sgkey);
+  return *this;
+}
+
+
+/**
+ * @brief Change the key of the object to which we're referring.
+ * @param sgkey The StoreGate key for the object.
+ * 
+ * The provided key may actually start with the name of the store,
+ * separated by a "+":  "MyStore+Obj".  If no "+" is present
+ * the store is not changed.  A key name that starts with a "+"
+ * is interpreted as a hierarchical key name, not an empty store name.
+ *
+ * Returns failure the key string format is bad.
+ */
+template <class T>
+StatusCode ReadDecorHandleKey<T>::assign (const std::string& sgkey)
+{
+  if (m_contHandleKey.assign (contKeyFromKey (sgkey)).isFailure())
+    return StatusCode::FAILURE;
+  return Base::assign (sgkey);
 }
 
 
@@ -70,4 +114,31 @@ ReadDecorHandleKey<T>::ReadDecorHandleKey( OWNER* owner,
 // }
 
 
+/**
+ * @brief If this object is used as a property, then this should be called
+ *        during the initialize phase.  It will fail if the requested
+ *        StoreGate service cannot be found or if the key is blank.
+ *
+ * @param used If false, then this handle is not to be used.
+ *             Instead of normal initialization, the key will be cleared.
+ */
+template <class T>
+StatusCode ReadDecorHandleKey<T>::initialize (bool used /*= true*/)
+{
+  if (m_contHandleKey.initialize (used).isFailure())
+    return StatusCode::FAILURE;
+  return Base::initialize (used);
+}
+
+
+/**
+ * @brief Return the handle key for the container.
+ */
+template <class T>
+const ReadHandleKey<T>& ReadDecorHandleKey<T>::contHandleKey() const
+{
+  return m_contHandleKey;
+}
+
+
 } // namespace SG
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadHandleKey.icc b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadHandleKey.icc
index be2422d1c43bb5f97634e22a8596ce3edf73f8d0..9878c897f3e6dc23ddda6f9a3145de5064a2bec5 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadHandleKey.icc
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/ReadHandleKey.icc
@@ -31,19 +31,19 @@ ReadHandleKey<T>::ReadHandleKey (const std::string& key)
 }
 
 
-// /**
-//  * @brief Auto-declaring Property constructor.
-//  * @param owner Owning component.
-//  * @param name Name of the Property.
-//  * @param key  Default StoreGate key for the object.
-//  * @param doc Documentation string.
-//  *
-//  * Will associate the named Property with this RHK via declareProperty.
-//  *
-//  * The provided key may actually start with the name of the store,
-//  * separated by a "+":  "MyStore+Obj".  If no "+" is present
-//  * the store named by @c storeName is used.
-//  */
+/**
+ * @brief Auto-declaring Property constructor.
+ * @param owner Owning component.
+ * @param name Name of the Property.
+ * @param key  Default StoreGate key for the object.
+ * @param doc Documentation string.
+ *
+ * Will associate the named Property with this RHK via declareProperty.
+ *
+ * The provided key may actually start with the name of the store,
+ * separated by a "+":  "MyStore+Obj".  If no "+" is present
+ * the store named by @c storeName is used.
+ */
 template <class T>
 template <class OWNER, class K>
 inline
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandle.h b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandle.h
index 7e113d0899fd600a01cc541251d9205b7bca2444..b02aa5f2189529d5e3208981f5231adb4f91017f 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandle.h
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandle.h
@@ -68,19 +68,20 @@ public:
   explicit WriteDecorHandle (const WriteDecorHandleKey<T>& key);
 
 
-//   /**
-//    * @brief Constructor from a ReadDecorHandleKey and an explicit event context.
-//    * @param key The key object holding the clid/key.
-//    * @param ctx The event context.
-//    *
-//    * This will raise an exception if the StoreGate key is blank,
-//    * or if the event store cannot be found.
-//    *
-//    * If the default event store has been requested, then the thread-specific
-//    * store from the event context will be used.
-//    */
-//   explicit WriteDecorHandle (const WriteDecorHandleKey<T>& key,
-//                              const EventContext& ctx);
+  /**
+   * @brief Constructor from a ReadDecorHandleKey and an explicit event context.
+   * @param key The key object holding the clid/key.
+   * @param ctx The event context.
+   *
+   * This will raise an exception if the StoreGate key is blank,
+   * or if the event store cannot be found.
+   *
+   * If the default event store has been requested, then the thread-specific
+   * store from the event context will be used.
+   */
+  explicit WriteDecorHandle (const WriteDecorHandleKey<T>& key,
+                             const EventContext& ctx);
+
 
 //   /**
 //    * @brief Copy constructor.
@@ -112,15 +113,15 @@ public:
 //   WriteDecorHandle& operator= (WriteDecorHandle&& rhs);
 
 
-//   /**
-//    * @brief Is the referenced container present in SG?
-//    *
-//    * Note that this tests for the presence of the _container_,
-//    * not for the decoration.
-//    *
-//    * Const method; the handle does not change as a result of this.
-//    */
-//   bool isPresent() const;
+  /**
+   * @brief Is the referenced container present in SG?
+   *
+   * Note that this tests for the presence of the _container_,
+   * not for the decoration.
+   *
+   * Const method; the handle does not change as a result of this.
+   */
+  bool isPresent() const;
 
 
 //   /**
@@ -160,11 +161,11 @@ public:
 //   getDecorationArray();
 
 
-//   /**
-//    * @brief Test to see if this variable exists in the store,
-//    *        for the referenced object.
-//    */
-//   bool isAvailable();
+  /**
+   * @brief Test to see if this variable exists in the store,
+   *        for the referenced object.
+   */
+  bool isAvailable();
 
 
 //   /**
@@ -172,7 +173,19 @@ public:
 //    */
 //   SG::auxid_t auxid() const;
 
-  
+
+  // /**
+  //  * @brief Return the mode (read/write/update) for this handle.
+  //  */
+  // Gaudi::DataHandle::Mode mode() const;
+
+
+  /**
+   * @brief Return the name of the decoration alias (CONT.DECOR).
+   */
+  std::string decorKey() const;
+
+
 // private:
 //   /**
 //    * @brief Retrieve an object from StoreGate.
@@ -184,22 +197,22 @@ public:
 //   virtual void* typeless_dataPointer_impl (bool quiet) override;
 
 
-//   /**
-//    * @brief Test to see if this variable exists in the store,
-//    *        for the referenced object.
-//    *        Specialization for the case of a standalone object
-//    *        (@c T derives from @c SG::AuxElement).
-//    */
-//   bool isAvailable (std::true_type);
+  /**
+   * @brief Test to see if this variable exists in the store,
+   *        for the referenced object.
+   *        Specialization for the case of a standalone object
+   *        (@c T derives from @c SG::AuxElement).
+   */
+  bool isAvailable (std::true_type);
 
 
-//   /**
-//    * @brief Test to see if this variable exists in the store,
-//    *        for the referenced object.
-//    *        Specialization for the case of a container
-//    *        (@c T does not derive from @c SG::AuxElement).
-//    */
-//   bool isAvailable (std::false_type);
+  /**
+   * @brief Test to see if this variable exists in the store,
+   *        for the referenced object.
+   *        Specialization for the case of a container
+   *        (@c T does not derive from @c SG::AuxElement).
+   */
+  bool isAvailable (std::false_type);
 
 
 //   /** 
@@ -228,9 +241,8 @@ public:
 //   const SG::AuxVectorData* vectorData();
 
 
-//   /// Handle for reading the referenced object using its original name
-//   /// (not the alias).
-//   SG::ReadHandle<T> m_contHandle;
+  /// Name of the decoration alias: CONT.DECOR.
+  std::string m_decorKey;
 
 
   /// Accessor for the aux data item.
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandle.icc b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandle.icc
index 485db240290c53750c148433c409e5d94d2faf8b..f54aa1ecba57ba1ee46e410ae3b0849f2c74edf9 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandle.icc
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandle.icc
@@ -24,34 +24,34 @@ namespace SG {
  */
 template <class T, class D>
 WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandleKey<T>& key)
-  : Base (key, nullptr),
-    // m_contHandle (key.contHandleKey()),
+  : Base (key.contHandleKey(), nullptr),
+    m_decorKey (key.key()),
     m_acc (SG::decorKeyFromKey (key.key()))
     // m_madeAlias (false)
 {
 }
 
 
-// /**
-//  * @brief Constructor from a ReadDecorHandleKey and an explicit event context.
-//  * @param key The key object holding the clid/key.
-//  * @param ctx The event context.
-//  *
-//  * This will raise an exception if the StoreGate key is blank,
-//  * or if the event store cannot be found.
-//  *
-//  * If the default event store has been requested, then the thread-specific
-//  * store from the event context will be used.
-//  */
-// template <class T, class D>
-// WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandleKey<T>& key,
-//                                           const EventContext& ctx)
-//   : Base (key, &ctx),
-//     m_contHandle (key.contHandleKey(), ctx),
-//     m_acc (SG::decorKeyFromKey (key.key())),
-//     m_madeAlias (false)
-// {
-// }
+/**
+ * @brief Constructor from a ReadDecorHandleKey and an explicit event context.
+ * @param key The key object holding the clid/key.
+ * @param ctx The event context.
+ *
+ * This will raise an exception if the StoreGate key is blank,
+ * or if the event store cannot be found.
+ *
+ * If the default event store has been requested, then the thread-specific
+ * store from the event context will be used.
+ */
+template <class T, class D>
+WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandleKey<T>& key,
+                                          const EventContext& ctx)
+  : Base (key.contHandleKey(), &ctx),
+    m_decorKey (key.key()),
+    m_acc (SG::decorKeyFromKey (key.key()))
+    // m_madeAlias (false)
+{
+}
 
 
 // /**
@@ -60,7 +60,7 @@ WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandleKey<T>& key)
 // template <class T, class D>
 // WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandle& rhs)
 //   : Base (rhs),
-//     m_contHandle (rhs.m_contHandle),
+//     m_decorKey (rhs.m_decorKey),
 //     m_acc (rhs.m_acc),
 //     m_madeAlias (rhs.m_madeAlias)
 // {
@@ -73,7 +73,7 @@ WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandleKey<T>& key)
 // template <class T, class D>
 // WriteDecorHandle<T, D>::WriteDecorHandle (WriteDecorHandle&& rhs)
 //   : Base (std::move (rhs)),
-//     m_contHandle (std::move (rhs.m_contHandle)),
+//     m_decorKey (std::move (rhs.m_decorKey)),
 //     m_acc (std::move (rhs.m_acc)),
 //     m_madeAlias (rhs.m_madeAlias)
 // {
@@ -107,7 +107,7 @@ WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandleKey<T>& key)
 //   if (this != &rhs) {
 //     *static_cast<Base*>(this) = rhs;
 //     m_acc = rhs.m_acc;
-//     m_contHandle = rhs.m_contHandle;
+//     m_decorKey = rhs.m_decorKey;
 //     m_madeAlias = rhs.m_madeAlias;
 //   }
 //   return *this;
@@ -123,7 +123,7 @@ WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandleKey<T>& key)
 //   if (this != &rhs) {
 //     *static_cast<Base*>(this) = std::move (rhs);
 //     m_acc = std::move (rhs.m_acc);
-//     m_contHandle = std::move (rhs.m_contHandle);
+//     m_decorKey = std::move (rhs.m_decorKey);
 //     m_madeAlias = rhs.m_madeAlias;
 //     rhs.m_madeAlias = false;
 //   }
@@ -131,19 +131,19 @@ WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandleKey<T>& key)
 // }
 
 
-// /**
-//  * @brief Is the referenced container present in SG?
-//  *
-//  * Note that this tests for the presence of the _container_,
-//  * not for the decoration.
-//  *
-//  * Const method; the handle does not change as a result of this.
-//  */
-// template <class T, class D>
-// bool WriteDecorHandle<T, D>::isPresent() const
-// {
-//   return m_contHandle.isPresent();
-// }
+/**
+ * @brief Is the referenced container present in SG?
+ *
+ * Note that this tests for the presence of the _container_,
+ * not for the decoration.
+ *
+ * Const method; the handle does not change as a result of this.
+ */
+template <class T, class D>
+bool WriteDecorHandle<T, D>::isPresent() const
+{
+  return Base::isPresent();
+}
 
 
 // /**
@@ -159,8 +159,6 @@ WriteDecorHandle<T, D>::WriteDecorHandle (const WriteDecorHandleKey<T>& key)
 // StatusCode WriteDecorHandle<T, D>::setProxyDict (IProxyDict* store)
 // {
 //   m_madeAlias = false;
-//   if (m_contHandle.setProxyDict (store).isFailure())
-//     return StatusCode::FAILURE;
 //   return Base::setProxyDict (store);
 // }
 
@@ -207,72 +205,96 @@ WriteDecorHandle<T, D>::operator() (const AuxElement& e)
 // }
 
 
-// /**
-//  * @brief Test to see if this variable exists in the store,
-//  *        for the referenced object.
-//  *        Specialization for the case of a standalone object
-//  *        (@c T derives from @c SG::AuxElement).
-//  */
-// template <class T, class D>
-// inline
-// bool WriteDecorHandle<T, D>::isAvailable (std::true_type)
-// {
-//   if (this->m_ptr) {
-//     const SG::AuxVectorData* obj = static_cast<const T*>(this->m_ptr)->container();
-//     if (obj) {
-//       return obj->isAvailable (m_acc.auxid());
-//     }
-//   }
+/**
+ * @brief Test to see if this variable exists in the store,
+ *        for the referenced object.
+ *        Specialization for the case of a standalone object
+ *        (@c T derives from @c SG::AuxElement).
+ */
+template <class T, class D>
+inline
+bool WriteDecorHandle<T, D>::isAvailable (std::true_type)
+{
+  const T* ptr = this->ptr();
+  if (ptr) {
+    const SG::AuxVectorData* obj = ptr->container();
+    if (obj) {
+      return obj->isAvailable (m_acc.auxid());
+    }
+  }
+
+  return false;
+}
 
-//   return false;
-// }
 
+/**
+ * @brief Test to see if this variable exists in the store,
+ *        for the referenced object.
+ *        Specialization for the case of a container
+ *        (@c T does not derive from @c SG::AuxElement).
+ */
+template <class T, class D>
+inline
+bool WriteDecorHandle<T, D>::isAvailable (std::false_type)
+{
+  const T* ptr = this->ptr();
+  if (ptr) {
+    return ptr->isAvailable (m_acc.auxid());
+  }
 
-// /**
-//  * @brief Test to see if this variable exists in the store,
-//  *        for the referenced object.
-//  *        Specialization for the case of a container
-//  *        (@c T does not derive from @c SG::AuxElement).
-//  */
-// template <class T, class D>
-// inline
-// bool WriteDecorHandle<T, D>::isAvailable (std::false_type)
-// {
-//   if (this->m_ptr) {
-//     return static_cast<const T*>(this->m_ptr)->isAvailable (m_acc.auxid());
-//   }
+  return false;
+}
 
-//   return false;
-// }
+
+/**
+ * @brief Test to see if this variable exists in the store,
+ *        for the referenced object.
+ */
+template <class T, class D>
+inline
+bool WriteDecorHandle<T, D>::isAvailable()
+{
+  // if (!this->m_ptr) {
+  //   ReadHandle<T>::typeless_dataPointer_impl (true);
+  // }
+  // We can't just use vectorData() because that will create the decoration
+  // as a side effect.
+  return isAvailable (typename std::is_base_of<SG::AuxElement, T>::type());
+}
 
 
 // /**
-//  * @brief Test to see if this variable exists in the store,
-//  *        for the referenced object.
+//  * @brief Return the aux id for this variable.
 //  */
 // template <class T, class D>
-// inline
-// bool WriteDecorHandle<T, D>::isAvailable()
+// SG::auxid_t WriteDecorHandle<T, D>::auxid() const
 // {
-//   if (!this->m_ptr) {
-//     ReadHandle<T>::typeless_dataPointer_impl (true);
-//   }
-//   // We can't just use vectorData() because that will create the decoration
-//   // as a side effect.
-//   return isAvailable (typename std::is_base_of<SG::AuxElement, T>::type());
+//   return m_acc.auxid();
 // }
 
 
 // /**
-//  * @brief Return the aux id for this variable.
+//  * @brief Return the mode (read/write/update) for this handle.
 //  */
 // template <class T, class D>
-// SG::auxid_t WriteDecorHandle<T, D>::auxid() const
+// inline
+// Gaudi::DataHandle::Mode WriteDecorHandle<T, D>::mode() const
 // {
-//   return m_acc.auxid();
+//   return Gaudi::DataHandle::Writer;
 // }
 
 
+/**
+ * @brief Return the name of the decoration alias (CONT.DECOR).
+ */
+template <class T, class D>
+inline
+std::string WriteDecorHandle<T, D>::decorKey() const
+{
+  return m_decorKey;
+}
+
+
 // /**
 //  * @brief Retrieve an object from StoreGate.
 //  * @param quiet If true, suppress failure messages.
@@ -285,11 +307,14 @@ WriteDecorHandle<T, D>::operator() (const AuxElement& e)
 // {
 //   if (this->m_ptr && this->m_madeAlias)
 //     return this->m_ptr;
-//   if (m_contHandle.alias (WriteHandleKey<T> (this->key())).isFailure())
-//     return nullptr;
 //   if (!this->m_ptr) {
 //     ReadHandle<T>::typeless_dataPointer_impl (quiet);
 //   }
+//   if (!this->m_ptr) {
+//     return nullptr;
+//   }
+//   if (this->alias (WriteHandleKey<T> (this->m_decorKey)).isFailure())
+//     return nullptr;
 //   // Important to call the base class method above before calling vectorData;
 //   // otherwise, we'll get an infinite recursion.
 //   // Also don't call getDecorationArray if the container is empty.
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandleKey.h b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandleKey.h
index 2f3bf2a7e96dd9b0cb2c2811a35abde11dd6b176..ec654aea611fb2c78d0dd449313e3ab97a781a60 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandleKey.h
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandleKey.h
@@ -21,8 +21,8 @@
 
 
 #include "AsgDataHandles/DecorKeyHelpers.h"
+#include "AsgDataHandles/ReadHandleKey.h"
 #include "AsgDataHandles/WriteHandleKey.h"
-// #include "StoreGate/ReadHandleKey.h"
 
 
 // class AthAlgorithm;
@@ -81,10 +81,10 @@ public:
    * the store named by @c storeName is used.
    */
   template <class OWNER, class K>
-  WriteDecorHandleKey( OWNER* owner,
-                      const std::string& name,
-                      const K& key = {},
-                      const std::string& doc = "");
+  WriteDecorHandleKey (OWNER* owner,
+                       const std::string& name,
+                       const K& key = {},
+                       const std::string& doc = "");
 
 
   /**
@@ -98,34 +98,34 @@ public:
   WriteDecorHandleKey& operator= (const std::string& sgkey);
 
 
-//   /**
-//    * @brief Change the key of the object to which we're referring.
-//    * @param sgkey The StoreGate key for the object.
-//    * 
-//    * The provided key may actually start with the name of the store,
-//    * separated by a "+":  "MyStore+Obj".  If no "+" is present
-//    * the store is not changed.  A key name that starts with a slash
-//    * is interpreted as a hierarchical key name, not an empty store name.
-//    *
-//    * Returns failure the key string format is bad.
-//    */
-//   virtual StatusCode assign (const std::string& sgkey) override;
+  /**
+   * @brief Change the key of the object to which we're referring.
+   * @param sgkey The StoreGate key for the object.
+   * 
+   * The provided key may actually start with the name of the store,
+   * separated by a "+":  "MyStore+Obj".  If no "+" is present
+   * the store is not changed.  A key name that starts with a slash
+   * is interpreted as a hierarchical key name, not an empty store name.
+   *
+   * Returns failure the key string format is bad.
+   */
+  virtual StatusCode assign (const std::string& sgkey) override;
 
   
-//   /**
-//    * @brief If this object is used as a property, then this should be called
-//    *        during the initialize phase.  It will fail if the requested
-//    *        StoreGate service cannot be found or if the key is blank.
-//    * @param used If false, then this handle is not to be used.
-//    *             Instead of normal initialization, the key will be cleared.
-//    */
-//   StatusCode initialize (bool used = true);
+  /**
+   * @brief If this object is used as a property, then this should be called
+   *        during the initialize phase.  It will fail if the requested
+   *        StoreGate service cannot be found or if the key is blank.
+   * @param used If false, then this handle is not to be used.
+   *             Instead of normal initialization, the key will be cleared.
+   */
+  StatusCode initialize (bool used = true);
 
 
-//   /**
-//    * @brief Return the handle key for the container.
-//    */
-//   const ReadHandleKey<T>& contHandleKey() const;
+  /**
+   * @brief Return the handle key for the container.
+   */
+  const ReadHandleKey<T>& contHandleKey() const;
 
 
 // private:
@@ -141,8 +141,8 @@ public:
 //   ReadHandleKey<T>& contHandleKey_nc();
 
 
-//   /// The container handle.
-//   ReadHandleKey<T> m_contHandleKey;
+  /// The container handle.
+  ReadHandleKey<T> m_contHandleKey;
 };
 
 
diff --git a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandleKey.icc b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandleKey.icc
index 3195daa225c4dbb8d1394352fd2b5a17d5595f7f..20a8004d24311509fec72481cf2df0f32ed2083e 100644
--- a/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandleKey.icc
+++ b/Control/AthToolSupport/AsgDataHandles/AsgDataHandles/WriteDecorHandleKey.icc
@@ -11,7 +11,7 @@
  */
 
 
-// #include "StoreGate/tools/DecorKeyHelpers.h"
+#include "AsgDataHandles/DecorKeyHelpers.h"
 // #include "GaudiKernel/IDataHandleHolder.h"
 
 
@@ -43,8 +43,8 @@ namespace SG {
 template <class T>
 WriteDecorHandleKey<T>::WriteDecorHandleKey (const std::string& key /*= ""*/) :
                                              // const std::string& storeName /*= "StoreGateSvc"*/) :
-  Base (key/*, storeName*/)
-  // m_contHandleKey (contKeyFromKey (key)/*, storeName*/)
+  Base (key/*, storeName*/),
+  m_contHandleKey (contKeyFromKey (key)/*, storeName*/)
 {
 }
 
@@ -69,9 +69,10 @@ WriteDecorHandleKey<T>::WriteDecorHandleKey( OWNER* owner,
                                              const std::string& name,
                                              const K& key /*={}*/,
                                              const std::string& doc /*=""*/)
-  : Base (owner, name, key, doc)
-    // m_contHandleKey (contKeyFromKey (key), StoreID::storeName(StoreID::EVENT_STORE) )
+  : Base (key),
+    m_contHandleKey (contKeyFromKey (key)/*, StoreID::storeName(StoreID::EVENT_STORE) */)
 {
+  owner->declareProperty(name, *this, doc);
 }
 
 
@@ -87,58 +88,58 @@ template <class T>
 WriteDecorHandleKey<T>&
 WriteDecorHandleKey<T>::operator= (const std::string& sgkey)
 {
-  // m_contHandleKey = contKeyFromKey (sgkey);
+  m_contHandleKey = contKeyFromKey (sgkey);
   Base::operator= (sgkey);
   return *this;
 }
 
 
-// /**
-//  * @brief Change the key of the object to which we're referring.
-//  * @param sgkey The StoreGate key for the object.
-//  * 
-//  * The provided key may actually start with the name of the store,
-//  * separated by a "+":  "MyStore+Obj".  If no "+" is present
-//  * the store is not changed.  A key name that starts with a "+"
-//  * is interpreted as a hierarchical key name, not an empty store name.
-//  *
-//  * Returns failure the key string format is bad.
-//  */
-// template <class T>
-// StatusCode WriteDecorHandleKey<T>::assign (const std::string& sgkey)
-// {
-//   if (m_contHandleKey.assign (contKeyFromKey (sgkey)).isFailure())
-//     return StatusCode::FAILURE;
-//   return Base::assign (sgkey);
-// }
+/**
+ * @brief Change the key of the object to which we're referring.
+ * @param sgkey The StoreGate key for the object.
+ * 
+ * The provided key may actually start with the name of the store,
+ * separated by a "+":  "MyStore+Obj".  If no "+" is present
+ * the store is not changed.  A key name that starts with a "+"
+ * is interpreted as a hierarchical key name, not an empty store name.
+ *
+ * Returns failure the key string format is bad.
+ */
+template <class T>
+StatusCode WriteDecorHandleKey<T>::assign (const std::string& sgkey)
+{
+  if (m_contHandleKey.assign (contKeyFromKey (sgkey)).isFailure())
+    return StatusCode::FAILURE;
+  return Base::assign (sgkey);
+}
 
   
-// /**
-//  * @brief If this object is used as a property, then this should be called
-//  *        during the initialize phase.  It will fail if the requested
-//  *        StoreGate service cannot be found or if the key is blank.
-//  *
-//  * @param used If false, then this handle is not to be used.
-//  *             Instead of normal initialization, the key will be cleared.
-//  */
-// template <class T>
-// StatusCode WriteDecorHandleKey<T>::initialize (bool used /*= true*/)
-// {
-//   detail::registerWriteDecorHandleKey (this->owner(), m_contHandleKey.fullKey());
-//   if (m_contHandleKey.initialize (used).isFailure())
-//     return StatusCode::FAILURE;
-//   return Base::initialize (used);
-// }
+/**
+ * @brief If this object is used as a property, then this should be called
+ *        during the initialize phase.  It will fail if the requested
+ *        StoreGate service cannot be found or if the key is blank.
+ *
+ * @param used If false, then this handle is not to be used.
+ *             Instead of normal initialization, the key will be cleared.
+ */
+template <class T>
+StatusCode WriteDecorHandleKey<T>::initialize (bool used /*= true*/)
+{
+  // detail::registerWriteDecorHandleKey (this->owner(), m_contHandleKey.fullKey());
+  if (m_contHandleKey.initialize (used).isFailure())
+    return StatusCode::FAILURE;
+  return Base::initialize (used);
+}
 
 
-// /**
-//  * @brief Return the handle key for the container.
-//  */
-// template <class T>
-// const ReadHandleKey<T>& WriteDecorHandleKey<T>::contHandleKey() const
-// {
-//   return m_contHandleKey;
-// }
+/**
+ * @brief Return the handle key for the container.
+ */
+template <class T>
+const ReadHandleKey<T>& WriteDecorHandleKey<T>::contHandleKey() const
+{
+  return m_contHandleKey;
+}
 
 
 // /**
diff --git a/Control/AthToolSupport/AsgDataHandles/CMakeLists.txt b/Control/AthToolSupport/AsgDataHandles/CMakeLists.txt
index 704ebcb25f506d05cdb4a121a82cfc3a4e9881de..893eb01e1fc75c543b357e819af0c0df8ee6b238 100644
--- a/Control/AthToolSupport/AsgDataHandles/CMakeLists.txt
+++ b/Control/AthToolSupport/AsgDataHandles/CMakeLists.txt
@@ -19,6 +19,6 @@ atlas_add_library( AsgDataHandlesLib
    AsgDataHandles/*.h AsgDataHandles/*.icc Root/*.cxx
    PUBLIC_HEADERS AsgDataHandles
    PRIVATE_INCLUDE_DIRS
-   LINK_LIBRARIES AsgMessagingLib xAODRootAccessInterfaces )
+   LINK_LIBRARIES AthContainers AsgMessagingLib xAODRootAccessInterfaces )
 
 endif()
diff --git a/Control/AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx b/Control/AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx
index 9ad4a6667f0f0158c8a1796c37731a785fc957aa..a32781e4c174a7c66a896292429d37096e65513f 100644
--- a/Control/AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx
+++ b/Control/AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx
@@ -67,7 +67,9 @@ VarHandleKey::VarHandleKey (const std::string& sgkey)
  */
 VarHandleKey& VarHandleKey::operator= (const std::string& sgkey)
 {
-  m_sgKey = sgkey;
+  if (assign (sgkey).isFailure ()) {
+    throw std::runtime_error (std::string("Could not assign VarHandleKey with key ") + sgkey);
+  }
   return *this;
 }
 
diff --git a/Control/AthToolSupport/AsgExampleTools/AsgExampleTools/DataHandleTestTool.h b/Control/AthToolSupport/AsgExampleTools/AsgExampleTools/DataHandleTestTool.h
index e851fa666e9b91070b6aec99cc37ef9a0f489c8c..6595cbaf3b563c2e9196e2b8cbb5050005f08118 100644
--- a/Control/AthToolSupport/AsgExampleTools/AsgExampleTools/DataHandleTestTool.h
+++ b/Control/AthToolSupport/AsgExampleTools/AsgExampleTools/DataHandleTestTool.h
@@ -53,16 +53,20 @@ namespace asg
   public:
 #ifndef SIMULATIONBASE
     SG::ReadHandleKey<xAOD::MuonContainer> m_readKey {this, "readKey", "Muons", "regular read key"};
+    SG::ReadHandleKey<xAOD::MuonContainer> m_readKeyEmpty {this, "readKeyEmpty", "", "regular read key (empty by default)"};
     SG::ReadDecorHandleKey<xAOD::MuonContainer> m_readDecorKey {this, "readDecorKey", "Muons.pt", "read decor key"};
+    SG::ReadDecorHandleKey<xAOD::MuonContainer> m_readDecorKeyEmpty {this, "readDecorKeyEmpty", "", "read decor key (empty by default)"};
     SG::ReadHandleKeyArray<xAOD::MuonContainer> m_readKeyArray {this, "readKeyArray", {}, "array read key"};
     SG::WriteHandleKey<xAOD::MuonContainer> m_writeKey {this, "writeKey", "", "regular write key"};
     SG::WriteDecorHandleKey<xAOD::MuonContainer> m_writeDecorKey {this, "writeDecorKey", "", "write decor key"};
+    SG::WriteDecorHandleKey<xAOD::MuonContainer> m_writeDecorKeyExisting {this, "writeDecorKeyExisting", "", "write decor key (existing)"};
 #endif
     bool m_readFailure {false};
     bool m_readArray {false};
     bool m_readDecorFailure {false};
     std::string m_doWriteName;
     std::string m_doWriteDecorName;
+    std::string m_doWriteDecorNameExisting;
   };
 }
 
diff --git a/Control/AthToolSupport/AsgExampleTools/CMakeLists.txt b/Control/AthToolSupport/AsgExampleTools/CMakeLists.txt
index 96e3f8515f2ee86df5d1de93d6455e6ca0cf38e9..d1b02221d1c7c46281bcac73d46895db07964b99 100644
--- a/Control/AthToolSupport/AsgExampleTools/CMakeLists.txt
+++ b/Control/AthToolSupport/AsgExampleTools/CMakeLists.txt
@@ -98,6 +98,14 @@ if (NOT SIMULATIONBASE)
      set (extra_libs )
    endif()
 
+   if( XAOD_STANDALONE )
+      atlas_add_test( gt_DataHandlesUnitTest
+         SOURCES test/gt_DataHandlesUnitTest.cxx
+         INCLUDE_DIRS ${GTEST_INCLUDE_DIRS}
+         LINK_LIBRARIES ${GTEST_LIBRARIES} AsgDataHandlesLib AsgTestingLib xAODRootAccess)
+      set_tests_properties (AsgExampleTools_gt_DataHandlesUnitTest_ctest PROPERTIES LABELS "AsgDataHandles;AsgExampleTools" )
+   endif()
+
    atlas_add_test( gt_DataHandlesTest
       SOURCES test/gt_DataHandlesTest.cxx
       INCLUDE_DIRS ${GTEST_INCLUDE_DIRS}
diff --git a/Control/AthToolSupport/AsgExampleTools/Root/DataHandleTestTool.cxx b/Control/AthToolSupport/AsgExampleTools/Root/DataHandleTestTool.cxx
index 4248f17db322e26e05065a522b60f4380d53d4b6..452d872ba95c3dd0db151353eb0b29dcb4a4b522 100644
--- a/Control/AthToolSupport/AsgExampleTools/Root/DataHandleTestTool.cxx
+++ b/Control/AthToolSupport/AsgExampleTools/Root/DataHandleTestTool.cxx
@@ -39,6 +39,7 @@ namespace asg
     declareProperty ("readArray", m_readArray, "whether to read from the array");
     declareProperty ("doWriteName", m_doWriteName, "if we should write, the name we expect to write to");
     declareProperty ("doWriteDecorName", m_doWriteDecorName, "if we should write a decoration, the name we expect to write to");
+    declareProperty ("doWriteDecorNameExisting", m_doWriteDecorNameExisting, "if we should try to overwrite an existing decoration, the name we expect to write to");
   }
 
 
@@ -55,12 +56,13 @@ namespace asg
   {
 #ifndef SIMULATIONBASE
     ANA_CHECK (m_readKey.initialize ());
+    ANA_CHECK (m_readKeyEmpty.initialize (!m_readKeyEmpty.empty ()));
     ANA_CHECK (m_readDecorKey.initialize ());
-    if (!m_writeKey.empty())
-      ANA_CHECK (m_writeKey.initialize ());
+    ANA_CHECK (m_readDecorKeyEmpty.initialize (!m_readDecorKeyEmpty.empty ()));
+    ANA_CHECK (m_writeKey.initialize (!m_writeKey.empty()));
     ANA_CHECK (m_readKeyArray.initialize());
-    if (!m_writeDecorKey.empty())
-      ANA_CHECK (m_writeDecorKey.initialize ());
+    ANA_CHECK (m_writeDecorKey.initialize (!m_writeDecorKey.empty ()));
+    ANA_CHECK (m_writeDecorKeyExisting.initialize (!m_writeDecorKeyExisting.empty ()));
 #endif
     return StatusCode::SUCCESS;
   }
@@ -92,9 +94,13 @@ namespace asg
     SG::ReadDecorHandle<xAOD::MuonContainer,float> readDecorHandle (m_readDecorKey);
     if (m_readDecorFailure == true)
     {
+      EXPECT_TRUE(readDecorHandle.isPresent());
+      EXPECT_FALSE(readDecorHandle.isAvailable());
       EXPECT_ANY_THROW (readDecorHandle (*testMuon));
     } else
     {
+      EXPECT_TRUE(readDecorHandle.isPresent());
+      EXPECT_TRUE(readDecorHandle.isAvailable());
       SG::AuxElement::ConstAccessor<float> acc ("pt");
       EXPECT_EQ (acc (*testMuon), readDecorHandle (*testMuon));
     }
@@ -128,10 +134,19 @@ namespace asg
     if (!m_doWriteDecorName.empty())
     {
       auto writeDecorHandle = SG::makeHandle<unsigned> (m_writeDecorKey);
+      EXPECT_TRUE(writeDecorHandle.isPresent());
+      EXPECT_FALSE(writeDecorHandle.isAvailable());
       writeDecorHandle (*(*muonsStore)[0]) = 42u;
       SG::AuxElement::ConstAccessor<unsigned> acc (m_doWriteDecorName);
       EXPECT_EQ (42u, acc (*(*muonsStore)[0]));
     }
+
+    if (!m_doWriteDecorNameExisting.empty())
+    {
+      auto writeDecorHandleExisting = SG::makeHandle<float> (m_writeDecorKeyExisting);
+      EXPECT_TRUE(writeDecorHandleExisting.isPresent());
+      EXPECT_TRUE(writeDecorHandleExisting.isAvailable());
+    }
 #endif
   }
 }
diff --git a/Control/AthToolSupport/AsgExampleTools/test/gt_AnaToolHandle_test.cxx b/Control/AthToolSupport/AsgExampleTools/test/gt_AnaToolHandle_test.cxx
index c5556a927911a4a7e846f4df44341070a2ed04ca..78450a8ee9fe6b686ad10e5608f440e0d4853e8c 100644
--- a/Control/AthToolSupport/AsgExampleTools/test/gt_AnaToolHandle_test.cxx
+++ b/Control/AthToolSupport/AsgExampleTools/test/gt_AnaToolHandle_test.cxx
@@ -1034,16 +1034,23 @@ namespace asg
     std::make_tuple ("anaPublicHandle",  "public",  "NOINIT"),
     std::make_tuple ("regPublicHandle",  "public",  "empty"),
     std::make_tuple ("anaPublicHandle",  "public",  "empty"),
-    std::make_tuple ("regPrivateHandle", "private", "ATH"),
-    std::make_tuple ("anaPrivateHandle", "private", "ATH"),
-    std::make_tuple ("regPrivateHandle", "private", "TH"),
-    std::make_tuple ("anaPrivateHandle", "private", "TH"),
-    std::make_tuple ("regPrivateHandle", "private", "NOINIT"),
-    std::make_tuple ("anaPrivateHandle", "private", "NOINIT"),
     std::make_tuple ("regPrivateHandle", "private", "empty"),
     std::make_tuple ("anaPrivateHandle", "private", "empty"),
     std::make_tuple ("regPrivateHandle", "private", "none"),
     std::make_tuple ("anaPrivateHandle", "private", "none")));
+
+  // these tests no longer work in Athena since the migration to
+  // IOptionsSvc
+#ifdef XAOD_STANDALONE
+  INSTANTIATE_TEST_SUITE_P
+  (MySubtoolTest2, SubtoolTest, ::testing::Values
+   (std::make_tuple ("regPrivateHandle", "private", "ATH"),
+    std::make_tuple ("anaPrivateHandle", "private", "ATH"),
+    std::make_tuple ("regPrivateHandle", "private", "TH"),
+    std::make_tuple ("anaPrivateHandle", "private", "TH"),
+    std::make_tuple ("regPrivateHandle", "private", "NOINIT"),
+    std::make_tuple ("anaPrivateHandle", "private", "NOINIT")));
+#endif
 }
 
 ATLAS_GOOGLE_TEST_MAIN
diff --git a/Control/AthToolSupport/AsgExampleTools/test/gt_DataHandlesTest.cxx b/Control/AthToolSupport/AsgExampleTools/test/gt_DataHandlesTest.cxx
index b95079f43ba89d70797e43101ad6479ddeae06b1..9302fdd383b3fe9e874a4996ca524df36d9af5d7 100644
--- a/Control/AthToolSupport/AsgExampleTools/test/gt_DataHandlesTest.cxx
+++ b/Control/AthToolSupport/AsgExampleTools/test/gt_DataHandlesTest.cxx
@@ -14,6 +14,7 @@
 #include <AsgMessaging/MessageCheck.h>
 #include <AsgTesting/UnitTest.h>
 #include <AsgExampleTools/IDataHandleTestTool.h>
+#include <TClass.h>
 #include <TFile.h>
 #include <cmath>
 #include <gtest/gtest.h>
@@ -40,6 +41,10 @@ namespace asg
   {
     static void SetUpTestCase ()
     {
+      // Access the dictionary
+      ASSERT_NE (TClass::GetClass ("xAOD::MuonContainer"), nullptr);
+      ASSERT_NE (TClass::GetClass ("asg::DataHandleTestTool"), nullptr);
+
       const char *test_file = getenv ("ASG_TEST_FILE_MC");
       ASSERT_NE (nullptr, test_file);
       file.reset (TFile::Open (test_file, "READ"));
@@ -149,6 +154,28 @@ namespace asg
     ASSERT_SUCCESS (config.makeTool (tool, cleanup));
     tool->runTest ();
   }
+
+
+
+  // do an existing write decor handle test
+  TEST_F (DataHandlesTest, write_decor_handle_existing)
+  {
+    config.setPropertyFromString ("writeDecorKeyExisting", "Muons.pt");
+    config.setPropertyFromString ("doWriteDecorNameExisting", "pt");
+    ASSERT_SUCCESS (config.makeTool (tool, cleanup));
+    tool->runTest ();
+  }
+
+
+
+  // empty initial handles
+  TEST_F (DataHandlesTest, empty_initial_handles)
+  {
+    config.setPropertyFromString ("readKeyEmpty", "Muons");
+    config.setPropertyFromString ("readDecorKeyEmpty", "Muons.eta");
+    ASSERT_SUCCESS (config.makeTool (tool, cleanup));
+    tool->runTest ();
+  }
 }
 
 ATLAS_GOOGLE_TEST_MAIN
diff --git a/Control/AthToolSupport/AsgExampleTools/test/gt_DataHandlesUnitTest.cxx b/Control/AthToolSupport/AsgExampleTools/test/gt_DataHandlesUnitTest.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..8951cc9e64f97bbbfcd3e0ac74967f53e18d1215
--- /dev/null
+++ b/Control/AthToolSupport/AsgExampleTools/test/gt_DataHandlesUnitTest.cxx
@@ -0,0 +1,161 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
+#include <AsgDataHandles/ReadDecorHandle.h>
+#include <AsgDataHandles/ReadDecorHandleKey.h>
+#include <AsgDataHandles/ReadHandle.h>
+#include <AsgDataHandles/ReadHandleKey.h>
+#include <AsgDataHandles/WriteDecorHandle.h>
+#include <AsgDataHandles/WriteDecorHandleKey.h>
+#include <AsgDataHandles/WriteHandle.h>
+#include <AsgDataHandles/WriteHandleKey.h>
+#include <AsgTesting/UnitTest.h>
+#include <AsgTools/CurrentContext.h>
+#include <xAODCore/CLASS_DEF.h>
+#include <xAODRootAccess/TEvent.h>
+#include <gtest/gtest.h>
+
+
+class MyObj
+{
+public:
+  MyObj(int x=0) : x(x) {}
+  int x;
+};
+CLASS_DEF (MyObj, 293847295, 1)
+
+
+namespace asg
+{
+  struct DataHandlesUnitTest : public ::testing::Test
+  {
+    virtual void SetUp () override
+    {
+    }
+
+    xAOD::TEvent event;
+  };
+
+  // ReadHandle
+  TEST_F (DataHandlesUnitTest, ReadHandle)
+  {
+    SG::ReadHandleKey<MyObj> k1 ("aaa");
+    // ASSERT_EQ (k1.clid(), 293847295);
+    ASSERT_EQ (k1.key(), "aaa");
+    ASSERT_SUCCESS (k1.initialize());
+
+    k1 = "aab";
+    // ASSERT_EQ (k1.clid(), 293847295);
+    ASSERT_EQ (k1.key(), "aab");
+
+    SG::ReadHandleKey<MyObj> k2 ("asd");
+    ASSERT_SUCCESS (k2.initialize());
+    SG::ReadHandle<MyObj> h2 (k2);
+    // ASSERT_EQ (h2.clid(), 293847295);
+    ASSERT_EQ (h2.key(), "asd");
+
+    const EventContext &ctx3 = Gaudi::Hive::currentContext();
+    SG::ReadHandle<MyObj> h3 (k2, ctx3);
+    // ASSERT_EQ (h3.clid(), 293847295);
+    ASSERT_EQ (h3.key(), "asd");
+  }
+
+  // WriteHandle
+  TEST_F (DataHandlesUnitTest, WriteHandle)
+  {
+    SG::WriteHandleKey<MyObj> k1 ("aaa");
+    // ASSERT_EQ (k1.clid(), 293847295);
+    ASSERT_EQ (k1.key(), "aaa");
+    ASSERT_SUCCESS (k1.initialize());
+
+    k1 = "aab";
+    // ASSERT_EQ (k1.clid(), 293847295);
+    ASSERT_EQ (k1.key(), "aab");
+
+    SG::WriteHandleKey<MyObj> k2 ("asd");
+    ASSERT_SUCCESS (k2.initialize());
+    SG::WriteHandle<MyObj> h2 (k2);
+    // ASSERT_EQ (h2.clid(), 293847295);
+    ASSERT_EQ (h2.key(), "asd");
+
+    const EventContext &ctx3 = Gaudi::Hive::currentContext();
+    SG::WriteHandle<MyObj> h3 (k2, ctx3);
+    // ASSERT_EQ (h3.clid(), 293847295);
+    ASSERT_EQ (h3.key(), "asd");
+  }
+
+
+  // ReadDecorHandle
+  TEST_F (DataHandlesUnitTest, ReadDecorHandle)
+  {
+    SG::ReadDecorHandleKey<MyObj> k1 ("aaa.dec");
+    // ASSERT_EQ (k1.clid(), 293847295);
+    ASSERT_EQ (k1.key(), "aaa.dec");
+    ASSERT_SUCCESS (k1.initialize());
+
+    // ASSERT_EQ (k1.contHandleKey().clid(), 293847295);
+    ASSERT_EQ (k1.contHandleKey().key(), "aaa");
+
+    k1 = "bbb.foo";
+    ASSERT_EQ (k1.key(), "bbb.foo");
+    ASSERT_EQ (k1.contHandleKey().key(), "bbb");
+
+    ASSERT_SUCCESS (k1.assign ("ccc.fee"));
+    ASSERT_EQ (k1.key(), "ccc.fee");
+    ASSERT_EQ (k1.contHandleKey().key(), "ccc");
+
+    SG::ReadDecorHandleKey<MyObj> k2 ("asd.aaa");
+    ASSERT_SUCCESS (k2.initialize());
+
+    SG::ReadDecorHandle<MyObj, int> h1 (k2);
+    // ASSERT_EQ (h1.clid(), 293847295);
+    ASSERT_EQ (h1.key(), "asd");
+    ASSERT_EQ (h1.decorKey(), "asd.aaa");
+    ASSERT_FALSE (h1.isPresent());
+
+    const EventContext &ctx2 = Gaudi::Hive::currentContext();
+    SG::ReadDecorHandle<MyObj, int> h2 (k2, ctx2);
+    // ASSERT_EQ (h2.clid(), 293847295);
+    ASSERT_EQ (h2.key(), "asd");
+    ASSERT_EQ (h2.decorKey(), "asd.aaa");
+  }
+
+  // WriteDecorHandle
+  TEST_F (DataHandlesUnitTest, WriteDecorHandle)
+  {
+    SG::WriteDecorHandleKey<MyObj> k1 ("aaa.dec");
+    // ASSERT_EQ (k1.clid(), 293847295);
+    ASSERT_EQ (k1.key(), "aaa.dec");
+    ASSERT_SUCCESS (k1.initialize());
+
+    // ASSERT_EQ (k1.contHandleKey().clid(), 293847295);
+    ASSERT_EQ (k1.contHandleKey().key(), "aaa");
+
+    k1 = "bbb.foo";
+    ASSERT_EQ (k1.key(), "bbb.foo");
+    ASSERT_EQ (k1.contHandleKey().key(), "bbb");
+
+    ASSERT_SUCCESS (k1.assign ("ccc.fee"));
+    ASSERT_EQ (k1.key(), "ccc.fee");
+    ASSERT_EQ (k1.contHandleKey().key(), "ccc");
+
+    SG::WriteDecorHandleKey<MyObj> k2 ("asd.aaa");
+    ASSERT_SUCCESS (k2.initialize());
+
+    SG::WriteDecorHandle<MyObj, int> h1 (k2);
+    // ASSERT_EQ (h1.clid(), 293847295);
+    ASSERT_EQ (h1.key(), "asd");
+    ASSERT_EQ (h1.decorKey(), "asd.aaa");
+    ASSERT_FALSE (h1.isPresent());
+
+    const EventContext &ctx2 = Gaudi::Hive::currentContext();
+    SG::WriteDecorHandle<MyObj, int> h2 (k2, ctx2);
+    // ASSERT_EQ (h2.clid(), 293847295);
+    ASSERT_EQ (h2.key(), "asd");
+    ASSERT_EQ (h2.decorKey(), "asd.aaa");
+  }
+
+}
+
+ATLAS_GOOGLE_TEST_MAIN
diff --git a/Control/AthToolSupport/AsgTools/AsgTools/AnaToolHandle.icc b/Control/AthToolSupport/AsgTools/AsgTools/AnaToolHandle.icc
index 4ff0fa22fd02d70e3f7a6fc3e4bc1b21464beab1..a350041179f428319bed242818760ee62a8f3157 100644
--- a/Control/AthToolSupport/AsgTools/AsgTools/AnaToolHandle.icc
+++ b/Control/AthToolSupport/AsgTools/AsgTools/AnaToolHandle.icc
@@ -11,7 +11,7 @@
 #include <cstdlib>
 
 #ifndef XAOD_STANDALONE
-#include "GaudiKernel/IJobOptionsSvc.h"
+#include "Gaudi/Interfaces/IOptionsSvc.h"
 #endif
 
 
diff --git a/Control/AthToolSupport/AsgTools/Root/AnaToolHandle.cxx b/Control/AthToolSupport/AsgTools/Root/AnaToolHandle.cxx
index 1687aae831eec9c369575bba743805c1f07f43e6..4883aec3241a19b5f09d3bce392b21d58c9ad217 100644
--- a/Control/AthToolSupport/AsgTools/Root/AnaToolHandle.cxx
+++ b/Control/AthToolSupport/AsgTools/Root/AnaToolHandle.cxx
@@ -24,7 +24,7 @@
 #include <GaudiKernel/AlgTool.h>
 #include <AsgMessaging/MessageCheck.h>
 #include <GaudiKernel/IToolSvc.h>
-#include <GaudiKernel/IJobOptionsSvc.h>
+#include "Gaudi/Interfaces/IOptionsSvc.h"
 #endif
 
 //
@@ -187,11 +187,16 @@ namespace asg
   namespace detail
   {
    StatusCode hasPropertiesInCatalogue( const std::string& toolName ) {
-      ServiceHandle<IJobOptionsSvc> svc("JobOptionsSvc","AnaToolHandle");
+      ServiceHandle<Gaudi::Interfaces::IOptionsSvc> svc("JobOptionsSvc","AnaToolHandle");
       if( svc.retrieve().isFailure() ) return StatusCode::FAILURE;
-      auto props = svc->getProperties(toolName);
+      auto props = svc->items(std::regex("^" + toolName + "\\."));
       StatusCode out = StatusCode::FAILURE;
-      if( props && props->size()>0 ) out = StatusCode::SUCCESS;
+      for (auto& prop : svc->items())
+      {
+        if (std::get<0>(prop).substr (0, toolName.size()) == toolName &&
+            std::get<0>(prop)[toolName.size()] == '.')
+          out = StatusCode::SUCCESS;
+      }
       svc.release().ignore();
       //delete props;
       return out;
@@ -199,15 +204,9 @@ namespace asg
 
     StatusCode addPropertyToCatalogue( const std::string& toolName, const std::string& propertyName, const std::string& propertyValue ) {
 //std::cout << "Adding " << toolName << " ." << propertyName << " = " << propertyValue << std::endl;
-      ServiceHandle<IJobOptionsSvc> joSvc("JobOptionsSvc","AnaToolHandle");
+      ServiceHandle<Gaudi::Interfaces::IOptionsSvc> joSvc("JobOptionsSvc","AnaToolHandle");
       //check if propertyName contains '.' . If it does, then assume settng a property of a private tool, so adjust toolname
-      std::string theToolName = toolName; std::string thePropertyName=propertyName;
-      std::string::size_type dotLocation = thePropertyName.find_last_of('.');
-      if(dotLocation != std::string::npos) {
-         theToolName = toolName + "." + thePropertyName.substr(0,dotLocation);
-         thePropertyName = thePropertyName.substr(dotLocation+1,thePropertyName.length()-dotLocation);
-      }
-      if(joSvc->addPropertyToCatalogue( theToolName , StringProperty(thePropertyName,propertyValue) ).isFailure()) return StatusCode::FAILURE;
+      joSvc->set( toolName + "." + propertyName, propertyValue );
       if(joSvc.release().isFailure()) return StatusCode::FAILURE;
       return StatusCode::SUCCESS;
    }
@@ -215,7 +214,7 @@ namespace asg
 
 
    StatusCode removePropertyFromCatalogue( const std::string& toolName, const std::string& propertyName ) {
-      ServiceHandle<IJobOptionsSvc> joSvc("JobOptionsSvc","AnaToolHandle");
+      ServiceHandle<Gaudi::Interfaces::IOptionsSvc> joSvc("JobOptionsSvc","AnaToolHandle");
       //check if propertyName contains '.' . If it does, then assume settng a property of a private tool, so adjust toolname
       std::string theToolName = toolName; std::string thePropertyName=propertyName;
       std::string::size_type dotLocation = thePropertyName.find_last_of('.');
@@ -223,7 +222,7 @@ namespace asg
          theToolName = toolName + "." + thePropertyName.substr(0,dotLocation);
          thePropertyName = thePropertyName.substr(dotLocation+1,thePropertyName.length()-dotLocation);
       }
-      if(joSvc->removePropertyFromCatalogue( theToolName , thePropertyName ).isFailure()) return StatusCode::FAILURE;
+      joSvc->pop( theToolName + "." + thePropertyName );
       if(joSvc.release().isFailure()) return StatusCode::FAILURE;
       return StatusCode::SUCCESS;
    }
@@ -254,23 +253,11 @@ namespace asg
 //std::cout << "copy : " << fromTool << " -> " << toTool << std::endl;
       if(fromTool == toTool) return StatusCode::SUCCESS; //nothing to do
 
-      ServiceHandle<IJobOptionsSvc> joSvc("JobOptionsSvc","AnaToolHandle");
-      auto fromProps = joSvc->getProperties(fromTool);
-      if(fromProps) {
-         for(auto prop : *fromProps) {
-            ANA_CHECK( joSvc->addPropertyToCatalogue( toTool , *prop ) );
-         }
-         for(auto prop : *fromProps) {
-            ANA_CHECK( joSvc->removePropertyFromCatalogue( fromTool , prop->name() ) );
-         }
-      }
-      //now also check for subtools which will need copying over 
-      auto clients = joSvc->getClients();
-      for(auto& client : clients) {
-         if(client.find(fromTool+".") == 0 && client!=fromTool) {
-            std::string newClient(client); newClient.replace(0,strlen(fromTool.c_str()),toTool);
-            ANA_CHECK( copyPropertiesInCatalogue( client , newClient ) );
-         }
+      ServiceHandle<Gaudi::Interfaces::IOptionsSvc> joSvc("JobOptionsSvc","AnaToolHandle");
+      auto fromProps = joSvc->items(std::regex ("^" + fromTool));
+      for(auto& prop : fromProps) {
+        std::get<0>(prop).replace (0, fromTool.size(), toTool);
+        joSvc->set( std::get<0>(prop) , std::get<1>(prop) );
       }
       if(joSvc.release().isFailure()) return StatusCode::FAILURE;
       return StatusCode::SUCCESS;
diff --git a/Control/AthToolSupport/AsgTools/Root/AsgComponentConfig.cxx b/Control/AthToolSupport/AsgTools/Root/AsgComponentConfig.cxx
index a36a30bb57ead9e2665f6d5c7fbfb83c8e2c4ed4..f8c2fa148956fb7426bc1ce16df3d0e58ceffaf7 100644
--- a/Control/AthToolSupport/AsgTools/Root/AsgComponentConfig.cxx
+++ b/Control/AthToolSupport/AsgTools/Root/AsgComponentConfig.cxx
@@ -24,7 +24,7 @@
 
 #else
 
-#include <GaudiKernel/IJobOptionsSvc.h>
+#include "Gaudi/Interfaces/IOptionsSvc.h"
 #include <GaudiKernel/ServiceHandle.h>
 
 #endif
@@ -360,7 +360,7 @@ namespace asg
 
     ANA_CHECK (checkTypeName (nestedNames));
 
-    ServiceHandle<IJobOptionsSvc> joSvc("JobOptionsSvc","AsgComponentConfig");
+    ServiceHandle<Gaudi::Interfaces::IOptionsSvc> joSvc("JobOptionsSvc","AsgComponentConfig");
     ANA_CHECK (joSvc.retrieve());
 
     for (const auto& tool : m_privateTools)
@@ -368,19 +368,13 @@ namespace asg
       std::string toolPath = prefix + m_name + "." + tool.first;
       const auto split = toolPath.rfind ('.');
       std::string toolName = toolPath.substr (split+1);
-      std::string parentName = toolPath.substr (0, split);
-      StringProperty athenaProperty (toolName, tool.second + "/" + toolName);
-      ANA_CHECK (joSvc->addPropertyToCatalogue (parentName, std::move (athenaProperty)));
+      joSvc->set (toolPath, tool.second + "/" + toolName);
     }
 
     for (const auto& property : m_propertyValues)
     {
       std::string propertyPath = prefix + m_name + "." + property.first;
-      const auto split = propertyPath.rfind ('.');
-      std::string propertyName = propertyPath.substr (split+1);
-      std::string componentName = propertyPath.substr (0, split);
-      StringProperty athenaProperty (propertyName, property.second);
-      ANA_CHECK (joSvc->addPropertyToCatalogue (componentName, std::move (athenaProperty)));
+      joSvc->set (propertyPath, property.second);
     }
 
     return StatusCode::SUCCESS;
diff --git a/Control/AthenaConfiguration/python/AllConfigFlags.py b/Control/AthenaConfiguration/python/AllConfigFlags.py
index 49b4594f5ee89604fd444dedb72a85bb942c2122..137186d0313e87ab866d1817b0f29bec2e6752e3 100644
--- a/Control/AthenaConfiguration/python/AllConfigFlags.py
+++ b/Control/AthenaConfiguration/python/AllConfigFlags.py
@@ -53,7 +53,9 @@ def _createCfgFlags():
     acf.addFlag('Scheduler.ShowDataDeps', True)
     acf.addFlag('Scheduler.ShowDataFlow', True)
     acf.addFlag('Scheduler.ShowControlFlow', True)
+    acf.addFlag('Scheduler.EnableVerboseViews', True)
 
+    acf.addFlag('Common.MsgSourceLength',50) #Lenght of the source-field in the format str of MessageSvc
     acf.addFlag('Common.isOnline', False ) #  Job runs in an online environment (access only to resources available at P1) # former global.isOnline
     acf.addFlag('Common.useOnlineLumi', lambda prevFlags : prevFlags.Common.isOnline ) #  Use online version of luminosity. ??? Should just use isOnline?
     acf.addFlag('Common.doExpressProcessing', False)
diff --git a/Control/AthenaConfiguration/python/MainServicesConfig.py b/Control/AthenaConfiguration/python/MainServicesConfig.py
index 666aa64607dbc014a0b169ac85f2b92bcddfbd9d..5755cf0f5369f9ab91506c6e9033d95e70dd7909 100644
--- a/Control/AthenaConfiguration/python/MainServicesConfig.py
+++ b/Control/AthenaConfiguration/python/MainServicesConfig.py
@@ -84,6 +84,7 @@ def MainServicesCfg(cfgFlags, LoopMgr='AthenaEventLoopMgr'):
 
     msgsvc=CompFactory.MessageSvc()
     msgsvc.OutputLevel=cfgFlags.Exec.OutputLevel
+    msgsvc.Format = "% F%{:d}W%C%7W%R%T %0W%M".format(cfgFlags.Common.MsgSourceLength)
     cfg.addService(msgsvc)
 
     if cfgFlags.Exec.DebugStage != "":
@@ -97,7 +98,7 @@ def MainServicesCfg(cfgFlags, LoopMgr='AthenaEventLoopMgr'):
         # Migrated code from AtlasThreadedJob.py
         AuditorSvc=CompFactory.AuditorSvc
         msgsvc.defaultLimit = 0
-        msgsvc.Format = "% F%40W%S%4W%R%e%s%8W%R%T %0W%M"
+        msgsvc.Format = "% F%{:d}W%C%4W%R%e%s%8W%R%T %0W%M".format(cfgFlags.Common.MsgSourceLength)
 
         SG__HiveMgrSvc=CompFactory.SG.HiveMgrSvc
         hivesvc = SG__HiveMgrSvc("EventDataSvc")
@@ -116,6 +117,7 @@ def MainServicesCfg(cfgFlags, LoopMgr='AthenaEventLoopMgr'):
         scheduler.ShowDataDependencies = cfgFlags.Scheduler.ShowDataDeps
         scheduler.ShowDataFlow         = cfgFlags.Scheduler.ShowDataFlow
         scheduler.ShowControlFlow      = cfgFlags.Scheduler.ShowControlFlow
+        scheduler.VerboseSubSlots      = cfgFlags.Scheduler.EnableVerboseViews
         scheduler.ThreadPoolSize       = cfgFlags.Concurrency.NumThreads
         cfg.addService(scheduler)
 
diff --git a/Control/AthenaExamples/AthExOnnxRuntime/CMakeLists.txt b/Control/AthenaExamples/AthExOnnxRuntime/CMakeLists.txt
index 8361d3a13413f4d417dd25d03cdceedfc09d0c6e..2cf4c6266bf76455785f1d518a18c77a02562daf 100644
--- a/Control/AthenaExamples/AthExOnnxRuntime/CMakeLists.txt
+++ b/Control/AthenaExamples/AthExOnnxRuntime/CMakeLists.txt
@@ -3,9 +3,6 @@
 # Declare the package's name.
 atlas_subdir( AthExOnnxRuntime )
 
-# External dependencies.
-find_package( onnxruntime )
-
 # Component(s) in the package.
 atlas_add_library( AthExOnnxRuntimeLib
    INTERFACE
@@ -25,6 +22,7 @@ atlas_install_joboptions( share/*.py )
 atlas_add_test( AthExOnnxRuntimeJob_serial
    SCRIPT athena.py AthExOnnxRuntime/AthExOnnxRuntime_jobOptions.py )
 
+
 atlas_add_test( AthExOnnxRuntimeJob_mt
    SCRIPT athena.py --threads=2
           AthExOnnxRuntime/AthExOnnxRuntime_jobOptions.py )
diff --git a/Control/AthenaExamples/AthExOnnxRuntime/README.md b/Control/AthenaExamples/AthExOnnxRuntime/README.md
index 34afcb68bea518c13b3f5b95e7df3a72d248ab53..79efde7c57245e7fb133de8baa11f9f976d5a363 100644
--- a/Control/AthenaExamples/AthExOnnxRuntime/README.md
+++ b/Control/AthenaExamples/AthExOnnxRuntime/README.md
@@ -4,37 +4,48 @@ This package is meant to hold code demonstrating how to use onnxruntime
 from Athena.
 
 The package loads a MNIST_testModel.onnx model previously trained to recognize 
-handwritten digits in the form of 28x28 pixels from `0 to 9`.
-
-The package further loads test pixel dataset and their labels. CxxApiAlgorithm
+handwritten digits in the form of 28x28 pixels from `0 to 9`. When Run in a DEBUG
+mode the logistics of the input and output layers can be seen 
+```
+AthONNX             DEBUG Input 0 :  name= flatten_input:0
+AthONNX             DEBUG Input 0 : num_dims= 3
+AthONNX             DEBUG Input 0 : dim 0= -1
+AthONNX             DEBUG Input 0 : dim 1= 28
+AthONNX             DEBUG Input 0 : dim 2= 28
+AthONNX             DEBUG Output 0 :  name= dense_1/Softmax:0
+AthONNX             DEBUG Output 0 : num_dims= 2
+AthONNX             DEBUG Output 0 : dim 0= -1
+AthONNX             DEBUG Output 0 : dim 1= 10
+``` 
+The `dim 0= -1` always represents the batch size and ready to take any intger no. The model in this
+example package has provition to run both No-BatchMode and BatchMode. For No-BatchMode `dim 0= 1` for
+BatchMode `dim 0= batch size`
+
+The package further loads test pixel dataset and their labels. When not running in batch mode EvaluateModel 
 randomly picks a sample from the dataset and passes through MNIST_testModel.onnx
 model and predicts its value among 0 to 9. The highest probable(score) value should
 match with actual label of the sample e.g.:
 ```
-AthONNX              INFO Label for the input test data  = 9
-AthONNX              INFO Score for class 0 = 3.32061e-09
-
-AthONNX              INFO Score for class 1 = 1.52828e-08
-
-AthONNX              INFO Score for class 2 = 3.08599e-08
-
-AthONNX              INFO Score for class 3 = 1.14768e-07
-
-AthONNX              INFO Score for class 4 = 2.05344e-05
-
-AthONNX              INFO Score for class 5 = 1.54014e-11
-
-AthONNX              INFO Score for class 6 = 1.0932e-10
-
-AthONNX              INFO Score for class 7 = 0.000205113
-
-AthONNX              INFO Score for class 8 = 5.37525e-08
-
-AthONNX              INFO Score for class 9 = 0.999774
-
-AthONNX              INFO Class: 9 has the highest score: 0.999774
+INFO Label for the input test data  = 1
+AthONNX             DEBUG Score for class 0 = 1.07293e-07
+AthONNX             DEBUG Score for class 1 = 0.999818
+AthONNX             DEBUG Score for class 2 = 1.18024e-05
+AthONNX             DEBUG Score for class 3 = 2.53529e-05
+AthONNX             DEBUG Score for class 4 = 4.19157e-06
+AthONNX             DEBUG Score for class 5 = 1.66088e-06
+AthONNX             DEBUG Score for class 6 = 7.7723e-06
+AthONNX             DEBUG Score for class 7 = 6.33801e-05
+AthONNX             DEBUG Score for class 8 = 5.83467e-05
+AthONNX             DEBUG Score for class 9 = 9.74693e-06
+AthONNX              INFO Class: 1 has the highest score: 0.999818
 ```
 The above result can be obtained by running `athena AthExOnnxRuntime_jobOptions.py`
-in your run directory
+in your run directory. Edit AthExOnnxRuntime_jobOptions.py's `AthONNX.DoBatches = False` to run in No Batch
+mode.
+
+To Run in Batch mode edit `AthONNX.DoBatches = True` and provide number of batches and each batch size to
+`AthONNX.NumberOfBatches` and to `AthONNX.SizeOfBatch` respectively.
+
+Fyi. by default the algorithms will run in No-Batch mode 
 
 
diff --git a/Control/AthenaExamples/AthExOnnxRuntime/share/AthExOnnxRuntime_jobOptions.py b/Control/AthenaExamples/AthExOnnxRuntime/share/AthExOnnxRuntime_jobOptions.py
index 20b057cc213ca497ee730ff39148bc74260d331a..ac1beaef5aeb13e9bd1ac3bf12cb308e5face1a4 100644
--- a/Control/AthenaExamples/AthExOnnxRuntime/share/AthExOnnxRuntime_jobOptions.py
+++ b/Control/AthenaExamples/AthExOnnxRuntime/share/AthExOnnxRuntime_jobOptions.py
@@ -5,17 +5,21 @@ from AthenaCommon.AlgSequence import AlgSequence
 algSequence = AlgSequence()
 
 # Set up the job.
-from AthExOnnxRuntime.AthExOnnxRuntimeConf import AthONNX__CxxApiAlgorithm
+from AthExOnnxRuntime.AthExOnnxRuntimeConf import AthONNX__EvaluateModel
 from AthOnnxruntimeService.AthOnnxruntimeServiceConf import AthONNX__ONNXRuntimeSvc
 
 from AthenaCommon.AppMgr import ServiceMgr
 ServiceMgr += AthONNX__ONNXRuntimeSvc( OutputLevel = DEBUG )
-algSequence += AthONNX__CxxApiAlgorithm("AthONNX")
+algSequence += AthONNX__EvaluateModel("AthONNX")
 
 # Get a	random no. between 0 to	10k for	test sample
 from random import randint
 
 AthONNX = algSequence.AthONNX
 AthONNX.TestSample = randint(0, 9999)
+AthONNX.DoBatches = False
+AthONNX.NumberOfBatches = 1
+AthONNX.SizeOfBatch = 1
+
 # Run for 10 "events".
-theApp.EvtMax = 10
+theApp.EvtMax = 2
diff --git a/Control/AthenaExamples/AthExOnnxRuntime/src/CxxApiAlgorithm.cxx b/Control/AthenaExamples/AthExOnnxRuntime/src/CxxApiAlgorithm.cxx
deleted file mode 100644
index 0efc2041879050a1e390be7f9e7d716527da51c8..0000000000000000000000000000000000000000
--- a/Control/AthenaExamples/AthExOnnxRuntime/src/CxxApiAlgorithm.cxx
+++ /dev/null
@@ -1,198 +0,0 @@
-// Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-
-// Local include(s).
-#include "CxxApiAlgorithm.h"
-
-// Framework include(s).
-#include "PathResolver/PathResolver.h"
-
-namespace AthONNX {
-
-   //*******************************************************************
-   // for reading MNIST images
-   std::vector<std::vector<float>> read_mnist_pixel(const std::string &full_path) //function to load test images
-   {
-     std::vector<std::vector<float>> input_tensor_values;
-     input_tensor_values.resize(10000, std::vector<float>(28*28*1));  
-     std::ifstream file (full_path.c_str(), std::ios::binary);
-     int magic_number=0;
-     int number_of_images=0;
-     int n_rows=0;
-     int n_cols=0;
-     file.read((char*)&magic_number,sizeof(magic_number));
-     magic_number= ntohl(magic_number);
-     file.read((char*)&number_of_images,sizeof(number_of_images));
-     number_of_images= ntohl(number_of_images);
-     file.read((char*)&n_rows,sizeof(n_rows));
-     n_rows= ntohl(n_rows);
-     file.read((char*)&n_cols,sizeof(n_cols));
-     n_cols= ntohl(n_cols);
-     for(int i=0;i<number_of_images;++i)
-     {
-        for(int r=0;r<n_rows;++r)
-        {
-           for(int c=0;c<n_cols;++c)
-           {
-             unsigned char temp=0;
-             file.read((char*)&temp,sizeof(temp));
-             input_tensor_values[i][r*n_cols+c]= float(temp)/255;
-           }
-        }
-     }
-     return input_tensor_values;
-   }
-
-   //********************************************************************************
-   // for reading MNIST labels
-   std::vector<int> read_mnist_label(const std::string &full_path) //function to load test labels
-   {
-     std::vector<int> output_tensor_values(1*10000);
-     std::ifstream file (full_path.c_str(), std::ios::binary);
-     int magic_number=0;
-     int number_of_labels=0;
-     file.read((char*)&magic_number,sizeof(magic_number));
-     magic_number= ntohl(magic_number);
-     file.read((char*)&number_of_labels,sizeof(number_of_labels));
-     number_of_labels= ntohl(number_of_labels);
-     for(int i=0;i<number_of_labels;++i)
-     {
-          unsigned char temp=0;
-          file.read((char*)&temp,sizeof(temp));
-          output_tensor_values[i]= int(temp);
-     }
-      return output_tensor_values;
-    }
-
-   StatusCode CxxApiAlgorithm::initialize() {
-
-      // Access the service.
-      ATH_CHECK( m_svc.retrieve() );
-
-      // Find the model file.
-      const std::string modelFileName =
-         PathResolverFindCalibFile( m_modelFileName );
-      const std::string pixelFileName =
-         PathResolverFindCalibFile( m_pixelFileName );
-      const std::string labelFileName =
-         PathResolverFindCalibFile( m_labelFileName );
-      ATH_MSG_INFO( "Using model file: " << modelFileName );
-      ATH_MSG_INFO( "Using pixel file: " << pixelFileName );
-      ATH_MSG_INFO( "Using pixel file: " << labelFileName );
-      // Set up the ONNX Runtime session.
-      Ort::SessionOptions sessionOptions;
-      sessionOptions.SetIntraOpNumThreads( 1 );
-      sessionOptions.SetGraphOptimizationLevel( ORT_ENABLE_BASIC );
-      Ort::AllocatorWithDefaultOptions allocator;  
-      m_session = std::make_unique< Ort::Session >( m_svc->env(),
-                                                    modelFileName.c_str(),
-                                                    sessionOptions );
-      ATH_MSG_INFO( "Created the ONNX Runtime session" );
-      std::vector<int64_t> input_node_dims;
-      size_t num_input_nodes = m_session->GetInputCount();
-      std::vector<const char*> input_node_names(num_input_nodes);
-      for( std::size_t i = 0; i < num_input_nodes; i++ ) {
-        // print input node names
-        char* input_name = m_session->GetInputName(i, allocator);
-        ATH_MSG_DEBUG("Input "<<i<<" : "<<" name= "<<input_name);
-        input_node_names[i] = input_name;
-        // print input node types
-        Ort::TypeInfo type_info = m_session->GetInputTypeInfo(i);
-        auto tensor_info = type_info.GetTensorTypeAndShapeInfo();
-        ONNXTensorElementDataType type = tensor_info.GetElementType();
-        ATH_MSG_DEBUG("Input "<<i<<" : "<<" type= "<<type);
-
-        // print input shapes/dims
-        input_node_dims = tensor_info.GetShape();
-        ATH_MSG_DEBUG("Input "<<i<<" : num_dims= "<<input_node_dims.size());
-        for (std::size_t j = 0; j < input_node_dims.size(); j++){
-           if(input_node_dims[j]<0)
-             input_node_dims[j] =1;
-           ATH_MSG_DEBUG("Input"<<i<<" : dim "<<j<<"= "<<input_node_dims[j]);
-          }  
-         }
-      
-      //output nodes
-     std::vector<int64_t> output_node_dims;
-     size_t num_output_nodes = m_session->GetOutputCount();
-     std::vector<const char*> output_node_names(num_output_nodes);
-
-     for( std::size_t i = 0; i < num_output_nodes; i++ ) {
-     // print output node names
-        char* output_name = m_session->GetOutputName(i, allocator);
-        ATH_MSG_DEBUG("Output "<<i<<" : "<<" name= "<<output_name);
-        output_node_names[i] = output_name;
-
-        Ort::TypeInfo type_info = m_session->GetOutputTypeInfo(i);
-        auto tensor_info = type_info.GetTensorTypeAndShapeInfo();
-        ONNXTensorElementDataType type = tensor_info.GetElementType();
-        ATH_MSG_DEBUG("Output "<<i<<" : "<<" type= "<<type);
-
-      // print output shapes/dims
-        output_node_dims = tensor_info.GetShape();
-        ATH_MSG_DEBUG("Output "<<i<<" : num_dims= "<<output_node_dims.size());
-        for (std::size_t j = 0; j < output_node_dims.size(); j++){
-           if(output_node_dims[j]<0)
-              output_node_dims[j] =1;
-        ATH_MSG_DEBUG("Output"<<i<<" : dim "<<j<<"= "<<output_node_dims[j]);
-       }  
-      }
-     //*************************************************************************
-     // Score the model using sample data, and inspect values
-     //loading input data
-  
-     std::vector<std::vector<float>> input_tensor_values_ = read_mnist_pixel(pixelFileName);
-     std::vector<int> output_tensor_values_ = read_mnist_label(labelFileName);
-  
-     //preparing container to hold input data
-  
-     size_t input_tensor_size = 1*28*28;
-     std::vector<float> input_tensor_values(input_tensor_size);
-     input_tensor_values = input_tensor_values_[m_testSample];
-  
-     //preparing container to hold output data
-     int output_tensor_values = output_tensor_values_[m_testSample]; 
-
-     // create input tensor object from data values
-     auto memory_info = Ort::MemoryInfo::CreateCpu(OrtArenaAllocator, OrtMemTypeDefault);
-     Ort::Value input_tensor = Ort::Value::CreateTensor<float>(memory_info, input_tensor_values.data(), input_tensor_size, input_node_dims.data(), input_node_dims.size());
-     assert(input_tensor.IsTensor());
-
-     // score model & input tensor, get back output tensor
-     auto output_tensors = m_session->Run(Ort::RunOptions{nullptr}, input_node_names.data(), &input_tensor, input_node_names.size(), output_node_names.data(), output_node_names.size());
-     assert(output_tensors.size() == 1 && output_tensors.front().IsTensor());
-  
-     // Get pointer to output tensor float values
-     float* floatarr = output_tensors.front().GetTensorMutableData<float>();
-     
-     // show  true label for the test input
-     ATH_MSG_INFO("Label for the input test data  = "<<output_tensor_values);
-     float max = -999;
-     int max_index;
-     for (int i = 0; i < 10; i++){
-       ATH_MSG_INFO("Score for class "<<i<<" = "<<floatarr[i]<<std::endl);
-       if (max<floatarr[i]){
-          max = floatarr[i];
-          max_index = i;
-       }
-     }
-     ATH_MSG_INFO("Class: "<<max_index<<" has the highest score: "<<floatarr[max_index]);
-      // Return gracefully.
-      return StatusCode::SUCCESS;
-   }
-
-   StatusCode CxxApiAlgorithm::execute( const EventContext& /*ctx*/ ) const {
-
-      // Return gracefully.
-      return StatusCode::SUCCESS;
-   }
-
-   StatusCode CxxApiAlgorithm::finalize() {
-
-      // Delete the session object.
-      m_session.reset();
-
-      // Return gracefully.
-      return StatusCode::SUCCESS;
-   }
-
-} // namespace AthONNX
diff --git a/Control/AthenaExamples/AthExOnnxRuntime/src/EvaluateModel.cxx b/Control/AthenaExamples/AthExOnnxRuntime/src/EvaluateModel.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..f4a9ce0b0f8ecaa1c89acf967a7074bfd28a3cdf
--- /dev/null
+++ b/Control/AthenaExamples/AthExOnnxRuntime/src/EvaluateModel.cxx
@@ -0,0 +1,296 @@
+// Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+
+// Local include(s).
+#include "EvaluateModel.h"
+
+// Framework include(s).
+#include "PathResolver/PathResolver.h"
+
+namespace AthONNX {
+
+   //*******************************************************************
+   // for reading MNIST images
+   std::vector<std::vector<float>> read_mnist_pixel(const std::string &full_path) //function to load test images
+   {
+     std::vector<std::vector<float>> input_tensor_values;
+     input_tensor_values.resize(10000, std::vector<float>(28*28*1));  
+     std::ifstream file (full_path.c_str(), std::ios::binary);
+     int magic_number=0;
+     int number_of_images=0;
+     int n_rows=0;
+     int n_cols=0;
+     file.read((char*)&magic_number,sizeof(magic_number));
+     magic_number= ntohl(magic_number);
+     file.read((char*)&number_of_images,sizeof(number_of_images));
+     number_of_images= ntohl(number_of_images);
+     file.read((char*)&n_rows,sizeof(n_rows));
+     n_rows= ntohl(n_rows);
+     file.read((char*)&n_cols,sizeof(n_cols));
+     n_cols= ntohl(n_cols);
+     for(int i=0;i<number_of_images;++i)
+     {
+        for(int r=0;r<n_rows;++r)
+        {
+           for(int c=0;c<n_cols;++c)
+           {
+             unsigned char temp=0;
+             file.read((char*)&temp,sizeof(temp));
+             input_tensor_values[i][r*n_cols+c]= float(temp)/255;
+           }
+        }
+     }
+     return input_tensor_values;
+   }
+
+   //********************************************************************************
+   // for reading MNIST labels
+   std::vector<int> read_mnist_label(const std::string &full_path) //function to load test labels
+   {
+     std::vector<int> output_tensor_values(1*10000);
+     std::ifstream file (full_path.c_str(), std::ios::binary);
+     int magic_number=0;
+     int number_of_labels=0;
+     file.read((char*)&magic_number,sizeof(magic_number));
+     magic_number= ntohl(magic_number);
+     file.read((char*)&number_of_labels,sizeof(number_of_labels));
+     number_of_labels= ntohl(number_of_labels);
+     for(int i=0;i<number_of_labels;++i)
+     {
+          unsigned char temp=0;
+          file.read((char*)&temp,sizeof(temp));
+          output_tensor_values[i]= int(temp);
+     }
+      return output_tensor_values;
+    }
+
+   StatusCode EvaluateModel::initialize() {
+
+      // Access the service.
+      ATH_CHECK( m_svc.retrieve() );
+
+      /*****
+       The combination of no. of batches and batch size shouldn't cross 
+       the total smple size which is 10000 for this example
+      *****/         
+      if(m_doBatches && (m_numberOfBatches*m_sizeOfBatch)>10000){
+        ATH_MSG_INFO("The total no. of sample crossed the no. of available sample ....");
+	return StatusCode::FAILURE;
+      }
+      // Find the model file.
+      const std::string modelFileName =
+         PathResolverFindCalibFile( m_modelFileName );
+      const std::string pixelFileName =
+         PathResolverFindCalibFile( m_pixelFileName );
+      const std::string labelFileName =
+         PathResolverFindCalibFile( m_labelFileName );
+      ATH_MSG_INFO( "Using model file: " << modelFileName );
+      ATH_MSG_INFO( "Using pixel file: " << pixelFileName );
+      ATH_MSG_INFO( "Using pixel file: " << labelFileName );
+      // Set up the ONNX Runtime session.
+      Ort::SessionOptions sessionOptions;
+      sessionOptions.SetIntraOpNumThreads( 1 );
+      sessionOptions.SetGraphOptimizationLevel( ORT_ENABLE_BASIC );
+      Ort::AllocatorWithDefaultOptions allocator;  
+      m_session = std::make_unique< Ort::Session >( m_svc->env(),
+                                                    modelFileName.c_str(),
+                                                    sessionOptions );
+      ATH_MSG_INFO( "Created the ONNX Runtime session" );
+      m_input_tensor_values = read_mnist_pixel(pixelFileName);
+      m_output_tensor_values = read_mnist_label(labelFileName);
+
+      // Return gracefully.
+      return StatusCode::SUCCESS;
+   }
+
+   StatusCode EvaluateModel::execute( const EventContext& /*ctx*/ ) const {
+     
+     Ort::AllocatorWithDefaultOptions allocator;
+     auto memory_info = Ort::MemoryInfo::CreateCpu(OrtArenaAllocator, OrtMemTypeDefault);
+     /************************** Input Nodes *****************************/
+     /*********************************************************************/
+     std::vector<int64_t> input_node_dims;
+     size_t num_input_nodes = m_session->GetInputCount();
+     std::vector<const char*> input_node_names(num_input_nodes);
+     for( std::size_t i = 0; i < num_input_nodes; i++ ) {
+        // print input node names
+        char* input_name = m_session->GetInputName(i, allocator);
+        ATH_MSG_DEBUG("Input "<<i<<" : "<<" name= "<<input_name);
+        input_node_names[i] = input_name;
+        Ort::TypeInfo type_info = m_session->GetInputTypeInfo(i);
+        auto tensor_info = type_info.GetTensorTypeAndShapeInfo();
+        // print input shapes/dims
+        input_node_dims = tensor_info.GetShape();
+        ATH_MSG_DEBUG("Input "<<i<<" : num_dims= "<<input_node_dims.size());
+        for (std::size_t j = 0; j < input_node_dims.size(); j++){
+           ATH_MSG_DEBUG("Input "<<i<<" : dim "<<j<<"= "<<input_node_dims[j]);
+          }  
+       }
+    
+     /************************** Output Nodes *****************************/
+     /*********************************************************************/
+     //output nodes
+     std::vector<int64_t> output_node_dims;
+     size_t num_output_nodes = m_session->GetOutputCount();
+     std::vector<const char*> output_node_names(num_output_nodes);
+
+     for( std::size_t i = 0; i < num_output_nodes; i++ ) {
+     // print output node names
+        char* output_name = m_session->GetOutputName(i, allocator);
+        ATH_MSG_DEBUG("Output "<<i<<" : "<<" name= "<<output_name);
+        output_node_names[i] = output_name;
+
+        Ort::TypeInfo type_info = m_session->GetOutputTypeInfo(i);
+        auto tensor_info = type_info.GetTensorTypeAndShapeInfo();
+
+      // print output shapes/dims
+        output_node_dims = tensor_info.GetShape();
+        ATH_MSG_DEBUG("Output "<<i<<" : num_dims= "<<output_node_dims.size());
+        for (std::size_t j = 0; j < output_node_dims.size(); j++){
+        	ATH_MSG_DEBUG("Output "<<i<<" : dim "<<j<<"= "<<output_node_dims[j]);
+       }  
+      }
+
+    /************************* Score if input is not a batch ********************/
+    /****************************************************************************/
+     if(m_doBatches == false){
+
+        /**************************************************************************************
+         * input_node_dims[0] = -1; -1 needs to be replaced by the batch size; for no batch is 1 
+         * input_node_dims[1] = 28
+         * input_node_dims[2] = 28
+        ****************************************************************************************/
+
+     	input_node_dims[0] = 1;
+     	output_node_dims[0] = 1;
+ 
+       /***************** Choose an example sample randomly ****************************/  
+     	std::vector<float> input_tensor_values = m_input_tensor_values[m_testSample];
+        // Output label of corresponding m_input_tensor_values[m_testSample]; e.g 0, 1, 2, 3 etc
+        int output_tensor_values = m_output_tensor_values[m_testSample];
+       
+        // For a check that the sample dimension is fully flatten (1x28x28 = 784)
+     	ATH_MSG_DEBUG("Size of Input tensor: "<<input_tensor_values.size()); 
+
+     	/************** Create input tensor object from input data values to feed into your model *********************/
+     	Ort::Value input_tensor = Ort::Value::CreateTensor<float>(memory_info, 
+                                                                  input_tensor_values.data(), 
+                                                                  input_tensor_values.size(),  /*** 1x28x28 = 784 ***/ 
+                                                                  input_node_dims.data(), 
+                                                                  input_node_dims.size());     /*** [1, 28, 28] = 3 ***/
+
+        /********* Convert 784 elements long flattened 1D array to 3D (1, 28, 28) onnx compatible tensor ************/
+        ATH_MSG_DEBUG("Input tensor size after converted to Ort tensor: "<<input_tensor.GetTensorTypeAndShapeInfo().GetShape());     	
+        // Makes sure input tensor has same dimensions as input layer of the model
+        assert(input_tensor.IsTensor()&&
+     		input_tensors.GetTensorTypeAndShapeInfo().GetShape() == input_node_dims.size());
+
+     	/********* Score model by feeding input tensor and get output tensor in return *****************************/
+        auto output_tensor = m_session->Run(Ort::RunOptions{nullptr}, 
+                                             input_node_names.data(), 
+                                             &input_tensor, 
+                                             input_node_names.size(),      /** 1, flatten_input:0 **/ 
+                                             output_node_names.data(), 
+                                             output_node_names.size());    /** 1, dense_1/Softmax:0 **/
+
+        assert(output_tensor.size() == output_node_names.size() && output_tensor.front().IsTensor());
+  
+     	// Get pointer to output tensor float values
+     	float* floatarr = output_tensor.front().GetTensorMutableData<float>();
+
+     	// show  true label for the test input
+     	ATH_MSG_INFO("Label for the input test data  = "<<output_tensor_values);
+     	float max = -999;
+     	int max_index;
+     	for (int i = 0; i < 10; i++){
+       		ATH_MSG_DEBUG("Score for class "<<i<<" = "<<floatarr[i]);
+       		if (max<floatarr[i]){
+          		max = floatarr[i];
+          		max_index = i;
+       		}
+     	}
+     	ATH_MSG_INFO("Class: "<<max_index<<" has the highest score: "<<floatarr[max_index]);
+     
+     } // m_doBatches == false codition ends   
+    /************************* Score if input is a batch ********************/
+    /****************************************************************************/
+    else {
+        /**************************************************************************************
+         Similar scoring structure like non batch execution but 1st demention needs to be replaced by batch size
+         for this example lets take 3 batches with batch size 5
+         * input_node_dims[0] = 5
+         * input_node_dims[1] = 28
+         * input_node_dims[2] = 28
+        ****************************************************************************************/
+        
+     	input_node_dims[0] = m_sizeOfBatch;
+     	output_node_dims[0] = m_sizeOfBatch;   
+     
+	/************************** process multiple batches ********************************/
+     	for (int i = 0; i < m_numberOfBatches; i++) {
+     		ATH_MSG_DEBUG("Processing batch #" << i);
+      		std::vector<float> batch_input_tensor_values;
+  
+      		for (int j = 0; j < m_sizeOfBatch; j++) {
+
+                        /******************For each batch we need a flattened (5 x 28 x 28 = 3920) 1D array******************************/
+        		batch_input_tensor_values.insert(batch_input_tensor_values.end(),m_input_tensor_values[j].begin(),m_input_tensor_values[j].end());
+        	}   
+
+        	Ort::Value batch_input_tensors = Ort::Value::CreateTensor<float>(memory_info,
+                                                                      batch_input_tensor_values.data(),
+                                                                      batch_input_tensor_values.size(), /*** 5x28x28 = 3920 ***/
+                                                                      input_node_dims.data(),
+                                                                      input_node_dims.size());         /*** [5, 28, 28] = 3 ***/
+
+                assert(batch_input_tensors.IsTensor()&&
+                	batch_input_tensors.GetTensorTypeAndShapeInfo().GetShape() == input_node_dims.size());
+   
+        	auto batch_output_tensors = m_session->Run(Ort::RunOptions{nullptr}, 
+                                                   input_node_names.data(), 
+                                                   &batch_input_tensors, 
+                                                   input_node_names.size(),    /** 1, flatten_input:0 **/
+                                                   output_node_names.data(), 
+                                                   output_node_names.size());  /** 1, dense_1/Softmax:0 **/  
+ 
+      		assert(batch_output_tensors.size() == output_names.size() &&
+             		batch_output_tensors.IsTensor() &&
+             		batch_output_tensors.GetTensorTypeAndShapeInfo().GetShape()[0] == m_sizeOfBatch);
+        
+		// Get pointer to output tensor float values
+
+        	ATH_MSG_DEBUG("output vector size: "<<batch_output_tensors[0].GetTensorTypeAndShapeInfo().GetShape());
+        	float* floatarr = batch_output_tensors.front().GetTensorMutableData<float>();
+     
+     		// show  true label for the test input
+		for(int i = 0; i<m_sizeOfBatch; i++){
+     			ATH_MSG_INFO("Label for the input test data  = "<<m_output_tensor_values[i]);
+                	int k = i*10;
+                	float max = -999;
+                	int max_index = 0;
+     			for (int j =k ; j < k+10; j++){
+       				ATH_MSG_INFO("Score for class "<<j-k<<" = "<<floatarr[j]);
+       				if (max<floatarr[j]){
+          				max = floatarr[j];
+          				max_index = j;
+       				}
+     			}
+    	       	ATH_MSG_INFO("Class: "<<max_index-k<<" has the highest score: "<<floatarr[max_index]);
+      		} 
+
+          }
+     } // else/m_doBatches == True codition ends
+    // Return gracefully.
+      return StatusCode::SUCCESS;
+   }
+   StatusCode EvaluateModel::finalize() {
+
+      // Delete the session object.
+      m_session.reset();
+
+      // Return gracefully.
+      return StatusCode::SUCCESS;
+   }
+
+} // namespace AthONNX
+
+
diff --git a/Control/AthenaExamples/AthExOnnxRuntime/src/CxxApiAlgorithm.h b/Control/AthenaExamples/AthExOnnxRuntime/src/EvaluateModel.h
similarity index 76%
rename from Control/AthenaExamples/AthExOnnxRuntime/src/CxxApiAlgorithm.h
rename to Control/AthenaExamples/AthExOnnxRuntime/src/EvaluateModel.h
index 0ebf218804d234f0374acb740cb2e033178ca2bc..59e0fc5933e604e5a793aeb88479fe107d8989a9 100644
--- a/Control/AthenaExamples/AthExOnnxRuntime/src/CxxApiAlgorithm.h
+++ b/Control/AthenaExamples/AthExOnnxRuntime/src/EvaluateModel.h
@@ -1,7 +1,7 @@
 // Dear emacs, this is -*- c++ -*-
 // Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-#ifndef ATHEXONNXRUNTIME_CXXAPIALGORITHM_H
-#define ATHEXONNXRUNTIME_CXXAPIALGORITHM_H
+#ifndef ATHEXONNXRUNTIME_EVALUATEMODEL_H
+#define ATHEXONNXRUNTIME_EVALUATEMODEL_H
 
 // Local include(s).
 #include "AthOnnxruntimeService/IONNXRuntimeSvc.h"
@@ -19,6 +19,8 @@
 #include <iostream> 
 #include <fstream>
 #include <arpa/inet.h>
+#include <vector>
+#include <iterator>
 
 namespace AthONNX {
 
@@ -29,7 +31,7 @@ namespace AthONNX {
    /// @author Debottam Bakshi Gupta <Debottam.Bakshi.Gupta@cern.ch>
    /// @author Attila Krasznahorkay <Attila.Krasznahorkay@cern.ch>
    ///
-   class CxxApiAlgorithm : public AthReentrantAlgorithm {
+   class EvaluateModel: public AthReentrantAlgorithm {
 
    public:
       /// Inherit the base class's constructor
@@ -62,6 +64,12 @@ namespace AthONNX {
          "dev/MLTest/2020-03-31/t10k-labels-idx1-ubyte",
          "Name of the label file to load" };
       Gaudi::Property<int> m_testSample {this, "TestSample", 0, "A Random Test Sample"};
+
+      /// Following properties needed to be consdered if the .onnx model is evaluated in batch mode
+      Gaudi::Property<bool> m_doBatches {this, "DoBatches", false, "Processing events by batches"};
+      Gaudi::Property<int> m_numberOfBatches {this, "NumberOfBatches", 1, "No. of batches to be passed"};
+      Gaudi::Property<int> m_sizeOfBatch {this, "SizeOfBatch", 1, "No. of elements/example in a batch"};
+      
       /// Handle to @c AthONNX::IONNXRuntimeSvc
       ServiceHandle< IONNXRuntimeSvc > m_svc{ this, "ONNXRuntimeSvc",
                                               "AthONNX::ONNXRuntimeSvc",
@@ -71,9 +79,11 @@ namespace AthONNX {
 
       /// The "session" of ONNX Runtime that we'll be using
       std::unique_ptr< Ort::Session > m_session;
+      std::vector<std::vector<float>> m_input_tensor_values;
+      std::vector<int> m_output_tensor_values;
 
-   }; // class CxxApiAlgorithm
+   }; // class EvaluateModel
 
 } // namespace AthONNX
 
-#endif // ATHEXONNXRUNTIME_CXXAPIALGORITHM_H
+#endif // ATHEXONNXRUNTIME_EVALUATEMODEL_H
diff --git a/Control/AthenaExamples/AthExOnnxRuntime/src/components/AthExOnnxRuntime_entries.cxx b/Control/AthenaExamples/AthExOnnxRuntime/src/components/AthExOnnxRuntime_entries.cxx
index ca1006fe95b4329ec5e9109389f78389ff0a9d61..cb25a4bfd9d2e30534c0158a17ae01e6ddd719ee 100644
--- a/Control/AthenaExamples/AthExOnnxRuntime/src/components/AthExOnnxRuntime_entries.cxx
+++ b/Control/AthenaExamples/AthExOnnxRuntime/src/components/AthExOnnxRuntime_entries.cxx
@@ -1,7 +1,6 @@
 // Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 // Local include(s).
-#include "../CxxApiAlgorithm.h"
-
+#include "../EvaluateModel.h"
 // Declare the package's components.
-DECLARE_COMPONENT( AthONNX::CxxApiAlgorithm )
+DECLARE_COMPONENT( AthONNX::EvaluateModel )
diff --git a/Control/AthenaKernel/AthenaKernel/CondCont.icc b/Control/AthenaKernel/AthenaKernel/CondCont.icc
index 76f4cdcf021a3286dc0e290db616b8dec45ac8c1..ab40ddbbf0e75d6cedf8cbf0e33392860b84faef 100644
--- a/Control/AthenaKernel/AthenaKernel/CondCont.icc
+++ b/Control/AthenaKernel/AthenaKernel/CondCont.icc
@@ -212,7 +212,7 @@ CondCont<T>::CondCont (Athena::IRCUSvc& rcusvc,
  * @brief Destructor.
  */
 template <typename T>
-CondCont<T>::~CondCont<T>()
+CondCont<T>::~CondCont()
 {
 }    
 
@@ -409,7 +409,7 @@ bool CondContMixedBase::valid (const EventIDBase& t) const
  * @brief Destructor.
  */
 template <typename T>
-CondContMixed<T>::~CondContMixed<T>()
+CondContMixed<T>::~CondContMixed()
 {
 }    
 
diff --git a/Control/AthenaKernel/AthenaKernel/MetaCont.h b/Control/AthenaKernel/AthenaKernel/MetaCont.h
index c19ee682149a8ab6c08c687781a0b78356d5c38f..62b1e079162acea6a0393f9401a0be31f7309e20 100644
--- a/Control/AthenaKernel/AthenaKernel/MetaCont.h
+++ b/Control/AthenaKernel/AthenaKernel/MetaCont.h
@@ -104,7 +104,7 @@ namespace SG {
 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
 
 template <typename T>
-MetaCont<T>::~MetaCont<T>() {
+MetaCont<T>::~MetaCont() {
   for (auto t : m_metaSet) {
     delete t.second;
   }
diff --git a/Control/CxxUtils/CxxUtils/get_unaligned.h b/Control/CxxUtils/CxxUtils/get_unaligned.h
index 02aa49fa19d3a553ec72889faecaa46f617f98cb..fcb9c01f4c23b69b83b4da10dab94381fa0190ba 100644
--- a/Control/CxxUtils/CxxUtils/get_unaligned.h
+++ b/Control/CxxUtils/CxxUtils/get_unaligned.h
@@ -13,7 +13,7 @@
  *   char* p = ...;
  *   int* ip = reinterpret_cast<int*>(p);
  *   int i = *ip++;
- @endif
+ *@endcode
  *
  * is undefined if @c p isn't aligned to an int boundary.  It further
  * will read the value using the host endianness, which is an issue
diff --git a/Control/CxxUtils/share/OptionalContainer_test.ref b/Control/CxxUtils/share/OptionalContainer_test.ref
old mode 100755
new mode 100644
diff --git a/Control/CxxUtils/test/phihelper_test.cxx b/Control/CxxUtils/test/phihelper_test.cxx
index 1227ff72d6ec9e5b931cc07aada4ac7e8f9b2943..7dfdfdd7e652e8f43921a911c088026ba49f1416 100644
--- a/Control/CxxUtils/test/phihelper_test.cxx
+++ b/Control/CxxUtils/test/phihelper_test.cxx
@@ -88,7 +88,7 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(test_mean, T, test_types)
                                     {-0.25 * PI, -0.75 * PI},
                                     {-0.25 * PI, -0.75 * PI},
                                     {9 * PI / 4, 11 * PI / 4}};
-  for (const auto [a, b] : v) {
+  for (const auto& [a, b] : v) {
     // Check symmetry
     const auto r1 = phiMean<T>(a, b);
     const auto r2 = phiMean<T>(b, a);
@@ -109,7 +109,7 @@ BOOST_AUTO_TEST_CASE_TEMPLATE(test_mean, T, test_types)
                                         {0.5 * PI, -0.5 * PI, 0.0},
                                         {0.75 * PI, -0.25 * PI, 0.25 * PI},
                                         {0.0, -1.0 * PI, -0.5 * PI}};
-  for (const auto [a, b, r] : w) {
+  for (const auto& [a, b, r] : w) {
     // Check symmetry and result
     const auto result = phiMean<T>(a, b);
     BOOST_TEST(result == phiMean<T>(b, a));
diff --git a/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1.ref b/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1.ref
index b638b15f051a1ad24abae18fa71de8fe7f7085f4..8381b7f18e248bf29369bb3ae5bb31cdd6ba3328 100644
--- a/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1.ref
+++ b/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1.ref
@@ -1,7 +1,6 @@
-Sat Jun 27 18:32:57 CEST 2020
-Preloading tcmalloc_minimal.so
+Wed Nov 25 18:25:44 EST 2020
 Py:Athena            INFO including file "AthenaCommon/Preparation.py"
-Py:Athena            INFO using release [WorkDir-22.0.16] [x86_64-centos7-gcc8-opt] [atlas-work3/0446faaa9579] -- built on [2020-06-26T2302]
+Py:Athena            INFO using release [?-22.0.0] [?] [?/?] -- built on [?]
 Py:Athena            INFO including file "AthenaCommon/Atlas.UnixStandardJob.py"
 Py:Athena            INFO executing ROOT6Setup
 Py:Athena            INFO including file "AthenaCommon/Execution.py"
@@ -9,30 +8,28 @@ Py:Athena            INFO including file "DataModelRunTests/xAODTestDecorHandle1
 Py:Athena            INFO including file "DataModelRunTests/commonTrailer.py"
 Py:Athena            INFO including file "DataModelRunTests/setCatalog.py"
 Py:Athena            INFO including file "AthenaCommon/runbatch.py"
-Py:ConfigurableDb    INFO Read module info for 5552 configurables from 78 genConfDb files
+Py:ConfigurableDb    INFO Read module info for 923 configurables from 2 genConfDb files
 Py:ConfigurableDb    INFO No duplicates have been found: that's good !
-ApplicationMgr       INFO Updating Gaudi::PluginService::SetDebug(level) to level= 'PluginDebugLevel':0
-ApplicationMgr       INFO Updating Gaudi::PluginService::SetDebug(level) to level= 'PluginDebugLevel':0
+# setting LC_ALL to "C"
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v33r1)
-                                          running on lxplus755.cern.ch on Sat Jun 27 18:33:12 2020
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v27r1p99)
+                                          running on karma on Wed Nov 25 18:25:52 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-ApplicationMgr       INFO Updating Gaudi::PluginService::SetDebug(level) to level= 'PluginDebugLevel':0
 AthDictLoaderSvc     INFO in initialize...
 AthDictLoaderSvc     INFO acquired Dso-registry
-ClassIDSvc           INFO  getRegistryEntries: read 7027 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 3308 CLIDRegistry entries for module ALL
 CoreDumpSvc          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
 AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 705 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 1415 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 4610 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 849 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 1817 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 8511 CLIDRegistry entries for module ALL
 xAODMaker::Even...   INFO Initializing - Package version: xAODEventInfoCnv-00-00-00
 xAODMaker::Even...   INFO Initializing - Package version: xAODEventInfoCnv-00-00-00
 xAODMaker::Even...WARNING Beam conditions service not available
 xAODMaker::Even...WARNING Will not fill beam spot information into xAOD::EventInfo
-ClassIDSvc           INFO  getRegistryEntries: read 423 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 430 CLIDRegistry entries for module ALL
 EventSelector        INFO  Enter McEventSelector Initialization 
 AthenaEventLoopMgr   INFO Setup EventSelector service EventSelector
 ApplicationMgr       INFO Application Manager Initialized successfully
@@ -40,125 +37,205 @@ ApplicationMgr       INFO Application Manager Started successfully
 EventPersistenc...   INFO Added successfully Conversion service:McCnvSvc
 AthenaEventLoopMgr   INFO   ===>>>  start of run 0    <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #0, run #0 0 events processed so far  <<<===
-ClassIDSvc           INFO  getRegistryEntries: read 108 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 110 CLIDRegistry entries for module ALL
 xAODTestReadDecor    INFO cvec.dInt1: 401 402 403 404 405 406 407 408 409 410
 xAODTestReadDecor    INFO cinfo.dInt1: 3000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 3001
 xAODTestReadDecor    INFO cinfo.dInt1: 3000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 401 402 403 404 405 406 407 408 409 410
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 3000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 3001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 3000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #0, run #0 1 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #1, run #0 1 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 801 802 803 804 805 806 807 808 809 810
 xAODTestReadDecor    INFO cinfo.dInt1: 6000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 6001
 xAODTestReadDecor    INFO cinfo.dInt1: 6000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 801 802 803 804 805 806 807 808 809 810
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 6000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 6001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 6000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #1, run #0 2 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #2, run #0 2 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210
 xAODTestReadDecor    INFO cinfo.dInt1: 9000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 9001
 xAODTestReadDecor    INFO cinfo.dInt1: 9000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 9000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 9001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 9000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #2, run #0 3 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #3, run #0 3 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610
 xAODTestReadDecor    INFO cinfo.dInt1: 12000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 12001
 xAODTestReadDecor    INFO cinfo.dInt1: 12000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 12000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 12001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 12000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #3, run #0 4 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #4, run #0 4 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1:
 xAODTestReadDecor    INFO cinfo.dInt1: 15000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 15001
 xAODTestReadDecor    INFO cinfo.dInt1: 15000
+xAODTestReadDec...   INFO scopy_cvec.dInt1:
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 15000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 15001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 15000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #4, run #0 5 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #5, run #0 5 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410
 xAODTestReadDecor    INFO cinfo.dInt1: 18000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 18001
 xAODTestReadDecor    INFO cinfo.dInt1: 18000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 18000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 18001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 18000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #5, run #0 6 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #6, run #0 6 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 2801 2802 2803 2804 2805 2806 2807 2808 2809 2810
 xAODTestReadDecor    INFO cinfo.dInt1: 21000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 21001
 xAODTestReadDecor    INFO cinfo.dInt1: 21000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 2801 2802 2803 2804 2805 2806 2807 2808 2809 2810
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 21000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 21001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 21000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #6, run #0 7 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #7, run #0 7 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210
 xAODTestReadDecor    INFO cinfo.dInt1: 24000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 24001
 xAODTestReadDecor    INFO cinfo.dInt1: 24000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 24000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 24001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 24000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #7, run #0 8 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #8, run #0 8 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610
 xAODTestReadDecor    INFO cinfo.dInt1: 27000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 27001
 xAODTestReadDecor    INFO cinfo.dInt1: 27000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 27000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 27001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 27000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #8, run #0 9 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #9, run #0 9 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010
 xAODTestReadDecor    INFO cinfo.dInt1: 30000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 30001
 xAODTestReadDecor    INFO cinfo.dInt1: 30000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 30000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 30001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 30000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #9, run #0 10 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #10, run #0 10 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 4401 4402 4403 4404 4405 4406 4407 4408 4409 4410
 xAODTestReadDecor    INFO cinfo.dInt1: 33000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 33001
 xAODTestReadDecor    INFO cinfo.dInt1: 33000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 4401 4402 4403 4404 4405 4406 4407 4408 4409 4410
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 33000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 33001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 33000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #10, run #0 11 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #11, run #0 11 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 4801 4802 4803 4804 4805 4806 4807 4808 4809 4810
 xAODTestReadDecor    INFO cinfo.dInt1: 36000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 36001
 xAODTestReadDecor    INFO cinfo.dInt1: 36000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 4801 4802 4803 4804 4805 4806 4807 4808 4809 4810
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 36000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 36001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 36000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #11, run #0 12 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #12, run #0 12 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 5201 5202 5203 5204 5205 5206 5207 5208 5209 5210
 xAODTestReadDecor    INFO cinfo.dInt1: 39000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 39001
 xAODTestReadDecor    INFO cinfo.dInt1: 39000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 5201 5202 5203 5204 5205 5206 5207 5208 5209 5210
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 39000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 39001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 39000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #12, run #0 13 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #13, run #0 13 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 5601 5602 5603 5604 5605 5606 5607 5608 5609 5610
 xAODTestReadDecor    INFO cinfo.dInt1: 42000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 42001
 xAODTestReadDecor    INFO cinfo.dInt1: 42000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 5601 5602 5603 5604 5605 5606 5607 5608 5609 5610
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 42000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 42001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 42000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #13, run #0 14 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #14, run #0 14 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 6001 6002 6003 6004 6005 6006 6007 6008 6009 6010
 xAODTestReadDecor    INFO cinfo.dInt1: 45000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 45001
 xAODTestReadDecor    INFO cinfo.dInt1: 45000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 6001 6002 6003 6004 6005 6006 6007 6008 6009 6010
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 45000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 45001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 45000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #14, run #0 15 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #15, run #0 15 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 6401 6402 6403 6404 6405 6406 6407 6408 6409 6410
 xAODTestReadDecor    INFO cinfo.dInt1: 48000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 48001
 xAODTestReadDecor    INFO cinfo.dInt1: 48000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 6401 6402 6403 6404 6405 6406 6407 6408 6409 6410
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 48000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 48001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 48000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #15, run #0 16 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #16, run #0 16 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 6801 6802 6803 6804 6805 6806 6807 6808 6809 6810
 xAODTestReadDecor    INFO cinfo.dInt1: 51000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 51001
 xAODTestReadDecor    INFO cinfo.dInt1: 51000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 6801 6802 6803 6804 6805 6806 6807 6808 6809 6810
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 51000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 51001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 51000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #16, run #0 17 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #17, run #0 17 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 7201 7202 7203 7204 7205 7206 7207 7208 7209 7210
 xAODTestReadDecor    INFO cinfo.dInt1: 54000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 54001
 xAODTestReadDecor    INFO cinfo.dInt1: 54000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 7201 7202 7203 7204 7205 7206 7207 7208 7209 7210
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 54000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 54001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 54000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #17, run #0 18 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #18, run #0 18 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 7601 7602 7603 7604 7605 7606 7607 7608 7609 7610
 xAODTestReadDecor    INFO cinfo.dInt1: 57000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 57001
 xAODTestReadDecor    INFO cinfo.dInt1: 57000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 7601 7602 7603 7604 7605 7606 7607 7608 7609 7610
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 57000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 57001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 57000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #18, run #0 19 events processed so far  <<<===
 AthenaEventLoopMgr   INFO   ===>>>  start processing event #19, run #0 19 events processed so far  <<<===
 xAODTestReadDecor    INFO cvec.dInt1: 8001 8002 8003 8004 8005 8006 8007 8008 8009 8010
 xAODTestReadDecor    INFO cinfo.dInt1: 60000
 xAODTestReadDecor    INFO cinfo.dInt1Base: 60001
 xAODTestReadDecor    INFO cinfo.dInt1: 60000
+xAODTestReadDec...   INFO scopy_cvec.dInt1: 8001 8002 8003 8004 8005 8006 8007 8008 8009 8010
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 60000
+xAODTestReadDec...   INFO scopy_cinfo.dInt1Base: 60001
+xAODTestReadDec...   INFO scopy_cinfo.dInt1: 60000
 AthenaEventLoopMgr   INFO   ===>>>  done processing event #19, run #0 20 events processed so far  <<<===
 ApplicationMgr       INFO Application Manager Stopped successfully
 IncidentProcAlg1     INFO Finalize
diff --git a/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1MT.ref b/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1MT.ref
index 4a36780ffeb517501df32efbf799366695fb2885..d1bd884fb2429641bee2f164ec887068e9c303a5 100644
--- a/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1MT.ref
+++ b/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1MT.ref
@@ -1,7 +1,6 @@
-Sat Jun 27 04:58:32 CEST 2020
-Preloading tcmalloc_minimal.so
+Wed Nov 25 18:31:35 EST 2020
 Py:Athena            INFO including file "AthenaCommon/Preparation.py"
-Py:Athena            INFO using release [WorkDir-22.0.16] [x86_64-centos7-gcc8-opt] [atlas-work3/0446faaa9579] -- built on [2020-06-26T2302]
+Py:Athena            INFO using release [?-22.0.0] [?] [?/?] -- built on [?]
 Py:Athena            INFO including file "AthenaCommon/Atlas.UnixStandardJob.py"
 Py:Athena            INFO executing ROOT6Setup
 Py:Athena            INFO configuring AthenaHive with [1] concurrent threads and [1] concurrent events
@@ -12,33 +11,31 @@ Py:Athena            INFO including file "DataModelRunTests/xAODTestDecorHandle1
 Py:Athena            INFO including file "DataModelRunTests/commonTrailer.py"
 Py:Athena            INFO including file "DataModelRunTests/setCatalog.py"
 Py:Athena            INFO including file "AthenaCommon/runbatch.py"
-Py:ConfigurableDb    INFO Read module info for 5552 configurables from 78 genConfDb files
+Py:ConfigurableDb    INFO Read module info for 923 configurables from 2 genConfDb files
 Py:ConfigurableDb    INFO No duplicates have been found: that's good !
-ApplicationMgr       INFO Updating Gaudi::PluginService::SetDebug(level) to level= 'PluginDebugLevel':0
-ApplicationMgr       INFO Updating Gaudi::PluginService::SetDebug(level) to level= 'PluginDebugLevel':0
+# setting LC_ALL to "C"
 MessageSvc           INFO Activating in a separate thread
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v33r1)
-                                          running on lxplus755.cern.ch on Sat Jun 27 04:58:42 2020
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v27r1p99)
+                                          running on karma on Wed Nov 25 18:31:39 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-ApplicationMgr                                      INFO Updating Gaudi::PluginService::SetDebug(level) to level= 'PluginDebugLevel':0
 AthDictLoaderSvc                                    INFO in initialize...
 AthDictLoaderSvc                                    INFO acquired Dso-registry
-ClassIDSvc                                          INFO  getRegistryEntries: read 7399 CLIDRegistry entries for module ALL
+ClassIDSvc                                          INFO  getRegistryEntries: read 3308 CLIDRegistry entries for module ALL
 CoreDumpSvc                                         INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
 AthenaHiveEventLoopMgr                              INFO Initializing AthenaHiveEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc                                     0    INFO  getRegistryEntries: read 1128 CLIDRegistry entries for module ALL
-ClassIDSvc                                     0    INFO  getRegistryEntries: read 1415 CLIDRegistry entries for module ALL
-ClassIDSvc                                     0    INFO  getRegistryEntries: read 4610 CLIDRegistry entries for module ALL
+ClassIDSvc                                     0    INFO  getRegistryEntries: read 1279 CLIDRegistry entries for module ALL
+ClassIDSvc                                     0    INFO  getRegistryEntries: read 1817 CLIDRegistry entries for module ALL
+ClassIDSvc                                     0    INFO  getRegistryEntries: read 8511 CLIDRegistry entries for module ALL
 xAODMaker::EventInfoCnvAlg                     0    INFO Initializing - Package version: xAODEventInfoCnv-00-00-00
 xAODMaker::EventInfoCnvAlg.EventInfoC...       0    INFO Initializing - Package version: xAODEventInfoCnv-00-00-00
 xAODMaker::EventInfoCnvAlg.EventInfoC...       0 WARNING Beam conditions service not available
 xAODMaker::EventInfoCnvAlg.EventInfoC...       0 WARNING Will not fill beam spot information into xAOD::EventInfo
 ThreadPoolSvc                                  0    INFO no thread init tools attached
 AvalancheSchedulerSvc                          0    INFO Activating scheduler in a separate thread
-AvalancheSchedulerSvc                          0    INFO Found 11 algorithms
+AvalancheSchedulerSvc                          0    INFO Found 13 algorithms
 AvalancheSchedulerSvc                          0    INFO Data Dependencies for Algorithms:
   BeginIncFiringAlg
       none
@@ -86,6 +83,30 @@ AvalancheSchedulerSvc                          0    INFO Data Dependencies for A
     o INPUT   ( 'DMTest::CVec' , 'StoreGateSvc+cvec.dInt1' ) 
     o INPUT   ( 'SG::AuxElement' , 'StoreGateSvc+cinfo.dInt1' ) 
     o INPUT   ( 'SG::AuxElement' , 'StoreGateSvc+cinfo.dInt1Base' ) 
+  xAODTestShallowCopy
+    o INPUT   ( 'DMTest::C' , 'StoreGateSvc+cinfo' ) 
+    o INPUT   ( 'DMTest::C' , 'StoreGateSvc+cinfo.dInt1' ) 
+    o INPUT   ( 'DMTest::CVec' , 'StoreGateSvc+cvec' ) 
+    o INPUT   ( 'DMTest::CVec' , 'StoreGateSvc+cvec.dInt1' ) 
+    o OUTPUT  ( 'DMTest::C' , 'StoreGateSvc+scopy_cinfo' ) 
+    o OUTPUT  ( 'DMTest::C' , 'StoreGateSvc+scopy_cinfo.anInt10' ) 
+    o OUTPUT  ( 'DMTest::C' , 'StoreGateSvc+scopy_cinfo.dInt1' ) 
+    o OUTPUT  ( 'DMTest::CVec' , 'StoreGateSvc+dInt1' ) 
+    o OUTPUT  ( 'DMTest::CVec' , 'StoreGateSvc+scopy_cvec' ) 
+    o OUTPUT  ( 'DMTest::CVec' , 'StoreGateSvc+scopy_cvec.anInt10' ) 
+    o OUTPUT  ( 'DMTest::CVec' , 'StoreGateSvc+scopy_cvec.dInt1' ) 
+    o OUTPUT  ( 'DMTest::CVecWithData' , 'StoreGateSvc+dInt1' ) 
+    o OUTPUT  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo' ) 
+    o OUTPUT  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.anInt10' ) 
+    o OUTPUT  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1' ) 
+    o OUTPUT  ( 'SG::AuxVectorBase' , 'StoreGateSvc+dInt1' ) 
+    o OUTPUT  ( 'SG::AuxVectorBase' , 'StoreGateSvc+scopy_cvec' ) 
+    o OUTPUT  ( 'SG::AuxVectorBase' , 'StoreGateSvc+scopy_cvec.anInt10' ) 
+    o OUTPUT  ( 'SG::AuxVectorBase' , 'StoreGateSvc+scopy_cvec.dInt1' ) 
+  xAODTestReadDecorSCopy
+    o INPUT   ( 'DMTest::CVec' , 'StoreGateSvc+scopy_cvec.dInt1' ) 
+    o INPUT   ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1' ) 
+    o INPUT   ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
   EndIncFiringAlg
       none
   IncidentProcAlg2
@@ -95,6 +116,8 @@ AvalancheSchedulerSvc                          0    INFO Will attribute the foll
        * xAODMaker::EventInfoCnvAlg
        * xAODTestDecor
        * xAODTestWriteCInfo
+   o  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' )     required by Algorithm: 
+       * xAODTestReadDecorSCopy
 PrecedenceSvc                                  0    INFO Assembling CF and DF task precedence rules
 PrecedenceSvc                                  0    INFO PrecedenceSvc initialized successfully
 AvalancheSchedulerSvc                          0    INFO Concurrency level information:
@@ -112,127 +135,227 @@ AthenaHiveEventLoopMgr                         0    INFO Starting loop on events
 EventPersistencySvc                        0   0    INFO Added successfully Conversion service:McCnvSvc
 AthenaHiveEventLoopMgr                     0   0    INFO   ===>>>  start of run 0    <<<===
 AthenaHiveEventLoopMgr                     0   0    INFO   ===>>>  start processing event #0, run #0 on slot 0,  0 events processed so far  <<<===
-ClassIDSvc                                 0   0    INFO  getRegistryEntries: read 108 CLIDRegistry entries for module ALL
+ClassIDSvc                                 0   0    INFO  getRegistryEntries: read 110 CLIDRegistry entries for module ALL
+SGInputLoader                              0   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          0   0    INFO cvec.dInt1: 401 402 403 404 405 406 407 408 409 410
 xAODTestReadDecor                          0   0    INFO cinfo.dInt1: 3000
 xAODTestReadDecor                          0   0    INFO cinfo.dInt1Base: 3001
 xAODTestReadDecor                          0   0    INFO cinfo.dInt1: 3000
+xAODTestReadDecorSCopy                     0   0    INFO scopy_cvec.dInt1: 401 402 403 404 405 406 407 408 409 410
+xAODTestReadDecorSCopy                     0   0    INFO scopy_cinfo.dInt1: 3000
+xAODTestReadDecorSCopy                     0   0    INFO scopy_cinfo.dInt1Base: 3001
+xAODTestReadDecorSCopy                     0   0    INFO scopy_cinfo.dInt1: 3000
 AthenaHiveEventLoopMgr                     0   0    INFO   ===>>>  done processing event #0, run #0 on slot 0,  1 events processed so far  <<<===
 AthenaHiveEventLoopMgr                     1   0    INFO   ===>>>  start processing event #1, run #0 on slot 0,  1 events processed so far  <<<===
+SGInputLoader                              1   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          1   0    INFO cvec.dInt1: 801 802 803 804 805 806 807 808 809 810
 xAODTestReadDecor                          1   0    INFO cinfo.dInt1: 6000
 xAODTestReadDecor                          1   0    INFO cinfo.dInt1Base: 6001
 xAODTestReadDecor                          1   0    INFO cinfo.dInt1: 6000
+xAODTestReadDecorSCopy                     1   0    INFO scopy_cvec.dInt1: 801 802 803 804 805 806 807 808 809 810
+xAODTestReadDecorSCopy                     1   0    INFO scopy_cinfo.dInt1: 6000
+xAODTestReadDecorSCopy                     1   0    INFO scopy_cinfo.dInt1Base: 6001
+xAODTestReadDecorSCopy                     1   0    INFO scopy_cinfo.dInt1: 6000
 AthenaHiveEventLoopMgr                     1   0    INFO   ===>>>  done processing event #1, run #0 on slot 0,  2 events processed so far  <<<===
 AthenaHiveEventLoopMgr                     2   0    INFO   ===>>>  start processing event #2, run #0 on slot 0,  2 events processed so far  <<<===
+SGInputLoader                              2   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          2   0    INFO cvec.dInt1: 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210
 xAODTestReadDecor                          2   0    INFO cinfo.dInt1: 9000
 xAODTestReadDecor                          2   0    INFO cinfo.dInt1Base: 9001
 xAODTestReadDecor                          2   0    INFO cinfo.dInt1: 9000
+xAODTestReadDecorSCopy                     2   0    INFO scopy_cvec.dInt1: 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210
+xAODTestReadDecorSCopy                     2   0    INFO scopy_cinfo.dInt1: 9000
+xAODTestReadDecorSCopy                     2   0    INFO scopy_cinfo.dInt1Base: 9001
+xAODTestReadDecorSCopy                     2   0    INFO scopy_cinfo.dInt1: 9000
 AthenaHiveEventLoopMgr                     2   0    INFO   ===>>>  done processing event #2, run #0 on slot 0,  3 events processed so far  <<<===
 AthenaHiveEventLoopMgr                     3   0    INFO   ===>>>  start processing event #3, run #0 on slot 0,  3 events processed so far  <<<===
+SGInputLoader                              3   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          3   0    INFO cvec.dInt1: 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610
 xAODTestReadDecor                          3   0    INFO cinfo.dInt1: 12000
 xAODTestReadDecor                          3   0    INFO cinfo.dInt1Base: 12001
 xAODTestReadDecor                          3   0    INFO cinfo.dInt1: 12000
+xAODTestReadDecorSCopy                     3   0    INFO scopy_cvec.dInt1: 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610
+xAODTestReadDecorSCopy                     3   0    INFO scopy_cinfo.dInt1: 12000
+xAODTestReadDecorSCopy                     3   0    INFO scopy_cinfo.dInt1Base: 12001
+xAODTestReadDecorSCopy                     3   0    INFO scopy_cinfo.dInt1: 12000
 AthenaHiveEventLoopMgr                     3   0    INFO   ===>>>  done processing event #3, run #0 on slot 0,  4 events processed so far  <<<===
 AthenaHiveEventLoopMgr                     4   0    INFO   ===>>>  start processing event #4, run #0 on slot 0,  4 events processed so far  <<<===
+SGInputLoader                              4   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          4   0    INFO cvec.dInt1:
 xAODTestReadDecor                          4   0    INFO cinfo.dInt1: 15000
 xAODTestReadDecor                          4   0    INFO cinfo.dInt1Base: 15001
 xAODTestReadDecor                          4   0    INFO cinfo.dInt1: 15000
+xAODTestReadDecorSCopy                     4   0    INFO scopy_cvec.dInt1:
+xAODTestReadDecorSCopy                     4   0    INFO scopy_cinfo.dInt1: 15000
+xAODTestReadDecorSCopy                     4   0    INFO scopy_cinfo.dInt1Base: 15001
+xAODTestReadDecorSCopy                     4   0    INFO scopy_cinfo.dInt1: 15000
 AthenaHiveEventLoopMgr                     4   0    INFO   ===>>>  done processing event #4, run #0 on slot 0,  5 events processed so far  <<<===
 AthenaHiveEventLoopMgr                     5   0    INFO   ===>>>  start processing event #5, run #0 on slot 0,  5 events processed so far  <<<===
+SGInputLoader                              5   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          5   0    INFO cvec.dInt1: 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410
 xAODTestReadDecor                          5   0    INFO cinfo.dInt1: 18000
 xAODTestReadDecor                          5   0    INFO cinfo.dInt1Base: 18001
 xAODTestReadDecor                          5   0    INFO cinfo.dInt1: 18000
+xAODTestReadDecorSCopy                     5   0    INFO scopy_cvec.dInt1: 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410
+xAODTestReadDecorSCopy                     5   0    INFO scopy_cinfo.dInt1: 18000
+xAODTestReadDecorSCopy                     5   0    INFO scopy_cinfo.dInt1Base: 18001
+xAODTestReadDecorSCopy                     5   0    INFO scopy_cinfo.dInt1: 18000
 AthenaHiveEventLoopMgr                     5   0    INFO   ===>>>  done processing event #5, run #0 on slot 0,  6 events processed so far  <<<===
 AthenaHiveEventLoopMgr                     6   0    INFO   ===>>>  start processing event #6, run #0 on slot 0,  6 events processed so far  <<<===
+SGInputLoader                              6   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          6   0    INFO cvec.dInt1: 2801 2802 2803 2804 2805 2806 2807 2808 2809 2810
 xAODTestReadDecor                          6   0    INFO cinfo.dInt1: 21000
 xAODTestReadDecor                          6   0    INFO cinfo.dInt1Base: 21001
 xAODTestReadDecor                          6   0    INFO cinfo.dInt1: 21000
+xAODTestReadDecorSCopy                     6   0    INFO scopy_cvec.dInt1: 2801 2802 2803 2804 2805 2806 2807 2808 2809 2810
+xAODTestReadDecorSCopy                     6   0    INFO scopy_cinfo.dInt1: 21000
+xAODTestReadDecorSCopy                     6   0    INFO scopy_cinfo.dInt1Base: 21001
+xAODTestReadDecorSCopy                     6   0    INFO scopy_cinfo.dInt1: 21000
 AthenaHiveEventLoopMgr                     6   0    INFO   ===>>>  done processing event #6, run #0 on slot 0,  7 events processed so far  <<<===
 AthenaHiveEventLoopMgr                     7   0    INFO   ===>>>  start processing event #7, run #0 on slot 0,  7 events processed so far  <<<===
+SGInputLoader                              7   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          7   0    INFO cvec.dInt1: 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210
 xAODTestReadDecor                          7   0    INFO cinfo.dInt1: 24000
 xAODTestReadDecor                          7   0    INFO cinfo.dInt1Base: 24001
 xAODTestReadDecor                          7   0    INFO cinfo.dInt1: 24000
+xAODTestReadDecorSCopy                     7   0    INFO scopy_cvec.dInt1: 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210
+xAODTestReadDecorSCopy                     7   0    INFO scopy_cinfo.dInt1: 24000
+xAODTestReadDecorSCopy                     7   0    INFO scopy_cinfo.dInt1Base: 24001
+xAODTestReadDecorSCopy                     7   0    INFO scopy_cinfo.dInt1: 24000
 AthenaHiveEventLoopMgr                     7   0    INFO   ===>>>  done processing event #7, run #0 on slot 0,  8 events processed so far  <<<===
 AthenaHiveEventLoopMgr                     8   0    INFO   ===>>>  start processing event #8, run #0 on slot 0,  8 events processed so far  <<<===
+SGInputLoader                              8   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          8   0    INFO cvec.dInt1: 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610
 xAODTestReadDecor                          8   0    INFO cinfo.dInt1: 27000
 xAODTestReadDecor                          8   0    INFO cinfo.dInt1Base: 27001
 xAODTestReadDecor                          8   0    INFO cinfo.dInt1: 27000
+xAODTestReadDecorSCopy                     8   0    INFO scopy_cvec.dInt1: 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610
+xAODTestReadDecorSCopy                     8   0    INFO scopy_cinfo.dInt1: 27000
+xAODTestReadDecorSCopy                     8   0    INFO scopy_cinfo.dInt1Base: 27001
+xAODTestReadDecorSCopy                     8   0    INFO scopy_cinfo.dInt1: 27000
 AthenaHiveEventLoopMgr                     8   0    INFO   ===>>>  done processing event #8, run #0 on slot 0,  9 events processed so far  <<<===
 AthenaHiveEventLoopMgr                     9   0    INFO   ===>>>  start processing event #9, run #0 on slot 0,  9 events processed so far  <<<===
+SGInputLoader                              9   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                          9   0    INFO cvec.dInt1: 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010
 xAODTestReadDecor                          9   0    INFO cinfo.dInt1: 30000
 xAODTestReadDecor                          9   0    INFO cinfo.dInt1Base: 30001
 xAODTestReadDecor                          9   0    INFO cinfo.dInt1: 30000
+xAODTestReadDecorSCopy                     9   0    INFO scopy_cvec.dInt1: 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010
+xAODTestReadDecorSCopy                     9   0    INFO scopy_cinfo.dInt1: 30000
+xAODTestReadDecorSCopy                     9   0    INFO scopy_cinfo.dInt1Base: 30001
+xAODTestReadDecorSCopy                     9   0    INFO scopy_cinfo.dInt1: 30000
 AthenaHiveEventLoopMgr                     9   0    INFO   ===>>>  done processing event #9, run #0 on slot 0,  10 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    10   0    INFO   ===>>>  start processing event #10, run #0 on slot 0,  10 events processed so far  <<<===
+SGInputLoader                             10   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         10   0    INFO cvec.dInt1: 4401 4402 4403 4404 4405 4406 4407 4408 4409 4410
 xAODTestReadDecor                         10   0    INFO cinfo.dInt1: 33000
 xAODTestReadDecor                         10   0    INFO cinfo.dInt1Base: 33001
 xAODTestReadDecor                         10   0    INFO cinfo.dInt1: 33000
+xAODTestReadDecorSCopy                    10   0    INFO scopy_cvec.dInt1: 4401 4402 4403 4404 4405 4406 4407 4408 4409 4410
+xAODTestReadDecorSCopy                    10   0    INFO scopy_cinfo.dInt1: 33000
+xAODTestReadDecorSCopy                    10   0    INFO scopy_cinfo.dInt1Base: 33001
+xAODTestReadDecorSCopy                    10   0    INFO scopy_cinfo.dInt1: 33000
 AthenaHiveEventLoopMgr                    10   0    INFO   ===>>>  done processing event #10, run #0 on slot 0,  11 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    11   0    INFO   ===>>>  start processing event #11, run #0 on slot 0,  11 events processed so far  <<<===
+SGInputLoader                             11   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         11   0    INFO cvec.dInt1: 4801 4802 4803 4804 4805 4806 4807 4808 4809 4810
 xAODTestReadDecor                         11   0    INFO cinfo.dInt1: 36000
 xAODTestReadDecor                         11   0    INFO cinfo.dInt1Base: 36001
 xAODTestReadDecor                         11   0    INFO cinfo.dInt1: 36000
+xAODTestReadDecorSCopy                    11   0    INFO scopy_cvec.dInt1: 4801 4802 4803 4804 4805 4806 4807 4808 4809 4810
+xAODTestReadDecorSCopy                    11   0    INFO scopy_cinfo.dInt1: 36000
+xAODTestReadDecorSCopy                    11   0    INFO scopy_cinfo.dInt1Base: 36001
+xAODTestReadDecorSCopy                    11   0    INFO scopy_cinfo.dInt1: 36000
 AthenaHiveEventLoopMgr                    11   0    INFO   ===>>>  done processing event #11, run #0 on slot 0,  12 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    12   0    INFO   ===>>>  start processing event #12, run #0 on slot 0,  12 events processed so far  <<<===
+SGInputLoader                             12   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         12   0    INFO cvec.dInt1: 5201 5202 5203 5204 5205 5206 5207 5208 5209 5210
 xAODTestReadDecor                         12   0    INFO cinfo.dInt1: 39000
 xAODTestReadDecor                         12   0    INFO cinfo.dInt1Base: 39001
 xAODTestReadDecor                         12   0    INFO cinfo.dInt1: 39000
+xAODTestReadDecorSCopy                    12   0    INFO scopy_cvec.dInt1: 5201 5202 5203 5204 5205 5206 5207 5208 5209 5210
+xAODTestReadDecorSCopy                    12   0    INFO scopy_cinfo.dInt1: 39000
+xAODTestReadDecorSCopy                    12   0    INFO scopy_cinfo.dInt1Base: 39001
+xAODTestReadDecorSCopy                    12   0    INFO scopy_cinfo.dInt1: 39000
 AthenaHiveEventLoopMgr                    12   0    INFO   ===>>>  done processing event #12, run #0 on slot 0,  13 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    13   0    INFO   ===>>>  start processing event #13, run #0 on slot 0,  13 events processed so far  <<<===
+SGInputLoader                             13   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         13   0    INFO cvec.dInt1: 5601 5602 5603 5604 5605 5606 5607 5608 5609 5610
 xAODTestReadDecor                         13   0    INFO cinfo.dInt1: 42000
 xAODTestReadDecor                         13   0    INFO cinfo.dInt1Base: 42001
 xAODTestReadDecor                         13   0    INFO cinfo.dInt1: 42000
+xAODTestReadDecorSCopy                    13   0    INFO scopy_cvec.dInt1: 5601 5602 5603 5604 5605 5606 5607 5608 5609 5610
+xAODTestReadDecorSCopy                    13   0    INFO scopy_cinfo.dInt1: 42000
+xAODTestReadDecorSCopy                    13   0    INFO scopy_cinfo.dInt1Base: 42001
+xAODTestReadDecorSCopy                    13   0    INFO scopy_cinfo.dInt1: 42000
 AthenaHiveEventLoopMgr                    13   0    INFO   ===>>>  done processing event #13, run #0 on slot 0,  14 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    14   0    INFO   ===>>>  start processing event #14, run #0 on slot 0,  14 events processed so far  <<<===
+SGInputLoader                             14   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         14   0    INFO cvec.dInt1: 6001 6002 6003 6004 6005 6006 6007 6008 6009 6010
 xAODTestReadDecor                         14   0    INFO cinfo.dInt1: 45000
 xAODTestReadDecor                         14   0    INFO cinfo.dInt1Base: 45001
 xAODTestReadDecor                         14   0    INFO cinfo.dInt1: 45000
+xAODTestReadDecorSCopy                    14   0    INFO scopy_cvec.dInt1: 6001 6002 6003 6004 6005 6006 6007 6008 6009 6010
+xAODTestReadDecorSCopy                    14   0    INFO scopy_cinfo.dInt1: 45000
+xAODTestReadDecorSCopy                    14   0    INFO scopy_cinfo.dInt1Base: 45001
+xAODTestReadDecorSCopy                    14   0    INFO scopy_cinfo.dInt1: 45000
 AthenaHiveEventLoopMgr                    14   0    INFO   ===>>>  done processing event #14, run #0 on slot 0,  15 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    15   0    INFO   ===>>>  start processing event #15, run #0 on slot 0,  15 events processed so far  <<<===
+SGInputLoader                             15   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         15   0    INFO cvec.dInt1: 6401 6402 6403 6404 6405 6406 6407 6408 6409 6410
 xAODTestReadDecor                         15   0    INFO cinfo.dInt1: 48000
 xAODTestReadDecor                         15   0    INFO cinfo.dInt1Base: 48001
 xAODTestReadDecor                         15   0    INFO cinfo.dInt1: 48000
+xAODTestReadDecorSCopy                    15   0    INFO scopy_cvec.dInt1: 6401 6402 6403 6404 6405 6406 6407 6408 6409 6410
+xAODTestReadDecorSCopy                    15   0    INFO scopy_cinfo.dInt1: 48000
+xAODTestReadDecorSCopy                    15   0    INFO scopy_cinfo.dInt1Base: 48001
+xAODTestReadDecorSCopy                    15   0    INFO scopy_cinfo.dInt1: 48000
 AthenaHiveEventLoopMgr                    15   0    INFO   ===>>>  done processing event #15, run #0 on slot 0,  16 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    16   0    INFO   ===>>>  start processing event #16, run #0 on slot 0,  16 events processed so far  <<<===
+SGInputLoader                             16   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         16   0    INFO cvec.dInt1: 6801 6802 6803 6804 6805 6806 6807 6808 6809 6810
 xAODTestReadDecor                         16   0    INFO cinfo.dInt1: 51000
 xAODTestReadDecor                         16   0    INFO cinfo.dInt1Base: 51001
 xAODTestReadDecor                         16   0    INFO cinfo.dInt1: 51000
+xAODTestReadDecorSCopy                    16   0    INFO scopy_cvec.dInt1: 6801 6802 6803 6804 6805 6806 6807 6808 6809 6810
+xAODTestReadDecorSCopy                    16   0    INFO scopy_cinfo.dInt1: 51000
+xAODTestReadDecorSCopy                    16   0    INFO scopy_cinfo.dInt1Base: 51001
+xAODTestReadDecorSCopy                    16   0    INFO scopy_cinfo.dInt1: 51000
 AthenaHiveEventLoopMgr                    16   0    INFO   ===>>>  done processing event #16, run #0 on slot 0,  17 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    17   0    INFO   ===>>>  start processing event #17, run #0 on slot 0,  17 events processed so far  <<<===
+SGInputLoader                             17   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         17   0    INFO cvec.dInt1: 7201 7202 7203 7204 7205 7206 7207 7208 7209 7210
 xAODTestReadDecor                         17   0    INFO cinfo.dInt1: 54000
 xAODTestReadDecor                         17   0    INFO cinfo.dInt1Base: 54001
 xAODTestReadDecor                         17   0    INFO cinfo.dInt1: 54000
+xAODTestReadDecorSCopy                    17   0    INFO scopy_cvec.dInt1: 7201 7202 7203 7204 7205 7206 7207 7208 7209 7210
+xAODTestReadDecorSCopy                    17   0    INFO scopy_cinfo.dInt1: 54000
+xAODTestReadDecorSCopy                    17   0    INFO scopy_cinfo.dInt1Base: 54001
+xAODTestReadDecorSCopy                    17   0    INFO scopy_cinfo.dInt1: 54000
 AthenaHiveEventLoopMgr                    17   0    INFO   ===>>>  done processing event #17, run #0 on slot 0,  18 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    18   0    INFO   ===>>>  start processing event #18, run #0 on slot 0,  18 events processed so far  <<<===
+SGInputLoader                             18   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         18   0    INFO cvec.dInt1: 7601 7602 7603 7604 7605 7606 7607 7608 7609 7610
 xAODTestReadDecor                         18   0    INFO cinfo.dInt1: 57000
 xAODTestReadDecor                         18   0    INFO cinfo.dInt1Base: 57001
 xAODTestReadDecor                         18   0    INFO cinfo.dInt1: 57000
+xAODTestReadDecorSCopy                    18   0    INFO scopy_cvec.dInt1: 7601 7602 7603 7604 7605 7606 7607 7608 7609 7610
+xAODTestReadDecorSCopy                    18   0    INFO scopy_cinfo.dInt1: 57000
+xAODTestReadDecorSCopy                    18   0    INFO scopy_cinfo.dInt1Base: 57001
+xAODTestReadDecorSCopy                    18   0    INFO scopy_cinfo.dInt1: 57000
 AthenaHiveEventLoopMgr                    18   0    INFO   ===>>>  done processing event #18, run #0 on slot 0,  19 events processed so far  <<<===
 AthenaHiveEventLoopMgr                    19   0    INFO   ===>>>  start processing event #19, run #0 on slot 0,  19 events processed so far  <<<===
+SGInputLoader                             19   0 WARNING unable to find proxy for  ( 'SG::AuxElement' , 'StoreGateSvc+scopy_cinfo.dInt1Base' ) 
 xAODTestReadDecor                         19   0    INFO cvec.dInt1: 8001 8002 8003 8004 8005 8006 8007 8008 8009 8010
 xAODTestReadDecor                         19   0    INFO cinfo.dInt1: 60000
 xAODTestReadDecor                         19   0    INFO cinfo.dInt1Base: 60001
 xAODTestReadDecor                         19   0    INFO cinfo.dInt1: 60000
+xAODTestReadDecorSCopy                    19   0    INFO scopy_cvec.dInt1: 8001 8002 8003 8004 8005 8006 8007 8008 8009 8010
+xAODTestReadDecorSCopy                    19   0    INFO scopy_cinfo.dInt1: 60000
+xAODTestReadDecorSCopy                    19   0    INFO scopy_cinfo.dInt1Base: 60001
+xAODTestReadDecorSCopy                    19   0    INFO scopy_cinfo.dInt1: 60000
 AthenaHiveEventLoopMgr                    19   0    INFO   ===>>>  done processing event #19, run #0 on slot 0,  20 events processed so far  <<<===
-AthenaHiveEventLoopMgr                    19   0    INFO ---> Loop Finished (seconds): 0.0376902
+AthenaHiveEventLoopMgr                    19   0    INFO ---> Loop Finished (seconds): 0.0770563
 ApplicationMgr                                      INFO Application Manager Stopped successfully
 IncidentProcAlg1                                    INFO Finalize
 SGInputLoader                                       INFO Finalizing SGInputLoader...
diff --git a/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1_jo.py b/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1_jo.py
index f380e434b1012e2bfc680d53147c10fdb68dccc6..32b90501e9bd4eb49230df7706faa54bf3cfede7 100644
--- a/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1_jo.py
+++ b/Control/DataModelTest/DataModelRunTests/share/xAODTestDecorHandle1_jo.py
@@ -41,7 +41,8 @@ from DataModelTestDataCommon.DataModelTestDataCommonConf import \
      DMTest__xAODTestWriteCVec, \
      DMTest__xAODTestWriteCInfo, \
      DMTest__xAODTestDecor, \
-     DMTest__xAODTestReadDecor
+     DMTest__xAODTestReadDecor, \
+     DMTest__xAODTestShallowCopy
 from DataModelTestDataWrite.DataModelTestDataWriteConf import \
      DMTest__xAODTestWrite
 topSequence += DMTest__xAODTestWriteCVec ("xAODTestWriteCVec")
@@ -50,5 +51,10 @@ topSequence += DMTest__xAODTestWrite ("xAODTestWrite")
 topSequence += DMTest__xAODTestDecor ("xAODTestDecor")
 topSequence += DMTest__xAODTestReadDecor ("xAODTestReadDecor")
 
+topSequence += DMTest__xAODTestShallowCopy ("xAODTestShallowCopy",
+                                            CVecWDReadKey = '',
+                                            CTrigReadKey = '')
+topSequence += DMTest__xAODTestReadDecor ("xAODTestReadDecorSCopy",
+                                          ReadPrefix = "scopy_")
 
 include ('DataModelRunTests/commonTrailer.py')
diff --git a/Control/DataModelTest/DataModelRunTests/share/xAODTestRead_jo.py b/Control/DataModelTest/DataModelRunTests/share/xAODTestRead_jo.py
index 4b4285cae8969b63ab588433de7ed0c4525c4935..774c7c4db1d0a0bfe10b5739668fb1ae5f4aa5df 100755
--- a/Control/DataModelTest/DataModelRunTests/share/xAODTestRead_jo.py
+++ b/Control/DataModelTest/DataModelRunTests/share/xAODTestRead_jo.py
@@ -96,14 +96,15 @@ theApp.EvtMax = 20
 
 from DataModelTestDataCommon.DataModelTestDataCommonConf import \
      DMTest__xAODTestReadCVec, \
-     DMTest__xAODTestDecor
+     DMTest__xAODTestDecor, \
+     DMTest__xAODTestShallowCopy
 from DataModelTestDataRead.DataModelTestDataReadConf import \
      DMTest__xAODTestReadCInfo, \
      DMTest__xAODTestRead, \
      DMTest__xAODTestReadCView, \
      DMTest__xAODTestReadHVec, \
      DMTest__xAODTestClearDecor, \
-     DMTest__xAODTestShallowCopy
+     DMTest__xAODTestShallowCopyHVec
 
 
 topSequence += DMTest__xAODTestReadCVec ('xAODTestReadCVec',
@@ -124,8 +125,8 @@ topSequence += DMTest__xAODTestDecor ('AuxDataTestDecor1',
                                       DecorName = 'dInt100',
                                       Offset = 100)
 
-topSequence += DMTest__xAODTestShallowCopy ('xAODTestShallowCopy',
-                                            WritePrefix = 'scopy_')
+topSequence += DMTest__xAODTestShallowCopy ('xAODTestShallowCopy')
+topSequence += DMTest__xAODTestShallowCopyHVec ('xAODTestShallowCopyHVec')
 
 topSequence += DMTest__xAODTestDecor ('AuxDataTestDecor1_scopy',
                                       ReadPrefix = 'scopy_',
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/components/DataModelTestDataCommon_entries.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/components/DataModelTestDataCommon_entries.cxx
index ee2c82bd1674c2271c91e8585b7794fa5f2f83b7..5ac3ef370136f8613036e0fadc3b319c02d1a117 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/components/DataModelTestDataCommon_entries.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/components/DataModelTestDataCommon_entries.cxx
@@ -1,8 +1,6 @@
 /*
- * Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration.
+ * Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration.
  */
-
-// $Id$
 /**
  * @file DataModeltestDataCommon/src/components/DataModelTestDataCommon_entries.cxx
  * @author snyder@bnl.gov
@@ -21,6 +19,7 @@
 #include "../xAODTestWriteCLinks.h"
 #include "../xAODTestReadCVec.h"
 #include "../xAODTestReadCLinks.h"
+#include "../xAODTestShallowCopy.h"
 #include "../CondWriterAlg.h"
 #include "../CondWriterExtAlg.h"
 #include "../CondReaderAlg.h"
@@ -41,6 +40,7 @@ DECLARE_COMPONENT( DMTest::xAODTestThinCVec )
 DECLARE_COMPONENT( DMTest::xAODTestWriteCLinks )
 DECLARE_COMPONENT( DMTest::xAODTestReadCVec )
 DECLARE_COMPONENT( DMTest::xAODTestReadCLinks )
+DECLARE_COMPONENT( DMTest::xAODTestShallowCopy )
 DECLARE_COMPONENT( DMTest::CondWriterAlg )
 DECLARE_COMPONENT( DMTest::CondWriterExtAlg )
 DECLARE_COMPONENT( DMTest::CondReaderAlg )
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx
index b3b0b48fc2f64dad1f88118d9dbc0de42893192b..8da08f9de17c67cd79b9b08be7a0b4ed80409c30 100644
--- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx
@@ -1,7 +1,6 @@
 /*
- * Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration.
+ * Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration.
  */
-// $Id$
 /**
  * @file DataModelTestDataCommon/src/AuxDataTestDecor.cxx
  * @author snyder@bnl.gov
@@ -46,15 +45,19 @@ xAODTestReadDecor::xAODTestReadDecor (const std::string &name,
  */
 StatusCode xAODTestReadDecor::initialize()
 {
-  m_cvecDecorKey  = m_readPrefix + m_cvecName +  "."  + m_decorName;
-  m_cinfoDecorKey = m_readPrefix + m_cinfoName + "." + m_decorName;
-  m_cinfoBaseDecorKey = m_readPrefix + m_cinfoName + "." + m_decorName + "Base";
-  m_objDecorKey = m_readPrefix + m_cinfoName + "." + m_decorName;
-
-  ATH_CHECK( m_cvecDecorKey.initialize() );
-  ATH_CHECK( m_cinfoDecorKey.initialize() );
-  ATH_CHECK( m_cinfoBaseDecorKey.initialize() );
-  ATH_CHECK( m_objDecorKey.initialize() );
+  if (!m_cvecName.empty()) {
+    m_cvecDecorKey  = m_readPrefix + m_cvecName +  "."  + m_decorName;
+    ATH_CHECK( m_cvecDecorKey.initialize() );
+  }
+
+  if (!m_cinfoName.empty()) {
+    m_cinfoDecorKey = m_readPrefix + m_cinfoName + "." + m_decorName;
+    m_cinfoBaseDecorKey = m_readPrefix + m_cinfoName + "." + m_decorName + "Base";
+    m_objDecorKey = m_readPrefix + m_cinfoName + "." + m_decorName;
+    ATH_CHECK( m_cinfoDecorKey.initialize() );
+    ATH_CHECK( m_cinfoBaseDecorKey.initialize() );
+    ATH_CHECK( m_objDecorKey.initialize() );
+  }
   return StatusCode::SUCCESS;
 }
 
@@ -64,7 +67,7 @@ StatusCode xAODTestReadDecor::initialize()
  */
 StatusCode xAODTestReadDecor::execute (const EventContext& ctx) const
 {
-  {
+  if (!m_cvecDecorKey.empty()) {
     std::ostringstream ss;
     SG::ReadDecorHandle<CVec, int> cvecDecor (m_cvecDecorKey, ctx);
     if (!cvecDecor.isPresent()) return StatusCode::FAILURE;
@@ -74,25 +77,25 @@ StatusCode xAODTestReadDecor::execute (const EventContext& ctx) const
     ATH_MSG_INFO (m_cvecDecorKey.key() << ":" << ss.str());
   }
 
-  {
+  if (!m_cinfoDecorKey.empty()) {
     SG::ReadDecorHandle<C, int> cinfoDecor (m_cinfoDecorKey, ctx);
     if (!cinfoDecor.isPresent()) return StatusCode::FAILURE;
     ATH_MSG_INFO (m_cinfoDecorKey.key() << ": " << cinfoDecor(0));
   }
 
-  {
+  if (!m_cinfoBaseDecorKey.empty()) {
     SG::ReadDecorHandle<C, int> cinfoBaseDecor (m_cinfoBaseDecorKey, ctx);
     if (!cinfoBaseDecor.isPresent()) return StatusCode::FAILURE;
     ATH_MSG_INFO (m_cinfoBaseDecorKey.key() << ": " << cinfoBaseDecor(0));
   }
 
-  {
+  if (!m_objDecorKey.empty()) {
     SG::ReadDecorHandle<SG::AuxElement, int> objDecor (m_objDecorKey, ctx);
     if (!objDecor.isPresent()) return StatusCode::FAILURE;
     ATH_MSG_INFO (m_objDecorKey.key() << ": " << objDecor(0));
   }
 
-  {
+  if (!m_cinfoDecorKey.empty()) {
     SG::ReadDecorHandleKey<C> testKey (m_cinfoDecorKey);
     testKey = testKey.key() + "_test";
     SG::ReadDecorHandle<C, int> cinfoDecorTest (testKey, ctx);
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestShallowCopy.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestShallowCopy.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..a2d9ae0dee76edf83bd84994cb436bc33ab36fba
--- /dev/null
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestShallowCopy.cxx
@@ -0,0 +1,155 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+/**
+ * @file DataModelTestDataCommon/src/xAODTestShallowCopy.cxx
+ * @author snyder@bnl.gov
+ * @date Nov 2020, from earlier version Jun, 2014
+ * @brief Algorithm to test shallow-copy of xAOD data.
+ */
+
+
+#include "xAODTestShallowCopy.h"
+#include "DataModelTestDataCommon/CVec.h"
+#include "DataModelTestDataCommon/CVecWithData.h"
+#include "DataModelTestDataCommon/C.h"
+#include "DataModelTestDataCommon/CAuxContainer.h"
+#include "DataModelTestDataCommon/CTrigAuxContainer.h"
+#include "DataModelTestDataCommon/CInfoAuxContainer.h"
+#include "xAODCore/ShallowCopy.h"
+#include "StoreGate/ReadHandle.h"
+#include "StoreGate/WriteHandle.h"
+#include "StoreGate/WriteDecorHandle.h"
+#include "AthContainers/AuxTypeRegistry.h"
+#include "AthenaKernel/errorcheck.h"
+
+
+namespace DMTest {
+
+
+/**
+ * @brief Algorithm initialization; called at the beginning of the job.
+ */
+StatusCode xAODTestShallowCopy::initialize()
+{
+  if (m_cvecReadKey.empty()) {
+    m_cvecWriteKey = "";
+    m_cvecAnInt10Key = "";
+  }
+  else {
+    ATH_CHECK( m_cvecReadKey.initialize() );
+    ATH_CHECK( m_cvecWriteKey.initialize() );
+    ATH_CHECK( m_cvecAnInt10Key.initialize() );
+    ATH_CHECK( m_cvecDecorDeps.initialize (m_cvecReadKey, m_cvecWriteKey) );
+  }
+
+  if (m_cvecWDReadKey.empty()) {
+    m_cvecWDWriteKey = "";
+    m_cvecWDAnInt10Key = "";
+  }
+  else {
+    ATH_CHECK( m_cvecWDReadKey.initialize() );
+    ATH_CHECK( m_cvecWDWriteKey.initialize() );
+    ATH_CHECK( m_cvecWDAnInt10Key.initialize() );
+    ATH_CHECK( m_cvecWDDecorDeps.initialize (m_cvecWDReadKey, m_cvecWDWriteKey) );
+  }
+
+  if (m_cinfoReadKey.empty()) {
+    m_cinfoWriteKey = "";
+    m_cinfoAnInt10Key = "";
+  }
+  else {
+    ATH_CHECK( m_cinfoReadKey.initialize() );
+    ATH_CHECK( m_cinfoWriteKey.initialize() );
+    ATH_CHECK( m_cinfoAnInt10Key.initialize() );
+    ATH_CHECK( m_cinfoDecorDeps.initialize (m_cinfoReadKey, m_cinfoWriteKey) );
+  }
+
+  if (m_ctrigReadKey.empty()) {
+    m_ctrigWriteKey = "";
+    m_ctrigAnInt10Key = "";
+  }
+  else {
+    ATH_CHECK( m_ctrigReadKey.initialize() );
+    ATH_CHECK( m_ctrigWriteKey.initialize() );
+    ATH_CHECK( m_ctrigAnInt10Key.initialize() );
+    ATH_CHECK( m_ctrigDecorDeps.initialize (m_ctrigReadKey, m_ctrigWriteKey) );
+  }
+
+  return StatusCode::SUCCESS;
+}
+
+
+/**
+ * @brief Algorithm event processing.
+ */
+StatusCode xAODTestShallowCopy::execute (const EventContext& ctx) const
+{
+  int count = ctx.evt() + 1;
+
+  if (!m_cvecReadKey.empty()) {
+    SG::ReadHandle<CVec> vec (m_cvecReadKey, ctx);
+    auto ret = xAOD::shallowCopyContainer (*vec);
+
+    SG::WriteHandle<DMTest::CVec> copy (m_cvecWriteKey, ctx);
+    ATH_CHECK( copy.record (std::unique_ptr<DMTest::CVec>(ret.first),
+                            std::unique_ptr<xAOD::ShallowAuxContainer>(ret.second)) );
+
+    ATH_CHECK( m_cvecDecorDeps.linkDecors (m_cvecReadKey, ctx) );
+
+    SG::WriteDecorHandle<DMTest::CVec, int> anInt10 (m_cvecAnInt10Key, ctx);
+    for (C* c : *ret.first)
+      anInt10(*c) = count * 20000 + c->anInt() * 100;
+  }
+
+  if (!m_cvecWDReadKey.empty()) {
+    SG::ReadHandle<CVecWithData> vec (m_cvecWDReadKey, ctx);
+    auto ret = xAOD::shallowCopyContainer (*vec);
+    ret.first->meta1 = vec->meta1;
+
+    SG::WriteHandle<DMTest::CVecWithData> copy (m_cvecWDWriteKey, ctx);
+    ATH_CHECK( copy.record (std::unique_ptr<DMTest::CVecWithData>(ret.first),
+                            std::unique_ptr<xAOD::ShallowAuxContainer>(ret.second)) );
+
+    ATH_CHECK( m_cvecWDDecorDeps.linkDecors (m_cvecWDReadKey, ctx) );
+
+    SG::WriteDecorHandle<DMTest::CVecWithData, int> anInt10 (m_cvecWDAnInt10Key, ctx);
+    for (C* c : *ret.first)
+      anInt10(*c) = count * 20000 + c->anInt() * 100;
+  }
+
+  if (!m_cinfoReadKey.empty()) {
+    SG::ReadHandle<C> cinfo (m_cinfoReadKey, ctx);
+    auto ret = xAOD::shallowCopyObject (*cinfo);
+
+    SG::WriteHandle<DMTest::C> copy (m_cinfoWriteKey, ctx);
+    ATH_CHECK( copy.record (std::unique_ptr<DMTest::C>(ret.first),
+                            std::unique_ptr<xAOD::ShallowAuxInfo>(ret.second)) );
+
+    ATH_CHECK( m_cinfoDecorDeps.linkDecors (m_cinfoReadKey, ctx) );
+
+    SG::WriteDecorHandle<DMTest::C, int> anInt10 (m_cinfoAnInt10Key, ctx);
+    anInt10(*ret.first) = count * 20000 + ret.first->anInt() * 200;
+  }
+
+  if (!m_ctrigReadKey.empty()) {
+    SG::ReadHandle<CVec> ctrig (m_ctrigReadKey, ctx);
+    auto ret = xAOD::shallowCopyContainer (*ctrig);
+
+    SG::WriteHandle<DMTest::CVec> copy (m_ctrigWriteKey, ctx);
+    ATH_CHECK( copy.record (std::unique_ptr<DMTest::CVec>(ret.first),
+                            std::unique_ptr<xAOD::ShallowAuxContainer>(ret.second)) );
+
+    ATH_CHECK( m_ctrigDecorDeps.linkDecors (m_ctrigReadKey, ctx) );
+
+    SG::WriteDecorHandle<DMTest::CVec, int> anInt10 (m_ctrigAnInt10Key, ctx);
+    for (C* c : *ret.first)
+      anInt10(*c) = count * 20000 + c->anInt() * 300;
+  }
+
+  return StatusCode::SUCCESS;
+}
+
+
+} // namespace DMTest
+
diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestShallowCopy.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestShallowCopy.h
new file mode 100644
index 0000000000000000000000000000000000000000..f6607709a4d50ddc594101a867ca27db81744724
--- /dev/null
+++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestShallowCopy.h
@@ -0,0 +1,95 @@
+// This file's extension implies that it's C, but it's really -*- C++ -*-.
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+/**
+ * @file DataModelTestDataCommon/src/xAODTestShallowCopy.h
+ * @author scott snyder <snyder@bnl.gov>
+ * @date Nov 2020, from earlier version Jun, 2014
+ * @brief Algorithm to test shallow-copy of xAOD data.
+ */
+
+
+#ifndef DATAMODELTESTDATACOMMON_XAODTESTSHALLOWCOPY_H
+#define DATAMODELTESTDATACOMMON_XAODTESTSHALLOWCOPY_H
+
+
+#include "AthenaBaseComps/AthReentrantAlgorithm.h"
+#include "DataModelTestDataCommon/C.h"
+#include "DataModelTestDataCommon/CVec.h"
+#include "DataModelTestDataCommon/CVecWithData.h"
+#include "StoreGate/ReadHandleKey.h"
+#include "StoreGate/WriteHandleKey.h"
+#include "StoreGate/WriteDecorHandleKey.h"
+#include "StoreGate/ShallowCopyDecorDeps.h"
+
+
+namespace DMTest {
+
+
+/**
+ * @brief Algorithm to do a shallow copy of CVec types.
+ */
+class xAODTestShallowCopy
+  : public AthReentrantAlgorithm
+{
+public:
+  using AthReentrantAlgorithm::AthReentrantAlgorithm;
+  
+
+  /**
+   * @brief Algorithm initialization; called at the beginning of the job.
+   */
+  virtual StatusCode initialize() override;
+
+
+  /**
+   * @brief Algorithm event processing.
+   */
+  virtual StatusCode execute (const EventContext& ctx) const override;
+
+
+private:
+  SG::ReadHandleKey<DMTest::CVec> m_cvecReadKey
+  { this, "CVecReadKey", "cvec", "Key for cvec object read from SG" };
+  SG::WriteHandleKey<DMTest::CVec> m_cvecWriteKey
+  { this, "CVecWriteKey", "scopy_cvec", "Key for cvec object written to SG" };
+  SG::WriteDecorHandleKey<DMTest::CVec> m_cvecAnInt10Key
+  { this, "CVecAnInt10Key", "scopy_cvec.anInt10", "Key for cvec anInt10 decoration" };
+  SG::ShallowCopyDecorDeps<DMTest::CVec> m_cvecDecorDeps
+  { this, "CVecDecorHelper", { "dInt1" } };
+
+  SG::ReadHandleKey<DMTest::CVecWithData> m_cvecWDReadKey
+  { this, "CVecWDReadKey", "cvecWD", "Key for cvecWD object read from SG" };
+  SG::WriteHandleKey<DMTest::CVecWithData> m_cvecWDWriteKey
+  { this, "CVecWDWriteKey", "scopy_cvecWD", "Key for cvecWD object written to SG" };
+  SG::WriteDecorHandleKey<DMTest::CVecWithData> m_cvecWDAnInt10Key
+  { this, "CVecWDAnInt10Key", "scopy_cvecWD.anInt10", "Key for cvecWD anInt10 decoration" };
+  SG::ShallowCopyDecorDeps<DMTest::CVecWithData> m_cvecWDDecorDeps
+  { this, "CVecWDDecorHelper", { "dInt1" } };
+
+  SG::ReadHandleKey<DMTest::C> m_cinfoReadKey
+  { this, "CInfoReadKey", "cinfo", "Key for cinfo object read from SG" };
+  SG::WriteHandleKey<DMTest::C> m_cinfoWriteKey
+  { this, "CInfoWriteKey", "scopy_cinfo", "Key for cinfo object written to SG" };
+  SG::WriteDecorHandleKey<DMTest::C> m_cinfoAnInt10Key
+  { this, "CInfoAnInt10Key", "scopy_cinfo.anInt10", "Key for cinfo anInt10 decoration" };
+  SG::ShallowCopyDecorDeps<DMTest::C> m_cinfoDecorDeps
+  { this, "CInfoDecorHelper", { "dInt1" } };
+
+  SG::ReadHandleKey<DMTest::CVec> m_ctrigReadKey
+  { this, "CTrigReadKey", "ctrig", "Key for ctrig object read from SG" };
+  SG::WriteHandleKey<DMTest::CVec> m_ctrigWriteKey
+  { this, "CTrigWriteKey", "scopy_ctrig", "Key for ctrig object written to SG" };
+  SG::WriteDecorHandleKey<DMTest::CVec> m_ctrigAnInt10Key
+  { this, "CTrigAnInt10Key", "scopy_ctrig.anInt10", "Key for ctrig anInt10 decoration" };
+  SG::ShallowCopyDecorDeps<DMTest::CVec> m_ctrigDecorDeps
+  { this, "CTrigDecorHelper", { "dInt1" } };
+
+};
+
+
+} // namespace DMTest
+
+
+#endif // not DATAMODELTESTDATACOMMON_XAODTESTSHALLOWCOPY_H
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/components/DataModelTestDataRead_entries.cxx b/Control/DataModelTest/DataModelTestDataRead/src/components/DataModelTestDataRead_entries.cxx
index ba0775b1d5e90a0c0465a70b2b1941db28d04931..f00921e8e38fabf7fbd6823579dbcd01116ee5f9 100644
--- a/Control/DataModelTest/DataModelTestDataRead/src/components/DataModelTestDataRead_entries.cxx
+++ b/Control/DataModelTest/DataModelTestDataRead/src/components/DataModelTestDataRead_entries.cxx
@@ -18,7 +18,7 @@
 #include "../xAODTestFilterCVec.h"
 #include "../xAODTestClearDecor.h"
 #include "../xAODTestTypelessRead.h"
-#include "../xAODTestShallowCopy.h"
+#include "../xAODTestShallowCopyHVec.h"
 #include "../HLTResultReader.h"
 
 DECLARE_COMPONENT( DMTest::DMTestRead )
@@ -33,6 +33,6 @@ DECLARE_COMPONENT( DMTest::xAODTestReadHVec )
 DECLARE_COMPONENT( DMTest::xAODTestFilterCVec )
 DECLARE_COMPONENT( DMTest::xAODTestClearDecor )
 DECLARE_COMPONENT( DMTest::xAODTestTypelessRead )
-DECLARE_COMPONENT( DMTest::xAODTestShallowCopy )
+DECLARE_COMPONENT( DMTest::xAODTestShallowCopyHVec )
 DECLARE_COMPONENT( DMTest::HLTResultReader )
 
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopy.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopy.cxx
deleted file mode 100644
index 695f851a4bc5ef58ab6085d59c981d463412585d..0000000000000000000000000000000000000000
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopy.cxx
+++ /dev/null
@@ -1,140 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-// $Id$
-/**
- * @file  src/xAODTestShallowCopy.cxx
- * @author snyder@bnl.gov
- * @date Jun, 2014
- * @brief Algorithm to test shallow-copy of xAOD data.
- */
-
-
-#include "xAODTestShallowCopy.h"
-#include "DataModelTestDataCommon/CVec.h"
-#include "DataModelTestDataCommon/CVecWithData.h"
-#include "DataModelTestDataCommon/C.h"
-#include "DataModelTestDataCommon/CAuxContainer.h"
-#include "DataModelTestDataCommon/CTrigAuxContainer.h"
-#include "DataModelTestDataCommon/CInfoAuxContainer.h"
-#include "DataModelTestDataRead/HVec.h"
-#include "DataModelTestDataRead/H.h"
-#include "DataModelTestDataRead/HAuxContainer.h"
-#include "xAODCore/ShallowCopy.h"
-#include "AthContainers/AuxTypeRegistry.h"
-#include "AthenaKernel/errorcheck.h"
-
-
-namespace DMTest {
-
-
-/**
- * @brief Constructor.
- * @param name The algorithm name.
- * @param svc The service locator.
- */
-xAODTestShallowCopy::xAODTestShallowCopy (const std::string &name,
-                            ISvcLocator *pSvcLocator)
-  : AthAlgorithm (name, pSvcLocator),
-    m_count(0)
-{
-  declareProperty ("ReadPrefix",  m_readPrefix);
-  declareProperty ("WritePrefix", m_writePrefix);
-}
-  
-
-/**
- * @brief Algorithm initialization; called at the beginning of the job.
- */
-StatusCode xAODTestShallowCopy::initialize()
-{
-  return StatusCode::SUCCESS;
-}
-
-
-/**
- * @brief Algorithm event processing.
- */
-StatusCode xAODTestShallowCopy::execute()
-{
-  ++m_count;
-
-  static C::Accessor<int> anInt10 ("anInt10");
-
-  {
-    const CVec* vec = 0;
-    CHECK( evtStore()->retrieve (vec, m_readPrefix + "cvec") );
-    auto ret = xAOD::shallowCopyContainer (*vec);
-
-    for (C* c : *ret.first)
-      anInt10(*c) = m_count * 20000 + c->anInt() * 100;
-
-    CHECK (evtStore()->record (ret.first, m_writePrefix + "cvec", false));
-    CHECK (evtStore()->record (ret.second, m_writePrefix + "cvecAux.", false));
-  }
-
-  {
-    const CVecWithData* vec = 0;
-    CHECK( evtStore()->retrieve (vec, m_readPrefix + "cvecWD") );
-    auto ret = xAOD::shallowCopyContainer (*vec);
-    ret.first->meta1 = vec->meta1;
-
-    for (C* c : *ret.first)
-      anInt10(*c) = m_count * 20000 + c->anInt() * 100;
-
-    CHECK (evtStore()->record (ret.first, m_writePrefix + "cvecWD", false));
-    CHECK (evtStore()->record (ret.second, m_writePrefix + "cvecWDAux.", false));
-  }
-
-  {
-    const C* cinfo = 0;
-    CHECK( evtStore()->retrieve (cinfo, m_readPrefix + "cinfo") );
-    auto ret = xAOD::shallowCopyObject (*cinfo);
-
-    anInt10(*ret.first) = m_count * 20000 + ret.first->anInt() * 200;
-
-    CHECK (evtStore()->record (ret.first, m_writePrefix + "cinfo", false));
-    CHECK (evtStore()->record (ret.second, m_writePrefix + "cinfoAux.", false));
-  }
-
-  {
-    const CVec* ctrig = 0;
-    CHECK( evtStore()->retrieve (ctrig, m_readPrefix + "ctrig") );
-    auto ret = xAOD::shallowCopyContainer (*ctrig);
-
-    for (C* c : *ret.first)
-      anInt10(*c) = m_count * 20000 + c->anInt() * 300;
-
-    CHECK (evtStore()->record (ret.first, m_writePrefix + "ctrig", false));
-    CHECK (evtStore()->record (ret.second, m_writePrefix + "ctrigAux.", false));
-  }
-
-  {
-    static H::Accessor<float> aFloat20 ("aFloat20");
-    const HVec* vec = 0;
-    CHECK( evtStore()->retrieve (vec, m_readPrefix + "hvec") );
-    auto ret = xAOD::shallowCopyContainer (*vec);
-
-    for (H* h : *ret.first)
-      aFloat20(*h) = m_count * 20000 + h->aFloat();
-
-    CHECK (evtStore()->record (ret.first, m_writePrefix + "hvec", false));
-    CHECK (evtStore()->record (ret.second, m_writePrefix + "hvecAux.", false));
-  }
-
-  return StatusCode::SUCCESS;
-}
-
-
-/**
- * @brief Algorithm finalization; called at the end of the job.
- */
-StatusCode xAODTestShallowCopy::finalize()
-{
-  return StatusCode::SUCCESS;
-}
-
-
-} // namespace DMTest
-
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopy.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopy.h
deleted file mode 100644
index 5853c5c80f45572f5db6a7d02d8057e3e74bb585..0000000000000000000000000000000000000000
--- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopy.h
+++ /dev/null
@@ -1,74 +0,0 @@
-// 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
-*/
-
-// $Id$
-/**
- * @file src/xAODTestShallowCopy.h
- * @author scott snyder <snyder@bnl.gov>
- * @date Jun, 2014
- * @brief Algorithm to test shallow-copy of xAOD data.
- */
-
-
-#ifndef DATAMODELTESTDATAREAD_XAODTESTSHALLOWCOPY_H
-#define DATAMODELTESTDATAREAD_XAODTESTSHALLOWCOPY_H
-
-
-#include "AthenaBaseComps/AthAlgorithm.h"
-
-
-namespace DMTest {
-
-
-/**
- * @brief Algorithm for reading test aux data.
- */
-class xAODTestShallowCopy
-  : public AthAlgorithm
-{
-public:
-  /**
-   * @brief Constructor.
-   * @param name The algorithm name.
-   * @param svc The service locator.
-   */
-  xAODTestShallowCopy (const std::string &name, ISvcLocator *pSvcLocator);
-  
-
-  /**
-   * @brief Algorithm initialization; called at the beginning of the job.
-   */
-  virtual StatusCode initialize();
-
-
-  /**
-   * @brief Algorithm event processing.
-   */
-  virtual StatusCode execute(); 
-
-
-  /**
-   * @brief Algorithm finalization; called at the end of the job.
-   */
-  virtual StatusCode finalize();
-
-
-private:
-  /// Parameter: Prefix for names read from SG.
-  std::string m_readPrefix;
-
-  /// Parameter: Prefix for names written to SG.  Null for no write.
-  std::string m_writePrefix;
-
-  /// Event counter.
-  int m_count;
-};
-
-
-} // namespace DMTest
-
-
-#endif // not DATAMODELTESTDATAREAD_XAODTESTSHALLOWCOPY_H
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopyHVec.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopyHVec.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..4ae333ec496c1970617b6294ebbd2bfaa923a342
--- /dev/null
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopyHVec.cxx
@@ -0,0 +1,64 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+/**
+ * @file DataModelTestDataRead/src/xAODTestShallowCopyHVec.cxx
+ * @author snyder@bnl.gov
+ * @date Nov 2020, from earlier version Jun, 2014
+ * @brief Algorithm to test shallow-copy of xAOD data.
+ */
+
+
+#include "xAODTestShallowCopyHVec.h"
+#include "DataModelTestDataRead/HVec.h"
+#include "DataModelTestDataRead/H.h"
+#include "DataModelTestDataRead/HAuxContainer.h"
+#include "xAODCore/ShallowCopy.h"
+#include "StoreGate/ReadHandle.h"
+#include "StoreGate/WriteHandle.h"
+#include "StoreGate/WriteDecorHandle.h"
+#include "AthContainers/AuxTypeRegistry.h"
+#include "AthenaKernel/errorcheck.h"
+
+
+namespace DMTest {
+
+
+/**
+ * @brief Algorithm initialization; called at the beginning of the job.
+ */
+StatusCode xAODTestShallowCopyHVec::initialize()
+{
+  ATH_CHECK( m_readKey.initialize() );
+  ATH_CHECK( m_writeKey.initialize() );
+  ATH_CHECK( m_aFloat20Key.initialize() );
+  return StatusCode::SUCCESS;
+}
+
+
+/**
+ * @brief Algorithm event processing.
+ */
+StatusCode xAODTestShallowCopyHVec::execute (const EventContext& ctx) const
+{
+  size_t count = ctx.evt() + 1;
+
+  {
+    SG::ReadHandle<DMTest::HVec> vec (m_readKey, ctx);
+    auto ret = xAOD::shallowCopyContainer (*vec);
+
+    SG::WriteHandle<DMTest::HVec> copy (m_writeKey, ctx);
+    ATH_CHECK( copy.record (std::unique_ptr<DMTest::HVec>(ret.first),
+                            std::unique_ptr<xAOD::ShallowAuxContainer>(ret.second)) );
+
+    SG::WriteDecorHandle<DMTest::HVec, float> aFloat20 (m_aFloat20Key, ctx);
+    for (H* h : *ret.first)
+      aFloat20(*h) = count * 20000 + h->aFloat();
+  }
+
+  return StatusCode::SUCCESS;
+}
+
+
+} // namespace DMTest
+
diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopyHVec.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopyHVec.h
new file mode 100644
index 0000000000000000000000000000000000000000..63d1c43aec53daee636e6bfb5b244d389e136fac
--- /dev/null
+++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestShallowCopyHVec.h
@@ -0,0 +1,65 @@
+// This file's extension implies that it's C, but it's really -*- C++ -*-.
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+/**
+ * @file DataModelTestDataRead/src/xAODTestShallowCopyHVec.h
+ * @author scott snyder <snyder@bnl.gov>
+ * @date Nov 2020, from earlier version Jun, 2014
+ * @brief Algorithm to test shallow-copy of xAOD data.
+ */
+
+
+#ifndef DATAMODELTESTDATAREAD_XAODTESTSHALLOWCOPYHVEC_H
+#define DATAMODELTESTDATAREAD_XAODTESTSHALLOWCOPYHVEC_H
+
+
+#include "AthenaBaseComps/AthReentrantAlgorithm.h"
+#include "DataModelTestDataRead/HVec.h"
+#include "StoreGate/ReadHandleKey.h"
+#include "StoreGate/WriteHandleKey.h"
+#include "StoreGate/WriteDecorHandleKey.h"
+#include "StoreGate/ShallowCopyDecorDeps.h"
+
+
+namespace DMTest {
+
+
+/**
+ * @brief Algorithm to do a shallow copy of HVec types.
+ */
+class xAODTestShallowCopyHVec
+  : public AthReentrantAlgorithm
+{
+public:
+  using AthReentrantAlgorithm::AthReentrantAlgorithm;
+  
+
+  /**
+   * @brief Algorithm initialization; called at the beginning of the job.
+   */
+  virtual StatusCode initialize() override;
+
+
+  /**
+   * @brief Algorithm event processing.
+   */
+  virtual StatusCode execute (const EventContext& ctx) const override;
+
+
+private:
+  SG::ReadHandleKey<DMTest::HVec> m_readKey
+  { this, "ReadKey", "hvec", "Key for object read from SG" };
+
+  SG::WriteHandleKey<DMTest::HVec> m_writeKey
+  { this, "WriteKey", "scopy_hvec", "Key for object written to SG" };
+
+  SG::WriteDecorHandleKey<DMTest::HVec> m_aFloat20Key
+  { this, "AFloat20Key", "scopy_hvec.aFloat20", "Key for aFloat20 decoration" };
+};
+
+
+} // namespace DMTest
+
+
+#endif // not DATAMODELTESTDATAREAD_XAODTESTSHALLOWCOPYHVEC_H
diff --git a/Control/IOVSvc/src/IOVSvcTool.cxx b/Control/IOVSvc/src/IOVSvcTool.cxx
index 885a2e62cf0d8fda7dc92403b9c87a1b1ee1f0f4..20b7b57532b76fb6ac6c45691a023ecd7f17db09 100644
--- a/Control/IOVSvc/src/IOVSvcTool.cxx
+++ b/Control/IOVSvc/src/IOVSvcTool.cxx
@@ -996,9 +996,13 @@ IOVSvcTool::preLoadProxies() {
         ATH_MSG_VERBOSE("preloading data for ("
                         << dp->clID() << "/"
                         << dp->name() << ")");
-
-        sc =  ( dp->accessData() != nullptr ?
-                StatusCode::SUCCESS : StatusCode::FAILURE );
+        if( dp->accessData() != nullptr ) {
+           sc = StatusCode::SUCCESS;
+        } else {
+           sc = StatusCode::FAILURE;
+           ATH_MSG_ERROR("preLoading proxies: accessData() failed for " <<
+                         dp->clID() << "/" << dp->name() << ")");
+        }
       }
     }
 
diff --git a/Control/RootUtils/CMakeLists.txt b/Control/RootUtils/CMakeLists.txt
index a3e11e0870e7e12ec5ce7642385d4e3e3bb43edf..fff981ad55c180da7bee92f3c4979b5ea432223a 100644
--- a/Control/RootUtils/CMakeLists.txt
+++ b/Control/RootUtils/CMakeLists.txt
@@ -10,6 +10,7 @@ find_package( ROOT COMPONENTS RIO Hist Tree Core MathCore ROOTTPython
    cppyy${Python_VERSION_MAJOR}_${Python_VERSION_MINOR} )
 
 set( ROOT_LIBRARIES_PYROOT ${ROOT_LIBRARIES} )
+unset( ROOT_FOUND )
 find_package( ROOT COMPONENTS RIO Hist Tree Core MathCore )
 
 # Component(s) in the package:
diff --git a/Control/StoreGate/CMakeLists.txt b/Control/StoreGate/CMakeLists.txt
index 0f774c3a3cb863ae411d09b8b64e77c0c4cd3e1f..20e267b4f50ff97cede3bef8207d4c3db93650e1 100644
--- a/Control/StoreGate/CMakeLists.txt
+++ b/Control/StoreGate/CMakeLists.txt
@@ -22,161 +22,60 @@ atlas_add_library( SGtests test/SGtests.cxx
    NO_PUBLIC_HEADERS
    LINK_LIBRARIES CxxUtils StoreGateLib TestTools )
 
-# Declare the package's tests:o
-atlas_add_test( ActiveStore_test
-   SOURCES test/ActiveStore_test.cxx
-   LINK_LIBRARIES SGtests )
+# Declare the package's tests:
+# Helper function setting up the test(s) in the package:
+function( _add_test name )
+   cmake_parse_arguments( ARG "" "LOG_IGNORE_PATTERN" "" ${ARGN} )
+   if( ARG_LOG_IGNORE_PATTERN )
+      set( extra_arg LOG_IGNORE_PATTERN ${ARG_LOG_IGNORE_PATTERN} )
+   endif()
+   atlas_add_test( ${name}
+      SOURCES test/${name}.cxx
+      INCLUDE_DIRS ${Boost_INCLUDE_DIRS}
+      LINK_LIBRARIES StoreGateLib TestTools
+      ${extra_arg} )
+endfunction( _add_test )
+
+set( _hivePatterns "JobOptionsSvc +INFO|StoreGateSvc.*DEBUG|HiveMgrSvc +DEBUG" )
+
+
+_add_test( ActiveStore_test )
+_add_test( SGTiming_test LOG_IGNORE_PATTERN "${_hivePatterns}|rec:|averages" )
+_add_test( SGHive_test LOG_IGNORE_PATTERN "${_hivePatterns}" )
+_add_test( DataHandle_test )
+_add_test( SGIterator_test )
+_add_test( KeyConcept_test )
+_add_test( StoreClearedIncident_test )
+_add_test( SegMemSvc_test )
+_add_test( exceptions_test )
+_add_test( VarHandleKey_parseKey_test )
+_add_test( VarHandleKey_test )
+_add_test( VarHandleKeyProperty_test )
+_add_test( VarHandleProperty_test )
+_add_test( ReadHandleKey_test )
+_add_test( WriteHandleKey_test )
+_add_test( UpdateHandleKey_test )
+_add_test( TypelessWriteHandleKey_test )
+_add_test( VarHandleBase_test )
+_add_test( VarHandles_test )
+_add_test( WriteHandle_test )
+_add_test( ReadHandle_test )
+_add_test( UpdateHandle_test )
+_add_test( TypelessWriteHandle_test )
+_add_test( DecorKeyHelpers_test )
+_add_test( ReadDecorHandleKey_test )
+_add_test( WriteDecorHandleKey_test )
+_add_test( ReadDecorHandle_test )
+_add_test( WriteDecorHandle_test )
+_add_test( CondHandleKeyArray_test )
+_add_test( WriteCondHandle_test )
+_add_test( WriteDecorHandleKeyArray_test )
+_add_test( ReadDecorHandleKeyArray_test )
+_add_test( ThinningHandleKey_test )
+_add_test( ThinningHandleBase_test )
+_add_test( ThinningHandle_test )
+_add_test( ShallowCopyDecorDeps_test )
 
-   set( _hivePatterns "JobOptionsSvc +INFO|StoreGateSvc.*DEBUG|HiveMgrSvc +DEBUG" )
-
-atlas_add_test( SGTiming_test
-   SOURCES test/SGTiming_test.cxx
-   LINK_LIBRARIES SGtests
-   LOG_IGNORE_PATTERN "${_hivePatterns}|rec:|averages" )
-
-atlas_add_test( SGHive_test
-   SOURCES test/SGHive_test.cxx
-   LINK_LIBRARIES SGtests
-   LOG_IGNORE_PATTERN "${_hivePatterns}" )
-
-atlas_add_test( DataHandle_test
-   SOURCES test/DataHandle_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( SGIterator_test
-   SOURCES test/SGIterator_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( KeyConcept_test
-   SOURCES test/KeyConcept_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( StoreClearedIncident_test
-   SOURCES test/StoreClearedIncident_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( SegMemSvc_test
-   SOURCES test/SegMemSvc_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( exceptions_test
-   SOURCES test/exceptions_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( VarHandleKey_parseKey_test
-   SOURCES test/VarHandleKey_parseKey_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( VarHandleKey_test
-   SOURCES test/VarHandleKey_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( VarHandleKeyProperty_test
-   SOURCES test/VarHandleKeyProperty_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( VarHandleProperty_test
-   SOURCES test/VarHandleProperty_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( ReadHandleKey_test
-   SOURCES test/ReadHandleKey_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( WriteHandleKey_test
-   SOURCES test/WriteHandleKey_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( UpdateHandleKey_test
-   SOURCES test/UpdateHandleKey_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( TypelessWriteHandleKey_test
-   SOURCES test/TypelessWriteHandleKey_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( VarHandleBase_test
-   SOURCES test/VarHandleBase_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( VarHandles_test
-   SOURCES test/VarHandles_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( WriteHandle_test
-   SOURCES test/WriteHandle_test.cxx
-   LINK_LIBRARIES SGtests AthContainers )
-
-atlas_add_test( ReadHandle_test
-   SOURCES test/ReadHandle_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( UpdateHandle_test
-   SOURCES test/UpdateHandle_test.cxx
-   LINK_LIBRARIES SGtests )
-
-atlas_add_test( TypelessWriteHandle_test
-   SOURCES test/TypelessWriteHandle_test.cxx
-   LINK_LIBRARIES SGtests AthContainers )
-
-atlas_add_test( DecorKeyHelpers_test
-   SOURCES test/DecorKeyHelpers_test.cxx
-   LINK_LIBRARIES StoreGateLib )
-
-atlas_add_test( ReadDecorHandleKey_test
-   SOURCES test/ReadDecorHandleKey_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib TestTools )
-
-atlas_add_test( WriteDecorHandleKey_test
-   SOURCES test/WriteDecorHandleKey_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib TestTools )
-
-atlas_add_test( ReadDecorHandle_test
-   SOURCES test/ReadDecorHandle_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib AthContainers TestTools )
-
-atlas_add_test( WriteDecorHandle_test
-   SOURCES test/WriteDecorHandle_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib AthContainers TestTools )
-
-atlas_add_test( CondHandleKeyArray_test
-   SOURCES test/CondHandleKeyArray_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib AthContainers TestTools )
-
-atlas_add_test( WriteCondHandle_test
-   SOURCES test/WriteCondHandle_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib AthContainers TestTools )
- 
-atlas_add_test( WriteDecorHandleKeyArray_test
-   SOURCES test/WriteDecorHandleKeyArray_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib TestTools )
-
-atlas_add_test( ReadDecorHandleKeyArray_test
-   SOURCES test/ReadDecorHandleKeyArray_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib TestTools )
-
-atlas_add_test( ThinningHandleKey_test
-   SOURCES test/ThinningHandleKey_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib AthContainers TestTools )
-
-atlas_add_test( ThinningHandleBase_test
-   SOURCES test/ThinningHandleBase_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib AthContainers TestTools )
-
-atlas_add_test( ThinningHandle_test
-   SOURCES test/ThinningHandle_test.cxx
-   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} 
-   LINK_LIBRARIES StoreGateLib AthContainers TestTools )
 
 # Install files from the package:
 atlas_install_joboptions( share/*.txt
diff --git a/Control/StoreGate/StoreGate/ShallowCopyDecorDeps.h b/Control/StoreGate/StoreGate/ShallowCopyDecorDeps.h
new file mode 100644
index 0000000000000000000000000000000000000000..3c18fc2528ede1b3e279178773cdf5d0d0e4478c
--- /dev/null
+++ b/Control/StoreGate/StoreGate/ShallowCopyDecorDeps.h
@@ -0,0 +1,129 @@
+// This file's extension implies that it's C, but it's really -*- C++ -*-.
+/*
+ * Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration.
+ */
+/**
+ * @file StoreGate/ShallowCopyDecorDeps.h
+ * @author scott snyder <snyder@bnl.gov>
+ * @date Nov, 2020
+ * @brief Helper to propagate decoration dependencies to a shallow copy.
+ */
+
+
+#ifndef STOREGATE_SHALLOWCOPYDECORDEPS_H
+#define STOREGATE_SHALLOWCOPYDECORDEPS_H
+
+
+#include "StoreGate/ReadHandleKeyArray.h"
+#include "StoreGate/WriteHandleKeyArray.h"
+#include "StoreGate/ReadHandle.h"
+#include "StoreGate/ReadHandleKey.h"
+#include "StoreGate/WriteHandle.h"
+#include "StoreGate/WriteHandleKey.h"
+#include "AthenaKernel/errorcheck.h"
+#include "GaudiKernel/ThreadLocalContext.h"
+
+
+namespace SG {
+
+
+/**
+ * @brief Helper to propagate decoration dependencies to a shallow copy.
+ *
+ * When we do a shallow copy of ORIG to COPY, any decorations of ORIG
+ * are readable via COPY.  However, the scheduler doesn't know about this.
+ * The scheduler keeps track of decoration dependencies via aliases
+ * of the form ORIG.DECOR.  If one tries to use a ReadDecorHandle
+ * for COPY.DECOR, the scheduler won't be able to resolve that dependency
+ * because that alias doesn't exist --- only ORIG.DECOR.
+ *
+ * This class will help in propagating the decoration aliases
+ * from the original object to the shallow copy.  The set of decorations
+ * does need to be specified in advance.
+ *
+ * It is assumed that you have a Gaudi component which does the shallow copy,
+ * and that the original and copy are specified by a ReadHandleKey
+ * and a WriteHandleKey, respectively.
+ *
+ * In the definition of the component class, add a ShallowCopyDecorDeps
+ * member as a property.  The value of the property should be the list
+ * of decorations to be copied:
+ *
+ *@code
+ *  SG::ShallowCopyDecorDeps<MyObj> m_decorDeps
+ *  { this, "DecorDeps", {"decor1", "decor2"},
+ *    "List of decorations to propagate through the shallow copy." };
+ @endcode
+ * 
+ * In the @c initialize() method, call @c initialize on the
+ * ShallowCopyDecorDeps object, passing in the read and write
+ * handle keys for the original object and the shallow copy:
+ *
+ *@code
+ *   ATH_CHECK( m_decorDeps.initialize (m_origKey, m_copyKey) );
+ @endcode
+ *
+ * Finally, after the copy has been recorded, call @c linkDecors,
+ * passing the read handle key for the original object:
+ *
+ *@code
+ *  ATH_CHECK( m_decorDeps.linkDecors (m_origKey, ctx) );
+ @endcode
+ */
+template <class T>
+class ShallowCopyDecorDeps
+{
+public:
+  /** 
+   * @brief Auto-declaring Property constructor.
+   * @param owner Owning component.
+   * @param name Name of the Property.
+   * @param l Default list of decorations to propagate.
+   * @param doc Documentation string.
+   */
+  template <class OWNER>
+  ShallowCopyDecorDeps (OWNER* owner,
+                        const std::string& name,
+                        std::initializer_list<std::string> l,
+                        const std::string& doc = "");
+
+
+  /**
+   * @brief Initialize this property.  Call this from initialize().
+   * @param origKey Key for the source of the shallow copy.
+   * @param copyKey Key for the result of the shallow copy.
+   * @param used If false, then this handle is not to be used.
+   *             Instead of normal initialization, the keys will be cleared.
+   */
+  StatusCode initialize (const SG::ReadHandleKey<T>& origKey,
+                         const SG::WriteHandleKey<T>& copyKey,
+                         bool used = true);
+
+
+  /**
+   * @brief Create alias for the decorations, linked to the shallow copy.
+   * @param origKey Key for the source of the shallow copy.
+   * @param ctx The current EventContext.
+   *
+   * Call this after the shallow copy has been recorded in SG.
+   */
+  StatusCode linkDecors (const SG::ReadHandleKey<T>& origKey,
+                         const EventContext& ctx = Gaudi::Hive::currentContext()) const;
+
+
+private:
+  /// Keys for the decorations on the original object.
+  SG::ReadHandleKeyArray<T> m_readKeys;
+
+  /// Keys for decorations to alias for the shallow copy.
+  SG::WriteHandleKeyArray<T> m_writeKeys;
+};
+
+
+} // namespace SG
+
+
+#include "StoreGate/ShallowCopyDecorDeps.icc"
+
+
+#endif // not STOREGATE_SHALLOWCOPYDECORDEPS_H
diff --git a/Control/StoreGate/StoreGate/ShallowCopyDecorDeps.icc b/Control/StoreGate/StoreGate/ShallowCopyDecorDeps.icc
new file mode 100644
index 0000000000000000000000000000000000000000..8944a4347caef330d6691c4751dafd72e114e387
--- /dev/null
+++ b/Control/StoreGate/StoreGate/ShallowCopyDecorDeps.icc
@@ -0,0 +1,83 @@
+/*
+ * Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration.
+ */
+/**
+ * @file StoreGate/ShallowCopyDecorDeps.icc
+ * @author scott snyder <snyder@bnl.gov>
+ * @date Nov, 2020
+ * @brief Helper to propagate decoration dependencies to a shallow copy.
+ */
+
+
+namespace SG {
+
+
+/** 
+ * @brief Auto-declaring Property constructor.
+ * @param owner Owning component.
+ * @param name Name of the Property.
+ * @param l Default list of decorations to propagate.
+ * @param doc Documentation string.
+ */
+template <class T>
+template <class OWNER>
+ShallowCopyDecorDeps<T>::ShallowCopyDecorDeps (OWNER* owner,
+                                               const std::string& name,
+                                               std::initializer_list<std::string> l,
+                                               const std::string& doc /*= ""*/)
+  : m_readKeys (owner, name + "ReadKeys", {}, "[Internal property]"),
+    m_writeKeys (owner, name, l, doc)
+{
+}
+
+
+/**
+ * @brief Initialize this property.  Call this from initialize().
+ * @param origKey Key for the source of the shallow copy.
+ * @param copyKey Key for the result of the shallow copy.
+ * @param used If false, then this handle is not to be used.
+ *             Instead of normal initialization, the keys will be cleared.
+ */
+template <class T>
+StatusCode
+ShallowCopyDecorDeps<T>::initialize (const SG::ReadHandleKey<T>& origKey,
+                                     const SG::WriteHandleKey<T>& copyKey,
+                                     bool used /*= true*/)
+{
+  m_readKeys.clear();
+  if (used) {
+    for (SG::WriteHandleKey<T>& k : m_writeKeys) {
+      m_readKeys.emplace_back (origKey.key() + "." + k.key());
+      k = copyKey.key() + "." + k.key();
+    }
+    CHECK( m_readKeys.initialize() );
+    CHECK( m_writeKeys.initialize() );
+  }
+  else {
+    m_writeKeys.clear();
+  }
+  return StatusCode::SUCCESS;
+}
+
+
+/**
+ * @brief Create alias for the decorations, linked to the shallow copy.
+ * @param origKey Key for the source of the shallow copy.
+ * @param ctx The current EventContext.
+ *
+ * Call this after the shallow copy has been recorded in SG.
+ */
+template <class T>
+StatusCode
+ShallowCopyDecorDeps<T>::linkDecors (const SG::ReadHandleKey<T>& origKey,
+                                     const EventContext& ctx /*= Gaudi::Hive::currentContext()*/) const
+{
+  SG::ReadHandle<T> orig (origKey, ctx);
+  for (const SG::WriteHandleKey<T>& k : m_writeKeys) {
+    CHECK( orig.alias (k) );
+  }
+  return StatusCode::SUCCESS;
+}
+
+
+} // namespace SG
diff --git a/Control/StoreGate/share/ShallowCopyDecorDeps_test.ref b/Control/StoreGate/share/ShallowCopyDecorDeps_test.ref
new file mode 100644
index 0000000000000000000000000000000000000000..0c5e0952444d59bdea5ae672068422e9c0c71d7e
--- /dev/null
+++ b/Control/StoreGate/share/ShallowCopyDecorDeps_test.ref
@@ -0,0 +1,12 @@
+StoreGate/ShallowCopyDecorDeps_test
+ApplicationMgr    SUCCESS 
+====================================================================================================================================
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v27r1p99)
+                                          running on karma on Wed Nov 25 15:44:43 2020
+====================================================================================================================================
+ApplicationMgr       INFO Application Manager Configured successfully
+EventLoopMgr      WARNING Unable to locate service "EventSelector" 
+EventLoopMgr      WARNING No events will be processed from external input.
+ApplicationMgr       INFO Application Manager Initialized successfully
+ApplicationMgr Ready
+test1
diff --git a/Control/StoreGate/test/ShallowCopyDecorDeps_test.cxx b/Control/StoreGate/test/ShallowCopyDecorDeps_test.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..20d0a9181a28dffb3c676c08ecedcc2810c48e89
--- /dev/null
+++ b/Control/StoreGate/test/ShallowCopyDecorDeps_test.cxx
@@ -0,0 +1,87 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+/**
+ * @file StoreGate/test/ShallowCopyDecorDeps_test.cxx
+ * @author scott snyder <snyder@bnl.gov>
+ * @date Nov, 2020
+ * @brief Tests for ShallowCopyDecorDeps.
+ */
+
+
+#undef NDEBUG
+#include "StoreGate/ShallowCopyDecorDeps.h"
+#include "StoreGate/StoreGateSvc.h"
+#include "SGTools/TestStore.h"
+#include "AthenaKernel/ExtendedEventContext.h"
+#include "AthenaKernel/CLASS_DEF.h"
+#include "TestTools/initGaudi.h"
+#include "TestOwner.h"
+#include <cassert>
+#include <iostream>
+
+
+class MyObj {};
+CLASS_DEF (MyObj, 293847295, 1)
+
+
+void test1 (ISvcLocator* svcloc)
+{
+  std::cout << "test1\n";
+
+  TestOwner owner;
+  SG::ShallowCopyDecorDeps<MyObj> scdd (&owner, "SCDD", {"d1", "d2"}, "doc string");
+  SG::ReadHandleKey<MyObj> origKey (&owner, "ReadKey", "myObj");
+  SG::WriteHandleKey<MyObj> copyKey (&owner, "WriteKey", "scopy_myObj");
+
+  assert( origKey.initialize().isSuccess() );
+  assert( copyKey.initialize().isSuccess() );
+  assert( scdd.initialize (origKey, copyKey) );
+
+  assert (owner.getProperty ("SCDD").name() == "SCDD");
+  assert (owner.getProperty ("SCDD").documentation() == "doc string");
+  assert (owner.getProperty ("SCDD").type_info() == &typeid(SG::VarHandleKeyArray));
+  assert (owner.getProperty ("SCDD").toString() == "['StoreGateSvc+scopy_myObj.d1','StoreGateSvc+scopy_myObj.d2']");
+  assert (owner.getProperty ("SCDD").ownerTypeName() == "TestOwner");
+
+  assert (owner.getProperty ("SCDDReadKeys").name() == "SCDDReadKeys");
+  assert (owner.getProperty ("SCDDReadKeys").documentation() == "[Internal property]");
+  assert (owner.getProperty ("SCDDReadKeys").type_info() == &typeid(SG::VarHandleKeyArray));
+  assert (owner.getProperty ("SCDDReadKeys").toString() == "['StoreGateSvc+myObj.d1','StoreGateSvc+myObj.d2']");
+  assert (owner.getProperty ("SCDDReadKeys").ownerTypeName() == "TestOwner");
+
+  StoreGateSvc* sg = nullptr;
+  assert (svcloc->service ("StoreGateSvc", sg).isSuccess());
+  assert (sg->record (std::make_unique<MyObj>(), "myObj", false).isSuccess());
+
+  EventContext ctx;
+  ctx.setExtension( Atlas::ExtendedEventContext(sg) );
+
+  assert( scdd.linkDecors (origKey, ctx).isSuccess() );
+
+  const MyObj* myObj = nullptr;
+  assert (sg->retrieve (myObj, "myObj").isSuccess());
+  assert (myObj != nullptr);
+
+  const MyObj* myObj2 = nullptr;
+  assert (sg->retrieve (myObj2, "scopy_myObj.d1").isSuccess());
+  assert (myObj == myObj2);
+
+  myObj2 = nullptr;
+  assert (sg->retrieve (myObj2, "scopy_myObj.d2").isSuccess());
+  assert (myObj == myObj2);
+}
+
+
+int main()
+{
+  std::cout << "StoreGate/ShallowCopyDecorDeps_test\n";
+
+  ISvcLocator* svcloc = nullptr;
+  if (!Athena_test::initGaudi("StoreGate/VarHandleBase_test.txt", svcloc)) {
+    return 1;
+  }
+
+  test1 (svcloc);
+  return 0;
+}
diff --git a/Control/StoreGate/test/TestOwner.h b/Control/StoreGate/test/TestOwner.h
index e289c93db20b7a0b65f775f702b0f5d8551bc18e..cab216579942ca9a82745847e5ee10c14bd2a621 100644
--- a/Control/StoreGate/test/TestOwner.h
+++ b/Control/StoreGate/test/TestOwner.h
@@ -1,6 +1,6 @@
 // This file's extension implies that it's C, but it's really -*- C++ -*-.
 /*
-   Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+   Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
  */
 /**
  * @file StoreGate/test/TestOwner.h
@@ -18,6 +18,7 @@
 
 
 #include "StoreGate/VarHandleKeyProperty.h"
+#include "StoreGate/VarHandleKeyArrayProperty.h"
 #include "GaudiKernel/PropertyHolder.h"
 #include "GaudiKernel/IProperty.h"
 
diff --git a/DataQuality/DataQualityConfigurations/CMakeLists.txt b/DataQuality/DataQualityConfigurations/CMakeLists.txt
index 2a673e40cd41459f98139f3b90708c5bcc07318d..ae0c85f1cc740f3d41f8e3e917b4f87a0a911bd6 100644
--- a/DataQuality/DataQualityConfigurations/CMakeLists.txt
+++ b/DataQuality/DataQualityConfigurations/CMakeLists.txt
@@ -4,7 +4,7 @@
 atlas_subdir( DataQualityConfigurations )
 
 # Install files from the package:
-atlas_install_python_modules( python/*.py )
+atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 atlas_install_scripts( scripts/MergeConfigs.py scripts/UploadDQAMITag.py
    scripts/merge_all_han_configs.sh scripts/merge_some_han_configs.sh
    scripts/han-config-indent.sh scripts/han-config-check.sh
diff --git a/DataQuality/DataQualityConfigurations/config/Pixel/collisions_run.config b/DataQuality/DataQualityConfigurations/config/Pixel/collisions_run.config
index 6b48ce1db823ca01c0fe18ea242d6059679dd1c0..48af7b739110b372ef79ca22f4a808e7f7303399 100644
--- a/DataQuality/DataQualityConfigurations/config/Pixel/collisions_run.config
+++ b/DataQuality/DataQualityConfigurations/config/Pixel/collisions_run.config
@@ -1170,12 +1170,321 @@ dir Pixel {
 
   dir Errors {
 
+    hist OpticalErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SyncErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SyncErrorsMod_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist SyncErrorsMod_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsMod_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsMod_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsMod_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsMod_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SyncErrorsROD_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist TimeoutErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist FEMCCErrorwords_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SEUErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+   
+    hist TruncErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist TruncErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist TruncErrorsMod_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist TruncErrorsMod_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist TruncErrorMod_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsMod_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsMod_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsMod_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist TruncErrorsROD_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsROD_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorROD_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsROD_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsROD_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsROD_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
     hist SyncErrorsFracPerEvent_IBL {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-
     hist SyncErrorsFracPerEvent_B0 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
@@ -1202,102 +1511,133 @@ dir Pixel {
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
 
-    hist SyncErrorsRODFracPerEvent_IBL {
+    hist SyncErrorsModFracPerEvent_IBL {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_B0 {
+    hist SyncErrorsModFracPerEvent_B0 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_B1 {
+    hist SyncErrorsModFracPerEvent_B1 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_B2 {
+    hist SyncErrorsModFracPerEvent_B2 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_ECA {
+    hist SyncErrorsModFracPerEvent_ECA {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_ECC {
+    hist SyncErrorsModFracPerEvent_ECC {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
-    }
+    } 
 
-    hist ErrorStatePerLumi_IBL {
+    hist SyncErrorsRODFracPerEvent_IBL {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_B0 {
+    hist SyncErrorsRODFracPerEvent_B0 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_B1 {
+    hist SyncErrorsRODFracPerEvent_B1 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_B2 {
+    hist SyncErrorsRODFracPerEvent_B2 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_ECA {
+    hist SyncErrorsRODFracPerEvent_ECA {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_ECC {
+    hist SyncErrorsRODFracPerEvent_ECC {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
 
+    #hist ErrorStatePerLumi_IBL {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_B0 {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_B1 {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_B2 {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_ECA {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_ECC {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+
     hist SEUErrorsFracPerEvent_IBL {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_B0 {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_B1 {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_B2 {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_ECA {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_ECC {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
 
@@ -1376,41 +1716,99 @@ dir Pixel {
     }
 
     hist TruncationErrorsFracPerEvent_IBL {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_B0 {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_B1 {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_B2 {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_ECA {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_ECC {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+
+    hist TruncErrorsModFracPerEvent_IBL {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_B0 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_B1 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_B2 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_ECA {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_ECC {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    } 
+   
+    hist TruncErrorsRODFracPerEvent_IBL {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_B0 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_B1 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_B2 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_ECA {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_ECC {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
+ 
+  
 
     ######################################
     hist SyncErrorsFracPerEvent_IBL {
@@ -1484,347 +1882,2645 @@ dir Pixel {
 
   dir ErrorsExpert {
 
-    #hist FE_Warning_per_lumi_PIX {
-    #  algorithm = Plain_GatherData
-    #  output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
-    #}
-    hist FEWarningPerLumi_ECA {
+    hist ServiceRecordUnweighted_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist FEWarningPerLumi_ECC {
+    hist ServiceRecordUnweighted_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist FEWarningPerLumi_B0 {
+    hist ServiceRecordUnweighted_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist FEWarningPerLumi_B1 {
+    hist ServiceRecordUnweighted_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist FEWarningPerLumi_B2 {
+    hist ServiceRecordUnweighted_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModSyncBCID1ErrorsPerLumi_ECA {
+    hist ServiceRecordUnweighted_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID1ErrorsPerLumi_ECC {
+
+    hist ServiceRecordWeighted_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID1ErrorsPerLumi_B0 {
+    hist ServiceRecordWeighted_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID1ErrorsPerLumi_B1 {
+    hist ServiceRecordWeighted_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID1ErrorsPerLumi_B2 {
+    hist ServiceRecordWeighted_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModSyncBCID2ErrorsPerLumi_B0 {
+    hist ServiceRecordWeighted_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID2ErrorsPerLumi_B1 {
+    hist ServiceRecordWeighted_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID2ErrorsPerLumi_B2 {
+
+    hist FEWarningMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID2ErrorsPerLumi_ECA {
+    hist FEWarningMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID2ErrorsPerLumi_ECC {
+    hist FEWarningMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModSyncLVL1IDErrorsPerLumi_B0 {
+    hist FEWarningMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncLVL1IDErrorsPerLumi_B1 {
+    hist FEWarningMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncLVL1IDErrorsPerLumi_B2 {
+    hist FEWarningMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncLVL1IDErrorsPerLumi_ECA {
+
+    hist ModSyncBCID1ErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncLVL1IDErrorsPerLumi_ECC {
+    hist ModSyncBCID1ErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModTruncEOCErrorsPerLumi_ECA {
+    hist ModSyncBCID1ErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEOCErrorsPerLumi_ECC {
+    hist ModSyncBCID1ErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEOCErrorsPerLumi_B0 {
+    hist ModSyncBCID1ErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEOCErrorsPerLumi_B1 {
+    hist ModSyncBCID1ErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEOCErrorsPerLumi_B2 {
+
+    hist ModSyncBCID2ErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModTruncEoEOverflowErrorsPerLumi_B0 {
+    hist ModSyncBCID2ErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEoEOverflowErrorsPerLumi_B1 {
+    hist ModSyncBCID2ErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEoEOverflowErrorsPerLumi_B2 {
+    hist ModSyncBCID2ErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEoEOverflowErrorsPerLumi_ECA {
+    hist ModSyncBCID2ErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEoEOverflowErrorsPerLumi_ECC {
+    hist ModSyncBCID2ErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
-    hist ModTruncHitOverflowErrorsPerLumi_B0 {
+    hist ModSyncLVL1IDErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncHitOverflowErrorsPerLumi_B1 {
+    hist ModSyncLVL1IDErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist ModSyncLVL1IDErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncHitOverflowErrorsPerLumi_B2 {
+    hist ModSyncLVL1IDErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncHitOverflowErrorsPerLumi_ECA {
+    hist ModSyncLVL1IDErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncHitOverflowErrorsPerLumi_ECC {
+    hist ModSyncLVL1IDErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
-    hist OpticalErrorsPerLumi_B0 {
+    hist ModTruncEOCErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist OpticalErrorsPerLumi_B1 {
+    hist ModTruncEOCErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
-    }
-    hist OpticalErrorsPerLumi_B2 {
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist ModTruncEOCErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist ModTruncEOCErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist OpticalErrorsPerLumi_ECA {
+    hist ModTruncEOCErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist OpticalErrorsPerLumi_ECC {
+    hist ModTruncEOCErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
-    hist RODSyncBCIDErrorsPerLumi_B0 {
+   hist ModTruncEoEOverflowErrorsMap_IBL { 
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncBCIDErrorsPerLumi_B1 {
+    hist ModTruncEoEOverflowErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncBCIDErrorsPerLumi_B2 {
+    hist ModTruncEoEOverflowErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncBCIDErrorsPerLumi_ECA {
+    hist ModTruncEoEOverflowErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncBCIDErrorsPerLumi_ECC {
+    hist ModTruncEoEOverflowErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
+    hist ModTruncEoEOverflowErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
 
-    hist RODSyncLVL1IDErrorsPerLumi_B0 {
+    hist ModTruncHitOverflowErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncLVL1IDErrorsPerLumi_B1 {
+    hist ModTruncHitOverflowErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncLVL1IDErrorsPerLumi_B2 {
+    hist ModTruncHitOverflowErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncLVL1IDErrorsPerLumi_ECA {
+    hist ModTruncHitOverflowErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncLVL1IDErrorsPerLumi_ECC {
+    hist ModTruncHitOverflowErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist RODTimeoutPerLumi_B0 {
+    hist ModTruncHitOverflowErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
-    }
-    hist RODTimeoutPerLumi_B1 {
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }    
+
+    hist OpticalErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTimeoutPerLumi_B2 {
+    hist OpticalErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTimeoutPerLumi_ECA {
+    hist OpticalErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTimeoutPerLumi_ECC {
+    hist OpticalErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist RODTruncHTLimitErrorsPerLumi_B0 {
+    hist OpticalErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncHTLimitErrorsPerLumi_B1 {
+    hist OpticalErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncHTLimitErrorsPerLumi_B2 {
+ 
+    hist RODBCIDErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncHTLimitErrorsPerLumi_ECA {
+    hist RODBCIDErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncHTLimitErrorsPerLumi_ECC {
+    hist RODBCIDErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist RODTruncRODOFErrorsPerLumi_B0 {
+    hist RODBCIDErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncRODOFErrorsPerLumi_B1 {
+    hist RODBCIDErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncRODOFErrorsPerLumi_B2 {
+    hist RODBCIDErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncRODOFErrorsPerLumi_ECA {
+
+    hist RODLVL1IDErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncRODOFErrorsPerLumi_ECC {
+    hist RODLVL1IDErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-
-    hist SEUHammingPerLumi_ECA {
+    hist RODLVL1IDErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHammingPerLumi_ECC {
+    hist RODLVL1IDErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHammingPerLumi_B0 {
+    hist RODLVL1IDErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHammingPerLumi_B1 {
+    hist RODLVL1IDErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHammingPerLumi_B2 {
+
+    hist RODLimitErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist SEUHitParityPerLumi_ECA {
+    hist RODLimitErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHitParityPerLumi_ECC {
+    hist RODLimitErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHitParityPerLumi_B0 {
+    hist RODLimitErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHitParityPerLumi_B1 {
+    hist RODLimitErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHitParityPerLumi_B2 {
+    hist RODLimitErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
-    hist SEURegisterParityPerLumi_ECA {
+    hist RODPreambleErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEURegisterParityPerLumi_ECC {
+    hist RODPreambleErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    
+    hist RODRowColumnErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    
+    hist RODSyncBCIDErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+
+    hist RODSyncLVL1IDErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTimeoutMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTimeoutErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTrailerBitErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    
+    hist RODTrailerErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
+    hist RODTruncHTLimitErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTruncRODOFErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SEUHammingMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+   
+    hist SEUHitParityMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+  
+    hist SEURegisterParityMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR0BCIDCounterErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR1HammingCode0ErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+
+    hist SR2HammingCode1ErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR3HammingCode2ErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR4L1InCounterErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR5L1RequestCounterErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR6L1RegisterErrorsMap_IBL { 
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR7L1TriggerIDErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR8FEReadoutProcessErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR15SkipppedTrigCountErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
+    hist SR16TruncatedEventFlagErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR24TripleRedundantErrorsCNFGMEMMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR25WriteRegDataErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR26AddressErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR27OtherCMDDecoderErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR28CMDDecoderBitflipErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR29TripleRedundantErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR30DataBusAddressErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR31TripleRedundantErrorsEFUSEMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+  
+    #hist FE_Warning_per_lumi_PIX {
+    #  algorithm = Plain_GatherData
+    #  output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+    #}
+    hist FEWarningPerLumi_ECA {
+      algorithm = Plain_GatherData
+      #output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+  
+
+    hist ModSyncBCID1ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist ModSyncBCID2ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist ModSyncLVL1IDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+ 
+    hist ModTruncEOCErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist ModTruncEoEOverflowErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist ModTruncHitOverflowErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist OpticalErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODSyncBCIDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODSyncLVL1IDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODTimeoutPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+ 
+    hist RODTimeoutErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+ 
+    hist RODTruncHTLimitErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODTruncRODOFErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+  
+    hist SEUHammingPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist SEUHitParityPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist SEURegisterParityPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODBCIDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODLVL1IDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODLVL1IDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    } 
+    hist RODLVL1IDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    } 
+    hist RODLVL1IDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODLVL1IDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    } 
+    hist RODLVL1IDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODLimitErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+   
+    hist RODMaskedLinkPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODMaskedLinkPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    } 
+    hist RODMaskedLinkPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    } 
+    hist RODMaskedLinkPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODMaskedLinkPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    } 
+    hist RODMaskedLinkPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+   
+    hist RODPreambleErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODRowColumnErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTrailerBitErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
+    hist RODTrailerErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist RODTrailerErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR0BCIDCounterErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR1HammingCode0ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR2HammingCode1ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR3HammingCode2ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode1ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR4L1InCounterErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR5L1RequestCounterErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+     
+    hist SR6L1RegisterErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR7L1TriggerIDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR8FEReadoutProcessErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEURegisterParityPerLumi_B0 {
+    hist SR8FEReadoutProcessErrorsPerLumi_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEURegisterParityPerLumi_B1 {
+    hist SR8FEReadoutProcessErrorsPerLumi_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEURegisterParityPerLumi_B2 {
+
+    hist SR15SkipppedTrigCountErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR16TruncatedEventFlagErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR25WriteRegDataErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR26AddressErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR27OtherCMDDecoderErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR28CMDDecoderBitflipErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
+    hist SR29TripleRedundantErrorsCMDPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR30DataBusAddressErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
   }
 
 
@@ -1832,7 +4528,7 @@ dir Pixel {
   #Below plot Combined Tracks
   dir TrackOnTrack {
 
-    hist tracksPerEvtPerLumi {
+    hist TracksPerEvtPerLumi {
       algorithm = Pix_LB_Bins_Diff_FromAvg
       output = InnerDetector/Pixel/PixelExpert/Tracks
       display = StatBox
diff --git a/DataQuality/DataQualityConfigurations/config/Pixel/cosmics_run.config b/DataQuality/DataQualityConfigurations/config/Pixel/cosmics_run.config
index 6b48ce1db823ca01c0fe18ea242d6059679dd1c0..48af7b739110b372ef79ca22f4a808e7f7303399 100644
--- a/DataQuality/DataQualityConfigurations/config/Pixel/cosmics_run.config
+++ b/DataQuality/DataQualityConfigurations/config/Pixel/cosmics_run.config
@@ -1170,12 +1170,321 @@ dir Pixel {
 
   dir Errors {
 
+    hist OpticalErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist OpticalErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SyncErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SyncErrorsMod_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist SyncErrorsMod_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsMod_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsMod_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsMod_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsMod_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SyncErrorsROD_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SyncErrorsROD_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist TimeoutErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TimeoutErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist FEMCCErrorwords_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist FEMCCErrorwords_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SEUErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+   
+    hist TruncErrors_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist TruncErrors_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrors_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrors_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrors_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrors_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist TruncErrorsMod_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist TruncErrorsMod_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist TruncErrorMod_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsMod_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsMod_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsMod_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist TruncErrorsROD_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsROD_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorROD_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsROD_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsROD_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist TruncErrorsROD_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
     hist SyncErrorsFracPerEvent_IBL {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-
     hist SyncErrorsFracPerEvent_B0 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
@@ -1202,102 +1511,133 @@ dir Pixel {
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
 
-    hist SyncErrorsRODFracPerEvent_IBL {
+    hist SyncErrorsModFracPerEvent_IBL {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_B0 {
+    hist SyncErrorsModFracPerEvent_B0 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_B1 {
+    hist SyncErrorsModFracPerEvent_B1 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_B2 {
+    hist SyncErrorsModFracPerEvent_B2 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_ECA {
+    hist SyncErrorsModFracPerEvent_ECA {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist SyncErrorsRODFracPerEvent_ECC {
+    hist SyncErrorsModFracPerEvent_ECC {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
-    }
+    } 
 
-    hist ErrorStatePerLumi_IBL {
+    hist SyncErrorsRODFracPerEvent_IBL {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_B0 {
+    hist SyncErrorsRODFracPerEvent_B0 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_B1 {
+    hist SyncErrorsRODFracPerEvent_B1 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_B2 {
+    hist SyncErrorsRODFracPerEvent_B2 {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_ECA {
+    hist SyncErrorsRODFracPerEvent_ECA {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
-    hist ErrorStatePerLumi_ECC {
+    hist SyncErrorsRODFracPerEvent_ECC {
       algorithm = Pix_NonZero_Errors
       output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
 
+    #hist ErrorStatePerLumi_IBL {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_B0 {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_B1 {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_B2 {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_ECA {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+    #hist ErrorStatePerLumi_ECC {
+    #  algorithm = Pix_NonZero_Errors
+    #  output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
+    #  description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    #}
+
     hist SEUErrorsFracPerEvent_IBL {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_B0 {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_B1 {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_B2 {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_ECA {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist SEUErrorsFracPerEvent_ECC {
       #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
 
@@ -1376,41 +1716,99 @@ dir Pixel {
     }
 
     hist TruncationErrorsFracPerEvent_IBL {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXIBL/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_B0 {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX0/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_B1 {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX1/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_B2 {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIX2/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_ECA {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXECA/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
     hist TruncationErrorsFracPerEvent_ECC {
-      #algorithm = Pix_NonZero_Errors
       algorithm = Pix_Frac_Errors
-      output = InnerDetector/Pixel/PIXECC/DisableAndErrorsLB
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+
+    hist TruncErrorsModFracPerEvent_IBL {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_B0 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_B1 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_B2 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_ECA {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsModFracPerEvent_ECC {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    } 
+   
+    hist TruncErrorsRODFracPerEvent_IBL {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_B0 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_B1 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_B2 {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_ECA {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
+    }
+    hist TruncErrorsRODFracPerEvent_ECC {
+      algorithm = Pix_Frac_Errors
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
       description = https://twiki.cern.ch/twiki/bin/viewauth/Atlas/PixelOfflineShiftInstructionsDQRun2#Errors
     }
+ 
+  
 
     ######################################
     hist SyncErrorsFracPerEvent_IBL {
@@ -1484,347 +1882,2645 @@ dir Pixel {
 
   dir ErrorsExpert {
 
-    #hist FE_Warning_per_lumi_PIX {
-    #  algorithm = Plain_GatherData
-    #  output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
-    #}
-    hist FEWarningPerLumi_ECA {
+    hist ServiceRecordUnweighted_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist FEWarningPerLumi_ECC {
+    hist ServiceRecordUnweighted_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist FEWarningPerLumi_B0 {
+    hist ServiceRecordUnweighted_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist FEWarningPerLumi_B1 {
+    hist ServiceRecordUnweighted_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist FEWarningPerLumi_B2 {
+    hist ServiceRecordUnweighted_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModSyncBCID1ErrorsPerLumi_ECA {
+    hist ServiceRecordUnweighted_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID1ErrorsPerLumi_ECC {
+
+    hist ServiceRecordWeighted_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID1ErrorsPerLumi_B0 {
+    hist ServiceRecordWeighted_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID1ErrorsPerLumi_B1 {
+    hist ServiceRecordWeighted_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID1ErrorsPerLumi_B2 {
+    hist ServiceRecordWeighted_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID1
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModSyncBCID2ErrorsPerLumi_B0 {
+    hist ServiceRecordWeighted_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID2ErrorsPerLumi_B1 {
+    hist ServiceRecordWeighted_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID2ErrorsPerLumi_B2 {
+
+    hist FEWarningMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID2ErrorsPerLumi_ECA {
+    hist FEWarningMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncBCID2ErrorsPerLumi_ECC {
+    hist FEWarningMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_BCID2
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModSyncLVL1IDErrorsPerLumi_B0 {
+    hist FEWarningMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncLVL1IDErrorsPerLumi_B1 {
+    hist FEWarningMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncLVL1IDErrorsPerLumi_B2 {
+    hist FEWarningMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncLVL1IDErrorsPerLumi_ECA {
+
+    hist ModSyncBCID1ErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModSyncLVL1IDErrorsPerLumi_ECC {
+    hist ModSyncBCID1ErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_Module_LVL1ID
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModTruncEOCErrorsPerLumi_ECA {
+    hist ModSyncBCID1ErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEOCErrorsPerLumi_ECC {
+    hist ModSyncBCID1ErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEOCErrorsPerLumi_B0 {
+    hist ModSyncBCID1ErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEOCErrorsPerLumi_B1 {
+    hist ModSyncBCID1ErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEOCErrorsPerLumi_B2 {
+
+    hist ModSyncBCID2ErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoC
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist ModTruncEoEOverflowErrorsPerLumi_B0 {
+    hist ModSyncBCID2ErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEoEOverflowErrorsPerLumi_B1 {
+    hist ModSyncBCID2ErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEoEOverflowErrorsPerLumi_B2 {
+    hist ModSyncBCID2ErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEoEOverflowErrorsPerLumi_ECA {
+    hist ModSyncBCID2ErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncEoEOverflowErrorsPerLumi_ECC {
+    hist ModSyncBCID2ErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_EoE_Overflow
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
-    hist ModTruncHitOverflowErrorsPerLumi_B0 {
+    hist ModSyncLVL1IDErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncHitOverflowErrorsPerLumi_B1 {
+    hist ModSyncLVL1IDErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist ModSyncLVL1IDErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncHitOverflowErrorsPerLumi_B2 {
+    hist ModSyncLVL1IDErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncHitOverflowErrorsPerLumi_ECA {
+    hist ModSyncLVL1IDErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist ModTruncHitOverflowErrorsPerLumi_ECC {
+    hist ModSyncLVL1IDErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_Module_Hit_Overflow
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
-    hist OpticalErrorsPerLumi_B0 {
+    hist ModTruncEOCErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist OpticalErrorsPerLumi_B1 {
+    hist ModTruncEOCErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
-    }
-    hist OpticalErrorsPerLumi_B2 {
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist ModTruncEOCErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist ModTruncEOCErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist OpticalErrorsPerLumi_ECA {
+    hist ModTruncEOCErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist OpticalErrorsPerLumi_ECC {
+    hist ModTruncEOCErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Optical_Errors
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
-    hist RODSyncBCIDErrorsPerLumi_B0 {
+   hist ModTruncEoEOverflowErrorsMap_IBL { 
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncBCIDErrorsPerLumi_B1 {
+    hist ModTruncEoEOverflowErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncBCIDErrorsPerLumi_B2 {
+    hist ModTruncEoEOverflowErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncBCIDErrorsPerLumi_ECA {
+    hist ModTruncEoEOverflowErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncBCIDErrorsPerLumi_ECC {
+    hist ModTruncEoEOverflowErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_BCID
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
+    hist ModTruncEoEOverflowErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
 
-    hist RODSyncLVL1IDErrorsPerLumi_B0 {
+    hist ModTruncHitOverflowErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncLVL1IDErrorsPerLumi_B1 {
+    hist ModTruncHitOverflowErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncLVL1IDErrorsPerLumi_B2 {
+    hist ModTruncHitOverflowErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncLVL1IDErrorsPerLumi_ECA {
+    hist ModTruncHitOverflowErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODSyncLVL1IDErrorsPerLumi_ECC {
+    hist ModTruncHitOverflowErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Synchronization_ROD_LVL1ID
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist RODTimeoutPerLumi_B0 {
+    hist ModTruncHitOverflowErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
-    }
-    hist RODTimeoutPerLumi_B1 {
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }    
+
+    hist OpticalErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTimeoutPerLumi_B2 {
+    hist OpticalErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTimeoutPerLumi_ECA {
+    hist OpticalErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTimeoutPerLumi_ECC {
+    hist OpticalErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/ROD_Timeout
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist RODTruncHTLimitErrorsPerLumi_B0 {
+    hist OpticalErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncHTLimitErrorsPerLumi_B1 {
+    hist OpticalErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncHTLimitErrorsPerLumi_B2 {
+ 
+    hist RODBCIDErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncHTLimitErrorsPerLumi_ECA {
+    hist RODBCIDErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncHTLimitErrorsPerLumi_ECC {
+    hist RODBCIDErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_HT_Limit
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist RODTruncRODOFErrorsPerLumi_B0 {
+    hist RODBCIDErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncRODOFErrorsPerLumi_B1 {
+    hist RODBCIDErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncRODOFErrorsPerLumi_B2 {
+    hist RODBCIDErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncRODOFErrorsPerLumi_ECA {
+
+    hist RODLVL1IDErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist RODTruncRODOFErrorsPerLumi_ECC {
+    hist RODLVL1IDErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/Truncation_ROD_FIFO_Overflow
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-
-    hist SEUHammingPerLumi_ECA {
+    hist RODLVL1IDErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHammingPerLumi_ECC {
+    hist RODLVL1IDErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHammingPerLumi_B0 {
+    hist RODLVL1IDErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHammingPerLumi_B1 {
+    hist RODLVL1IDErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHammingPerLumi_B2 {
+
+    hist RODLimitErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hamming
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-
-    hist SEUHitParityPerLumi_ECA {
+    hist RODLimitErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHitParityPerLumi_ECC {
+    hist RODLimitErrorsMap_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHitParityPerLumi_B0 {
+    hist RODLimitErrorsMap_B2 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHitParityPerLumi_B1 {
+    hist RODLimitErrorsMap_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEUHitParityPerLumi_B2 {
+    hist RODLimitErrorsMap_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Hit_Parity
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
-    hist SEURegisterParityPerLumi_ECA {
+    hist RODPreambleErrorsMap_IBL {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEURegisterParityPerLumi_ECC {
+    hist RODPreambleErrorsMap_B0 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    
+    hist RODRowColumnErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    
+    hist RODSyncBCIDErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncBCIDErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+
+    hist RODSyncLVL1IDErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODSyncLVL1IDErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTimeoutMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTimeoutErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTimeoutErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTrailerBitErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    
+    hist RODTrailerErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
+    hist RODTruncHTLimitErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncHTLimitErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTruncRODOFErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTruncRODOFErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SEUHammingMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHammingMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+   
+    hist SEUHitParityMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEUHitParityMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+  
+    hist SEURegisterParityMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SEURegisterParityMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR0BCIDCounterErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR1HammingCode0ErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+
+    hist SR2HammingCode1ErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR3HammingCode2ErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR4L1InCounterErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR5L1RequestCounterErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR6L1RegisterErrorsMap_IBL { 
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR7L1TriggerIDErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR8FEReadoutProcessErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR15SkipppedTrigCountErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
+    hist SR16TruncatedEventFlagErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR24TripleRedundantErrorsCNFGMEMMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR25WriteRegDataErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR26AddressErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR27OtherCMDDecoderErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR28CMDDecoderBitflipErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR29TripleRedundantErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR30DataBusAddressErrorsMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR31TripleRedundantErrorsEFUSEMap_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEMap_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrors
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+  
+    #hist FE_Warning_per_lumi_PIX {
+    #  algorithm = Plain_GatherData
+    #  output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+    #}
+    hist FEWarningPerLumi_ECA {
+      algorithm = Plain_GatherData
+      #output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/FE_Warning
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist FEWarningPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+  
+
+    hist ModSyncBCID1ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID1ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist ModSyncBCID2ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncBCID2ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist ModSyncLVL1IDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModSyncLVL1IDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+ 
+    hist ModTruncEOCErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEOCErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist ModTruncEoEOverflowErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncEoEOverflowErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist ModTruncHitOverflowErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist ModTruncHitOverflowErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist OpticalErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist OpticalErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODSyncBCIDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncBCIDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODSyncLVL1IDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODSyncLVL1IDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODTimeoutPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+ 
+    hist RODTimeoutErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODTimeoutErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+ 
+    hist RODTruncHTLimitErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncHTLimitErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODTruncRODOFErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODTruncRODOFErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+  
+    hist SEUHammingPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHammingPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist SEUHitParityPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist SEUHitParityPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist SEURegisterParityPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist SEURegisterParityPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODBCIDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODBCIDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODLVL1IDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODLVL1IDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    } 
+    hist RODLVL1IDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    } 
+    hist RODLVL1IDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODLVL1IDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    } 
+    hist RODLVL1IDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+
+    hist RODLimitErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    }
+    hist RODLimitErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+   
+    hist RODMaskedLinkPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+    }
+    hist RODMaskedLinkPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+    } 
+    hist RODMaskedLinkPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+    } 
+    hist RODMaskedLinkPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+    }
+    hist RODMaskedLinkPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+    } 
+    hist RODMaskedLinkPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+    }
+   
+    hist RODPreambleErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODPreambleErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODRowColumnErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODRowColumnErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist RODTrailerBitErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerBitErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
+    hist RODTrailerErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    } 
+    hist RODTrailerErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist RODTrailerErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR0BCIDCounterErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR0BCIDCounterErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR1HammingCode0ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR1HammingCode0ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR2HammingCode1ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR2HammingCode1ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR3HammingCode2ErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode1ErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR3HammingCode2ErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR4L1InCounterErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR4L1InCounterErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR5L1RequestCounterErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR5L1RequestCounterErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+     
+    hist SR6L1RegisterErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR6L1RegisterErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR7L1TriggerIDErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR7L1TriggerIDErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR8FEReadoutProcessErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR8FEReadoutProcessErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEURegisterParityPerLumi_B0 {
+    hist SR8FEReadoutProcessErrorsPerLumi_ECA {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEURegisterParityPerLumi_B1 {
+    hist SR8FEReadoutProcessErrorsPerLumi_ECC {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
-    hist SEURegisterParityPerLumi_B2 {
+
+    hist SR15SkipppedTrigCountErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR15SkipppedTrigCountErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR16TruncatedEventFlagErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR16TruncatedEventFlagErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR24TripleRedundantErrorsCNFGMEMPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR25WriteRegDataErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR25WriteRegDataErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR26AddressErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR26AddressErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR27OtherCMDDecoderErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR27OtherCMDDecoderErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR28CMDDecoderBitflipErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR28CMDDecoderBitflipErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
+    hist SR29TripleRedundantErrorsCMDPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_B1 {
       algorithm = Plain_GatherData
-      output = InnerDetector/Pixel/PixelExpert/Errors/Bad_Module_Errors/SEU_Register_Parity
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR29TripleRedundantErrorsCMDPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+
+    hist SR30DataBusAddressErrorsPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR30DataBusAddressErrorsPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
     }
 
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_IBL {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXIBL/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_B0 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX0/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_B1 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX1/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_B2 {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIX2/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_ECA {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECA/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+    hist SR31TripleRedundantErrorsEFUSEPerLumi_ECC {
+      algorithm = Plain_GatherData
+      output = InnerDetector/Pixel/PIXECC/_Experts/DisableAndErrorsLB
+      description = https://twiki.cern.ch/twiki/bin/view/Atlas/PixelOfflineShiftInstructionsDQ#Disabled_Modules
+    }
+ 
   }
 
 
@@ -1832,7 +4528,7 @@ dir Pixel {
   #Below plot Combined Tracks
   dir TrackOnTrack {
 
-    hist tracksPerEvtPerLumi {
+    hist TracksPerEvtPerLumi {
       algorithm = Pix_LB_Bins_Diff_FromAvg
       output = InnerDetector/Pixel/PixelExpert/Tracks
       display = StatBox
diff --git a/DataQuality/DataQualityConfigurations/python/DQCDispatch.py b/DataQuality/DataQualityConfigurations/python/DQCDispatch.py
index 026ecec90fc58e5873ded071aca7cb854acaa103..59c9d53b087e0dc166e6507eb3454b90b59d6ab4 100644
--- a/DataQuality/DataQualityConfigurations/python/DQCDispatch.py
+++ b/DataQuality/DataQualityConfigurations/python/DQCDispatch.py
@@ -1,4 +1,4 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 # This holds the method that returns an appropriate DataQualityConfiguration
 # module for the specified input string
@@ -53,11 +53,11 @@ def getmodule(modname):
 
     import re
     # Does it look like datann_hip?
-    m = re.match('data\d{2}_hip', modname)
+    m = re.match(r'data\d{2}_hip', modname)
     if m:
         from . import base_data_hi; return base_data_hi
     # Does it look like datann?
-    m = re.match('data\d{2}$', modname)
+    m = re.match(r'data\d{2}$', modname)
     if m:
         from . import base_data; return base_data
 
diff --git a/DataQuality/DataQualityConfigurations/python/__init__.py b/DataQuality/DataQualityConfigurations/python/__init__.py
index 75416ffbf4c28a040489339291d160e30fbf1de7..5ff522e53eaa849163b63d0f9c89889089664f62 100644
--- a/DataQuality/DataQualityConfigurations/python/__init__.py
+++ b/DataQuality/DataQualityConfigurations/python/__init__.py
@@ -1,8 +1,5 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 # Hook for the DataQualityConfigurations package
-__all__ = ['data09', 'data09_1beam','data09_calocomm', 'data09_calophys',
-           'data09_cos', 'data09_idcomm', 'data09_larcomm', 'data09_muoncomm',
-           'data09_tilecomm', 'data08', 'data08_1beam', 'data08_1beammag',
-           'data08_cos', 'data08_cosmag', 'data08_idcomm', 'TestDisplay']
-from .DQCDispatch import getmodule
+__all__ = ['TestDisplay']
+from .DQCDispatch import getmodule  # noqa: F401
diff --git a/DataQuality/DataQualityConfigurations/python/_resolve_data_path.py b/DataQuality/DataQualityConfigurations/python/_resolve_data_path.py
index 0366d000d292be5b07d00fe9a3ae6f8530fe7241..4bbe6fe97f86a89e712a3b76f2633f113d682383 100644
--- a/DataQuality/DataQualityConfigurations/python/_resolve_data_path.py
+++ b/DataQuality/DataQualityConfigurations/python/_resolve_data_path.py
@@ -1,3 +1,4 @@
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 import os
 import logging
 logging.basicConfig()
diff --git a/DataQuality/DataQualityConfigurations/python/data08.py b/DataQuality/DataQualityConfigurations/python/data08.py
deleted file mode 100644
index c4ec0c6fafeb41570dfda47ab60ed1a39d143659..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data08.py
+++ /dev/null
@@ -1,26 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-
-from DataQualityUtils.DQWebDisplayConfig import DQWebDisplayConfig
-
-dqconfig = DQWebDisplayConfig()
-dqconfig.config         = "data08"
-dqconfig.hcfg           = "/afs/cern.ch/user/a/atlasdqm/dqmdisk/tier0/han_config/Collisions/collisions_run.1.63.hcfg"
-dqconfig.hcfg_min10     = "/afs/cern.ch/user/a/atlasdqm/dqmdisk/tier0/han_config/Collisions/collisions_minutes10.1.18.hcfg"
-dqconfig.hcfg_min30     = "/afs/cern.ch/user/a/atlasdqm/dqmdisk/tier0/han_config/Collisions/collisions_minutes30.1.6.hcfg"
-dqconfig.server         = "voatlas12.cern.ch"
-dqconfig.histogramCache = "/afs/cern.ch/user/a/atlasdqm/w1/histogram_web_display_cache"
-dqconfig.hanResultsDir  = "/dqmdisk0/han_results/tier0/all"
-dqconfig.htmlDir        = "/dqmdisk0/www/tier0/data08"
-dqconfig.htmlWeb        = "http://atlasdqm.cern.ch/tier0/data08"
-dqconfig.runlist        = "runlist_data08.xml"
-dqconfig.indexFile      = "results_data08.html"
-dqconfig.lockFile       = "DQWebDisplay_data08.lock"
-#dqconfig.dbConnection       = "oracle://ATLAS_COOLWRITE;schema=ATLAS_COOLOFL_GLOBAL;dbname=COMP200;"
-#dqconfig.dqmfOfl            = "/GLOBAL/DETSTATUS/DQMFOFL"
-#dqconfig.dbConnectionHisto  = "oracle://ATLAS_COOLWRITE;schema=ATLAS_COOLOFL_GLOBAL;dbname=COMP200;"
-#dqconfig.dqmfOflHisto       = "/GLOBAL/DETSTATUS/DQMFOFLH"
-#dqconfig.dbTagName          = "HEAD"
-
-#authentication file at Tier0 (uncomment this option at Tier0 only)
-#dqconfig.auth       = "/afs/cern.ch/atlas/project/tzero/var"
diff --git a/DataQuality/DataQualityConfigurations/python/data08_1beam.py b/DataQuality/DataQualityConfigurations/python/data08_1beam.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data08_1beam.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data08_1beammag.py b/DataQuality/DataQualityConfigurations/python/data08_1beammag.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data08_1beammag.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data08_coll900.py b/DataQuality/DataQualityConfigurations/python/data08_coll900.py
deleted file mode 100644
index 639112681909becce6b4b99168fe6d8884702ed8..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data08_coll900.py
+++ /dev/null
@@ -1,26 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-
-from DataQualityUtils.DQWebDisplayConfig import DQWebDisplayConfig
-
-dqconfig = DQWebDisplayConfig()
-dqconfig.config         = "data08_coll900"
-dqconfig.hcfg           = "/afs/cern.ch/user/a/atlasdqm/dqmdisk/tier0/han_config/Collisions/collisions_run.1.36.hcfg"
-dqconfig.hcfg_min10     = "/afs/cern.ch/user/a/atlasdqm/dqmdisk/tier0/han_config/Collisions/collisions_minutes10.1.9.hcfg"
-dqconfig.hcfg_min30     = "/afs/cern.ch/user/a/atlasdqm/dqmdisk/tier0/han_config/Collisions/collisions_minutes30.1.5.hcfg"
-dqconfig.server         = "voatlas12.cern.ch"
-dqconfig.histogramCache = "/afs/cern.ch/user/a/atlasdqm/w1/histogram_web_display_cache"
-dqconfig.hanResultsDir  = "/dqmdisk0/han_results/tier0/NotUsed"
-dqconfig.htmlDir        = "/dqmdisk0/www/tier0/data08_coll900"
-dqconfig.htmlWeb        = "http://atlasdqm.cern.ch/tier0/data08_coll900"
-dqconfig.runlist        = "runlist_data08_coll900.xml"
-dqconfig.indexFile      = "results_data08_coll900.html"
-dqconfig.lockFile       = "DQWebDisplay_data08_coll900.lock"
-#dqconfig.dbConnection       = "oracle://ATLAS_COOLWRITE;schema=ATLAS_COOLOFL_GLOBAL;dbname=COMP200;"
-#dqconfig.dqmfOfl            = "/GLOBAL/DETSTATUS/DQMFOFL"
-#dqconfig.dbConnectionHisto  = "oracle://ATLAS_COOLWRITE;schema=ATLAS_COOLOFL_GLOBAL;dbname=COMP200;"
-#dqconfig.dqmfOflHisto       = "/GLOBAL/DETSTATUS/DQMFOFLH"
-#dqconfig.dbTagName          = "HEAD"
-
-#authentication file at Tier0 (uncomment this option at Tier0 only)
-#dqconfig.auth       = "/afs/cern.ch/atlas/project/tzero/var"
diff --git a/DataQuality/DataQualityConfigurations/python/data08_cos.py b/DataQuality/DataQualityConfigurations/python/data08_cos.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data08_cos.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data08_cosmag.py b/DataQuality/DataQualityConfigurations/python/data08_cosmag.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data08_cosmag.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data08_idcomm.py b/DataQuality/DataQualityConfigurations/python/data08_idcomm.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data08_idcomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data09.py b/DataQuality/DataQualityConfigurations/python/data09.py
deleted file mode 100644
index 20c43c63c877bdf3a9a91d7e6e5c94eb5ff7e1d3..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data09.py
+++ /dev/null
@@ -1,4 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# -*- coding: utf-8 -*-
-from base_data import *
diff --git a/DataQuality/DataQualityConfigurations/python/data09_1beam.py b/DataQuality/DataQualityConfigurations/python/data09_1beam.py
deleted file mode 100644
index 3b261a0b9f34956d1a3b4aa6ba9f6d85e43c1809..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data09_1beam.py
+++ /dev/null
@@ -1,4 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# -*- coding: utf-8 -*-
-from base_data_1beam import *
diff --git a/DataQuality/DataQualityConfigurations/python/data09_2TeV.py b/DataQuality/DataQualityConfigurations/python/data09_2TeV.py
index 1a86084fd40a65715d7157b63341452e1936f177..bae1a7a3b516e7e6c9baf62797ed494e0052e7ee 100644
--- a/DataQuality/DataQualityConfigurations/python/data09_2TeV.py
+++ b/DataQuality/DataQualityConfigurations/python/data09_2TeV.py
@@ -1,3 +1,3 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-from data09 import *
+from base_data import *  # noqa: F401 F403
diff --git a/DataQuality/DataQualityConfigurations/python/data09_900GeV.py b/DataQuality/DataQualityConfigurations/python/data09_900GeV.py
deleted file mode 100644
index 1a86084fd40a65715d7157b63341452e1936f177..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data09_900GeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data09_calocomm.py b/DataQuality/DataQualityConfigurations/python/data09_calocomm.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data09_calocomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data09_calophys.py b/DataQuality/DataQualityConfigurations/python/data09_calophys.py
index 0fc683042d2598a4467df2c00ec27e134e3fa858..c892f2a397532d0e29bb778266495e387b54ca8d 100644
--- a/DataQuality/DataQualityConfigurations/python/data09_calophys.py
+++ b/DataQuality/DataQualityConfigurations/python/data09_calophys.py
@@ -1,3 +1,3 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-from data09_cos import *
+from base_data_cos import *  # noqa: F401 F403
diff --git a/DataQuality/DataQualityConfigurations/python/data09_cos.py b/DataQuality/DataQualityConfigurations/python/data09_cos.py
deleted file mode 100644
index cd491ff01826dc92bb6bb6365baff02471a4c25b..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data09_cos.py
+++ /dev/null
@@ -1,4 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# -*- coding: utf-8 -*-
-from base_data_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data09_idcomm.py b/DataQuality/DataQualityConfigurations/python/data09_idcomm.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data09_idcomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data09_larcomm.py b/DataQuality/DataQualityConfigurations/python/data09_larcomm.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data09_larcomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data09_muoncomm.py b/DataQuality/DataQualityConfigurations/python/data09_muoncomm.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data09_muoncomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data09_tilecomm.py b/DataQuality/DataQualityConfigurations/python/data09_tilecomm.py
deleted file mode 100644
index 0fc683042d2598a4467df2c00ec27e134e3fa858..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data09_tilecomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data09_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10.py b/DataQuality/DataQualityConfigurations/python/data10.py
deleted file mode 100644
index 356567aecb2d3749c85c6453874ae4d72beedf88..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_10TeV.py b/DataQuality/DataQualityConfigurations/python/data10_10TeV.py
deleted file mode 100644
index 75f4ab196ff44aa7031f9c8beafa944add1e9486..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_10TeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_1beam.py b/DataQuality/DataQualityConfigurations/python/data10_1beam.py
deleted file mode 100644
index 3b261a0b9f34956d1a3b4aa6ba9f6d85e43c1809..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_1beam.py
+++ /dev/null
@@ -1,4 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# -*- coding: utf-8 -*-
-from base_data_1beam import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_2TeV.py b/DataQuality/DataQualityConfigurations/python/data10_2TeV.py
deleted file mode 100644
index 75f4ab196ff44aa7031f9c8beafa944add1e9486..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_2TeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_7TeV.py b/DataQuality/DataQualityConfigurations/python/data10_7TeV.py
deleted file mode 100644
index 75f4ab196ff44aa7031f9c8beafa944add1e9486..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_7TeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_900GeV.py b/DataQuality/DataQualityConfigurations/python/data10_900GeV.py
deleted file mode 100644
index 75f4ab196ff44aa7031f9c8beafa944add1e9486..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_900GeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_calocomm.py b/DataQuality/DataQualityConfigurations/python/data10_calocomm.py
deleted file mode 100644
index 4f706cab764a5e1d1c1a240c182e3c42c9ef37ee..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_calocomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_comm.py b/DataQuality/DataQualityConfigurations/python/data10_comm.py
deleted file mode 100644
index 75f4ab196ff44aa7031f9c8beafa944add1e9486..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_comm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_cos.py b/DataQuality/DataQualityConfigurations/python/data10_cos.py
deleted file mode 100644
index 46db26b2c0e9fb1bcced3972fd55ee825873d9c8..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_cos.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_hi.py b/DataQuality/DataQualityConfigurations/python/data10_hi.py
deleted file mode 100644
index bf30d7abe058228901ae83e5f597429594c4aaf5..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_hi.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_hi import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_idcomm.py b/DataQuality/DataQualityConfigurations/python/data10_idcomm.py
deleted file mode 100644
index 4f706cab764a5e1d1c1a240c182e3c42c9ef37ee..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_idcomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_larcomm.py b/DataQuality/DataQualityConfigurations/python/data10_larcomm.py
deleted file mode 100644
index 4f706cab764a5e1d1c1a240c182e3c42c9ef37ee..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_larcomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_muoncomm.py b/DataQuality/DataQualityConfigurations/python/data10_muoncomm.py
deleted file mode 100644
index 4f706cab764a5e1d1c1a240c182e3c42c9ef37ee..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_muoncomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data10_tilecomm.py b/DataQuality/DataQualityConfigurations/python/data10_tilecomm.py
deleted file mode 100644
index 4f706cab764a5e1d1c1a240c182e3c42c9ef37ee..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data10_tilecomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data10_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11.py b/DataQuality/DataQualityConfigurations/python/data11.py
deleted file mode 100644
index 356567aecb2d3749c85c6453874ae4d72beedf88..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_1beam.py b/DataQuality/DataQualityConfigurations/python/data11_1beam.py
deleted file mode 100644
index 3b261a0b9f34956d1a3b4aa6ba9f6d85e43c1809..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_1beam.py
+++ /dev/null
@@ -1,4 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# -*- coding: utf-8 -*-
-from base_data_1beam import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_2p76TeV.py b/DataQuality/DataQualityConfigurations/python/data11_2p76TeV.py
deleted file mode 100644
index e9136bd0947092f5869d9edb06332430d71f4159..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_2p76TeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_7TeV.py b/DataQuality/DataQualityConfigurations/python/data11_7TeV.py
deleted file mode 100644
index e9136bd0947092f5869d9edb06332430d71f4159..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_7TeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_900GeV.py b/DataQuality/DataQualityConfigurations/python/data11_900GeV.py
deleted file mode 100644
index e9136bd0947092f5869d9edb06332430d71f4159..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_900GeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_calib.py b/DataQuality/DataQualityConfigurations/python/data11_calib.py
deleted file mode 100644
index e9136bd0947092f5869d9edb06332430d71f4159..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_calib.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_calocomm.py b/DataQuality/DataQualityConfigurations/python/data11_calocomm.py
deleted file mode 100644
index 0326946874391d91d4098055a668592305b4c167..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_calocomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_comm.py b/DataQuality/DataQualityConfigurations/python/data11_comm.py
deleted file mode 100644
index e9136bd0947092f5869d9edb06332430d71f4159..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_comm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_cos.py b/DataQuality/DataQualityConfigurations/python/data11_cos.py
deleted file mode 100644
index 46db26b2c0e9fb1bcced3972fd55ee825873d9c8..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_cos.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_hi.py b/DataQuality/DataQualityConfigurations/python/data11_hi.py
deleted file mode 100644
index bf30d7abe058228901ae83e5f597429594c4aaf5..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_hi.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_hi import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_hip.py b/DataQuality/DataQualityConfigurations/python/data11_hip.py
deleted file mode 100644
index bf30d7abe058228901ae83e5f597429594c4aaf5..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_hip.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_hi import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_idcomm.py b/DataQuality/DataQualityConfigurations/python/data11_idcomm.py
deleted file mode 100644
index 0326946874391d91d4098055a668592305b4c167..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_idcomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_larcomm.py b/DataQuality/DataQualityConfigurations/python/data11_larcomm.py
deleted file mode 100644
index 0326946874391d91d4098055a668592305b4c167..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_larcomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_muoncomm.py b/DataQuality/DataQualityConfigurations/python/data11_muoncomm.py
deleted file mode 100644
index 0326946874391d91d4098055a668592305b4c167..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_muoncomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data11_tilecomm.py b/DataQuality/DataQualityConfigurations/python/data11_tilecomm.py
deleted file mode 100644
index 0326946874391d91d4098055a668592305b4c167..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data11_tilecomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data11_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12.py b/DataQuality/DataQualityConfigurations/python/data12.py
deleted file mode 100644
index 356567aecb2d3749c85c6453874ae4d72beedf88..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_1beam.py b/DataQuality/DataQualityConfigurations/python/data12_1beam.py
deleted file mode 100644
index d05935a89afb4fb215efe76e414ceca914b27e27..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_1beam.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_1beam import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_2p76TeV.py b/DataQuality/DataQualityConfigurations/python/data12_2p76TeV.py
deleted file mode 100644
index fdb594b2bafca0a477a8b0af79d4b7ac14d63fef..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_2p76TeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_7TeV.py b/DataQuality/DataQualityConfigurations/python/data12_7TeV.py
deleted file mode 100644
index fdb594b2bafca0a477a8b0af79d4b7ac14d63fef..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_7TeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_8TeV.py b/DataQuality/DataQualityConfigurations/python/data12_8TeV.py
deleted file mode 100644
index fdb594b2bafca0a477a8b0af79d4b7ac14d63fef..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_8TeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_900GeV.py b/DataQuality/DataQualityConfigurations/python/data12_900GeV.py
deleted file mode 100644
index fdb594b2bafca0a477a8b0af79d4b7ac14d63fef..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_900GeV.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_calib.py b/DataQuality/DataQualityConfigurations/python/data12_calib.py
deleted file mode 100644
index fdb594b2bafca0a477a8b0af79d4b7ac14d63fef..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_calib.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_calocomm.py b/DataQuality/DataQualityConfigurations/python/data12_calocomm.py
deleted file mode 100644
index 90c6ed2e3db6c99f8cc453ba9395e6916a7e5a4a..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_calocomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_comm.py b/DataQuality/DataQualityConfigurations/python/data12_comm.py
deleted file mode 100644
index fdb594b2bafca0a477a8b0af79d4b7ac14d63fef..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_comm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12 import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_cos.py b/DataQuality/DataQualityConfigurations/python/data12_cos.py
deleted file mode 100644
index 46db26b2c0e9fb1bcced3972fd55ee825873d9c8..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_cos.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_hi.py b/DataQuality/DataQualityConfigurations/python/data12_hi.py
deleted file mode 100644
index bf30d7abe058228901ae83e5f597429594c4aaf5..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_hi.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_hi import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_hip.py b/DataQuality/DataQualityConfigurations/python/data12_hip.py
deleted file mode 100644
index bf30d7abe058228901ae83e5f597429594c4aaf5..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_hip.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_hi import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_idcomm.py b/DataQuality/DataQualityConfigurations/python/data12_idcomm.py
deleted file mode 100644
index 90c6ed2e3db6c99f8cc453ba9395e6916a7e5a4a..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_idcomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_larcomm.py b/DataQuality/DataQualityConfigurations/python/data12_larcomm.py
deleted file mode 100644
index 90c6ed2e3db6c99f8cc453ba9395e6916a7e5a4a..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_larcomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_muoncomm.py b/DataQuality/DataQualityConfigurations/python/data12_muoncomm.py
deleted file mode 100644
index 90c6ed2e3db6c99f8cc453ba9395e6916a7e5a4a..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_muoncomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data12_tilecomm.py b/DataQuality/DataQualityConfigurations/python/data12_tilecomm.py
deleted file mode 100644
index 90c6ed2e3db6c99f8cc453ba9395e6916a7e5a4a..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data12_tilecomm.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from data12_cos import *
diff --git a/DataQuality/DataQualityConfigurations/python/data13_hip.py b/DataQuality/DataQualityConfigurations/python/data13_hip.py
deleted file mode 100644
index bf30d7abe058228901ae83e5f597429594c4aaf5..0000000000000000000000000000000000000000
--- a/DataQuality/DataQualityConfigurations/python/data13_hip.py
+++ /dev/null
@@ -1,3 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-from base_data_hi import *
diff --git a/DataQuality/dqm_algorithms/src/BinContentComp.cxx b/DataQuality/dqm_algorithms/src/BinContentComp.cxx
index e963f099179491be4b26b79bef45688901c0fc85..dc69025d225ddd3485e143e61021ede0ac5895cf 100644
--- a/DataQuality/dqm_algorithms/src/BinContentComp.cxx
+++ b/DataQuality/dqm_algorithms/src/BinContentComp.cxx
@@ -1,7 +1,8 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
+
 /*! \file BinContentComp.cxx compares bins of histogram wrt to reference histogram and counts number of bins N Sigma away from ref; returns dqm_core::Result
  * \author Haleh Hadavand
  */
@@ -11,6 +12,8 @@
 #include <dqm_algorithms/tools/AlgorithmHelper.h>
 #include <TH1.h>
 #include <TF1.h>
+#include <TProfile.h>
+#include <TProfile2D.h>
 #include <TClass.h>
 #include <math.h>
 #include <ers/ers.h>
@@ -90,8 +93,17 @@ dqm_algorithms::BinContentComp::execute(	const std::string & name,
     result->tags_["InsufficientEntries"] = histogram->GetEntries();
     return result;
   }
-  
+
+  const TProfile* profile(nullptr);
+  const TProfile2D* profile2D(nullptr);
+  const double minBinEntries = dqm_algorithms::tools::GetFirstFromMap( "MinBinEntries", config.getParameters(), -1);
+  if(minBinEntries > 0) {
+   if (object.InheritsFrom("TProfile"))        profile   = dynamic_cast<const TProfile*>(&object);
+   else if (object.InheritsFrom("TProfile2D")) profile2D = dynamic_cast<const TProfile2D*>(&object);
+  }
+
   const bool ignorezero = (bool) dqm_algorithms::tools::GetFirstFromMap( "Ignore0", config.getParameters(), 0);
+  const bool ignoreInputZero = (bool) dqm_algorithms::tools::GetFirstFromMap( "IgnoreInput0", config.getParameters(), 0);
   bool greaterthan = (bool) dqm_algorithms::tools::GetFirstFromMap( "GreaterThan", config.getParameters(), 0);
   bool lessthan = (bool) dqm_algorithms::tools::GetFirstFromMap( "LessThan", config.getParameters(), 0);
   const bool publish = (bool) dqm_algorithms::tools::GetFirstFromMap( "PublishBins", config.getParameters(), 0);
@@ -144,8 +156,24 @@ dqm_algorithms::BinContentComp::execute(	const std::string & name,
       refhist->Scale(ratio);
    }
 
+   int nSkippedBins(0);
   for ( int i = range[0]; i <= range[1]; ++i ) {
     for ( int j = range[2]; j <= range[3]; ++j ) {
+      if (minBinEntries > 0) {
+        int bin = histogram->GetBin(i, j);
+        if (profile) {
+          if (profile->GetBinEntries(bin) < minBinEntries) {
+            ++nSkippedBins;
+            continue;
+          }
+        } else if (profile2D) {
+          if (profile2D->GetBinEntries(bin) < minBinEntries) {
+            ++nSkippedBins;
+            continue;
+          }
+        }
+      }
+
      if ( ! refhist ){
 	 refcont=value;
      } else {
@@ -172,8 +200,11 @@ dqm_algorithms::BinContentComp::execute(	const std::string & name,
       double reldiff=1;
       if(refcont!=0) reldiff=diff/refcont;
       else if(diff==0) reldiff=0;
+
       if (ignorezero && refcont==0) continue;
-      if (ignorezero && ! refhist && inputcont==0) continue;
+      if (ignorezero && !refhist && inputcont==0) continue;
+      if (ignoreInputZero && inputcont==0) continue;
+
       if (inputerr !=0){
 	double sigma=diff/inputerr;
 	if (greaterthan && diff < 0. ) continue;  
@@ -200,8 +231,9 @@ dqm_algorithms::BinContentComp::execute(	const std::string & name,
   
   
   result->tags_["NBins"] = count;
+  result->tags_["NSkippedBins"] = nSkippedBins;
   result->object_ =  (boost::shared_ptr<TObject>)(TObject*)(resulthisto);
-  
+
   if (gthreshold > rthreshold) {
      if ( count >= gthreshold ) {
         result->status_ = dqm_core::Result::Green;
@@ -236,6 +268,7 @@ dqm_algorithms::BinContentComp::printDescription(std::ostream& out)
   
   out<<"Optional Parameter: MinStat: Minimum histogram statistics needed to perform Algorithm"<<std::endl;
   out<<"Optional Parameter: Ignore0: Ignore bins which have zero entries in reference histogram"<<std::endl;
+  out<<"Optional Parameter: IgnoreInput0: Ignore bins which have zero entries in tested histogram"<<std::endl;
   out<<"Optional Parameter: xmin: minimum x range"<<std::endl;
   out<<"Optional Parameter: xmax: maximum x range"<<std::endl;
   out<<"Optional Parameter: ymin: minimum y range"<<std::endl;
@@ -249,6 +282,7 @@ dqm_algorithms::BinContentComp::printDescription(std::ostream& out)
   out<<"Optional Parameter: MaxDiffRel: test fails if NBins more than NSigma away and NBins more than MaxDiffRel (relative difference) away\n"<<std::endl; 
   out<<"Optional Parameter: FixedError: override the histogram errors with this value"<<std::endl;
   out<<"Optional Parameter: IncludeRefError: use both the histogram and reference histogram errors in calculation"<<std::endl;
-                                                                                                                                            
+  out<<"Optional Parameter: MinBinEntries: Minimum bin entries in profile histogram needed to check this bin (by default: -1)"<<std::endl;
+
 }
 
diff --git a/Database/APR/CollectionUtilities/src/Args2Container.cpp b/Database/APR/CollectionUtilities/src/Args2Container.cpp
index 1dcbd2514a518e4749b06000c77cddf2bdd14828..577838539a862d8568d82522ed52c81a2f8ad115 100644
--- a/Database/APR/CollectionUtilities/src/Args2Container.cpp
+++ b/Database/APR/CollectionUtilities/src/Args2Container.cpp
@@ -15,20 +15,14 @@
 
 #include <xercesc/sax/SAXException.hpp>
 
-#include <xercesc/framework/StdOutFormatTarget.hpp>
-#include <xercesc/framework/LocalFileFormatTarget.hpp>
 #include <xercesc/framework/StdOutFormatTarget.hpp>
 #include <xercesc/framework/LocalFileFormatTarget.hpp>
 
 #include <xercesc/util/XMLUni.hpp>
 #include <xercesc/util/PlatformUtils.hpp>
-#include <xercesc/util/XMLUni.hpp>
 #include <xercesc/util/OutOfMemoryException.hpp>
-#include <xercesc/util/PlatformUtils.hpp>
 #include <xercesc/util/TransService.hpp>
 
-//#include <xercesc/parsers/XercesDOMParser.hpp>
-
 #include <ctime>
 #include <stdexcept>
 
diff --git a/Database/APR/CollectionUtilities/src/QueryInfo.cpp b/Database/APR/CollectionUtilities/src/QueryInfo.cpp
index 126a452f8d6b06c622901ce06eb8d0b482eed861..c4242d03a97d7a9e8d9e7ed74a3c923537ccb42b 100644
--- a/Database/APR/CollectionUtilities/src/QueryInfo.cpp
+++ b/Database/APR/CollectionUtilities/src/QueryInfo.cpp
@@ -16,8 +16,6 @@
 #include "CollectionBase/CollectionFactory.h"
 
 #include "CollectionBase/ICollectionQuery.h"
-#include "CollectionBase/ICollectionCursor.h"
-#include "CollectionBase/CollectionRowBuffer.h"
 #include "CoralBase/Attribute.h"
 
 #include "POOLCore/Exception.h"
diff --git a/Database/APR/CollectionUtilities/utilities/CollListMetadata.cpp b/Database/APR/CollectionUtilities/utilities/CollListMetadata.cpp
index d3e490ced4d0eab560ec5031b857f25ea8573d07..ce65f24894b7a3aec88156c6c48c8a9f23ef9bba 100644
--- a/Database/APR/CollectionUtilities/utilities/CollListMetadata.cpp
+++ b/Database/APR/CollectionUtilities/utilities/CollListMetadata.cpp
@@ -30,16 +30,12 @@
  
 #include <xercesc/sax/SAXException.hpp> 
  
-#include <xercesc/framework/StdOutFormatTarget.hpp> 
-#include <xercesc/framework/LocalFileFormatTarget.hpp> 
 #include <xercesc/framework/StdOutFormatTarget.hpp> 
 #include <xercesc/framework/LocalFileFormatTarget.hpp> 
          
 #include <xercesc/util/XMLUni.hpp> 
 #include <xercesc/util/PlatformUtils.hpp> 
-#include <xercesc/util/XMLUni.hpp> 
 #include <xercesc/util/OutOfMemoryException.hpp> 
-#include <xercesc/util/PlatformUtils.hpp> 
 #include <xercesc/util/TransService.hpp> 
 
 XERCES_CPP_NAMESPACE_USE 
diff --git a/Database/AthenaPOOL/AtlasCollectionTools/src/CollSplitByRun.cxx b/Database/AthenaPOOL/AtlasCollectionTools/src/CollSplitByRun.cxx
index 07f309cf53263476d8db94861649a60bdbb3cb90..4a2af7be12d0d4f03e5cdd872ae80b257819b379 100755
--- a/Database/AthenaPOOL/AtlasCollectionTools/src/CollSplitByRun.cxx
+++ b/Database/AthenaPOOL/AtlasCollectionTools/src/CollSplitByRun.cxx
@@ -45,7 +45,6 @@
 #include "POOLCollectionTools/CatalogInfo.h"
 #include "POOLCollectionTools/UtilityFuncs.h"
 
-#include "CoralBase/MessageStream.h"
 #include "StorageSvc/DbStatus.h"
 
 #include <iostream>
diff --git a/Database/AthenaRoot/AthenaRootComps/src/xAODEventSelector.cxx b/Database/AthenaRoot/AthenaRootComps/src/xAODEventSelector.cxx
index 4860a19f06c2e0e155ff596eff702f4796b6ffa6..2a5455163e4a647cec80447f2c6b2594f103578d 100644
--- a/Database/AthenaRoot/AthenaRootComps/src/xAODEventSelector.cxx
+++ b/Database/AthenaRoot/AthenaRootComps/src/xAODEventSelector.cxx
@@ -27,7 +27,6 @@
 #include "Gaudi/Property.h"
 
 // Framework includes
-//#include "GaudiKernel/GenericAddress.h"
 #include "GaudiKernel/FileIncident.h"
 #include "GaudiKernel/IIoComponentMgr.h"
 #include "GaudiKernel/ISvcLocator.h"
@@ -62,11 +61,7 @@
 // xAOD include(s):
 #include "xAODRootAccess/Init.h"
 
-//#include "xAODRootAccess/TEvent.h"
-//#include "AsgTools/SgTEvent.h"
-
 #include "GaudiKernel/ServiceHandle.h"
-#include "AthenaKernel/IClassIDSvc.h"
 #include "AthenaKernel/IProxyProviderSvc.h"
 #include <map>
 
diff --git a/Database/CoolConvUtilities/src/AtlCoolCopy.cxx b/Database/CoolConvUtilities/src/AtlCoolCopy.cxx
index 5e34ed8a26a4a95a77586b361cb43c3b3f319afd..6dcf1e9b3968a818b6d973028fa56d59239af71e 100755
--- a/Database/CoolConvUtilities/src/AtlCoolCopy.cxx
+++ b/Database/CoolConvUtilities/src/AtlCoolCopy.cxx
@@ -25,7 +25,6 @@
 #include "CoolKernel/IFolderSet.h"
 #include "CoolKernel/IObject.h"
 #include "CoolKernel/IObjectIterator.h"
-#include "CoolKernel/Exception.h"
 #include "CoolKernel/IRecordIterator.h"
 #include "CoolApplication/Application.h"
 #include "CoralBase/AttributeListException.h"
diff --git a/Database/FileStager/src/FileStagerAlg.cxx b/Database/FileStager/src/FileStagerAlg.cxx
index e55b95c23be7a939d3ff17f1da97ab38bac1f161..1d69c49e01bd547c1cd5fe4180f0ddc58c45fcdf 100644
--- a/Database/FileStager/src/FileStagerAlg.cxx
+++ b/Database/FileStager/src/FileStagerAlg.cxx
@@ -18,7 +18,6 @@
 #include <TTree.h>
 #include <TStopwatch.h>
 #include <TH1D.h>
-#include <TFile.h>
 
 FileStagerAlg::FileStagerAlg(const std::string& name, ISvcLocator* pSvcLocator) 
  : Algorithm(name, pSvcLocator)
diff --git a/Database/IOVDbSvc/share/IOVRecExCommission.py b/Database/IOVDbSvc/share/IOVRecExCommission.py
deleted file mode 100644
index f1e69355b0977b321c417c42907f76dd86a8ca7d..0000000000000000000000000000000000000000
--- a/Database/IOVDbSvc/share/IOVRecExCommission.py
+++ /dev/null
@@ -1,10 +0,0 @@
-# IOVRecExCommission.py - setup IOVDbSvc for RecExCommission
-# commissioning with real data
-
-log.warning("IOVDbSvc/IOVRecExCommission.py - This file is obselete; conditions DB access should automatically be configured from detector geometry")
-
-from AthenaCommon.GlobalFlags import globalflags
-if (globalflags.DetGeo()=='commis' and globalflags.DataSource()=='data'):
-    from IOVDbSvc.CondDB import conddb
-else:
-    raise RuntimeError,'IOVRecExCommission.py included but geometry is not commis / real data'
diff --git a/Database/IOVDbSvc/share/IOVRecExCommissionMC.py b/Database/IOVDbSvc/share/IOVRecExCommissionMC.py
deleted file mode 100644
index 107bab00a4bac343899bc9472d47f0c4b5e9f29f..0000000000000000000000000000000000000000
--- a/Database/IOVDbSvc/share/IOVRecExCommissionMC.py
+++ /dev/null
@@ -1,10 +0,0 @@
-# IOVRecExCommission.py - setup IOVDbSvc for RecExCommissionMC
-# commissioning with Monte Carlo
-
-log.warning("IOVDbSvc/IOVRecExCommissionMC.py - This file is obselete; conditions DB access should automatically be configured from detector geometry")
-
-from AthenaCommon.GlobalFlags import globalflags
-if (globalflags.DetGeo()=='commis' and globalflags.DataSource()!='data'):
-    from IOVDbSvc.CondDB import conddb
-else:
-    raise RuntimeError,'IOVRecExCommissionMC.py included but geometry is not commis / Monte Carlo'
diff --git a/Database/IOVDbSvc/share/IOVRecExCommissionSR1.py b/Database/IOVDbSvc/share/IOVRecExCommissionSR1.py
deleted file mode 100644
index 2c536f0fb08314bba560061f720afaa74a4d559b..0000000000000000000000000000000000000000
--- a/Database/IOVDbSvc/share/IOVRecExCommissionSR1.py
+++ /dev/null
@@ -1,17 +0,0 @@
-# IOVRecExCommissionSR1.py - setup IOVDbSvc for ID commissioning in SR1
-# commissioning with real data, but temporarily using COOL1.2.x CMCPROD db
-# setup for sqlite replica expected to be found in sqlite130/CMCPROD.db
-#
-
-include.block ( "IOVDbSvc/IOVRecExCommissionSR1.py" )
-
-IOVCoolDBTech="sqlite"
-IOVCoolDBProd="CMCPROD"
-IOVCoolDBUser="ATLAS_COOL_READER"
-IOVCoolDBPwd="COOLRED4PRO"
-#
-include("IOVDbSvc/IOVCondDB.py")
-
-# include comcond catalog via DATAPATH
-PoolSvc = Service( "PoolSvc" )
-PoolSvc.ReadCatalog+= [ "prfile:poolcond/PoolCat_comcond.xml" ]
diff --git a/Database/IOVDbSvc/src/IOVDbSvc.cxx b/Database/IOVDbSvc/src/IOVDbSvc.cxx
index 490f5f337797d81228c91f28cb04da4a40c69090..270918bcbfa33885d80e2bd1d1354582b8c896cb 100644
--- a/Database/IOVDbSvc/src/IOVDbSvc.cxx
+++ b/Database/IOVDbSvc/src/IOVDbSvc.cxx
@@ -695,7 +695,8 @@ StatusCode IOVDbSvc::processTagInfo() {
   // Set GlobalTag and any folder-specific overrides if given
 
   // dump out contents of TagInfo
-   ATH_MSG_DEBUG( "Tags from input TagInfo:" << std::endl << m_h_tagInfoMgr->dumpTagInfoToStr() );
+   ATH_MSG_DEBUG( "Tags from input TagInfo:");
+  if( msg().level()>=MSG::DEBUG ) m_h_tagInfoMgr->printTags(msg());
   
   // check IOVDbSvc GlobalTag, if not already set
   if (m_globalTag=="") {
diff --git a/Database/IOVDbSvc/src/IOVDbSvc.h b/Database/IOVDbSvc/src/IOVDbSvc.h
index b8b97e91a4b66dbc4bf6c537cd81c7d0c4290a5e..1dc71aa1b797e6c4e41607743c33cfd45a357bc1 100644
--- a/Database/IOVDbSvc/src/IOVDbSvc.h
+++ b/Database/IOVDbSvc/src/IOVDbSvc.h
@@ -35,6 +35,7 @@
 #include "AthenaKernel/IIOVDbSvc.h"
 #include "IOVDbSvc/IIOVCondDbSvc.h"
 #include "AthenaKernel/IOVTime.h"
+#include "AthenaKernel/IAddressProvider.h"
 
 #include "CoolKernel/IDatabase.h"
 #include "CoolKernel/ValidityKey.h"
diff --git a/Database/TPTools/TPTools/ITPConverter.h b/Database/TPTools/TPTools/ITPConverter.h
index 780244d387eba4ad309479ce027637085b06bbe9..f575dc5b5d88bfca1c1c6f00fd49e16f988f9b08 100644
--- a/Database/TPTools/TPTools/ITPConverter.h
+++ b/Database/TPTools/TPTools/ITPConverter.h
@@ -103,7 +103,6 @@ public:
 
 //--------------  TPConverterTypeMap<CONVERTER_BASE>  -------------
 #include <map>
-#include <typeinfo>
 
 /** class TPConverterTypeMap
     Converter registry template: a map from type_info to the appropriate converter.
diff --git a/DetectorDescription/GeoModel/GeoModelInterfaces/GeoModelInterfaces/IGeoModelSvc.h b/DetectorDescription/GeoModel/GeoModelInterfaces/GeoModelInterfaces/IGeoModelSvc.h
index 9cc4ad58c7e150901aecaaecfa9f575d7407dcf1..d0dc05904263284fb953369ff9768ba388a8d809 100755
--- a/DetectorDescription/GeoModel/GeoModelInterfaces/GeoModelInterfaces/IGeoModelSvc.h
+++ b/DetectorDescription/GeoModel/GeoModelInterfaces/GeoModelInterfaces/IGeoModelSvc.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef GEOMODELINTERFACES_IGEOMODELSVC_H
@@ -9,21 +9,15 @@
 #include "GeoModelInterfaces/IGeoDbTagSvc.h"
 #include "GaudiKernel/IInterface.h"
 #include "GaudiKernel/StatusCode.h"
-#include "AthenaKernel/IOVSvcDefs.h"
 #include <string>
 
 // Forward declarations
-class IIncidentListener;
-class Incident;
 class IGeoModelTool;
 
 class IGeoModelSvc : virtual public IInterface {
-
 public:
-
     /// Retrieve interface ID
-  static const InterfaceID& interfaceID();
-
+    static const InterfaceID& interfaceID();
 
     virtual const std::string & atlasVersion()         const =0;
     virtual const std::string & inDetVersion()         const =0;
@@ -52,10 +46,6 @@ public:
     
     virtual GeoModel::GeoConfig geoConfig() const = 0;
 
-    // Callback functions
-    virtual StatusCode align       (IOVSVC_CALLBACK_ARGS) = 0;
-    virtual StatusCode compareTags (IOVSVC_CALLBACK_ARGS) = 0;
-
     // Access to subsystem tool for callback registration
     virtual const IGeoModelTool* getTool(std::string toolName) const = 0;
 
diff --git a/DetectorDescription/GeoModel/GeoModelSvc/CMakeLists.txt b/DetectorDescription/GeoModel/GeoModelSvc/CMakeLists.txt
index bffea5f28e1b461fe1aee402b42463b454b51a08..9c7d307c7a8a66ff1298b119d4ada17947f6bb7f 100644
--- a/DetectorDescription/GeoModel/GeoModelSvc/CMakeLists.txt
+++ b/DetectorDescription/GeoModel/GeoModelSvc/CMakeLists.txt
@@ -17,7 +17,7 @@ atlas_add_component( GeoModelSvc
                      src/RDBMaterialManager.cxx
                      src/components/GeoModelSvc_entries.cxx
                      INCLUDE_DIRS ${CORAL_INCLUDE_DIRS} ${GEOMODELCORE_INCLUDE_DIRS}
-                     LINK_LIBRARIES ${CORAL_LIBRARIES} ${GEOMODELCORE_LIBRARIES} AthenaBaseComps AthenaKernel SGTools StoreGateLib SGtests GeoModelUtilities EventInfo GaudiKernel RDBAccessSvcLib EventInfoMgtLib )
+                     LINK_LIBRARIES ${CORAL_LIBRARIES} ${GEOMODELCORE_LIBRARIES} AthenaBaseComps AthenaKernel SGTools StoreGateLib SGtests GeoModelUtilities GaudiKernel RDBAccessSvcLib EventInfoMgtLib )
 
 # Install files from the package:
 atlas_install_joboptions( share/*.py )
diff --git a/DetectorDescription/GeoModel/GeoModelSvc/src/GeoModelSvc.cxx b/DetectorDescription/GeoModel/GeoModelSvc/src/GeoModelSvc.cxx
index 53d089ed73d97dbdaa7f8be650f217eeca1f6558..658cdee9670f6c37406bf1a1c6f97f4c725e036f 100755
--- a/DetectorDescription/GeoModel/GeoModelSvc/src/GeoModelSvc.cxx
+++ b/DetectorDescription/GeoModel/GeoModelSvc/src/GeoModelSvc.cxx
@@ -20,14 +20,13 @@
 #include "RDBAccessSvc/IRDBRecordset.h"
 #include "RDBAccessSvc/IRDBRecord.h"
 
-#include "EventInfo/TagInfo.h"
-
 #include "GeoModelKernel/GeoPerfUtils.h"
 #include <fstream>
 
 #include "AthenaKernel/ClassID_traits.h"
 #include "SGTools/DataProxy.h"
 
+
 GeoModelSvc::GeoModelSvc(const std::string& name,ISvcLocator* svc)
   : AthService(name,svc),
     m_detectorTools(this), 
@@ -103,13 +102,8 @@ StatusCode GeoModelSvc::initialize()
   ToolHandleArray< IGeoModelTool >::iterator itPriv = m_detectorTools.begin(),
     itPrivEnd = m_detectorTools.end();
 
-  // **** **** **** TagInfo **** **** ****
-  std::string tagInfoKey = "";
-
   if(m_useTagInfo) {
-    // get the key
     ATH_CHECK( m_tagInfoMgr.retrieve() );
-    tagInfoKey = m_tagInfoMgr->tagInfoKey();
   }
 
   // build regular geometry
@@ -134,12 +128,6 @@ StatusCode GeoModelSvc::initialize()
     }
   }
   else {
-    // _________________ Align functions NOT registered as callbacks _____________
-
-    // We want to register IGeoModelSvc::align() even if no alignment callback is registered by
-    // subsystem tools, such that clients like CaloTowerBuilder can simply go after IGeoModelSvc::align()
-    bool alignRegistered = false;
-
     // Register align() functions for all Tools 
     for (; itPriv!=itPrivEnd; ++itPriv) {
       IGeoModelTool* theTool = &(**itPriv);
@@ -148,19 +136,10 @@ StatusCode GeoModelSvc::initialize()
 	ATH_MSG_DEBUG("IGeoModelTool::align() was not registerred on CondDB object for the tool " << theTool->name());
       }
       else {
-	if(StatusCode::SUCCESS == m_detStore->regFcn(&IGeoModelTool::align,theTool,
-						      &IGeoModelSvc::align,dynamic_cast<IGeoModelSvc*>(this))) {
-	  ATH_MSG_DEBUG("IGeoModelSvc::align() callback registered for the tool " << theTool->name());
-	  alignRegistered = true;
-
-	  // Set useCaloAlign flag if the successful tool is LAr
-	  if((*itPriv).typeAndName().find("LAr")!=std::string::npos) {
-	      m_useCaloAlign = true;
-	  }
-	}
-	else {
-	  ATH_MSG_DEBUG("Unable to register callback on IGeoModelSvc::align() for the tool " << theTool->name());
-	}
+         // Set useCaloAlign flag if the successful tool is LAr
+         if((*itPriv).typeAndName().find("LAr")!=std::string::npos) {
+            m_useCaloAlign = true;
+         }
       }
     }
 
@@ -178,28 +157,9 @@ StatusCode GeoModelSvc::initialize()
     // Register a callback on TagInfo in order to compare geometry configurations defined in job options
     // to the one read from the input file
     if(m_useTagInfo) {
-      const DataHandle<TagInfo> tagInfoH;
-      if(m_detStore->regFcn(&IGeoModelSvc::compareTags,dynamic_cast<IGeoModelSvc*>(this), tagInfoH, tagInfoKey) != StatusCode::SUCCESS) {
-	ATH_MSG_WARNING("Cannot register compareTags function for key "  << tagInfoKey);
-      }
-      else {
-	ATH_MSG_DEBUG("Registered compareTags callback for key: " << tagInfoKey);
-	
-	if(!alignRegistered) {
-	  // There is no successfull alignment callback registration from subsystems
-	  // Register IGeoModelSvc::align() after IGeoModelSvc::compareTags() then
-	  if(m_detStore->regFcn(&IGeoModelSvc::compareTags,dynamic_cast<IGeoModelSvc*>(this),
-				 &IGeoModelSvc::align,dynamic_cast<IGeoModelSvc*>(this)) == StatusCode::SUCCESS) {
-	    ATH_MSG_DEBUG("Registered IGeoModelSvc::align() after IGeoModelSvc::compareTags()");
-	  }
-	  else {
-	    ATH_MSG_WARNING("Cannot register IGeoModelSvc::align() after IGeoModelSvc::compareTags()");
-	  }
-	}
-      }
-
-      // Fill in the contents of TagInfo
-      ATH_CHECK(fillTagInfo());
+       m_tagInfoMgr->addListener( this );
+       // Fill in the contents of TagInfo
+       ATH_CHECK(fillTagInfo());
     }
   }
 
@@ -208,6 +168,7 @@ StatusCode GeoModelSvc::initialize()
 
 StatusCode GeoModelSvc::finalize()
 {
+  m_tagInfoMgr->removeListener(this);
   return StatusCode::SUCCESS;
 }
 
@@ -374,24 +335,21 @@ StatusCode GeoModelSvc::geoInit()
   return StatusCode::SUCCESS;
 }
 
-StatusCode GeoModelSvc::align(IOVSVC_CALLBACK_ARGS)
+
+void GeoModelSvc::tagInfoUpdated()
 {
-  ATH_MSG_DEBUG("GeoModelSvc::align() called");
-  return StatusCode::SUCCESS;
+  compareTags().ignore();
 }
 
-StatusCode GeoModelSvc::compareTags(IOVSVC_CALLBACK_ARGS)
+
+StatusCode GeoModelSvc::compareTags()
 {
   bool tagsMatch = true;  
 
-  ATH_MSG_DEBUG("GeoModelSvc::compareTags() callback trigerred");
-
-  // Get TagInfo and retrieve tags
-  const TagInfo* tagInfo = 0;
-  ATH_CHECK( m_detStore->retrieve(tagInfo) );
+  ATH_MSG_DEBUG("in compareTags()");
 
-  TagInfo::NameTagPairVec pairs;
-  tagInfo->getInputTags(pairs);
+  // Get tags from TagInfoMgr
+  const ITagInfoMgr::NameTagPairVec pairs = m_tagInfoMgr->getInputTags();
   for( const auto& pair : pairs ) {
     std::string tagPairName = pair.first;
     if(tagPairName=="GeoAtlas") {
diff --git a/DetectorDescription/GeoModel/GeoModelSvc/src/GeoModelSvc.h b/DetectorDescription/GeoModel/GeoModelSvc/src/GeoModelSvc.h
index d4cf73251cd1eafd71911f8d48879561ce73dca6..40be6a51c67e055926a2947f5b7a40e33853ec05 100755
--- a/DetectorDescription/GeoModel/GeoModelSvc/src/GeoModelSvc.h
+++ b/DetectorDescription/GeoModel/GeoModelSvc/src/GeoModelSvc.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef GEOMODELSVC_GEOMODELSVC_H
@@ -22,8 +22,9 @@ class ISvcLocator;
 
 template <class TYPE> class SvcFactory;
 
-class GeoModelSvc : public AthService, virtual public IGeoModelSvc {
-
+class GeoModelSvc : public AthService, virtual public IGeoModelSvc,
+                    virtual public ITagInfoMgr::Listener
+{
 public:
 
     virtual StatusCode initialize();
@@ -36,8 +37,10 @@ public:
     // N.B. Don't forget to release the interface after use!!!
     virtual StatusCode queryInterface( const InterfaceID& riid, void** ppvInterface );
 
-    virtual StatusCode align        (IOVSVC_CALLBACK_ARGS);
-    virtual StatusCode compareTags  (IOVSVC_CALLBACK_ARGS);
+    /// Callback from TagInfoMgr on TagInfo change
+    virtual void       tagInfoUpdated() override final;
+
+    StatusCode compareTags();
 
     virtual const IGeoModelTool* getTool(std::string toolName) const;
 
@@ -127,3 +130,4 @@ private:
 };
 
 #endif // GEOMODELSVC_GEOMODELSVC_H
+
diff --git a/Event/ByteStreamCnvSvc/test/AtlCopyBSEvent.cxx b/Event/ByteStreamCnvSvc/test/AtlCopyBSEvent.cxx
index d7a84c2507e71f66d942dfd544bffa6153713fa5..462be7a87eb5deab2c24e613d9ad350f6811e756 100644
--- a/Event/ByteStreamCnvSvc/test/AtlCopyBSEvent.cxx
+++ b/Event/ByteStreamCnvSvc/test/AtlCopyBSEvent.cxx
@@ -15,7 +15,6 @@
 #include <memory>
 #include <string>
 #include <fstream>
-#include <sstream>
 #include <vector>
 #include <algorithm>
 
diff --git a/Event/ByteStreamCnvSvcLegacy/src/offline_EventStorage/v5_ESCompression.h b/Event/ByteStreamCnvSvcLegacy/src/offline_EventStorage/v5_ESCompression.h
index 36d8eb17e7108a2b7e9628b8621258a0620d45af..19e7117428a5296278b698d3f71fc9684d0f2675 100644
--- a/Event/ByteStreamCnvSvcLegacy/src/offline_EventStorage/v5_ESCompression.h
+++ b/Event/ByteStreamCnvSvcLegacy/src/offline_EventStorage/v5_ESCompression.h
@@ -11,7 +11,6 @@
 #include <string>
 #include <sys/uio.h>
 #include "ers/ers.h"
-#include <string>
 
 #include "ByteStreamCnvSvcLegacy/offline_EventStorage/v5_EventStorageRecords.h"
 
diff --git a/Event/EventContainers/src/InternalOnline.cxx b/Event/EventContainers/src/InternalOnline.cxx
index 40754f370dd682beb9e65ead0a2d890ec25e35e1..fa7498764e82c93a8f9641b4a170a30e60b4fc3d 100644
--- a/Event/EventContainers/src/InternalOnline.cxx
+++ b/Event/EventContainers/src/InternalOnline.cxx
@@ -7,7 +7,6 @@
 #include "EventContainers/IDC_WriteHandleBase.h"
 #include "CxxUtils/AthUnlikelyMacros.h"
 #include "EventContainers/IdentifiableCacheBase.h"
-#include "CxxUtils/AthUnlikelyMacros.h"
 
 using namespace EventContainers;
 typedef I_InternalIDC::InternalConstItr InternalConstItr;
diff --git a/Event/EventInfoMgt/EventInfoMgt/ITagInfoMgr.h b/Event/EventInfoMgt/EventInfoMgt/ITagInfoMgr.h
index 1c49d0d24615cc06a808a780853562313a2b335c..2ef96dbb3134cdb9feddacfa0cab07ba6f4c96b1 100755
--- a/Event/EventInfoMgt/EventInfoMgt/ITagInfoMgr.h
+++ b/Event/EventInfoMgt/EventInfoMgt/ITagInfoMgr.h
@@ -8,20 +8,16 @@
  * @file TagInfoMgr.h
  *
  * @brief This is a Athena service which manages detector description
- *  tag information. It maintains a TagInfo object in the Detector
- *  Store with current tag values. 
+ *  tag information. It maintains a private TagInfo object 
  *
  * @author RD Schaffer <R.D.Schaffer@cern.ch>
  */
 
 //<<<<<< INCLUDES                                                       >>>>>>
 
-#include "AthenaKernel/IOVSvcDefs.h"
 #include "GaudiKernel/Service.h"
-#include "GaudiKernel/IIncidentListener.h"
-#include "AthenaKernel/IAddressProvider.h"
-#include "AthenaKernel/IOVSvcDefs.h"
 
+class MsgStream;
 
 //<<<<<< CLASS DECLARATIONS                                             >>>>>>
 
@@ -29,8 +25,7 @@
  * @class ITagInfoMgr
  *
  * @brief This is a Athena service which manages detector description
- *  tag information. It maintains a TagInfo object in the Detector
- *  Store with current tag values. 
+ *  tag information. It maintains a TagInfo object with current tag values.
  *
  *  The tags to fill the TagInfo object may come from a variety of
  *  sources: i.e. the tags specified by the GeoModelSvc and IOVDbSvc,
@@ -52,14 +47,11 @@
  *  Some clients need to know when detector description tags change
  *  so that they may update their descriptions, such as the geometry
  *  description. The TagInfo object will change in this case. So
- *  clients that need to know when tags change should set up a
- *  callback to the TagInfo object. This is done with regFcn of the
- *  StoreGate service (for the DetectorStore). The method 
- *
- *  virtual std::string& tagInfoKey() = 0;
- *
- *  provides access to the SG key of TagInfo which is needed to
- *  register a data handle for the callback.
+ *  clients that need to know when tags change should register themselves
+ *  by calling ITagInfoMgr::addListener(listener*) method.
+ *  These clients need to implement the ITagInfoMgr::Listener interface and
+ *  ITagInfoMgr::Listener::tagInfoUpdated() method which will be called
+ *  when the TagInfo changes.
  *
  */
 class ITagInfoMgr : virtual public IInterface
@@ -71,6 +63,21 @@ public:
     typedef     std::vector<NameTagPair>             NameTagPairVec;
     //@}
 
+
+    /// Listener interface class that client who want to be notified about TagInfo
+    /// update should implement (and then register themselves calliing addListener())
+    class Listener {
+    public:
+       virtual void tagInfoUpdated() = 0;
+    };
+
+    /// Add a Listener to the notification list for TagInfo changes
+    virtual void              addListener(Listener* listener) = 0;
+
+    /// Remove a Listener from the notification list for TagInfo changes
+    virtual void              removeListener(Listener* listener) = 0;
+      
+
     /// Retrieve interface ID
     static const InterfaceID& interfaceID();
 
@@ -82,20 +89,20 @@ public:
     /// on the input
     virtual StatusCode        removeTagFromInput(const std::string& tagName) = 0;
 
-    /// Method to allow clients to access the TagInfo object key.
-    virtual std::string&      tagInfoKey() = 0;
+    /// Find tag by its name, return by value - empty string if not found
+    virtual std::string       findTag(const std::string & name) const = 0;
 
-    /// callback from IOVSvc - only used as test of callback
-    virtual StatusCode        checkTagInfo(IOVSVC_CALLBACK_ARGS) = 0;
-
-    /// Find tag by name, return by value
-    virtual std::string findTag(const std::string & name) const = 0;
+    /// Find INPUT tag by its name, return by value - empty string if not found
+    virtual std::string       findInputTag(const std::string& name) const = 0;
 
     /// Return a vector with all current input tags
-    virtual NameTagPairVec getInputTags() const = 0;
+    virtual NameTagPairVec    getInputTags() const = 0;
 
     /// Dump the content of the current TagInfo to std::string for debug
-    virtual std::string dumpTagInfoToStr() const = 0;
+    virtual std::string       dumpTagInfoToStr() const = 0;
+
+    /// Printout method
+    virtual void              printTags(MsgStream& log) const = 0;
 };
 
 
diff --git a/Event/EventInfoMgt/python/EventInfoMgtInit.py b/Event/EventInfoMgt/python/EventInfoMgtInit.py
index 6b9e14bbadd08cc4e088d64eb9df836b4419c87c..00bbe16d28b3147c549774e25846c2164bb7742f 100755
--- a/Event/EventInfoMgt/python/EventInfoMgtInit.py
+++ b/Event/EventInfoMgt/python/EventInfoMgtInit.py
@@ -76,18 +76,6 @@ def _loadBasicEventInfoMgt():
     print ("EventInfoMgtInit: Got release version ",release)
     svcMgr.TagInfoMgr.ExtraTagValuePairs = {"AtlasRelease" : release }
 
-    # Add TagInfoMgr as cnv svc
-    from GaudiCommonSvc.GaudiCommonSvcConf import EvtPersistencySvc
-    if not hasattr (svcMgr, 'EventPersistencySvc'):
-        svcMgr += EvtPersistencySvc( "EventPersistencySvc" )
-    svcMgr.EventPersistencySvc.CnvServices += [ "TagInfoMgr" ]
-
-    # Set TagInfoMgr as proxy provider
-    from AthenaCommon.ConfigurableDb import getConfigurable
-    if not hasattr (svcMgr, 'ProxyProviderSvc'):
-        svcMgr += getConfigurable("ProxyProviderSvc")()
-    svcMgr.ProxyProviderSvc.ProviderNames += [ "TagInfoMgr" ]
-
     msg.debug( "Loading basic services for EventInfoMgt... [DONE]" )
     return
 
diff --git a/Event/EventInfoMgt/python/TagInfoMgrConfig.py b/Event/EventInfoMgt/python/TagInfoMgrConfig.py
index 5c2cec609bf1381e1fc03e1590bf114a72bb1b2a..c0c810d80e2eac8deb8cb9ffd1e319fc24e81c50 100644
--- a/Event/EventInfoMgt/python/TagInfoMgrConfig.py
+++ b/Event/EventInfoMgt/python/TagInfoMgrConfig.py
@@ -1,4 +1,4 @@
-# Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 from __future__ import print_function
 from AthenaConfiguration.ComponentFactory import CompFactory
@@ -13,29 +13,18 @@ def TagInfoMgrCfg(configFlags,tagValuePairs={}):
     if not isinstance(tagValuePairs,dict):
         raise ConfigurationError("Parameter extraTagValuePairs is supposed to be a dictionary")
 
-    result=ComponentAccumulator()
-
-    TagInfoMgr=CompFactory.TagInfoMgr
-    ProxyProviderSvc=CompFactory.ProxyProviderSvc
-    EvtPersistencySvc=CompFactory.EvtPersistencySvc
-
     #Build project-version string for the TagInfoMgr 
     project = os.getenv('AtlasProject',"Unknown")
     version = os.getenv('AtlasVersion',"Unknown")     
     atlasRelease=project+"-"+version
-    
 
     tagValuePairs.update({"AtlasRelease" : atlasRelease})
 
+    TagInfoMgr=CompFactory.TagInfoMgr
     tagInfoMgr=TagInfoMgr(ExtraTagValuePairs = tagValuePairs)
+
+    result=ComponentAccumulator()
     result.addService(tagInfoMgr)
-    
-    #Add to EventPersistencySvc 
-    result.addService(EvtPersistencySvc("EventPersistencySvc",CnvServices=[tagInfoMgr.getName(),]))
-    
-    #Add to ProxyProviderSvc
-    result.addService(ProxyProviderSvc(ProviderNames=[tagInfoMgr.getName(),]))
-                       
     return result,tagInfoMgr
     
 if __name__ == "__main__":
diff --git a/Event/EventInfoMgt/src/TagInfoMgr.cxx b/Event/EventInfoMgt/src/TagInfoMgr.cxx
index 938e8bd9e709e7107f2a2145b86a693004046e59..810f14348025f146bbe56317569dc48ebd1b0af4 100755
--- a/Event/EventInfoMgt/src/TagInfoMgr.cxx
+++ b/Event/EventInfoMgt/src/TagInfoMgr.cxx
@@ -18,7 +18,6 @@
 #include "EventInfo/EventID.h"
 #include "EventInfo/EventInfo.h"
 #include "EventInfo/EventType.h"
-#include "EventInfo/TriggerInfo.h"
 
 #include "EventInfoUtils/EventIDFromStore.h"
 
@@ -30,25 +29,22 @@
 #include "AthenaKernel/IIOVSvc.h"
 #include "AthenaKernel/IOVTime.h"
 #include "AthenaKernel/IOVRange.h"
-#include "SGTools/TransientAddress.h"
 #include "AthenaPoolUtilities/CondAttrListCollection.h"
 #include "AthenaPoolUtilities/CondAttrListCollAddress.h"
-#include "IOVDbMetaDataTools/IIOVDbMetaDataTool.h"
 #include "AthenaKernel/ExtendedEventContext.h"
 
 // Gaudi includes
 #include "GaudiKernel/IIncidentSvc.h"
-#include "GaudiKernel/IOpaqueAddress.h"
-#include "GaudiKernel/GenericAddress.h"
 #include "GaudiKernel/GaudiException.h"
 
-// External definitions
-long TagInfoMgr_StorageType = 0x50;
+
+const std::string IOVCbkObjKey( "TagInfoMgrIOVCBKKey" );
+
 
 // Constructor with parameters:
 TagInfoMgr::TagInfoMgr(const std::string &name, 
                        ISvcLocator *pSvcLocator) :
-    AthCnvSvc(name, pSvcLocator, TagInfoMgr_StorageType)
+    AthService(name, pSvcLocator)
 {}
 
 TagInfoMgr::~TagInfoMgr() 
@@ -67,60 +63,19 @@ TagInfoMgr::queryInterface( const InterfaceID& riid, void** ppvInterface )
     }
     else {
         // Interface is not directly available: try out a base class
-        return(::AthCnvSvc::queryInterface(riid, ppvInterface));
+        return(::AthService::queryInterface(riid, ppvInterface));
     }
 
     return StatusCode::SUCCESS;
 }
 
-/// Method to allow clients add in tags as: tag name, tag value
-StatusCode
-TagInfoMgr::addTag(const std::string& tagName, 
-                   const std::string& tagValue) 
-{
-    // Add name/value to input vector
-    ATH_MSG_DEBUG("addTag - adding name/value pairs: " 
-          << tagName << " " << tagValue);
-
-    //FIXME: Add a mutex here! 
-    m_extraTagValuePairsViaInterface[tagName]=tagValue;
-    return StatusCode::SUCCESS;
-}
-
-/// Method to allow clients to remove a tag which may have come in on
-/// the input
-StatusCode  
-TagInfoMgr::removeTagFromInput(const std::string& tagName) 
-{
-    // Add name/value to input vector
-    ATH_MSG_DEBUG( "removeTagFromInput - adding tag name to be removed: " 
-          << tagName);
-    m_tagsToBeRemoved.insert(tagName);
-    return StatusCode::SUCCESS;
-}
-
-    
-
-/// Method to allow clients to access the TagInfo object key.
-std::string&
-TagInfoMgr::tagInfoKey()
-{
-    return (m_tagInfoKeyValue);
-}
-
 // Initialize method:
 StatusCode TagInfoMgr::initialize()
 {
-    // Must first initialize base class
-    if(!(AthCnvSvc::initialize()).isSuccess()) return StatusCode::FAILURE;
-
-    // Get the key value
-    m_tagInfoKeyValue = m_tagInfoKey.value();
+    ATH_CHECK( AthService::initialize() );
 
     // Get the messaging service, print where you are
     ATH_MSG_DEBUG( "initialize()");
-    ATH_MSG_DEBUG( "OverrideEventInfoTags   " << m_overrideEventInfoTags);
-    ATH_MSG_DEBUG( "TagInfoKey              " << m_tagInfoKey);
     
     if (msgLvl(MSG::DEBUG)) {
         ATH_MSG_DEBUG( "ExtraTagValuePairs " );
@@ -132,11 +87,10 @@ StatusCode TagInfoMgr::initialize()
     // To copy TagInfo to EventInfo, we set listener to the
     // IncidentSvc for BeginRun and BeginInputFile
     ServiceHandle<IIncidentSvc> incSvc("IncidentSvc", name());
-    long int pri=1000;
 
     // Add BeginRun to trigger tag extraction and writing to output
     // file meta data
-    incSvc->addListener( this, "BeginRun", pri);
+    incSvc->addListener( this, "BeginRun", 100);
 
     // Add BeginInputFile to trigger refilling meta data store after a new input file - priority has
     // to be < 50 to be run after IOVDbMetaDataTool (triggered by MetaDataSvc), which has mergeing
@@ -156,8 +110,7 @@ StatusCode TagInfoMgr::start()
     // meta data
     if (m_detStore->contains<CondAttrListCollection>("/TagInfo")) { 
         const DataHandle<CondAttrListCollection> tagInfoH;
-        if (m_detStore->regFcn(&ITagInfoMgr::checkTagInfo, 
-                               dynamic_cast<ITagInfoMgr*>(this), 
+        if (m_detStore->regFcn(&TagInfoMgr::checkTagInfo, this,
                                tagInfoH, "/TagInfo").isSuccess()) {
           ATH_MSG_DEBUG( "Registered checkTagInfo callback for  /TagInfo ");
         }
@@ -178,7 +131,7 @@ StatusCode TagInfoMgr::finalize()
 }
 
 StatusCode 
-TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond, TagInfo* tagInfo) const
+TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond)
 {
 
     // Fill tag info
@@ -195,6 +148,8 @@ TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond, TagInfo* tagI
 
     // Get the messaging service, print where you are
     ATH_MSG_DEBUG( "fillTagInfo: ");
+    // clear existing tags
+    m_tagInfo = TagInfo();
 
     // Add tags to TagInfo
 
@@ -221,7 +176,7 @@ TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond, TagInfo* tagI
                 // First make sure that this tag name is not on the
                 // list of those to be removed
                 if (m_tagsToBeRemoved.find(name) == m_tagsToBeRemoved.end()) {
-                    if (tagInfo->addTag(EventType::NameTagPair(name, value)).isFailure()) {
+                    if (m_tagInfo.addTag(EventType::NameTagPair(name, value)).isFailure()) {
                         ATH_MSG_WARNING( "fillTagInfo: Unable to add value/tag to TagInfo " 
                               << name << " " << value);
                     }
@@ -238,7 +193,7 @@ TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond, TagInfo* tagI
                 // be the "first ones in" and there should not be any
                 // clash with existing tags. Return WARNING if this
                 // happens
-                if (tagInfo->addInputTag(EventType::NameTagPair(name, value)).isFailure()) {
+                if (m_tagInfo.addInputTag(EventType::NameTagPair(name, value)).isFailure()) {
                     ATH_MSG_WARNING( "fillTagInfo: Unable to add value/tag to TagInfo as input tag " 
                           << name << " " << value);
                 }
@@ -307,7 +262,7 @@ TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond, TagInfo* tagI
                 // list of those to be removed
                 std::string& name = pairs1[i].first;
                 if (m_tagsToBeRemoved.find(name) == m_tagsToBeRemoved.end()) {
-                    if (tagInfo->addTag(pairs1[i]).isFailure()) {
+                    if (m_tagInfo.addTag(pairs1[i]).isFailure()) {
                         ATH_MSG_ERROR( "fillTagInfo: Unable to add tag to TagInfo: name/tag " 
                               << pairs1[i].first << " : "
                               << pairs1[i].second);
@@ -326,7 +281,7 @@ TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond, TagInfo* tagI
                 // Assumption is that EventInfo tags should be the
                 // "first ones in" and there should not be any clash
                 // with existing tags. Return ERROR if this happens
-                if (tagInfo->addInputTag(pairs1[i]).isFailure()) {
+                if (m_tagInfo.addInputTag(pairs1[i]).isFailure()) {
                     ATH_MSG_ERROR( "fillTagInfo: Unable to add input tag to TagInfo: name/tag " 
                         << pairs1[i].first << " : "
                         << pairs1[i].second);
@@ -340,11 +295,11 @@ TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond, TagInfo* tagI
     
     // Dump out contents of TagInfo
     ATH_MSG_DEBUG( "fillTagInfo: print out tags before adding extra tags");
-    ATH_MSG_DEBUG(tagInfo->str());
+    ATH_MSG_DEBUG(m_tagInfo.str());
 
 
     // Add in any extra tag value pairs if specified
-    std::map<std::string,std::string> valueTagPairs(m_extraTagValuePairs);//Copy (not sure why)
+    std::map<std::string,std::string> valueTagPairs(m_extraTagValuePairs);
     // Add in pairs from interface
     for (auto & tv : m_extraTagValuePairsViaInterface) {
       valueTagPairs[tv.first]=tv.second;
@@ -352,15 +307,14 @@ TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond, TagInfo* tagI
 
     for (auto& tv : valueTagPairs) {
       ATH_MSG_DEBUG( "fillTagInfo: Adding extra value/tag pair: " << tv.first << " " << tv.second);
-      if (tagInfo->addTag(EventType::NameTagPair(tv.first,tv.second),
-			  m_overrideEventInfoTags).isFailure()) {
+      if (m_tagInfo.addTag(EventType::NameTagPair(tv.first,tv.second), true).isFailure()) {
 	ATH_MSG_WARNING( "fillTagInfo: Extra value/tag not added to TagInfo ");
       }
     }
 
     // Dump out contents of TagInfo
     ATH_MSG_DEBUG( "fillTagInfo: print out tags");
-    ATH_MSG_DEBUG(tagInfo->str());
+    ATH_MSG_DEBUG(m_tagInfo.str());
     
     return StatusCode::SUCCESS;
 
@@ -368,7 +322,7 @@ TagInfoMgr::fillTagInfo(const CondAttrListCollection* tagInfoCond, TagInfo* tagI
 
 
 StatusCode
-TagInfoMgr::fillMetaData   (const TagInfo* tagInfo, const CondAttrListCollection* tagInfoCond) 
+TagInfoMgr::fillMetaData(const CondAttrListCollection* tagInfoCond)
 {
     // fillMetaData is called at the beginning of the job and for each
     // new file being read in.
@@ -410,7 +364,7 @@ TagInfoMgr::fillMetaData   (const TagInfo* tagInfo, const CondAttrListCollection
     // Copy tags to AttributeList
     coral::AttributeList attrList;
     EventType::NameTagPairVec pairs;
-    tagInfo->getTags(pairs);
+    m_tagInfo.getTags(pairs);
     ATH_MSG_DEBUG( "fillMetaData: Adding value/tag pairs to file meta data: ");
     for (unsigned int i = 0; i < pairs.size(); ++i) {
         attrList.extend(pairs[i].first, "string");
@@ -435,8 +389,9 @@ TagInfoMgr::fillMetaData   (const TagInfo* tagInfo, const CondAttrListCollection
             IOVRange minRange = tagInfoCond->minRange();
             start = minRange.start();
             stop  = minRange.stop();
+            ATH_MSG_DEBUG( "IOV minRange from IOVMetaData: " << tagInfoCond->minRange());
             m_lastIOVRange = IOVRange(start, stop);
-            isFirstIOVCheck = true; // 
+            isFirstIOVCheck = true;
         }
         if (m_lastIOVRange.isInRange(testTime)) {
             // set start to runNumber after the 
@@ -551,11 +506,6 @@ TagInfoMgr::handle(const Incident& inc) {
     **      The member m_currentRun is saved to be used for the IOV 
     **      in fillMetaData.
     **
-    **      Note: the detector store 'retrieve' of the TagInfo will call 
-    **      TagInfoMgr::createObj to do the first creation and filling it 
-    **      accordingly. And this also fills the output file metadata with 
-    **      contents of the TagInfo object.
-    **                
     **   2) Then whenever a new file is opened (BeginInputFile), we
     **      use the TagInfo object from the detector store to "re-fill"
     **      and overwrite the newly merged TagInfo meta data in the output
@@ -574,37 +524,34 @@ TagInfoMgr::handle(const Incident& inc) {
     ATH_MSG_DEBUG( "handle: entering handle(), incidence type " << inc.type()
           << " from " << inc.source());
 
-    // Return quickly for BeginEvent if not needed
-    if (!m_isFirstBeginRun && inc.type() ==  IncidentType::BeginEvent) return;
+    const EventIDBase eventID =  inc.context().eventID();
 
-    
-    // At first BeginRun we retrieve TagInfo and trigger IOVDbSvc to
-    // use it
-    if (inc.type() == IncidentType::BeginRun && m_isFirstBeginRun) {
+    if (inc.type() == IncidentType::BeginRun) {
+       // For begin run, reset the current run number
 
-        // No longer first BeginRun 
-        m_isFirstBeginRun = false; 
+       // get conditionsRun from the Context - can be used if no EventID in the SG (for HLT)
+       m_conditionsRun = Atlas::getExtendedEventContext(inc.context()).conditionsRun();
 
-        // get conditionsRun from the Context - can be used if no EventID in the SG (for HLT) 
-        m_conditionsRun = Atlas::getExtendedEventContext(inc.context()).conditionsRun();
+       // Set current run number to be used for fillMetaData
+       m_currentRun = eventID.run_number();
 
-        // Print out EventInfo
-        // can't use a ref here!
-        const EventIDBase eventID =  inc.context().eventID();
+       ATH_MSG_DEBUG( "handle: BeginRun incident - Event ID: ["
+                      << eventID.run_number()   << ","
+                      << eventID.lumi_block() << ":"
+                      << eventID.time_stamp() << "] ");
+       if( m_conditionsRun != EventIDBase::UNDEFNUM ) {
+          ATH_MSG_DEBUG( "handle: conditionsRun = " << m_conditionsRun);
+       }
+       if( m_currentRun != EventIDBase::UNDEFNUM ) {
+          ATH_MSG_DEBUG( "handle: currentRun = " << m_currentRun);
+       }
+    }
 
-        // Set current run number to be used for fillMetaData
-        m_currentRun = eventID.run_number();
-        
-        ATH_MSG_DEBUG( "handle: First BeginRun incident - Event ID: ["
-                       << eventID.run_number()   << ","
-                       << eventID.lumi_block() << ":"
-                       << eventID.time_stamp() << "] ");
-        if( m_conditionsRun != EventIDBase::UNDEFNUM ) {
-            ATH_MSG_DEBUG( "handle: conditionsRun = " << m_conditionsRun);
-        }
-        if( m_currentRun != EventIDBase::UNDEFNUM ) {
-            ATH_MSG_DEBUG( "handle: currentRun = " << m_currentRun);
-        }
+    // At first BeginRun we retrieve TagInfo and trigger IOVDbSvc to use it
+    if (inc.type() == IncidentType::BeginRun && m_isFirstBeginRun) {
+
+        // No longer first BeginRun 
+        m_isFirstBeginRun = false; 
 
         // For the moment, we must set IOVDbSvc into the BeginRun
         // state to be able to access TagInfo from the file meta data
@@ -620,261 +567,85 @@ TagInfoMgr::handle(const Incident& inc) {
         nsTime         += eventID.time_stamp_ns_offset();
         curTime.setTimestamp(nsTime);
 
-        if (StatusCode::SUCCESS != m_iovDbSvc->signalBeginRun(curTime,
-                                                              inc.context()))
+        if (StatusCode::SUCCESS != m_iovDbSvc->signalBeginRun(curTime, inc.context()))
         {
             ATH_MSG_ERROR( "Unable to signal begin run to IOVDbSvc");
             throw GaudiException( "Unable to signal begin run to IOVDbSvc", "TagInfoMgr::handle", StatusCode::FAILURE );
         }
         ATH_MSG_DEBUG( "Signaled begin run to IOVDbSvc " << curTime);
         
+        // For BeginRun, update TagInfo
+        if( updateTagInfo().isFailure() ) {
+           throw GaudiException( "updateTagInfo ERROR:", "TagInfoMgr::handle", StatusCode::FAILURE );
+        }
 
-        ATH_MSG_DEBUG( "Retrieve tag info ");
-
-        // For BeginRun, retrieve and fill TagInfo 
-        const TagInfo* tagInfo = 0;
-        if (m_detStore->retrieve( tagInfo, m_tagInfoKeyValue ).isFailure() ) {
-            ATH_MSG_DEBUG( "handle:   Could not retrieve TagInfo object from the detector store on first try.");      
             // May have pre-existing TagInfo with incorrect IOV
             // range. Try dropping and retrieving again.
-            bool sc = m_iovDbSvc->dropObject("/TagInfo");
-            ATH_MSG_DEBUG( "handle:   Try dropping /TagInfo - " << sc);      
-            if (m_detStore->retrieve( tagInfo, m_tagInfoKeyValue ).isFailure() ) {
-                ATH_MSG_ERROR( "handle:   Could not retrieve TagInfo object from the detector store");      
-                return;
-            }
-        }
-        ATH_MSG_DEBUG( "Retrieved tag info ");
+            //    bool sc = m_iovDbSvc->dropObject("/TagInfo");  //MN: No idea what that was supposed to do
 
 	// Process TagInfo by IOVDbSvc
         if (m_iovDbSvc->processTagInfo().isFailure() ) {
-            ATH_MSG_ERROR( "handle: Unable process TagInfo by IOVDbSvc");
-        }
-        else {
-            ATH_MSG_DEBUG( "handle: TagInfo successfully processed by IOVDbSvc to register callback");
+           throw GaudiException( "iovDbSvc::processTagInfo ERROR", "TagInfoMgr::handle", StatusCode::FAILURE );
         }
+        ATH_MSG_DEBUG( "handle: TagInfo successfully processed by IOVDbSvc to register callback");
     }
     else if ((inc.type() == IncidentType::BeginInputFile || inc.type() == IncidentType::BeginRun)
-             && !m_isFirstBeginRun) {
-
-        // For a new file incident or a subsequent begin run incident, we must "refill" the meta
-        // data store with the current value of the TagInfo folder in the detector store.
-
-        if (inc.type() == IncidentType::BeginRun) {
-            
-            // For begin run, reset the current run number
-        
-            // get conditionsRun from the Context - can be used if no EventID in the SG (for HLT) 
-            m_conditionsRun = Atlas::getExtendedEventContext(inc.context()).conditionsRun();
-
-            // Get current run number
-            const EventIDBase eventID =  inc.context().eventID();
-
-            // Set current run number to be used for fillMetaData
-            m_currentRun = eventID.run_number();
-        
-            ATH_MSG_DEBUG( "handle: secondary BeginRun incident - Event ID: ["
-                           << eventID.run_number()   << ","
-                           << eventID.lumi_block() << ":"
-                           << eventID.time_stamp() << "] ");
-            if( m_conditionsRun != EventIDBase::UNDEFNUM ) {
-                ATH_MSG_DEBUG( "handle: conditionsRun = " << m_conditionsRun);
-            }
-            if( m_currentRun != EventIDBase::UNDEFNUM ) {
-                ATH_MSG_DEBUG( "handle: currentRun = " << m_currentRun);
-            }
-        }
-        
-        
-        // Return if /TagInfo does NOT exists
-        const CondAttrListCollection* attrListColl = 0;
-        if (m_detStore->contains<CondAttrListCollection>("/TagInfo")) { 
-            if (m_detStore->retrieve( attrListColl, "/TagInfo" ).isFailure() ) {
-                ATH_MSG_ERROR( "handle - " << inc.type() << ": No TagInfo meta data in DetectorStore");
-                std::string excStr { inc.type() + " - No TagInfo meta data in DetectorStore" };
-                throw GaudiException( excStr , "TagInfoMgr::handle", StatusCode::FAILURE );
-            }
-            else {
-                ATH_MSG_DEBUG( "handle - " << inc.type() << ": Retrieved TagInfo meta data from detStore");
-            } 
-        }
-        else {
-            ATH_MSG_DEBUG( "handle - " << inc.type() << ": det store does NOT contain AttrListColl for TagInfo"); 
-            return;
-        }
-
-        const TagInfo* tagInfo = 0;
-        if (m_detStore->retrieve( tagInfo, m_tagInfoKeyValue ).isFailure() ) {
-            ATH_MSG_ERROR( "handle - " << inc.type() << ": Could not retrieve TagInfo object from the detector store");
-            std::string excStr { inc.type() + " - Could not retrieve TagInfo object from the detector store" };
-            throw GaudiException( excStr, "TagInfoMgr::handle", StatusCode::FAILURE );
-        }
-
-        // Copy TagInfo to meta data store for writing to file meta data
-        if (StatusCode::SUCCESS != fillMetaData(tagInfo, attrListColl)) {
-            ATH_MSG_ERROR( "handle - " << inc.type() << ": Unable to write TagInfo to MetaDataStore !");
-            std::string excStr { inc.type() + " - Unable to write TagInfo to MetaDataStore !" };
-            throw GaudiException( excStr, "TagInfoMgr::handle", StatusCode::FAILURE );
-        } 
-        else {
-            ATH_MSG_DEBUG( "handle - " << inc.type() << ": Wrote TagInfo to MetaDataStore ");
-        }
+             && !m_isFirstBeginRun)
+    {
+       // For a new file incident or a subsequent begin run incident, we must "refill" the meta
+       // data store with the current value of the TagInfo folder in the detector store.
+       if( updateTagInfo().isFailure() ) {
+          throw GaudiException( "updateTagInfo ERROR:", "TagInfoMgr::handle", StatusCode::FAILURE );
+       }
     }
 }
 
-
+//______________________________________________________________________________
 StatusCode
 TagInfoMgr::checkTagInfo(IOVSVC_CALLBACK_ARGS)
 {
     // The conditions object in file meta data has change so we need
     // to reset the TagInfo object in the detector store.
     //
-    // To do so, we retrieve the TagInfo object proxy, reset it to
-    // delete the current TagInfo object, and then retrieve the
-    // TagInfo object to assure that it is recreated with the
-    // information coming from both the file meta data and the
-    // job-specific overrides.
-    //
-    ATH_MSG_DEBUG( "checkTagInfo: entering checkTagInfo");
-
-    // Retrieve and save the contents of the TagInfo object in case
-    // file meta data is empty, then the saved contents will be reused
-    // and a new IOV assigned.
-    const TagInfo* tagInfo = 0;
-    if (m_detStore->retrieve( tagInfo, m_tagInfoKeyValue ).isFailure() ) {
-        ATH_MSG_ERROR( "checkTagInfo: Could not retrieve TagInfo object from the detector store to save the contents ");      
-        return StatusCode::FAILURE;
-    }
-    else {
-        ATH_MSG_DEBUG( "checkTagInfo: retrieved TagInfo to save its contents");
-    }
-    m_lastTagInfo = TagInfo(*tagInfo);
-    ATH_MSG_DEBUG( "checkTagInfo: saved TagInfo contents");
-
-    // Now remove the object in the detector store
-    SG::DataProxy* tagInfoProxy = 
-        m_detStore->proxy( ClassID_traits<TagInfo>::ID(), m_tagInfoKeyValue );
-
-    if (0 == tagInfoProxy) {
-        ATH_MSG_ERROR( "checkTagInfo: Unable to retrieve TagInfo object with clid/key: " 
-              << ClassID_traits<TagInfo>::ID() << " " << m_tagInfoKeyValue);
-        return StatusCode::FAILURE;
-    }
-    // reset and retrieve
-    ATH_MSG_DEBUG( "checkTagInfo: reset TagInfo");
-    tagInfoProxy->reset();
-    tagInfo = 0;
-    if (m_detStore->retrieve( tagInfo, m_tagInfoKeyValue ).isFailure() ) {
-        ATH_MSG_ERROR( "checkTagInfo: Could not retrieve TagInfo object from the detector store");      
-        return StatusCode::FAILURE;
-    }
-    else {
-        ATH_MSG_DEBUG( "checkTagInfo: retrieved TagInfo");
-    }
-    return StatusCode::SUCCESS;
-}
-
-StatusCode 
-TagInfoMgr::preLoadAddresses( StoreID::type storeID,
-                              tadList& tlist )
-{
-    if (storeID == StoreID::DETECTOR_STORE) {
-
-        std::unique_ptr<SG::TransientAddress> tad = 
-          std::make_unique<SG::TransientAddress>( ClassID_traits<TagInfo>::ID(), m_tagInfoKeyValue );
-        IAddressProvider* addp = this;
-        tad->setProvider(addp, storeID);
-        // Get IOpaqueAddress and add to tad
-        IOpaqueAddress* ioa = 0;
-        std::string refAddr(m_tagInfoKeyValue);
-        StatusCode sc = createAddress(TagInfoMgr_StorageType, tad->clID(), refAddr, ioa);
-        if ( sc.isFailure() ) {
-            ATH_MSG_ERROR( "preLoadAddresses: Could not create IOpaqueAddress");      
-            delete ioa;
-            return StatusCode::FAILURE;
-        }
-        tad->setAddress(ioa);
-        // set flag to avoid resetting the ioa when a proxy is reset
-        tad->clearAddress(false);
-        tlist.push_back( tad.release() );
-
-        ATH_MSG_DEBUG( "preLoadAddresses - add transient address for TagInfo to detector store");
-        ATH_MSG_DEBUG( "preLoadAddresses - Found CLID: " << ioa->clID()  
-              << " key from ioa " << *(ioa->par()));
-    }
-    return StatusCode::SUCCESS;
+    ATH_MSG_DEBUG( "checkTagInfo IOV callback");
+    StatusCode sc = updateTagInfo();
+    return sc;
 }
 
-
-StatusCode       
-TagInfoMgr::updateAddress(StoreID::type /*storeID*/, SG::TransientAddress* tad,
-                          const EventContext& /*ctx*/)
+//______________________________________________________________________________
+void
+TagInfoMgr::notifyListeners() const
 {
-    //
-    // Here we do nothing, simply return success for TagInfo
-    //
-    ATH_MSG_VERBOSE( "updateAddress - fill TagInfo");
-    CLID clid        = tad->clID();
-    std::string key  = tad->name();
-  
-    ATH_MSG_VERBOSE( "updateAddress - Found CLID: " << clid << " -  key: " << key);
-    
-    if (clid != ClassID_traits<TagInfo>::ID() || key != m_tagInfoKeyValue) {
-        ATH_MSG_VERBOSE( "updateAddress - Found CLID: " << clid << " -  key: " << key 
-              << " NOT TagInfo - do nothing "
-             );
-        return StatusCode::FAILURE ;
-    }
-    ATH_MSG_VERBOSE( "updateAddress - doing NOTHING, just return success!!");
-
-    return StatusCode::SUCCESS;
+   ATH_MSG_DEBUG( "notifyListeners  (" << m_listeners.size() <<" registered)");
+   for( auto listener : m_listeners ) {
+      listener->tagInfoUpdated();
+   }
 }
 
 //______________________________________________________________________________
 StatusCode 
-TagInfoMgr::createObj(IOpaqueAddress* addr, DataObject*& dataObj) {
+TagInfoMgr::updateTagInfo() {
 
-    // Create new TagInfo object 
+    // Fill the TagInfo object
     //   The tag info may come from either the input file meta data or
     //   the currently available EventInfo object
 
-    ATH_MSG_DEBUG( "createObj: get TagInfo"); 
-
-    // Do checks: 
-    // IOpaqueAddress set?
-    if (addr == 0) {
-        ATH_MSG_ERROR( "createObj: IOpaqueAddress is not set");
-        return(StatusCode::FAILURE);
-    }
-
-    // Correct clid/key?
-    CLID clid              = addr->clID();
-    const std::string& key = *(addr->par());
-    if (clid != ClassID_traits<TagInfo>::ID() || key != m_tagInfoKeyValue) {
-        ATH_MSG_ERROR( "createObj:  Found CLID: " << clid << " -  key: " << key 
-            << " NOT TagInfo - expect: " << ClassID_traits<TagInfo>::ID() << " " 
-            << m_tagInfoKeyValue);
-        return StatusCode::FAILURE ;
-    }
-
-    // Create TagInfo from either incoming conditions for from the
-    // saved TagInfo object
-    std::unique_ptr<TagInfo> tagInfo;
+    ATH_MSG_DEBUG( "updateTagInfo: getting /TagInfo");
 
     // Check whether TagInfo is coming from file meta data or the
     // input event
     const CondAttrListCollection* attrListColl = 0;
     if (m_detStore->contains<CondAttrListCollection>("/TagInfo")) { 
         if (m_detStore->retrieve( attrListColl, "/TagInfo" ).isFailure() ) {
-            ATH_MSG_ERROR( "createObj: No TagInfo meta data in DetectorStore");
+            ATH_MSG_ERROR( "updateTagInfo: No TagInfo meta data in DetectorStore");
             return StatusCode::FAILURE ;
         }
         else {
-            ATH_MSG_DEBUG( "createObj: Retrieved TagInfo meta data from detStore. size " << attrListColl->size());
-        } 
+            ATH_MSG_DEBUG( "updateTagInfo: Retrieved TagInfo meta data from detStore. size " << attrListColl->size());
+        }
     }
     else {
-        ATH_MSG_DEBUG( "createObj: det store does NOT contain AttrListColl for TagInfo"); 
+        ATH_MSG_DEBUG( "updateTagInfo: det store does NOT contain AttrListColl for TagInfo");
     }
 
     // Fill TagInfo from (file meta data) conditions if they exist. If
@@ -882,107 +653,153 @@ TagInfoMgr::createObj(IOpaqueAddress* addr, DataObject*& dataObj) {
     // information. Otherwise we fill from from event info (OLD and
     // most likely not used anymore. RDS 08/2012).
     if (attrListColl && attrListColl->size() == 0) {
-        tagInfo = std::make_unique<TagInfo>(m_lastTagInfo);
-        ATH_MSG_DEBUG( "createObj: recreate tagInfo from saved info"); 
-        ATH_MSG_DEBUG(tagInfo->str());
-    }
-    else {
-        tagInfo = std::make_unique<TagInfo>();
-        if (StatusCode::SUCCESS != fillTagInfo(attrListColl, tagInfo.get())) {
-            ATH_MSG_DEBUG( "createObj: Unable to fill TagInfo !");
-            return StatusCode::FAILURE;
-        } 
-        if (attrListColl) ATH_MSG_DEBUG( "createObj: Filled TagInfo from file meta data ");
-        else ATH_MSG_DEBUG( "createObj: Filled TagInfo from input event ");
+        ATH_MSG_DEBUG( "updateTagInfo: /TagInfo empty - do nothing");
+        ATH_MSG_DEBUG(m_tagInfo.str());
+        return StatusCode::SUCCESS;
     }
+
+    ATH_CHECK( fillTagInfo(attrListColl) );
+    if (attrListColl) ATH_MSG_DEBUG( "updateTagInfo: Filled TagInfo from file meta data ");
+    else ATH_MSG_DEBUG( "updateTagInfo: Filled TagInfo from input event ");
     
     // Copy TagInfo to meta data store for writing to file meta data
-    if (StatusCode::SUCCESS != fillMetaData(tagInfo.get(), attrListColl)) {
-        ATH_MSG_ERROR( "createObj: Unable to write TagInfo to MetaDataStore !");
-        return StatusCode::FAILURE;
-    } 
-    else {
-        ATH_MSG_DEBUG( "createObj: Wrote TagInfo to MetaDataStore ");
-    }
-
-    // Do standard conversion to data object
-    dataObj = SG::asStorable(std::move(tagInfo));
-
-    ATH_MSG_DEBUG( "createObj:  created new TagInfo object ");
+    ATH_CHECK( fillMetaData(attrListColl) );
+    ATH_MSG_DEBUG( "updateTagInfo: Wrote TagInfo to MetaDataStore ");
 
     return StatusCode::SUCCESS;
-
 }
 
-//______________________________________________________________________________
-StatusCode 
-TagInfoMgr::createAddress(long svcType,
-                const CLID& clid,
-                const std::string* par,
-                const unsigned long* ip,
-                IOpaqueAddress*& refpAddress) {
-   return(::AthCnvSvc::createAddress(svcType, clid, par, ip, refpAddress));
-}
 
 //______________________________________________________________________________
-StatusCode 
-TagInfoMgr::convertAddress(const IOpaqueAddress* pAddress,
-                std::string& refAddress) {
-   assert(pAddress);
-   refAddress = *pAddress->par();
-   return(StatusCode::SUCCESS);
+/// Method to allow clients add in tags as: tag name, tag value
+StatusCode
+TagInfoMgr::addTag(const std::string& tagName, const std::string& tagValue)
+{
+    // Add name/value to input vector
+    ATH_MSG_DEBUG("addTag - adding name/value pairs: "
+          << tagName << " " << tagValue);
+
+    //FIXME: Add a mutex here!
+    m_extraTagValuePairsViaInterface[tagName]=tagValue;
+    return StatusCode::SUCCESS;
 }
 
 //______________________________________________________________________________
+/// Method to allow clients to remove a tag which may have come in on
+/// the input
 StatusCode
-TagInfoMgr::createAddress(long svcType,
-                          const CLID& clid,
-                          const std::string& refAddress,
-                          IOpaqueAddress*& refpAddress) {
-    if (svcType != TagInfoMgr_StorageType) {
-        ATH_MSG_ERROR( "createAddress: svcType != TagInfoMgr_StorageType "
-            << svcType
-            << " "
-            << TagInfoMgr_StorageType);
-        return(StatusCode::FAILURE);
-    }
-    refpAddress = new GenericAddress(TagInfoMgr_StorageType, clid, refAddress);
-    return(StatusCode::SUCCESS);
+TagInfoMgr::removeTagFromInput(const std::string& tagName)
+{
+    // Add name/value to input vector
+    ATH_MSG_DEBUG( "removeTagFromInput - adding tag name to be removed: "
+          << tagName);
+    m_tagsToBeRemoved.insert(tagName);
+    return StatusCode::SUCCESS;
 }
 
 //______________________________________________________________________________
 std::string TagInfoMgr::findTag(const std::string & name) const
 {
-   const TagInfo *tagInfo = 0;
    const auto iter = m_extraTagValuePairsViaInterface.find(name);
    if( iter != m_extraTagValuePairsViaInterface.end() ) {
       return iter->second;
    }
-   if( m_detStore->retrieve(tagInfo, m_tagInfoKeyValue).isFailure() ) {
-      return "";
-   }
-   return tagInfo->findTag(name);
+   return m_tagInfo.findTag(name);
+}
+
+//______________________________________________________________________________
+std::string TagInfoMgr::findInputTag(const std::string & name) const
+{
+   return m_tagInfo.findInputTag(name);
 }
 
 //______________________________________________________________________________
 ITagInfoMgr::NameTagPairVec
 TagInfoMgr::getInputTags() const
 {
-   const TagInfo *tagInfo = 0; 
-   if( m_detStore->retrieve(tagInfo, m_tagInfoKeyValue).isFailure() ) {
-      return TagInfo::NameTagPairVec{};
-   }
-   return tagInfo->getInputTags();
+   return m_tagInfo.getInputTags();
 }
 
 //______________________________________________________________________________
 std::string 
 TagInfoMgr::dumpTagInfoToStr() const
 {
-   const TagInfo *tagInfo = 0; 
-   if( m_detStore->retrieve(tagInfo, m_tagInfoKeyValue).isFailure() ) {
-      return "";
+   return m_tagInfo.str();
+}
+
+//______________________________________________________________________________
+void
+TagInfoMgr::printTags(MsgStream& log) const
+{
+   m_tagInfo.printTags(log);
+}
+
+
+StatusCode
+TagInfoMgr::iovCallback(IOVSVC_CALLBACK_ARGS)
+{
+   ATH_MSG_DEBUG( "IOV callback");
+   notifyListeners();
+   return StatusCode::SUCCESS;
+}
+
+//______________________________________________________________________________
+void TagInfoMgr::addListener(Listener* listener)
+{
+   if( not m_detStore->contains<std::string>(IOVCbkObjKey)  ) {
+      ATH_MSG_DEBUG("adding IOV callback object to DetStore");
+      auto alignObj = std::make_unique<std::string>("Geometry aligment callbck trigger object");
+      if( m_detStore->record(std::move(alignObj), IOVCbkObjKey)  != StatusCode::SUCCESS) {
+         ATH_MSG_WARNING("Cannot register IOV callback object with key "  << IOVCbkObjKey);
+      }
+      else {
+         SG::DataProxy *dp =  m_detStore->proxy(ClassID_traits<std::string>::ID(), IOVCbkObjKey);
+         if( dp ) {
+            dp->setProvider(this, StoreID::DETECTOR_STORE);
+
+            const DataHandle<std::string> alignObjH;
+            if(m_detStore->regFcn(&TagInfoMgr::iovCallback, this,
+                                  alignObjH, IOVCbkObjKey) != StatusCode::SUCCESS) {
+               ATH_MSG_WARNING("Cannot register IOV callback for key - TagInfo update notification will not work"  << IOVCbkObjKey);
+            }
+            else {
+               ATH_MSG_DEBUG("Registered IOV callback for TagInfo changes");
+            }
+         } else {
+            ATH_MSG_WARNING("Failed to retrieve "  << IOVCbkObjKey);
+         }
+      }
+   }
+
+   if( m_listeners.find(listener) == m_listeners.end() )
+      m_listeners.insert( listener );
+}
+
+//______________________________________________________________________________
+void TagInfoMgr::removeListener(Listener* listener)
+{
+   m_listeners.erase( listener );
+}
+
+
+
+
+StatusCode 
+TagInfoMgr::preLoadAddresses( StoreID::type storeID, tadList& /*tlist*/ )
+{
+   if (storeID == StoreID::DETECTOR_STORE) {
+      ATH_MSG_DEBUG( "preLoadAddresses - not expected to be called");
    }
-   return tagInfo->str();
+   return StatusCode::SUCCESS;
+}
+
+
+
+StatusCode       
+TagInfoMgr::updateAddress(StoreID::type /*storeID*/, SG::TransientAddress* /*tad*/,
+                          const EventContext& /*ctx*/)
+{
+   ATH_MSG_DEBUG( "updateAddress");
+   return StatusCode::SUCCESS;
 }
 
diff --git a/Event/EventInfoMgt/src/TagInfoMgr.h b/Event/EventInfoMgt/src/TagInfoMgr.h
index 736d6e20860a71882d333657fe9c1836e9c3e40f..0c17cb157235659002b24a07cdf483700fb71805 100755
--- a/Event/EventInfoMgt/src/TagInfoMgr.h
+++ b/Event/EventInfoMgt/src/TagInfoMgr.h
@@ -9,8 +9,7 @@
  * @file TagInfoMgr.h
  *
  * @brief This is a Athena service which manages detector description
- *  tag information. It maintains a TagInfo object in the Detector
- *  Store with current tag values. 
+ *  tag information. It maintains a TagInfo object with current tag values. 
  *
  * @author RD Schaffer <R.D.Schaffer@cern.ch>
  */
@@ -19,19 +18,19 @@
 
 #include "EventInfoMgt/ITagInfoMgr.h"
 #include "AthenaKernel/IOVSvcDefs.h"
-#include "AthenaBaseComps/AthCnvSvc.h"
+#include "AthenaBaseComps/AthService.h"
 #include "GaudiKernel/Service.h"
 #include "GaudiKernel/ServiceHandle.h"
 #include "GaudiKernel/ToolHandle.h"
-#include "GaudiKernel/IIncidentListener.h"
-#include "AthenaKernel/IAddressProvider.h"
 #include "AthenaKernel/IOVRange.h"
 #include "AthenaKernel/IIOVDbSvc.h"
 #include "GaudiKernel/MsgStream.h"
 #include "EventInfo/TagInfo.h"
 #include "IOVDbMetaDataTools/IIOVDbMetaDataTool.h"
+#include "AthenaKernel/IAddressProvider.h"
 
 #include <map>
+#include <set>
 
 //<<<<<< PUBLIC TYPES                                                   >>>>>>
 
@@ -45,7 +44,7 @@ class CondAttrListCollection;
  *
  * @brief This is a Athena service which manages detector description
  *  tag information. It maintains a TagInfo object in the Detector
- *  Store with current tag values. 
+ *  Store with current tag values.
  *
  *  The tags to fill the TagInfo object may come from a variety of
  *  sources: i.e. the tags specified by the GeoModelSvc and IOVDbSvc,
@@ -65,16 +64,11 @@ class CondAttrListCollection;
  *  stream. Currently, the tags are NOT written to the IOV DB via the
  *  TagInfoMgr. 
  *
- *  Some clients need to know when detector description tags change
- *  so that they may update their descriptions, such as the geometry
- *  description. These clients need to set up a callback with the
- *  IOVSvc, as is done below for this class. 
- *
  */
-class TagInfoMgr : public ::AthCnvSvc,
+class TagInfoMgr : virtual public AthService,
                    virtual public ITagInfoMgr,
-                   virtual public IIncidentListener,
-		   virtual public IAddressProvider
+                   virtual public IAddressProvider,
+                   virtual public IIncidentListener
 {
 public:
 
@@ -102,75 +96,55 @@ public:
     /// on the input
     virtual StatusCode   removeTagFromInput(const std::string& tagName) override;
 
-    /// Method to allow clients to access the TagInfo object key.
-    virtual std::string& tagInfoKey() override;
-
     /// callback from IOVSvc - only used as test of callback
-    virtual StatusCode           checkTagInfo(IOVSVC_CALLBACK_ARGS) override;
-    //@}
+    StatusCode           checkTagInfo(IOVSVC_CALLBACK_ARGS);
 
     /// Find tag by name, return by value
-    virtual std::string findTag(const std::string & name) const override final;
+    virtual std::string  findTag(const std::string & name) const override final;
+
+    /// Find tag by its name - for input tags, return by value
+    virtual std::string  findInputTag(const std::string& name) const override final;
 
     /// Return a vector with all current input tags
     virtual NameTagPairVec getInputTags() const override final;
 
     /// Dump the content of the current TagInfo to std::string for debug
-    virtual std::string dumpTagInfoToStr() const override final;
+    virtual std::string  dumpTagInfoToStr() const override final;
+
+    /// Printout method
+    virtual void         printTags(MsgStream& log) const override final;
+
+    /// Add a Listener to the notification list for TagInfo changes
+    virtual void         addListener(Listener* listener) override final;
+
+    /// Remove a Listener from the notification list for TagInfo changes
+    virtual void         removeListener(Listener* listener) override final;
+    //@}
    
     /// @name TagInfo management methods:
     //@{
-    /// Callback at BeginRun and BeginEvent
-    ///   - BeginRun:   fill and regsister TagInfo
-    ///   - BeginEvent: fill EventInfo from TagInfo
-    virtual void handle(const Incident& incident) override;
+    void                 handle(const Incident& incident) override final;
 
-    typedef IAddressProvider::tadList tadList;
-    typedef IAddressProvider::tadListIterator tadListIterator;
-  
-    /// preload the detector store with the transient address for
-    /// TagInfo 
-    virtual StatusCode preLoadAddresses( StoreID::type storeID,
-					 tadList& tlist ) override;
-      
-    ///  Create a TagInfo object and record in storegate
-    virtual StatusCode updateAddress(StoreID::type storeID, SG::TransientAddress* tad,
-                                     const EventContext& ctx) override;
+    /// Update Tags when input tags (/TagInfo in-file metadata) change
+    StatusCode           updateTagInfo();
 
+    /// Notify all listeners that the Tags were updated.
+    void                 notifyListeners() const;
+    /// Callback from IOVSvc used to notifyListeners at the right time 
+    StatusCode           iovCallback(IOVSVC_CALLBACK_ARGS);
 
-    /// Implementation of IConverter: Create the transient representation of an object from persistent state.
-    /// @param pAddress [IN] pointer to IOpaqueAddress of the representation.
-    /// @param refpObject [OUT] pointer to DataObject to be created.
-    virtual StatusCode createObj(IOpaqueAddress* pAddress, DataObject*& refpObject) override;
-
-   /// Create a Generic address using explicit arguments to identify a single object.
-   /// @param svcType [IN] service type of the address.
-   /// @param clid [IN] class id for the address.
-   /// @param par [IN] string containing the database name.
-   /// @param ip [IN] object identifier.
-   /// @param refpAddress [OUT] converted address.
-   virtual StatusCode createAddress(long svcType,
-		   const CLID& clid,
-		   const std::string* par,
-		   const unsigned long* ip,
-		   IOpaqueAddress*& refpAddress) override;
-
-   /// Convert address to string form
-   /// @param pAddress [IN] address to be converted.
-   /// @param refAddress [OUT] converted string form.
-   virtual StatusCode convertAddress(const IOpaqueAddress* pAddress, std::string& refAddress) override;
-
-    /// Create address from string form
-    /// @param svcType [IN] service type of the address.
-    /// @param clid [IN] class id for the address.
-    /// @param refAddress [IN] string form to be converted.
-    /// @param refpAddress [OUT] converted address.
-    virtual StatusCode createAddress(long svcType,
-                                     const CLID& clid,
-                                     const std::string& refAddress,
-                                     IOpaqueAddress*& refpAddress) override;
+    // Fake IAddressProvider interface implementation - allows to make TagInfoMgr
+    // a proxy provider and attach it to an object with an IOV callback
+    // MN: non-functional, hoipefully temporaru
+    using IAddressProvider::tadList, IAddressProvider::tadListIterator;
+
+    virtual StatusCode preLoadAddresses( StoreID::type storeID, tadList& tlist ) override;
+
+    virtual StatusCode updateAddress(StoreID::type storeID, SG::TransientAddress* tad,
+                                     const EventContext& ctx) override;
     //@}
 
+
     ///////////////////////////////////////////////////////////////////
     // Private methods:
     ///////////////////////////////////////////////////////////////////
@@ -192,14 +166,10 @@ private:
 
     /// @name TagInfo management methods:
     //@{
-    StatusCode fillTagInfo    (const CondAttrListCollection* tagInfoCond, TagInfo* tagInfo) const;
-    StatusCode fillMetaData   (const TagInfo* tagInfo, const CondAttrListCollection* tagInfoCond);
+    StatusCode fillTagInfo(const CondAttrListCollection* tagInfoCond);
+    StatusCode fillMetaData(const CondAttrListCollection* tagInfoCond);
     //@}
 
-    /// Flag to add override the tags from EventInfo from other
-    /// sources 
-    Gaudi::Property<bool>   m_overrideEventInfoTags { this, "OverrideEventInfoTags", true, "Override tags yes/no" };
-
     /// Extra tags/values pairs added in my jobOptions
     Gaudi::Property<std::map<std::string,std::string> >
         m_extraTagValuePairs { this, "ExtraTagValuePairs", {}, "key/value pairs to be added", "mapMergeNoReplace<T,T>" };
@@ -210,11 +180,6 @@ private:
     /// Extra tags to be removed
     std::set<std::string>          m_tagsToBeRemoved;
 
-    /// The StoreGate key for the TagInfo
-    Gaudi::Property<std::string>   m_tagInfoKey{ this, "TagInfoKey", "ProcessingTags", "SG key for TagInfo" };
-
-    std::string                    m_tagInfoKeyValue;
-
     /// The event store
     ServiceHandle<StoreGateSvc>    m_storeGate { this, "StoreGateSvc", "StoreGateSvc" };
 
@@ -239,9 +204,11 @@ private:
     /// IOVRange of last TagInfo added to the file meta data
     IOVRange                       m_lastIOVRange { IOVRange(IOVTime(), IOVTime()) };
 
-    /// Last TagInfo added to the detector store
-    TagInfo                        m_lastTagInfo;
+    /// The Tags
+    TagInfo                        m_tagInfo;
 
+    /// List of listeners notified when the TagInfo changed
+    std::set< Listener* >       m_listeners;
 };
 
 
diff --git a/Event/FourMomUtils/FourMomUtils/P4Helpers.h b/Event/FourMomUtils/FourMomUtils/P4Helpers.h
index 4a4402a3f9520be5da81b8ddfb669ccb68716be4..d7ef01a25423350b11769a4564e8362e129d9cdb 100644
--- a/Event/FourMomUtils/FourMomUtils/P4Helpers.h
+++ b/Event/FourMomUtils/FourMomUtils/P4Helpers.h
@@ -37,7 +37,6 @@ namespace P4Helpers
 
 
 // STL includes
-#include <cmath>
 #include <algorithm> // for std::sort
 #include <limits>    // for std::numeric_limits
 
diff --git a/Event/xAOD/xAODCore/xAODCore/ShallowCopy.h b/Event/xAOD/xAODCore/xAODCore/ShallowCopy.h
index b47ba572c78dbf6f4f89e9049e08ba5f818b6c87..ff9dfa596afe148402f3c3aa20ebdf9497bc05ac 100644
--- a/Event/xAOD/xAODCore/xAODCore/ShallowCopy.h
+++ b/Event/xAOD/xAODCore/xAODCore/ShallowCopy.h
@@ -1,7 +1,7 @@
 // Dear emacs, this is -*- c++ -*-
 
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 // $Id: ShallowCopy.h 766390 2016-08-04 11:18:59Z wlampl $
@@ -48,6 +48,10 @@ namespace xAOD {
    /// @returns A pair of pointers to the created objects. The caller takes
    ///          ownership of the created objects
    ///
+   /// Be aware: If CONT has decorations, then the scheduler won't automatically
+   /// known that they are available on the copy.  To make that happen, see
+   /// StoreGate/ShallowCopyDecorDeps.h.
+   ///
    template< class T >
    std::pair< T*, ShallowAuxContainer* > shallowCopyContainer( const T& cont ) {
 
@@ -97,6 +101,10 @@ namespace xAOD {
    /// @returns A pair of pointers to the created objects. The caller takes
    ///          ownership of the created objects
    ///
+   /// Be aware: If CONT has decorations, then the scheduler won't automatically
+   /// known that they are available on the copy.  To make that happen, see
+   /// StoreGate/ShallowCopyDecorDeps.h.
+   ///
    template< class T >
    std::pair< T*, ShallowAuxInfo* > shallowCopyObject( const T& obj ) {
 
diff --git a/Event/xAOD/xAODTracking/xAODTracking/versions/Vertex_v1.h b/Event/xAOD/xAODTracking/xAODTracking/versions/Vertex_v1.h
index d3156ccf94ee6c9cd870d6f2c5f34850e902463e..ee71bebc05ff37e4db2fec7f3cc0288bc72dd527 100644
--- a/Event/xAOD/xAODTracking/xAODTracking/versions/Vertex_v1.h
+++ b/Event/xAOD/xAODTracking/xAODTracking/versions/Vertex_v1.h
@@ -29,9 +29,6 @@
 #include "xAODTracking/NeutralParticleContainer.h"
 #include "xAODBase/ObjectType.h"
 
-// Local include(s):
-#include "xAODTracking/TrackingPrimitives.h"
-
 //MT CachedValue
 #include "CxxUtils/CachedValue.h"
 
diff --git a/ForwardDetectors/ALFA/ALFA_Reconstruction/ALFA_GloRec/src/ALFA_GloRec.cxx b/ForwardDetectors/ALFA/ALFA_Reconstruction/ALFA_GloRec/src/ALFA_GloRec.cxx
index 2dac1d0c7d653f08cbe0539d757bc0f007f093d7..f4f104249c1f53e610c8b81fb6781da50f03a507 100644
--- a/ForwardDetectors/ALFA/ALFA_Reconstruction/ALFA_GloRec/src/ALFA_GloRec.cxx
+++ b/ForwardDetectors/ALFA/ALFA_Reconstruction/ALFA_GloRec/src/ALFA_GloRec.cxx
@@ -342,22 +342,18 @@ StatusCode ALFA_GloRec::Truth_info(){
 
   //loop over collection (container) with hits (i.e. over 1 event)
   for(;mcTruBeg!=mcTruEnd;++mcTruBeg){
-
-    HepMC::GenEvent::particle_const_iterator begGenItr = (**mcTruBeg).particles_begin();
-    HepMC::GenEvent::particle_const_iterator endGenItr = (**mcTruBeg).particles_end();    
    
     //loop over one event
     m_z_g_pos = -1.e10;
     m_z_g_neg =  1.e10;
-    for(int i = 0;begGenItr!=endGenItr;++begGenItr){
- 	  //if(((*begGenItr)->status()==1)&&((abs((*begGenItr)->pdg_id())==2212)||(abs((*begGenItr)->pdg_id())==211))){
-	 		if(((abs((*begGenItr)->pdg_id())==2212)||(abs((*begGenItr)->pdg_id())==211))){
+    for(auto begGen:  (**mcTruBeg)){
+	 		if(((std::abs(begGen->pdg_id())==2212)||(std::abs(begGen->pdg_id())==211))){
 				double px, py, pz;
 				double x, y, z;
-				px = (**begGenItr).momentum().px();	  
-			  py = (**begGenItr).momentum().py();
-				pz = (**begGenItr).momentum().pz();
-				HepMC::GenVertex * l_prodvert = (**begGenItr).production_vertex();
+				px = begGen->momentum().px();	  
+				py = begGen->momentum().py();
+				pz = begGen->momentum().pz();
+				auto  l_prodvert = begGen->production_vertex();
 				x = l_prodvert->position().x();
 				y = l_prodvert->position().y();
 				z = l_prodvert->position().z();
@@ -379,7 +375,6 @@ StatusCode ALFA_GloRec::Truth_info(){
 					continue;							
 				}
 		
-			  i++;
 			  // ... break the loop if both suitable vertices were found
 			  if (m_z_g_pos > 0. && m_z_g_neg < 0.){
 				msg(MSG::DEBUG) << "gen px, py, pz = " << m_px_g_pos <<  "  " << m_py_g_pos << "  " << m_pz_g_pos << endmsg;
diff --git a/ForwardDetectors/LUCID/LUCID_Monitoring/share/args.ESDtoAOD.lucid.py b/ForwardDetectors/LUCID/LUCID_Monitoring/share/args.ESDtoAOD.lucid.py
index a92cb9ab1db321dc3f7453c6adebb301ec81c5aa..be7ea706f4997515105765b9291d0422953c3bd0 100755
--- a/ForwardDetectors/LUCID/LUCID_Monitoring/share/args.ESDtoAOD.lucid.py
+++ b/ForwardDetectors/LUCID/LUCID_Monitoring/share/args.ESDtoAOD.lucid.py
@@ -21,7 +21,7 @@ runArgs.maxEvents = -1
 
 runArgs.inputESDFile = ['myESD.pool.root']
 
-runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCommission/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py', 'RecJobTransforms/debugConfig.py']
+runArgs.preInclude = ['RecExCommon/RecoUsefulFlags.py', 'RecExCond/MinimalCommissioningSetup.py', 'RecJobTransforms/UseOracle.py', 'RecJobTransforms/debugConfig.py']
 
 runArgs.outputAODFile = 'myAOD.pool.root'
 
diff --git a/Generators/AtlasHepMC/AtlasHepMC/Flow.h b/Generators/AtlasHepMC/AtlasHepMC/Flow.h
index 1aee5c176b48c6264f8f21e8a7f756c4c4262624..f54e9acdf9cc8b00d425f55b860f6c91f073e4c2 100644
--- a/Generators/AtlasHepMC/AtlasHepMC/Flow.h
+++ b/Generators/AtlasHepMC/AtlasHepMC/Flow.h
@@ -8,48 +8,44 @@
 #ifdef HEPMC3
 #include "HepMC3/Attribute.h"
 #include "HepMC3/GenParticle.h"
-namespace HepMC
-{
+namespace HepMC {
 typedef std::shared_ptr<HepMC3::VectorIntAttribute> Flow;
-inline int flow(HepMC3::GenParticlePtr p, int i){
-std::shared_ptr<HepMC3::IntAttribute> f=p->attribute<HepMC3::IntAttribute>("flow"+std::to_string(i));  if (f) return f->value(); 
-std::shared_ptr<HepMC3::VectorIntAttribute> vf=p->attribute<HepMC3::VectorIntAttribute>("flow");  if (vf) if (0<i&&i<(int)(vf->value().size())) return vf->value().at(i); 
-return 0;
-}
-inline int flow(HepMC3::ConstGenParticlePtr p, int i){
-std::shared_ptr<HepMC3::IntAttribute> f=p->attribute<HepMC3::IntAttribute>("flow"+std::to_string(i));  if (f) return f->value(); 
-std::shared_ptr<HepMC3::VectorIntAttribute> vf=p->attribute<HepMC3::VectorIntAttribute>("flow");  if (vf) if (0<i&&i<(int)(vf->value().size())) return vf->value().at(i); 
-return 0;
-}
-inline Flow flow(HepMC3::GenParticlePtr p){
-std::shared_ptr<HepMC3::VectorIntAttribute> vf=p->attribute<HepMC3::VectorIntAttribute>("flow");  
-if (vf)  return vf;
+inline int flow(HepMC3::GenParticlePtr p, int i) {
+    std::shared_ptr<HepMC3::IntAttribute> f=p->attribute<HepMC3::IntAttribute>("flow"+std::to_string(i));  if (f) return f->value();
+    std::shared_ptr<HepMC3::VectorIntAttribute> vf=p->attribute<HepMC3::VectorIntAttribute>("flow");  if (vf) if (0<i&&i<(int)(vf->value().size())) return vf->value().at(i);
+    return 0;
+}
+inline int flow(HepMC3::ConstGenParticlePtr p, int i) {
+    std::shared_ptr<HepMC3::IntAttribute> f=p->attribute<HepMC3::IntAttribute>("flow"+std::to_string(i));  if (f) return f->value();
+    std::shared_ptr<HepMC3::VectorIntAttribute> vf=p->attribute<HepMC3::VectorIntAttribute>("flow");  if (vf) if (0<i&&i<(int)(vf->value().size())) return vf->value().at(i);
+    return 0;
+}
+inline Flow flow(HepMC3::GenParticlePtr p) {
+    std::shared_ptr<HepMC3::VectorIntAttribute> vf=p->attribute<HepMC3::VectorIntAttribute>("flow");
+    if (vf)  return vf;
 
-std::vector<int> fl;
-for (int i=1;i<=10;i++)
-{
-std::shared_ptr<HepMC3::IntAttribute> f=p->attribute<HepMC3::IntAttribute>("flow"+std::to_string(i));  if (f) fl.push_back(i); else break;
-}
-return std::make_shared<HepMC3::VectorIntAttribute>(fl);
-}
-inline Flow flow(HepMC3::ConstGenParticlePtr p){
-std::shared_ptr<HepMC3::VectorIntAttribute> vf=p->attribute<HepMC3::VectorIntAttribute>("flow");  
-if (vf)  return vf;
+    std::vector<int> fl;
+    for (int i=1; i<=10; i++) {
+        std::shared_ptr<HepMC3::IntAttribute> f=p->attribute<HepMC3::IntAttribute>("flow"+std::to_string(i));  if (f) fl.push_back(i); else break;
+    }
+    return std::make_shared<HepMC3::VectorIntAttribute>(fl);
+}
+inline Flow flow(HepMC3::ConstGenParticlePtr p) {
+    std::shared_ptr<HepMC3::VectorIntAttribute> vf=p->attribute<HepMC3::VectorIntAttribute>("flow");
+    if (vf)  return vf;
 
-std::vector<int> fl;
-for (int i=1;i<=10;i++)
-{
-std::shared_ptr<HepMC3::IntAttribute> f=p->attribute<HepMC3::IntAttribute>("flow"+std::to_string(i));  if (f) fl.push_back(i); else break;
-}
-return std::make_shared<HepMC3::VectorIntAttribute>(fl);
+    std::vector<int> fl;
+    for (int i=1; i<=10; i++) {
+        std::shared_ptr<HepMC3::IntAttribute> f=p->attribute<HepMC3::IntAttribute>("flow"+std::to_string(i));  if (f) fl.push_back(i); else break;
+    }
+    return std::make_shared<HepMC3::VectorIntAttribute>(fl);
 }
 }
 #else
 #include "HepMC/Flow.h"
-namespace HepMC
-{
-template <class T> int flow(T a,int i){return a->flow(i);}
-template <class T> Flow flow(T a){return a->flow();}
+namespace HepMC {
+template <class T> int flow(T a,int i) {return a->flow(i);}
+template <class T> Flow flow(T a) {return a->flow();}
 }
 #endif
 #endif
diff --git a/Generators/AtlasHepMC/AtlasHepMC/GenEvent.h b/Generators/AtlasHepMC/AtlasHepMC/GenEvent.h
index 20259b2fd1d4dee5d7b2f7558956b452697f97dd..f3e4753ab542745576e66c9a94a0b6c3462b7903 100644
--- a/Generators/AtlasHepMC/AtlasHepMC/GenEvent.h
+++ b/Generators/AtlasHepMC/AtlasHepMC/GenEvent.h
@@ -14,12 +14,11 @@
 #include "AtlasHepMC/GenVertex.h"
 #include "AtlasHepMC/GenParticle.h"
 #include "AtlasHepMC/SimpleVector.h"
-namespace HepMC3
-{
-inline std::vector<HepMC3::GenParticlePtr>::const_iterator  begin(HepMC3::GenEvent& e){ return e.particles().begin(); }
-inline std::vector<HepMC3::GenParticlePtr>::const_iterator  end(HepMC3::GenEvent& e){ return e.particles().end(); }
-inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  begin(const HepMC3::GenEvent& e){ return e.particles().begin(); }
-inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  end(const HepMC3::GenEvent& e){ return e.particles().end(); }
+namespace HepMC3 {
+inline std::vector<HepMC3::GenParticlePtr>::const_iterator  begin(HepMC3::GenEvent& e) { return e.particles().begin(); }
+inline std::vector<HepMC3::GenParticlePtr>::const_iterator  end(HepMC3::GenEvent& e) { return e.particles().end(); }
+inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  begin(const HepMC3::GenEvent& e) { return e.particles().begin(); }
+inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  end(const HepMC3::GenEvent& e) { return e.particles().end(); }
 }
 
 namespace HepMC {
@@ -27,88 +26,91 @@ using Print=HepMC3::Print;
 using GenHeavyIon=HepMC3::GenHeavyIon;
 using GenEvent=HepMC3::GenEvent;
 
-inline std::vector<HepMC3::GenParticlePtr>::const_iterator  begin(HepMC3::GenEvent& e){ return e.particles().begin(); }
-inline std::vector<HepMC3::GenParticlePtr>::const_iterator  end(HepMC3::GenEvent& e){ return e.particles().end(); }
-inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  begin(const HepMC3::GenEvent& e){ return e.particles().begin(); }
-inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  end(const HepMC3::GenEvent& e){ return e.particles().end(); }
+inline std::vector<HepMC3::GenParticlePtr>::const_iterator  begin(HepMC3::GenEvent& e) { return e.particles().begin(); }
+inline std::vector<HepMC3::GenParticlePtr>::const_iterator  end(HepMC3::GenEvent& e) { return e.particles().end(); }
+inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  begin(const HepMC3::GenEvent& e) { return e.particles().begin(); }
+inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  end(const HepMC3::GenEvent& e) { return e.particles().end(); }
 
-inline GenEvent* newGenEvent(const int signal_process_id, const int event_number ){ GenEvent* e= new GenEvent(); 
-std::shared_ptr<HepMC3::IntAttribute> signal_process_id_A = std::make_shared<HepMC3::IntAttribute>(signal_process_id);
-e->add_attribute("signal_process_id",signal_process_id_A); 
-e->set_event_number(event_number);
-return e;
+inline GenEvent* newGenEvent(const int signal_process_id, const int event_number ) {
+    GenEvent* e= new GenEvent();
+    std::shared_ptr<HepMC3::IntAttribute> signal_process_id_A = std::make_shared<HepMC3::IntAttribute>(signal_process_id);
+    e->add_attribute("signal_process_id",signal_process_id_A);
+    e->set_event_number(event_number);
+    return e;
 }
 
-inline GenVertexPtr  barcode_to_vertex(const GenEvent* e, int id ){
-auto vertices=((GenEvent*)e)->vertices();
-for (auto v: vertices)  
-{
-auto barcode_attr=e->attribute<HepMC3::IntAttribute>("barcode");
-if (!barcode_attr) continue;
-if (barcode_attr->value()==id) return v;
-}
-if (-id>0&&-id<=(int)vertices.size()) return vertices[-id-1];
-return  HepMC3::GenVertexPtr(); 
+inline GenVertexPtr  barcode_to_vertex(const GenEvent* e, int id ) {
+    auto vertices=((GenEvent*)e)->vertices();
+    for (auto v: vertices) {
+        auto barcode_attr=e->attribute<HepMC3::IntAttribute>("barcode");
+        if (!barcode_attr) continue;
+        if (barcode_attr->value()==id) return v;
+    }
+    if (-id>0&&-id<=(int)vertices.size()) return vertices[-id-1];
+    return  HepMC3::GenVertexPtr();
 }
 
-inline GenParticlePtr  barcode_to_particle(const GenEvent* e, int id ){
-auto particles=((GenEvent*)e)->particles();
-for (auto p: particles)  
-{
-auto barcode_attr=p->attribute<HepMC3::IntAttribute>("barcode");
-if (!barcode_attr) continue;
-if (barcode_attr->value()==id) return p;
-}
-if (id>0&&id<=(int)particles.size()) return particles[id-1];
-return  HepMC3::GenParticlePtr(); 
+inline GenParticlePtr  barcode_to_particle(const GenEvent* e, int id ) {
+    auto particles=((GenEvent*)e)->particles();
+    for (auto p: particles) {
+        auto barcode_attr=p->attribute<HepMC3::IntAttribute>("barcode");
+        if (!barcode_attr) continue;
+        if (barcode_attr->value()==id) return p;
+    }
+    if (id>0&&id<=(int)particles.size()) return particles[id-1];
+    return  HepMC3::GenParticlePtr();
 }
 
 inline int mpi(const GenEvent evt) {
-std::shared_ptr<HepMC3::IntAttribute> A_mpi=evt.attribute<HepMC3::IntAttribute>("mpi");
- return A_mpi?(A_mpi->value()):0;
+    std::shared_ptr<HepMC3::IntAttribute> A_mpi=evt.attribute<HepMC3::IntAttribute>("mpi");
+    return A_mpi?(A_mpi->value()):0;
 }
 inline int mpi(const GenEvent* evt) {
-std::shared_ptr<HepMC3::IntAttribute> A_mpi=evt->attribute<HepMC3::IntAttribute>("mpi");
- return A_mpi?(A_mpi->value()):0;
+    std::shared_ptr<HepMC3::IntAttribute> A_mpi=evt->attribute<HepMC3::IntAttribute>("mpi");
+    return A_mpi?(A_mpi->value()):0;
 }
 
 inline int signal_process_id(const GenEvent evt) {
-std::shared_ptr<HepMC3::IntAttribute> A_signal_process_id=evt.attribute<HepMC3::IntAttribute>("signal_process_id");
- return A_signal_process_id?(A_signal_process_id->value()):0;
+    std::shared_ptr<HepMC3::IntAttribute> A_signal_process_id=evt.attribute<HepMC3::IntAttribute>("signal_process_id");
+    return A_signal_process_id?(A_signal_process_id->value()):0;
 }
 inline int signal_process_id(const GenEvent* evt) {
-std::shared_ptr<HepMC3::IntAttribute> A_signal_process_id=evt->attribute<HepMC3::IntAttribute>("signal_process_id");
- return A_signal_process_id?(A_signal_process_id->value()):0;
+    std::shared_ptr<HepMC3::IntAttribute> A_signal_process_id=evt->attribute<HepMC3::IntAttribute>("signal_process_id");
+    return A_signal_process_id?(A_signal_process_id->value()):0;
+}
+inline void set_signal_process_id(GenEvent* e, const int i=0) {
+    std::shared_ptr<HepMC3::IntAttribute> signal_process_id = std::make_shared<HepMC3::IntAttribute>(i);
+    e->add_attribute("signal_process_id",signal_process_id);
 }
-inline void set_signal_process_id(GenEvent* e, const int i=0) {     std::shared_ptr<HepMC3::IntAttribute> signal_process_id = std::make_shared<HepMC3::IntAttribute>(i);
-                                                                    e->add_attribute("signal_process_id",signal_process_id);  }
-inline void set_mpi(GenEvent* e, const int i=0) {     std::shared_ptr<HepMC3::IntAttribute> mpi = std::make_shared<HepMC3::IntAttribute>(i);
-                                                                    e->add_attribute("mpi",mpi);  }
-inline void set_random_states(GenEvent* e, std::vector<long int>& a)  { 
- e->add_attribute("random_states",std::make_shared<HepMC3::VectorLongIntAttribute>(a));
+inline void set_mpi(GenEvent* e, const int i=0) {
+    std::shared_ptr<HepMC3::IntAttribute> mpi = std::make_shared<HepMC3::IntAttribute>(i);
+    e->add_attribute("mpi",mpi);
 }
-template <class T> void set_signal_process_vertex(GenEvent* e, T v){
-if (!v) return;
-if (v->parent_event()!=e) return;
-v->add_attribute("signal_process_vertex",std::make_shared<HepMC3::IntAttribute>(1));
+inline void set_random_states(GenEvent* e, std::vector<long int>& a) {
+    e->add_attribute("random_states",std::make_shared<HepMC3::VectorLongIntAttribute>(a));
+}
+template <class T> void set_signal_process_vertex(GenEvent* e, T v) {
+    if (!v) return;
+    if (v->parent_event()!=e) return;
+    v->add_attribute("signal_process_vertex",std::make_shared<HepMC3::IntAttribute>(1));
 }
 inline ConstGenVertexPtr signal_process_vertex(const GenEvent* e) { for (auto v: e->vertices()) if (v->attribute<HepMC3::IntAttribute>("signal_process_vertex")) return v; return nullptr; }
 inline      GenVertexPtr signal_process_vertex(GenEvent* e) { for (auto v: e->vertices()) if (v->attribute<HepMC3::IntAttribute>("signal_process_vertex")) return v; return nullptr; }
-inline bool valid_beam_particles(const GenEvent* e){ if (!e) return false; if  (e->beams().size()!=2) return false; return true;}
+inline bool valid_beam_particles(const GenEvent* e) { if (!e) return false; if  (e->beams().size()!=2) return false; return true;}
 }
 #else
 #include "HepMC/GenEvent.h"
 #include "HepMC/GenVertex.h"
 #include "AtlasHepMC/GenVertex.h"
 namespace HepMC {
-inline GenEvent::particle_iterator  begin(HepMC::GenEvent& e){ return e.particles_begin(); }
-inline GenEvent::particle_iterator  end(HepMC::GenEvent& e){ return e.particles_end(); }
-inline GenEvent::particle_const_iterator  begin(const HepMC::GenEvent& e){ return e.particles_begin(); }
-inline GenEvent::particle_const_iterator  end(const HepMC::GenEvent& e){ return e.particles_end(); }
-inline GenEvent* newGenEvent(const int a, const int b ){ return new GenEvent(a,b); }
+inline GenEvent::particle_iterator  begin(HepMC::GenEvent& e) { return e.particles_begin(); }
+inline GenEvent::particle_iterator  end(HepMC::GenEvent& e) { return e.particles_end(); }
+inline GenEvent::particle_const_iterator  begin(const HepMC::GenEvent& e) { return e.particles_begin(); }
+inline GenEvent::particle_const_iterator  end(const HepMC::GenEvent& e) { return e.particles_end(); }
+inline GenEvent* newGenEvent(const int a, const int b ) { return new GenEvent(a,b); }
 inline GenVertex* signal_process_vertex(const GenEvent* e) { return e->signal_process_vertex(); }
-inline GenVertex* barcode_to_vertex(const GenEvent* e, int id ){return  e->barcode_to_vertex(id);}
-inline GenParticle* barcode_to_particle(const GenEvent* e, int id ){return  e->barcode_to_particle(id);}
+inline GenVertex* barcode_to_vertex(const GenEvent* e, int id ) {return  e->barcode_to_vertex(id);}
+inline GenParticle* barcode_to_particle(const GenEvent* e, int id ) {return  e->barcode_to_particle(id);}
 inline int mpi(const GenEvent e) {
     return e.mpi();
 }
@@ -134,10 +136,10 @@ template <class T> void set_signal_process_vertex(GenEvent* e, T v) {
     e->set_signal_process_vertex(v);
 }
 namespace Print {
-inline void line(std::ostream& os,const GenEvent& e){e.print(os);}
-inline void line(std::ostream& os,const GenEvent* e){e->print(os);}
+inline void line(std::ostream& os,const GenEvent& e) {e.print(os);}
+inline void line(std::ostream& os,const GenEvent* e) {e->print(os);}
 }
-inline bool valid_beam_particles(const GenEvent* e){return e->valid_beam_particles();}
+inline bool valid_beam_particles(const GenEvent* e) {return e->valid_beam_particles();}
 }
 #include "AtlasHepMC/SimpleVector.h"
 #endif
diff --git a/Generators/AtlasHepMC/AtlasHepMC/GenParticle.h b/Generators/AtlasHepMC/AtlasHepMC/GenParticle.h
index 0faf0b32fe7381857ae45e7a1d3169721b68c9dd..54d6e42689467f790ea23339684518348d20fa7b 100644
--- a/Generators/AtlasHepMC/AtlasHepMC/GenParticle.h
+++ b/Generators/AtlasHepMC/AtlasHepMC/GenParticle.h
@@ -14,28 +14,28 @@ namespace HepMC {
 typedef HepMC3::GenParticlePtr GenParticlePtr;
 typedef HepMC3::ConstGenParticlePtr ConstGenParticlePtr;
 inline GenParticlePtr newGenParticlePtr(const HepMC3::FourVector &mom = HepMC3::FourVector::ZERO_VECTOR(), int pid = 0, int status = 0) {
-  return std::make_shared<HepMC3::GenParticle>(mom,pid,status);
+    return std::make_shared<HepMC3::GenParticle>(mom,pid,status);
 }
-inline int barcode(GenParticlePtr p){ 
-	if (!p) return 0;
-	std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
-		 return barcode?(barcode->value()):p->id();
+inline int barcode(GenParticlePtr p) {
+    if (!p) return 0;
+    std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
+    return barcode?(barcode->value()):p->id();
 }
-inline int barcode(ConstGenParticlePtr p){ 
-	if (!p) return 0;
-	std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
-		 return barcode?(barcode->value()):p->id();
+inline int barcode(ConstGenParticlePtr p) {
+    if (!p) return 0;
+    std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
+    return barcode?(barcode->value()):p->id();
 }
-inline int barcode(const HepMC3::GenParticle p){ 
-	std::shared_ptr<HepMC3::IntAttribute> barcode=p.attribute<HepMC3::IntAttribute>("barcode");
-		 return barcode?(barcode->value()):p.id();
+inline int barcode(const HepMC3::GenParticle p) {
+    std::shared_ptr<HepMC3::IntAttribute> barcode=p.attribute<HepMC3::IntAttribute>("barcode");
+    return barcode?(barcode->value()):p.id();
 }
-inline int barcode(const HepMC3::GenParticle* p){ 
-	if (!p) return 0;
-	std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
-		 return barcode?(barcode->value()):p->id();
+inline int barcode(const HepMC3::GenParticle* p) {
+    if (!p) return 0;
+    std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
+    return barcode?(barcode->value()):p->id();
 }
-template <class T> void suggest_barcode(T p, int i){p->add_attribute("barcode",std::make_shared<HepMC3::IntAttribute>(i));}
+template <class T> bool suggest_barcode(T p, int i) {return p->add_attribute("barcode",std::make_shared<HepMC3::IntAttribute>(i));}
 using HepMC3::GenParticle;
 }
 #else
@@ -48,14 +48,14 @@ inline GenParticlePtr newGenParticlePtr(const HepMC::FourVector &mom = HepMC::Fo
 }
 inline int barcode(GenParticle p) {   return    p.barcode(); }
 template <class T> inline int barcode(T p) {   return    p->barcode(); }
-template <class T> void suggest_barcode(T p, int i){p->suggest_barcode(i);}
-inline void suggest_barcode(GenParticle p, int i){p.suggest_barcode(i);}
-template <class T> void suggest_barcode(T* p, int i){p->suggest_barcode(i);}
+template <class T> bool suggest_barcode(T p, int i) {return p->suggest_barcode(i);}
+inline bool suggest_barcode(GenParticle p, int i) {return p.suggest_barcode(i);}
+template <class T> bool suggest_barcode(T* p, int i) {return p->suggest_barcode(i);}
 namespace Print {
-inline void line(std::ostream& os,const GenParticle& p){p.print(os);}
-inline void line(std::ostream& os,const GenParticle* p){p->print(os);}
+inline void line(std::ostream& os,const GenParticle& p) {p.print(os);}
+inline void line(std::ostream& os,const GenParticle* p) {p->print(os);}
 }
-inline std::ostream& operator<<( std::ostream& os, const GenParticle* p ) { if (p) return os<<(*p); else return os;} 
+inline std::ostream& operator<<( std::ostream& os, const GenParticle* p ) { if (p) return os<<(*p); else return os;}
 }
 #endif
 #endif
diff --git a/Generators/AtlasHepMC/AtlasHepMC/GenVertex.h b/Generators/AtlasHepMC/AtlasHepMC/GenVertex.h
index 80bad06fc50716512d7b69890fa58dac60bbadee..02220ccc846d15399c614494c4d16961ad631aa2 100644
--- a/Generators/AtlasHepMC/AtlasHepMC/GenVertex.h
+++ b/Generators/AtlasHepMC/AtlasHepMC/GenVertex.h
@@ -8,36 +8,35 @@
 #ifdef HEPMC3
 #include "HepMC3/GenVertex.h"
 #include "HepMC3/PrintStreams.h"
-namespace HepMC3
-{
-inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  begin(const HepMC3::GenVertex& v){ return v.particles_out().begin(); }
-inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  end(const HepMC3::GenVertex& v){ return v.particles_out().end(); }
+namespace HepMC3 {
+inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  begin(const HepMC3::GenVertex& v) { return v.particles_out().begin(); }
+inline std::vector<HepMC3::ConstGenParticlePtr>::const_iterator  end(const HepMC3::GenVertex& v) { return v.particles_out().end(); }
 }
 namespace HepMC {
 typedef HepMC3::GenVertexPtr GenVertexPtr;
 typedef HepMC3::ConstGenVertexPtr ConstGenVertexPtr;
 inline GenVertexPtr newGenVertexPtr(const HepMC3::FourVector &pos = HepMC3::FourVector::ZERO_VECTOR(),const int i=0) {
-  GenVertexPtr v=std::make_shared<HepMC3::GenVertex>(pos);
-  v->set_status(i);
-  return v;
+    GenVertexPtr v=std::make_shared<HepMC3::GenVertex>(pos);
+    v->set_status(i);
+    return v;
 }
-inline int barcode(GenVertexPtr p){
-	if (!p) return 0; 
-	std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
-		 return barcode?(barcode->value()):p->id();
+inline int barcode(GenVertexPtr p) {
+    if (!p) return 0;
+    std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
+    return barcode?(barcode->value()):p->id();
 }
-inline int barcode(ConstGenVertexPtr p){ 
-	if (!p) return 0;
-	std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
-		 return barcode?(barcode->value()):p->id();
+inline int barcode(ConstGenVertexPtr p) {
+    if (!p) return 0;
+    std::shared_ptr<HepMC3::IntAttribute> barcode=p->attribute<HepMC3::IntAttribute>("barcode");
+    return barcode?(barcode->value()):p->id();
 }
-inline int barcode(HepMC3::GenVertex p){ 
-	std::shared_ptr<HepMC3::IntAttribute> barcode=p.attribute<HepMC3::IntAttribute>("barcode");
-		 return barcode?(barcode->value()):p.id();
+inline int barcode(HepMC3::GenVertex p) {
+    std::shared_ptr<HepMC3::IntAttribute> barcode=p.attribute<HepMC3::IntAttribute>("barcode");
+    return barcode?(barcode->value()):p.id();
 }
 
-inline void* raw_pointer(GenVertexPtr p){ return p.get();}
-inline const void* raw_pointer(ConstGenVertexPtr p){ return p.get();}
+inline void* raw_pointer(GenVertexPtr p) { return p.get();}
+inline const void* raw_pointer(ConstGenVertexPtr p) { return p.get();}
 using HepMC3::GenVertex;
 }
 #else
@@ -45,20 +44,20 @@ using HepMC3::GenVertex;
 namespace HepMC {
 typedef HepMC::GenVertex* GenVertexPtr;
 typedef const HepMC::GenVertex* ConstGenVertexPtr;
-inline GenVertex::particles_out_const_iterator  begin(const HepMC::GenVertex& v){ return v.particles_out_const_begin(); }
-inline GenVertex::particles_out_const_iterator  end(const HepMC::GenVertex& v){ return v.particles_out_const_end(); }
+inline GenVertex::particles_out_const_iterator  begin(const HepMC::GenVertex& v) { return v.particles_out_const_begin(); }
+inline GenVertex::particles_out_const_iterator  end(const HepMC::GenVertex& v) { return v.particles_out_const_end(); }
 
 inline GenVertexPtr newGenVertexPtr(const HepMC::FourVector &pos = HepMC::FourVector(0.0,0.0,0.0,0.0), const int i=0) {
     return new HepMC::GenVertex(pos,i);
 }
 namespace Print {
-inline void line(std::ostream& os,const GenVertex& v){v.print(os);}
-inline void line(std::ostream& os,const GenVertex* v){v->print(os);}
+inline void line(std::ostream& os,const GenVertex& v) {v.print(os);}
+inline void line(std::ostream& os,const GenVertex* v) {v->print(os);}
 }
-inline int barcode(ConstGenVertexPtr p){ return p->barcode();}
-inline void* raw_pointer(GenVertexPtr p){ return p;}
-inline const void* raw_pointer(ConstGenVertexPtr p){ return p;}
-inline std::ostream& operator<<( std::ostream& os, const GenVertex* v ) { if (v) return os<<(*v); else return os;} 
+inline int barcode(ConstGenVertexPtr p) { return p->barcode();}
+inline void* raw_pointer(GenVertexPtr p) { return p;}
+inline const void* raw_pointer(ConstGenVertexPtr p) { return p;}
+inline std::ostream& operator<<( std::ostream& os, const GenVertex* v ) { if (v) return os<<(*v); else return os;}
 }
 #endif
 #endif
diff --git a/Generators/AtlasHepMC/AtlasHepMC/HEPEVT_Wrapper.h b/Generators/AtlasHepMC/AtlasHepMC/HEPEVT_Wrapper.h
index eb5d60c177a994dea41fe518ffe1df8a7e8aeb97..7eee5e1fea52931698b1f258f3281392c343ce2a 100644
--- a/Generators/AtlasHepMC/AtlasHepMC/HEPEVT_Wrapper.h
+++ b/Generators/AtlasHepMC/AtlasHepMC/HEPEVT_Wrapper.h
@@ -7,8 +7,7 @@
 #define ATLASHEPMC_HEPEVTWRAPPER_H
 #ifdef HEPMC3
 #include "HepMC3/HEPEVT_Wrapper.h"
-namespace HepMC
-{
+namespace HepMC {
 typedef HepMC3::HEPEVT_Wrapper HEPEVT_Wrapper;
 }
 #else
diff --git a/Generators/AtlasHepMC/AtlasHepMC/IO_GenEvent.h b/Generators/AtlasHepMC/AtlasHepMC/IO_GenEvent.h
index 04dd2c9f6b91111edaaa491f080268a419c50173..ce3247278fbd0aadfd3e6ba5639c14a51a68fbd0 100644
--- a/Generators/AtlasHepMC/AtlasHepMC/IO_GenEvent.h
+++ b/Generators/AtlasHepMC/AtlasHepMC/IO_GenEvent.h
@@ -11,8 +11,7 @@
 #include "HepMC3/Writer.h"
 #include "HepMC3/ReaderAsciiHepMC2.h"
 #include "HepMC3/WriterAsciiHepMC2.h"
-namespace HepMC
-{
+namespace HepMC {
 typedef HepMC3::WriterAsciiHepMC2   WriterAsciiHepMC2;
 typedef HepMC3::ReaderAsciiHepMC2   ReaderAsciiHepMC2;
 class IO_GenEvent {
diff --git a/Generators/AtlasHepMC/AtlasHepMC/PdfInfo.h b/Generators/AtlasHepMC/AtlasHepMC/PdfInfo.h
index d2db820062956da96e26ca9680c005a8e6b00e8b..6ae4c64aec0ad01c273613b720e021e4f25473d5 100644
--- a/Generators/AtlasHepMC/AtlasHepMC/PdfInfo.h
+++ b/Generators/AtlasHepMC/AtlasHepMC/PdfInfo.h
@@ -8,14 +8,12 @@
 #ifdef HEPMC3
 #include "HepMC3/GenEvent.h"
 #include "HepMC3/PrintStreams.h"
-namespace HepMC
-{
+namespace HepMC {
 typedef std::shared_ptr<HepMC3::GenPdfInfo>  GenPdfInfoPtr;
 }
 #else
 #include "HepMC/PdfInfo.h"
-namespace HepMC
-{
+namespace HepMC {
 typedef HepMC::PdfInfo*  GenPdfInfoPtr;
 }
 #endif
diff --git a/Generators/AtlasHepMC/AtlasHepMC/Polarization.h b/Generators/AtlasHepMC/AtlasHepMC/Polarization.h
index e954879347bcd8f6209a169f81947f2e2c08e139..78c16cc52d9ff9d5a40182338a6e7d01635578fa 100644
--- a/Generators/AtlasHepMC/AtlasHepMC/Polarization.h
+++ b/Generators/AtlasHepMC/AtlasHepMC/Polarization.h
@@ -8,43 +8,40 @@
 #ifdef HEPMC3
 #include "HepMC3/GenParticle.h"
 #include "HepMC3/Attribute.h"
-namespace HepMC
-{
-class Polarization  {
+namespace HepMC {
+class Polarization {
 public:
-Polarization( const double a=0.0, const double b=0.0): m_theta(a), m_phi(b) {};
-~Polarization(){};
-double theta() const  { return m_theta;}
-double phi() const { return m_phi;}
-bool is_defined() const { if (std::abs(m_theta)<0.00001&&std::abs(m_phi)<0.00001) return false; return true; }
+    Polarization( const double a=0.0, const double b=0.0): m_theta(a), m_phi(b) {};
+    ~Polarization() {};
+    double theta() const  { return m_theta;}
+    double phi() const { return m_phi;}
+    bool is_defined() const { if (std::abs(m_theta)<0.00001&&std::abs(m_phi)<0.00001) return false; return true; }
 private:
-double m_theta;
-double m_phi;
+    double m_theta;
+    double m_phi;
 };
-inline Polarization polarization(HepMC3::GenParticlePtr a){
-	std::shared_ptr<HepMC3::DoubleAttribute> phi_A =a->attribute<HepMC3::DoubleAttribute>("phi");
-	std::shared_ptr<HepMC3::DoubleAttribute> theta_A=a->attribute<HepMC3::DoubleAttribute>("theta");
+inline Polarization polarization(HepMC3::GenParticlePtr a) {
+    std::shared_ptr<HepMC3::DoubleAttribute> phi_A =a->attribute<HepMC3::DoubleAttribute>("phi");
+    std::shared_ptr<HepMC3::DoubleAttribute> theta_A=a->attribute<HepMC3::DoubleAttribute>("theta");
     double phi=(phi_A?phi_A->value():0.0);
     double theta=(theta_A?theta_A->value():0.0);
-	return Polarization(theta,phi);
+    return Polarization(theta,phi);
 }
-inline Polarization polarization(HepMC3::ConstGenParticlePtr a){
-	std::shared_ptr<HepMC3::DoubleAttribute> phi_A =a->attribute<HepMC3::DoubleAttribute>("phi");
-	std::shared_ptr<HepMC3::DoubleAttribute> theta_A=a->attribute<HepMC3::DoubleAttribute>("theta");
+inline Polarization polarization(HepMC3::ConstGenParticlePtr a) {
+    std::shared_ptr<HepMC3::DoubleAttribute> phi_A =a->attribute<HepMC3::DoubleAttribute>("phi");
+    std::shared_ptr<HepMC3::DoubleAttribute> theta_A=a->attribute<HepMC3::DoubleAttribute>("theta");
     double phi=(phi_A?phi_A->value():0.0);
     double theta=(theta_A?theta_A->value():0.0);
-	return Polarization(theta,phi);
+    return Polarization(theta,phi);
 }
-template<class T> void  set_polarization( T a,  Polarization b) 
-{
-a->add_attribute("phi",std::make_shared<HepMC3::DoubleAttribute>(b.phi())); 
-a->add_attribute("theta",std::make_shared<HepMC3::DoubleAttribute>(b.theta())); 
+template<class T> void  set_polarization( T a,  Polarization b) {
+    a->add_attribute("phi",std::make_shared<HepMC3::DoubleAttribute>(b.phi()));
+    a->add_attribute("theta",std::make_shared<HepMC3::DoubleAttribute>(b.theta()));
 }
 }
 #else
 #include "HepMC/Polarization.h"
-namespace HepMC
-{
+namespace HepMC {
 template<class T> void set_polarization( T a,  Polarization b) {
     a->set_polarization(b);
 }
diff --git a/Generators/AtlasHepMC/AtlasHepMC/SimpleVector.h b/Generators/AtlasHepMC/AtlasHepMC/SimpleVector.h
index 8a578130b0e01c915b1f5a5569619edb65d2fb10..41bef08e206d3742a71ac01d31e0ec184591d3d9 100644
--- a/Generators/AtlasHepMC/AtlasHepMC/SimpleVector.h
+++ b/Generators/AtlasHepMC/AtlasHepMC/SimpleVector.h
@@ -8,8 +8,7 @@
 #ifdef HEPMC3
 #include "HepMC3/FourVector.h"
 #include "HepMC3/PrintStreams.h"
-namespace HepMC
-{
+namespace HepMC {
 typedef HepMC3::FourVector FourVector;
 }
 #else
diff --git a/Generators/GenInterfaces/GenInterfaces/IHiggsTruthCategoryTool.h b/Generators/GenInterfaces/GenInterfaces/IHiggsTruthCategoryTool.h
index 9220b3f0ea18829044594bcd66f664f929ac1508..dd8b1e0de73c0940884f400ac840c8c78f177623 100644
--- a/Generators/GenInterfaces/GenInterfaces/IHiggsTruthCategoryTool.h
+++ b/Generators/GenInterfaces/GenInterfaces/IHiggsTruthCategoryTool.h
@@ -25,7 +25,7 @@ class IHiggsTruthCategoryTool : public virtual asg::IAsgTool {
  public:
   virtual StatusCode initialize() = 0;
   virtual StatusCode finalize () = 0;  
-  virtual HTXS::HiggsClassification* getHiggsTruthCategoryObject(const HepMC::GenEvent& HepMCEvent, const HTXS::HiggsProdMode prodMode)=0;
+  virtual HTXS::HiggsClassification* getHiggsTruthCategoryObject(const HepMC::GenEvent& HepMCEvent, const HTXS::HiggsProdMode prodMode) const =0;
 };
 
 #endif //> !GENINTERFACES_IHIGGSTRUTHCATEGORYTOOL_H
diff --git a/Generators/GenInterfaces/GenInterfaces/IxAODtoHepMCTool.h b/Generators/GenInterfaces/GenInterfaces/IxAODtoHepMCTool.h
new file mode 100644
index 0000000000000000000000000000000000000000..2045eee2f551e395b1ece7c6bd78fe653e3fd42a
--- /dev/null
+++ b/Generators/GenInterfaces/GenInterfaces/IxAODtoHepMCTool.h
@@ -0,0 +1,46 @@
+/*
+  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+*/
+
+/*
+ * dual-use tool for converting xAOD truth events back to HepMC
+ * Principal Authors (responsible for the core conversion algorithm): Josh McFayden and James Catmore
+ * Tool Author: Jim Lacey (Carleton University) 
+ * ... updated tool interface to be dual-use
+ * ... added missing PDF information and requirements to allow running on full sim (remove Geant4 secondaries)
+ * <james.lacey@cern.ch,jlacey@physics.carleton.ca>
+ * <dag.gillberg@cern.ch>
+ */
+
+#ifndef GENINTERFACES_IXAODTOHEPMCTOOL_H
+#define GENINTERFACES_IXAODTOHEPMCTOOL_H 1
+
+#include "AsgTools/IAsgTool.h"
+
+
+// STL includes
+#include <string>
+#include <map>
+
+#include "xAODEventInfo/EventInfo.h"
+#include "xAODTruth/TruthEventContainer.h"
+
+#include "HepMC/GenEvent.h"
+
+namespace HepMC {
+  class GenEvent;
+  class GenParticle;
+  class GenVertex;
+}
+
+class IxAODtoHepMCTool : public virtual asg::IAsgTool {
+ public:
+  ASG_TOOL_INTERFACE( IxAODtoHepMCTool )  
+    virtual ~  IxAODtoHepMCTool () { };
+ public:
+  virtual StatusCode initialize() = 0;
+  virtual StatusCode finalize () = 0;
+  virtual std::vector<HepMC::GenEvent> getHepMCEvents(const xAOD::TruthEventContainer* xTruthEventContainer, const xAOD::EventInfo* eventInfo) const = 0;
+};
+
+#endif //> !GENINTERFACES_IXAODTOHEPMCTOOL_H
diff --git a/Generators/TruthConverters/CMakeLists.txt b/Generators/TruthConverters/CMakeLists.txt
new file mode 100644
index 0000000000000000000000000000000000000000..76b8dd3277a7f1403c86d16e4d1651601ce22f24
--- /dev/null
+++ b/Generators/TruthConverters/CMakeLists.txt
@@ -0,0 +1,22 @@
+# $Id: CMakeLists.txt 769086 2016-08-22 12:03:50Z krasznaa $
+################################################################################
+# Package: TruthConverters
+################################################################################
+
+# Set the name of the package:
+atlas_subdir( TruthConverters )
+
+# External(s) needed by the package:
+find_package( HepMC )
+
+# Component(s) in the package:
+atlas_add_library( TruthConvertersLib
+   TruthConverters/*.h Root/*.cxx
+   SHARED
+	PUBLIC_HEADERS TruthConverters
+	INCLUDE_DIRS ${HEPMC_INCLUDE_DIRS}
+	LINK_LIBRARIES ${HEPMC_LIBRARIES} AsgTools xAODEventInfo xAODTruth GenInterfacesLib )
+
+atlas_add_component( TruthConverters 
+	src/components/*.cxx
+	LINK_LIBRARIES TruthConvertersLib GaudiKernel GenInterfacesLib )
diff --git a/Generators/TruthConverters/Root/xAODtoHepMCTool.cxx b/Generators/TruthConverters/Root/xAODtoHepMCTool.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..29972fe36750267a5ee40265e7a1494cc4a226d4
--- /dev/null
+++ b/Generators/TruthConverters/Root/xAODtoHepMCTool.cxx
@@ -0,0 +1,286 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
+
+#include "TruthConverters/xAODtoHepMCTool.h"
+
+xAODtoHepMCTool::xAODtoHepMCTool( const std::string& name ) 
+  : asg::AsgTool( name ),
+  m_momFac(1.), //<-- MeV/GeV conversion factor
+  m_lenFac(1.), //<-- length conversion factor
+  m_signalOnly(true),
+  m_maxCount(0)
+{
+}
+
+
+StatusCode xAODtoHepMCTool::initialize() {
+  ATH_MSG_INFO ("Initializing xAODtoHepMCTool "<< name() << "...");
+  ATH_MSG_INFO ("SignalOnly         = " << m_signalOnly);
+  m_evtCount   = 0;
+  m_badSuggest = 0;
+  m_noProdVtx  = 0;
+  m_badBeams   = 0;
+  return StatusCode::SUCCESS;
+}
+
+
+
+StatusCode xAODtoHepMCTool :: finalize ()
+{
+  ATH_MSG_INFO ("==============================================================");
+  ATH_MSG_INFO ("==========    xAOD -> HepMC Tool :: Run Summary     ==========");
+  ATH_MSG_INFO ("==============================================================");
+  if( m_badSuggest ){
+    ATH_MSG_INFO ("Number of suggest_barcode failures = " << m_badSuggest);
+    ATH_MSG_INFO (" ... check input particle/vertex barcodes.");
+  } else {
+    ATH_MSG_INFO ("No suggest_barcode failures");
+  }
+  if ( m_noProdVtx ) {
+    ATH_MSG_INFO ("Number of events that have a missing production vertex = " << m_noProdVtx);
+  }else{
+    ATH_MSG_INFO ("No missing production vertices");
+  }
+  if ( m_badBeams ){
+    ATH_MSG_INFO ("Number events with improperly defined beamparticles = " << m_badBeams);
+    ATH_MSG_INFO ("Inconsistencies with the beam particles storage in the event record!");
+    ATH_MSG_INFO ("... check xAOD::TruthEvent record ...");
+  }else{
+    ATH_MSG_INFO ("No events with undefined beams.");
+  }
+  ATH_MSG_INFO ("==============================================================");
+  ATH_MSG_INFO ("===================    End Run Summary     ===================");
+  ATH_MSG_INFO ("==============================================================");
+  return StatusCode::SUCCESS;
+}
+
+std::vector<HepMC::GenEvent> xAODtoHepMCTool :: getHepMCEvents(const xAOD::TruthEventContainer* xTruthEventContainer, const xAOD::EventInfo* eventInfo) const
+{
+  ++m_evtCount;
+  bool doPrint = m_evtCount < m_maxCount;
+  // CREATE HEPMC EVENT COLLECTION
+  std::vector<HepMC::GenEvent> mcEventCollection;
+  // Loop over xAOD truth container
+  // Signal event is always first, followed by pileup events
+  ATH_MSG_DEBUG("Start event loop");
+  for (const xAOD::TruthEvent* xAODEvent : *xTruthEventContainer) {
+    if( doPrint ) ATH_MSG_DEBUG("XXX Printing xAOD Event");
+    if( doPrint ) printxAODEvent( xAODEvent,eventInfo );
+    // Create GenEvent for each xAOD truth event
+    ATH_MSG_DEBUG("Create new GenEvent");
+    HepMC::GenEvent hepmcEvent = createHepMCEvent(xAODEvent,eventInfo);
+    // Insert into McEventCollection
+    mcEventCollection.push_back(hepmcEvent);    
+    if( doPrint ) ATH_MSG_DEBUG("XXX Printing HepMC Event");
+    if( doPrint ) hepmcEvent.print();
+    // Quit if signal only
+    if( m_signalOnly ) break;
+  }  
+  return mcEventCollection;
+}
+
+
+HepMC::GenEvent xAODtoHepMCTool::createHepMCEvent(const xAOD::TruthEvent* xEvt, const xAOD::EventInfo* eventInfo) const {
+  
+  ///EVENT LEVEL
+  HepMC::GenEvent genEvt;
+
+  long long int evtNum = eventInfo->eventNumber();    
+  genEvt.set_event_number(evtNum);
+  ATH_MSG_DEBUG("Start createHepMCEvent for event " <<evtNum);
+  
+  // PARTICLES AND VERTICES  
+  // Map of existing vertices - needed for the tree linking
+  std::map<const xAOD::TruthVertex*,HepMC::GenVertex*> vertexMap;
+
+  // Loop over all of the particles in the event, call particle builder
+  // Call suggest_barcode only after insertion!  
+  for (auto tlink:xEvt->truthParticleLinks()) {
+    if (!tlink.isValid()) continue;
+    const xAOD::TruthParticle* xPart = *tlink;
+    
+    // sanity check
+    if (xPart == nullptr) {
+      ATH_MSG_WARNING("xAOD TruthParticle is equal to NULL. This should not happen!");
+      continue;
+    }
+
+    if( !xPart->hasProdVtx() && !xPart->hasDecayVtx() ){
+      ATH_MSG_WARNING("xAOD particle with no vertices, bc = "<<xPart->barcode());
+      continue;
+    }
+
+    // skip particles with barcode > 200000 --> Geant4 secondaries 
+    if ( xPart->barcode() > 200000 ) continue; 
+
+    // Create GenParticle
+    //presumably the GenEvent takes ownership of this, but creating a unique_ptr here as that will only happen if there's an associated vertex
+    std::unique_ptr<HepMC::GenParticle> hepmcParticle( createHepMCParticle(xPart) );
+    int bcpart = xPart->barcode();
+    
+    // status 10902 should be treated just as status 2
+    if ( hepmcParticle->status() == 10902 ) hepmcParticle->set_status(2);
+
+    // Get the production and decay vertices
+    if( xPart->hasProdVtx() ) {
+      const xAOD::TruthVertex* xAODProdVtx = xPart->prodVtx();
+      // skip production vertices with barcode > 200000 --> Geant4 secondaries 
+      if ( std::abs(xAODProdVtx->barcode()) > 200000 ) continue; 
+      bool prodVtxSeenBefore(false); // is this new?
+      HepMC::GenVertex* hepmcProdVtx = vertexHelper(xAODProdVtx,vertexMap,prodVtxSeenBefore);
+      // Set the decay/production links
+      hepmcProdVtx->add_particle_out(hepmcParticle.release());
+      // Insert into Event
+      if (!prodVtxSeenBefore){ 
+	genEvt.add_vertex(hepmcProdVtx);
+	if( !hepmcProdVtx->suggest_barcode(xAODProdVtx->barcode()) ){
+	  ATH_MSG_WARNING("suggest_barcode failed for vertex "<<xAODProdVtx->barcode());
+	  ++m_badSuggest;
+	}
+            }
+      if( !hepmcParticle->suggest_barcode(bcpart) ){
+	ATH_MSG_DEBUG("suggest_barcode failed for particle " <<bcpart);
+	++m_badSuggest;
+      }
+      bcpart = 0;
+    } else {
+      ATH_MSG_DEBUG("No production vertex found for particle "<<xPart->barcode());
+    }
+    
+    if( xPart->hasDecayVtx() ){
+      const xAOD::TruthVertex* xAODDecayVtx = xPart->decayVtx();
+      // skip decay vertices with barcode > 200000 --> Geant4 secondaries 
+      if ( fabs(xAODDecayVtx->barcode()) > 200000 ) continue; 
+      bool decayVtxSeenBefore(false); // is this new?
+      HepMC::GenVertex* hepmcDecayVtx = vertexHelper(xAODDecayVtx,vertexMap,decayVtxSeenBefore);
+      // Set the decay/production links
+      hepmcDecayVtx->add_particle_in(hepmcParticle.release());
+      // Insert into Event
+      if (!decayVtxSeenBefore){ 
+	genEvt.add_vertex(hepmcDecayVtx);
+	if( !hepmcDecayVtx->suggest_barcode(xAODDecayVtx->barcode()) ){
+	  ATH_MSG_WARNING("suggest_barcode failed for vertex "
+			  <<xAODDecayVtx->barcode());
+	  ++m_badSuggest;
+	}
+      }
+      if( bcpart != 0 ){
+	if( !hepmcParticle->suggest_barcode(bcpart) ){
+	  ATH_MSG_DEBUG("suggest_barcode failed for particle " <<bcpart);
+	  ++m_badSuggest;
+	}
+	bcpart = 0;
+      }
+    }
+
+  } // end of particle loop
+
+  const HepMC::GenEvent constGenEvt(genEvt);
+  ATH_MSG_DEBUG("Returning const GenEvent");
+  return constGenEvt;
+  
+}
+
+// Helper to check whether a vertex exists or not using a map; 
+// calls createHepMCVertex if not
+HepMC::GenVertex* xAODtoHepMCTool::vertexHelper(const xAOD::TruthVertex* xaodVertex,
+						std::map<const xAOD::TruthVertex*,HepMC::GenVertex*> &vertexMap,
+						bool &seenBefore) const {
+  
+  HepMC::GenVertex* hepmcVertex;
+  std::map<const xAOD::TruthVertex*,HepMC::GenVertex*>::iterator vMapItr;
+  vMapItr=vertexMap.find(xaodVertex);
+  // Vertex seen before?
+  if (vMapItr!=vertexMap.end()) {
+            // YES: use the HepMC::Vertex already in the map
+    hepmcVertex = (*vMapItr).second;
+    seenBefore = true;
+  } else {
+    // NO: create a new HepMC::Vertex
+    vertexMap[xaodVertex] = createHepMCVertex(xaodVertex);
+    hepmcVertex=vertexMap[xaodVertex];
+    seenBefore = false;
+  }
+  return hepmcVertex;
+  
+}
+
+// Create the HepMC GenParticle
+// Call suggest_barcode after insertion!
+HepMC::GenParticle* xAODtoHepMCTool::createHepMCParticle(const xAOD::TruthParticle* particle) const {
+  ATH_MSG_VERBOSE("Creating GenParticle for barcode " <<particle->barcode());
+  const HepMC::FourVector fourVec( m_momFac * particle->px(), m_momFac * particle->py(), m_momFac * particle->pz(), m_momFac * particle->e() );
+  HepMC::GenParticle* hepmcParticle=new HepMC::GenParticle(fourVec, particle->pdgId(), particle->status());
+  hepmcParticle->set_generated_mass( m_momFac * particle->m());
+  return hepmcParticle;
+}
+
+// Create the HepMC GenVertex
+// Call suggest_barcode after insertion!
+HepMC::GenVertex* xAODtoHepMCTool::createHepMCVertex(const xAOD::TruthVertex* vertex) const {
+  ATH_MSG_VERBOSE("Creating GenVertex for barcode " <<vertex->barcode());
+  HepMC::FourVector prod_pos( m_lenFac * vertex->x(), m_lenFac * vertex->y(),m_lenFac * vertex->z(), m_lenFac * vertex->t() );
+  HepMC::GenVertex* genVertex=new HepMC::GenVertex(prod_pos);
+  return genVertex;
+}
+
+// Print xAODTruth Event. The printout is particle oriented, unlike the
+// HepMC particle/vertex printout. Geant and pileup particles with
+// barcode>100000 are omitted.
+void xAODtoHepMCTool::printxAODEvent(const xAOD::TruthEvent* event, const xAOD::EventInfo* eventInfo) const{
+  
+  std::vector<int> bcPars;
+  std::vector<int> bcKids;
+
+  long long int evtNum = eventInfo->eventNumber();
+
+  std::cout <<"======================================================================================" <<std::endl;
+  std::cout <<"xAODTruth Event " << evtNum <<std::endl;
+  std::cout <<"   Barcode      PDG Id  Status   px(GeV)   py(GeV)   pz(GeV)    E(GeV)   Parent: Decay" <<std::endl;
+  std::cout <<"   -----------------------------------------------------------------------------------" <<std::endl;
+
+  int nPart = event->nTruthParticles();
+  for(int i=0; i<nPart; ++i){
+    const xAOD::TruthParticle* part = event->truthParticle(i);
+    if (part==nullptr) continue;
+    int bc = part->barcode();
+    if( bc > 100000 ) continue;
+    int id = part->pdgId();
+    if ( id != 25 ) continue;
+    int stat = part->status();
+    float px = part->px()/1000.;
+    float py = part->py()/1000.;
+    float pz = part->pz()/1000.;
+    float e = part->e()/1000.;
+    bcPars.clear();
+    bcKids.clear();
+
+    if( part->hasProdVtx() ){
+      const xAOD::TruthVertex* pvtx = part->prodVtx();
+      if( pvtx ) bcPars.push_back(pvtx->barcode());
+    }
+
+    if( part->hasDecayVtx() ){
+      const xAOD::TruthVertex* dvtx = part->decayVtx();
+      if( dvtx ) bcKids.push_back(dvtx->barcode());
+    }
+
+    std::cout <<std::setw(10)<<bc <<std::setw(12)<<id
+              <<std::setw(8)<<stat
+              <<std::setprecision(2)<<std::fixed
+              <<std::setw(10)<<px <<std::setw(10)<<py
+              <<std::setw(10)<<pz <<std::setw(10)<<e <<"   ";
+    std::cout <<"P: ";
+    for(unsigned int k=0; k<bcPars.size(); ++k){
+      std::cout <<bcPars[k] <<" ";
+    }
+    std::cout <<"  D: ";
+    for(unsigned int k=0; k<bcKids.size(); ++k){
+      std::cout <<bcKids[k] <<" ";
+    }
+    std::cout <<std::endl;
+  }
+  std::cout <<"======================================================================================" <<std::endl;
+}
diff --git a/Generators/TruthConverters/TruthConverters/selection.xml b/Generators/TruthConverters/TruthConverters/selection.xml
new file mode 100644
index 0000000000000000000000000000000000000000..a52825c0a277f2ff9e3e2761bca10d6a7ea9b724
--- /dev/null
+++ b/Generators/TruthConverters/TruthConverters/selection.xml
@@ -0,0 +1,5 @@
+
+<lcgdict>
+   <class name="xAODtoHepMCTool" />
+   <class name="IxAODtoHepMCTool" />
+</lcgdict>
diff --git a/Generators/TruthConverters/TruthConverters/xAODtoHepMCDict.h b/Generators/TruthConverters/TruthConverters/xAODtoHepMCDict.h
new file mode 100644
index 0000000000000000000000000000000000000000..a5e812f29ab0503f5df123695d104693f6084116
--- /dev/null
+++ b/Generators/TruthConverters/TruthConverters/xAODtoHepMCDict.h
@@ -0,0 +1,11 @@
+/*
+  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+*/
+
+
+#ifndef TRUTHCONVERTERS_XAODTOHEPMCDICT_H
+#define TRUTHCONVERTERS_XAODTOHEPMCDICT_H
+
+#include "TruthConverters/xAODtoHepMCTool.h"
+
+#endif
diff --git a/Generators/TruthConverters/TruthConverters/xAODtoHepMCTool.h b/Generators/TruthConverters/TruthConverters/xAODtoHepMCTool.h
new file mode 100644
index 0000000000000000000000000000000000000000..15aa09edbef47bc8fd8cfa8b19e597ec9614ac9f
--- /dev/null
+++ b/Generators/TruthConverters/TruthConverters/xAODtoHepMCTool.h
@@ -0,0 +1,55 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
+/*
+ * dual-use tool for converting xAOD truth events back to HepMC
+ * Principal Authors (responsible for the core conversion algorithm): Josh McFayden and James Catmore
+ * Tool Author: Jim Lacey (Carleton University) 
+ * ... updated tool interface to be dual-use
+ * ... added missing PDF information and requirements to allow running on full sim (remove Geant4 secondaries)
+ * <james.lacey@cern.ch,jlacey@physics.carleton.ca>
+ * <dag.gillberg@cern.ch>
+ */
+
+#ifndef TRUTHCONVERTERS_XAODTOHEPMCTOOL_H
+#define TRUTHCONVERTERS_XAODTOHEPMCTOOL_H 1
+
+#include "AsgTools/AsgTool.h"
+#include "GenInterfaces/IxAODtoHepMCTool.h"
+
+
+class xAODtoHepMCTool: public asg::AsgTool, public virtual IxAODtoHepMCTool { 
+ public: 
+   ASG_TOOL_CLASS( xAODtoHepMCTool , IxAODtoHepMCTool )
+   xAODtoHepMCTool( const std::string& name );
+   virtual ~xAODtoHepMCTool () { };
+
+   virtual StatusCode  initialize() override;
+   StatusCode finalize () override;
+
+ public:
+   std::vector<HepMC::GenEvent> getHepMCEvents(const xAOD::TruthEventContainer* xTruthEventContainer, const xAOD::EventInfo* eventInfo) const override;
+
+ private:
+   HepMC::GenEvent createHepMCEvent(const xAOD::TruthEvent* xEvt, const xAOD::EventInfo* eventInfo) const;
+   HepMC::GenVertex* vertexHelper(const xAOD::TruthVertex*,std::map<const xAOD::TruthVertex*,HepMC::GenVertex*>&,bool&) const;
+   HepMC::GenParticle* createHepMCParticle(const xAOD::TruthParticle*) const;
+   HepMC::GenVertex* createHepMCVertex(const xAOD::TruthVertex*) const;
+   void printxAODEvent(const xAOD::TruthEvent* event, const xAOD::EventInfo* eventInfo) const;
+   
+ private:
+   /// Input container key (job property)
+   float m_momFac,m_lenFac;
+   bool m_signalOnly;
+   int m_maxCount;
+   /// Counters
+   //not sure if these need to be atomic but just in case this will run in MT
+   mutable std::atomic<int> m_evtCount;
+   mutable std::atomic<int> m_badSuggest;
+   int m_noProdVtx;
+   int m_badBeams;
+
+}; 
+
+#endif //> !XAODTOHEPMC_XAODTOHEPMCTOOL_H
diff --git a/Generators/TruthConverters/src/components/TruthConverters_entries.cxx b/Generators/TruthConverters/src/components/TruthConverters_entries.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..fc6fea6d6af7a77c778477aa29db21c2d2fbccf6
--- /dev/null
+++ b/Generators/TruthConverters/src/components/TruthConverters_entries.cxx
@@ -0,0 +1,4 @@
+
+#include "TruthConverters/xAODtoHepMCTool.h"
+
+DECLARE_COMPONENT( xAODtoHepMCTool )
diff --git a/Generators/TruthRivetTools/Root/HiggsTruthCategoryTool.cxx b/Generators/TruthRivetTools/Root/HiggsTruthCategoryTool.cxx
index d2790e23680f848bedb4f5cf6571992a64df0fd4..0ba2d87a2802de0b02776d429540e4a9e8cac3bb 100644
--- a/Generators/TruthRivetTools/Root/HiggsTruthCategoryTool.cxx
+++ b/Generators/TruthRivetTools/Root/HiggsTruthCategoryTool.cxx
@@ -21,7 +21,7 @@ StatusCode HiggsTruthCategoryTool::initialize() {
   ATH_MSG_INFO ("Initializing " << name() << "...");
   // Rivet analysis :: Higgs truth event classifier class
   higgsTemplateCrossSections = new Rivet::HiggsTemplateCrossSections();
-  // crreate an instance of the Rivet analysis handler
+  // create an instance of the Rivet analysis handler
   rivetAnaHandler = new Rivet::AnalysisHandler();
   // Add the Higgs truth classifier class to the handler
   rivetAnaHandler->addAnalysis(&(*higgsTemplateCrossSections));
@@ -32,8 +32,10 @@ StatusCode HiggsTruthCategoryTool :: finalize () {
   ATH_MSG_INFO (" ====================================================== ");
   ATH_MSG_INFO (" ---- Finalizing" << name() << "...");
   ATH_MSG_INFO (" ====================================================== ");
-  if ( !m_outHistos )
-    higgsTemplateCrossSections->printClassificationSummary( );
+  if ( !m_outHistos ){
+    //this seems to thrown an exception
+    //higgsTemplateCrossSections->printClassificationSummary( );
+  }
   else{
     // TODO:: update the tool properly deal with output files/paths
     rivetAnaHandler->finalize();
@@ -43,7 +45,7 @@ StatusCode HiggsTruthCategoryTool :: finalize () {
   return StatusCode::SUCCESS;  
 }
 
-HTXS::HiggsClassification* HiggsTruthCategoryTool :: getHiggsTruthCategoryObject (const HepMC::GenEvent& HepMCEvent, const HTXS::HiggsProdMode prodMode){
+HTXS::HiggsClassification* HiggsTruthCategoryTool :: getHiggsTruthCategoryObject (const HepMC::GenEvent& HepMCEvent, const HTXS::HiggsProdMode prodMode) const {
   if ( !m_isInitialized ) {
     higgsTemplateCrossSections->setHiggsProdMode(prodMode); 
     rivetAnaHandler->init(HepMCEvent); 
diff --git a/Generators/TruthRivetTools/TruthRivetTools/HiggsTruthCategoryTool.h b/Generators/TruthRivetTools/TruthRivetTools/HiggsTruthCategoryTool.h
index 77e63f24a7493f9fc27c2ed40069befb41530871..7e6399d0a6316c4fe8ce159682ebb0d69d3a0b98 100644
--- a/Generators/TruthRivetTools/TruthRivetTools/HiggsTruthCategoryTool.h
+++ b/Generators/TruthRivetTools/TruthRivetTools/HiggsTruthCategoryTool.h
@@ -47,9 +47,9 @@ class HiggsTruthCategoryTool
    Rivet::HiggsTemplateCrossSections *higgsTemplateCrossSections; //!
    virtual StatusCode  initialize() override;
    StatusCode finalize () override;
-   HTXS::HiggsClassification* getHiggsTruthCategoryObject(const HepMC::GenEvent& HepMCEvent, const HTXS::HiggsProdMode prodMode) override;
+   HTXS::HiggsClassification* getHiggsTruthCategoryObject(const HepMC::GenEvent& HepMCEvent, const HTXS::HiggsProdMode prodMode) const override;
  private:
-   bool m_isInitialized;
+   mutable std::atomic<bool> m_isInitialized;
    bool m_outHistos;
 };
 
diff --git a/HLT/Trigger/TrigControl/TrigPSC/src/Psc.cxx b/HLT/Trigger/TrigControl/TrigPSC/src/Psc.cxx
index fb3b3d883960761eb81fe1a27d28f3e5593a25e0..f25ed2f26f4ec43c0252eebdff403850a09839e0 100644
--- a/HLT/Trigger/TrigControl/TrigPSC/src/Psc.cxx
+++ b/HLT/Trigger/TrigControl/TrigPSC/src/Psc.cxx
@@ -44,8 +44,6 @@
 
 #include <boost/property_tree/xml_parser.hpp>
 
-#include "CxxUtils/checker_macros.h"
-
 using namespace boost::property_tree;
 
 namespace
diff --git a/HLT/Trigger/TrigControl/TrigServices/src/HltROBDataProviderSvc.cxx b/HLT/Trigger/TrigControl/TrigServices/src/HltROBDataProviderSvc.cxx
index 4c66982eb6fa0da7c92d35287e1ae4ab185a3c57..8d12be750c08fb9f4eb81ef9c34006be91bb8923 100644
--- a/HLT/Trigger/TrigControl/TrigServices/src/HltROBDataProviderSvc.cxx
+++ b/HLT/Trigger/TrigControl/TrigServices/src/HltROBDataProviderSvc.cxx
@@ -382,18 +382,42 @@ void HltROBDataProviderSvc::getROBData(const EventContext& context,
       monitorData.requested_ROBs[robFrag->source_id()] = robmap_getRobData(*robFrag, robmonitor::HLT_CACHED);
     }
 
+    // Add the ROBs to the cache/rob map and collect ignored robs
+    std::set<uint32_t> robIds_ignored;
+    eventCache_addRobData(cache, robFragments_missing, robIds_ignored);
+
     // Monitor DCM ROBs
     for (const hltinterface::DCM_ROBInfo& robInfo : vRobInfos) {
-      monitorData.requested_ROBs[robInfo.robFragment.source_id()] = robmap_getRobData(robInfo.robFragment, 
-        robInfo.robIsCached ? robmonitor::DCM_CACHED : robmonitor::RETRIEVED);
+      robmonitor::ROBHistory status;
+
+      // Check ROB history
+      if (robIds_ignored.find(robInfo.robFragment.source_id()) != robIds_ignored.end()) {
+        status = robmonitor::IGNORED;
+      }
+      else {
+        status = robInfo.robIsCached ? robmonitor::DCM_CACHED : robmonitor::RETRIEVED;
+      }
+
+      monitorData.requested_ROBs[robInfo.robFragment.source_id()] = robmap_getRobData(robInfo.robFragment, status);
     }
-  }
 
-  // add the ROBs to the cache/rob map
-  eventCache_addRobData(cache, robFragments_missing) ;
+    // Return all the requested ROB fragments from the cache and collect disabled ROBs
+    std::set<uint32_t> robIds_disabled;
+    eventCache_checkRobListToCache(cache, robIds, robFragments, robIds_missing, robIds_disabled);
 
-  // return all the requested ROB fragments from the cache
-  eventCache_checkRobListToCache(cache, robIds, robFragments, robIds_missing) ;
+    // Fill disabled ROBs
+    for (uint32_t robId : robIds_disabled) {
+        monitorData.requested_ROBs[robId] = robmonitor::ROBDataStruct(robId);
+        monitorData.requested_ROBs[robId].rob_history = robmonitor::DISABLED;
+    }
+  }
+  else {
+    // add the ROBs to the cache/rob map
+    eventCache_addRobData(cache, robFragments_missing) ;
+
+    // return all the requested ROB fragments from the cache
+    eventCache_checkRobListToCache(cache, robIds, robFragments, robIds_missing) ;
+  }
 
   // Save ROS processing time and pass ROS data to CostMonitor
   if (m_doCostMonitoring && m_trigCostSvcHandle->isMonitoredEvent(context, /*includeMultiSlot =*/ false)) {
@@ -414,8 +438,8 @@ robmonitor::ROBDataStruct HltROBDataProviderSvc::robmap_getRobData(const ROBF& r
 {
   auto robData = robmonitor::ROBDataStruct(robFrag.source_id());
   robData.rob_size = robFrag.fragment_size_word();
-  robData.rob_history = robStatus;
   robData.rob_status_word = robFrag.nstatus() ? robFrag.status()[0] : 0;
+  robData.rob_history = robStatus;
 
   return robData;
 }
@@ -579,7 +603,8 @@ void HltROBDataProviderSvc::eventCache_clear(EventCache* cache)
 
 void HltROBDataProviderSvc::eventCache_checkRobListToCache(EventCache* cache, const std::vector<uint32_t>& robIds_toCheck, 
 							     std::vector<const ROBF*>& robFragments_inCache, 
-							     std::vector<uint32_t>& robIds_missing )
+							     std::vector<uint32_t>& robIds_missing,
+                   std::optional<std::reference_wrapper<std::set<uint32_t>>> robIds_disabled )
 {
   ATH_MSG_VERBOSE("start of " << __FUNCTION__ << " number of ROB Ids to check = " << robIds_toCheck.size());
 
@@ -613,12 +638,15 @@ void HltROBDataProviderSvc::eventCache_checkRobListToCache(EventCache* cache, co
 
     // check if ROB is actually enabled for readout
     if (m_enabledROBs.value().size() != 0) {
-      std::vector<uint32_t>::const_iterator rob_enabled_it =
-	std::find(m_enabledROBs.value().begin(), m_enabledROBs.value().end(),id);
+      std::vector<uint32_t>::const_iterator rob_enabled_it = 
+        std::find(m_enabledROBs.value().begin(), m_enabledROBs.value().end(),id);
       if(rob_enabled_it == m_enabledROBs.value().end()) {
-	ATH_MSG_VERBOSE(__FUNCTION__ << " ROB Id : 0x" << MSG::hex << id << MSG::dec
-		      << " will be not added, since it is not on the list of enabled ROBs.");
-	continue;
+        ATH_MSG_VERBOSE(__FUNCTION__ << " ROB Id : 0x" << MSG::hex << id << MSG::dec
+                << " will be not added, since it is not on the list of enabled ROBs.");
+        if (robIds_disabled) {
+          robIds_disabled->get().insert(id);
+        }
+        continue;
       }
     }
 
@@ -628,7 +656,8 @@ void HltROBDataProviderSvc::eventCache_checkRobListToCache(EventCache* cache, co
   } // end loop over input ROB Ids to check
 }
 
-void HltROBDataProviderSvc::eventCache_addRobData(EventCache* cache, const std::vector<ROBF>& robFragments)
+void HltROBDataProviderSvc::eventCache_addRobData(EventCache* cache, const std::vector<ROBF>& robFragments,
+              std::optional<std::reference_wrapper<std::set<uint32_t>>> robIds_ignored)
 {
   ATH_MSG_VERBOSE("start of " << __FUNCTION__ << " number of ROB fragments to add = " << robFragments.size());
 
@@ -679,6 +708,9 @@ void HltROBDataProviderSvc::eventCache_addRobData(EventCache* cache, const std::
 			<< " and Specific Status Code = 0x" << std::setw(4) << tmpstatus.specific() << MSG::dec
 			<< " removed for (global Id, L1 Id) = (" << cache->globalEventNumber << "," << cache->currentLvl1ID <<")" );
       }
+      if (robIds_ignored) {
+        robIds_ignored->get().insert(id);
+      }
       continue;
     }
 
diff --git a/HLT/Trigger/TrigControl/TrigServices/src/HltROBDataProviderSvc.h b/HLT/Trigger/TrigControl/TrigServices/src/HltROBDataProviderSvc.h
index 72ae025fffbcb89bf9f6894cb92f2f967a2fabef..bdf1a69f3fe686f9b527a0dc319299dc1f7f917f 100644
--- a/HLT/Trigger/TrigControl/TrigServices/src/HltROBDataProviderSvc.h
+++ b/HLT/Trigger/TrigControl/TrigServices/src/HltROBDataProviderSvc.h
@@ -203,14 +203,19 @@ private:
   /// output:
   ///     vector of ROB fragments available already in cache
   ///     vector of ROB Ids missing in cache
+  ///     set of disabled ROBs
   void eventCache_checkRobListToCache(EventCache*, const std::vector<uint32_t>&, 
-				      std::vector<const ROBF*>&, std::vector<uint32_t>& );
+				      std::vector<const ROBF*>&, std::vector<uint32_t>&, 
+              std::optional<std::reference_wrapper<std::set<uint32_t>>> robIds_disabled = std::nullopt);
 
   /// method to add ROB fragments to an event cache in a slot
   /// input:
   ///     pointer to cache
   ///     vector of ROB fragments to add to the cache
-  void eventCache_addRobData(EventCache*, const std::vector<ROBF>&) ;
+  /// output:
+  ///     set of ignored ROBs
+  void eventCache_addRobData(EventCache*, const std::vector<ROBF>&,
+              std::optional<std::reference_wrapper<std::set<uint32_t>>> robIds_ignored = std::nullopt) ;
 
   /// Monitoring tool
   ToolHandle<GenericMonitoringTool> m_monTool{this, "MonTool", "", "Monitoring tool"};
diff --git a/HLT/Trigger/TrigMonitoring/TrigOnlineMonitor/share/TrigL1TopoWriteValData.py b/HLT/Trigger/TrigMonitoring/TrigOnlineMonitor/share/TrigL1TopoWriteValData.py
index cbf3c84a238709c06a32a00ba13d263bc5f6d53a..8388b47ca14b9274ba2bdbc3b650abc648faa0a0 100755
--- a/HLT/Trigger/TrigMonitoring/TrigOnlineMonitor/share/TrigL1TopoWriteValData.py
+++ b/HLT/Trigger/TrigMonitoring/TrigOnlineMonitor/share/TrigL1TopoWriteValData.py
@@ -55,10 +55,10 @@ else:
 
 
 # Add an instance of TrigL1TopoWriteValData to the sequence
-from AthenaCommon import CfgMgr
-l1topoWriteValData = CfgMgr.TrigL1TopoWriteValData("l1topoWriteValData")
-topSequence += l1topoWriteValData
-log.debug("added l1topoWriteValData to topSequence")
+#from AthenaCommon import CfgMgr
+#l1topoWriteValData = CfgMgr.TrigL1TopoWriteValData("l1topoWriteValData")
+#topSequence += l1topoWriteValData
+#log.debug("added l1topoWriteValData to topSequence")
 #l1topoWriteValData.OutputLevel=1
 
 #--------------------------------------------------------------
diff --git a/InnerDetector/InDetConditions/BeamSpotConditions/python/__init__.py b/InnerDetector/InDetConditions/BeamSpotConditions/python/__init__.py
old mode 100644
new mode 100755
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/CMakeLists.txt b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/CMakeLists.txt
index ea2bc8b58e8e04b3e89b4bff131503dc6f44d2df..dc82c6166717846434209ec31f0ea492c0df3624 100644
--- a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/CMakeLists.txt
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/CMakeLists.txt
@@ -90,9 +90,33 @@ atlas_add_test( TestConfigNewConf
 atlas_add_test( TestDCSConditionsNewConf
                 SCRIPT python -m SCT_ConditionsAlgorithms.SCT_DCSConditionsTestAlgConfig
                 PROPERTIES TIMEOUT 600 )
+atlas_add_test( TestLinkMaskingNewConf
+                SCRIPT share/TestLinkMaskingNewConf.sh
+                PROPERTIES TIMEOUT 600 )
+atlas_add_test( TestMajorityNewConf
+                SCRIPT python -m SCT_ConditionsAlgorithms.SCT_MajorityConditionsTestAlgConfig
+                PROPERTIES TIMEOUT 600 )
+atlas_add_test( TestModuleVetoNewConf
+                SCRIPT python -m SCT_ConditionsAlgorithms.SCT_ModuleVetoTestAlgConfig
+                PROPERTIES TIMEOUT 600 )
 atlas_add_test( TestMonReadNewConf
                 SCRIPT python -m SCT_ConditionsAlgorithms.SCT_MonitorConditionsTestAlgConfig
                 PROPERTIES TIMEOUT 600 )
+atlas_add_test( TestParametersNewConf
+                SCRIPT python -m SCT_ConditionsAlgorithms.SCT_ConditionsParameterTestAlgConfig
+                PROPERTIES TIMEOUT 600 )
+atlas_add_test( TestReadoutNewConf
+                SCRIPT python -m SCT_ConditionsAlgorithms.SCT_ReadoutTestAlgConfig
+                PROPERTIES TIMEOUT 600 )
+atlas_add_test( TestRodVetoNewConf
+                SCRIPT python -m SCT_ConditionsAlgorithms.SCT_RODVetoTestAlgConfig
+                PROPERTIES TIMEOUT 600 )
+atlas_add_test( TestSensorsNewConf
+                SCRIPT python -m SCT_ConditionsAlgorithms.SCT_SensorsTestAlgConfig
+                PROPERTIES TIMEOUT 600 )
+atlas_add_test( TestStripVetoNewConf
+                SCRIPT python -m SCT_ConditionsAlgorithms.SCT_StripVetoTestAlgConfig
+                PROPERTIES TIMEOUT 600 )
 atlas_add_test( TestSummaryNewConf
                 SCRIPT python -m SCT_ConditionsAlgorithms.SCT_ConditionsSummaryTestAlgConfig
                 PROPERTIES TIMEOUT 600 )
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_ConditionsParameterTestAlgConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_ConditionsParameterTestAlgConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..2f0535c323d2c1ea8a35fe6494be95f2c152f32a
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_ConditionsParameterTestAlgConfig.py
@@ -0,0 +1,43 @@
+"""Define method to configure and test SCT_ConditionsParameterTestAlg
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+
+def SCT_ConditionsParameterTestAlgCfg(flags, name="SCT_ConditionsParameterTestAlg", **kwargs):
+    """Return a configured SCT_ConditionsParameterTestAlg"""
+    acc = ComponentAccumulator()
+    from SCT_ConditionsTools.SCT_ConditionsParameterConfig import SCT_ConditionsParameterCfg
+    kwargs.setdefault("SCT_ConditionsParameterTool", acc.popToolsAndMerge(SCT_ConditionsParameterCfg(flags)))
+    acc.addEventAlgo(CompFactory.SCT_ConditionsParameterTestAlg(**kwargs))
+    return acc
+
+if __name__=="__main__":
+    from AthenaCommon.Logging import log
+    from AthenaCommon.Constants import INFO
+    log.setLevel(INFO)
+
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior=1
+    
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.isMC = False
+    ConfigFlags.Input.ProjectName = "data12_8TeV"
+    ConfigFlags.Input.RunNumber = 215643
+    ConfigFlags.addFlag("Input.InitialTimeStamp", 1354748400) # LB 469 of run 215643, 2012-12-05 @ 11:00pm (UTC)
+    ConfigFlags.IOVDb.GlobalTag = "COMCOND-BLKPA-RUN1-09"
+    ConfigFlags.IOVDb.DatabaseInstance = "COMP200"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R1-2012-03-00-00"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    cfg = MainServicesCfg(ConfigFlags)
+
+    from McEventSelector.McEventSelectorConfig import McEventSelectorCfg
+    cfg.merge(McEventSelectorCfg(ConfigFlags))
+
+    cfg.merge(SCT_ConditionsParameterTestAlgCfg(ConfigFlags))
+
+    cfg.run(maxEvents=20)
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_LinkMaskingTestAlgConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_LinkMaskingTestAlgConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..02fe8f9590e969d2852979547e3d2ea75a213589
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_LinkMaskingTestAlgConfig.py
@@ -0,0 +1,42 @@
+"""Define method to configure and test SCT_LinkMaskingTestAlg
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+
+def SCT_LinkMaskingTestAlgCfg(flags, name="SCT_LinkMaskingTestAlg", **kwargs):
+    """Return a configured SCT_LinkMaskingTestAlg"""
+    acc = ComponentAccumulator()
+    from SCT_ConditionsTools.SCT_LinkMaskingConfig import SCT_LinkMaskingCfg
+    kwargs.setdefault("LinkMaskingTool", acc.popToolsAndMerge(SCT_LinkMaskingCfg(flags)))
+    acc.addEventAlgo(CompFactory.SCT_LinkMaskingTestAlg(**kwargs))
+    return acc
+
+if __name__=="__main__":
+    from AthenaCommon.Logging import log
+    from AthenaCommon.Constants import INFO
+    log.setLevel(INFO)
+
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior=1
+    
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.isMC = False
+    ConfigFlags.Input.ProjectName = "data16_13TeV"
+    ConfigFlags.Input.RunNumber = 310809
+    ConfigFlags.addFlag("Input.InitialTimeStamp", 1476741326) # LB 18 of run 310809, 10/17/2016 @ 9:55pm (UTC)
+    ConfigFlags.IOVDb.GlobalTag = "CONDBR2-BLKPA-2017-10"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R2-2016-01-00-01"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    cfg = MainServicesCfg(ConfigFlags)
+
+    from McEventSelector.McEventSelectorConfig import McEventSelectorCfg
+    cfg.merge(McEventSelectorCfg(ConfigFlags))
+
+    cfg.merge(SCT_LinkMaskingTestAlgCfg(ConfigFlags))
+
+    cfg.run(maxEvents=20)
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_MajorityConditionsTestAlgConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_MajorityConditionsTestAlgConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..5dc62a8bb0ea0ba5eccbd9ecf7c4ecc8379b2a2a
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_MajorityConditionsTestAlgConfig.py
@@ -0,0 +1,42 @@
+"""Define method to configure and test SCT_MajorityConditionsTestAlg
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+
+def SCT_MajorityConditionsTestAlgCfg(flags, name="SCT_MajorityConditionsTestAlg", **kwargs):
+    """Return a configured SCT_MajorityConditionsTestAlg"""
+    acc = ComponentAccumulator()
+    from SCT_ConditionsTools.SCT_MajorityConditionsConfig import SCT_MajorityConditionsCfg
+    kwargs.setdefault("MajorityTool", acc.popToolsAndMerge(SCT_MajorityConditionsCfg(flags)))
+    acc.addEventAlgo(CompFactory.SCT_MajorityConditionsTestAlg(**kwargs))
+    return acc
+
+if __name__=="__main__":
+    from AthenaCommon.Logging import log
+    from AthenaCommon.Constants import INFO
+    log.setLevel(INFO)
+
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior=1
+    
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.isMC = False
+    ConfigFlags.Input.ProjectName = "data16_13TeV"
+    ConfigFlags.Input.RunNumber = 310809
+    ConfigFlags.addFlag("Input.InitialTimeStamp", 1476741326) # LB 18 of run 310809, 10/17/2016 @ 9:55pm (UTC)
+    ConfigFlags.IOVDb.GlobalTag = "CONDBR2-BLKPA-2017-06"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R2-2016-01-00-01"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    cfg = MainServicesCfg(ConfigFlags)
+
+    from McEventSelector.McEventSelectorConfig import McEventSelectorCfg
+    cfg.merge(McEventSelectorCfg(ConfigFlags))
+
+    cfg.merge(SCT_MajorityConditionsTestAlgCfg(ConfigFlags))
+
+    cfg.run(maxEvents=20)
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_ModuleVetoTestAlgConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_ModuleVetoTestAlgConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..65ca7cd97ffa929bd3ab49070558173b7965d3b2
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_ModuleVetoTestAlgConfig.py
@@ -0,0 +1,52 @@
+"""Define method to configure and test SCT_ModuleVetoTestAlg
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+
+def SCT_StripVetoTestAlgCfg(flags, name="SCT_ModuleVetoTestAlg", **kwargs):
+    """Return a configured SCT_ModuleVetoTestAlg"""
+    acc = ComponentAccumulator()
+    from SCT_ConditionsTools.SCT_ModuleVetoConfig import SCT_ModuleVetoCfg
+    acc.addEventAlgo(CompFactory.SCT_ModuleVetoTestAlg(name=name,
+                                                       ModuleVetoTool=acc.popToolsAndMerge(SCT_ModuleVetoCfg(flags, **kwargs))))
+    return acc
+
+if __name__=="__main__":
+    from AthenaCommon.Logging import log
+    from AthenaCommon.Constants import INFO
+    log.setLevel(INFO)
+
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior=1
+    
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.isMC = True
+    ConfigFlags.Input.ProjectName = "mc16_13TeV"
+    ConfigFlags.Input.RunNumber = 300000 # MC16c 2017 run number
+    ConfigFlags.addFlag("Input.InitialTimeStamp", 1500000000) # MC16c 2017 time stamp
+    ConfigFlags.IOVDb.GlobalTag = "OFLCOND-MC16-SDR-18"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R2-2015-03-01-00"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    cfg = MainServicesCfg(ConfigFlags)
+
+    from McEventSelector.McEventSelectorConfig import McEventSelectorCfg
+    cfg.merge(McEventSelectorCfg(ConfigFlags))
+
+    kwargs = {}
+
+    ### Use COOL database for SCT_ModuleVetoTool
+    kwargs["useDB"] = True # False
+    if kwargs["useDB"]:
+        kwargs["folderTag"] = "SCTManualBadModules-000-00"
+        kwargs["BadModuleIdentifiers"] = ["database"]
+    else:
+        kwargs["BadModuleIdentifiers"] = ["1", "2"]
+
+    cfg.merge(SCT_StripVetoTestAlgCfg(ConfigFlags, **kwargs))
+
+    cfg.run(maxEvents=20)
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_RODVetoTestAlgConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_RODVetoTestAlgConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..7416073803c19eddbd0d027ceb01ad909601c564
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_RODVetoTestAlgConfig.py
@@ -0,0 +1,45 @@
+"""Define method to configure and test SCT_RODVetoTestAlg
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+
+def SCT_RODVetoTestAlgCfg(flags, name="SCT_RODVetoTestAlg", **kwargs):
+    """Return a configured SCT_RODVetoTestAlg"""
+    acc = ComponentAccumulator()
+    from SCT_ConditionsTools.SCT_RODVetoConfig import SCT_RODVetoCfg
+    algArgs = {}
+    algArgs["SCT_RODVetoTool"] = acc.popToolsAndMerge(SCT_RODVetoCfg(flags, **kwargs))
+    acc.addEventAlgo(CompFactory.SCT_RODVetoTestAlg(**algArgs))
+    return acc
+
+if __name__=="__main__":
+    from AthenaCommon.Logging import log
+    from AthenaCommon.Constants import INFO
+    log.setLevel(INFO)
+
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior=1
+    
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.isMC = True
+    ConfigFlags.Input.ProjectName = "mc16_13TeV"
+    ConfigFlags.Input.RunNumber = 300000 # MC16c 2017 run number
+    ConfigFlags.addFlag("Input.InitialTimeStamp", 1500000000)
+    ConfigFlags.IOVDb.GlobalTag = "OFLCOND-MC16-SDR-18"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R2-2015-03-01-00"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    cfg = MainServicesCfg(ConfigFlags)
+
+    from McEventSelector.McEventSelectorConfig import McEventSelectorCfg
+    cfg.merge(McEventSelectorCfg(ConfigFlags))
+
+    kwargs = {}
+    kwargs["BadRODIds"] = [0x240100, 0x240030] # RODs to be vetoed
+    cfg.merge(SCT_RODVetoTestAlgCfg(ConfigFlags, **kwargs))
+
+    cfg.run(maxEvents=20)
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_ReadoutTestAlgConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_ReadoutTestAlgConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..ed4a7cc2f0f760b7c8c8be42d0ef3c97cbf173b3
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_ReadoutTestAlgConfig.py
@@ -0,0 +1,81 @@
+"""Define method to configure and test SCT_ReadoutTestAlg
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+
+def SCT_ReadoutTestAlgCfg(flags, name="SCT_ReadoutTestAlg", **kwargs):
+    """Return a configured SCT_ReadoutTestAlg"""
+    acc = ComponentAccumulator()
+    from InDetConfig.InDetRecToolConfig import SCT_ReadoutToolCfg
+    kwargs.setdefault("SCT_ReadoutTool", acc.popToolsAndMerge(SCT_ReadoutToolCfg(flags)))
+
+    # Module type and link status
+    # kwargs.setdefault("ModuleId", 143704064) # Endcap (default is barrel)
+    # kwargs.setdefault("LinkOStatus", False)  # Link 0 disabled (default is 'good')
+    # kwargs.setdefault("Link1Status", False)  # Link 1 disabled (default is 'good')
+
+    # Some possible chip configs strings
+    masterChip       = "10110000000001"
+    slaveChip        = "10110000000101"
+    # slaveChipIn1     = "10110000010101"
+    # slaveChipOut1    = "10110000001101"
+    endChip          = "10110000000111"
+    # masterAndEndChip = "10110000000011"
+
+    # Some test module configs
+    defaultLink            = [masterChip] + [slaveChip]*4 + [endChip]
+    # noEndLink              = [masterChip] + [slaveChip]*5
+    # endAt2Link             = [masterChip] + [slaveChip] + [endChip] + [slaveChip]*3
+    # bypass2Link            = [masterChip] + [slaveChipIn1] + [slaveChip] + [slaveChipOut1]  + [slaveChip] + [endChip]
+    # master3Link            = [slaveChip]*3 + [masterChip] + [slaveChip] + [endChip]
+    # noMapped4Link          = [masterChip] + [slaveChip]*3 + [slaveChipIn1] + [endChip]
+    # nothingTalkingTo2Link  = [masterChip] + [slaveChip] + [slaveChipIn1] + [slaveChip]*2 + [endChip]
+    # allExcept1Link0Mod     = [masterChip] + [slaveChip]*4 + [slaveChipIn1] + [slaveChipOut1] + [masterAndEndChip] + [slaveChip]*3 + [endChip]
+    # allLink0EndcapMod      = [masterChip] + [slaveChip]*10 + [endChip]
+    # allLink1EndcapMod      = [slaveChip]*5 + [endChip] + [masterChip] + [slaveChip]*5
+    # infiniteEndcapMod      = [masterChip] + [slaveChip]*11
+
+    kwargs.setdefault("ChipConfigurationList", defaultLink*2)
+    # kwargs.setdefault("ChipConfigurationList", defaultLink + endAt2Link)
+    # kwargs.setdefault("ChipConfigurationList", bypass2Link + defaultLink)
+    # kwargs.setdefault("ChipConfigurationList", master3Link + defaultLink)
+    # kwargs.setdefault("ChipConfigurationList", defaultLink + noMapped4Link)
+    # kwargs.setdefault("ChipConfigurationList", defaultLink + nothingTalkingTo2Link)
+    # kwargs.setdefault("ChipConfigurationList", noEndLink + defaultLink)
+    # kwargs.setdefault("ChipConfigurationList", allExcept1Link1Mod)
+    # kwargs.setdefault("ChipConfigurationList", allLink0EndcapMod)
+    # kwargs.setdefault("ChipConfigurationList", allLink1EndcapMod)
+    # kwargs.setdefault("ChipConfigurationList", infiniteEndcapMod)
+
+    acc.addEventAlgo(CompFactory.SCT_ReadoutTestAlg(**kwargs))
+    return acc
+
+if __name__=="__main__":
+    from AthenaCommon.Logging import log
+    from AthenaCommon.Constants import INFO
+    log.setLevel(INFO)
+
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior=1
+    
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.isMC = True
+    ConfigFlags.Input.ProjectName = "mc16_13TeV"
+    ConfigFlags.Input.RunNumber = 300000 # MC16c 2017 run number
+    ConfigFlags.addFlag("Input.InitialTimeStamp", 1500000000)
+    ConfigFlags.IOVDb.GlobalTag = "OFLCOND-MC16-SDR-18"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R2-2015-03-01-00"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    cfg = MainServicesCfg(ConfigFlags)
+
+    from McEventSelector.McEventSelectorConfig import McEventSelectorCfg
+    cfg.merge(McEventSelectorCfg(ConfigFlags))
+
+    cfg.merge(SCT_ReadoutTestAlgCfg(ConfigFlags))
+
+    cfg.run(maxEvents=20)
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_SensorsTestAlgConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_SensorsTestAlgConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..0dbce8e2670babc79dffc1b29bf91cca8e0451bc
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_SensorsTestAlgConfig.py
@@ -0,0 +1,45 @@
+"""Define method to configure and test SCT_SensorsTestAlg
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+
+def SCT_MajorityConditionsTestAlgCfg(flags, name="SCT_SensorsTestAlg", **kwargs):
+    """Return a configured SCT_SensorsTestAlg"""
+    acc = ComponentAccumulator()
+    from SCT_ConditionsTools.SCT_SensorsConfig import SCT_SensorsCfg
+    kwargs.setdefault("SCT_SensorsTool", acc.popToolsAndMerge(SCT_SensorsCfg(flags, **kwargs)))
+    acc.addEventAlgo(CompFactory.SCT_SensorsTestAlg())
+    return acc
+
+if __name__=="__main__":
+    from AthenaCommon.Logging import log
+    from AthenaCommon.Constants import INFO
+    log.setLevel(INFO)
+
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior=1
+    
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.isMC = False
+    ConfigFlags.Input.ProjectName = "data12_8TeV"
+    ConfigFlags.Input.RunNumber = 142913
+    ConfigFlags.addFlag("Input.InitialTimeStamp", 1260630000) # During run 142913, 12/12/2009 @ 3:00pm (UTC)
+    ConfigFlags.IOVDb.GlobalTag = "COMCOND-BLKPA-RUN1-09"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R1-2012-03-00-00"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    cfg = MainServicesCfg(ConfigFlags)
+
+    from McEventSelector.McEventSelectorConfig import McEventSelectorCfg
+    cfg.merge(McEventSelectorCfg(ConfigFlags))
+
+    kwargs = {}
+    kwargs["folderTag"] = "SctSensors-Sep03-14"
+
+    cfg.merge(SCT_MajorityConditionsTestAlgCfg(ConfigFlags, **kwargs))
+
+    cfg.run(maxEvents=20)
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_StripVetoTestAlgConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_StripVetoTestAlgConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..56ff2c2cc52b6f2d77739f5c580012727f9937fd
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/python/SCT_StripVetoTestAlgConfig.py
@@ -0,0 +1,42 @@
+"""Define method to configure and test SCT_StripVetoTestAlg
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+
+def SCT_StripVetoTestAlgCfg(flags, name="SCT_StripVetoTestAlg", **kwargs):
+    """Return a configured SCT_SiliconConditionsTestAlg"""
+    acc = ComponentAccumulator()
+    from SCT_ConditionsTools.SCT_StripVetoConfig import SCT_StripVetoCfg
+    kwargs.setdefault("StripVetoTool", acc.popToolsAndMerge(SCT_StripVetoCfg(flags)))
+    acc.addEventAlgo(CompFactory.SCT_StripVetoTestAlg(name=name, **kwargs))
+    return acc
+
+if __name__=="__main__":
+    from AthenaCommon.Logging import log
+    from AthenaCommon.Constants import INFO
+    log.setLevel(INFO)
+
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior=1
+    
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.isMC = True
+    ConfigFlags.Input.ProjectName = "mc16_13TeV"
+    ConfigFlags.Input.RunNumber = 300000 # MC16c 2017 run number
+    ConfigFlags.addFlag("Input.InitialTimeStamp", 1500000000) # MC16c 2017 time stamp
+    ConfigFlags.IOVDb.GlobalTag = "OFLCOND-MC16-SDR-18"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R2-2015-03-01-00"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    cfg = MainServicesCfg(ConfigFlags)
+
+    from McEventSelector.McEventSelectorConfig import McEventSelectorCfg
+    cfg.merge(McEventSelectorCfg(ConfigFlags))
+
+    cfg.merge(SCT_StripVetoTestAlgCfg(ConfigFlags))
+
+    cfg.run(maxEvents=20)
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/share/TestLinkMaskingNewConf.sh b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/share/TestLinkMaskingNewConf.sh
new file mode 100755
index 0000000000000000000000000000000000000000..501e5fa0c87e01b1407a6fa145473b27d8192829
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/share/TestLinkMaskingNewConf.sh
@@ -0,0 +1,4 @@
+get_files -scripts createLinkMaskingSQLiteFile.py
+python createLinkMaskingSQLiteFile.py
+ln -s LinkMasking.db mycool.db # mycool.db is hard coded in Database/IOVDbSvc/python/IOVDbSvcConfig.py
+python -m SCT_ConditionsAlgorithms.SCT_LinkMaskingTestAlgConfig
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/share/testModuleVeto.py b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/share/testModuleVeto.py
index 015eb1526c8c8274b30f1c6840d9500d76e705c8..91c81d10bab00c757805e40396f9eb26e715862a 100644
--- a/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/share/testModuleVeto.py
+++ b/InnerDetector/InDetConditions/SCT_ConditionsAlgorithms/share/testModuleVeto.py
@@ -76,7 +76,7 @@ IOVDbSvc = Service("IOVDbSvc")
 from IOVDbSvc.CondDB import conddb
 IOVDbSvc.GlobalTag="OFLCOND-MC16-SDR-18"
 
-### Use COOL database for SCT_ModuleVetoSvc
+### Use COOL database for SCT_ModuleVetoTool
 useDB = True # False
 
 from SCT_ConditionsTools.SCT_ModuleVetoToolSetup import SCT_ModuleVetoToolSetup
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_ConditionsParameterConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_ConditionsParameterConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..c33bb65e0327efeccefe9656f8eb9d8252927610
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_ConditionsParameterConfig.py
@@ -0,0 +1,34 @@
+"""Define methods to configure SCT_ConditionsParameter
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+from IOVDbSvc.IOVDbSvcConfig import addFolders
+from AtlasGeoModel.GeoModelConfig import GeoModelCfg
+from InDetConfig.InDetRecToolConfig import SCT_CablingToolCfg
+
+def SCT_ConditionsParameterCfg(flags, name="SCT_ConditionsParameter", **kwargs):
+    """Configure necessary condition folder, condition algorithm 
+       for SCT_ConditionsParameterTool and return it.
+    """
+    acc = ComponentAccumulator()
+
+    # For SCT_ID used in SCT_CablingTool
+    acc.merge(GeoModelCfg(flags))
+
+    # Condition folder
+    folder = "/SCT/DAQ/Configuration/Chip"
+    dbInstance = "SCT"
+    acc.merge(addFolders(flags, folder, dbInstance, className="CondAttrListVec"))
+
+    # Condition algorithm
+    alg = CompFactory.SCT_ConditionsParameterCondAlg(name=name+"CondAlg",
+                                                     ReadKey=folder,
+                                                     SCT_CablingTool=acc.popToolsAndMerge(SCT_CablingToolCfg(flags)))
+    acc.addCondAlgo(alg)
+
+    # Condition tool
+    acc.setPrivateTools(CompFactory.SCT_ConditionsParameterTool(name=name+"Tool"))
+
+    return acc
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_LinkMaskingConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_LinkMaskingConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..d0acba43f9538ffb71c2ccb8dab7ae5ad95cc9df
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_LinkMaskingConfig.py
@@ -0,0 +1,34 @@
+"""Define methods to configure SCT_LinkMaskingTool
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+from AtlasGeoModel.GeoModelConfig import GeoModelCfg
+from IOVDbSvc.IOVDbSvcConfig import addFolders
+
+def SCT_LinkMaskingCfg(flags, name="SCT_LinkMasking", **kwargs):
+    """Configure necessary condition folder, condition algorithm
+       for SCT_LinkMaskingTool and return it.
+    """
+    acc = ComponentAccumulator()
+
+    # For SCT_ID used in SCT_LinkMaskingTool
+    acc.merge(GeoModelCfg(flags))
+
+    # Condition folders
+    folder = "/purple/pants"
+    # mycool.db is hard coded in Database/IOVDbSvc/python/IOVDbSvcConfig.py
+    dbConnection = "<dbConnection>sqlite://;schema=mycool.db;dbname=CONDBR2</dbConnection>"
+    acc.merge(addFolders(configFlags=flags, folderstrings=folder, className="CondAttrListCollection", db=dbConnection))
+
+    # Condition algorithm
+    kwargs.setdefault("ReadKey", folder)
+    alg = CompFactory.SCT_LinkMaskingCondAlg(name=name+"CondAlg", **kwargs)
+    acc.addCondAlgo(alg)
+
+    # Condition tool
+    acc.merge(GeoModelCfg(flags)) # For SCT_ID used in SCT_DCSConditionsTool
+    acc.setPrivateTools(CompFactory.SCT_LinkMaskingTool(name=name+"Tool"))
+
+    return acc
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_MajorityConditionsConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_MajorityConditionsConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..0d16a135d517bc1def9125045235d9f177b738a6
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_MajorityConditionsConfig.py
@@ -0,0 +1,26 @@
+"""Define methods to configure SCT_MajorityConditions
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+from IOVDbSvc.IOVDbSvcConfig import addFolders
+
+def SCT_MajorityConditionsCfg(flags, name="InDetSCT_MajorityConditions", **kwargs):
+    """Configure necessary condition folder, condition algorithm
+       for SCT_MajorityConditionsTool and return it.
+    """
+    acc = ComponentAccumulator()
+
+    # Condition folder
+    folder = "/SCT/DCS/MAJ"
+    dbInstance = "DCS_OFL"
+    
+    # Condition algorithm
+    acc.merge(addFolders(flags, folder, dbInstance, className="CondAttrListCollection"))
+    acc.addCondAlgo(CompFactory.SCT_MajorityCondAlg())
+
+    # Condition tool
+    acc.setPrivateTools(CompFactory.SCT_MajorityConditionsTool(name=name+"Tool"))
+
+    return acc
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_ModuleVetoConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_ModuleVetoConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..95201b6af17024ac8692c04aa8726daa5f61c0f7
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_ModuleVetoConfig.py
@@ -0,0 +1,33 @@
+"""Define methods to configure SCT_ModuleVetoTool
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+from AtlasGeoModel.GeoModelConfig import GeoModelCfg
+from IOVDbSvc.IOVDbSvcConfig import addFolders
+
+def SCT_ModuleVetoCfg(flags, name="InDetSCT_ModuleVeto", **kwargs):
+    """Return a ComponentAccumulator configured for SCT_ModuleVetoTool
+    """
+    acc = ComponentAccumulator()
+
+    # For SCT_ID used in SCT_ModuleVetoTool
+    acc.merge(GeoModelCfg(flags))
+
+    if kwargs["useDB"]:
+        # Condition folder
+        acc.merge(addFolders(configFlags=flags,
+                             folderstrings="/SCT/Manual/BadModules",
+                             detDb="SCT_OFL",
+                             className="AthenaAttributeList",
+                             tag=kwargs["folderTag"]))
+        # Condition algorithm
+        acc.addCondAlgo(CompFactory.SCT_ModuleVetoCondAlg())
+
+    # Condition tool
+    toolArgs = {}
+    toolArgs["BadModuleIdentifiers"] = kwargs["BadModuleIdentifiers"]
+    acc.setPrivateTools(CompFactory.SCT_ModuleVetoTool(name=name+"Tool", **toolArgs))
+
+    return acc
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_RODVetoConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_RODVetoConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..86b62b2f39eaca55cb76aea6460750b8b6773e39
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_RODVetoConfig.py
@@ -0,0 +1,29 @@
+"""Define methods to configure SCT_RODVeto
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+from AtlasGeoModel.GeoModelConfig import GeoModelCfg
+from InDetConfig.InDetRecToolConfig import SCT_CablingToolCfg
+
+def SCT_RODVetoCfg(flags, name="SCT_RODVeto", **kwargs):
+    """Configure necessary condition folders, condition algorithms 
+       for SCT_DCSConditionsTool and return it.
+    """
+    acc = ComponentAccumulator()
+
+    # For SCT_ID used in SCT_RODVetoCondAlg and SCT_RODVetoTool
+    acc.merge(GeoModelCfg(flags))
+
+    # For SCT_CablingTool used in SCT_RODVetoCondAlg
+    kwargs.setdefault("SCT_CablingTool", acc.popToolsAndMerge(SCT_CablingToolCfg(flags)))
+
+    # Condition algorithm (actually event algorithm)
+    alg = CompFactory.SCT_RODVetoCondAlg(name=name+"CondAlg", **kwargs)
+    acc.addEventAlgo(alg)
+
+    # Condition tool
+    acc.setPrivateTools(CompFactory.SCT_RODVetoTool(name=name+"Tool"))
+
+    return acc
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_SensorsConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_SensorsConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..cea909b3bfc2de1c4b7ad4e5b657520da709edd2
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_SensorsConfig.py
@@ -0,0 +1,30 @@
+"""Define methods to configure SCT_Sensors
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+from IOVDbSvc.IOVDbSvcConfig import addFolders
+
+def SCT_SensorsCfg(flags, name="SCT_Sensors", **kwargs):
+    """Configure necessary condition folder, condition algorithm
+       for SCT_MajorityConditionsTool and return it.
+    """
+    acc = ComponentAccumulator()
+
+    # Condition folder
+    folder = "/SCT/Sensors"
+    dbInstance = "SCT_OFL"
+
+    if "folderTag" in kwargs:
+        acc.merge(addFolders(flags, folder, dbInstance, className="CondAttrListCollection", tag=kwargs["folderTag"]))
+    else:
+        acc.merge(addFolders(flags, folder, dbInstance, className="CondAttrListCollection"))
+    
+    # Condition algorithm
+    acc.addCondAlgo(CompFactory.SCT_SensorsCondAlg())
+
+    # Condition tool
+    acc.setPrivateTools(CompFactory.SCT_SensorsTool(name=name+"Tool"))
+
+    return acc
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_StripVetoConfig.py b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_StripVetoConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..3bfbd151ac6f14c4bea30c1b34e966f3f8a91b9c
--- /dev/null
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/python/SCT_StripVetoConfig.py
@@ -0,0 +1,29 @@
+"""Define methods to configure SCT_StripVetoTool
+
+Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+"""
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory import CompFactory
+from AtlasGeoModel.GeoModelConfig import GeoModelCfg
+
+def SCT_StripVetoCfg(flags, name="SCT_StripVeto", **kwargs):
+    """Return a ComponentAccumulator configured for SCT_StripVetoTool
+    """
+    acc = ComponentAccumulator()
+
+    # For SCT_ID used in SCT_StripVetoTool
+    acc.merge(GeoModelCfg(flags))
+
+    # Condition tool
+    # Identifiers should be given as strings and decimal.
+    # Identifier::compact() method returns unsigned long long.
+    kwargs.setdefault("BadStripIdentifiers", ["576522359582752768",
+                                              "576522475009998848",
+                                              "576522475278434304",
+                                              # "576522475546869760",
+                                              # "576522475815305216",
+                                              # "576522476083740672",
+                                             ])
+    acc.setPrivateTools(CompFactory.SCT_StripVetoTool(name=name+"Tool", **kwargs))
+
+    return acc
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConditionsSummaryTool.cxx b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConditionsSummaryTool.cxx
index 573fee4b9c084bfecf2e9ac2052eb04dd88ce94f..931263fb47de037451d9cbf2baff7fb8e1c0c8b1 100644
--- a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConditionsSummaryTool.cxx
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConditionsSummaryTool.cxx
@@ -33,13 +33,6 @@ SCT_ConditionsSummaryTool::initialize() {
   return sc;
 }
 
-//Finalize
-StatusCode
-SCT_ConditionsSummaryTool::finalize() {
-  ATH_MSG_INFO("Thank-you for using the SCT_ConditionsSummaryTool, version " << PACKAGE_VERSION);
-  return StatusCode::SUCCESS;
-}
-
 bool
 SCT_ConditionsSummaryTool::isActive(const Identifier& elementId, const InDetConditions::Hierarchy h) const {
   return isGood(elementId, h);
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConditionsSummaryTool.h b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConditionsSummaryTool.h
index e22a2630e6d2d5448d9d621231bc8e0cd62f95c0..c6baa8060ae892dfba3f36f469610a29c89f5731 100644
--- a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConditionsSummaryTool.h
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConditionsSummaryTool.h
@@ -36,7 +36,6 @@ public:
   //@name Gaudi STool Implementation
   //@{
   virtual StatusCode initialize() override;          //!< Tool init
-  virtual StatusCode finalize() override;            //!< Tool finalize
   //@}
   
   //@name reimplemented from IInDetConditionsTool
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConfigurationConditionsTool.cxx b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConfigurationConditionsTool.cxx
index 01cb66d16d8cc6aafe95b64062d823ca5222a772..b5640e503f447e369f134ae75390c67820b246b4 100644
--- a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConfigurationConditionsTool.cxx
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConfigurationConditionsTool.cxx
@@ -17,7 +17,7 @@ SCT_ConfigurationConditionsTool::SCT_ConfigurationConditionsTool(const std::stri
 
 // Initialize
 StatusCode SCT_ConfigurationConditionsTool::initialize() {
-  ATH_MSG_INFO("Initializing configuration");
+  ATH_MSG_DEBUG("Initializing configuration");
 
   ATH_CHECK(detStore()->retrieve(m_pHelper, "SCT_ID"));
 
@@ -28,13 +28,6 @@ StatusCode SCT_ConfigurationConditionsTool::initialize() {
   return StatusCode::SUCCESS;
 }
 
-// Finalize
-StatusCode SCT_ConfigurationConditionsTool::finalize() {
-  ATH_MSG_INFO("Configuration finalize");
-
-  return StatusCode::SUCCESS;
-}
-
 // What level of element can this service report about
 bool SCT_ConfigurationConditionsTool::canReportAbout(InDetConditions::Hierarchy h) const {
   return (h == InDetConditions::SCT_STRIP or
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConfigurationConditionsTool.h b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConfigurationConditionsTool.h
index 9f99fd80841066ba2999a72978875712b51639cf..41125f081c17a87f1a4f614636b106728e651daa 100644
--- a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConfigurationConditionsTool.h
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_ConfigurationConditionsTool.h
@@ -1,12 +1,12 @@
 // -*- C++ -*-
 
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /**
  * @file SCT_ConfigurationConditionsTool.h
- * header file for service which reads SCT configuration from database
+ * header file for tool which reads SCT configuration from database
  * @author shaun.roe@cern.ch, gwilliam@mail.cern.ch
 **/
 
@@ -41,15 +41,14 @@ class SCT_ID;
 class SCT_ConfigurationConditionsTool: public extends<AthAlgTool, ISCT_ConfigurationConditionsTool> {
  public:
 
-  //@name Service methods
+  //@name Tool methods
   //@{
   SCT_ConfigurationConditionsTool(const std::string& type, const std::string& name, const IInterface* parent);
   virtual ~SCT_ConfigurationConditionsTool() = default;
   virtual StatusCode initialize() override;
-  virtual StatusCode finalize() override;
   //@}
   
-  /**Can the service report about the given component? (chip, module...)*/
+  /**Can the tool report about the given component? (chip, module...)*/
   virtual bool                          canReportAbout(InDetConditions::Hierarchy h) const override;
   
   /**Is the detector element good?*/
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_LinkMaskingTool.cxx b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_LinkMaskingTool.cxx
index 3f9b5493b2c165cd2f9cfc56af1696d5beb4248b..79eeb5244ef9b5050835d400c32142ea40e7d446 100644
--- a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_LinkMaskingTool.cxx
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_LinkMaskingTool.cxx
@@ -15,7 +15,7 @@ SCT_LinkMaskingTool::SCT_LinkMaskingTool(const std::string& type, const std::str
 
 // Initialize
 StatusCode SCT_LinkMaskingTool::initialize() {
-  ATH_MSG_INFO("Initializing configuration");
+  ATH_MSG_DEBUG("Initializing configuration");
 
   // Retrieve SCT ID helper
   if (detStore()->retrieve(m_sctHelper, "SCT_ID").isFailure()) {
@@ -29,12 +29,6 @@ StatusCode SCT_LinkMaskingTool::initialize() {
   return StatusCode::SUCCESS;
 }
 
-// Finalize
-StatusCode SCT_LinkMaskingTool::finalize() {
-  ATH_MSG_INFO("Configuration finalize");
-  return StatusCode::SUCCESS;
-}
-
 // What level of element can this service report about
 bool SCT_LinkMaskingTool::canReportAbout(InDetConditions::Hierarchy h) const {
   return (h==InDetConditions::SCT_SIDE or h==InDetConditions::DEFAULT); 
diff --git a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_LinkMaskingTool.h b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_LinkMaskingTool.h
index b5ad7ff6f4c6a121af70a9d3d9a213377394307e..a0c825173fe873a29142a4d3ed82dd3bce84dae4 100644
--- a/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_LinkMaskingTool.h
+++ b/InnerDetector/InDetConditions/SCT_ConditionsTools/src/SCT_LinkMaskingTool.h
@@ -1,7 +1,7 @@
 // -*- C++ -*-
 
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /**
@@ -38,7 +38,6 @@ public:
   SCT_LinkMaskingTool(const std::string& type, const std::string& name, const IInterface* parent);
   virtual ~SCT_LinkMaskingTool() = default;
   virtual StatusCode initialize() override;
-  virtual StatusCode finalize() override;
   //@}
   
   /**Can the service report about the given component? (chip, module...)*/
diff --git a/InnerDetector/InDetConfig/python/BackTrackingConfig.py b/InnerDetector/InDetConfig/python/BackTrackingConfig.py
index 940233ffa232f2d59ca6405c8bdec8fdb2d3c9c6..5d2714b8d588a25aaca0742a73e555b90b3bb0df 100644
--- a/InnerDetector/InDetConfig/python/BackTrackingConfig.py
+++ b/InnerDetector/InDetConfig/python/BackTrackingConfig.py
@@ -94,10 +94,9 @@ def TRT_SeededTrackFinder_ATLCfg(flags, name='InDetTRT_SeededTrackMaker', Tracki
     InDetSiComTrackFinder = acc.popToolsAndMerge(TC.SiCombinatorialTrackFinder_xkCfg(flags))
     acc.addPublicTool(InDetSiComTrackFinder)
 
-    InDetTRT_SeededSiRoadMaker = acc.popToolsAndMerge(SiDetElementsRoadMaker_xkCfg(flags, TrackingFlags=TrackingFlags))
-    acc.addPublicTool(InDetTRT_SeededSiRoadMaker)
-
     if (TrackingFlags.usePixel and TrackingFlags.useSCT) is not False:
+        InDetTRT_SeededSiRoadMaker = acc.popToolsAndMerge(SiDetElementsRoadMaker_xkCfg(flags, TrackingFlags=TrackingFlags))
+        acc.addPublicTool(InDetTRT_SeededSiRoadMaker)
         kwargs.setdefault("RoadTool", InDetTRT_SeededSiRoadMaker)
 
     #
@@ -155,8 +154,8 @@ def TRT_SeededTrackFinderCfg(flags, name='InDetTRT_SeededTrackFinder', TrackingF
         suffix = ''
         usePrdAssociationTool = False
 
-    InDetTrackFitter = acc.popToolsAndMerge(TC.InDetKalmanFitterCfg(flags))
-    acc.addPublicTool(InDetTrackFitter)
+    InDetTrackFitterBT = acc.popToolsAndMerge(TC.InDetTrackFitterBTCfg(flags))
+    acc.addPublicTool(InDetTrackFitterBT)
 
     InDetTrackSummaryToolNoHoleSearch = acc.popToolsAndMerge(TC.InDetTrackSummaryToolNoHoleSearchCfg(flags))
     acc.addPublicTool(InDetTrackSummaryToolNoHoleSearch)
@@ -174,7 +173,7 @@ def TRT_SeededTrackFinderCfg(flags, name='InDetTRT_SeededTrackFinder', TrackingF
                                                                                  InputCollections=InputCollections))
     acc.addPublicTool(InDetTRT_SeededTrackTool)
 
-    kwargs.setdefault("RefitterTool", InDetTrackFitter)
+    kwargs.setdefault("RefitterTool", InDetTrackFitterBT)
     kwargs.setdefault("TrackTool", InDetTRT_SeededTrackTool)
     kwargs.setdefault("PRDtoTrackMap", prefix+'PRDtoTrackMap'+suffix if usePrdAssociationTool else "")
     kwargs.setdefault("TrackSummaryTool", InDetTrackSummaryToolNoHoleSearch)
@@ -251,8 +250,8 @@ def SimpleAmbiguityProcessorToolCfg(flags, name='InDetTRT_SeededAmbiguityProcess
     #
     # --- load Ambiguity Processor
     #
-    InDetTrackFitter = acc.popToolsAndMerge(TC.InDetKalmanFitterCfg(flags))
-    acc.addPublicTool(InDetTrackFitter)
+    InDetTrackFitterBT = acc.popToolsAndMerge(TC.InDetTrackFitterBTCfg(flags))
+    acc.addPublicTool(InDetTrackFitterBT)
 
     InDetPRDtoTrackMapToolGangedPixels = TC.InDetPRDtoTrackMapToolGangedPixelsCfg(flags)
     acc.addPublicTool(InDetPRDtoTrackMapToolGangedPixels)
@@ -274,7 +273,7 @@ def SimpleAmbiguityProcessorToolCfg(flags, name='InDetTRT_SeededAmbiguityProcess
     InDetTRT_SeededAmbiTrackSelectionTool = acc.popToolsAndMerge(InDetAmbiTrackSelectionToolCfg(flags, TrackingFlags=TrackingFlags))
     acc.addPublicTool(InDetTRT_SeededAmbiTrackSelectionTool)
 
-    kwargs.setdefault("Fitter", InDetTrackFitter)
+    kwargs.setdefault("Fitter", InDetTrackFitterBT)
     kwargs.setdefault("AssociationTool", InDetPRDtoTrackMapToolGangedPixels)
     kwargs.setdefault("TrackSummaryTool", InDetTRT_SeededSummaryTool)
     kwargs.setdefault("SelectionTool", InDetTRT_SeededAmbiTrackSelectionTool)
@@ -383,9 +382,6 @@ if __name__ == "__main__":
     from AthenaPoolCnvSvc.PoolReadConfig import PoolReadCfg
     top_acc.merge(PoolReadCfg(ConfigFlags))
 
-    from MagFieldServices.MagFieldServicesConfig import MagneticFieldSvcCfg
-    top_acc.merge(MagneticFieldSvcCfg(ConfigFlags))
-
     from PixelGeoModel.PixelGeoModelConfig import PixelGeometryCfg
     top_acc.merge( PixelGeometryCfg(ConfigFlags) )
 
@@ -418,7 +414,7 @@ if __name__ == "__main__":
     from SiLorentzAngleTool.SCT_LorentzAngleConfig import SCT_LorentzAngleCfg
     top_acc.addPublicTool(top_acc.popToolsAndMerge(SCT_LorentzAngleCfg(ConfigFlags)))
     ##
-    from PixelConditionsAlgorithms.PixelConditionsConfig import (PixelOfflineCalibCondAlgCfg, PixelDistortionAlgCfg)
+    from PixelConditionsAlgorithms.PixelConditionsConfig import PixelOfflineCalibCondAlgCfg, PixelDistortionAlgCfg
     top_acc.merge(PixelOfflineCalibCondAlgCfg(ConfigFlags))
     top_acc.merge(PixelDistortionAlgCfg(ConfigFlags))
     ##
@@ -462,8 +458,6 @@ if __name__ == "__main__":
     iovsvc = top_acc.getService('IOVDbSvc')
     iovsvc.OutputLevel=5
 
-    top_acc.getService('StoreGateSvc').Dump = True
-    top_acc.printConfig(withDetails = True, summariseProps = True)
-
+    top_acc.printConfig()
     top_acc.run(25)
     top_acc.store(open("test_BackTrackingConfig.pkl", "wb"))
\ No newline at end of file
diff --git a/InnerDetector/InDetConfig/python/InDetRecToolConfig.py b/InnerDetector/InDetConfig/python/InDetRecToolConfig.py
index d7b58eb7e96e446239af7d66bc8041e521ea5392..bd552697ff0b1389e3513f638f00f5cb32b5b616 100644
--- a/InnerDetector/InDetConfig/python/InDetRecToolConfig.py
+++ b/InnerDetector/InDetConfig/python/InDetRecToolConfig.py
@@ -375,6 +375,10 @@ def SCT_ConfigurationCondAlgCfg(flags, name="SCT_ConfigurationCondAlg", **kwargs
   kwargs.setdefault("SCT_CablingTool", acc.popPrivateTools())
   result.merge(acc)
 
+  acc = SCT_ReadoutToolCfg(flags)
+  kwargs.setdefault("SCT_ReadoutTool", acc.popPrivateTools())
+  result.merge(acc)
+
   result.addCondAlgo(CompFactory.SCT_ConfigurationCondAlg(name, **kwargs))
   return result
 
@@ -458,12 +462,29 @@ def SCT_ByteStreamErrorsToolCfg(flags, name="SCT_ByteStreamErrorsTool", **kwargs
   return result
 
 def SCT_CablingToolCfg(flags):
-    from SCT_Cabling.SCT_CablingConfig import SCT_CablingCondAlgCfg
-    result = SCT_CablingCondAlgCfg(flags)
+  result = ComponentAccumulator()
 
-    tool = CompFactory.SCT_CablingTool()
-    result.setPrivateTools(tool)
-    return result
+  # For SCT_ID used in SCT_CablingTool
+  from AtlasGeoModel.GeoModelConfig import GeoModelCfg
+  result.merge(GeoModelCfg(flags))
+
+  from SCT_Cabling.SCT_CablingConfig import SCT_CablingCondAlgCfg
+  result.merge(SCT_CablingCondAlgCfg(flags))
+
+  tool = CompFactory.SCT_CablingTool()
+  result.setPrivateTools(tool)
+  return result
+
+def SCT_ReadoutToolCfg(flags, name="SCT_ReadoutTool", **kwargs):
+  result = ComponentAccumulator()
+
+  acc = SCT_CablingToolCfg(flags)
+  kwargs.setdefault("SCT_CablingTool", acc.popPrivateTools())
+  result.merge(acc)
+
+  tool = CompFactory.SCT_ReadoutTool(**kwargs)
+  result.setPrivateTools(tool)
+  return result
 
 def SCT_TdaqEnabledToolCfg(flags, name="InDetSCT_TdaqEnabledTool", **kwargs):
   if flags.Input.isMC:
diff --git a/InnerDetector/InDetConfig/python/NewTrackingTRTExtensionConfig.py b/InnerDetector/InDetConfig/python/TRTExtensionConfig.py
similarity index 91%
rename from InnerDetector/InDetConfig/python/NewTrackingTRTExtensionConfig.py
rename to InnerDetector/InDetConfig/python/TRTExtensionConfig.py
index f2e3f048b3b51a68a11d50bdd2d3211937f6c5aa..d6c695fdc97f1dc7d13ecda31c9e7b2c6e390a80 100644
--- a/InnerDetector/InDetConfig/python/NewTrackingTRTExtensionConfig.py
+++ b/InnerDetector/InDetConfig/python/TRTExtensionConfig.py
@@ -5,14 +5,6 @@ import InDetConfig.TrackingCommonConfig         as   TC
 import AthenaCommon.SystemOfUnits               as   Units
 
 #///////////// Temporary location TrackingSiPatternConfig configurations ///////////////////////
-def SiDetElementBoundaryLinksCondAlg_xkCfg(name="InDetSiDetElementBoundaryLinksPixelCondAlg", **kwargs) :
-    acc = ComponentAccumulator()
-
-    kwargs.setdefault("ReadKey", "PixelDetectorElementCollection")
-    kwargs.setdefault("WriteKey", "PixelDetElementBoundaryLinks_xk")
-    acc.addCondAlgo(CompFactory.InDet.SiDetElementBoundaryLinksCondAlg_xk(name = name))
-    return acc
-
 def SiCombinatorialTrackFinder_xkCfg(flags, name="InDetSiComTrackFinder", TrackingFlags = None, **kwargs) :
     acc = ComponentAccumulator()
     #
@@ -33,14 +25,22 @@ def SiCombinatorialTrackFinder_xkCfg(flags, name="InDetSiComTrackFinder", Tracki
     InDetPatternUpdator = TC.InDetPatternUpdatorCfg()
     acc.addPublicTool(InDetPatternUpdator)
 
+    from  InDetConfig.InDetRecToolConfig import InDetBoundaryCheckToolCfg
+    boundary_check_tool = acc.popToolsAndMerge(InDetBoundaryCheckToolCfg(flags))
+    acc.addPublicTool(boundary_check_tool)
+
     kwargs.setdefault("PropagatorTool", InDetPatternPropagator)
     kwargs.setdefault("UpdatorTool", InDetPatternUpdator)
+    kwargs.setdefault("BoundaryCheckTool", boundary_check_tool)
     kwargs.setdefault("RIOonTrackTool", rot_creator_digital)
     kwargs.setdefault("usePixel", flags.Detector.RecoPixel)
     kwargs.setdefault("useSCT", flags.Detector.RecoSCT if not is_dbm else False)
     kwargs.setdefault("PixelClusterContainer", 'PixelClusters') # InDetKeys.PixelClusters()
     kwargs.setdefault("SCT_ClusterContainer", 'SCT_Clusters') # InDetKeys.SCT_Clusters()
 
+    if TrackingFlags.extension == "Offline": 
+        kwargs.setdefault("writeHolesFromPattern", flags.InDet.useHolesFromPattern)
+
     if is_dbm :
         kwargs.setdefault("MagneticFieldMode", "NoField")
         kwargs.setdefault("TrackQualityCut", 9.3)
@@ -56,11 +56,42 @@ def SiCombinatorialTrackFinder_xkCfg(flags, name="InDetSiComTrackFinder", Tracki
     acc.setPrivateTools(track_finder)
     return acc
 
+def SiDetElementsRoadMaker_xkCfg(flags, name="InDetSiRoadMaker", TrackingFlags = None, **kwargs) :
+    acc = ComponentAccumulator()
+    #
+    # --- SCT and Pixel detector elements road builder
+    #
+    InDetPatternPropagator = TC.InDetPatternPropagatorCfg()
+    acc.addPublicTool(InDetPatternPropagator)
+
+    kwargs.setdefault("PropagatorTool", InDetPatternPropagator)
+    kwargs.setdefault("usePixel", TrackingFlags.usePixel )
+    kwargs.setdefault("PixManagerLocation", 'Pixel')
+    kwargs.setdefault("useSCT", TrackingFlags.useSCT)
+    kwargs.setdefault("SCTManagerLocation", 'SCT')
+    kwargs.setdefault("RoadWidth", TrackingFlags.roadWidth)
+
+    InDetSiDetElementsRoadMaker = CompFactory.InDet.SiDetElementsRoadMaker_xk(name = name+TrackingFlags.extension, **kwargs)
+    acc.setPrivateTools(InDetSiDetElementsRoadMaker)
+    return acc
+
 def SiTrackMaker_xkCfg(flags, name="InDetSiTrackMaker", InputCollections = None, TrackingFlags = None, **kwargs) :
     acc = ComponentAccumulator()
     useBremMode = TrackingFlags.extension == "Offline" or TrackingFlags.extension == "SLHC" or TrackingFlags.extension == "DBM"
-    #InDetSiDetElementsRoadMaker = acc.popToolsAndMerge(SiDetElementsRoadMaker_xkCfg(flags, TrackingFlags = TrackingFlags ))
-    #acc.addPublicTool(InDetSiDetElementsRoadMaker)
+    InDetSiDetElementsRoadMaker = acc.popToolsAndMerge(SiDetElementsRoadMaker_xkCfg(flags, TrackingFlags = TrackingFlags ))
+    acc.addPublicTool(InDetSiDetElementsRoadMaker)
+    if flags.Detector.RecoPixel:
+        acc.addCondAlgo( CompFactory.InDet.SiDetElementBoundaryLinksCondAlg_xk( name = "InDetSiDetElementBoundaryLinksPixelCondAlg",
+                                                                                ReadKey  = "PixelDetectorElementCollection",
+                                                                                WriteKey = "PixelDetElementBoundaryLinks_xk") )
+    if TrackingFlags.useSCT:
+        acc.addCondAlgo(CompFactory.InDet.SiDetElementsRoadCondAlg_xk(name = "InDet__SiDetElementsRoadCondAlg_xk"))
+
+        acc.addCondAlgo( CompFactory.InDet.SiDetElementBoundaryLinksCondAlg_xk( name = "InDetSiDetElementBoundaryLinksSCTCondAlg",
+                                                                                ReadKey  = "SCT_DetectorElementCollection",
+                                                                                WriteKey = "SCT_DetElementBoundaryLinks_xk") )
+
+
     track_finder = acc.popToolsAndMerge(SiCombinatorialTrackFinder_xkCfg(flags, TrackingFlags = TrackingFlags))
     acc.addPublicTool(track_finder)
 
@@ -74,7 +105,7 @@ def SiTrackMaker_xkCfg(flags, name="InDetSiTrackMaker", InputCollections = None,
 
     kwargs.setdefault("useSCT", TrackingFlags.useSCT)  #TrackingFlags.useSCT()
     kwargs.setdefault("usePixel", TrackingFlags.usePixel) #TrackingFlags.usePixel()
-    #kwargs.setdefault("RoadTool", InDetSiDetElementsRoadMaker)
+    kwargs.setdefault("RoadTool", InDetSiDetElementsRoadMaker)
     kwargs.setdefault("CombinatorialTrackFinder", track_finder)
     kwargs.setdefault("pTmin", TrackingFlags.minPT)
     kwargs.setdefault("pTminBrem", TrackingFlags.minPTBrem)
@@ -214,6 +245,8 @@ def SiSpacePointsSeedMakerCfg(flags, name="InDetSpSeedsMaker", InputCollections
             kwargs.setdefault("alwaysKeepConfirmedPixelSeeds", TrackingFlags.keepAllConfirmedPixelSeeds)
             kwargs.setdefault("mindRadius", 10)
             kwargs.setdefault("maxSizeSP", 200)
+            kwargs.setdefault("dImpactCutSlopeUnconfirmedSSS", 1.25)
+            kwargs.setdefault("dImpactCutSlopeUnconfirmedPPP", 2.0)
         
     if TrackingFlags.extension == "R3LargeD0":
         kwargs.setdefault("optimisePhiBinning", False)
@@ -346,6 +379,9 @@ def SiSPSeededTrackFinderCfg(flags, name="InDetSiSpTrackFinder", InputCollection
     if flags.InDet.doHeavyIon :
         kwargs.setdefault("FreeClustersCut",2) #Heavy Ion optimization from Igor
 
+    if TrackingFlags.extension == "Offline":
+        kwargs.setdefault("writeHolesFromPattern", flags.InDet.useHolesFromPattern)
+
     InDetSiSPSeededTrackFinder = CompFactory.InDet.SiSPSeededTrackFinder(name = name+TrackingFlags.extension, **kwargs)
     acc.addEventAlgo(InDetSiSPSeededTrackFinder)
     return acc
@@ -401,6 +437,7 @@ def DeterministicAnnealingFilterCfg(flags, name = 'InDetDAF', **kwargs):
 
 def InDetExtensionProcessorCfg(flags, TrackingFlags, SiTrackCollection=None, ExtendedTrackCollection = None, ExtendedTracksMap = None, doPhase=True, **kwargs):
     acc = ComponentAccumulator()
+
     ForwardTrackCollection = ExtendedTrackCollection
     # set output extension map name
     OutputExtendedTracks = ExtendedTracksMap
@@ -412,8 +449,19 @@ def InDetExtensionProcessorCfg(flags, TrackingFlags, SiTrackCollection=None, Ext
         InDetExtensionFitter = acc.popToolsAndMerge(DeterministicAnnealingFilterCfg(flags, name = 'InDetDAF'+ TrackingFlags.extension))
         acc.addPublicTool(InDetExtensionFitter)
     else:
-        InDetExtensionFitter = acc.popToolsAndMerge(TC.InDetKalmanFitterCfg(flags, name = "InDetTrackFitter"))
-        acc.addPublicTool(InDetExtensionFitter)
+        fitter_args = {}
+        if flags.InDet.holeSearchInGX2Fit:
+            fitter_args.setdefault("DoHoleSearch", True)
+            from  InDetConfig.InDetRecToolConfig import InDetBoundaryCheckToolCfg
+            InDetBoundaryCheckTool = acc.popToolsAndMerge(InDetBoundaryCheckToolCfg(flags))
+            acc.addPublicTool(InDetBoundaryCheckTool)
+            fitter_args.setdefault("BoundaryCheckTool", InDetBoundaryCheckTool)
+        if TrackingFlags.extension != "LowPt":
+            InDetExtensionFitter = acc.popToolsAndMerge(TC.InDetTrackFitterCfg(flags, 'InDetTrackFitter_TRTExtension'+TrackingFlags.extension, **fitter_args))
+            acc.addPublicTool(InDetExtensionFitter)
+        else:
+            InDetExtensionFitter = acc.popToolsAndMerge(TC.InDetTrackFitterLowPt(flags, 'InDetTrackFitter_TRTExtension'+TrackingFlags.extension, **fitter_args))
+            acc.addPublicTool(InDetExtensionFitter)
     #
     # --- load scoring for extension
     #
@@ -519,6 +567,8 @@ if __name__ == "__main__":
 
     ConfigFlags.addFlag('InDet.doTRTExtension', True)
     ConfigFlags.addFlag('InDet.doExtensionProcessor', True)
+    ConfigFlags.addFlag('InDet.useHolesFromPattern', False)
+    ConfigFlags.addFlag('InDet.holeSearchInGX2Fit', True)
 
     # SiliconPreProcessing
     ConfigFlags.InDet.doPixelClusterSplitting = True
@@ -535,9 +585,6 @@ if __name__ == "__main__":
     from AthenaPoolCnvSvc.PoolReadConfig import PoolReadCfg
     top_acc.merge(PoolReadCfg(ConfigFlags))
 
-    from MagFieldServices.MagFieldServicesConfig import MagneticFieldSvcCfg
-    top_acc.merge(MagneticFieldSvcCfg(ConfigFlags))
-
     from PixelGeoModel.PixelGeoModelConfig import PixelGeometryCfg
     from SCT_GeoModel.SCT_GeoModelConfig import SCT_GeometryCfg
     top_acc.merge(PixelGeometryCfg(ConfigFlags))
@@ -553,8 +600,7 @@ if __name__ == "__main__":
     from BeamSpotConditions.BeamSpotConditionsConfig import BeamSpotCondAlgCfg
     top_acc.merge(BeamSpotCondAlgCfg(ConfigFlags))
 
-    from PixelConditionsAlgorithms.PixelConditionsConfig import (PixelOfflineCalibCondAlgCfg, PixelDistortionAlgCfg)
-    top_acc.merge(PixelOfflineCalibCondAlgCfg(ConfigFlags))
+    from PixelConditionsAlgorithms.PixelConditionsConfig import PixelDistortionAlgCfg
     top_acc.merge(PixelDistortionAlgCfg(ConfigFlags))
 
     from InDetConfig.TRTSegmentFindingConfig import TRTActiveCondAlgCfg
@@ -569,14 +615,6 @@ if __name__ == "__main__":
     from SiLorentzAngleTool.SCT_LorentzAngleConfig import SCT_LorentzAngleCfg
     top_acc.addPublicTool(top_acc.popToolsAndMerge(SCT_LorentzAngleCfg(ConfigFlags)))
 
-    from PixelConditionsAlgorithms.PixelConditionsConfig import (PixelChargeCalibCondAlgCfg, PixelConfigCondAlgCfg, PixelCablingCondAlgCfg, PixelReadoutSpeedAlgCfg, PixelOfflineCalibCondAlgCfg, PixelDistortionAlgCfg)
-    top_acc.merge(PixelChargeCalibCondAlgCfg(ConfigFlags))
-    top_acc.merge(PixelConfigCondAlgCfg(ConfigFlags))
-    top_acc.merge(PixelCablingCondAlgCfg(ConfigFlags))
-    top_acc.merge(PixelReadoutSpeedAlgCfg(ConfigFlags))
-    top_acc.merge(PixelOfflineCalibCondAlgCfg(ConfigFlags))
-    top_acc.merge(PixelDistortionAlgCfg(ConfigFlags))
-
     top_acc.merge(TC.PixelClusterNnCondAlgCfg(ConfigFlags))
     top_acc.merge(TC.PixelClusterNnWithTrackCondAlgCfg(ConfigFlags))
 
@@ -587,30 +625,13 @@ if __name__ == "__main__":
     InputCollections = []
     
     InDetSpSeededTracksKey    = 'SiSPSeededTracks'  # InDetKeys.SiSpSeededTracks()
-
-    if ConfigFlags.InDet.doDBMstandalone:
-        InDetSpSeededTracksKey    = 'SiSPSeededDBMTracks' # InDetKeys.SiSpSeededDBMTracks()
-
     SiSPSeededTrackCollectionKey = InDetSpSeededTracksKey
 
     ExtendedTrackCollection = 'ExtendedTracksPhase' # InDetKeys.ExtendedTracksPhase
     ExtendedTracksMap = 'ExtendedTracksMapPhase'    # InDetKeys.ExtendedTracksMapPhase
 
     #################### Additional Configuration  ########################
-    from IOVDbSvc.IOVDbSvcConfig import addFoldersSplitOnline
-    top_acc.merge(addFoldersSplitOnline(ConfigFlags, "TRT", "/TRT/Onl/Cond/StatusHT", "/TRT/Cond/StatusHT", className='TRTCond::StrawStatusMultChanContainer'))
-    top_acc.merge(addFoldersSplitOnline(ConfigFlags, 'INDET','/Indet/Onl/TrkErrorScaling','/Indet/TrkErrorScaling', className="CondAttrListCollection"))
-
-    top_acc.addCondAlgo( CompFactory.InDet.SiDetElementBoundaryLinksCondAlg_xk( name = "InDetSiDetElementBoundaryLinksPixelCondAlg",
-                                                                                ReadKey  = "PixelDetectorElementCollection",
-                                                                                WriteKey = "PixelDetElementBoundaryLinks_xk") )
-
-    top_acc.addCondAlgo( CompFactory.InDet.SiDetElementBoundaryLinksCondAlg_xk( name = "InDetSiDetElementBoundaryLinksSCTCondAlg",
-                                                                                ReadKey  = "SCT_DetectorElementCollection",
-                                                                                WriteKey = "SCT_DetElementBoundaryLinks_xk") )
-
-    top_acc.addCondAlgo(CompFactory.InDet.SiDetElementsRoadCondAlg_xk(name = "InDet__SiDetElementsRoadCondAlg_xk"))
-
+    #######################################################################
     ################# TRTPreProcessing Configuration ######################
     from InDetConfig.TRTPreProcessing import TRTPreProcessingCfg
     if not ConfigFlags.InDet.doDBMstandalone:
@@ -627,8 +648,6 @@ if __name__ == "__main__":
 
     ####################### TrackingSiPattern #############################
     if ConfigFlags.InDet.doSiSPSeededTrackFinder:
-        if ConfigFlags.Detector.RecoPixel:
-            top_acc.merge(SiDetElementBoundaryLinksCondAlg_xkCfg())
         top_acc.merge(SiSPSeededTrackFinderCfg( ConfigFlags,
                                                 InputCollections = InputCollections, 
                                                 SiSPSeededTrackCollectionKey = InDetSpSeededTracksKey, 
@@ -659,4 +678,4 @@ if __name__ == "__main__":
     #
     top_acc.printConfig()
     top_acc.run(25)
-    top_acc.store(open("NewTrackingTRTExtensionConfig.pkl", "wb"))
\ No newline at end of file
+    top_acc.store(open("TRTExtensionConfig.pkl", "wb"))
\ No newline at end of file
diff --git a/InnerDetector/InDetConfig/python/TRTStandaloneConfig.py b/InnerDetector/InDetConfig/python/TRTStandaloneConfig.py
index bd7b10255d1dd90a7becb1e6c7137f78e02ad041..455bf062905ca5bef27852b9ce2011b7385c0375 100644
--- a/InnerDetector/InDetConfig/python/TRTStandaloneConfig.py
+++ b/InnerDetector/InDetConfig/python/TRTStandaloneConfig.py
@@ -52,7 +52,7 @@ def TRT_SegmentToTrackToolCfg(flags, name ='InDetTRT_SegmentToTrackTool', Tracki
     else:
         asso_tool = None
 
-    InDetTrackFitterTRT = acc.popToolsAndMerge(TC.GlobalChi2FitterCfg(flags))
+    InDetTrackFitterTRT = acc.popToolsAndMerge(TC.InDetTrackFitterTRTCfg(flags))
     acc.addPublicTool(InDetTrackFitterTRT)
 
     InDetTrackSummaryTool = acc.popToolsAndMerge(TC.InDetTrackSummaryToolCfg(flags))
@@ -230,9 +230,6 @@ if __name__ == "__main__":
     from AthenaPoolCnvSvc.PoolReadConfig import PoolReadCfg
     top_acc.merge(PoolReadCfg(ConfigFlags))
 
-    from MagFieldServices.MagFieldServicesConfig import MagneticFieldSvcCfg
-    top_acc.merge(MagneticFieldSvcCfg(ConfigFlags))
-
     from TRT_GeoModel.TRT_GeoModelConfig import TRT_GeometryCfg
     top_acc.merge(TRT_GeometryCfg( ConfigFlags ))
 
@@ -264,9 +261,6 @@ if __name__ == "__main__":
     PixeldEdxAlg = CompFactory.PixeldEdxAlg(name="PixeldEdxAlg", ReadFromCOOL = True)
     top_acc.addCondAlgo(PixeldEdxAlg)
     ###
-    ###
-    top_acc.merge(addFoldersSplitOnline(ConfigFlags, "TRT", "/TRT/Onl/Cond/Status", "/TRT/Cond/Status", className='TRTCond::StrawStatusMultChanContainer'))
-
     InDetTRTStrawStatusSummaryTool = top_acc.popToolsAndMerge(TC.InDetTRTStrawStatusSummaryToolCfg(ConfigFlags))
     top_acc.addPublicTool(InDetTRTStrawStatusSummaryTool)
 
@@ -302,11 +296,11 @@ if __name__ == "__main__":
 
     top_acc.merge(TRTActiveCondAlgCfg(ConfigFlags))
     top_acc.merge(TC.TRT_DetElementsRoadCondAlgCfg())
-
+    ############################# TRTPreProcessing configuration ############################
     from InDetConfig.TRTPreProcessing import TRTPreProcessingCfg
     if not ConfigFlags.InDet.doDBMstandalone:
         top_acc.merge(TRTPreProcessingCfg(ConfigFlags,(not ConfigFlags.InDet.doTRTPhaseCalculation or ConfigFlags.Beam.Type =="collisions"),False))
-
+    ########################### TRTSegmentFindingCfg configuration ##########################
     TrackingFlags = ConfigFlags.InDet.Tracking
     # NewTracking collection keys
     InputCombinedInDetTracks = []
@@ -316,7 +310,7 @@ if __name__ == "__main__":
                                         InputCombinedInDetTracks,
                                         TrackingFlags,
                                         'TRTSegments')) # InDetKeys.TRT_Segments
-
+    #########################################################################################
     ############################### TRTStandalone configuration #############################
     top_acc.merge(TRTStandaloneCfg( ConfigFlags, 
                                     extension = "",
@@ -327,7 +321,5 @@ if __name__ == "__main__":
     iovsvc = top_acc.getService('IOVDbSvc')
     iovsvc.OutputLevel=5
 
-    top_acc.getService('StoreGateSvc').Dump = True
-    top_acc.printConfig(withDetails = True, summariseProps = True)
     top_acc.run(25)
     top_acc.store(open("test_TRTStandaloneConfig.pkl", "wb"))
\ No newline at end of file
diff --git a/InnerDetector/InDetConfig/python/TrackTruthConfig.py b/InnerDetector/InDetConfig/python/TrackTruthConfig.py
new file mode 100644
index 0000000000000000000000000000000000000000..f905b397c052d36a20cf4030aff4f4a2386cec4a
--- /dev/null
+++ b/InnerDetector/InDetConfig/python/TrackTruthConfig.py
@@ -0,0 +1,166 @@
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
+from AthenaConfiguration.ComponentFactory     import CompFactory
+# -------------------------------------------------------------------------
+#
+# ------- fragment to handle track truth association
+#
+# -------------------------------------------------------------------------
+
+def InDetDetailedTrackTruthMakerCfg(flags, Tracks, DetailedTruth, name='Maker',**kwargs) :
+    acc = ComponentAccumulator()
+    kwargs.setdefault("TrackCollectionName", Tracks)
+    kwargs.setdefault("DetailedTrackTruthName", DetailedTruth)
+    kwargs.setdefault("TruthNamePixel", 'PRD_MultiTruthPixel')
+    kwargs.setdefault("TruthNameSCT", 'PRD_MultiTruthSCT')
+    kwargs.setdefault("TruthNameTRT", 'PRD_MultiTruthTRT')
+
+    # this is how the truth maker gets to know which detector is on ...
+    if (not flags.Detector.RecoPixel):
+        kwargs.setdefault("TruthNamePixel", "")
+    if (not flags.Detector.RecoSCT):
+        kwargs.setdefault("TruthNameSCT", "")
+    # for cosmics, at the stage of SiPatternRecognition, the TRT truth information is not yet available
+    if ((not flags.Detector.RecoTRT) or (flags.Beam.Type == 'cosmics' and (DetailedTruth == "SiSPSeededTracksDetailedTruth" or DetailedTruth == "ResolvedTracksDetailedTruth"))):
+        kwargs.setdefault("TruthNameTRT", "")
+
+    acc.addEventAlgo(CompFactory.InDet.InDetDetailedTrackTruthMaker(name = DetailedTruth+name, **kwargs))
+    return acc
+
+def InDetTruthMatchToolCfg(flags, name='InDetTruthMatchTool', **kwargs) :
+    acc = ComponentAccumulator()
+
+    if flags.InDet.truthMatchStrategy == 'TruthMatchRatio':
+        InDetTruthMatchTool = CompFactory.Trk.TruthMatchRatio
+    elif flags.InDet.truthMatchStrategy == 'TruthMatchTanimoto':
+        InDetTruthMatchTool = CompFactory.Trk.TruthMatchTanimoto
+
+    kwargs.setdefault("WeightPixel", 10.)
+    kwargs.setdefault("WeightSCT", 5.)
+    kwargs.setdefault("WeightTRT", 1.)
+
+    InDetTruthMatchSimilarityTool = InDetTruthMatchTool(name = name, **kwargs)
+    acc.setPrivateTools(InDetTruthMatchSimilarityTool)
+    return acc
+
+def TrackTruthSimilaritySelectorCfg(flags, DetailedTruth, TracksTruth, name='Selector', **kwargs) :
+    acc = ComponentAccumulator()
+
+    InDetTruthMatchSimilarityTool = acc.popToolsAndMerge(InDetTruthMatchToolCfg(flags))
+    acc.addPublicTool(InDetTruthMatchSimilarityTool)
+
+    kwargs.setdefault("DetailedTrackTruthName", DetailedTruth)
+    kwargs.setdefault("OutputName", TracksTruth)
+    kwargs.setdefault("TrackTruthSimilarityTool", InDetTruthMatchSimilarityTool)
+
+    acc.addEventAlgo(CompFactory.TrackTruthSimilaritySelector(name = TracksTruth+name, **kwargs))
+    return acc
+
+def  InDetTrackTruthCfg(flags, Tracks = None, DetailedTruth = None, TracksTruth = None):
+    acc = ComponentAccumulator()
+    #
+    # --- Enable the detailed track truth
+    #
+    acc.merge(InDetDetailedTrackTruthMakerCfg(flags, Tracks, DetailedTruth))
+    #
+    # --- Detailed to old TrackTruth
+    #
+    acc.merge(TrackTruthSimilaritySelectorCfg(flags, DetailedTruth, TracksTruth))
+
+    return acc
+
+
+if __name__ == "__main__":
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior=1
+
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+
+    numThreads=1
+    ConfigFlags.Concurrency.NumThreads=numThreads
+    ConfigFlags.Concurrency.NumConcurrentEvents=numThreads # Might change this later, but good enough for the moment.
+
+    ConfigFlags.Detector.GeometryPixel = True
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.Detector.GeometryTRT   = True
+
+    ConfigFlags.InDet.doPixelClusterSplitting = True
+
+    ConfigFlags.Detector.RecoIBL = True
+    ConfigFlags.Detector.RecoPixel = True
+    ConfigFlags.Detector.RecoTRT = True
+    ConfigFlags.Detector.RecoSCT = True
+
+    ConfigFlags.addFlag('InDet.useHolesFromPattern', False)
+
+    from AthenaConfiguration.TestDefaults import defaultTestFiles
+    ConfigFlags.Input.Files = defaultTestFiles.RDO
+    ConfigFlags.lock()
+    ConfigFlags.dump()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    top_acc = MainServicesCfg(ConfigFlags)
+
+    from AthenaPoolCnvSvc.PoolReadConfig import PoolReadCfg
+    top_acc.merge(PoolReadCfg(ConfigFlags))
+
+    ####################### Aditional Configurations #########################
+
+    from PixelGeoModel.PixelGeoModelConfig import PixelGeometryCfg
+    top_acc.merge( PixelGeometryCfg(ConfigFlags) )
+
+    from SCT_GeoModel.SCT_GeoModelConfig import SCT_GeometryCfg
+    top_acc.merge(SCT_GeometryCfg(ConfigFlags))
+
+    from TRT_GeoModel.TRT_GeoModelConfig import TRT_GeometryCfg
+    top_acc.merge(TRT_GeometryCfg( ConfigFlags ))
+
+    from BeamSpotConditions.BeamSpotConditionsConfig import BeamSpotCondAlgCfg
+    top_acc.merge(BeamSpotCondAlgCfg(ConfigFlags))
+
+    from PixelConditionsAlgorithms.PixelConditionsConfig import PixelDistortionAlgCfg, PixelHitDiscCnfgAlgCfg
+    top_acc.merge(PixelDistortionAlgCfg(ConfigFlags))
+    top_acc.merge(PixelHitDiscCnfgAlgCfg(ConfigFlags))
+
+    from SiLorentzAngleTool.PixelLorentzAngleConfig import PixelLorentzAngleTool, PixelLorentzAngleCfg
+    top_acc.addPublicTool(PixelLorentzAngleTool(ConfigFlags))
+    top_acc.addPublicTool(top_acc.popToolsAndMerge(PixelLorentzAngleCfg(ConfigFlags)))
+
+    from InDetOverlay.PixelOverlayConfig import PixelRawDataProviderAlgCfg
+    top_acc.merge(PixelRawDataProviderAlgCfg(ConfigFlags))
+
+    ################## SiliconPreProcessing Configurations ###################
+    from InDetConfig.SiliconPreProcessing import InDetRecPreProcessingSiliconCfg
+    top_acc.merge(InDetRecPreProcessingSiliconCfg(ConfigFlags))
+    #################### TRTPreProcessing Configurations #####################
+    from InDetConfig.TRTPreProcessing import TRTPreProcessingCfg
+    top_acc.merge(TRTPreProcessingCfg(ConfigFlags,(not ConfigFlags.InDet.doTRTPhaseCalculation or ConfigFlags.Beam.Type =="collisions"),False))
+    
+    #//// TrackingSiPatternConfig configurations from Temporary location /////
+    ################# SiSPSeededTrackFinder Configurations ###################
+    TrackingFlags = ConfigFlags.InDet.Tracking
+
+    InputCollections = []
+
+    SiSPSeededTrackCollectionKey = 'SiSPSeededPixelTracks'
+    ResolvedTrackCollectionKey = 'ResolvedPixelTracks'
+    from InDetConfig.TRTExtensionConfig import SiSPSeededTrackFinderCfg
+    top_acc.merge(SiSPSeededTrackFinderCfg( ConfigFlags,
+                                            InputCollections = InputCollections, 
+                                            SiSPSeededTrackCollectionKey = SiSPSeededTrackCollectionKey, 
+                                            TrackingFlags = TrackingFlags))
+    ##########################################################################
+    #################### InDetTrackTruth Configurations ######################
+
+    InputTrackCollection = 'SiSPSeededPixelTracks'
+    InputDetailedTrackTruth = 'DetailedTrackTruth'
+    InputTrackCollectionTruth = 'TrackTruthCollection'
+    
+    top_acc.merge(InDetTrackTruthCfg(flags=ConfigFlags,
+                                     Tracks = InputTrackCollection,
+                                     DetailedTruth = InputDetailedTrackTruth,
+                                     TracksTruth = InputTrackCollectionTruth))
+    #################################################################
+    top_acc.printConfig()
+    top_acc.run(25)
+    top_acc.store(open("TrackTruthConfig.pkl", "wb"))
\ No newline at end of file
diff --git a/InnerDetector/InDetConfig/python/TrackingCommonConfig.py b/InnerDetector/InDetConfig/python/TrackingCommonConfig.py
index 40a893f022a3d70ab36e3e220679a92354ebef6a..13107c433f5a52c3a9c6101a3bf23d53298038d5 100644
--- a/InnerDetector/InDetConfig/python/TrackingCommonConfig.py
+++ b/InnerDetector/InDetConfig/python/TrackingCommonConfig.py
@@ -3,6 +3,7 @@ from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator
 from AthenaConfiguration.ComponentFactory     import CompFactory
 from IOVDbSvc.IOVDbSvcConfig                  import addFoldersSplitOnline
 from InDetConfig.InDetRecToolConfig           import makeName
+import AthenaCommon.SystemOfUnits               as   Units
 #######################################################################
 
 def copyArgs(kwargs, copy_list):
@@ -12,6 +13,12 @@ def copyArgs(kwargs, copy_list):
             dict_copy[elm]=kwargs[elm]
     return dict_copy
 
+def stripArgs(kwargs, copy_list) :
+    dict_copy = copyArgs(kwargs,copy_list)
+    for an_arg in copy_list :
+        kwargs.pop(an_arg,None)
+    return dict_copy
+
 def NeuralNetworkToHistoToolCfg(**kwargs):
     acc = ComponentAccumulator()
     name = kwargs.pop('name',"NeuralNetworkToHistoTool")
@@ -88,7 +95,7 @@ def NnClusterizationFactoryCfg(flags, name = 'NnClusterizationFactory', **kwargs
         acc.merge(addFoldersSplitOnline(flags, "PIXEL", "/PIXEL/Onl/PixelClustering/PixelClusNNCalib", "/PIXEL/PixelClustering/PixelClusNNCalib", className='CondAttrListCollection'))
         acc.merge(LWTNNCondAlgCfg(flags, name='LWTNNCondAlg'))
 
-    kwargs.setdefault("doRunI", True)
+    kwargs.setdefault("doRunI", do_runI)
     kwargs.setdefault("useToT", False if do_runI else flags.InDet.doNNToTCalibration)
     kwargs.setdefault("useRecenteringNNWithoutTracks", True  if do_runI else False)
     kwargs.setdefault("useRecenteringNNWithTracks", False if do_runI else False)
@@ -144,7 +151,8 @@ def InDetPixelClusterOnTrackToolNNSplittingCfg(flags, name='InDetPixelClusterOnT
 def InDetPixelClusterOnTrackToolCfg(flags, name='InDetPixelClusterOnTrackTool', **kwargs):
     if 'LorentzAngleTool' not in kwargs :
         from SiLorentzAngleTool.PixelLorentzAngleConfig import PixelLorentzAngleTool
-        kwargs.setdefault("LorentzAngleTool", PixelLorentzAngleTool(flags, name="PixelLorentzAngleTool") )
+        tool = PixelLorentzAngleTool(flags, name="PixelLorentzAngleTool")
+        kwargs.setdefault("LorentzAngleTool", tool )
 
     if flags.InDet.doDigitalROTCreation:
         return InDetPixelClusterOnTrackToolDigitalCfg(flags, name=name, **kwargs)
@@ -155,9 +163,10 @@ def InDetSCT_ClusterOnTrackToolCfg(flags, name='InDetSCT_ClusterOnTrackTool', **
     the_name = makeName(name, kwargs)
 
     if 'LorentzAngleTool' not in kwargs :
-        from SiLorentzAngleTool.PixelLorentzAngleConfig import PixelLorentzAngleTool
-        kwargs.setdefault("LorentzAngleTool", PixelLorentzAngleTool(flags, name="PixelLorentzAngleTool") )
-
+        from SiLorentzAngleTool.SCT_LorentzAngleConfig import SCT_LorentzAngleCfg
+        SCT_LorentzAngle = SCT_LorentzAngleCfg(flags).popPrivateTools()
+        kwargs.setdefault("LorentzAngleTool", SCT_LorentzAngle )
+        
     kwargs.setdefault("CorrectionStrategy", 0 ) # do correct position bias
     kwargs.setdefault("ErrorStrategy", 2 ) # do use phi dependent errors
     return CompFactory.InDet.SCT_ClusterOnTrackTool(the_name, **kwargs)
@@ -198,13 +207,26 @@ def RIO_OnTrackErrorScalingCondAlgCfg(flags, **kwargs):
     acc.addCondAlgo(CompFactory.RIO_OnTrackErrorScalingCondAlg(**kwargs))
     return acc
 
+def LumiCondDataKeyForTRTMuScalingCfg(flags, **kwargs) :
+    acc = ComponentAccumulator()
+    LuminosityOutputKey = ''
+    if not flags.Beam.Type == 'cosmics' and False: # InDetFlags.useMuForTRTErrorScaling()  "temporary value"
+        from LumiBlockComps.LuminosityCondAlgConfig import LuminosityCondAlgCfg
+        LuminosityCondAlg = LuminosityCondAlgCfg (flags)
+        acc.merge(LuminosityCondAlg)
+        LuminosityOutputKey = LuminosityCondAlg.getCondAlgo ('LuminosityCondAlg').LuminosityOutputKey
+
+    return acc, LuminosityOutputKey
+
 def InDetTRT_DriftCircleOnTrackToolCfg(flags, name='TRT_DriftCircleOnTrackTool', **kwargs):
     acc = ComponentAccumulator()
     the_name = makeName( name, kwargs)
     kwargs.pop('isHLT',None)
     acc.merge(RIO_OnTrackErrorScalingCondAlgCfg(flags, name = 'RIO_OnTrackErrorScalingCondAlg'))
     kwargs.setdefault("TRTErrorScalingKey", '/Indet/TrkErrorScalingTRT')
-    kwargs.setdefault("LumiDataKey", '') # need to check
+    tmpAcc, LuminosityOutputKey = LumiCondDataKeyForTRTMuScalingCfg(flags)
+    acc.merge(tmpAcc)
+    kwargs.setdefault("LumiDataKey", LuminosityOutputKey)
     acc.addPublicTool(CompFactory.InDet.TRT_DriftCircleOnTrackTool(name = the_name, **kwargs), primary = True)
     return acc
 
@@ -214,7 +236,7 @@ def InDetBroadTRT_DriftCircleOnTrackToolCfg(name='InDetBroadTRT_DriftCircleOnTra
 
 def InDetRotCreatorCfg(flags, name='InDetRotCreator', **kwargs):
     acc = ComponentAccumulator()
-    strip_args=['SplitClusterMapExtension','ClusterSplitProbabilityName','RenounceInputHandles','nameSuffix']
+    strip_args=['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix']
     pix_cluster_on_track_args = copyArgs(kwargs,strip_args)
     the_name = makeName(name, kwargs)
 
@@ -323,9 +345,8 @@ def InDetTrackSummaryToolCfg(flags, name='InDetTrackSummaryTool', **kwargs):
     acc = ComponentAccumulator()
     # makeName will remove the namePrefix in suffix from kwargs, so copyArgs has to be first
     hlt_args = copyArgs(kwargs,['isHLT','namePrefix'])
-    id_helper_args = copyArgs(kwargs,['ClusterSplitProbabilityName','RenounceInputHandles','namePrefix','nameSuffix']) if 'ClusterSplitProbabilityName' in kwargs else {}
+    id_helper_args = copyArgs(kwargs,['ClusterSplitProbabilityName','namePrefix','nameSuffix']) if 'ClusterSplitProbabilityName' in kwargs else {}
     kwargs.pop('ClusterSplitProbabilityName',None)
-    kwargs.pop('RenounceInputHandles',None)
     kwargs.pop('isHLT',None)
     the_name = makeName( name, kwargs)
     do_holes=kwargs.get("doHolesInDet",True)
@@ -333,13 +354,15 @@ def InDetTrackSummaryToolCfg(flags, name='InDetTrackSummaryTool', **kwargs):
         id_helper_args.update(hlt_args)
 
     if 'InDetSummaryHelperTool' not in kwargs :
-        from  InDetConfig.InDetRecToolConfig import InDetTrackSummaryHelperToolCfg
-        tmpAcc =  InDetTrackSummaryHelperToolCfg(flags, **id_helper_args)
-        InDetSummaryHelper = tmpAcc.getPrimary()
-        acc.merge(tmpAcc)
-        InDetSummaryHelperNoHoleSearch = acc.popToolsAndMerge(InDetSummaryHelperNoHoleSearchCfg(flags, **id_helper_args))
-        acc.addPublicTool(InDetSummaryHelperNoHoleSearch)
-        kwargs.setdefault("InDetSummaryHelperTool", InDetSummaryHelper if do_holes else InDetSummaryHelperNoHoleSearch)
+        if do_holes:
+            from  InDetConfig.InDetRecToolConfig import InDetTrackSummaryHelperToolCfg
+            tmpAcc =  InDetTrackSummaryHelperToolCfg(flags, **id_helper_args)
+            InDetSummaryHelperTool = tmpAcc.getPrimary()
+            acc.merge(tmpAcc)
+        else:
+            InDetSummaryHelperTool = acc.popToolsAndMerge(InDetSummaryHelperNoHoleSearchCfg(flags, **id_helper_args))
+            acc.addPublicTool(InDetSummaryHelperTool)
+        kwargs.setdefault("InDetSummaryHelperTool", InDetSummaryHelperTool)
 
     #
     # Configurable version of TrkTrackSummaryTool: no TRT_PID tool needed here (no shared hits)
@@ -484,7 +507,7 @@ def InDetTRT_ElectronPidToolCfg(flags, name = "InDetTRT_ElectronPidTool", **kwar
             InDetTRT_dEdxTool = None
         kwargs.setdefault( "TRT_ToT_dEdx_Tool", InDetTRT_dEdxTool)
 
-    kwargs.setdefault( "isData", not flags.Input.isMC)
+    kwargs.setdefault( "CalculateNNPid", flags.InDet.doTRTPIDNN)
 
     InDetTRT_ElectronPidTool = CompFactory.InDet.TRT_ElectronPidToolRun2(name = the_name, **kwargs)
     return InDetTRT_ElectronPidTool
@@ -492,13 +515,12 @@ def InDetTRT_ElectronPidToolCfg(flags, name = "InDetTRT_ElectronPidTool", **kwar
 def InDetTrackSummaryToolSharedHitsCfg(flags, name='InDetTrackSummaryToolSharedHits',**kwargs):
     acc = ComponentAccumulator()
     if 'InDetSummaryHelperTool' not in kwargs :
-        copy_args=['ClusterSplitProbabilityName','RenounceInputHandles','namePrefix','nameSuffix']
+        copy_args=['ClusterSplitProbabilityName','namePrefix','nameSuffix']
         do_holes=kwargs.get("doHolesInDet",True)
         if do_holes :
             copy_args += ['isHLT']
         id_helper_args = copyArgs(kwargs,copy_args) if 'ClusterSplitProbabilityName' in kwargs else {}
         kwargs.pop('ClusterSplitProbabilityName',None)
-        kwargs.pop('RenounceInputHandles',None)
 
         InDetSummaryHelperSharedHits = acc.popToolsAndMerge(InDetSummaryHelperSharedHitsCfg(flags, **id_helper_args))
         acc.addPublicTool(InDetSummaryHelperSharedHits)
@@ -546,10 +568,329 @@ def InDetMultipleScatteringUpdatorCfg(name = "InDetMultipleScatteringUpdator", *
     acc.setPrivateTools(MultipleScatteringUpdator)
     return acc
 
-def GlobalChi2FitterCfg(flags, name ='InDetTrackFitterTRT', **kwargs):
+def InDetMeasRecalibSTCfg(flags, name='InDetMeasRecalibST', **kwargs) :
+    acc = ComponentAccumulator()
+
+    pix_cluster_on_track_args = stripArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix'])
+
+    if 'BroadPixelClusterOnTrackTool' not in kwargs :
+        InDetBroadPixelClusterOnTrackTool = InDetBroadPixelClusterOnTrackToolCfg(flags, **pix_cluster_on_track_args)
+        kwargs.setdefault('BroadPixelClusterOnTrackTool', InDetBroadPixelClusterOnTrackTool)
+        acc.addPublicTool(InDetBroadPixelClusterOnTrackTool)
+    if 'BroadSCT_ClusterOnTrackTool' not in kwargs :
+        InDetBroadSCT_ClusterOnTrackTool = InDetBroadSCT_ClusterOnTrackToolCfg(flags)
+        acc.addPublicTool(InDetBroadSCT_ClusterOnTrackTool)
+        kwargs.setdefault('BroadSCT_ClusterOnTrackTool', InDetBroadSCT_ClusterOnTrackTool)
+    if 'CommonRotCreator' not in kwargs :
+        InDetRefitRotCreator = acc.popToolsAndMerge(InDetRefitRotCreatorCfg(flags, **pix_cluster_on_track_args))
+        acc.addPublicTool(InDetRefitRotCreator)
+        kwargs.setdefault('CommonRotCreator', InDetRefitRotCreator)
+
+    MeasRecalibSteeringTool = CompFactory.Trk.MeasRecalibSteeringTool(name, **kwargs)
+    acc.setPrivateTools(MeasRecalibSteeringTool)
+    return acc
+
+def InDetKalmanTrackFitterBaseCfg(flags, name='InDetKalmanTrackFitterBase',**kwargs) :
+    acc = ComponentAccumulator()
+    nameSuffix=kwargs.pop('nameSuffix','')
+    pix_cluster_on_track_args = stripArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName'])
+    if len(pix_cluster_on_track_args)>0 and len(nameSuffix)>0 :
+        pix_cluster_on_track_args['nameSuffix']=nameSuffix
+
+    from  InDetConfig.InDetRecToolConfig import InDetExtrapolatorCfg
+    tmpAcc =  InDetExtrapolatorCfg(flags)
+    kwargs.setdefault("ExtrapolatorHandle", tmpAcc.getPrimary())
+    acc.merge(tmpAcc)
+
+    if 'RIO_OnTrackCreatorHandle' not in kwargs :
+        InDetRefitRotCreator = acc.popToolsAndMerge(InDetRefitRotCreatorCfg(flags, **pix_cluster_on_track_args))
+        acc.addPublicTool(InDetRefitRotCreator)
+        kwargs.setdefault("RIO_OnTrackCreatorHandle", InDetRefitRotCreator)
+
+    InDetUpdator = InDetUpdatorCfg(flags)
+    acc.addPublicTool(InDetUpdator)
+    kwargs.setdefault('MeasurementUpdatorHandle', InDetUpdator)
+    kwargs.setdefault('KalmanSmootherHandle', InDetBKS())
+    kwargs.setdefault('KalmanOutlierLogicHandle', InDetKOL())
+    kwargs.setdefault('DynamicNoiseAdjustorHandle', None)
+    kwargs.setdefault('BrempointAnalyserHandle', None)
+    kwargs.setdefault('AlignableSurfaceProviderHandle',None)
+
+    if len(pix_cluster_on_track_args)>0 :
+        if 'RecalibratorHandle' not in kwargs :
+            the_tool_name = 'InDetMeasRecalibST'
+            InDetMeasRecalibST = acc.popToolsAndMerge(InDetMeasRecalibSTCfg(flags, name=the_tool_name+nameSuffix, **pix_cluster_on_track_args))
+            acc.addPublicTool(InDetMeasRecalibST)
+            kwargs.setdefault('RecalibratorHandle', InDetMeasRecalibST)
+    else :
+        InDetMeasRecalibST = acc.popToolsAndMerge(InDetMeasRecalibSTCfg(flags))
+        acc.addPublicTool(InDetMeasRecalibST)
+        kwargs.setdefault('RecalibratorHandle', InDetMeasRecalibST)
+
+    KalmanFitter = CompFactory.Trk.KalmanFitter(name=name, **kwargs)
+    acc.setPrivateTools(KalmanFitter)
+    return acc
+
+def InDetDNAdjustor(name='InDetDNAdjustor', **kwargs) :
+    return CompFactory.Trk.InDetDynamicNoiseAdjustment(name=name,**kwargs)
+
+def InDetDNASeparator(name='InDetDNASeparator',**kwargs) :
+    return CompFactory.InDet.InDetDNASeparator(name=name,**kwargs)
+
+def InDetAnnealBKS(name='InDetAnnealBKS',**kwargs) :
+    kwargs.setdefault('InitialCovarianceSeedFactor',200.)
+    return CompFactory.Trk.KalmanSmoother(name=name,**kwargs)
+
+def KalmanCompetingPixelClustersTool(name='KalmanCompetingPixelClustersTool',**kwargs):
+    kwargs.setdefault('WeightCutValueBarrel',5.5)
+    kwargs.setdefault('WeightCutValueEndCap',5.5)
+    return CompFactory.InDet.CompetingPixelClustersOnTrackTool(name=name, **kwargs)
+
+def KalmanCompetingSCT_ClustersTool(name='KalmanCompetingSCT_ClustersTool',**kwargs) :
+    kwargs.setdefault('WeightCutValueBarrel',5.5)
+    kwargs.setdefault('WeightCutValueEndCap',5.5)
+    return CompFactory.InDet.CompetingSCT_ClustersOnTrackTool(name=name,**kwargs)
+
+def KalmanCompetingRIOsTool(name='KalmanCompetingRIOsTool',**kwargs) :
+    kwargs.setdefault('ToolForCompPixelClusters',KalmanCompetingPixelClustersTool())
+    kwargs.setdefault('ToolForCompSCT_Clusters',KalmanCompetingSCT_ClustersTool())
+    return CompFactory.Trk.CompetingRIOsOnTrackTool(name=name,**kwargs)
+
+def KalmanInternalDAF(name='KalmanInternalDAF',**kwargs) :
+    kwargs.setdefault('CompetingRIOsOnTrackCreator',KalmanCompetingRIOsTool())
+    kwargs.setdefault('BackwardSmoother',InDetAnnealBKS())
+    return CompFactory.Trk.KalmanPiecewiseAnnealingFilter(name=name,**kwargs)
+
+def InDetAnnealFKF(name='InDetAnnealFKF',**kwargs) :
+    return CompFactory.Trk.ForwardKalmanFitter(name=name,**kwargs)
+
+def InDetFKFRef(name='InDetFKFRef',**kwargs) :
+    kwargs.setdefault('StateChi2PerNDFPreCut',30.0)
+    return InDetAnnealFKF(name=name,**kwargs)
+
+def KalmanInternalDAFRef(name='KalmanInternalDAFRef',**kwargs) :
+    kwargs.setdefault('ForwardFitter', InDetAnnealFKF())
+    kwargs.setdefault('BackwardSmoother', InDetBKS())
+    return KalmanInternalDAF(name=name,**kwargs)
+
+def InDetBroadRotCreatorCfg(flags, name='InDetBroadInDetRotCreator', **kwargs) :
+    acc = ComponentAccumulator()
+
+    if 'ToolPixelCluster' not in kwargs :
+        pix_cluster_on_track_args = copyArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix'])
+        InDetBroadPixelClusterOnTrackTool = InDetBroadPixelClusterOnTrackToolCfg(flags, **pix_cluster_on_track_args)
+        acc.addPublicTool(InDetBroadPixelClusterOnTrackTool)
+        kwargs.setdefault('ToolPixelCluster', InDetBroadPixelClusterOnTrackTool)
+
+    if 'ToolSCT_Cluster' not in kwargs :
+        InDetBroadSCT_ClusterOnTrackTool = InDetBroadSCT_ClusterOnTrackToolCfg(flags)
+        acc.addPublicTool(InDetBroadSCT_ClusterOnTrackTool)
+        kwargs.setdefault('ToolSCT_Cluster', InDetBroadSCT_ClusterOnTrackTool)
+
+    if flags.Detector.RecoTRT:
+        if 'ToolTRT_DriftCircle' not in kwargs :
+            InDetBroadTRT_DriftCircleOnTrackTool = InDetBroadTRT_DriftCircleOnTrackToolCfg()
+            acc.addPublicTool(InDetBroadTRT_DriftCircleOnTrackTool)
+            kwargs.setdefault('ToolTRT_DriftCircle', InDetBroadTRT_DriftCircleOnTrackTool)
+
+    InDetRotCreator = acc.popToolsAndMerge(InDetRotCreatorCfg(flags, name = name, **kwargs))
+    acc.setPrivateTools(InDetRotCreator)
+    return acc
+
+def KalmanFitterCfg(flags, name='KalmanFitter',**kwargs) :
+    acc = ComponentAccumulator()
+
+    kwargs.setdefault('ForwardKalmanFitterHandle', InDetFKF())
+    if flags.InDet.doBremRecovery:
+        kwargs.setdefault('DynamicNoiseAdjustorHandle', InDetDNAdjustor())
+        kwargs.setdefault('BrempointAnalyserHandle', InDetDNASeparator())
+        kwargs.setdefault('DoDNAForElectronsOnly', True)
+    else:
+        kwargs.setdefault('DynamicNoiseAdjustorHandle', None)
+        kwargs.setdefault('BrempointAnalyserHandle', None)
+
+    kwargs.setdefault('InternalDAFHandle', KalmanInternalDAF())
+
+    InDetKalmanTrackFitterBase = acc.popToolsAndMerge(InDetKalmanTrackFitterBaseCfg(flags, name=name, **kwargs))
+    acc.setPrivateTools(InDetKalmanTrackFitterBase)
+    return acc
+
+def KalmanDNAFitterCfg(flags, name='KalmanDNAFitter',**kwargs) :
+    acc = ComponentAccumulator()
+
+    kwargs.setdefault('ForwardKalmanFitterHandle', InDetFKF())
+    kwargs.setdefault('DynamicNoiseAdjustorHandle', InDetDNAdjustor())
+    kwargs.setdefault('BrempointAnalyserHandle', InDetDNASeparator())
+    kwargs.setdefault('InternalDAFHandle', KalmanInternalDAF())
+
+    InDetKalmanTrackFitterBase = acc.popToolsAndMerge(InDetKalmanTrackFitterBaseCfg(flags, name=name, **kwargs))
+    acc.setPrivateTools(InDetKalmanTrackFitterBase)
+    return acc
+
+def ReferenceKalmanFitterCfg(flags, name='ReferenceKalmanFitter',**kwargs) :
+    acc = ComponentAccumulator()
+    
+    kwargs.setdefault('ForwardKalmanFitterHandle', InDetFKFRef())
+    kwargs.setdefault('InternalDAFHandle', KalmanInternalDAFRef())
+
+    InDetKalmanTrackFitterBase = acc.popToolsAndMerge(InDetKalmanTrackFitterBaseCfg(flags, name=name, **kwargs))
+    acc.setPrivateTools(InDetKalmanTrackFitterBase)
+    return acc
+
+def DistributedKalmanFilterCfg(flags, name="DistributedKalmanFilter", **kwargs) :
+    acc = ComponentAccumulator()
+
+    pix_cluster_on_track_args = stripArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix'])
+
+    if 'ExtrapolatorTool' not in kwargs :
+        from  InDetConfig.InDetRecToolConfig import InDetExtrapolatorCfg
+        tmpAcc =  InDetExtrapolatorCfg(flags)
+        InDetExtrapolator = tmpAcc.getPrimary()
+        acc.merge(tmpAcc)
+        kwargs.setdefault('ExtrapolatorTool', InDetExtrapolator)
+
+    if 'ROTcreator' not in kwargs :
+        InDetRotCreator = acc.popToolsAndMerge(InDetRotCreatorCfg(flags, **pix_cluster_on_track_args))
+        acc.addPublicTool(InDetRotCreator)
+        kwargs.setdefault('ROTcreator', InDetRotCreator)
+
+    DistributedKalmanFilter = CompFactory.Trk.DistributedKalmanFilter(name = name, **kwargs)
+    acc.setPrivateTools(DistributedKalmanFilter)
+    return acc
+
+def InDetGlobalChi2FitterCfg(flags, name='InDetGlobalChi2Fitter', **kwargs) :
+    acc = ComponentAccumulator()
+
+    pix_cluster_on_track_args = stripArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix'])
+    # PHF cut during fit iterations to save CPU time
+    kwargs.setdefault('MinPHFCut', flags.InDet.Tracking.minTRTPrecFrac)
+
+    if 'RotCreatorTool' not in kwargs :
+        InDetRotCreator = acc.popToolsAndMerge(InDetRotCreatorCfg(flags, **pix_cluster_on_track_args))
+        acc.addPublicTool(InDetRotCreator)
+        kwargs.setdefault('RotCreatorTool', InDetRotCreator)
+
+    use_broad_cluster_any = flags.InDet.useBroadClusterErrors and (not flags.InDet.doDBMstandalone)
+
+    if 'BroadRotCreatorTool' not in kwargs and  not flags.InDet.doRefit:
+        InDetBroadRotCreator = acc.popToolsAndMerge(InDetBroadRotCreatorCfg(flags, **pix_cluster_on_track_args))
+        acc.addPublicTool(InDetBroadRotCreator)
+        kwargs.setdefault('BroadRotCreatorTool', InDetBroadRotCreator)
+
+    if flags.InDet.doDBMstandalone:
+        kwargs.setdefault('StraightLine', True)
+        kwargs.setdefault('OutlierCut', 5)
+        kwargs.setdefault('RecalibrateTRT', False)
+        kwargs.setdefault('TRTExtensionCuts', False)
+        kwargs.setdefault('TrackChi2PerNDFCut', 20)
+
+    if flags.InDet.doRefit or use_broad_cluster_any is True:
+        kwargs.setdefault('RecalibrateSilicon', False)
+
+    if flags.InDet.doRefit:
+        kwargs.setdefault('BroadRotCreatorTool', None)
+        kwargs.setdefault('ReintegrateOutliers', False)
+        kwargs.setdefault('RecalibrateTRT', False)
+
+    if flags.InDet.doRobustReco:
+        kwargs.setdefault('OutlierCut', 10.0)
+        kwargs.setdefault('TrackChi2PerNDFCut', 20)
+
+    if flags.InDet.doRobustReco or flags.Beam.Type == 'cosmics':
+        kwargs.setdefault('MaxOutliers', 99)
+
+    if flags.Beam.Type == 'cosmics' or flags.InDet.doBeamHalo:
+        kwargs.setdefault('Acceleration', False)
+
+    if flags.InDet.materialInteractions and not flags.BField.solenoidOn:
+        kwargs.setdefault('Momentum', 1000.*Units.MeV)
+
+    InDetGlobalChi2FitterBase = acc.popToolsAndMerge(InDetGlobalChi2FitterBaseCfg(flags, name=name, **kwargs))
+    acc.setPrivateTools(InDetGlobalChi2FitterBase)
+    return acc
+
+def InDetGsfMaterialUpdatorCfg(name='InDetGsfMaterialUpdator', **kwargs) :
+    the_name = makeName( name, kwargs)
+    acc = ComponentAccumulator()
+
+    if 'MaximumNumberOfComponents' not in kwargs :
+        kwargs.setdefault('MaximumNumberOfComponents', 12)
+
+    GsfMaterialMixtureConvolution = CompFactory.Trk.GsfMaterialMixtureConvolution (name = the_name, **kwargs)
+    acc.setPrivateTools(GsfMaterialMixtureConvolution)
+    return acc
+
+def InDetGsfExtrapolatorCfg(flags, name='InDetGsfExtrapolator', **kwargs) :
+    the_name = makeName(name,kwargs)
+    acc = ComponentAccumulator()
+
+    if 'Propagators' not in kwargs :
+        from  InDetConfig.InDetRecToolConfig import InDetPropagatorCfg
+        InDetPropagator = acc.popToolsAndMerge(InDetPropagatorCfg(flags))
+        acc.addPublicTool(InDetPropagator)
+        kwargs.setdefault('Propagators', [ InDetPropagator ])
+
+    if 'Navigator' not in kwargs :
+        from InDetConfig.InDetRecToolConfig  import InDetNavigatorCfg
+        InDetNavigator = acc.popToolsAndMerge(InDetNavigatorCfg(flags))
+        acc.addPublicTool(InDetNavigator)
+        kwargs.setdefault('Navigator', InDetNavigator)
+
+    if 'GsfMaterialConvolution' not in kwargs :
+        InDetGsfMaterialUpdato = acc.popToolsAndMerge(InDetGsfMaterialUpdatorCfg())
+        acc.addPublicTool(InDetGsfMaterialUpdato)
+        kwargs.setdefault('GsfMaterialConvolution', InDetGsfMaterialUpdato)
+
+    kwargs.setdefault('SearchLevelClosestParameters', 10)
+    kwargs.setdefault('StickyConfiguration', True)
+    kwargs.setdefault('SurfaceBasedMaterialEffects', False)
+
+    GsfExtrapolator = CompFactory.Trk.GsfExtrapolator(name = the_name, **kwargs)
+    acc.setPrivateTools(GsfExtrapolator)
+    return acc
+
+def GaussianSumFitterCfg(flags, name='GaussianSumFitter', **kwargs) :
+    acc = ComponentAccumulator()
+
+    pix_cluster_on_track_args = stripArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix'])
+
+    if 'ToolForROTCreation' not in kwargs :
+        InDetRotCreator = acc.popToolsAndMerge(InDetRotCreatorCfg(flags, **pix_cluster_on_track_args))
+        acc.addPublicTool(InDetRotCreator)
+        kwargs.setdefault('ToolForROTCreation', InDetRotCreator)
+
+    if 'ToolForExtrapolation' not in kwargs :
+        InDetGsfExtrapolator = acc.popToolsAndMerge(InDetGsfExtrapolatorCfg(flags))
+        acc.addPublicTool(InDetGsfExtrapolator)
+        kwargs.setdefault('ToolForExtrapolation', InDetGsfExtrapolator)
+    
+    kwargs.setdefault('ReintegrateOutliers', False)
+    kwargs.setdefault('MakePerigee', True)
+    kwargs.setdefault('RefitOnMeasurementBase', True)
+    kwargs.setdefault('DoHitSorting', True)
+
+    GaussianSumFitter = CompFactory.Trk.GaussianSumFitter(name = name, **kwargs)
+    acc.setPrivateTools(GaussianSumFitter)
+    return acc
+
+def InDetTrackFitterCfg(flags, name='InDetTrackFitter', **kwargs) :
+    return {
+            'KalmanFitter'            : KalmanFitterCfg,
+            'KalmanDNAFitter'         : KalmanDNAFitterCfg,
+            'ReferenceKalmanFitter'   : ReferenceKalmanFitterCfg,
+            'DistributedKalmanFilter' : DistributedKalmanFilterCfg,
+            'GlobalChi2Fitter'        : InDetGlobalChi2FitterCfg,
+            'GaussianSumFilter'       : GaussianSumFitterCfg
+    }[flags.InDet.trackFitterType](flags, name=name, **kwargs)
+
+def InDetGlobalChi2FitterBaseCfg(flags, name='GlobalChi2FitterBase', **kwargs) :
     from InDetConfig.InDetRecToolConfig  import InDetNavigatorCfg, InDetPropagatorCfg, InDetExtrapolatorCfg
     acc = ComponentAccumulator()
 
+    from TrkConfig.AtlasTrackingGeometrySvcConfig import TrackingGeometrySvcCfg
+    acc.merge(TrackingGeometrySvcCfg(flags))
+    AtlasTrackingGeometrySvc = acc.getService('AtlasTrackingGeometrySvc')
+
     tmpAcc =  InDetExtrapolatorCfg(flags)
     InDetExtrapolator = tmpAcc.getPrimary()
     acc.merge(tmpAcc)
@@ -560,35 +901,140 @@ def GlobalChi2FitterCfg(flags, name ='InDetTrackFitterTRT', **kwargs):
     InDetPropagator = acc.popToolsAndMerge(InDetPropagatorCfg(flags))
     acc.addPublicTool(InDetPropagator)
 
-    InDetRefitRotCreator = acc.popToolsAndMerge(InDetRefitRotCreatorCfg(flags))
-    acc.addPublicTool(InDetRefitRotCreator)
-
     InDetUpdator = InDetUpdatorCfg(flags)
     acc.addPublicTool(InDetUpdator)
 
     InDetMultipleScatteringUpdator = acc.popToolsAndMerge(InDetMultipleScatteringUpdatorCfg())
     acc.addPublicTool(InDetMultipleScatteringUpdator)
 
-    if flags.InDet.doRobustReco or flags.Beam.Type == "cosmics":
-        kwargs.setdefault("MaxOutliers", 99)
-
-    if flags.InDet.materialInteractions and not flags.BField.solenoidOn:
-        from AthenaCommon.SystemOfUnits import MeV
-        kwargs.setdefault("Momentum", 1000.*MeV)
+    from InDetConfig.InDetRecToolConfig  import InDetMaterialEffectsUpdatorCfg
+    InDetMaterialEffectsUpdator = acc.popToolsAndMerge(InDetMaterialEffectsUpdatorCfg(flags))
+    acc.addPublicTool(InDetMaterialEffectsUpdator)
 
     kwargs.setdefault("ExtrapolationTool", InDetExtrapolator)
     kwargs.setdefault("NavigatorTool", InDetNavigator)
     kwargs.setdefault("PropagatorTool", InDetPropagator)
-    kwargs.setdefault("RotCreatorTool", InDetRefitRotCreator)
-    kwargs.setdefault("MeasurementUpdateTool", InDetUpdator)
     kwargs.setdefault("MultipleScatteringTool", InDetMultipleScatteringUpdator)
+    kwargs.setdefault("MeasurementUpdateTool", InDetUpdator)
+    kwargs.setdefault("TrackingGeometrySvc", AtlasTrackingGeometrySvc)
+    kwargs.setdefault("MaterialUpdateTool", InDetMaterialEffectsUpdator)
     kwargs.setdefault("StraightLine", not flags.BField.solenoidOn)
-    kwargs.setdefault("ReintegrateOutliers", False)
+    kwargs.setdefault("OutlierCut", 4)
+    kwargs.setdefault("SignedDriftRadius", True)
+    kwargs.setdefault("ReintegrateOutliers", True)
+    kwargs.setdefault("RecalibrateSilicon", True)
+    kwargs.setdefault("RecalibrateTRT", True)
+    kwargs.setdefault("TRTTubeHitCut", 1.75)
+    kwargs.setdefault("MaxIterations", 40)
+    kwargs.setdefault("Acceleration", True)
+    kwargs.setdefault("RecalculateDerivatives", flags.InDet.doMinBias or flags.Beam.Type == 'cosmics' or flags.InDet.doBeamHalo)
+    kwargs.setdefault("TRTExtensionCuts", True)
+    kwargs.setdefault("TrackChi2PerNDFCut", 7)
+
+    GlobalChi2Fitter = CompFactory.Trk.GlobalChi2Fitter(name=name, **kwargs)
+    acc.setPrivateTools(GlobalChi2Fitter)
+    return acc
+
+def InDetGlobalChi2FitterTRTCfg(flags, name='InDetGlobalChi2FitterTRT', **kwargs) :
+    acc = ComponentAccumulator()
+    '''
+    Global Chi2 Fitter for TRT segments with different settings
+    '''
+    pix_cluster_on_track_args = stripArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix'])
+
+    if 'RotCreatorTool' not in kwargs :
+        InDetRefitRotCreator = acc.popToolsAndMerge(InDetRefitRotCreatorCfg(flags, **pix_cluster_on_track_args))
+        acc.addPublicTool(InDetRefitRotCreator)
+        kwargs.setdefault("RotCreatorTool", InDetRefitRotCreator)
+
+    kwargs.setdefault("MaterialUpdateTool", '')
+    kwargs.setdefault("TrackingGeometrySvc", '')
+    kwargs.setdefault("SignedDriftRadius", True)
+    kwargs.setdefault("RecalibrateSilicon", False)
+    kwargs.setdefault("RecalibrateTRT", False)
+    kwargs.setdefault("TRTTubeHitCut", 2.5)
     kwargs.setdefault("MaxIterations", 10)
+    kwargs.setdefault("Acceleration", False)
     kwargs.setdefault("RecalculateDerivatives", False)
+    kwargs.setdefault("TRTExtensionCuts", True)
     kwargs.setdefault("TrackChi2PerNDFCut", 999999)
+    kwargs.setdefault("Momentum", 1000.*Units.MeV   if flags.InDet.materialInteractions and not flags.BField.solenoidOn else  0)
+    kwargs.setdefault("OutlierCut", 5)
+    kwargs.setdefault("MaxOutliers", 99 if flags.InDet.doRobustReco or flags.Beam.Type == 'cosmics' else 10)
+    kwargs.setdefault("ReintegrateOutliers", False if flags.InDet.doRefit else False)
 
-    acc.setPrivateTools(CompFactory.Trk.GlobalChi2Fitter(name = name, **kwargs))
+    InDetGlobalChi2FitterBase = acc.popToolsAndMerge(InDetGlobalChi2FitterBaseCfg(flags, name=name, **kwargs))
+    acc.setPrivateTools(InDetGlobalChi2FitterBase)
+    return acc
+
+def InDetTrackFitterTRTCfg(flags, name='InDetTrackFitterTRT', **kwargs) :
+    acc = ComponentAccumulator()
+
+    if flags.InDet.trackFitterType != 'GlobalChi2Fitter' :
+        InDetTrackFitter = acc.popToolsAndMerge(InDetTrackFitterCfg(flags, name, **kwargs))
+        acc.setPrivateTools(InDetTrackFitter)
+    else :
+        InDetGlobalChi2FitterTRT = acc.popToolsAndMerge(InDetGlobalChi2FitterTRTCfg(flags, name, **kwargs))
+        acc.setPrivateTools(InDetGlobalChi2FitterTRT)
+
+    return acc
+
+def InDetGlobalChi2FitterLowPtCfg(flags, name='InDetGlobalChi2FitterLowPt', **kwargs) :
+    acc = ComponentAccumulator()
+    # @TODO TrackingGeometrySvc was not set but is set now
+    #       RotCreatorTool and BroadRotCreatorTool not set
+    pix_cluster_on_track_args = stripArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix'])
+
+    if 'RotCreatorTool' not in kwargs :
+        InDetRotCreator = acc.popToolsAndMerge(InDetRotCreatorCfg(flags, **pix_cluster_on_track_args))
+        acc.addPublicTool(InDetRotCreator)
+        kwargs.setdefault('RotCreatorTool', InDetRotCreator)
+
+    if 'BroadRotCreatorTool' not in kwargs and  not flags.InDet.doRefit:
+        InDetBroadRotCreator = acc.popToolsAndMerge(InDetBroadRotCreatorCfg(flags, **pix_cluster_on_track_args))
+        acc.addPublicTool(InDetBroadRotCreator)
+        kwargs.setdefault('BroadRotCreatorTool', InDetBroadRotCreator)
+
+    kwargs.setdefault('OutlierCut', 5.0)
+    kwargs.setdefault('Acceleration', False)
+    kwargs.setdefault('RecalculateDerivatives', True)
+    kwargs.setdefault('TrackChi2PerNDFCut', 10)
+
+    InDetGlobalChi2FitterBase = acc.popToolsAndMerge(InDetGlobalChi2FitterBaseCfg(flags, name=name, **kwargs))
+    acc.setPrivateTools(InDetGlobalChi2FitterBase)
+    return acc
+
+def InDetTrackFitterLowPt(flags, name='InDetTrackFitter', **kwargs) :
+    acc = ComponentAccumulator()
+
+    if flags.InDet.trackFitterType != 'GlobalChi2Fitter' :
+        InDetTrackFitter = acc.popToolsAndMerge(InDetTrackFitterCfg(flags, name, **kwargs))
+        acc.setPrivateTools(InDetTrackFitter)
+    else :
+        InDetGlobalChi2FitterLowPt = acc.popToolsAndMerge(InDetGlobalChi2FitterLowPtCfg(flags, name, **kwargs))
+        acc.setPrivateTools(InDetGlobalChi2FitterLowPt)
+    return acc
+
+def InDetGlobalChi2FitterBTCfg(flags, name='InDetGlobalChi2FitterBT', **kwargs):
+    acc = ComponentAccumulator()
+    '''
+    Global Chi2 Fitter for backtracking
+    '''
+    kwargs.setdefault("MinPHFCut", 0.)
+
+    InDetGlobalChi2Fitter = acc.popToolsAndMerge(InDetGlobalChi2FitterCfg(flags, name=name, **kwargs))
+    acc.setPrivateTools(InDetGlobalChi2Fitter)
+    return acc
+
+def InDetTrackFitterBTCfg(flags, name='InDetTrackFitterBT', **kwargs) :
+    acc = ComponentAccumulator()
+
+    if flags.InDet.trackFitterType != 'GlobalChi2Fitter' :
+        InDetTrackFitter = acc.popToolsAndMerge(InDetTrackFitterCfg(flags, name, **kwargs))
+        acc.setPrivateTools(InDetTrackFitter)
+    else :
+        InDetGlobalChi2Fitter = acc.popToolsAndMerge(InDetGlobalChi2FitterBTCfg(flags, name, **kwargs))
+        acc.setPrivateTools(InDetGlobalChi2Fitter)
     return acc
 
 def InDetTrackSummaryToolTRTTracksCfg(flags, name='InDetTrackSummaryToolTRTTracks',**kwargs):
@@ -613,35 +1059,6 @@ def InDetKOL(name = 'InDetKOL', **kwargs):
     kwargs.setdefault("StateChi2PerNDFCut", 12.5)
     PublicKOL = CompFactory.Trk.KalmanOutlierLogic
     return PublicKOL(name = name, **kwargs)
-
-def InDetKalmanFitterCfg(flags, name ='InDetKalmanFitter', **kwargs):
-    acc = ComponentAccumulator()
-    from InDetConfig.InDetRecToolConfig import InDetExtrapolatorCfg
-
-    tmpAcc =  InDetExtrapolatorCfg(flags)
-    InDetExtrapolator = tmpAcc.getPrimary()
-    acc.merge(tmpAcc)
-
-    InDetUpdator = InDetUpdatorCfg(flags)
-    acc.addPublicTool(InDetUpdator)
-
-    InDetRotCreator = acc.popToolsAndMerge(InDetRotCreatorCfg(flags))
-    acc.addPublicTool(InDetRotCreator)
-
-    kwargs.setdefault("ExtrapolatorHandle", InDetExtrapolator)
-    kwargs.setdefault("RIO_OnTrackCreatorHandle", InDetRotCreator)
-    kwargs.setdefault("MeasurementUpdatorHandle", InDetUpdator)
-    kwargs.setdefault("ForwardKalmanFitterHandle", InDetFKF())
-    kwargs.setdefault("KalmanSmootherHandle", InDetBKS())
-    kwargs.setdefault("KalmanOutlierLogicHandle", InDetKOL())
-    kwargs.setdefault("DynamicNoiseAdjustorHandle", None)
-    kwargs.setdefault("BrempointAnalyserHandle", None)
-    kwargs.setdefault("AlignableSurfaceProviderHandle", None)
-    kwargs.setdefault("RecalibratorHandle", None)
-    kwargs.setdefault("InternalDAFHandle", None)
-
-    acc.setPrivateTools(CompFactory.Trk.KalmanFitter(name = name, **kwargs))
-    return acc
 #############################################################################################
 #TRTSegmentFinder
 #############################################################################################
@@ -823,7 +1240,7 @@ def TRT_DetElementsRoadCondAlgCfg(**kwargs):
 def InDetRotCreatorDigitalCfg(flags, name='InDetRotCreatorDigital', **kwargs) :
     acc = ComponentAccumulator()
     if 'ToolPixelCluster' not in kwargs :
-        pix_cluster_on_track_args = copyArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','RenounceInputHandles','nameSuffix'])
+        pix_cluster_on_track_args = copyArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix'])
 
         ToolPixelCluster = InDetPixelClusterOnTrackToolDigitalCfg(flags, **pix_cluster_on_track_args)
         kwargs.setdefault('ToolPixelCluster', ToolPixelCluster)
@@ -925,11 +1342,16 @@ def SiCombinatorialTrackFinder_xkCfg(flags, name='InDetSiComTrackFinder', **kwar
     InDetRotCreatorDigital = acc.popToolsAndMerge(InDetRotCreatorDigitalCfg(flags))
     acc.addPublicTool(InDetRotCreatorDigital)
 
+    from  InDetConfig.InDetRecToolConfig import InDetBoundaryCheckToolCfg
+    InDetBoundaryCheckTool = acc.popToolsAndMerge(InDetBoundaryCheckToolCfg(flags))
+    acc.addPublicTool(InDetBoundaryCheckTool)
+
     kwargs.setdefault("PropagatorTool",  InDetPatternPropagator)
     kwargs.setdefault("UpdatorTool", InDetPatternUpdator)
+    kwargs.setdefault("BoundaryCheckTool", InDetBoundaryCheckTool)
     kwargs.setdefault("RIOonTrackTool", InDetRotCreatorDigital)
     kwargs.setdefault("usePixel", flags.Detector.RecoPixel) #DetFlags.haveRIO.pixel_on()
-    kwargs.setdefault("useSCT", flags.Detector.RecoSCT) #DetFlags.haveRIO.SCT_on()
+    kwargs.setdefault("useSCT", False)
     kwargs.setdefault("PixelClusterContainer", 'PixelClusters') #InDetKeys.PixelClusters()
     kwargs.setdefault("SCT_ClusterContainer", 'SCT_Clusters') # InDetKeys.SCT_Clusters()
 
@@ -1016,7 +1438,7 @@ def InDetPixelClusterOnTrackToolDBMCfg(flags, name='InDetPixelClusterOnTrackTool
 def InDetRotCreatorDBMCfg(flags, name='InDetRotCreatorDBM', **kwargs) :
     acc = ComponentAccumulator()
     if 'ToolPixelCluster' not in kwargs :
-        pix_cluster_on_track_args = copyArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','RenounceInputHandles','nameSuffix'])
+        pix_cluster_on_track_args = copyArgs(kwargs,['SplitClusterMapExtension','ClusterSplitProbabilityName','nameSuffix'])
 
         if flags.InDet.loadRotCreator and flags.Detector.RecoPixel:
             ToolPixelCluster = InDetPixelClusterOnTrackToolDBMCfg(flags, pix_cluster_on_track_args)
diff --git a/InnerDetector/InDetDetDescr/InDetTrackingGeometry/src/BeamPipeBuilderCond.cxx b/InnerDetector/InDetDetDescr/InDetTrackingGeometry/src/BeamPipeBuilderCond.cxx
index b76e58c252896ef22daa679cb53b6c19db9820c3..f12714475323156a23af2e6d94665c5f48cfc2ba 100755
--- a/InnerDetector/InDetDetDescr/InDetTrackingGeometry/src/BeamPipeBuilderCond.cxx
+++ b/InnerDetector/InDetDetDescr/InDetTrackingGeometry/src/BeamPipeBuilderCond.cxx
@@ -119,8 +119,29 @@ std::pair<EventIDRange, const std::vector< const Trk::CylinderLayer* >*>  InDet:
             // get the geoShape and translate
             Trk::GeoShapeConverter geoShaper;
             beamPipeTube = dynamic_cast<const GeoTube*>(beamPipeLogVolume->getShape());
-            if (beamPipeTube)
-                beamPipeRadius = beamPipeTube->getRMax()-m_beamPipeEnvelope;
+            if (beamPipeTube){
+
+	      for(unsigned int i=0;i<beamPipeTopVolume->getNChildVols();i++){
+
+		if(beamPipeTopVolume->getNameOfChildVol(i)=="SectionC03"){
+		  PVConstLink childTopVolume =  beamPipeTopVolume->getChildVol(i);
+		  const GeoLogVol* childLogVolume = childTopVolume->getLogVol();
+		  const GeoTube* childTube = 0;
+
+		  if (childLogVolume){
+		    childTube = dynamic_cast<const GeoTube*>(childLogVolume->getShape());
+		    if (childTube){
+		      beamPipeRadius = 0.5 * (childTube->getRMax()+childTube->getRMin());
+		    }
+		  }
+
+		  break; //Exit loop after SectionC03 is found
+		}
+
+	      } // Loop over child volumes
+
+	    }
+
         }
         ATH_MSG_VERBOSE("BeamPipe constructed from Database: translation (yes) - radius "<< ( beamPipeTube ? "(yes)" : "(no)") << " - r = " << beamPipeRadius );        
   } else 
diff --git a/InnerDetector/InDetDetDescr/SCT_Cabling/src/SCT_CablingTool.cxx b/InnerDetector/InDetDetDescr/SCT_Cabling/src/SCT_CablingTool.cxx
index 7832fc63c83d9badde54e6b93690a5bc7c7d4754..48aece39e277a9bcab83041967ee681cb27a0a0b 100644
--- a/InnerDetector/InDetDetDescr/SCT_Cabling/src/SCT_CablingTool.cxx
+++ b/InnerDetector/InDetDetDescr/SCT_Cabling/src/SCT_CablingTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /**
@@ -49,7 +49,7 @@ SCT_CablingTool::SCT_CablingTool(const std::string& type, const std::string& nam
 //
 StatusCode
 SCT_CablingTool::initialize() {
-  ATH_MSG_INFO("Initialize SCT cabling");
+  ATH_MSG_DEBUG("Initialize SCT cabling");
   const std::string cablingDataSource = m_cablingDataSource.value();
   m_usingDatabase=(cablingDataSource == coracool) or (cablingDataSource == coolVectorPayload) or (cablingDataSource == file);
   ATH_CHECK(detStore()->retrieve(m_idHelper, "SCT_ID"));
@@ -57,13 +57,6 @@ SCT_CablingTool::initialize() {
   return StatusCode::SUCCESS;
 }
 
-// 
-StatusCode
-SCT_CablingTool::finalize() {
-  ATH_MSG_INFO("Thank-you for using the SCT_CablingTool");
-  return StatusCode::SUCCESS;
-}
-
 //
 unsigned int
 SCT_CablingTool::size(const EventContext& ctx) const {
diff --git a/InnerDetector/InDetDetDescr/SCT_Cabling/src/SCT_CablingTool.h b/InnerDetector/InDetDetDescr/SCT_Cabling/src/SCT_CablingTool.h
index 904c37f0a09d65c52d2b2ad40b855f089ff4f8b5..ea820fc607a4a2866a4e1f0976b87a26ebb5deda 100644
--- a/InnerDetector/InDetDetDescr/SCT_Cabling/src/SCT_CablingTool.h
+++ b/InnerDetector/InDetDetDescr/SCT_Cabling/src/SCT_CablingTool.h
@@ -44,7 +44,6 @@ class SCT_CablingTool: public extends<AthAlgTool, ISCT_CablingTool> {
   SCT_CablingTool(const std::string& type, const std::string& name, const IInterface* parent);
   virtual ~SCT_CablingTool() = default;
   virtual StatusCode initialize() override;
-  virtual StatusCode finalize() override;
   //@}
   
   //@name ISCT_CablingTool methods implemented, these are visible to clients
diff --git a/InnerDetector/InDetEventCnv/InDetEventAthenaPool/test/InDetSimDataCollectionCnv_common_test.h b/InnerDetector/InDetEventCnv/InDetEventAthenaPool/test/InDetSimDataCollectionCnv_common_test.h
index a517380278106309318e4eeef56806a9b754d04e..806b45cd25edf220d6bb65340a23061f0419c1c9 100644
--- a/InnerDetector/InDetEventCnv/InDetEventAthenaPool/test/InDetSimDataCollectionCnv_common_test.h
+++ b/InnerDetector/InDetEventCnv/InDetEventAthenaPool/test/InDetSimDataCollectionCnv_common_test.h
@@ -15,6 +15,7 @@
 
 #include "AtlasHepMC/GenEvent.h"
 #include "AtlasHepMC/GenParticle.h"
+#include "AtlasHepMC/Operators.h"
 #include "GeneratorObjectsTPCnv/initMcEventCollection.h"
 #include "InDetIdentifier/PixelID.h"
 #include "IdDictParser/IdDictParser.h"
diff --git a/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/CMakeLists.txt b/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/CMakeLists.txt
index d083dfad1825329180397afcc64bcbcaabd9c8fb..ff5c6c2a395f2502833ce8d958cc9af73f85470a 100644
--- a/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/CMakeLists.txt
+++ b/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/CMakeLists.txt
@@ -32,7 +32,10 @@ atlas_add_test( TestSCTEncode
                 PROPERTIES TIMEOUT 300
                 ENVIRONMENT THREADS=1 )
 atlas_add_test( TestSCTDecodeNewConf
-                SCRIPT python -m SCT_RawDataByteStreamCnv.SCT_RawDataByteStreamCnvConfig
+                SCRIPT python -m SCT_RawDataByteStreamCnv.testSCTDecodeNewConf
+                PROPERTIES TIMEOUT 600 )
+atlas_add_test( TestSCTEncodeNewConf
+                SCRIPT python -m SCT_RawDataByteStreamCnv.testSCTEncodeNewConf
                 PROPERTIES TIMEOUT 600 )
 
 # Install files from the package:
diff --git a/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/SCT_RawDataByteStreamCnvConfig.py b/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/SCT_RawDataByteStreamCnvConfig.py
index 760a1a4ace1942ac2d5a4aa3a5633dff233efdef..bcdc96b2fe30b46e7244388647a6566b2c1e3c67 100644
--- a/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/SCT_RawDataByteStreamCnvConfig.py
+++ b/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/SCT_RawDataByteStreamCnvConfig.py
@@ -35,25 +35,3 @@ def SCTEventFlagWriterCfg(flags, prefix="InDet", suffix="", **kwargs):
     acc.addEventAlgo(CompFactory.SCTEventFlagWriter(name=prefix+"SCTEventFlagWriter"+suffix,
                                                     **kwargs))
     return acc
-
-if __name__ == "__main__":
-    from AthenaCommon.Configurable import Configurable
-    Configurable.configurableRun3Behavior = 1
-
-    from AthenaConfiguration.AllConfigFlags import ConfigFlags
-    ConfigFlags.Input.Files = ["/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/data17_13TeV.00330470.physics_Main.daq.RAW._lb0310._SFO-1._0001.data"]
-    ConfigFlags.IOVDb.GlobalTag = "CONDBR2-BLKPA-2018-03"
-    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R2-2016-01-00-01"
-    ConfigFlags.Detector.GeometrySCT = True
-    ConfigFlags.lock()
-
-    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
-    acc = MainServicesCfg(ConfigFlags)
-
-    from ByteStreamCnvSvc.ByteStreamConfig import ByteStreamReadCfg
-    acc.merge(ByteStreamReadCfg(ConfigFlags))
-
-    acc.merge(SCTRawDataProviderCfg(ConfigFlags))
-    acc.merge(SCTEventFlagWriterCfg(ConfigFlags))
-
-    acc.run(maxEvents=10)
diff --git a/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/testSCTDecodeNewConf.py b/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/testSCTDecodeNewConf.py
new file mode 100644
index 0000000000000000000000000000000000000000..01a2efb6396bba2fd2247cc38f213b7e58bc478e
--- /dev/null
+++ b/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/testSCTDecodeNewConf.py
@@ -0,0 +1,27 @@
+#
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+#
+
+if __name__ == "__main__":
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior = 1
+
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.Files = ["/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/data17_13TeV.00330470.physics_Main.daq.RAW._lb0310._SFO-1._0001.data"]
+    ConfigFlags.IOVDb.GlobalTag = "CONDBR2-BLKPA-2018-03"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R2-2016-01-00-01"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    acc = MainServicesCfg(ConfigFlags)
+
+    from ByteStreamCnvSvc.ByteStreamConfig import ByteStreamReadCfg
+    acc.merge(ByteStreamReadCfg(ConfigFlags))
+
+    from SCT_RawDataByteStreamCnv.SCT_RawDataByteStreamCnvConfig import SCTRawDataProviderCfg
+    acc.merge(SCTRawDataProviderCfg(ConfigFlags))
+    from SCT_RawDataByteStreamCnv.SCT_RawDataByteStreamCnvConfig import SCTEventFlagWriterCfg
+    acc.merge(SCTEventFlagWriterCfg(ConfigFlags))
+
+    acc.run(maxEvents=10)
diff --git a/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/testSCTEncodeNewConf.py b/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/testSCTEncodeNewConf.py
new file mode 100644
index 0000000000000000000000000000000000000000..7134a51451760999753fe200c801e36a938c22fc
--- /dev/null
+++ b/InnerDetector/InDetEventCnv/SCT_RawDataByteStreamCnv/python/testSCTEncodeNewConf.py
@@ -0,0 +1,43 @@
+#
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+#
+
+if __name__ == "__main__":
+    from AthenaCommon.Configurable import Configurable
+    Configurable.configurableRun3Behavior = 1
+
+    from AthenaConfiguration.AllConfigFlags import ConfigFlags
+    ConfigFlags.Input.isMC = True
+    ConfigFlags.Input.Files = ["/afs/cern.ch/atlas/project/rig/referencefiles/RTTinputFiles/MC15_13TeV/valid1.110401.PowhegPythia_P2012_ttbar_nonallhad.recon.RDO.e3099_s2578_r6699_10evt.pool.root"]
+    ConfigFlags.IOVDb.GlobalTag = "OFLCOND-RUN12-SDR-31"
+    ConfigFlags.GeoModel.AtlasVersion = "ATLAS-R2-2015-03-01-00"
+    ConfigFlags.Detector.GeometrySCT = True
+    ConfigFlags.lock()
+
+    from AthenaConfiguration.MainServicesConfig import MainServicesCfg
+    acc = MainServicesCfg(ConfigFlags)
+
+    # For POOL file reading
+    from AthenaPoolCnvSvc.PoolReadConfig import PoolReadCfg
+    acc.merge(PoolReadCfg(ConfigFlags))
+
+    # For ByteStream file writing
+    from ByteStreamCnvSvc.ByteStreamConfig import ByteStreamWriteCfg
+    writingAcc = ByteStreamWriteCfg(ConfigFlags, [ "SCT_RDO_Container#SCT_RDOs" ] )
+    writingAcc.getService("ByteStreamEventStorageOutputSvc").StreamType = "EventStorage"
+    writingAcc.getService("ByteStreamEventStorageOutputSvc").StreamName = "StreamBSFileOutput"
+    acc.merge(writingAcc)
+
+    # For SCT geometry and cabling
+    from SCT_GeoModel.SCT_GeoModelConfig import SCT_GeometryCfg
+    acc.merge(SCT_GeometryCfg(ConfigFlags))
+    from InDetConfig.InDetRecToolConfig import SCT_CablingToolCfg
+    acc.popToolsAndMerge(SCT_CablingToolCfg(ConfigFlags))
+
+    # For EventInfo necessary for ByteStream file writing
+    from xAODEventInfoCnv.xAODEventInfoCnvConfig import EventInfoCnvAlgCfg
+    acc.merge(EventInfoCnvAlgCfg(ConfigFlags,
+                                 inputKey="McEventInfo",
+                                 outputKey="EventInfo"))
+
+    acc.run(maxEvents=10)
diff --git a/InnerDetector/InDetExample/InDetRecExample/python/InDetJobProperties.py b/InnerDetector/InDetExample/InDetRecExample/python/InDetJobProperties.py
index bde48a9e830dc70529939563ef5a30abbc1b54bf..e945c5532be84cc23f7534525f515bec5d4b4d14 100644
--- a/InnerDetector/InDetExample/InDetRecExample/python/InDetJobProperties.py
+++ b/InnerDetector/InDetExample/InDetRecExample/python/InDetJobProperties.py
@@ -1261,6 +1261,7 @@ class InDetJobProperties(JobPropertyContainer):
        self.checkThenSet(self.doTRTPhaseCalculation  , False)
        self.checkThenSet(self.doTRTStandalone        , True)
        self.checkThenSet(self.doForwardTracks        , False)
+       self.checkThenSet(self.doR3LargeD0            , False)
        self.checkThenSet(self.doBackTracking         , False)
        self.checkThenSet(self.doVertexFinding        , False)
        self.checkThenSet(self.doV0Finder             , False)
@@ -1281,6 +1282,7 @@ class InDetJobProperties(JobPropertyContainer):
        self.checkThenSet(self.doBeamHalo             , False)
        self.checkThenSet(self.doBackTracking         , False)
        self.checkThenSet(self.doForwardTracks        , False)
+       self.checkThenSet(self.doR3LargeD0            , False)
        self.checkThenSet(self.doTRTStandalone        , True ) # *ME* this is different than 15.4.0 and before
        self.checkThenSet(self.doTRTPhaseCalculation  , True )
        self.checkThenSet(self.doParticleCreation     , True )
@@ -1315,6 +1317,7 @@ class InDetJobProperties(JobPropertyContainer):
        self.checkThenSet(self.doTrackSegmentsSCT     , False)
        self.checkThenSet(self.doTrackSegmentsTRT     , False)
        self.checkThenSet(self.doForwardTracks        , False)
+       self.checkThenSet(self.doR3LargeD0            , False)
        self.checkThenSet(self.doBeamGas              , False)
        self.checkThenSet(self.doBeamHalo             , False)
        self.checkThenSet(self.doVertexFinding        , True)
@@ -1347,6 +1350,7 @@ class InDetJobProperties(JobPropertyContainer):
        self.checkThenSet(self.doBackTracking         , False)
        self.checkThenSet(self.doTRTStandalone        , False)
        self.checkThenSet(self.doForwardTracks        , False)
+       self.checkThenSet(self.doR3LargeD0            , False)
        self.checkThenSet(self.doVertexFinding        , True)
        self.checkThenSet(self.primaryVertexSetup     , "IterativeFinding")
        self.checkThenSet(self.primaryVertexCutSetup  , "SLHC")
@@ -1403,6 +1407,7 @@ class InDetJobProperties(JobPropertyContainer):
        self.checkThenSet(self.doBackTracking         , False)
        self.checkThenSet(self.doTRTStandalone        , False)
        self.checkThenSet(self.doForwardTracks        , False)
+       self.checkThenSet(self.doR3LargeD0            , False)
        self.checkThenSet(self.doVertexFinding        , True)
        self.checkThenSet(self.primaryVertexSetup     , "IterativeFinding") 
        self.checkThenSet(self.primaryVertexCutSetup  , "Offline") 
@@ -1430,6 +1435,7 @@ class InDetJobProperties(JobPropertyContainer):
        self.checkThenSet(self.doBackTracking         , False)
        self.checkThenSet(self.doTRTStandalone        , False)
        self.checkThenSet(self.doForwardTracks        , False)
+       self.checkThenSet(self.doR3LargeD0            , False)
        self.checkThenSet(self.doVertexFinding        , True)
        self.checkThenSet(self.primaryVertexSetup     , "IterativeFinding") 
        self.checkThenSet(self.primaryVertexCutSetup  , "Offline") 
@@ -1468,6 +1474,7 @@ class InDetJobProperties(JobPropertyContainer):
        self.checkThenSet(self.doBackTracking         , False)
        self.checkThenSet(self.doTRTStandalone        , False)
        self.checkThenSet(self.doForwardTracks        , False)
+       self.checkThenSet(self.doR3LargeD0            , False)
        self.checkThenSet(self.doVertexFinding        , True)
        self.checkThenSet(self.primaryVertexSetup     , "IterativeFinding")
        self.checkThenSet(self.primaryVertexCutSetup  , "Offline")
@@ -1501,6 +1508,7 @@ class InDetJobProperties(JobPropertyContainer):
        self.checkThenSet(self.doVeryLowPt            , False )
        self.checkThenSet(self.doSLHCConversionFinding, False)
        self.checkThenSet(self.doForwardTracks        , False )
+       self.checkThenSet(self.doR3LargeD0            , False )
        self.checkThenSet(self.doBeamGas              , False )
        self.checkThenSet(self.doBeamHalo             , False )
        self.checkThenSet(self.doBackTracking         , False )
diff --git a/InnerDetector/InDetExample/InDetRecExample/share/ConfiguredTRTSegmentFinding.py b/InnerDetector/InDetExample/InDetRecExample/share/ConfiguredTRTSegmentFinding.py
index f4d53ada886c8a1dc2b50bfcc49394dc208f97ca..9aa33c9c4e23778871300ed5de93a7a2204c3722 100644
--- a/InnerDetector/InDetExample/InDetRecExample/share/ConfiguredTRTSegmentFinding.py
+++ b/InnerDetector/InDetExample/InDetRecExample/share/ConfiguredTRTSegmentFinding.py
@@ -115,7 +115,7 @@ class ConfiguredTRTSegmentFinding:
       condSeq = AthSequencer("AthCondSeq")
       if not hasattr(condSeq, "InDet__TRT_TrackSegmentsMakerCondAlg_ATLxk"):
         from TRT_TrackSegmentsTool_xk.TRT_TrackSegmentsTool_xkConf import InDet__TRT_TrackSegmentsMakerCondAlg_ATLxk
-        InDetTRT_TrackSegmentsMakerCondAlg = InDet__TRT_TrackSegmentsMakerCondAlg_ATLxk(name                    = 'InDetTRT_SeedsMakerCondAlg'+extension,
+        InDetTRT_TrackSegmentsMakerCondAlg = InDet__TRT_TrackSegmentsMakerCondAlg_ATLxk(name                    = 'InDet__TRT_TrackSegmentsMakerCondAlg_ATLxk',
                                                                                         PropagatorTool          = InDetPatternPropagator,
                                                                                         NumberMomentumChannel   = NewTrackingCuts.TRTSegFinderPtBins(),
                                                                                         pTmin                   = pTmin)
diff --git a/InnerDetector/InDetExample/InDetRecExample/share/InDetMonitoringPixel.py b/InnerDetector/InDetExample/InDetRecExample/share/InDetMonitoringPixel.py
index 12e28bd78ac5140ace0ccfef1a6e75ea21f9e724..5e12c1b905164a80d25333378cb19d2b34f59a0c 100644
--- a/InnerDetector/InDetExample/InDetRecExample/share/InDetMonitoringPixel.py
+++ b/InnerDetector/InDetExample/InDetRecExample/share/InDetMonitoringPixel.py
@@ -23,27 +23,25 @@ from PixelMonitoring.PixelAthErrorMonAlgCfg import PixelAthErrorMonAlgCfg
 from InDetRecExample.InDetKeys import InDetKeys                                                                                     
 
 kwargsHitMonAlg = { 'doOnline'        : True if athenaCommonFlags.isOnline() else False,      #Histograms for online (athenaPT) running
-                     'doModules'       : True if athenaCommonFlags.isOnline() else False, #Turn on/off the sets of 1744 module histograms (for dqmf)
                      'doLumiBlock'     : False if athenaCommonFlags.isOnline() else True,       #Turn on/off histograms stored for each lumi block
                      'doLowOccupancy'  : False,      #Turn on/off histograms with binning for cosmics/single beam                    
                      'doHighOccupancy' : True,       #Turn on/off histograms with binning for collisions
                      'doHeavyIonMon'   : InDetFlags.doHeavyIon(),   # Histogram modification for heavy ion monitoring
+                     'doFEPlots'       : False,       #Turn on/off histograms with FE Status information
                      'RDOName'         : InDetKeys.PixelRDOs()
 }
 
 kwargsClusMonAlg = { 'doOnline'        : True if athenaCommonFlags.isOnline() else False,      #Histograms for online (athenaPT) running
-                      'doModules'       : True if athenaCommonFlags.isOnline() else False, #Turn on/off the sets of 1744 module histograms (for dqmf)
                       'doLumiBlock'     : False if athenaCommonFlags.isOnline() else True,       #Turn on/off histograms stored for each lumi block
                       'doLowOccupancy'  : False,      #Turn on/off histograms with binning for cosmics/single beam
                       'doHighOccupancy' : True,       #Turn on/off histograms with binning for collisions
                       'doHeavyIonMon'   : InDetFlags.doHeavyIon(),   # Histogram modification for heavy ion monitoring
-                      #                  'doStatus'        : True,       #Turn on/off histograms with Module Status information
+                      'doFEPlots'       : False,       #Turn on/off histograms with FE Status information
                       'ClusterName'     : InDetKeys.PixelClusters(),
                       'TrackName'       : InDetKeys.Tracks()
 }
 
 kwargsErrMonAlg = { 'doOnline'        : True if athenaCommonFlags.isOnline() else False,      #Histograms for online (athenaPT) running
-                     'doModules'       : True if athenaCommonFlags.isOnline() else False, #Turn on/off the sets of 1744 module histograms (for dqmf)
                      'doLumiBlock'     : False if athenaCommonFlags.isOnline() else True,       #Turn on/off histograms stored for each lumi block
                      'doLowOccupancy'  : False,      #Turn on/off histograms with binning for cosmics/single beam                    
                      'doHighOccupancy' : True,       #Turn on/off histograms with binning for collisions
diff --git a/InnerDetector/InDetExample/InDetSLHC_Example/share/preInclude.SLHC_Rec.py b/InnerDetector/InDetExample/InDetSLHC_Example/share/preInclude.SLHC_Rec.py
index 9e5473d41bf1e043845c43caacad9bf99645746e..3acc9797f2e6eddbb060f6059a6d12a2b9a63081 100644
--- a/InnerDetector/InDetExample/InDetSLHC_Example/share/preInclude.SLHC_Rec.py
+++ b/InnerDetector/InDetExample/InDetSLHC_Example/share/preInclude.SLHC_Rec.py
@@ -15,8 +15,7 @@ if rec.doWriteESD() or rec.doWriteAOD() or ('doWriteESD' in dir() and doWriteESD
     # --- turn off trigger
     #rec.doTrigger = False
     from TriggerJobOpts.TriggerFlags import TriggerFlags
-    TriggerFlags.doLVL2.set_Value_and_Lock(False)
-    TriggerFlags.doEF.set_Value_and_Lock(False)
+    TriggerFlags.doHLT.set_Value_and_Lock(False)
 
     # --- this is the SLHC 
     InDetFlags.doSLHC = True
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/CMakeLists.txt b/InnerDetector/InDetExample/InDetTrigRecExample/CMakeLists.txt
index b0e6f63e30b9741dddf4ca2c5ed83cde05e25d9a..23611ae2aa85f42346b0da38d63cfacc3eea431e 100644
--- a/InnerDetector/InDetExample/InDetTrigRecExample/CMakeLists.txt
+++ b/InnerDetector/InDetExample/InDetTrigRecExample/CMakeLists.txt
@@ -6,5 +6,3 @@ atlas_subdir( InDetTrigRecExample )
 # Install files from the package:
 atlas_install_python_modules( python/*.py )
 atlas_install_joboptions( share/*.py )
-atlas_install_scripts( share/RTT_NoBField_transform.sh )
-
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/python/ConfiguredNewTrackingTrigCuts.py b/InnerDetector/InDetExample/InDetTrigRecExample/python/ConfiguredNewTrackingTrigCuts.py
index 1835a9e49e02466e0db0a87784578a8ac04dee73..a34eca6206c86cec4ec180cb8cf55998f4aae036 100644
--- a/InnerDetector/InDetExample/InDetTrigRecExample/python/ConfiguredNewTrackingTrigCuts.py
+++ b/InnerDetector/InDetExample/InDetTrigRecExample/python/ConfiguredNewTrackingTrigCuts.py
@@ -17,7 +17,7 @@ del _sharedcuts
 
 class ConfiguredNewTrackingTrigCuts(InDetTrigTrackingCuts):
   pass
-  
+
 if not 'EFIDTrackingCuts' in globals():
   EFIDTrackingCuts = ConfiguredNewTrackingTrigCuts("Offline")
   EFIDTrackingCutsCosmics = ConfiguredNewTrackingTrigCuts("Cosmics")
@@ -25,4 +25,5 @@ if not 'EFIDTrackingCuts' in globals():
   EFIDTrackingCutsLowPt = ConfiguredNewTrackingTrigCuts("LowPt")
   EFIDTrackingCutsTRT = ConfiguredNewTrackingTrigCuts("TRT")
   EFIDTrackingCutsHeavyIon = ConfiguredNewTrackingTrigCuts("HeavyIon")
+  EFIDTrackingCutLRT = ConfiguredNewTrackingTrigCuts("LRT")
   L2IDTrackingCuts = EFIDTrackingCuts
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/python/EFInDetConfig.py b/InnerDetector/InDetExample/InDetTrigRecExample/python/EFInDetConfig.py
index 24ad50ac90c992592e78c4d2c2f1a4b58c33cec7..e880f6c9e9b3a4ca4bdfe5d0f0089530c0d40ebd 100755
--- a/InnerDetector/InDetExample/InDetTrigRecExample/python/EFInDetConfig.py
+++ b/InnerDetector/InDetExample/InDetTrigRecExample/python/EFInDetConfig.py
@@ -282,7 +282,7 @@ class TrigEFIDSequence(TrigInDetSequenceBase):
     #    modify the sequence acoording to triggerflags
     from TriggerJobOpts.TriggerFlags  import TriggerFlags
 
-    if not ( TriggerFlags.doEF() or TriggerFlags.doHLT() ) or not TriggerFlags.doFEX():
+    if not TriggerFlags.doHLT() or not TriggerFlags.doFEX():
       from TrigSteeringTest.TrigSteeringTestConf import PESA__dummyAlgo as dummyAlgo_disabledByTriggerFlags_EFID
       dummyAlgEFID = dummyAlgo_disabledByTriggerFlags_EFID("doEF_or_doFEX_False_no_EFID")
       alglist = '[dummyAlgEFID]'
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/python/InDetTrigSliceSettings.py b/InnerDetector/InDetExample/InDetTrigRecExample/python/InDetTrigSliceSettings.py
index 34dda093fdbb032a925fa752f30df6c6415fa770..8ba1625c9fe01a7779401b212e923bf75bb511e9 100644
--- a/InnerDetector/InDetExample/InDetTrigRecExample/python/InDetTrigSliceSettings.py
+++ b/InnerDetector/InDetExample/InDetTrigRecExample/python/InDetTrigSliceSettings.py
@@ -22,13 +22,13 @@ class InDetTrigSliceSettingsDB:
   other InDetTrigRecExample files are included)
   for example a preExec line
   from InDetTrigRecExample.InDetTrigSliceSettings import InDetTrigSliceSettings; InDetTrigSliceSettings[('pTmin','bjetVtx')] = 5000.
-  allows testing the bjetVtx instance with as different reconstruction threshold, as in the Run 2 configureation 
+  allows testing the bjetVtx instance with as different reconstruction threshold, as in the Run 2 configureation
   """
   def __init__(self):
     from AthenaCommon.SystemOfUnits import GeV
     _slices = ['electron','photon',
                'muon', 'muonFS', 'muonCore', 'muonLate', 'muonIso',
-               'tau', 'tauCore', 'tauIso', 
+               'tau', 'tauCore', 'tauIso',
                # nonsense duplicated tau instances
                # "tauId", "tauEF", "tauTrk", "tauTrkTwo",
                'bjet', 'bjetVtx',
@@ -42,11 +42,12 @@ class InDetTrigSliceSettingsDB:
                'hadCalib', 'fullScan500',       #hadCalib instances
                'heavyIon', 'heavyIonFS',   #RoI and FS instances for the heavy ion
                'beamSpot', 'cosmics',
-               'bphysHighPt'
+               'bphysHighPt',
+               'electronLRT', 'muonLRT', 'tauLRT', 'fullScanLRT', 'bjetLRT'
                ]
 
     self.db = {}
-    
+
     ptmin =   {}
     etahalf = {}
     phihalf = {}
@@ -101,18 +102,21 @@ class InDetTrigSliceSettingsDB:
     d0seedmax['cosmics'] = 1000.0
     d0seedppsmax['cosmics'] = 1000.0
 
+    for i in ["fullScanLRT", "electronLRT", "muonLRT", "tauLRT", "bjetLRT"]:
+        d0seedmax[i] = 300.
+
     self.db['d0SeedMax']=d0seedmax
     self.db['d0SeedPPSMax']=d0seedppsmax
 
     for i in _slices:
-      dozfinder[i] = False 
-      dotrigindettrack[i] = False 
+      dozfinder[i] = False
+      dotrigindettrack[i] = False
     dozfinder['beamSpot'] = True
     self.db['doZFinder']=dozfinder
     self.db['doTrigInDetTrack']=dotrigindettrack
 
     for i in _slices:
-      doresmon[i] = False 
+      doresmon[i] = False
     doresmon['muon'] = True
     self.db['doResMon']=doresmon
 
@@ -133,7 +137,7 @@ class InDetTrigSliceSettingsDB:
       docloneremoval[i] = True
     docloneremoval['electron'] = False
     self.db['doCloneRemoval'] = docloneremoval
-    
+
 
 
     for i in _slices:
@@ -144,12 +148,14 @@ class InDetTrigSliceSettingsDB:
     checkseedredundancy['muonLate'] = True
     checkseedredundancy['muonCore'] = True
     # muonIso instance has default seed redundency of False
-  
+
     checkseedredundancy['bphysics'] = True
     checkseedredundancy['beamSpot'] = True
+    checkseedredundancy["fullScanLRT"] = True
+
     self.db['checkRedundantSeeds'] = checkseedredundancy
 
-    
+
     for i in _slices:
       drdoubletmax[i] = 270
       seedradbinwidth[i] = 2
@@ -195,6 +201,11 @@ class InDetTrigSliceSettingsDB:
       'tauIso'    : 0.4,
       'beamSpot'  : 3.0,
       'bjetVtx'   : 0.2,
+      'electronLRT': 0.1,
+      'muonLRT': 0.1,
+      'tauLRT': 0.4,
+      'fullScanLRT': 3,
+      'bjetLRT': 0.2
       }
     self.db['etaHalfWidth']=etahalf
 
@@ -228,6 +239,11 @@ class InDetTrigSliceSettingsDB:
       'tauIso'    : 0.4,
       'beamSpot'  : 3.14159,
       'bjetVtx'   : 0.201,
+      'electronLRT': 0.1,
+      'muonLRT': 0.1,
+      'tauLRT': 0.4,
+      'fullScanLRT': 3.14159,
+      'bjetLRT': 0.201
       }
     self.db['phiHalfWidth']=phihalf
 
@@ -246,6 +262,7 @@ class InDetTrigSliceSettingsDB:
     fullscan['heavyIonFS']=True
     fullscan['minBias400']=True
     fullscan['beamSpot']  =True
+    fullscan['fullScanLRT'] = True
 
     self.db['doFullScan']=fullscan
 
@@ -262,6 +279,44 @@ class InDetTrigSliceSettingsDB:
     monptmin['muon'] = 12 * GeV
     self.db['monPtMin']=monptmin
 
+    #TRT extension
+    dotrt = {}
+    for i in _slices:
+      dotrt[i] = False
+
+    dotrt["tauIso"] = True
+    dotrt["tauCore"] = True
+    dotrt["tau"] = True
+    dotrt["electron"] = True
+    dotrt["tauLRT"] = True
+
+    self.db['doTRT'] = dotrt
+
+
+    #d0 track max, z0 track max and usepixelsp
+    d0trackmax = {}
+    z0trackmax = {}
+    usepixelsp = {}
+
+    for i in _slices:
+      d0trackmax[i] = 20.
+      z0trackmax[i] = 300.
+      usepixelsp[i] = True
+
+    d0trackmax["cosmics"] = 1000.
+    z0trackmax["cosmics"] = 1000.
+
+    for i in ["fullScanLRT", "electronLRT", "muonLRT", "tauLRT", "bjetLRT"]:
+      d0trackmax[i] = 300.
+      z0trackmax[i] = 500.
+      usepixelsp[i] = False
+
+
+
+    self.db["d0TrackMax"] = d0trackmax
+    self.db["z0TrackMax"] = z0trackmax
+    self.db["usePixelSP"] = usepixelsp
+
   def __getitem__(self, p):
     (quantity, slice) = p
     v = None
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/python/InDetTrigTrackingCuts.py b/InnerDetector/InDetExample/InDetTrigRecExample/python/InDetTrigTrackingCuts.py
index 3eb6db3aa4d3ac8692226543a7782d83eb482588..23ae108fec50979d1e151ad9e110c4948d8c47bc 100755
--- a/InnerDetector/InDetExample/InDetTrigRecExample/python/InDetTrigTrackingCuts.py
+++ b/InnerDetector/InDetExample/InDetTrigRecExample/python/InDetTrigTrackingCuts.py
@@ -5,7 +5,6 @@ from __future__ import print_function
 class InDetTrigTrackingCuts :
   """
   A copy of ConfiguredNewtrackingCuts from InDetRecExample used by the trigger.
-  
   """
 
 
@@ -22,13 +21,13 @@ class InDetTrigTrackingCuts :
     from AthenaCommon.DetFlags import DetFlags
     from AthenaCommon.BeamFlags import jobproperties
     from RecExConfig.RecFlags import rec
-    
+
     # --- put defaults to run Pixel/SCT/TRT
     self.__usePixel = DetFlags.haveRIO.pixel_on()
     self.__useSCT   = DetFlags.haveRIO.SCT_on()
     self.__useTRT   = DetFlags.haveRIO.TRT_on()
 
-    # --- first set kinematic defaults 
+    # --- first set kinematic defaults
     self.__minPT                   = 0.500 * Units.GeV
     self.__maxPT                   = None            # off !
     self.__maxEta                  = 2.7
@@ -37,13 +36,13 @@ class InDetTrigTrackingCuts :
     self.__minClusters             = 7                # Igor 6, was 7
     self.__minSiNotShared          = 5
     self.__maxShared               = 2
-    self.__minPixel                = 0                
+    self.__minPixel                = 0
     self.__maxHoles                = 3                # was 5
     self.__maxPixelHoles           = 2                # was 5
     self.__maxSctHoles             = 3                # was 5
     self.__maxDoubleHoles          = 1                # was 2
     self.__maxPrimaryImpact        = 10.0 * Units.mm  # low lumi
-    self.__maxZImpact              = 320. * Units.mm    
+    self.__maxZImpact              = 320. * Units.mm
     if self.__indetflags.doRobustReco():
       self.__minClusters             = 7                # Igor 6, was 7
       self.__maxHoles                = 5                # was 5
@@ -52,7 +51,7 @@ class InDetTrigTrackingCuts :
       self.__maxDoubleHoles          = 4                # was 2
       self.__maxZImpact              = 500.0 * Units.mm
 
-    # --- seeding 
+    # --- seeding
     self.__seedFilterLevel         = 1
     self.__maxdImpactPPSSeeds      = 1.7
     self.__maxdImpactSSSSeeds      = 1000.0
@@ -61,11 +60,11 @@ class InDetTrigTrackingCuts :
     self.__minPTBrem               = 1. * Units.GeV # off
     self.__phiWidthBrem            = 0.3 # default is 0.3
     self.__etaWidthBrem            = 0.2 # default is 0.3
-    
+
     # --- this is for the TRT-extension + segements and backtracking
     self.__minTRTonTrk               = 9
     self.__useParameterizedTRTCuts   = False
-    self.__useNewParameterizationTRT = False 
+    self.__useNewParameterizationTRT = False
 
     # --- general pattern cuts for NewTracking
     self.__radMax                  = 600. * Units.mm # default R cut for SP in SiSpacePointsSeedMaker
@@ -82,7 +81,7 @@ class InDetTrigTrackingCuts :
     else:
       self.__SecondarynHolesMax      = 1
       self.__SecondarynHolesGapMax   = 1
-    
+
     # --- defaults for secondary tracking
     self.__maxSecondaryImpact      = 100.0 * Units.mm # low lumi
     self.__minSecondaryClusters    = 4
@@ -107,15 +106,15 @@ class InDetTrigTrackingCuts :
     self.__SecondaryXi2max         = 15.0
     self.__SecondaryXi2maxNoAdd    = 50.0
     if rec.Commissioning():
-      self.__SecondaryXi2max         = 50.0 
-      self.__SecondaryXi2maxNoAdd    = 100.0 
+      self.__SecondaryXi2max         = 50.0
+      self.__SecondaryXi2maxNoAdd    = 100.0
 
-    # --- settings for segment finder 
+    # --- settings for segment finder
     self.__TRTSegFinderPtBins        = 70
     self.__maxSegTRTShared           = 0.3
     self.__excludeUsedTRToutliers    = False
 
-    
+
     # --- TRT only
     self.__minTRTonlyMinPt         = 0.5 * Units.GeV
     self.__minTRTonly              = 15
@@ -167,10 +166,10 @@ class InDetTrigTrackingCuts :
     if self.__indetflags.cutLevel() >= 7:
       # --- more BackTracking cuts
       self.__minSecondaryTRTonTrk      = 15               # let's not allow for short overlap tracks
-      self.__maxSecondaryHoles         = 1                # tighten hole cuts 
-      self.__maxSecondaryPixelHoles    = 1                # tighten hole cuts 
-      self.__maxSecondarySCTHoles      = 1                # tighten hole cuts 
-      self.__maxSecondaryDoubleHoles   = 0                # tighten hole cuts 
+      self.__maxSecondaryHoles         = 1                # tighten hole cuts
+      self.__maxSecondaryPixelHoles    = 1                # tighten hole cuts
+      self.__maxSecondarySCTHoles      = 1                # tighten hole cuts
+      self.__maxSecondaryDoubleHoles   = 0                # tighten hole cuts
       self.__minSecondaryTRTPrecFrac   = 0.5              # default for all tracking now, as well for BackTracking
       self.__rejectShortExtensions     = True             # fall back onto segment if TRT extension is short
       self.__SiExtensionCuts           = True             # use cuts from ambi scoring already early
@@ -210,21 +209,21 @@ class InDetTrigTrackingCuts :
 
     if self.__indetflags.cutLevel() >= 17:
       # Tuning of the search road and strip seed IP in the track finder.
-      # Designed to speed up reconstruction at minimal performance impact. 
+      # Designed to speed up reconstruction at minimal performance impact.
       self.__roadWidth              = 12
       self.__maxdImpactSSSSeeds     = 5.0 * Units.mm
       self.__maxZImpact              = 200
 
     if self.__indetflags.cutLevel() >= 18:
-      # Further tuning of the pattern recognition designed to 
-      # speed up reconstruction compared to 17 with minimal additional 
-      # impact. Kept as separate level pending cross-check of 
+      # Further tuning of the pattern recognition designed to
+      # speed up reconstruction compared to 17 with minimal additional
+      # impact. Kept as separate level pending cross-check of
       # seed confirmation robustness with end-of-run-3 radiation
-      # damage. 
+      # damage.
       self.__keepAllConfirmedPixelSeeds  = True
       self.__maxSeedsPerSP_Pixels          = 1
       self.__maxSeedsPerSP_Strips          = 5
-    
+
     if self.__indetflags.cutLevel() >= 19:
       # Calo cluster Et for RoI seeded backtracking for TRT segment finding
       # and for TRT-si extensions
@@ -239,7 +238,7 @@ class InDetTrigTrackingCuts :
     if mode == "SLHC":
       self.__extension        = "SLHC"
       # --- higher pt cut and impact parameter cut
-      self.__minPT                   = 1.0 * Units.GeV      
+      self.__minPT                   = 1.0 * Units.GeV
       self.__maxPrimaryImpact        = 2.0 * Units.mm # highlumi
       # --- cluster cuts
       self.__minClusters             = 9
@@ -249,7 +248,7 @@ class InDetTrigTrackingCuts :
       self.__maxPixelHoles           = self.__maxHoles
       self.__maxSctHoles             = self.__maxHoles
       self.__maxDoubleHoles          = 2
-      # --- also tighten patter cuts 
+      # --- also tighten patter cuts
       self.__radMax                  = 1000. * Units.mm
       self.__seedFilterLevel         = 1
       self.__nHolesMax               = self.__maxHoles
@@ -264,25 +263,25 @@ class InDetTrigTrackingCuts :
       self.__minClusters = 3
     elif ( DetFlags.haveRIO.SCT_on() and not DetFlags.haveRIO.pixel_on() ):
       self.__minClusters = 6
-      
-    # --- change defaults for low pt tracking  
-    if mode == "LowPt": 
+
+    # --- change defaults for low pt tracking
+    if mode == "LowPt":
       self.__extension        = "LowPt" # this runs parallel to NewTracking
       self.__maxPT            = self.__minPT + 0.3 * Units.GeV # some overlap
       self.__minPT            = 0.100 * Units.GeV
       self.__minClusters      = 5
-      self.__minPixel         = 1   # At least one pixel hit for low-pt (ass seeded on pixels!)                
+      self.__minPixel         = 1   # At least one pixel hit for low-pt (ass seeded on pixels!)
       self.__maxHoles         = 4
       self.__maxPixelHoles    = self.__maxHoles # --> no effect
       self.__maxSctHoles      = self.__maxHoles # --> no effect
       self.__maxDoubleHoles   = 2
       self.__radMax           = 600. * Units.mm # restrivt to pixels
-    # --- change defauls for beam gas tracking 
+    # --- change defauls for beam gas tracking
     if mode == "BeamGas":
       self.__extension        = "BeamGas" # this runs parallel to NewTracking
       self.__minPT            = 0.500 * Units.GeV
-      self.__maxPrimaryImpact = 300. * Units.mm 
-      self.__maxZImpact       = 2000. * Units.mm 
+      self.__maxPrimaryImpact = 300. * Units.mm
+      self.__maxZImpact       = 2000. * Units.mm
       self.__minClusters      = 6
       self.__maxHoles         = 3
       self.__maxPixelHoles    = self.__maxHoles # --> no effect
@@ -291,8 +290,8 @@ class InDetTrigTrackingCuts :
     # --- changes for cosmics
     if mode == "Cosmics":
       self.__minPT            = 0.500 * Units.GeV
-      self.__maxPrimaryImpact = 1000. * Units.mm 
-      self.__maxZImpact       = 10000. * Units.mm 
+      self.__maxPrimaryImpact = 1000. * Units.mm
+      self.__maxZImpact       = 10000. * Units.mm
       self.__minClusters      = 4
       self.__maxHoles         = 3
       self.__maxPixelHoles    = self.__maxHoles # --> no effect
@@ -317,11 +316,11 @@ class InDetTrigTrackingCuts :
       self.__maxDoubleHoles   = 0
       self.__nHolesMax        = self.__maxHoles
       self.__nHolesGapMax     = self.__maxHoles
-      self.__Xi2max           = 6. 
+      self.__Xi2max           = 6.
       self.__Xi2maxNoAdd      = 10.
       self.__seedFilterLevel  = 1
       self.__radMax           = 600. * Units.mm # restrict to pixels + first SCT layer
-      self.__useTRT           = False 
+      self.__useTRT           = False
     # --- changes for Pixel segments
     if mode == "Pixel":
       self.__extension        = "Pixel" # this runs parallel to NewTracking
@@ -335,13 +334,13 @@ class InDetTrigTrackingCuts :
       self.__maxShared        = 0
       self.__seedFilterLevel  = 2
       self.__nHolesMax        = self.__maxHoles
-      self.__nHolesGapMax     = 2*self.__maxDoubleHoles      
+      self.__nHolesGapMax     = 2*self.__maxDoubleHoles
       self.__useSCT           = False
-      self.__useTRT           = False 
+      self.__useTRT           = False
       if self.__indetflags.doCosmics():
         self.__minPT            = 0.500 * Units.GeV
-        self.__maxPrimaryImpact = 1000. * Units.mm 
-        self.__maxZImpact       = 10000. * Units.mm 
+        self.__maxPrimaryImpact = 1000. * Units.mm
+        self.__maxZImpact       = 10000. * Units.mm
         self.__maxHoles         = 3
         self.__maxPixelHoles    = self.__maxHoles # --> no effect
         self.__maxSctHoles      = self.__maxHoles # --> no effect
@@ -349,7 +348,7 @@ class InDetTrigTrackingCuts :
         self.__roadWidth        = 60.
         self.__seedFilterLevel  = 3 # 2 ?
         self.__nHolesMax        = self.__maxHoles
-        self.__nHolesGapMax     = 2*self.__maxDoubleHoles      
+        self.__nHolesGapMax     = 2*self.__maxDoubleHoles
         self.__Xi2max           = 60.0
         self.__Xi2maxNoAdd      = 100.0
         self.__nWeightedClustersMin = 6
@@ -370,13 +369,13 @@ class InDetTrigTrackingCuts :
       self.__maxShared        = 0
       self.__seedFilterLevel  = 2
       self.__nHolesMax        = self.__maxHoles
-      self.__nHolesGapMax     = 2*self.__maxDoubleHoles      
+      self.__nHolesGapMax     = 2*self.__maxDoubleHoles
       self.__usePixel         = False
-      self.__useTRT           = False 
+      self.__useTRT           = False
       if self.__indetflags.doCosmics():
         self.__minPT            = 0.500 * Units.GeV
-        self.__maxPrimaryImpact = 1000. * Units.mm 
-        self.__maxZImpact       = 10000. * Units.mm 
+        self.__maxPrimaryImpact = 1000. * Units.mm
+        self.__maxZImpact       = 10000. * Units.mm
         self.__maxHoles         = 3
         self.__maxPixelHoles    = self.__maxHoles # --> no effect
         self.__maxSctHoles      = self.__maxHoles # --> no effect
@@ -384,11 +383,11 @@ class InDetTrigTrackingCuts :
         self.__roadWidth        = 60.
         self.__seedFilterLevel  = 3 # 2 ?
         self.__nHolesMax        = self.__maxHoles
-        self.__nHolesGapMax     = 2*self.__maxDoubleHoles      
+        self.__nHolesGapMax     = 2*self.__maxDoubleHoles
         self.__Xi2max           = 60.0
         self.__Xi2maxNoAdd      = 100.0
         self.__nWeightedClustersMin = 6
-    # --- mode for SCT and TRT 
+    # --- mode for SCT and TRT
     if mode == "SCTandTRT":
       self.__extension        = "SCTandTRT" # this runs parallel to NewTracking
       self.__minPT            = 0.5 * Units.GeV
@@ -401,13 +400,13 @@ class InDetTrigTrackingCuts :
       self.__maxShared        = 0
       self.__seedFilterLevel  = 2
       self.__nHolesMax        = self.__maxHoles
-      self.__nHolesGapMax     = 2*self.__maxDoubleHoles      
+      self.__nHolesGapMax     = 2*self.__maxDoubleHoles
       self.__usePixel         = False
-      self.__useTRT           = True 
+      self.__useTRT           = True
       if self.__indetflags.doCosmics():
         self.__minPT            = 0.500 * Units.GeV
-        self.__maxPrimaryImpact = 1000. * Units.mm 
-        self.__maxZImpact       = 10000. * Units.mm 
+        self.__maxPrimaryImpact = 1000. * Units.mm
+        self.__maxZImpact       = 10000. * Units.mm
         self.__maxHoles         = 3
         self.__maxPixelHoles    = self.__maxHoles # --> no effect
         self.__maxSctHoles      = self.__maxHoles # --> no effect
@@ -415,7 +414,7 @@ class InDetTrigTrackingCuts :
         self.__roadWidth        = 60.
         self.__seedFilterLevel  = 3 # 2 ?
         self.__nHolesMax        = self.__maxHoles
-        self.__nHolesGapMax     = 2*self.__maxDoubleHoles      
+        self.__nHolesGapMax     = 2*self.__maxDoubleHoles
         self.__Xi2max           = 60.0
         self.__Xi2maxNoAdd      = 100.0
         self.__nWeightedClustersMin = 6
@@ -426,6 +425,25 @@ class InDetTrigTrackingCuts :
   #      self.__maxDoubleHoles          = 4               # was 2
   #      self.__maxPrimaryImpact        = 50.0 * Units.mm # low lumi
   #      self.__maxZImpact              = 500.0 * Units.mm
+    if mode == "LRT":
+      self.__minClusters             = 8
+      self.__minSiNotShared          = 6
+      self.__maxShared               = 1
+      self.__maxHoles                = 2
+      self.__maxPixelHoles           = 1
+      self.__maxSctHoles             = 1
+      self.__maxDoubleHoles          = 0
+      self.__maxPrimaryImpact        = 300.0 * Units.mm
+      self.__maxZImpact              = 500. * Units.mm
+      self.__roadWidth               = 5.
+      self.__seedFilterLevel         = 1
+      self.__nHolesMax               = self.__maxHoles
+      self.__nHolesGapMax            = 1
+      self.__Xi2max                  = 9.
+      self.__Xi2maxNoAdd             = 25.0
+      self.__nWeightedClustersMin    = 8
+      self.__doZBoundary             = True
+      self.__maxdImpactSSSSeeds      = 300.0
 
 
 # ----------------------------------------------------------------------------
@@ -469,7 +487,7 @@ class InDetTrigTrackingCuts :
     return self.__minClusters
 
   def minPixel( self ) :
-    return self.__minPixel  
+    return self.__minPixel
 
   def minSecondaryClusters( self ) :
     return self.__minSecondaryClusters
@@ -506,7 +524,7 @@ class InDetTrigTrackingCuts :
 
   def maxDoubleHoles( self ) :
     return self.__maxDoubleHoles
-    
+
   def maxSecondaryDoubleHoles( self ) :
     return self.__maxSecondaryDoubleHoles
 
@@ -548,7 +566,7 @@ class InDetTrigTrackingCuts :
 
   def Xi2max( self ) :
     return self.__Xi2max
-  
+
   def Xi2maxNoAdd( self ) :
     return self.__Xi2maxNoAdd
 
@@ -560,12 +578,12 @@ class InDetTrigTrackingCuts :
 
   def SecondaryXi2max( self ) :
     return self.__SecondaryXi2max
-  
+
   def SecondaryXi2maxNoAdd( self ) :
     return self.__SecondaryXi2maxNoAdd
 
   def nWeightedClustersMin( self ) :
-    return self.__nWeightedClustersMin 
+    return self.__nWeightedClustersMin
 
   def maxdImpactPPSSeeds( self ) :
     return self.__maxdImpactPPSSeeds
@@ -575,7 +593,7 @@ class InDetTrigTrackingCuts :
 
   def usePixel( self ) :
     return self.__usePixel
-  
+
   def useSCT( self ) :
     return self.__useSCT
 
@@ -655,4 +673,3 @@ class InDetTrigTrackingCuts :
       print ('* min TRT only min pt         :  ', self.__minTRTonlyMinPt, ' MeV')
       print ('*')
     print ('************************************************************************************')
-
diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/share/RTT_NoBField_transform.sh b/InnerDetector/InDetExample/InDetTrigRecExample/share/RTT_NoBField_transform.sh
deleted file mode 100755
index bf9ea6862393b11657ca59057f5f96b627d7c71f..0000000000000000000000000000000000000000
--- a/InnerDetector/InDetExample/InDetTrigRecExample/share/RTT_NoBField_transform.sh
+++ /dev/null
@@ -1,13 +0,0 @@
-export STAGE_SVCCLASS=atlasgroupdisk
-Reco_trf.py \
-    inputBSFile_r2r=rfio:/castor/cern.ch/grid/atlas/DAQ/2009/00121513/physics_IDCosmic/data09_cos.00121513.physics_IDCosmic.daq.RAW._lb0000._SFO-1._0001.data,rfio:/castor/cern.ch/grid/atlas/DAQ/2009/00121513/physics_IDCosmic/data09_cos.00121513.physics_IDCosmic.daq.RAW._lb0000._SFO-1._0002.data,rfio:/castor/cern.ch/grid/atlas/DAQ/2009/00121513/physics_IDCosmic/data09_cos.00121513.physics_IDCosmic.daq.RAW._lb0000._SFO-1._0003.data,rfio:/castor/cern.ch/grid/atlas/DAQ/2009/00121513/physics_IDCosmic/data09_cos.00121513.physics_IDCosmic.daq.RAW._lb0000._SFO-1._0004.data,rfio:/castor/cern.ch/grid/atlas/DAQ/2009/00121513/physics_IDCosmic/data09_cos.00121513.physics_IDCosmic.daq.RAW._lb0000._SFO-1._0005.data,rfio:/castor/cern.ch/grid/atlas/DAQ/2009/00121513/physics_IDCosmic/data09_cos.00121513.physics_IDCosmic.daq.RAW._lb0000._SFO-1._0006.data,rfio:/castor/cern.ch/grid/atlas/DAQ/2009/00121513/physics_IDCosmic/data09_cos.00121513.physics_IDCosmic.daq.RAW._lb0000._SFO-1._0007.data,rfio:/castor/cern.ch/grid/atlas/DAQ/2009/00121513/physics_IDCosmic/data09_cos.00121513.physics_IDCosmic.daq.RAW._lb0000._SFO-1._0008.data,rfio:/castor/cern.ch/grid/atlas/DAQ/2009/00121513/physics_IDCosmic/data09_cos.00121513.physics_IDCosmic.daq.RAW._lb0000._SFO-1._0009.data \
-    outputBSFile='raw.data._0001.data'     \
-    outputHIST_TRIGEXPERTFile=trig-expert.root     \
-    maxEvents=-1     \
-    trigStream=IDCosmic \
-    autoConfiguration=FieldAndGeo,BeamType,ConditionsTag   \
-    preInclude=RecExCommission/RecExCommissionRepro.py,RecExCommission/MinimalCommissioningSetup.py,RecJobTransforms/TrigConfigForCosmic08RerunHLTRepro.py\
-    preExec='HLTMonDoOfflineTauTTP=False; doMonitoring=False'   \
-    outputESDFile=data09_cosmag.00121513.ESD.pool.root          \
-    outputCBNT=myCBNT.ntuple.root     \
-    --ignoreunknown
diff --git a/InnerDetector/InDetMonitoring/InDetAlignmentMonitoring/src/IDAlignMonResiduals.cxx b/InnerDetector/InDetMonitoring/InDetAlignmentMonitoring/src/IDAlignMonResiduals.cxx
index 9fd4e138df9196827adde02bc2ec707e9fcd727b..f561eb28bac2df11337e8b680113ae692c8af499 100755
--- a/InnerDetector/InDetMonitoring/InDetAlignmentMonitoring/src/IDAlignMonResiduals.cxx
+++ b/InnerDetector/InDetMonitoring/InDetAlignmentMonitoring/src/IDAlignMonResiduals.cxx
@@ -655,8 +655,8 @@ StatusCode IDAlignMonResiduals::bookHistograms()
     //
     //-----------------------------------
 
-    const Int_t nx = 21;
-    TString siliconLayers[nx] = {"Pix L0","Pix L1","Pix L2","SCT L0 S0","S1","SCT L1 S0","S1","SCT L2 S0","S1","SCT L3 S0","S1","SCT L4 S0","S1","SCT L5 S0","S1","SCT L6 S0","S1","SCT L7 S0","S1","SCT L8 S0","S1"};
+    const Int_t nsilay = 21;
+    TString siliconLayers[nsilay] = {"Pix L0","Pix L1","Pix L2","SCT L0 S0","S1","SCT L1 S0","S1","SCT L2 S0","S1","SCT L3 S0","S1","SCT L4 S0","S1","SCT L5 S0","S1","SCT L6 S0","S1","SCT L7 S0","S1","SCT L8 S0","S1"};
 
     //These histograms are filled in post-processing - only initiated here such that they can be registered as "shift".
 
@@ -664,23 +664,19 @@ StatusCode IDAlignMonResiduals::bookHistograms()
     // m_si_barrel_resX_mean = new TH1F("si_barrel_resX_mean","Mean Residual X vs Silicon Barrel Layer;Mean Residual X",11,-0.5,10.5);
     //for (int i=1;i<=11;i++) m_si_barrel_resX_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     //RegisterHisto(al_mon,m_si_barrel_resX_mean);
-    m_si_eca_resX_mean = new TH1F("si_eca_resX_mean","Mean Residual X vs Silicon ECA Layer; Mean Residual X",21,-0.5,21.5);
-    for (int i=1;i<=nx;i++) m_si_eca_resX_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_resX_mean = new TH1F("si_eca_resX_mean","Mean Residual X vs Silicon ECA Layer; Mean Residual X", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_eca_resX_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_eca_resX_mean);
-    m_si_ecc_resX_mean = new TH1F("si_ecc_resX_mean","Mean Residual X vs Silicon ECC Layer; Mean Residual X",21,-0.5,21.5);
-    for (int i=1;i<=nx;i++) m_si_ecc_resX_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_resX_mean = new TH1F("si_ecc_resX_mean","Mean Residual X vs Silicon ECC Layer; Mean Residual X", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_ecc_resX_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_ecc_resX_mean);
 
-    //m_si_barrel_resY_mean = new TH1F("si_barrel_resY_mean","Mean Residual Y vs Silicon Barrel Layer;Mean Residual Y",11,-0.5,10.5);
-    //for (int i=1;i<=11;i++) m_si_barrel_resY_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
-    //RegisterHisto(al_mon,m_si_barrel_resY_mean);
 
-
-    m_si_eca_resY_mean = new TH1F("si_eca_resY_mean","Mean Residual Y vs Silicon ECA Layer;Mean Residual Y",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_eca_resY_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_resY_mean = new TH1F("si_eca_resY_mean","Mean Residual Y vs Silicon ECA Layer;Mean Residual Y", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_eca_resY_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_eca_resY_mean);
-    m_si_ecc_resY_mean = new TH1F("si_ecc_resY_mean","Mean Residual Y vs Silicon ECC Layer;Mean Residual Y",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_ecc_resY_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_resY_mean = new TH1F("si_ecc_resY_mean","Mean Residual Y vs Silicon ECC Layer;Mean Residual Y", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_ecc_resY_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_ecc_resY_mean);
 
 
@@ -699,24 +695,21 @@ StatusCode IDAlignMonResiduals::bookHistograms()
     //for (int i=1;i<=11;i++) m_si_barrel_pullX_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     //m_si_barrel_pullX_width->GetYaxis()->SetTitle("Pull X Gaussian Width");
     //RegisterHisto(al_mon,m_si_barrel_pullX_width);
-    m_si_eca_pullX_width = new TH1F("si_eca_pullX_width","Pull X Gaussian Width vs Silicon ECA Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_eca_pullX_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_pullX_width = new TH1F("si_eca_pullX_width","Pull X Gaussian Width vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay ;i++) m_si_eca_pullX_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     m_si_eca_pullX_width->GetYaxis()->SetTitle("Pull X Gaussian Width");
     RegisterHisto(al_mon,m_si_eca_pullX_width);
-    m_si_ecc_pullX_width = new TH1F("si_ecc_pullX_width","Pull X Gaussian Width vs Silicon ECC Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_ecc_pullX_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_pullX_width = new TH1F("si_ecc_pullX_width","Pull X Gaussian Width vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_ecc_pullX_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     m_si_ecc_pullX_width->GetYaxis()->SetTitle("Pull X Gaussian Width");
     RegisterHisto(al_mon,m_si_ecc_pullX_width);
-    //m_si_barrel_pullY_width = new TH1F("si_barrel_pullY_width","Pull Y Gaussian Width vs Silicon Barrel Layer",11,-0.5,10.5);
-    //for (int i=1;i<=11;i++) m_si_barrel_pullY_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
-    //m_si_barrel_pullY_width->GetYaxis()->SetTitle("Pull Y Gaussian Width");
-    //RegisterHisto(al_mon,m_si_barrel_pullY_width);
-    m_si_eca_pullY_width = new TH1F("si_eca_pullY_width","Pull Y Gaussian Width vs Silicon ECA Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_eca_pullY_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+
+    m_si_eca_pullY_width = new TH1F("si_eca_pullY_width","Pull Y Gaussian Width vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_eca_pullY_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     m_si_eca_pullY_width->GetYaxis()->SetTitle("Pull Y Gaussian Width");
     RegisterHisto(al_mon,m_si_eca_pullY_width);
-    m_si_ecc_pullY_width = new TH1F("si_ecc_pullY_width","Pull Y Gaussian Width vs Silicon ECC Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_ecc_pullY_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_pullY_width = new TH1F("si_ecc_pullY_width","Pull Y Gaussian Width vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_ecc_pullY_width->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     m_si_ecc_pullY_width->GetYaxis()->SetTitle("Pull Y Gaussian Width");
     RegisterHisto(al_mon,m_si_ecc_pullY_width);
 
@@ -726,22 +719,22 @@ StatusCode IDAlignMonResiduals::bookHistograms()
     //for (int i=1;i<=11;i++) m_si_barrel_resX_rms->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     //m_si_barrel_resX_rms->GetYaxis()->SetTitle("Residual X RMS");
     //RegisterHisto(al_mon,m_si_barrel_resX_rms);
-    m_si_eca_resX_rms = new TH1F("si_eca_resX_rms","Residual X RMS vs Silicon ECA Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_eca_resX_rms->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_resX_rms = new TH1F("si_eca_resX_rms","Residual X RMS vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_eca_resX_rms->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     m_si_eca_resX_rms->GetYaxis()->SetTitle("Residual X RMS");
     RegisterHisto(al_mon,m_si_eca_resX_rms);
-    m_si_ecc_resX_rms = new TH1F("si_ecc_resX_rms","Residual X RMS vs Silicon ECC Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_ecc_resX_rms->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_resX_rms = new TH1F("si_ecc_resX_rms","Residual X RMS vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_ecc_resX_rms->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     m_si_ecc_resX_rms->GetYaxis()->SetTitle("Residual X RMS");
     RegisterHisto(al_mon,m_si_ecc_resX_rms);
     //Residual Y (only Pixel is filled currently - don't have SCT Y residuals yet)
 
-    m_si_eca_resY_rms = new TH1F("si_eca_resY_rms","Residual Y RMS vs Silicon ECA Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_eca_resY_rms->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_resY_rms = new TH1F("si_eca_resY_rms","Residual Y RMS vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<=nsilay; i++) m_si_eca_resY_rms->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     m_si_eca_resY_rms->GetYaxis()->SetTitle("Residual Y RMS");
     RegisterHisto(al_mon,m_si_eca_resY_rms);
-    m_si_ecc_resY_rms = new TH1F("si_ecc_resY_rms","Residual Y RMS vs Silicon ECC Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_ecc_resY_rms->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_resY_rms = new TH1F("si_ecc_resY_rms","Residual Y RMS vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i<= nsilay; i++) m_si_ecc_resY_rms->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     m_si_ecc_resY_rms->GetYaxis()->SetTitle("Residual Y RMS");
     RegisterHisto(al_mon,m_si_ecc_resY_rms);
 
@@ -756,58 +749,62 @@ StatusCode IDAlignMonResiduals::bookHistograms()
     RegisterHisto(al_mon,m_sirescalcfailure) ;
 
     //Si (Pix & SCT) residual histograms
-    m_si_residualx = new TH1F("si_residualx","Silicon UnBiased X Residual", 200,m_minSiResFillRange,m_maxSiResFillRange);
+    m_si_residualx = new TH1F("si_residualx","Silicon UnBiased X Residual", 100, m_minSiResFillRange, m_maxSiResFillRange);
     RegisterHisto(al_mon,m_si_residualx) ;
-    m_si_b_residualx = new TH1F("si_b_residualx","Silicon Barrel Only UnBiased X Residual",200, m_minSiResFillRange,m_maxSiResFillRange);
+    m_si_b_residualx = new TH1F("si_b_residualx","Silicon Barrel Only UnBiased X Residual", 100, m_minSiResFillRange, m_maxSiResFillRange);
     RegisterHisto(al_mon,m_si_b_residualx);
 
     //Pull 2D histograms for filling of Pull Gaussian width and mean plots in post-processing
 
-    m_si_eca_pullX = new TH2F("si_eca_pullX","Pull X vs Silicon ECA Layer", 21, -0.5, 20.5, 100,-m_RangeOfPullHistos, m_RangeOfPullHistos);
-    for (int i=1;i<=nx;i++) m_si_eca_pullX->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_pullX = new TH2F("si_eca_pullX","Pull X vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5, 50,-m_RangeOfPullHistos, m_RangeOfPullHistos);
+    for (int i=1; i<=nsilay; i++) m_si_eca_pullX->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_eca_pullX);
-    m_si_ecc_pullX = new TH2F("si_ecc_pullX","Pull X vs Silicon ECC Layer", 21, -0.5, 20.5, 100,-m_RangeOfPullHistos, m_RangeOfPullHistos);
-    for (int i=1;i<=nx;i++) m_si_ecc_pullX->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_pullX = new TH2F("si_ecc_pullX","Pull X vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5, 50,-m_RangeOfPullHistos, m_RangeOfPullHistos);
+    for (int i=1; i<=nsilay; i++) m_si_ecc_pullX->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_ecc_pullX);
 
-    m_si_eca_pullY = new TH2F("si_eca_pullY","Pull Y vs Silicon ECA Layer", 21, -0.5, 20.5, 100,-m_RangeOfPullHistos, m_RangeOfPullHistos);
-    for (int i=1;i<=nx;i++) m_si_eca_pullY->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_pullY = new TH2F("si_eca_pullY","Pull Y vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5, 50,-m_RangeOfPullHistos, m_RangeOfPullHistos);
+    for (int i=1; i<=nsilay; i++) m_si_eca_pullY->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_eca_pullY);
-    m_si_ecc_pullY = new TH2F("si_ecc_pullY","Pull Y vs Silicon ECC Layer", 21, -0.5, 20.5, 100,-m_RangeOfPullHistos, m_RangeOfPullHistos);
-    for (int i=1;i<=nx;i++) m_si_ecc_pullY->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_pullY = new TH2F("si_ecc_pullY","Pull Y vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5, 50,-m_RangeOfPullHistos, m_RangeOfPullHistos);
+    for (int i=1; i<=nsilay; i++) m_si_ecc_pullY->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_ecc_pullY);
 
     //Residual 2D histograms for filling of Residual Gaussian width and mean plots in post-processing
 
-    m_si_eca_resX = new TH2F("si_eca_resX","Residual X vs Silicon ECA Layer",21,-0.5,20.5,100*m_FinerBinningFactor,m_minSiResFillRange,m_maxSiResFillRange);
-    for (int i=1;i<=nx;i++) m_si_eca_resX->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_resX = new TH2F("si_eca_resX","Residual X vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5,
+			     100*m_FinerBinningFactor,m_minSiResFillRange,m_maxSiResFillRange);
+    for (int i=1; i<=nsilay; i++) m_si_eca_resX->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_eca_resX);
-    m_si_ecc_resX = new TH2F("si_ecc_resX","Residual X vs Silicon ECC Layer",21,-0.5,20.5,100*m_FinerBinningFactor,m_minSiResFillRange,m_maxSiResFillRange);
-    for (int i=1;i<=nx;i++) m_si_ecc_resX->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_resX = new TH2F("si_ecc_resX","Residual X vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5,
+			     100*m_FinerBinningFactor,m_minSiResFillRange,m_maxSiResFillRange);
+    for (int i=1; i<=nsilay; i++) m_si_ecc_resX->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_ecc_resX);
 
-    m_si_eca_resY = new TH2F("si_eca_resY","Residual Y vs Silicon ECA Layer",21,-0.5,20.5,100*m_FinerBinningFactor,m_minSiResFillRange,m_maxSiResFillRange);
-    for (int i=1;i<=nx;i++) m_si_eca_resY->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_resY = new TH2F("si_eca_resY","Residual Y vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5,
+			     100*m_FinerBinningFactor,m_minSiResFillRange,m_maxSiResFillRange);
+    for (int i=1; i <= nsilay; i++) m_si_eca_resY->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_eca_resY);
-    m_si_ecc_resY = new TH2F("si_ecc_resY","Residual Y vs Silicon ECC Layer",21,-0.5,20.5,100*m_FinerBinningFactor,m_minSiResFillRange,m_maxSiResFillRange);
-    for (int i=1;i<=nx;i++) m_si_ecc_resY->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_resY = new TH2F("si_ecc_resY","Residual Y vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5,
+			     100*m_FinerBinningFactor,m_minSiResFillRange,m_maxSiResFillRange);
+    for (int i=1; i <= nsilay; i++) m_si_ecc_resY->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_ecc_resY);
 
     //These histograms are filled in post-processing - only initiated here such that they can be registered to dqm
     //mean of Gaussian fit to pull distribution in each layer of the silicon
 
-    m_si_eca_pullX_mean = new TH1F("si_eca_pullX_mean","Pull X Gaussian Mean vs Silicon ECA Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_eca_pullX_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_pullX_mean = new TH1F("si_eca_pullX_mean","Pull X Gaussian Mean vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i <= nsilay; i++) m_si_eca_pullX_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_eca_pullX_mean);
-    m_si_ecc_pullX_mean = new TH1F("si_ecc_pullX_mean","Pull X Gaussian Mean vs Silicon ECC Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_ecc_pullX_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_pullX_mean = new TH1F("si_ecc_pullX_mean","Pull X Gaussian Mean vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i <= nsilay; i++) m_si_ecc_pullX_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_ecc_pullX_mean);
 
-    m_si_eca_pullY_mean = new TH1F("si_eca_pullY_mean","Pull Y Gaussian Mean vs Silicon ECA Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_eca_pullY_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_eca_pullY_mean = new TH1F("si_eca_pullY_mean","Pull Y Gaussian Mean vs Silicon ECA Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i <= nsilay; i++) m_si_eca_pullY_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_eca_pullY_mean);
-    m_si_ecc_pullY_mean = new TH1F("si_ecc_pullY_mean","Pull Y Gaussian Mean vs Silicon ECC Layer",21,-0.5,20.5);
-    for (int i=1;i<=nx;i++) m_si_ecc_pullY_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
+    m_si_ecc_pullY_mean = new TH1F("si_ecc_pullY_mean","Pull Y Gaussian Mean vs Silicon ECC Layer", nsilay, -0.5, nsilay-0.5);
+    for (int i=1; i <= nsilay; i++) m_si_ecc_pullY_mean->GetXaxis()->SetBinLabel(i,siliconLayers[i-1]);
     RegisterHisto(al_mon,m_si_ecc_pullY_mean);
 
     //Overlap Residual Plots - Pixel Mean and RMS vs Layer histograms (concatenated - both barrel and endcaps in one plot)
@@ -841,23 +838,24 @@ StatusCode IDAlignMonResiduals::bookHistograms()
     RegisterHisto(al_mon,m_sct_bec_Oyresx_rms);
 
     //Special histograms
-    if (m_extendedPlots)
-      {
-	m_totalEvents  = new TH1F("TotalEvents","TotalEvents",2,0,2);
-	RegisterHisto(al_mon,m_totalEvents);
+    if (m_extendedPlots) {
+      m_totalEvents  = new TH1F("TotalEvents","TotalEvents", 1, -0.5, 0.5);
+      RegisterHisto(al_mon,m_totalEvents);
 
-	m_mu_perEvent = new TH1F("mu_perEvent","<#mu> per event", m_nBinsMuRange, m_muRangeMin, m_muRangeMax);
-	RegisterHisto(al_mon,m_mu_perEvent);
-      }
+      m_mu_perEvent = new TH1F("mu_perEvent","<#mu> per event", m_nBinsMuRange, m_muRangeMin, m_muRangeMax);
+      RegisterHisto(al_mon,m_mu_perEvent);
+    }
     //Lumi wise histo
 
     //All modules
-    m_pix_b0_resXvsetaLumiBlock = new TProfile2D("pix_b0_resXvsetaLumiBlock","2D profile of X unbiased residuals vs IBL eta module per Lumi Block; LumiBlock;Module Eta",m_nBinsLB,m_LBRangeMin,m_LBRangeMax,20,-10.5,9.5,m_minPIXResXFillRange,m_maxPIXResXFillRange);
+    m_pix_b0_resXvsetaLumiBlock = new TProfile2D("pix_b0_resXvsetaLumiBlock","2D profile of X unbiased residuals vs IBL eta module per Lumi Block; LumiBlock;Module Eta",
+						 m_nBinsLB,m_LBRangeMin,m_LBRangeMax, 20,-10.5,9.5, m_minPIXResXFillRange,m_maxPIXResXFillRange);
     RegisterHisto(al_mon,m_pix_b0_resXvsetaLumiBlock);
 
     //Only planars
 
-    m_pix_b0_resXvsetaLumiBlock_planars = new TProfile2D("pix_b0_resXvsetaLumiBlock_planars","2D profile of X unbiased residuals vs IBL eta module per Lumi Block;LumiBlock; Module Eta",m_nBinsLB,m_LBRangeMin,m_LBRangeMax,12,-6.5,5.5,m_minPIXResXFillRange,m_maxPIXResXFillRange);
+    m_pix_b0_resXvsetaLumiBlock_planars = new TProfile2D("pix_b0_resXvsetaLumiBlock_planars","2D profile of X unbiased residuals vs IBL eta module per Lumi Block;LumiBlock; Module Eta",
+							 m_nBinsLB,m_LBRangeMin,m_LBRangeMax, 12,-6.5,5.5, m_minPIXResXFillRange,m_maxPIXResXFillRange);
     RegisterHisto(al_mon,m_pix_b0_resXvsetaLumiBlock_planars);
 
 
@@ -1051,10 +1049,8 @@ void IDAlignMonResiduals::RegisterHisto(MonGroup& mon, TH2* histo) {
 }
 
 //---------------------------------------------------------------------------------------
-
 StatusCode IDAlignMonResiduals::fillHistograms()
 {
-  
   const EventContext& ctx = Gaudi::Hive::currentContext();
   ++m_events;
   ATH_MSG_DEBUG ("IDAlignMonResiduals::fillHistograms ** START ** call for m_events " << m_events << " for track collection: " <<   m_tracksName.key());
@@ -4922,14 +4918,14 @@ void IDAlignMonResiduals::MakeTRTEndcapHistograms(MonGroup& al_mon){
       /** Residuals and pulls vs mu*/
       m_trt_ec_hist->residualR_mu[endcap] = MakeHist("trt_ec_residualR_mu_"+endcapName[endcap],
 						     "UnBiased Residual vs mu for TRT "+endcapName[endcap],
-						     m_nBinsPtRange, -m_PtRange, m_PtRange,
 						     m_nBinsMuRange, m_muRangeMin, m_muRangeMax,
+						     100, m_minTRTResWindow, m_maxTRTResWindow,
 						     "#mu ","Residual [mm]"); 
       RegisterHisto(al_mon,m_trt_ec_hist->residualR_mu[endcap]);
       
       m_trt_ec_hist->pullR_mu[endcap] = MakeHist("trt_ec_pullR_mu_"+endcapName[endcap],"Unbiased residual pull vs mu for TRT "+endcapName[endcap],
-						 m_nBinsPtRange, -m_PtRange, m_PtRange,
 						 m_nBinsMuRange, m_muRangeMin, m_muRangeMax,
+						 100, -m_RangeOfPullHistos,m_RangeOfPullHistos,
 						 "#mu","Pull");
       RegisterHisto(al_mon,m_trt_ec_hist->pullR_mu[endcap]);
     }
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthClusterMonAlgCfg.py b/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthClusterMonAlgCfg.py
index e36e202417a2b5b83724f25a3a4c7ee8dd638467..63e2f31534a0944b6bf8234b9b54809cf7391ffe 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthClusterMonAlgCfg.py
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthClusterMonAlgCfg.py
@@ -7,7 +7,7 @@
 @brief Configuration of Pixel Monitoring Clusters, Tracks and Status Histograms for Run 3
 '''
 
-from PixelMonitoring.PixelAthMonitoringBase import define2DProfHist, definePP0Histos
+from PixelMonitoring.PixelAthMonitoringBase import define2DProfHist, define2DProfPerFEHist, definePP0Histos
 from PixelMonitoring.PixelAthMonitoringBase import define1DLayers, defineMapVsLumiLayers
 from PixelMonitoring.PixelAthMonitoringBase import define1DProfLumiLayers
 from PixelMonitoring.PixelAthMonitoringBase import layers, totcuts, xbinsem, xminsem, lumibinsx, ztotbinsy, ztotminsy
@@ -19,6 +19,7 @@ def PixelAthClusterMonAlgCfg(helper, alg, **kwargs):
 
     doOnline  = kwargs.get('doOnline',  False)
     doLumiBlock = kwargs.get('doLumiBlock', False)
+    doFEPlots  = kwargs.get('doFEPlots',  False)
 
 ### begin status histograms
 
@@ -36,6 +37,11 @@ def PixelAthClusterMonAlgCfg(helper, alg, **kwargs):
         title = 'Modules Status (0=Active+Good, 1=Active+Bad, 2=Inactive)'
         define2DProfHist(helper, alg, histoGroupName, title, pathLowStat, type='TProfile2D', lifecycle='lumiblock', histname='MapOfModulesStatusLB')
 
+    if doFEPlots:
+        histoGroupName = 'MapOfFEsStatus' 
+        title = 'FEs Status (0=Active+Good, 1=Active+Bad, 2=Inactive)'
+        define2DProfPerFEHist(helper, alg, histoGroupName, title, path, type='TProfile2D')
+
     histoGroupName = 'BadModulesPerLumi'
     title          = 'Number of bad modules (bad+active) per event per LB'
     yaxistext      = ';# modules/event'
@@ -110,7 +116,8 @@ def PixelAthClusterMonAlgCfg(helper, alg, **kwargs):
 
     varName = 'pixclusmontool_lb,ntrks_per_event'
     title = fullDressTitle('Number of tracks per event per LB', False, ';lumi block', ';tracks/event')
-    varName += ';tracksPerEvtPerLumi'
+
+    varName += ';TracksPerEvtPerLumi'
     trackGroup.defineHistogram(varName,
                                 type='TProfile', path=path, title=title,
                                 xbins=lumibinsx, xmin=-0.5, xmax=-0.5+lumibinsx)
@@ -260,6 +267,10 @@ def PixelAthClusterMonAlgCfg(helper, alg, **kwargs):
             title = addOnTrackTxt('Average per module(FE) cluster occupancy reset every 5 min', ontrack, True)
             definePP0Histos(helper, alg, histoGroupName, title, pathGroup, opt='kLBNHistoryDepth=5')
 
+        if not ontrack and doFEPlots:
+            histoGroupName = 'ClusterFEOccupancy' 
+            title = 'Cluster occupancy per FE'
+            define2DProfPerFEHist(helper, alg, histoGroupName, title, pathGroup, type='TH2F')
 
         if doLumiBlock:
             pathGroup = addOnTrackToPath(pathLowStat, ontrack)
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthHitMonAlgCfg.py b/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthHitMonAlgCfg.py
index cfa7f401ddbf19609a3881c35728326f76ef8cd3..80ebdf7936c51e0a3864ec060522795b0d8df8ba 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthHitMonAlgCfg.py
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthHitMonAlgCfg.py
@@ -8,7 +8,8 @@
 '''
 
 from PixelMonitoring.PixelAthMonitoringBase import define2DProfHist, definePP0Histos, getLayerGroup
-from PixelMonitoring.PixelAthMonitoringBase import define1DProfLumiLayers
+from PixelMonitoring.PixelAthMonitoringBase import define1DProfLumiLayers, define2DProfPerFEHist
+from PixelMonitoring.PixelAthMonitoringBase import define1DLayers
 from PixelMonitoring.PixelAthMonitoringBase import layers, lumibinsx, bcidbinsx
 from PixelMonitoring.PixelAthMonitoringBase import addOnTrackTxt, addOnTrackToPath, fullDressTitle
 from PixelMonitoring.PixelAthMonitoringBase import runtext
@@ -22,6 +23,7 @@ def PixelAthHitMonAlgCfg(helper, alg, **kwargs):
     '''
     doOnline  = kwargs.get('doOnline',  False)
     doLumiBlock = kwargs.get('doLumiBlock', False)
+    doFEPlots  = kwargs.get('doFEPlots',  False)
 
     ontrack = False
 
@@ -59,12 +61,21 @@ def PixelAthHitMonAlgCfg(helper, alg, **kwargs):
         yaxistext      = ';occ. ratio to IBL'
         define1DProfLumiLayers(helper, alg, histoGroupName, title, pathGroup, yaxistext, type='TProfile')
 
+    histoGroupName = 'HitToT'
+    title = 'Hit ToT'
+    define1DLayers(helper, alg, histoGroupName, title, pathGroup, ';ToT [BC]', ';# hits', xbins=[300]*5+[20]*3, xmins=[-0.5]*8, binsizes=[1.0]*8)
+
     histoGroupName = 'HitMap' 
     title = 'hit map'
     define2DProfHist(helper, alg, histoGroupName, title, path, type='TH2F')
     if doLumiBlock:
         define2DProfHist(helper, alg, histoGroupName, title, pathLowStat, type='TH2F', lifecycle='lowStat', histname='HitMapLB')
 
+    if doFEPlots:
+        histoGroupName = 'HitFEMap' 
+        title = 'hit map per FE'
+        define2DProfPerFEHist(helper, alg, histoGroupName, title, path, type='TH2F')
+
     histoname = 'AvgOccPerBCID'
     for layer in layers:
         title      = 'Average pixel occupancy per BCID, {0}'.format(layer) + runtext + ';BCID;# hits/pixel/event'
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthMonitoringBase.py b/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthMonitoringBase.py
index 398c9669edbd2b467f268e7d19d6688bc5b5e2d7..4c26d5721f83f94d2d000a7983e07d273b883d8a 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthMonitoringBase.py
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelAthMonitoringBase.py
@@ -6,17 +6,7 @@
 @file PixelAthMonitoringBase.py
 @brief Helper functions for Run 3 Pixel monitoring algorithm configuration
 '''
-# hack to deal with global variables in this module
-# check if we are in "old-" or "new-style" configuration
-#from AthenaConfiguration.AllConfigFlags import ConfigFlags
-#from RecExConfig.AutoConfiguration import GetRunNumber
-#if ConfigFlags.DQ.isReallyOldStyle:
 runtext = ''
-#    if GetRunNumber() is not None:
-#        runtext = ' (Run %d)' % GetRunNumber()
-#else:
-#    runtext = ' (Run %d)' % ConfigFlags.Input.RunNumber[0]
-
 
 NumLayersDisk = 3
 NumLayersDBM  = 3
@@ -43,6 +33,10 @@ xminsl   = [ -0.5, -0.5,-6.5,-6.5,-6.5,-16.5,  -0.5,  -0.5]
 ybinsl   = [   48,   48,  22,  38,  52,   14,     4,     4]
 etatxt   = [ditxt,ditxt,btxt,btxt,btxt,sbtxt,dbmtxt,dbmtxt]
 phitext  = ";phi index of module"
+xbinsfel = [   24,   24, 104, 104, 104,   32,     3,     3]
+xminsfel = [ -0.5, -0.5, -52, -52, -52,-16.5,  -0.5,  -0.5]
+ybinsfel = [   96,   96,  44,  76, 104,   14,     4,     4]
+
 totcuts  = [   15,   15,  15,  15,  15,    4,     4,     4] 
 xbinsem  = [    3,    3,  13,  13,  13,   20,     3,     3]
 xminsem  = [  0.5,  0.5,-6.5,-6.5,-6.5,  -10,   0.5,   0.5]
@@ -81,6 +75,26 @@ LayersDBM = ["Layer 0", "Layer 1", "Layer 2"] #xDBM
 
 LabelX = [LayersDisk, LayersDisk, ModulesBarrel, ModulesBarrel, ModulesBarrel, ModulesIBL, LayersDBM, LayersDBM]
 
+#same for FE
+LayersDiskFE = [" ", " ", " ", "Disk 1", " ", " ", " ", " ",
+              " ", " ", " ", "Disk 2", " ", " ", " ", " ",
+              " ", " ", " ", "Disk 3", " ", " ", " ", " "]
+ModulesBarrelFE = [
+    " ", " ", " ", "M6C", " ", " ", " ", " ",
+    " ", " ", " ", "M5C", " ", " ", " ", " ",
+    " ", " ", " ", "M4C", " ", " ", " ", " ",
+    " ", " ", " ", "M3C", " ", " ", " ", " ",
+    " ", " ", " ", "M2C", " ", " ", " ", " ",
+    " ", " ", " ", "M1C", " ", " ", " ", " ",
+    " ", " ", " ", "M0", " ", " ", " ", " ",
+    " ", " ", " ", "M1A", " ", " ", " ", " ",
+    " ", " ", " ", "M2A", " ", " ", " ", " ",
+    " ", " ", " ", "M3A", " ", " ", " ", " ",
+    " ", " ", " ", "M4A", " ", " ", " ", " ",
+    " ", " ", " ", "M5A", " ", " ", " ", " ",
+    " ", " ", " ", "M6A", " ", " ", " ", " "]
+LabelFEX = [LayersDiskFE, LayersDiskFE, ModulesBarrelFE, ModulesBarrelFE, ModulesBarrelFE, ModulesIBL, LayersDBM, LayersDBM]
+
 ModulesECA = [
     "B01_S2_M1", "B01_S2_M6", "B01_S2_M2", "B01_S2_M5", "B01_S2_M3",
     "B01_S2_M4", "B02_S1_M1", "B02_S1_M6", "B02_S1_M2", "B02_S1_M5",
@@ -139,6 +153,24 @@ StavesIBL = [
 
 LabelY = [ModulesECA, ModulesECC, StavesL0, StavesL1, StavesL2, StavesIBL, ModulesDBM, ModulesDBM]
 
+#same for per-FE
+ModulesFEECA = []
+for i in ModulesECA: 
+    ModulesFEECA.extend([i, ' '])
+ModulesFEECC = []
+for i in ModulesECC: 
+    ModulesFEECC.extend([i, ' '])
+StavesFEL0 = []
+for i in StavesL0:
+    StavesFEL0.extend([i, ' '])
+StavesFEL1 = []
+for i in StavesL1:
+    StavesFEL1.extend([i, ' '])
+StavesFEL2 = []
+for i in StavesL2:
+    StavesFEL2.extend([i, ' '])
+LabelFEY = [ModulesFEECA, ModulesFEECC, StavesFEL0, StavesFEL1, StavesFEL2, StavesIBL, ModulesDBM, ModulesDBM]
+
 #PP0
 PP0sEC = [
     "D1_B01_S2", "D1_B02_S1", "D1_B02_S2", "D1_B03_S1", "D1_B03_S2", "D1_B04_S1", "D1_B04_S2", "D1_B01_S1",
@@ -281,6 +313,49 @@ def define2DProfHist(helper, alg, name, title, path, type='TProfile2D', doWeight
                                     duration=lifecycle,
                                     opt=opt, xlabels=LabelX[i], ylabels=LabelY[i])
 
+def define2DProfPerFEHist(helper, alg, name, title, path, type='TProfile2D', doWeight=False, lifecycle='run', zmin=None, zmax=None, opt='', histname=None, onlylayers=layers):
+    '''
+    This function configures 2D (Profile) histograms (or maps) for Pixel layers per FE.
+
+    Arguments:
+         helper     -- AthMonitorCfgHelper(Old) instance
+         alg        -- algorithm - Configurable object returned from addAlgorithm
+         name       -- Name of histogram (Name = name_layer)
+         title      -- Title of histogram (Title = title +' '+layer)
+         path       -- Path in output file for histogram
+         type       -- Type of histogram (TH2D, TProfile2D)
+         lifecycle  -- global life duration of histograms (run, lowstat [i.e. 20 LB], lumiblock) - APPLIES to MonGroup only
+         zmin(zmax) -- fix the displayed range - simply chopping the range!!!
+         opt        -- history depth of a histogram e.g. 'kLBNHistoryDepth=10'
+         histname   -- another way of naming the histogram(s), useful when multiple histograms are filled from exactly the same variables, but in a different way
+         onlylayers -- sublist of layers 
+    '''
+    assert(set(onlylayers).issubset(layers))
+    if histname is None:
+        histname = name
+    for i, layer in enumerate(layers):
+        if layer not in onlylayers: 
+            continue
+        fulltitle   = title + ', {0}'.format(layer) + runtext + etatxt[i] + phitext
+        layerGroup = getLayerGroup(helper, alg, layer)
+
+        fullvarstring = '{0}_{1},{0}_{2}'.format(name, 'em', 'pm')
+        weightvar = ''
+        if 'Profile' in type: 
+            fullvarstring += ',{0}_{1}'.format(name, 'val')
+        elif doWeight:
+            weightvar = '{0}_{1}'.format(name, 'val') # re-use the same variable for TH2 for now.
+            
+        fullvarstring += ';' + histname + '_{0}'.format(layer)
+        layerGroup.defineHistogram(fullvarstring, 
+                                    type=type, path=path, title=fulltitle, weight=weightvar,
+                                    xbins=xbinsfel[i], xmin=xminsfel[i], xmax=xminsfel[i]+xbinsfel[i], 
+                                    ybins=ybinsfel[i], ymin=-0.5, ymax=-0.5+ybinsfel[i],
+                                    zmin=zmin, zmax=zmax,
+                                    duration=lifecycle,
+                                    opt=opt, xlabels=LabelFEX[i], ylabels=LabelFEY[i])
+
+
 def definePP0Histos(helper, alg, name, title, path, opt=''):
     '''
     This function configures TProfile histograms for Pixel layers per pp0 or ROD.
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelMonitoringConfig.py b/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelMonitoringConfig.py
index 64331dad8eff2214ac9cfa5b9f49186049cc99ca..b07a05f5dec3c5648d47661c5e16a8aba6f9ce49 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelMonitoringConfig.py
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/python/PixelMonitoringConfig.py
@@ -1,5 +1,5 @@
 #
-#  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+#  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 #
 
 def PixelMonitoringConfig(flags):
@@ -9,24 +9,23 @@ def PixelMonitoringConfig(flags):
     # run on RAW only
     if flags.DQ.Environment in ('online', 'tier0', 'tier0Raw'):
         kwargsHitMonAlg = { 'doOnline'        : flags.Common.isOnline,      #Histograms for online (athenaPT) running
-                            'doModules'       : flags.Common.isOnline, #Turn on/off the sets of 1744 module histograms (for dqmf)
                             'doLumiBlock'     : not flags.Common.isOnline,       #Turn on/off histograms stored for each lumi block
                             'doLowOccupancy'  : False,      #Turn on/off histograms with binning for cosmics/single beam                    
                             'doHighOccupancy' : True,       #Turn on/off histograms with binning for collisions
                             #'doHeavyIonMon'   : InDetFlags.doHeavyIon(),   # Histogram modification for heavy ion monitoring
                             #'RDOName'         : InDetKeys.PixelRDOs()
                             'doHeavyIonMon'   : False,      #Until new config ready
+                            'doFEPlots'       : False,       #Turn on/off histograms with FE Status information
                             'RDOName'         : 'PixelRDOs',#Until new config ready
         }
 
         kwargsClusMonAlg = { 'doOnline'        : flags.Common.isOnline,      #Histograms for online (athenaPT) running
-                             'doModules'       : flags.Common.isOnline, #Turn on/off the sets of 1744 module histograms (for dqmf)
                              'doLumiBlock'     : not flags.Common.isOnline,       #Turn on/off histograms stored for each lumi block
                              'doLowOccupancy'  : False,      #Turn on/off histograms with binning for cosmics/single beam
                              'doHighOccupancy' : True,       #Turn on/off histograms with binning for collisions
                              #'doHeavyIonMon'   : InDetFlags.doHeavyIon(),   # Histogram modification for heavy ion monitoring
                              'doHeavyIonMon'   : False,   #Until new config ready
-                             #                  'doStatus'        : True,       #Turn on/off histograms with Module Status information
+                             'doFEPlots'       : False,       #Turn on/off histograms with FE Status information
                              #'ClusterName'     : InDetKeys.PixelClusters(),
                              'ClusterName'     : 'PixelClusters', #Until new config ready
                              #'TrackName'       : InDetKeys.Tracks()
@@ -34,7 +33,6 @@ def PixelMonitoringConfig(flags):
         }
 
         kwargsErrMonAlg = { 'doOnline'        : flags.Common.isOnline,      #Histograms for online (athenaPT) running
-                            'doModules'       : flags.Common.isOnline, #Turn on/off the sets of 1744 module histograms (for dqmf)
                             'doLumiBlock'     : not flags.Common.isOnline,       #Turn on/off histograms stored for each lumi block
                             'doLowOccupancy'  : False,      #Turn on/off histograms with binning for cosmics/single beam                    
                             'doHighOccupancy' : True,       #Turn on/off histograms with binning for collisions
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthClusterMonAlg.cxx b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthClusterMonAlg.cxx
index d7015683e82e1f816a584e84078232a955fad682..e04de719c682e6796bca653afb5f789afa8ebb38 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthClusterMonAlg.cxx
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthClusterMonAlg.cxx
@@ -6,6 +6,7 @@
 
 PixelAthClusterMonAlg::PixelAthClusterMonAlg( const std::string& name, ISvcLocator* pSvcLocator ) : 
   AthMonitorAlgorithm(name, pSvcLocator),
+  m_pixelCablingSvc("PixelCablingSvc", name),
   m_holeSearchTool("InDet::InDetTrackHoleSearchTool/InDetHoleSearchTool", this),
   m_trackSelTool("InDet::InDetTrackSelectionTool/TrackSelectionTool", this),
   m_atlasid(nullptr),
@@ -16,11 +17,11 @@ PixelAthClusterMonAlg::PixelAthClusterMonAlg( const std::string& name, ISvcLocat
   declareProperty("TrackSelectionTool", m_trackSelTool); //needed for cfg in python jo
 
   declareProperty("doOnline", m_doOnline = false);
-  declareProperty("doModules", m_doModules = false);
   declareProperty("doLumiBlock", m_doLumiBlock = false);
   declareProperty("doLowOccupancy", m_doLowOccupancy = false);
   declareProperty("doHighOccupancy", m_doHighOccupancy = true);
   declareProperty("doHeavyIonMon", m_doHeavyIonMon = false);
+  declareProperty("doFEPlots", m_doFEPlots = false);
 }
 
 
@@ -32,6 +33,7 @@ StatusCode PixelAthClusterMonAlg::initialize() {
   ATH_CHECK( detStore()->retrieve(m_atlasid, "AtlasID") );
   ATH_CHECK( detStore()->retrieve(m_pixelid, "PixelID") );
   ATH_CHECK( m_pixelCondSummaryTool.retrieve() );
+  ATH_CHECK( m_pixelCablingSvc.retrieve() );
   if ( !m_holeSearchTool.empty() ) ATH_CHECK( m_holeSearchTool.retrieve() );
   if ( !m_trackSelTool.empty() ) ATH_CHECK( m_trackSelTool.retrieve() );
 
@@ -60,7 +62,9 @@ StatusCode PixelAthClusterMonAlg::fillHistograms( const EventContext& ctx ) cons
   bool copyFEval(false);
   AccumulatorArrays clusPerEventArray = { {{0}}, {{0}}, {{0}}, {{0}}, {{0}}, {{0}} };
   VecAccumulator2DMap Map_Of_Modules_Status("MapOfModulesStatus", true);
-  
+
+  VecAccumulator2DMap Map_Of_FEs_Status("MapOfFEsStatus"); 
+
   for (auto idIt = m_pixelid->wafer_begin(); idIt!=m_pixelid->wafer_end(); ++idIt) {
     Identifier     waferID = *idIt;
     IdentifierHash id_hash = m_pixelid->wafer_hash(waferID);
@@ -102,12 +106,31 @@ StatusCode PixelAthClusterMonAlg::fillHistograms( const EventContext& ctx ) cons
     }
     
     Map_Of_Modules_Status.add(pixlayer, waferID, m_pixelid, index);
+
+    // Per FE Status
+    //
+    if (m_doFEPlots && !m_doOnline) {
+      int nFE = getNumberOfFEs(pixlayer, m_pixelid->eta_module(waferID));
+      for (int iFE=0; iFE<nFE; iFE++) {
+	Identifier pixelID = m_pixelCablingSvc->getPixelIdfromHash(id_hash, iFE, 1, 1);
+	if (m_pixelCondSummaryTool->isActive(id_hash, pixelID) == true && m_pixelCondSummaryTool->isGood(id_hash, pixelID) == true) {
+	  index = 0;  // active and good FE
+	} else if (m_pixelCondSummaryTool->isActive(id_hash, pixelID) == false) {
+	  index = 2;  // inactive or bad FE
+	} else {
+	  index = 1;  // active and bad FE
+	}
+	Map_Of_FEs_Status.add(pixlayer, waferID, m_pixelid, iFE, index);
+      }
+    }
   }  // end of pixelid wafer loop
 
   fill2DProfLayerAccum( Map_Of_Modules_Status );
   fill1DProfLumiLayers("BadModulesPerLumi", lb, nBadMod);
   fill1DProfLumiLayers("DisabledModulesPerLumi", lb, nDisabledMod);
 
+  if (m_doFEPlots && !m_doOnline) fill2DProfLayerAccum( Map_Of_FEs_Status );
+
   //*******************************************************************************
   //*************************** End of filling Status Histograms ******************
   //*******************************************************************************
@@ -307,7 +330,8 @@ StatusCode PixelAthClusterMonAlg::fillHistograms( const EventContext& ctx ) cons
 
   ATH_MSG_DEBUG("Filling Cluster Monitoring Histograms");
 
-  auto clToTcosAlphaLB = Monitored::Scalar<float>( "Cluster_ToTxCosAlpha_OnTrack_lb", lb);
+
+  auto clToTcosAlphaLB = Monitored::Scalar<float>( "ClusterToTxCosAlpha_OnTrack_lb", lb);
 
   VecAccumulator2DMap Cluster_LVL1A_Mod("ClusterLVL1AMod");
   VecAccumulator2DMap Cluster_LVL1A_SizeCut("ClusterLVL1ASizeCut");
@@ -320,6 +344,8 @@ StatusCode PixelAthClusterMonAlg::fillHistograms( const EventContext& ctx ) cons
   VecAccumulator2DMap Cluster_Occupancy_OnTrack("ClusterOccupancyOnTrack");
   VecAccumulator2DMap Clus_Occ_SizeCut("ClusOccSizeCut");
   VecAccumulator2DMap Clus_Occ_SizeCut_OnTrack("ClusOccSizeCutOnTrack");
+  VecAccumulator2DMap Cluster_FE_Occupancy("ClusterFEOccupancy");
+
   auto clusterGroup = getGroup("Cluster");
   auto clusterGroup_OnTrack = getGroup("Cluster_OnTrack");
 
@@ -378,6 +404,9 @@ StatusCode PixelAthClusterMonAlg::fillHistograms( const EventContext& ctx ) cons
       // begin cluster occupancy
       //
       Cluster_Occupancy.add(pixlayer, clusID, m_pixelid);
+      if (m_doFEPlots && !m_doOnline) {
+	Cluster_FE_Occupancy.add(pixlayer, clusID, m_pixelid, m_pixelCablingSvc->getFE(&clusID, clusID), 1.0);
+      }
       if (cluster.rdoList().size() > 1) Clus_Occ_SizeCut.add(pixlayer, clusID, m_pixelid);
       // end cluster occupancy
 
@@ -438,12 +467,11 @@ StatusCode PixelAthClusterMonAlg::fillHistograms( const EventContext& ctx ) cons
 	// begin cluster ToT and charge
 	//
 	auto clToTcosAlpha = Monitored::Scalar<float>( "ClusterToTxCosAlphaOnTrack_val", cluster.totalToT() * cosalpha );
-	fill( pixLayersLabel[pixlayer], clToTcosAlpha);
+	fill( pixLayersLabel[pixlayer], clToTcosAlphaLB, clToTcosAlpha);
+
 	if (!m_doOnline) {
 	  auto clQcosAlpha   = Monitored::Scalar<float>( "ClusterQxCosAlphaOnTrack_val", cluster.totalCharge() * cosalpha);
 	  fill( pixLayersLabel[pixlayer], clQcosAlpha);
-	} else {
-	  fill( pixLayersLabel[pixlayer], clToTcosAlphaLB, clToTcosAlpha);
 	}
 	// 
 	// end cluster ToT and charge   
@@ -464,7 +492,7 @@ StatusCode PixelAthClusterMonAlg::fillHistograms( const EventContext& ctx ) cons
   fill2DProfLayerAccum(Cluster_Occupancy_OnTrack);
   fill2DProfLayerAccum(Clus_Occ_SizeCut);
   fill2DProfLayerAccum(Clus_Occ_SizeCut_OnTrack);
-  
+  if (m_doFEPlots && !m_doOnline) fill2DProfLayerAccum(Cluster_FE_Occupancy);
   // begin cluster rates
   //
   auto nCls   = Monitored::Scalar<int>( "ncls_per_event", nclusters );
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthClusterMonAlg.h b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthClusterMonAlg.h
index 7e2e3783e5c371691767d91c9ec558ff4e5709af..9d51e018b101a226a83e38db9d56aad382150262 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthClusterMonAlg.h
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthClusterMonAlg.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef PIXELATHCLUSTERMONTOOL_H
@@ -9,6 +9,7 @@
 
 #include "AtlasDetDescr/AtlasDetectorID.h"
 #include "InDetConditionsSummaryService/IInDetConditionsTool.h"
+#include "PixelCabling/IPixelCablingSvc.h"
 
 #include "InDetPrepRawData/PixelClusterContainer.h"
 
@@ -51,7 +52,7 @@ class PixelAthClusterMonAlg : public PixelAthMonitoringBase {
   std::string findComponentString(int bec, int ld) const;
 
  private:
-
+  ServiceHandle<IPixelCablingSvc> m_pixelCablingSvc; //FE info
   ToolHandle<Trk::ITrackHoleSearchTool> m_holeSearchTool;
   ToolHandle<InDet::IInDetTrackSelectionTool> m_trackSelTool;
   ToolHandle<IInDetConditionsTool> m_pixelCondSummaryTool{this, "PixelConditionsSummaryTool", "PixelConditionsSummaryTool", "Tool to retrieve Pixel Conditions summary"};
@@ -63,11 +64,10 @@ class PixelAthClusterMonAlg : public PixelAthMonitoringBase {
   SG::ReadHandleKey<TrackCollection> m_tracksKey{this, "TrackName", "CombinedInDetTracks", "track data key"};
  
   bool m_doOnline;
-  bool m_doModules;
   bool m_doLumiBlock;
   bool m_doLowOccupancy;
   bool m_doHighOccupancy;
   bool m_doHeavyIonMon; 
-
+  bool m_doFEPlots;
 };
 #endif
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthErrorMonAlg.cxx b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthErrorMonAlg.cxx
index 3bb258cad486ec102fb19c44a59dc6644299779c..8842509f559b3156936081980652f780ce16824f 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthErrorMonAlg.cxx
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthErrorMonAlg.cxx
@@ -6,11 +6,11 @@
 
 PixelAthErrorMonAlg::PixelAthErrorMonAlg( const std::string& name, ISvcLocator* pSvcLocator ) : 
   AthMonitorAlgorithm(name, pSvcLocator),
+  m_pixelCablingSvc("PixelCablingSvc", name),
   m_pixelid(nullptr)
 {
   // jo flags
   declareProperty("doOnline", m_doOnline = false);
-  declareProperty("doModules", m_doModules = false);
   declareProperty("doLumiBlock", m_doLumiBlock = false);
   declareProperty("doLowOccupancy", m_doLowOccupancy = false);
   declareProperty("doHighOccupancy", m_doHighOccupancy = false);
@@ -25,6 +25,7 @@ StatusCode PixelAthErrorMonAlg::initialize() {
 
   ATH_CHECK( detStore()->retrieve(m_pixelid, "PixelID") );
   ATH_CHECK( m_pixelCondSummaryTool.retrieve() );
+  ATH_CHECK( m_pixelCablingSvc.retrieve() );
 
   return AthMonitorAlgorithm::initialize();
 }
@@ -42,20 +43,20 @@ StatusCode PixelAthErrorMonAlg::fillHistograms( const EventContext& ctx ) const
   std::vector<VecAccumulator2DMap> error_maps_per_state;
   error_maps_per_state.reserve(kNumErrorStatesFEI3 + kNumErrorStatesFEI4);
   for (const auto& state : error_names_stateFEI3) {
-    error_maps_per_state.emplace_back( state + std::string("Map"), true );
+    error_maps_per_state.emplace_back( state + std::string("Map") );
   }
   for (const auto& state : error_names_stateFEI4) {
-    error_maps_per_state.emplace_back( state + std::string("Map"), true );
+    error_maps_per_state.emplace_back( state + std::string("Map") );
   }
   std::vector<VecAccumulator2DMap> error_maps_per_cat_rodmod; 
   // only first four rodmod histos are unique, others are covered by 
   // the overall, rod/mod-agnostic categories below
   for (unsigned int cat = 0; cat < ErrorCategoryRODMOD::kTruncROD+1; ++cat) {
-    error_maps_per_cat_rodmod.emplace_back( error_names_cat_rodmod[cat], true );
+    error_maps_per_cat_rodmod.emplace_back( error_names_cat_rodmod[cat] );
   }
   std::vector<VecAccumulator2DMap> error_maps_per_cat;
   for (unsigned int cat = 0; cat < ErrorCategory::COUNT; ++cat) {
-    error_maps_per_cat.emplace_back( error_names_cat[cat], true );
+    error_maps_per_cat.emplace_back( error_names_cat[cat] );
   }
 
   // containers to keep IBL service records info
@@ -74,10 +75,10 @@ StatusCode PixelAthErrorMonAlg::fillHistograms( const EventContext& ctx ) const
   float num_errormodules_per_cat_rodmod[ErrorCategoryRODMOD::COUNT][PixLayers::COUNT] = {{0}};
 
   // Generate femcc_errwords and per LB maps, all _per module_, including IBL.
-  VecAccumulator2DMap femcc_errwords_maps("FEMCCErrorwords", true);
-  VecAccumulator2DMap all_errors_maps("ErrorsLB", true);
-  VecAccumulator2DMap modsync_errors_maps("ErrorsModSyncLB", true);
-  VecAccumulator2DMap rodsync_errors_maps("ErrorsRODSyncLB", true);
+  VecAccumulator2DMap femcc_errwords_maps("FEMCCErrorwords");
+  VecAccumulator2DMap all_errors_maps("ErrorsLB");
+  VecAccumulator2DMap modsync_errors_maps("ErrorsModSyncLB");
+  VecAccumulator2DMap rodsync_errors_maps("ErrorsRODSyncLB");
 
   //====================================================================================
   // This is an example how to read the Error informaiton.
@@ -123,18 +124,19 @@ StatusCode PixelAthErrorMonAlg::fillHistograms( const EventContext& ctx ) const
     int nFE;
     bool is_fei4;
     if (pixlayer == PixLayers::kDBMC || pixlayer == PixLayers::kDBMA) {
-      nFE = 2;  
+      nFE = 1;  
       is_fei4 = true;
     } else if (pixlayer == PixLayers::kIBL) {
-      nFE = 2;  
+      nFE = 1; // IBL 3D
+      if (m_pixelid->eta_module(waferID)>-7 && m_pixelid->eta_module(waferID)<6) nFE = 2; //IBL Planar
       is_fei4 = true;
     } else { // for fei3 Pixel layers
       nFE = 16;
       is_fei4 = false;
     }
     // flagging/counting categorized errors per module.
-    bool has_err_cat[ErrorCategory::COUNT] = {false};
-    int nerrors_cat_rodmod[ErrorCategoryRODMOD::COUNT] = {0};
+    bool has_err_cat[ErrorCategory::COUNT][nFEIBL2D] = {false};
+    int nerrors_cat_rodmod[ErrorCategoryRODMOD::COUNT][nFEIBL2D] = {0};
 
     // count number of words w/ MCC/FE flags per module
     unsigned int num_femcc_errwords = 0;
@@ -161,7 +163,7 @@ StatusCode PixelAthErrorMonAlg::fillHistograms( const EventContext& ctx ) const
       int offsetFE = (1+iFE)*maxHash + modHash;    // (FE index+1)*2048 + moduleHash
       uint64_t fe_errorword = m_pixelCondSummaryTool->getBSErrorWord(offsetFE, ctx);
 
-      fillErrorCatRODmod(fe_errorword, is_fei4, nerrors_cat_rodmod);
+      fillErrorCatRODmod(fe_errorword, is_fei4, nerrors_cat_rodmod, iFE);
 
       if (!is_fei4) {
 	std::bitset<kNumErrorStatesFEI3> stateFEI3 = getErrorStateFE(fe_errorword, is_fei4);  
@@ -176,10 +178,11 @@ StatusCode PixelAthErrorMonAlg::fillHistograms( const EventContext& ctx ) const
       } else {
 	std::bitset<kNumErrorStatesFEI3> stateFEI4 = getErrorStateFE(fe_errorword, is_fei4);  
 	num_errors[pixlayer]+=stateFEI4.count();
+	Identifier pixelIDperFEI4 = m_pixelCablingSvc->getPixelIdfromHash(modHash, iFE, 1, 1);
 	for (unsigned int state = 0; state < stateFEI4.size(); ++state) {
 	  if (stateFEI4[state]) {
 	    num_errors_per_state[state][pixlayer]++;
-	    error_maps_per_state[state+kNumErrorStatesFEI3].add(pixlayer, waferID, m_pixelid, 1.0);
+	    error_maps_per_state[state+kNumErrorStatesFEI3].add(pixlayer, pixelIDperFEI4, m_pixelid, 1.0);
 	  }
 	}
       }
@@ -201,6 +204,7 @@ StatusCode PixelAthErrorMonAlg::fillHistograms( const EventContext& ctx ) const
 	}
 	int serviceCodeOffset = serviceCode*280*nFE;
 	for (int iFE=0; iFE<nFE; iFE++) {
+	  Identifier pixelIDperFEI4 = m_pixelCablingSvc->getPixelIdfromHash(modHash, iFE, 1, 1);
 	  // index = offset + (serviceCode)*(#IBL*nFE) + (moduleHash-156)*nFE + FE
           int serviceCodeCounterIndex = serviceRecordFieldOffset + serviceCodeOffset + moduleOffset + iFE;
           uint64_t serviceCodeCounter = m_pixelCondSummaryTool->getBSErrorWord(serviceCodeCounterIndex, ctx);
@@ -213,9 +217,9 @@ StatusCode PixelAthErrorMonAlg::fillHistograms( const EventContext& ctx ) const
 	    int state = serviceCode + state_offset;
 	    num_errors[pixlayer] += payload;
 	    num_errors_per_state[state][pixlayer] += payload;
-	    error_maps_per_state[state+kNumErrorStatesFEI3].add(pixlayer, waferID, m_pixelid, payload);
+	    error_maps_per_state[state+kNumErrorStatesFEI3].add(pixlayer, pixelIDperFEI4, m_pixelid, payload);
 	   
-	    fillErrorCatRODmod(serviceCode, payload, nerrors_cat_rodmod);
+	    fillErrorCatRODmod(serviceCode, payload, nerrors_cat_rodmod, iFE);
 	  }
 
         } // over FE
@@ -223,37 +227,46 @@ StatusCode PixelAthErrorMonAlg::fillHistograms( const EventContext& ctx ) const
     } // IBL modules
 
     // access categorized error information per module
+    // access categorized error information per module (for IBL - FE)
     // it is only flagged - the actual number of errors per category is not tracked
-    for (int i = 0; i < ErrorCategoryRODMOD::COUNT; i++) {
-      if (nerrors_cat_rodmod[i]) {
-	if (getErrorCategory(i+1)!=99) has_err_cat[getErrorCategory(i+1)] = true;
-	num_errormodules_per_cat_rodmod[i][pixlayer]++;
-	if (!m_doOnline) {
-	  all_errors_maps.add(pixlayer, waferID, m_pixelid, nerrors_cat_rodmod[i]);
-	  if (i<ErrorCategoryRODMOD::kTruncROD+1) {
-	    error_maps_per_cat_rodmod[i].add(pixlayer, waferID, m_pixelid, 1.0);
-	    if (i==0) modsync_errors_maps.add(pixlayer, waferID, m_pixelid, 1.0);
-	    if (i==1) rodsync_errors_maps.add(pixlayer, waferID, m_pixelid, 1.0);
+    for (int iFE=0; iFE<nFE; iFE++) {
+
+      if (pixlayer != PixLayers::kIBL && iFE>0) continue;
+      Identifier pixID = waferID;
+      if (pixlayer == PixLayers::kIBL) {
+	pixID = m_pixelCablingSvc->getPixelIdfromHash(modHash, iFE, 1, 1);
+      }
+
+      for (int i = 0; i < ErrorCategoryRODMOD::COUNT; i++) {
+	if (nerrors_cat_rodmod[i][iFE]) {
+	  if (getErrorCategory(i+1)!=99) has_err_cat[getErrorCategory(i+1)][iFE] = true;
+	  num_errormodules_per_cat_rodmod[i][pixlayer]++;
+	  if (!m_doOnline) {
+	    all_errors_maps.add(pixlayer, pixID, m_pixelid, nerrors_cat_rodmod[i][iFE]);
+	    if (i<ErrorCategoryRODMOD::kTruncROD+1) {
+	      error_maps_per_cat_rodmod[i].add(pixlayer, pixID, m_pixelid, 1.0);
+	      if (i==0) modsync_errors_maps.add(pixlayer, pixID, m_pixelid, 1.0);
+	      if (i==1) rodsync_errors_maps.add(pixlayer, pixID, m_pixelid, 1.0);
+	    }
 	  }
 	}
       }
-    }
-    for (int i = 0; i < ErrorCategory::COUNT; i++) {
-      if (has_err_cat[i]) {
-	num_errormodules_per_cat[i][pixlayer]++;
-	if (!m_doOnline) {
-	  error_maps_per_cat[i].add(pixlayer, waferID, m_pixelid, 1.0);
+      for (int i = 0; i < ErrorCategory::COUNT; i++) {
+	if (has_err_cat[i][iFE]) {
+	  num_errormodules_per_cat[i][pixlayer]++;
+	  if (!m_doOnline) {
+	    error_maps_per_cat[i].add(pixlayer, pixID, m_pixelid, 1.0);
+	  }
 	}
       }
-    }
+
     // filling nActive modules per layer for later normalization
-    // for IBL (and DBM) normalization is effectively done by number of FEI4 
-    // REVIEW once per-FE active info is available
-    //
-    if (m_pixelCondSummaryTool->isActive(modHash) == true) {
-      if (pixlayer == PixLayers::kIBL && m_pixelid->eta_module(waferID)>-7 && m_pixelid->eta_module(waferID)<6) nActive_layer[pixlayer]+=2;
-      else nActive_layer[pixlayer]++;
-    }
+    // for IBL (and DBM) normalization isdone by number of FEI4 
+      if ( (pixlayer != PixLayers::kIBL && m_pixelCondSummaryTool->isActive(modHash) == true) ||
+	   (pixlayer == PixLayers::kIBL && m_pixelCondSummaryTool->isActive(modHash, pixID) == true) ) {
+	nActive_layer[pixlayer]++;
+      }
+    } // loop over FEs
 
   } // loop over modules
 
@@ -366,44 +379,46 @@ std::bitset<kNumErrorStatesFEI3> PixelAthErrorMonAlg::getErrorStateFE(uint64_t e
   return result;
 }
 
-void PixelAthErrorMonAlg::fillErrorCatRODmod(uint64_t errorword, int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT]) const {
-  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::TimeOut) )            nerrors_cat_rodmod[6]++; // timeout errors
-  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::BCID) )               nerrors_cat_rodmod[1]++; // ROD synchronization
-  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::LVL1ID) )             nerrors_cat_rodmod[1]++; // ROD synchronization
-  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Preamble) )           nerrors_cat_rodmod[4]++; // optical errors
-  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::RODHeaderLimit) )     nerrors_cat_rodmod[3]++; // ROD truncation
-  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::RODDataOVerflow) )    nerrors_cat_rodmod[3]++; // ROD truncation
+void PixelAthErrorMonAlg::fillErrorCatRODmod(uint64_t errorword, int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT][nFEIBL2D]) const {
+  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::TimeOut) )            nerrors_cat_rodmod[6][0]++; // timeout errors
+  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::BCID) )               nerrors_cat_rodmod[1][0]++; // ROD synchronization
+  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::LVL1ID) )             nerrors_cat_rodmod[1][0]++; // ROD synchronization
+  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Preamble) )           nerrors_cat_rodmod[4][0]++; // optical errors
+  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::RODHeaderLimit) )     nerrors_cat_rodmod[3][0]++; // ROD truncation
+  if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::RODDataOVerflow) )    nerrors_cat_rodmod[3][0]++; // ROD truncation
 }
 
-void PixelAthErrorMonAlg::fillErrorCatRODmod(uint64_t errorword, bool is_fei4, int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT]) const {
+void PixelAthErrorMonAlg::fillErrorCatRODmod(uint64_t errorword, bool is_fei4, 
+					     int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT][nFEIBL2D], int ife) const {
   if (!is_fei4) {
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCLVL1IDEoECheck) ) nerrors_cat_rodmod[0]++;  // module synchronization
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCBCIDEoECheck) )   nerrors_cat_rodmod[0]++;  // ---
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCLVL1IDCheck) )    nerrors_cat_rodmod[0]++;  // ---
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCEoEOverflow) )    nerrors_cat_rodmod[2]++;  // module truncation
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCHitOverflow) )    nerrors_cat_rodmod[2]++;  // ---
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::FEEoCOverflow) )     nerrors_cat_rodmod[2]++;  // ---
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::FEHitParity) )       nerrors_cat_rodmod[5]++;  // SEU (single event upset)
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::FERegisterParity) )  nerrors_cat_rodmod[5]++;  // ---
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::FEHammingCode) )     nerrors_cat_rodmod[5]++;  // ---
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCLVL1IDEoECheck) ) nerrors_cat_rodmod[0][0]++;  // module synchronization
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCBCIDEoECheck) )   nerrors_cat_rodmod[0][0]++;  // ---
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCLVL1IDCheck) )    nerrors_cat_rodmod[0][0]++;  // ---
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCEoEOverflow) )    nerrors_cat_rodmod[2][0]++;  // module truncation
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::MCCHitOverflow) )    nerrors_cat_rodmod[2][0]++;  // ---
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::FEEoCOverflow) )     nerrors_cat_rodmod[2][0]++;  // ---
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::FEHitParity) )       nerrors_cat_rodmod[5][0]++;  // SEU (single event upset)
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::FERegisterParity) )  nerrors_cat_rodmod[5][0]++;  // ---
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::FEHammingCode) )     nerrors_cat_rodmod[5][0]++;  // ---
   } else {
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::TimeOut) )           nerrors_cat_rodmod[6]++; // timeout errors
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::BCID) )              nerrors_cat_rodmod[1]++; // ROD synchronization
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::LVL1ID) )            nerrors_cat_rodmod[1]++; // ROD synchronization
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Preamble) )          nerrors_cat_rodmod[4]++; // optical errors
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Trailer) )           nerrors_cat_rodmod[6]++; // timeout errors
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Invalid) )           nerrors_cat_rodmod[3]++; // ROD truncation
-    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Limit) )             nerrors_cat_rodmod[3]++; // ROD truncation
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::TimeOut) )           nerrors_cat_rodmod[6][ife]++; // timeout errors
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::BCID) )              nerrors_cat_rodmod[1][ife]++; // ROD synchronization
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::LVL1ID) )            nerrors_cat_rodmod[1][ife]++; // ROD synchronization
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Preamble) )          nerrors_cat_rodmod[4][ife]++; // optical errors
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Trailer) )           nerrors_cat_rodmod[6][ife]++; // timeout errors
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Invalid) )           nerrors_cat_rodmod[3][ife]++; // ROD truncation
+    if ( PixelByteStreamErrors::hasError(errorword, PixelByteStreamErrors::Limit) )             nerrors_cat_rodmod[3][ife]++; // ROD truncation
   }
 }
 
-void PixelAthErrorMonAlg::fillErrorCatRODmod(int sc, int payload, int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT]) const {
+void PixelAthErrorMonAlg::fillErrorCatRODmod(int sc, int payload, 
+					     int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT][nFEIBL2D], int ife) const {
 
-  if (sc == 0)                  nerrors_cat_rodmod[0]+=payload;  // synchronization error   (SR0:BCID counter)
-  if (sc == 16)                 nerrors_cat_rodmod[2]+=payload;  // truncation error        (SR16:Truncated event)
+  if (sc == 0)                  nerrors_cat_rodmod[0][ife]+=payload;  // synchronization error   (SR0:BCID counter)
+  if (sc == 16)                 nerrors_cat_rodmod[2][ife]+=payload;  // truncation error        (SR16:Truncated event)
   if (sc == 1 || sc == 2 ||                                      // (SR1:Hamming code 0, SR2:Hamming code 1,
       sc == 3 || sc == 24 ||                                     // SR3:Hamming code 2, SR24:Triple redundant CNFGMEM,
       sc == 28 || sc == 29 ||                                    // SR28:Bit flip in CMD, SR29:Triple redundant CMD,
       sc == 31)                                                  // SR31:Triple redundant EFUSE)
-    nerrors_cat_rodmod[5]+=payload;                              // SEU error
+    nerrors_cat_rodmod[5][ife]+=payload;                              // SEU error
 }
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthErrorMonAlg.h b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthErrorMonAlg.h
index dfbdcc492348d4e01e7c4d1ed0b7eb0e37556c2b..ee7d3d6e15baa062855d9a8db2da99cee9c8d01a 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthErrorMonAlg.h
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthErrorMonAlg.h
@@ -8,6 +8,7 @@
 #include "PixelAthMonitoringBase.h"
 #include "InDetConditionsSummaryService/IInDetConditionsTool.h"
 #include "PixelConditionsData/PixelByteStreamErrors.h"
+#include "PixelCabling/IPixelCablingSvc.h"
 
 class PixelID;
 
@@ -119,6 +120,8 @@ static const int numErrorCatRODModsLayer[PixLayers::COUNT] = {
   kNumErrorCatRODMods, kNumErrorCatRODMods, kNumErrorCatRODMods, kNumErrorCatRODMods
 };
 
+static const int nFEIBL2D{2};
+
 class PixelAthErrorMonAlg : public PixelAthMonitoringBase {
 
  public:
@@ -131,21 +134,26 @@ class PixelAthErrorMonAlg : public PixelAthMonitoringBase {
   int getErrorCategory(int error_cat_rodmod) const;
   std::bitset<kNumErrorStatesFEI3> getErrorStateFEI3Mod(uint64_t errorword) const;
   std::bitset<kNumErrorStatesFEI3> getErrorStateFE(uint64_t errorword, bool isibl) const;
-  void fillErrorCatRODmod(uint64_t mod_errorword, int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT]) const;
-  void fillErrorCatRODmod(uint64_t fe_errorword, bool is_fei4, int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT]) const;
-  void fillErrorCatRODmod(int servicecode, int payload, int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT]) const;
+  void fillErrorCatRODmod(uint64_t mod_errorword, 
+			    int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT][nFEIBL2D]) const;
+  void fillErrorCatRODmod(uint64_t fe_errorword, bool is_fei4, 
+			    int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT][nFEIBL2D], int ife) const;
+  void fillErrorCatRODmod(int servicecode, int payload, 
+			    int (&nerrors_cat_rodmod)[ErrorCategoryRODMOD::COUNT][nFEIBL2D], int ife) const;
 
  private:
 
-  ToolHandle<IInDetConditionsTool> m_pixelCondSummaryTool{this, "PixelConditionsSummaryTool", "PixelConditionsSummaryTool", "Tool to retrieve Pixel Conditions summary"};
+  ServiceHandle<IPixelCablingSvc> m_pixelCablingSvc; //FE info
+  ToolHandle<IInDetConditionsTool> m_pixelCondSummaryTool{this, "PixelConditionsSummaryTool", 
+							    "PixelConditionsSummaryTool", "Tool to retrieve Pixel Conditions summary"};
 
   const PixelID* m_pixelid;
 
   bool m_doOnline;
-  bool m_doModules;
   bool m_doLumiBlock;
   bool m_doLowOccupancy;
   bool m_doHighOccupancy;
   bool m_doHeavyIonMon;
+
 };
 #endif
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthHitMonAlg.cxx b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthHitMonAlg.cxx
index 810662d94a34a50c544b839cc7fb9ac70b14e154..2e7b5209e883868c5d2e4b3818c5dcb4ec4bb72c 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthHitMonAlg.cxx
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthHitMonAlg.cxx
@@ -3,20 +3,19 @@
 */
 
 #include "PixelAthHitMonAlg.h"
-#include "PixelCabling/IPixelCablingSvc.h"
 
 PixelAthHitMonAlg::PixelAthHitMonAlg( const std::string& name, ISvcLocator* pSvcLocator ) : 
   AthMonitorAlgorithm(name, pSvcLocator),
-  m_pixelCableSvc("PixelCablingSvc", name),
+  m_pixelCablingSvc("PixelCablingSvc", name),
   m_pixelid(nullptr)
 {
   //jo flags
   declareProperty("doOnline", m_doOnline = false);
-  declareProperty("doModules", m_doModules = false);
   declareProperty("doLumiBlock", m_doLumiBlock = false);
   declareProperty("doLowOccupancy", m_doLowOccupancy = false);
   declareProperty("doHighOccupancy", m_doHighOccupancy = false);
   declareProperty("doHeavyIonMon", m_doHeavyIonMon = false);
+  declareProperty("doFEPlots", m_doFEPlots = false);
 }
 
 
@@ -27,7 +26,7 @@ StatusCode PixelAthHitMonAlg::initialize() {
 
   ATH_CHECK( detStore()->retrieve(m_pixelid, "PixelID") );
   ATH_CHECK( m_pixelCondSummaryTool.retrieve() );
-  ATH_CHECK( m_pixelCableSvc.retrieve() );
+  ATH_CHECK( m_pixelCablingSvc.retrieve() );
   ATH_CHECK( m_pixelRDOName.initialize() );
 
   return AthMonitorAlgorithm::initialize();
@@ -134,9 +133,10 @@ StatusCode PixelAthHitMonAlg::fillHistograms( const EventContext& ctx ) const {
 
 
   VecAccumulator2DMap HitMap("HitMap");
+  VecAccumulator2DMap HitFEMap("HitFEMap");
   std::vector<int> hitLvl1a;
   std::unordered_map<int, std::vector<int>> hitLvl1aLayer;
-
+  std::unordered_map<int, std::vector<int>> hitToTLayer;
 
   Identifier rdoID;
   PixelRDO_Container::const_iterator colNext = rdocontainer->begin();
@@ -156,10 +156,12 @@ StatusCode PixelAthHitMonAlg::fillHistograms( const EventContext& ctx ) const {
       int pixlayer = getPixLayersID(m_pixelid->barrel_ec(rdoID), m_pixelid->layer_disk(rdoID) );
       if (pixlayer == 99) continue;
       HitMap.add(pixlayer, rdoID, m_pixelid, 1.0);
+      if (m_doFEPlots && !m_doOnline) HitFEMap.add(pixlayer, rdoID, m_pixelid, m_pixelCablingSvc->getFE(&rdoID, rdoID), 1.0);
       nhits++;
       nhits_layer[pixlayer]++;
       hitLvl1a.push_back( (*p_rdo)->getLVL1A() );
       hitLvl1aLayer[pixlayer].push_back( (*p_rdo)->getLVL1A() );
+      hitToTLayer[pixlayer].push_back( (*p_rdo)->getToT() );
       getPhiEtaMod(m_pixelid, rdoID, phiMod, etaMod, copyFEval);
       switch (pixlayer) {
       case PixLayers::kECA : 
@@ -185,6 +187,7 @@ StatusCode PixelAthHitMonAlg::fillHistograms( const EventContext& ctx ) const {
   }
 
   fill2DProfLayerAccum( HitMap );
+  if (m_doFEPlots && !m_doOnline) fill2DProfLayerAccum( HitFEMap );
 
   auto vals = Monitored::Collection( "Hit_LVL1A_pixel", hitLvl1a );
   fill( hitGroup, vals);
@@ -193,6 +196,11 @@ StatusCode PixelAthHitMonAlg::fillHistograms( const EventContext& ctx ) const {
     auto vals = Monitored::Collection( "Hit_LVL1A_layer", hitLvl1aLayer.at(layer) );
     fill( pixLayersLabel[layer], vals);
   }
+  for ( const auto& itr : hitToTLayer ) {
+    int layer = itr.first;
+    auto vals = Monitored::Collection( "HitToT_val", hitToTLayer.at(layer) );
+    fill( pixLayersLabel[layer], vals);
+  }
 
 
   auto nhitsval = Monitored::Scalar<int>( "nhits_per_event", nhits );
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthHitMonAlg.h b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthHitMonAlg.h
index 8e2fd5a7764cea68de910d08cd5bbb1476b42fc5..4e6f294fbc3bbaf29e27cd3e8e6d340d6e55ce1a 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthHitMonAlg.h
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthHitMonAlg.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef PIXELATHHITMONTOOL_H
@@ -8,13 +8,13 @@
 #include "PixelAthMonitoringBase.h"
 #include "InDetConditionsSummaryService/IInDetConditionsTool.h"
 //#include "InDetReadoutGeometry/SiDetectorElementCollection.h"
+#include "PixelCabling/IPixelCablingSvc.h"
 
 #include "InDetRawData/InDetRawDataCLASS_DEF.h"
 #include "InDetRawData/InDetRawDataContainer.h"
 #include "InDetRawData/InDetTimeCollection.h"
 
 class PixelID;
-class IPixelCablingSvc;
 class PixelRDORawData;
 
 class PixelAthHitMonAlg : public PixelAthMonitoringBase {
@@ -29,7 +29,7 @@ class PixelAthHitMonAlg : public PixelAthMonitoringBase {
 
  private:
 
-  ServiceHandle<IPixelCablingSvc> m_pixelCableSvc; //FE info
+  ServiceHandle<IPixelCablingSvc> m_pixelCablingSvc; //FE info
   ToolHandle<IInDetConditionsTool> m_pixelCondSummaryTool{this, "PixelConditionsSummaryTool", "PixelConditionsSummaryTool", "Tool to retrieve Pixel Conditions summary"};
 
   const PixelID* m_pixelid;
@@ -37,10 +37,10 @@ class PixelAthHitMonAlg : public PixelAthMonitoringBase {
   SG::ReadHandleKey<PixelRDO_Container> m_pixelRDOName{this, "RDOName", "PixelRDOs", "rdo data key"};
 
   bool m_doOnline;
-  bool m_doModules;
   bool m_doLumiBlock;
   bool m_doLowOccupancy;
   bool m_doHighOccupancy;
   bool m_doHeavyIonMon;
+  bool m_doFEPlots;
 };
 #endif
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthMonitoringBase.cxx b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthMonitoringBase.cxx
index 5bce360ba810c324390d0012117e806e2ad1f48d..6f510323aa81262c699d5e39a1b34c11fad5ff6f 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthMonitoringBase.cxx
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthMonitoringBase.cxx
@@ -7,7 +7,7 @@
 
 //////////////////////////////////////////////
 ///
-/// helper class to accumulate points to fill a 2D plot with
+/// helper class to accumulate points to fill a 2D per-module plot with
 ///
 void PixelAthMonitoringBase::VecAccumulator2DMap::add( const int layer, const Identifier& id,
 						  const PixelID* pid, float value ) {
@@ -44,6 +44,62 @@ void PixelAthMonitoringBase::VecAccumulator2DMap::add( const int layer, const Id
   }   
 }
 
+//////////////////////////////////////////////
+///
+/// helper class to accumulate points to fill a 2D per-FE plot with
+///
+void PixelAthMonitoringBase::VecAccumulator2DMap::add( const int layer, const Identifier& id,
+						       const PixelID* pid, int iFE, float value ) {
+
+  // value
+  m_val[layer].push_back(value);
+
+  // for old pixel see https://twiki.cern.ch/twiki/pub/Atlas/PixelCOOLoffline/pixel_modules_sketch.png
+  // 
+  // phi (Y) coordinate
+  if ( layer == PixLayers::kIBL || layer == PixLayers::kDBMC || layer == PixLayers::kDBMA )
+    m_pm[layer].push_back( pid->phi_module(id) );
+  else {
+    if ( (layer == PixLayers::kECA || layer == PixLayers::kECC) && ( pid->phi_module(id) % 2 == 0 ) ) {
+      // even disk modules
+      m_pm[layer].push_back( pid->phi_module(id)*2 + iFE/8 );
+    } else { 
+      m_pm[layer].push_back( pid->phi_module(id)*2 + 1 - iFE/8 );
+    }
+  }
+  // eta (X) coordinate
+  int ld = pid->layer_disk(id);
+  int em(0);
+  // endcaps/DBM
+  if ( layer == PixLayers::kDBMC || layer == PixLayers::kDBMA ) em = ld;
+  else {
+    em = ld * 8;
+    if (iFE<8) em+= ( 7 - iFE%8 ); 
+    else em+= iFE%8; 
+  } 
+  // barrel
+  //
+  if (pid->barrel_ec(id) == 0) { 
+    if (ld == 0) {  //ibl
+      em = pid->eta_module(id);
+      int emf;
+      if (em < -6) {
+	emf = em - 6;
+      } else if (em > -7 && em < 6) {
+	emf = 2 * em + iFE;
+      } else {
+	emf = em + 6;
+      }
+      em = emf;
+    } else {
+      em = pid->eta_module(id) * 8 - 4;
+      if (iFE<8) em+= ( 7 - iFE%8 );
+      else em+= iFE%8; 
+    }
+  } // end barrel
+  m_em[layer].push_back(em);
+}
+
 //////////////////////////////////////////////
 ///
 /// take VecAccumulator2DMap and fill the corresponding group
@@ -230,6 +286,20 @@ int PixelAthMonitoringBase::getPixLayersID(int ec, int ld) const {
 }
 //////////////////////////////////////////////
 
+///
+/// helper function to get number of FEs per module
+///
+int PixelAthMonitoringBase::getNumberOfFEs(int pixlayer, int etaMod) const {
+  int nFE(16);
+  if (pixlayer == PixLayers::kIBL || pixlayer == PixLayers::kDBMC || pixlayer == PixLayers::kDBMA) {
+    nFE = 1;
+    if (etaMod>-7 && etaMod<6) nFE = 2; //IBL Planar
+  } 
+  return nFE;
+}
+//////////////////////////////////////////////
+
+
 ///
 /// helper function to get eta phi coordinates of per-layer arrays
 ///
diff --git a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthMonitoringBase.h b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthMonitoringBase.h
index 11283f3c0a129c5c9a81b425949491c9ceedcf42..9ce1939caff92d9d00830f95f1e3d766468ca49c 100644
--- a/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthMonitoringBase.h
+++ b/InnerDetector/InDetMonitoring/PixelMonitoring/src/PixelAthMonitoringBase.h
@@ -45,6 +45,7 @@ class PixelAthMonitoringBase : public virtual AthMonitorAlgorithm {
   void fill2DProfLumiLayers( const std::string& prof2Dname, int lb, float (*weights)[PixLayers::COUNT], const int* nCategories ) const;
 
   int getPixLayersID(int ec, int ld) const;
+  int getNumberOfFEs(int pixlayer, int etaMod) const;
   void getPhiEtaMod(const PixelID* pid, Identifier& id, int& phiMod, int& etaMod, bool& copyFE) const;
   bool isHitOnTrack(Identifier id, std::vector<Identifier> const &RDOIDs) const;
   bool isClusterOnTrack(Identifier id, std::vector<std::pair<Identifier, double> > const &ClusterIDs) const;
@@ -64,6 +65,8 @@ class PixelAthMonitoringBase : public virtual AthMonitorAlgorithm {
     
     void add( const int layer, const Identifier& id,
 	      const PixelID* pid, float value=1.0 );
+    void add( const int layer, const Identifier& id,
+	      const PixelID* pid, int iFE, float value);
   };
   void fill2DProfLayerAccum( const VecAccumulator2DMap& accumulator ) const;
 
diff --git a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx
index 0409f5acca3962696bfa95a631f92e627ef54d42..95e28a0906eb6a45ee1816f875181e69cee9c7d6 100755
--- a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx
+++ b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx
@@ -113,8 +113,6 @@ StatusCode SiTrackerSpacePointFinder::initialize()
 
   if (!m_monTool.empty()) CHECK(m_monTool.retrieve());
 
-  ATH_MSG_INFO( "SiTrackerSpacePointFinder::initialized for package version " << PACKAGE_VERSION );
-  
   return StatusCode::SUCCESS;
 }
 
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/DivisiveMultiSeedFinder.h b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/DivisiveMultiSeedFinder.h
index fa5d4b163133258a3f8a9be98866743e205d51fd..7d11fb5e92aed41ac1db46604966b4d3b8c6a8bb 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/DivisiveMultiSeedFinder.h
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/DivisiveMultiSeedFinder.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef InDetMultipleVertexSeedFinder_DivisiveMultiSeedFinder_H
@@ -29,9 +29,7 @@ namespace InDet
  
   public:
    
-   StatusCode initialize();
- 
-   StatusCode finalize();
+   virtual StatusCode initialize() override;
 
 /**
  * Constructor and destructor
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/HistogrammingMultiSeedFinder.h b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/HistogrammingMultiSeedFinder.h
index 0f4a651e8a15395a11db8f974304a86d2c2f4580..2ccf1445c2f98f168126c0cc403a59541d5e18e4 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/HistogrammingMultiSeedFinder.h
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/HistogrammingMultiSeedFinder.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef InDetMultipleVertexSeedFinder_HistogrammingMultiSeedFinder_H
@@ -42,9 +42,7 @@ namespace InDet
  {
   public:
    
-   StatusCode initialize();
- 
-   StatusCode finalize();
+   virtual StatusCode initialize() override;
 
 /**
  * Constructor and destructor
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/SlidingWindowMultiSeedFinder.h b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/SlidingWindowMultiSeedFinder.h
index ce611cefbadfee492b9671c213a444318f3d2049..fbbf71e2a2343608e715312e69359f0788742d00 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/SlidingWindowMultiSeedFinder.h
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/InDetMultipleVertexSeedFinder/SlidingWindowMultiSeedFinder.h
@@ -29,9 +29,7 @@ namespace InDet
  {
   public:
   
-   StatusCode initialize();
- 
-   StatusCode finalize();
+   virtual StatusCode initialize() override;
 
 /**
  * Constructor and destructor
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/DivisiveMultiSeedFinder.cxx b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/DivisiveMultiSeedFinder.cxx
index eb229f8d590bc6bcee8367561b31ffcba9c7eb12..dbec9d17a39232f6136f555bf042caf3ad5f58bc 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/DivisiveMultiSeedFinder.cxx
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/DivisiveMultiSeedFinder.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "InDetMultipleVertexSeedFinder/DivisiveMultiSeedFinder.h"
@@ -60,12 +60,7 @@ namespace InDet
    
   return StatusCode::SUCCESS;
  }//end of initialize mtehod
- 
- StatusCode DivisiveMultiSeedFinder::finalize()
- {
-  msg(MSG::INFO)  << "Finalize successful" << endmsg;
-  return StatusCode::SUCCESS;
- }
+
  
  DivisiveMultiSeedFinder::DivisiveMultiSeedFinder(const std::string& t, const std::string& n, const
  IInterface*p):AthAlgTool(t,n,p), 
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/HistogrammingMultiSeedFinder.cxx b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/HistogrammingMultiSeedFinder.cxx
index e94910a76cb907d4044aac2a137fa70879869f57..fc7c3bd7441b62cae33a76829bce221efefc0ffd 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/HistogrammingMultiSeedFinder.cxx
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/HistogrammingMultiSeedFinder.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "InDetMultipleVertexSeedFinder/HistogrammingMultiSeedFinder.h"
@@ -51,12 +51,7 @@ namespace InDet
                 
   return StatusCode::SUCCESS;
  }//end of initialize mtehod
- 
- StatusCode HistogrammingMultiSeedFinder::finalize()
- {
-  msg(MSG::INFO)  << "Finalize successful" << endmsg;
-  return StatusCode::SUCCESS;
- }
+
 
  HistogrammingMultiSeedFinder::HistogrammingMultiSeedFinder(const std::string& t, const std::string& n, const IInterface*p):
          AthAlgTool(t,n,p), 
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/SlidingWindowMultiSeedFinder.cxx b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/SlidingWindowMultiSeedFinder.cxx
index a2e3114483555c5f2e61eef79c662f90798f33f8..20e5ecc6f9045d80abdeedfb2f31c96117e0a43d 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/SlidingWindowMultiSeedFinder.cxx
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinder/src/SlidingWindowMultiSeedFinder.cxx
@@ -55,12 +55,7 @@ namespace InDet
   return StatusCode::SUCCESS;
  }//end of initialize mtehod
  
- StatusCode SlidingWindowMultiSeedFinder::finalize()
- {
-  msg(MSG::INFO)  << "Finalize successful" << endmsg;
-  return StatusCode::SUCCESS;
- }
- 
+
  SlidingWindowMultiSeedFinder::SlidingWindowMultiSeedFinder(const std::string& t, const std::string& n, const
                                                             IInterface*p):AthAlgTool(t,n,p), 
                                                                           m_clusterLength(5.),
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/InDetMultipleVertexSeedFinderUtils/InDetTrackClusterCleaningTool.h b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/InDetMultipleVertexSeedFinderUtils/InDetTrackClusterCleaningTool.h
index a2dea76b6db801804c581a024a78dd0b7a0f9693..2ea663f5559a7d906cf39c57c616b18c5d5de802 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/InDetMultipleVertexSeedFinderUtils/InDetTrackClusterCleaningTool.h
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/InDetMultipleVertexSeedFinderUtils/InDetTrackClusterCleaningTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef InDetMultipleVertexSeedFinderUtils_InDetTrackClusterCleaningTool_H
@@ -40,11 +40,9 @@ namespace InDet
  {
   public:
    
-   StatusCode initialize();
+   virtual StatusCode initialize() override;
     
-   StatusCode finalize();
-  
-   InDetTrackClusterCleaningTool(const std::string& t, const std::string& n, const IInterface*  p); 
+   InDetTrackClusterCleaningTool(const std::string& t, const std::string& n, const IInterface*  p);
     
    static const InterfaceID& interfaceID() {return IID_InDetTrackClusterCleaningTool;}
  
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/InDetMultipleVertexSeedFinderUtils/InDetTrackZ0SortingTool.h b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/InDetMultipleVertexSeedFinderUtils/InDetTrackZ0SortingTool.h
index 7e95de1293c1ea8aeb760172abb4135e5d0dc1d4..beae551f65a3d3d29d5386499a28e1c1ccd9a712 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/InDetMultipleVertexSeedFinderUtils/InDetTrackZ0SortingTool.h
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/InDetMultipleVertexSeedFinderUtils/InDetTrackZ0SortingTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef InDetMultipleVertexSeedFinderUtils_InDetTrackZ0SortingTool_H
@@ -41,11 +41,9 @@ namespace InDet
  
   public:
    
-   StatusCode initialize();
+   virtual StatusCode initialize() override;
     
-   StatusCode finalize();
-  
-   InDetTrackZ0SortingTool(const std::string& t, const std::string& n, const IInterface*  p); 
+   InDetTrackZ0SortingTool(const std::string& t, const std::string& n, const IInterface*  p);
     
    static const InterfaceID& interfaceID() {return IID_InDetTrackZ0SortingTool;}
  
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/src/InDetTrackClusterCleaningTool.cxx b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/src/InDetTrackClusterCleaningTool.cxx
index e9ff208c4833ca03740a095493377f3977713f5b..45a8c646f6d5bfe68b10718bd88bbd8dce57fefa 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/src/InDetTrackClusterCleaningTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/src/InDetTrackClusterCleaningTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "InDetMultipleVertexSeedFinderUtils/InDetTrackClusterCleaningTool.h"
@@ -26,12 +26,7 @@ namespace InDet
   return StatusCode::SUCCESS;
  }//end of initialize method
     
- StatusCode InDetTrackClusterCleaningTool::finalize()
- {
-  msg(MSG::INFO)  << "Finalize successful" << endmsg;
-  return StatusCode::SUCCESS;
- }//end of finalize method
-  
+
  InDetTrackClusterCleaningTool::InDetTrackClusterCleaningTool(const std::string& t, const std::string& n, const IInterface*  p):
  AthAlgTool(t,n,p), m_extrapolator("Trk::Extrapolator") ,m_zOffset(3.)
  {
diff --git a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/src/InDetTrackZ0SortingTool.cxx b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/src/InDetTrackZ0SortingTool.cxx
index 286beb825edd626b4f3d196d93b13e44a28993fa..a6af97148efb922c2320cc16e4142b3fb56e1f2a 100644
--- a/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/src/InDetTrackZ0SortingTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetMultipleVertexSeedFinderUtils/src/InDetTrackZ0SortingTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "InDetMultipleVertexSeedFinderUtils/InDetTrackZ0SortingTool.h"
@@ -26,13 +26,6 @@ namespace InDet
  }//end of initialize method
     
 
- StatusCode InDetTrackZ0SortingTool::finalize()
- {
-  msg(MSG::INFO)  << "Finalize successful" << endmsg;
-  return StatusCode::SUCCESS;
- }//end of finalize method
-  
-
  InDetTrackZ0SortingTool::InDetTrackZ0SortingTool(const std::string& t, const std::string& n, const IInterface*  p):
  AthAlgTool(t,n,p), m_extrapolator("Trk::Extrapolator")
  {
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetImprovedJetFitterVxFinder.h b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetImprovedJetFitterVxFinder.h
index ecc984ff3cc74672a0e04ccbb3afaa66204c1e69..ed687a57f512d38b2e7f5cfff37e3b2b9fbce182 100755
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetImprovedJetFitterVxFinder.h
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetImprovedJetFitterVxFinder.h
@@ -65,8 +65,7 @@ namespace InDet {
   public:
     
 
-    StatusCode initialize();
-    StatusCode finalize();
+    virtual StatusCode initialize() override;
 
     InDetImprovedJetFitterVxFinder(const std::string& t, const std::string& n, const IInterface*  p);
 
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetJetFitterUtils.h b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetJetFitterUtils.h
index 5079e999341f034f4ac44bcb828ea57bf3ce5d48..451ccd0e3e639c72ad9e29ccde1ae509e63e8f3b 100644
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetJetFitterUtils.h
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetJetFitterUtils.h
@@ -62,8 +62,7 @@ namespace InDet {
     }
  
 
-    StatusCode initialize();
-    StatusCode finalize();
+    virtual StatusCode initialize() override;
 
     InDetJetFitterUtils(const std::string& t, const std::string& n, const IInterface*  p);
 
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetJetFitterVxFinder.h b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetJetFitterVxFinder.h
index c35aea272bb75610fe1f6438d0b95a8d34b9afef..13cd285d3563d02e6a5e86843399cf797ee36837 100755
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetJetFitterVxFinder.h
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/InDetJetFitterVxFinder.h
@@ -56,8 +56,7 @@ namespace InDet {
   public:
  
 
-    StatusCode initialize();
-    StatusCode finalize();
+    virtual StatusCode initialize() override;
 
     InDetJetFitterVxFinder(const std::string& t, const std::string& n, const IInterface*  p);
 
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/JetFitterMultiStageFit.h b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/JetFitterMultiStageFit.h
index f5308e779b83e947d7a5101b87053893359fe4e7..abca69872426df583b3cb22a19113e42ccd75500 100644
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/JetFitterMultiStageFit.h
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/JetFitterMultiStageFit.h
@@ -36,9 +36,7 @@ public:
         return IID_JetFitterMultiStageFit;
     }
 
-    StatusCode initialize();
-
-    StatusCode finalize();
+    virtual StatusCode initialize() override;
 
     JetFitterMultiStageFit(const std::string &t, const std::string &n, const IInterface *p);
 
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/JetFitterTrackSelectorTool.h b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/JetFitterTrackSelectorTool.h
index e8d4d1a1eaa101ecddb5c6554fe2f5740fdb1e29..7ab33e6a68e704985f9e22fc066a937ba1129d23 100644
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/JetFitterTrackSelectorTool.h
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/InDetSecVxFinderTool/JetFitterTrackSelectorTool.h
@@ -39,8 +39,7 @@ namespace InDet {
             return IID_JetFitterTrackSelectorTool;
         }
 
-        StatusCode initialize();
-        StatusCode finalize();
+        virtual StatusCode initialize() override;
 
         JetFitterTrackSelectorTool(const std::string &t, const std::string &n, const IInterface *p);
         ~JetFitterTrackSelectorTool();
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetImprovedJetFitterVxFinder.cxx b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetImprovedJetFitterVxFinder.cxx
index 6c1a49d750a893da03a28bfd11dc4c9326118dd9..94277862eb42bdfe77e7f3b08eb1151d62286cdb 100755
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetImprovedJetFitterVxFinder.cxx
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetImprovedJetFitterVxFinder.cxx
@@ -96,12 +96,6 @@ namespace InDet
 
   StatusCode InDetImprovedJetFitterVxFinder::initialize() {
     
-    StatusCode sc = AlgTool::initialize();
-    if(sc.isFailure()) {
-      msg(MSG::ERROR)<<" Unable to initialize the AlgTool"<<endmsg;
-      return sc;
-    }
-    
     if (m_theTrackSelector.retrieve().isFailure()) {
       msg(MSG::ERROR) << "Could not find TrackSelector tool." << endmsg;
       return StatusCode::FAILURE;
@@ -122,18 +116,10 @@ namespace InDet
       return StatusCode::FAILURE;
     } else msg(MSG::INFO) << " JetFitterMultiStageFit retrieved" << endmsg;
 
-    msg(MSG::INFO) << "Initialize successful" << endmsg;
     return StatusCode::SUCCESS;
   }
   
 
-   StatusCode InDetImprovedJetFitterVxFinder::finalize() {
-
-     msg(MSG::INFO)  << "Finalize successful" << endmsg;
-    return StatusCode::SUCCESS;
-
-  } 
-
   Trk::VxSecVertexInfo* InDetImprovedJetFitterVxFinder::findSecVertex(const xAOD::Vertex & primaryVertex,
 								      const TLorentzVector & jetMomentum,
 								      const std::vector<const xAOD::IParticle*> & inputTracks) const
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetJetFitterUtils.cxx b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetJetFitterUtils.cxx
index 8e0704beb5a2c1c08af6eac2141b08ef8b761e14..199f1d3c598dc26aa6d63f035da0a776ea0c9f21 100644
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetJetFitterUtils.cxx
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetJetFitterUtils.cxx
@@ -82,17 +82,9 @@ namespace InDet
 
   StatusCode InDetJetFitterUtils::initialize() {
     
-    
-    StatusCode sc = AlgTool::initialize();
-    if(sc.isFailure())
-      {
-	msg(MSG::ERROR) <<" Unable to initialize the AlgTool"<<endmsg;
-	return sc;
-      }
-
     if (!m_LinearizedTrackFactory.empty())
     {
-      sc=m_LinearizedTrackFactory.retrieve();
+      StatusCode sc=m_LinearizedTrackFactory.retrieve();
       if (sc.isFailure()) {
         msg(MSG::FATAL) << "Could not find TrackLinearizer tool." << endmsg;
         return StatusCode::FAILURE;
@@ -106,7 +98,7 @@ namespace InDet
     
     if (!m_extrapolator.empty())
     {
-      sc=m_extrapolator.retrieve();
+      StatusCode sc=m_extrapolator.retrieve();
       if (sc.isFailure()) {
         msg(MSG::FATAL) << "Could not find Extrapolator tool." << endmsg;
         return StatusCode::FAILURE;
@@ -117,18 +109,10 @@ namespace InDet
       }
     }
     
-    msg(MSG::INFO)  << "Initialize successful" << endmsg;
     return StatusCode::SUCCESS;
   }
   
 
-  StatusCode InDetJetFitterUtils::finalize() {
-    
-    msg(MSG::INFO)  << "Finalize successful" << endmsg;
-    return StatusCode::SUCCESS;
-    
-  } 
- 
   std::pair<AmgMatrix(3,3),AmgSymMatrix(3)>  InDetJetFitterUtils::getPosMomentumAndMomentumCovMatrix(const Trk::LinearizedTrack* linTrack,
 												   const AmgSymMatrix(3) & vrt_cov,
 												   const AmgSymMatrix(3) & vrt_weight) const
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetJetFitterVxFinder.cxx b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetJetFitterVxFinder.cxx
index d9c0440d058030846b819648752d4a84ebc79c8d..c6b4d29acbdd4b2ea6389041bdb2e91b4f2f35fc 100755
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetJetFitterVxFinder.cxx
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/InDetJetFitterVxFinder.cxx
@@ -71,52 +71,17 @@ namespace InDet
   
 
   StatusCode InDetJetFitterVxFinder::initialize() {
-    
-    
-    StatusCode sc = AthAlgTool::initialize();
-    if(sc.isFailure())
-      {
-	msg(MSG::ERROR) << " Unable to initialize the AlgTool" << endmsg;
-	return sc;
-      }
-    
+
     //retrieving the udator itself 	 
-    sc =  m_helper.retrieve();
-    if(sc.isFailure()) 	  { 	 
-      msg(MSG::ERROR) << " Unable to retrieve "<<m_helper<<endmsg; 	 
-      return StatusCode::FAILURE; 	 
-    }else msg(MSG::INFO) << "JetFitter Helper retrieved"<<endmsg; 
-    
-    
-    sc = m_initializationHelper.retrieve();
-    if(sc.isFailure()) 	  { 	 
-      msg(MSG::ERROR) << " Unable to retrieve "<<m_initializationHelper<<endmsg; 	 
-      return StatusCode::FAILURE; 	 
-    }else msg(MSG::INFO) << "JetFitter Initialization Helper retrieved"<<endmsg; 
-    
-    sc = m_routines.retrieve();
-    if(sc.isFailure()) 	  { 	 
-      msg(MSG::ERROR) << " Unable to retrieve the JetFitter routines"<<m_routines<<endmsg; 	 
-      return StatusCode::FAILURE; 	 
-    }else msg(MSG::INFO) << "JetFitter Routines class retrieved"<<endmsg; 
-
-    if(m_trkFilter.retrieve().isFailure()) {
-      msg(MSG::ERROR) << " Unable to retrieve "<<m_trkFilter<<endmsg;
-      return StatusCode::FAILURE;
-    } else msg(MSG::INFO) << "Track filter retrieved"<<endmsg; 
-    
-    msg(MSG::INFO) << "Initialize successful" << endmsg;
+    ATH_CHECK( m_helper.retrieve() );
+    ATH_CHECK( m_initializationHelper.retrieve() );
+    ATH_CHECK( m_routines.retrieve() );
+    ATH_CHECK( m_trkFilter.retrieve() );
+
     return StatusCode::SUCCESS;
   }
   
 
-   StatusCode InDetJetFitterVxFinder::finalize() {
-
-    msg(MSG::INFO) <<  "Finalize successful" << endmsg;
-    return StatusCode::SUCCESS;
-
-  } 
-
   const Trk::VxSecVertexInfo* InDetJetFitterVxFinder::findSecVertex(const Trk::RecVertex & primaryVertex,
 							      const TLorentzVector & jetMomentum,
 							      const std::vector<const Trk::TrackParticleBase*> & myTracks) const {
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/JetFitterMultiStageFit.cxx b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/JetFitterMultiStageFit.cxx
index 5a100fc739f8b185f0b454c013ed45a61dd4aa71..975ca8b0ec7b654d67fbf8b1d7bbf720b6388d01 100644
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/JetFitterMultiStageFit.cxx
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/JetFitterMultiStageFit.cxx
@@ -30,46 +30,14 @@ JetFitterMultiStageFit::~JetFitterMultiStageFit() {}
 
 StatusCode JetFitterMultiStageFit::initialize() {
 
-    StatusCode sc = AlgTool::initialize();
-    if (sc.isFailure()) {
-        msg(MSG::ERROR) << " Unable to initialize the AlgTool" << endmsg;
-        return sc;
-    }
-
-    sc =  m_helper.retrieve();
-    if(sc.isFailure()) 	  {
-        msg(MSG::ERROR) << " Unable to retrieve "<<m_helper<<endmsg;
-        return StatusCode::FAILURE;
-    }else msg(MSG::INFO) << "JetFitter Helper retrieved"<<endmsg;
-
-    sc = m_initializationHelper.retrieve();
-    if(sc.isFailure()) 	  {
-        msg(MSG::ERROR) << " Unable to retrieve "<<m_initializationHelper<<endmsg;
-        return StatusCode::FAILURE;
-    }else msg(MSG::INFO) << "JetFitter Initialization Helper retrieved"<<endmsg;
-
-    sc = m_routines.retrieve();
-    if(sc.isFailure())
-    {
-        msg(MSG::ERROR) << " Unable to retrieve the JetFitter routines"<<m_routines<<endmsg;
-        return StatusCode::FAILURE;
-    }
-    else msg(MSG::INFO) << "JetFitter Routines class retrieved"<<endmsg;
-
-    if (m_jetFitterUtils.retrieve().isFailure())
-    {
-        msg(MSG::ERROR) << "Could not find JetFitterUtils tool." << endmsg;
-        return StatusCode::FAILURE;
-    }
-    else msg(MSG::INFO) << " JetFitterUtils retrieved" << endmsg;
+    ATH_CHECK( m_helper.retrieve() );
+    ATH_CHECK( m_initializationHelper.retrieve() );
+    ATH_CHECK( m_routines.retrieve() );
+    ATH_CHECK( m_jetFitterUtils.retrieve() );
 
     return StatusCode::SUCCESS;
 }
 
-StatusCode JetFitterMultiStageFit::finalize() {
-    msg(MSG::INFO) << "Finalize successful" << endmsg;
-    return StatusCode::SUCCESS;
-}
 
 Trk::VxJetCandidate* JetFitterMultiStageFit::doTwoStageFit(const Trk::RecVertex & primaryVertex,
                                                         const TLorentzVector & jetMomentum,
diff --git a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/JetFitterTrackSelectorTool.cxx b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/JetFitterTrackSelectorTool.cxx
index 5625ed49e86f6ce89d7d1242e89016199bb9858e..6c122a0daa160d5626c135a68977a26f6a3e1263 100644
--- a/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/JetFitterTrackSelectorTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetSecVxFinderTool/src/JetFitterTrackSelectorTool.cxx
@@ -16,11 +16,6 @@ using namespace InDet;
 
     StatusCode JetFitterTrackSelectorTool::initialize() {
 
-        if ( AlgTool::initialize().isFailure() ) {
-            msg(MSG::ERROR) << " Unable to initialize the AlgTool" << endmsg;
-            return StatusCode::FAILURE;
-        }
-
 	if ( m_trkFilter.retrieve().isFailure() ) {
 	  msg(MSG::ERROR) << " Unable to retrieve InDet::InDetDetailedTrackSelectorTool" << endmsg;
 	  return StatusCode::FAILURE;
@@ -39,10 +34,6 @@ using namespace InDet;
         return StatusCode::SUCCESS;
     }
 
-    StatusCode JetFitterTrackSelectorTool::finalize() {
-        msg(MSG::INFO) << "Finalize successful" << endmsg;
-        return StatusCode::SUCCESS;
-    }
 
     const Trk::SelectedTracksInJet* JetFitterTrackSelectorTool::doTrackSelection( const xAOD::Vertex &primaryVertex,
 										  const TLorentzVector &jetMomentum,
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetCosmicTrackSelectorTool.h b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetCosmicTrackSelectorTool.h
index cca93adf1f110f164b432826d8d8cdb29de05fae..007d78cf7437a948f374de5cd211580a701ed37b 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetCosmicTrackSelectorTool.h
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetCosmicTrackSelectorTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef InDetTrackSelectorTool_InDetCosmicTrackSelectorTool_H
@@ -32,9 +32,7 @@ namespace InDet
 
   public:
 
-    StatusCode initialize();
-
-    StatusCode finalize();
+    virtual StatusCode initialize() override;
 
     InDetCosmicTrackSelectorTool(const std::string& t, const std::string& n, const IInterface*  p);
 
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetIsoTrackSelectorTool.h b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetIsoTrackSelectorTool.h
index b282fadd429777f8c51562d40018cbc639a25122..b121018457f559283025a69c2dca42abaeabef66 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetIsoTrackSelectorTool.h
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetIsoTrackSelectorTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef InDetIsoTrackSelectorTool_InDetIsoTrackSelectorTool_H
@@ -35,8 +35,7 @@ namespace InDet
 
     public:
       /** Athena AlgTool methods */
-      StatusCode initialize();
-      StatusCode finalize();
+      virtual StatusCode initialize() override;
 
       /** Constructor / Destructor */
       InDetIsoTrackSelectorTool(const std::string& t, const std::string& n, const IInterface*  p);
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetTrackSelectorTool.h b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetTrackSelectorTool.h
index 61e6889b7d20da524b90c7f60a7ea323e2bf1c8b..386090734df037bd17f149c6eec1dfa17b665f8b 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetTrackSelectorTool.h
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetTrackSelectorTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef InDetTrackSelectorTool_InDetTrackSelectorTool_H
@@ -44,9 +44,7 @@ namespace InDet
 
     public:
 
-      StatusCode initialize();
-
-      StatusCode finalize();
+      virtual StatusCode initialize() override;
 
       InDetTrackSelectorTool(const std::string& t, const std::string& n, const IInterface*  p);
 
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetTrtDriftCircleCutTool.h b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetTrtDriftCircleCutTool.h
index a81a1e9e2e5dbf21adf45435406f734f865f7dd6..e399c8e5fc548e6cd596cdd9338c5b8eeba16a77 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetTrtDriftCircleCutTool.h
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/InDetTrackSelectorTool/InDetTrtDriftCircleCutTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef InDetTrackSelectorTool_InDetTrtDriftCircleCutTool_H
@@ -26,11 +26,9 @@ namespace InDet{
       
     public:
   
-      StatusCode initialize();
+      virtual StatusCode initialize() override;
       
-      StatusCode finalize();
-      
-      InDetTrtDriftCircleCutTool(const std::string& t, const std::string& n, const IInterface*  p); 
+      InDetTrtDriftCircleCutTool(const std::string& t, const std::string& n, const IInterface*  p);
       
       ~InDetTrtDriftCircleCutTool();
       
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetCosmicTrackSelectorTool.cxx b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetCosmicTrackSelectorTool.cxx
index 4bc59141999383fdb055c0ba5693c7aa2cc4504e..4be1d24aa4ff7aca73485460b91f57ba95bdcb74 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetCosmicTrackSelectorTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetCosmicTrackSelectorTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "InDetTrackSelectorTool/InDetCosmicTrackSelectorTool.h"
@@ -45,11 +45,6 @@ namespace InDet
   //----------------------------------------------------------------------------
   StatusCode  InDetCosmicTrackSelectorTool::initialize()
   {
-    if(AthAlgTool::initialize().isFailure()) {
-      msg(MSG::ERROR)<<" Unable to initialize the AlgTool"<<endmsg;
-      return StatusCode::FAILURE;
-    }
-
      m_trackSumToolAvailable = false;
      if (!m_trackSumTool.empty()) {
        if(m_trackSumTool.retrieve().isFailure())
@@ -67,13 +62,6 @@ namespace InDet
      return StatusCode::SUCCESS;
   }
 
-  //----------------------------------------------------------------------------
-  StatusCode InDetCosmicTrackSelectorTool::finalize()
-  {
-    ATH_MSG_INFO("Finalize successful");
-    return StatusCode::SUCCESS;
-  }
-
   //----------------------------------------------------------------------------
   bool InDetCosmicTrackSelectorTool::decision(const Trk::Track & track, const Trk::Vertex * vertex) const
   {
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetIsoTrackSelectorTool.cxx b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetIsoTrackSelectorTool.cxx
index 41ca00683acdc83d87ceccfa97b3a4ea3082eab0..a89d0425286bb9d79839419b5537baf050a6a400 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetIsoTrackSelectorTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetIsoTrackSelectorTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "InDetTrackSelectorTool/InDetIsoTrackSelectorTool.h"
@@ -62,12 +62,6 @@ StatusCode InDet::InDetIsoTrackSelectorTool::initialize()
   return StatusCode::SUCCESS;
 }
 
-//_______________________________________________________________________________
-StatusCode InDet::InDetIsoTrackSelectorTool::finalize()
-{
-  ATH_MSG_INFO("Finalize successful");
-  return StatusCode::SUCCESS;
-}
 
 //_______________________________________________________________________________
 bool InDet::InDetIsoTrackSelectorTool::decision(const Trk::AtaStraightLine& atl, const Trk::Track& track) const
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetTrackSelectorTool.cxx b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetTrackSelectorTool.cxx
index 6e45d318c9503a963ec60e1e533ad10d36c4b7b5..9d54d1e48ea816050663774b57a3bb9e313ca8af 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetTrackSelectorTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetTrackSelectorTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "InDetTrackSelectorTool/InDetTrackSelectorTool.h"
@@ -51,12 +51,6 @@ InDetTrackSelectorTool::~InDetTrackSelectorTool()
 //_______________________________________________________________________________
 StatusCode InDetTrackSelectorTool::initialize()
 {
-  StatusCode sc = AthAlgTool::initialize();
-  if(sc.isFailure()) {
-    msg(MSG::ERROR)<<" Unable to initialize the AlgTool"<<endmsg;
-    return StatusCode::FAILURE;
-  }
-
   m_trackSumToolAvailable = false;
   if (!m_trackSumTool.empty())
   {
@@ -79,12 +73,6 @@ StatusCode InDetTrackSelectorTool::initialize()
   return StatusCode::SUCCESS;
 }
 
-//_______________________________________________________________________________
-StatusCode InDetTrackSelectorTool::finalize()
-{
-  ATH_MSG_INFO("Finalize successful");
-  return StatusCode::SUCCESS;
-}
 
 //_______________________________________________________________________________
 bool InDetTrackSelectorTool::decision(const Trk::Track & track, const Trk::Vertex * vertex) const
diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetTrtDriftCircleCutTool.cxx b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetTrtDriftCircleCutTool.cxx
index d46a2587db7dcda0eec247e2f059ff127582a73f..0df692d48f84379598c6c5cfa8f6ecab085c876e 100644
--- a/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetTrtDriftCircleCutTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetTrackSelectorTool/src/InDetTrtDriftCircleCutTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "InDetTrackSelectorTool/InDetTrtDriftCircleCutTool.h"
@@ -7,26 +7,12 @@
 
 StatusCode  InDet::InDetTrtDriftCircleCutTool::initialize()
 {
-  StatusCode sc = AthAlgTool::initialize();
-
-
-  if(sc.isFailure()){
-    msg(MSG::ERROR)<<" Unable to initialize the AlgTool"<<endmsg;
-    return StatusCode::FAILURE;
-  }
-
-    // Read key
-   ATH_CHECK( m_strawReadKey.initialize() );
+  // Read key
+  ATH_CHECK( m_strawReadKey.initialize() );
  
   return StatusCode::SUCCESS;
 }
     
-StatusCode InDet::InDetTrtDriftCircleCutTool::finalize()
-{
-  msg(MSG::INFO)  << "Finalize successful" << endmsg;
-  return StatusCode::SUCCESS;
-}
-    
 InDet::InDetTrtDriftCircleCutTool::InDetTrtDriftCircleCutTool(const std::string& t, const std::string& n, const IInterface*  p)
   :AthAlgTool(t,n,p),
    m_minOffset(0),
diff --git a/InnerDetector/InDetRecTools/InDetTrackSummaryHelperTool/InDetTrackSummaryHelperTool/InDetTrackSummaryHelperTool.h b/InnerDetector/InDetRecTools/InDetTrackSummaryHelperTool/InDetTrackSummaryHelperTool/InDetTrackSummaryHelperTool.h
index 5d44f38c256e00de31e589a3f5ac63eb58e247ac..1309b85481c25d43f244ad98a8fd1237409a5ab2 100755
--- a/InnerDetector/InDetRecTools/InDetTrackSummaryHelperTool/InDetTrackSummaryHelperTool/InDetTrackSummaryHelperTool.h
+++ b/InnerDetector/InDetRecTools/InDetTrackSummaryHelperTool/InDetTrackSummaryHelperTool/InDetTrackSummaryHelperTool.h
@@ -58,6 +58,8 @@ namespace InDet {
         Input quantities rot, tsos are used to increment the counts for hits and outliers in information and to set the proper bits in hitPattern.
     */
     using IExtendedTrackSummaryHelperTool::analyse;
+    using IExtendedTrackSummaryHelperTool::addDetailedTrackSummary;
+
     virtual void analyse(
       const EventContext& ctx,
       const Trk::Track& track,
@@ -74,49 +76,34 @@ namespace InDet {
       const Trk::CompetingRIOsOnTrack* crot,
       const Trk::TrackStateOnSurface* tsos,
       std::vector<int>& information,
-      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override final;
+      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override final ;
+    /** @copydoc Trk::ITrackSummaryHelperTool::addDetailedTrackSummary(const
+     * Trk::Track&, Trk::TrackSummary&)*/
 
-    virtual void analyse(
-      const Trk::Track& track,
-      const Trk::RIO_OnTrack* rot,
-      const Trk::TrackStateOnSurface* tsos,
-      std::vector<int>& information,
-      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override
-    {
-      analyse(track, nullptr, rot, tsos, information, hitPattern);
-    }
-
-    virtual void analyse(
-      const Trk::Track& track,
-      const Trk::CompetingRIOsOnTrack* crot,
-      const Trk::TrackStateOnSurface* tsos,
-      std::vector<int>& information,
-      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override
-    {
-      analyse(track, nullptr, crot, tsos, information, hitPattern);
-    }
+    virtual void addDetailedTrackSummary(const EventContext& ctx,
+                                         const Trk::Track&,
+                                         Trk::TrackSummary&) const override final;
 
     /** Input : track, partHyp
         Output: Changes in information
-        This method first calls the method getListOfHits to isolate the relevant hits on the track before calling the method
-        performHoleSearchStepWise which then performs the actual hole search.
-        Additionally the Layers of the Pixel Detector which contribute measurements to the track are counted  
-        If problems occur, the information counters for Holes and PixelLayers are reset to -1 flagging them as not set.
+        This method first calls the method getListOfHits to isolate the relevant
+       hits on the track before calling the method performHoleSearchStepWise
+       which then performs the actual hole search. Additionally the Layers of
+       the Pixel Detector which contribute measurements to the track are counted
+        If problems occur, the information counters for Holes and PixelLayers
+       are reset to -1 flagging them as not set.
     */
-    virtual void searchForHoles(const Trk::Track& track, 
-                        std::vector<int>& information ,
-                        const Trk::ParticleHypothesis partHyp = Trk::pion) const override;
-
-    /** this method simply updaes the shared hit content - it is designed/optimised for track collection merging */
-    virtual void updateSharedHitCount(const Trk::Track& track,
-                                      const Trk::PRDtoTrackMap *prd_to_track_map,
-                                      Trk::TrackSummary& summary) const override;
-
-    /** this method simply updaes the shared hit content - it is designed/optimised for track collection merging */
-    virtual void updateSharedHitCount(const Trk::Track& track,
-                                      Trk::TrackSummary& summary) const override {
-      updateSharedHitCount(track,nullptr,summary);
-    }
+    virtual void searchForHoles(
+      const Trk::Track& track,
+      std::vector<int>& information,
+      const Trk::ParticleHypothesis partHyp = Trk::pion) const override final;
+
+    /** this method simply updaes the shared hit content - it is
+     * designed/optimised for track collection merging */
+    virtual void updateSharedHitCount(
+      const Trk::Track& track,
+      const Trk::PRDtoTrackMap* prd_to_track_map,
+      Trk::TrackSummary& summary) const override final;
 
     /** this method simply updaes the electron PID content - it is
      * designed/optimised for track collection merging */
@@ -124,14 +111,12 @@ namespace InDet {
                                       std::vector<float>& eprob,
                                       float& dedx,
                                       int& nclus,
-                                      int& noverflowclus) const override;
-    /** This method updates the expect... hit info*/
-    virtual void updateExpectedHitInfo(const Trk::Track& track, Trk::TrackSummary& summary) const override;
-
-    /** @copydoc Trk::ITrackSummaryHelperTool::addDetailedTrackSummary(const Trk::Track&, Trk::TrackSummary&)*/
-
-    virtual void addDetailedTrackSummary(const Trk::Track&, Trk::TrackSummary&) const override;
+                                      int& noverflowclus) const override final;
 
+    /** This method updates the expect... hit info*/
+    virtual void updateExpectedHitInfo(
+      const Trk::Track& track,
+      Trk::TrackSummary& summary) const override final;
 
   private:
     const Trk::ClusterSplitProbabilityContainer::ProbabilityInfo&
diff --git a/InnerDetector/InDetRecTools/InDetTrackSummaryHelperTool/src/InDetTrackSummaryHelperTool.cxx b/InnerDetector/InDetRecTools/InDetTrackSummaryHelperTool/src/InDetTrackSummaryHelperTool.cxx
index e9482a0348b14f289dc948ee2e4495f662ed735a..5e2967a1bb7b1799565691a3de470b10f543bc36 100755
--- a/InnerDetector/InDetRecTools/InDetTrackSummaryHelperTool/src/InDetTrackSummaryHelperTool.cxx
+++ b/InnerDetector/InDetRecTools/InDetTrackSummaryHelperTool/src/InDetTrackSummaryHelperTool.cxx
@@ -395,8 +395,13 @@ void InDet::InDetTrackSummaryHelperTool::updateSharedHitCount(const Trk::Track &
               if (pixPrd and splitProb.isSplit()) {
                 summary.m_information[Trk::numberOfPixelSplitHits]++;
                 hitIsSplit=true;
-                if ( m_pixelId->is_barrel(id) and m_pixelId->layer_disk(id)==0) summary.m_information[Trk::numberOfInnermostLayerSplitHits]++;
-                if ( m_pixelId->is_barrel(id) and m_pixelId->layer_disk(id)==1) summary.m_information[Trk::numberOfNextToInnermostLayerSplitHits]++;
+                if (m_pixelId->is_barrel(id) and m_pixelId->layer_disk(id) == 0){
+                  summary.m_information[Trk::numberOfInnermostLayerSplitHits]++;
+                }
+                if (m_pixelId->is_barrel(id) and m_pixelId->layer_disk(id) == 1){
+                  summary.m_information
+                    [Trk::numberOfNextToInnermostLayerSplitHits]++;
+                }
               }
             }
           }
@@ -434,7 +439,11 @@ void InDet::InDetTrackSummaryHelperTool::updateSharedHitCount(const Trk::Track &
   return;
 }
 
-void  InDet::InDetTrackSummaryHelperTool::updateExpectedHitInfo(const Trk::Track &track, Trk::TrackSummary& summary) const{
+void
+InDet::InDetTrackSummaryHelperTool::updateExpectedHitInfo(
+  const Trk::Track& track,
+  Trk::TrackSummary& summary) const
+{
 
   if (m_usePixel and not m_testBLayerTool.empty() ) {
 
@@ -475,9 +484,14 @@ void  InDet::InDetTrackSummaryHelperTool::updateExpectedHitInfo(const Trk::Track
   return;
 }
 
-
-void InDet::InDetTrackSummaryHelperTool::updateAdditionalInfo(Trk::TrackSummary& summary, std::vector<float>& eprob,
-                                                              float& dedx, int& nclus, int& noverflowclus) const {
+void
+InDet::InDetTrackSummaryHelperTool::updateAdditionalInfo(
+  Trk::TrackSummary& summary,
+  std::vector<float>& eprob,
+  float& dedx,
+  int& nclus,
+  int& noverflowclus) const
+{
   summary.m_eProbability = eprob;
   summary.m_dedx = dedx;
   summary.m_nhitsdedx =  nclus;
@@ -486,34 +500,49 @@ void InDet::InDetTrackSummaryHelperTool::updateAdditionalInfo(Trk::TrackSummary&
   return;
 }
 
-void  InDet::InDetTrackSummaryHelperTool::addDetailedTrackSummary(const Trk::Track& track, Trk::TrackSummary& summary) const {
+void
+InDet::InDetTrackSummaryHelperTool::addDetailedTrackSummary(
+  const EventContext& ctx,
+  const Trk::Track& track,
+  Trk::TrackSummary& summary) const
+{
   if (summary.m_indetTrackSummary and not m_overwriteidsummary) {
-    ATH_MSG_DEBUG("TrackSummary already has detailed indet track summary, not adding a new one");
+    ATH_MSG_DEBUG("TrackSummary already has detailed indet track summary, not "
+                  "adding a new one");
     return;
   }
   if (not m_usePixel) {
-    ATH_MSG_DEBUG("Pixels are off, so no need for an detailed indet track summary");
+    ATH_MSG_DEBUG(
+      "Pixels are off, so no need for an detailed indet track summary");
     return;
   }
   ATH_MSG_DEBUG("Adding detailed indet track summary");
   delete summary.m_indetTrackSummary;
   Trk::InDetTrackSummary* indetTrackSummary = new Trk::InDetTrackSummary();
-  Trk::InDetTrackSummary& trackSummary      = *indetTrackSummary;
-  if (m_usePixel and not m_pixeldedxtool.empty() and (track.perigeeParameters() or not track.trackParameters()->empty())) {
+  Trk::InDetTrackSummary& trackSummary = *indetTrackSummary;
+  if (m_usePixel and not m_pixeldedxtool.empty() and
+      (track.perigeeParameters() or not track.trackParameters()->empty())) {
     const Trk::TrackParameters* par = track.perigeeParameters();
-    if (par==nullptr) par = *track.trackParameters()->begin();
-    double p      = (par->parameters()[Trk::qOverP]!=0) ? 1./par->parameters()[Trk::qOverP] : 1.e15;
-    double dedx   = summary.getPixeldEdx();
+
+    if (par == nullptr){
+      par = *track.trackParameters()->begin();
+    }
+    double p = (par->parameters()[Trk::qOverP] != 0)
+                 ? 1. / par->parameters()[Trk::qOverP]
+                 : 1.e15;
+    double dedx = summary.getPixeldEdx();
     int ngoodhits = summary.numberOfUsedHitsdEdx();
-    if (ngoodhits>0 and dedx>0 and track.info().trackFitter()!=Trk::TrackInfo::Unknown and p<1.e15) {
-      trackSummary.m_likelihoodspixeldedx = m_pixeldedxtool->getLikelihoods(dedx, p, ngoodhits);
-      trackSummary.m_massdedx             = m_pixeldedxtool->getMass(dedx, p, ngoodhits);
+    if (ngoodhits > 0 and dedx > 0 and
+        track.info().trackFitter() != Trk::TrackInfo::Unknown and p < 1.e15) {
+      trackSummary.m_likelihoodspixeldedx =
+        m_pixeldedxtool->getLikelihoods(ctx, dedx, p, ngoodhits);
+      trackSummary.m_massdedx =
+        m_pixeldedxtool->getMass(ctx, dedx, p, ngoodhits);
     }
   }
   summary.m_indetTrackSummary = indetTrackSummary;
 }
 
-// ====================================================================================================================
 
 StatusCode InDet::InDetTrackSummaryHelperTool::finalize() {
   return StatusCode::SUCCESS;
diff --git a/InnerDetector/InDetRecTools/SiClusterizationTool/src/ClusterMakerTool.cxx b/InnerDetector/InDetRecTools/SiClusterizationTool/src/ClusterMakerTool.cxx
index 8b3d9b2588351098284025f3f2cc908ed6e54c9b..5d5841a7b8ce57d947785c86ce9f70f12bb7bd42 100644
--- a/InnerDetector/InDetRecTools/SiClusterizationTool/src/ClusterMakerTool.cxx
+++ b/InnerDetector/InDetRecTools/SiClusterizationTool/src/ClusterMakerTool.cxx
@@ -55,7 +55,7 @@ ClusterMakerTool::ClusterMakerTool(const std::string& t,
 StatusCode  ClusterMakerTool::initialize(){
   // Code entered here will be executed once at program start.
 
-   ATH_MSG_INFO ( name() << " initialize()" );
+   ATH_MSG_DEBUG ( name() << " initialize()" );
 
    if (not m_pixelCabling.empty()) {
      ATH_CHECK(m_pixelCabling.retrieve());
diff --git a/InnerDetector/InDetRecTools/TRT_ElectronPidTools/src/TRT_ToT_dEdx.cxx b/InnerDetector/InDetRecTools/TRT_ElectronPidTools/src/TRT_ToT_dEdx.cxx
index bb619ec0e06d949322377452a00f7aaa440c7b21..f1ec7ba6a49ee0dc4bd564dbf33d307e4e5b7f48 100644
--- a/InnerDetector/InDetRecTools/TRT_ElectronPidTools/src/TRT_ToT_dEdx.cxx
+++ b/InnerDetector/InDetRecTools/TRT_ElectronPidTools/src/TRT_ToT_dEdx.cxx
@@ -280,7 +280,7 @@ TRT_ToT_dEdx::dEdx(const EventContext& ctx,
 
     ToTsum = std::accumulate(vecToT.begin(), vecToT.end(), 0);
     if (m_correctionType == kTrackBased) {
-      correctionFactor=trackOccupancyCorrection(track, useHitsHT);
+      correctionFactor=trackOccupancyCorrection(ctx,track, useHitsHT);
     } else {
       correctionFactor=correctNormalization(ctx,nVtx);
     }
@@ -383,7 +383,7 @@ TRT_ToT_dEdx::dEdx(const EventContext& ctx,
     double ToTsum = ToTsumXe*nhitsXe + ToTsumAr*nhitsAr + ToTsumKr*nhitsKr;
 
 	  if (m_correctionType == kTrackBased) {
-      correctionFactor = trackOccupancyCorrection(track, useHitsHT);
+      correctionFactor = trackOccupancyCorrection(ctx,track, useHitsHT);
     } else {
       correctionFactor = correctNormalization(ctx,nVtx);
     }
@@ -846,34 +846,52 @@ TRT_ToT_dEdx::correctToT_corrRZ(const EventContext& ctx,
       valToT = fitFuncEndcap_corrRZL(ctx,gasType, hitRtrack, hitPosR, Layer, hitZ>0?1:(hitZ<0?-1:0));
   }else{
     if (abs(hitPart)==1) // Barrel
-      valToT = fitFuncBarrel_corrRZ(gasType, hitRtrack, hitZ, Layer, StrawLayer);
+      valToT = fitFuncBarrel_corrRZ(ctx,gasType, hitRtrack, hitZ, Layer, StrawLayer);
     else // End-cap
-      valToT = fitFuncEndcap_corrRZ(gasType, hitRtrack, hitPosR, Layer, hitZ>0?1:(hitZ<0?-1:0));
+      valToT = fitFuncEndcap_corrRZ(ctx,gasType, hitRtrack, hitPosR, Layer, hitZ>0?1:(hitZ<0?-1:0));
   }
   if (std::isinf(valToT)) return 0.;
   if (valToT!=0) return ToTmip*timeOverThreshold/valToT;
   return 0.;
 }
 
-double TRT_ToT_dEdx::fitFuncBarrel_corrRZ(EGasType gasType, double driftRadius,double zPosition, int Layer, int StrawLayer) const
+double
+TRT_ToT_dEdx::fitFuncBarrel_corrRZ(const EventContext& ctx,
+                                   EGasType gasType,
+                                   double driftRadius,
+                                   double zPosition,
+                                   int Layer,
+                                   int StrawLayer) const
 {
   if (Layer == 0 && StrawLayer < 9) {
-    return fitFuncBarrelShort_corrRZ(gasType, driftRadius, zPosition, StrawLayer);
+    return fitFuncBarrelShort_corrRZ(ctx,gasType, driftRadius, zPosition, StrawLayer);
   }
-  return fitFuncBarrelLong_corrRZ(gasType, driftRadius, zPosition, Layer, StrawLayer);
+  return fitFuncBarrelLong_corrRZ(ctx,gasType, driftRadius, zPosition, Layer, StrawLayer);
 }
 
-double TRT_ToT_dEdx::fitFuncEndcap_corrRZ(EGasType gasType, double driftRadius,double radialPosition, int Layer, int sign) const
+double
+TRT_ToT_dEdx::fitFuncEndcap_corrRZ(const EventContext& ctx,
+                                   EGasType gasType,
+                                   double driftRadius,
+                                   double radialPosition,
+                                   int Layer,
+                                   int sign) const
 {
   /**
    * T(r,R) = T0(r)+ a(r)*R
    */
-  double T0 =  fitFuncPol_corrRZ(gasType, 0,driftRadius,Layer,0,sign,2);
-  double a  =  fitFuncPol_corrRZ(gasType, 1,driftRadius,Layer,0,sign,2);
+  double T0 =  fitFuncPol_corrRZ(ctx,gasType, 0,driftRadius,Layer,0,sign,2);
+  double a  =  fitFuncPol_corrRZ(ctx,gasType, 1,driftRadius,Layer,0,sign,2);
   return T0+a*radialPosition;
 }
 
-double TRT_ToT_dEdx::fitFuncBarrelLong_corrRZ(EGasType gasType, double driftRadius,double zPosition, int Layer, int StrawLayer) const
+double
+TRT_ToT_dEdx::fitFuncBarrelLong_corrRZ(const EventContext& ctx,
+                                       EGasType gasType,
+                                       double driftRadius,
+                                       double zPosition,
+                                       int Layer,
+                                       int StrawLayer) const
 {
   /**
    *                   |z|       /|z| - l  \
@@ -885,9 +903,9 @@ double TRT_ToT_dEdx::fitFuncBarrelLong_corrRZ(EGasType gasType, double driftRadi
   if(zPosition<0)sign=-1;
   double l = 704.6;
   // define set of parameters for negative and positive z positions
-  double T0 =  fitFuncPol_corrRZ(gasType, 0,driftRadius,Layer,StrawLayer,sign,0);
-  double  v =  fitFuncPol_corrRZ(gasType, 1,driftRadius,Layer,StrawLayer,sign,0);
-  double  s =  fitFuncPol_corrRZ(gasType, 2,driftRadius,Layer,StrawLayer,sign,0);
+  double T0 =  fitFuncPol_corrRZ(ctx,gasType, 0,driftRadius,Layer,StrawLayer,sign,0);
+  double  v =  fitFuncPol_corrRZ(ctx,gasType, 1,driftRadius,Layer,StrawLayer,sign,0);
+  double  s =  fitFuncPol_corrRZ(ctx,gasType, 2,driftRadius,Layer,StrawLayer,sign,0);
   //_in theory_ For IEEE-compatible type double, argument causes exp to overflow if outside [-708.4, 709.8]
   //however, overflow still seen when argument is 702; so I restrict these to -600, 600
   const double expArg=(z-l)/s;
@@ -897,7 +915,12 @@ double TRT_ToT_dEdx::fitFuncBarrelLong_corrRZ(EGasType gasType, double driftRadi
   return T0+(z/v)*std::exp(expArg);
 }
 
-double TRT_ToT_dEdx::fitFuncBarrelShort_corrRZ(EGasType gasType, double driftRadius,double zPosition, int StrawLayer) const
+double
+TRT_ToT_dEdx::fitFuncBarrelShort_corrRZ(const EventContext& ctx,
+                                        EGasType gasType,
+                                        double driftRadius,
+                                        double zPosition,
+                                        int StrawLayer) const
 {
   /**
    *  T(r,z) = T0(r)+ b(r)*|z|
@@ -905,15 +928,22 @@ double TRT_ToT_dEdx::fitFuncBarrelShort_corrRZ(EGasType gasType, double driftRad
   double z = std::abs(zPosition);
   int sign=1;
   if(zPosition<0)sign=-1;
-  double T0 = fitFuncPol_corrRZ(gasType, 0,driftRadius,0,StrawLayer,sign,1);
-  double b  = fitFuncPol_corrRZ(gasType, 1,driftRadius,0,StrawLayer,sign,1);
+  double T0 = fitFuncPol_corrRZ(ctx,gasType, 0,driftRadius,0,StrawLayer,sign,1);
+  double b  = fitFuncPol_corrRZ(ctx,gasType, 1,driftRadius,0,StrawLayer,sign,1);
   return T0+b*z;
 }
 
-
-double TRT_ToT_dEdx::fitFuncPol_corrRZ(EGasType gasType, int parameter, double driftRadius, int Layer, int Strawlayer, int sign, int set) const
+double
+TRT_ToT_dEdx::fitFuncPol_corrRZ(const EventContext& ctx,
+                                EGasType gasType,
+                                int parameter,
+                                double driftRadius,
+                                int Layer,
+                                int Strawlayer,
+                                int sign,
+                                int set) const
 {
-  SG::ReadCondHandle<TRTDedxcorrection> readHandle{m_ReadKey};
+  SG::ReadCondHandle<TRTDedxcorrection> readHandle{m_ReadKey,ctx};
   const TRTDedxcorrection* dEdxCorrection{*readHandle};
   if(dEdxCorrection==nullptr)
     {
@@ -1191,9 +1221,12 @@ TRT_ToT_dEdx::hitOccupancyCorrection(const EventContext& ctx,
   return ToTmip*valToT;
 }
 
-double TRT_ToT_dEdx::trackOccupancyCorrection(const Trk::Track* track,  bool useHitsHT) const
+double
+TRT_ToT_dEdx::trackOccupancyCorrection(const EventContext& ctx,
+                                       const Trk::Track* track,
+                                       bool useHitsHT) const
 {
-  SG::ReadCondHandle<TRTDedxcorrection> readHandle{m_ReadKey};
+  SG::ReadCondHandle<TRTDedxcorrection> readHandle{m_ReadKey,ctx};
   const TRTDedxcorrection* dEdxCorrection{*readHandle};
 
   double corr=-999.;
diff --git a/InnerDetector/InDetRecTools/TRT_ElectronPidTools/src/TRT_ToT_dEdx.h b/InnerDetector/InDetRecTools/TRT_ElectronPidTools/src/TRT_ToT_dEdx.h
index 77c748e216d6ea3de7d791cd1c9d220937f952f0..45aea009de0dc164393d657352b208359310d1ba 100644
--- a/InnerDetector/InDetRecTools/TRT_ElectronPidTools/src/TRT_ToT_dEdx.h
+++ b/InnerDetector/InDetRecTools/TRT_ElectronPidTools/src/TRT_ToT_dEdx.h
@@ -260,7 +260,12 @@ private:
    * @param bool variable to specify whether data or MC correction
    * @return correction
    */
-  double fitFuncEndcap_corrRZ(EGasType gas, double driftRadius, double rPosition, int Layer, int sign) const;
+  double fitFuncEndcap_corrRZ(const EventContext& ctx,
+                              EGasType gas,
+                              double driftRadius,
+                              double rPosition,
+                              int Layer,
+                              int sign) const;
   /**
    * @brief function to compute correction factor in barrel region
    * @param driftradius
@@ -270,22 +275,43 @@ private:
    * @param bool variable to specify whether data or MC correction
    * @return correction
    */
-  double fitFuncBarrel_corrRZ(EGasType gas, double driftRadius,double zPosition,int Layer, int StrawLayer) const;
+  double fitFuncBarrel_corrRZ(const EventContext& ctx,
+                              EGasType gas,
+                              double driftRadius,
+                              double zPosition,
+                              int Layer,
+                              int StrawLayer) const;
 
   /**
    * @brief function called by fitFuncBarrel_corrRZ for long straws
    */
-  double fitFuncBarrelLong_corrRZ(EGasType gasType, double driftRadius,double zPosition,int Layer, int StrawLayer) const;
+  double fitFuncBarrelLong_corrRZ(const EventContext& ctx,
+                                  EGasType gasType,
+                                  double driftRadius,
+                                  double zPosition,
+                                  int Layer,
+                                  int StrawLayer) const;
 
   /**
    * @brief function called by fitFuncBarrel_corrRZ for short straws
    */
-  double fitFuncBarrelShort_corrRZ(EGasType gasType, double driftRadius,double zPosition, int StrawLayer) const;
+  double fitFuncBarrelShort_corrRZ(const EventContext& ctx,
+                                   EGasType gasType,
+                                   double driftRadius,
+                                   double zPosition,
+                                   int StrawLayer) const;
 
   /**
    * @brief function called by fitFuncBarrel_corrRZ and fitFuncEndcap_corrRZ
    */
-  double fitFuncPol_corrRZ(EGasType gasType, int parameter, double driftRadius, int Layer, int Strawlayer, int sign, int set) const;
+  double fitFuncPol_corrRZ(const EventContext& ctx,
+                           EGasType gasType,
+                           int parameter,
+                           double driftRadius,
+                           int Layer,
+                           int Strawlayer,
+                           int sign,
+                           int set) const;
 
   /**
    * @brief function to compute correction factor in endcap region
@@ -323,7 +349,8 @@ private:
   /* Calibration functions for occupancy corrections */
   double hitOccupancyCorrection(const EventContext& ctx,
                                 const Trk::TrackStateOnSurface* itr) const;
-  double trackOccupancyCorrection(const Trk::Track* track,
+  double trackOccupancyCorrection(const EventContext& ctx,
+                                  const Trk::Track* track,
                                   bool useHThits) const;
 
 public:
diff --git a/LArCalorimeter/LArCafJobs/share/skeleton.LArNoise_fromraw.py b/LArCalorimeter/LArCafJobs/share/skeleton.LArNoise_fromraw.py
index 6ed2b834009b25b3fe73064c08c6ded38454f538..360b07a9a47bc51712c100d67af7d9a704e814ac 100644
--- a/LArCalorimeter/LArCafJobs/share/skeleton.LArNoise_fromraw.py
+++ b/LArCalorimeter/LArCafJobs/share/skeleton.LArNoise_fromraw.py
@@ -217,10 +217,8 @@ if hasattr(runArgs,"outputNTUP_LARNOISEFile") or hasattr(runArgs,"outputNTUP_HEC
    from TriggerJobOpts.TriggerFlags import TriggerFlags as tf
    tf.readBS.set_Value_and_Lock(True)
    tf.doLVL1.set_Value_and_Lock(False)
-   tf.doLVL2.set_Value_and_Lock(False)
-   tf.doEF.set_Value_and_Lock(False)
+   tf.doHLT.set_Value_and_Lock(False)
    tf.doL1Topo.set_Value_and_Lock(False)
-   tf.readLVL1Calo.set_Value_and_Lock(True)
    tf.enableMonitoring.set_Value_and_Lock(False)
    tf.doID.set_Value_and_Lock(False)
    tf.doMuon.set_Value_and_Lock(False)
diff --git a/LArCalorimeter/LArCnv/LArByteStream/LArByteStream/LArRawDataContByteStreamTool.h b/LArCalorimeter/LArCnv/LArByteStream/LArByteStream/LArRawDataContByteStreamTool.h
index e8a6bc1643c1f59f2136900e0461a597cbb1d505..4a417c9e83ec443607a43809f5364a58a049025c 100644
--- a/LArCalorimeter/LArCnv/LArByteStream/LArByteStream/LArRawDataContByteStreamTool.h
+++ b/LArCalorimeter/LArCnv/LArByteStream/LArByteStream/LArRawDataContByteStreamTool.h
@@ -19,6 +19,8 @@
 //#include "GaudiKernel/ToolHandle.h"
 #include "LArByteStream/Hid2RESrcID.h"
 #include "LArByteStream/RodRobIdMap.h"
+#include "LArCabling/LArOnOffIdMapping.h"
+#include "LArRecConditions/LArFebRodMapping.h"
 #include "ByteStreamCnvSvcBase/FullEventAssembler.h" 
 #include "ByteStreamData/RawEvent.h" 
 #include "LArByteStream/LArRodDecoder.h"
@@ -26,6 +28,7 @@
 #include "CaloIdentifier/CaloGain.h"
 #include "CaloConditions/CaloNoise.h"
 #include "StoreGate/ReadCondHandleKey.h"
+#include "CxxUtils/CachedUniquePtr.h"
 
 #include "LArRawEvent/LArFebHeaderContainer.h"
 // Map of ROBs need this
@@ -115,6 +118,10 @@ private:
   /** Prepare ROB index before conversion */
   StatusCode prepareRobIndex (const RawEvent* event, RobIndex_t& robIndex) const;
  
+
+  /** Construct a RodBlockStructure instance of the proper concrete type. */
+  std::unique_ptr<LArRodBlockStructure> makeRodBlockStructure() const;
+
   //StatusCode prepareWriting();
   /** 
    * @brief Check that all elements in a container have the same gain
@@ -124,8 +131,9 @@ private:
   template <class COLLECTION >
     bool checkGainConsistency(const COLLECTION* coll) const;
  
-  Hid2RESrcID m_hid2re;       //!< Contains the mapping from channel to ROD
+  CxxUtils::CachedUniquePtr<Hid2RESrcID> m_hid2re;       //!< Contains the mapping from channel to ROD (writing only)
   LArRodDecoder *m_decoder;   //!< Pointer to RodDecoder class
+  const Hid2RESrcID& getHid2RESrcID (const LArFebRodMapping& rodMapping) const;
 
   /** Pointer to @c LArRodBlockStructure base class. 
       Which concrete implementation is used depends on the value of 
@@ -155,8 +163,16 @@ private:
   // Name of Digit container to retrieve
   std::string m_DigitContName;
 
+  const LArOnlineID*    m_onlineHelper = nullptr;
+
   SG::ReadCondHandleKey<CaloNoise> m_caloNoiseKey
   { this, "CaloNoiseKey", "totalNoise", "" };
+
+  SG::ReadCondHandleKey<LArOnOffIdMapping> m_onOffIdMappingKey
+  { this, "OnOffIdMappingKey", "LArOnOffIdMap", "LArOnOffIdMap" };
+
+  SG::ReadCondHandleKey<LArFebRodMapping> m_febRodMappingKey
+  { this, "FebRodMappingKey", "LArFebRodMap", "LArFebRodMap" };
 };
 
 
diff --git a/LArCalorimeter/LArCnv/LArByteStream/LArByteStream/LArRodEncoder.h b/LArCalorimeter/LArCnv/LArByteStream/LArByteStream/LArRodEncoder.h
index b22035d14fe34f1c8711e71179362c09fdd797c8..a76021514771ff09bae1c0380deee03f7fe31c50 100644
--- a/LArCalorimeter/LArCnv/LArByteStream/LArByteStream/LArRodEncoder.h
+++ b/LArCalorimeter/LArCnv/LArByteStream/LArByteStream/LArRodEncoder.h
@@ -41,7 +41,7 @@
 #include "LArRawEvent/LArCalibDigit.h"
 #include "LArRawEvent/LArCalibDigitContainer.h"
 
-#include "LArCabling/LArCablingLegacyService.h"
+#include "LArCabling/LArOnOffIdMapping.h"
 #include "LArByteStream/LArRodBlockStructure.h"
 //#include "LArByteStream/LArRodBlockStructure_0.h"
 //#include "LArByteStream/LArRodBlockStructure_1.h"
@@ -56,7 +56,10 @@ class LArRodEncoder
 public: 
 
   // constructor 
-  LArRodEncoder(); 
+  LArRodEncoder (const LArOnlineID& onlineHelper,
+                 const CaloDetDescrManager& calodd,
+                 const LArOnOffIdMapping& onOffIdMapping,
+                 LArRodBlockStructure* BlStruct); 
   // destructor 
   ~LArRodEncoder(); 
 
@@ -79,7 +82,6 @@ public:
 //  void fillROD(std::vector<uint32_t>& v, MsgStream& logstr) ; 
   void fillROD(std::vector<uint32_t>& v, MsgStream& logstr, const CaloNoise& noise, double nsigma) ;
 
-  static void setRodBlockStructure(LArRodBlockStructure* BlStructPtr);
 
 private:
   /*
@@ -110,11 +112,11 @@ private:
   //std::vector<FebData> m_vFEB;
   std::map<uint32_t,FebData_t> m_mFEB;
 
-  //Static members;
-  static LArRodBlockStructure* m_BlStruct;
-  static LArCablingLegacyService*    m_cablingSvc; 
-  static const CaloDetDescrManager* m_CaloDetDescrManager;
-  static const LArOnlineID*    m_onlineHelper; 
+  const LArOnlineID&    m_onlineHelper; 
+  const CaloDetDescrManager& m_CaloDetDescrManager;
+  const LArOnOffIdMapping&   m_onOffIdMapping;
+  LArRodBlockStructure* m_BlStruct;
+
   /*
  public:
   static int m_digitcounter; //for debug purpose only
diff --git a/LArCalorimeter/LArCnv/LArByteStream/python/LArByteStreamConfig.py b/LArCalorimeter/LArCnv/LArByteStream/python/LArByteStreamConfig.py
index 6ea1636676428559381632c704708362ecac09d5..cad5f10f176985535d9ba709db2b004cfd639c1f 100644
--- a/LArCalorimeter/LArCnv/LArByteStream/python/LArByteStreamConfig.py
+++ b/LArCalorimeter/LArCnv/LArByteStream/python/LArByteStreamConfig.py
@@ -12,11 +12,18 @@ def LArRawDataContByteStreamToolConfig (name="LArRawDataContByteStreamTool",
       tool = LArRawDataContByteStreamTool (name, **kwargs)
       if InitializeForWriting:
          from CaloTools.CaloNoiseCondAlg import CaloNoiseCondAlg
+         from LArCabling.LArCablingAccess import LArOnOffIdMapping, LArFebRodMapping
          noisealg = CaloNoiseCondAlg ('totalNoise')
+         LArOnOffIdMapping()
+         LArFebRodMapping()
          if stream:
             key = str(noisealg.OutputKey)
             if key.find ('+') < 0:
                key = 'ConditionStore+' + key
             stream.ExtraInputs += [('CaloNoise', key)]
+
+            stream.ExtraInputs += [('LArOnOffIdMapping', 'ConditionStore+LArOnOffIdMap')]
+
+            stream.ExtraInputs += [('LArFebRodMapping', 'ConditionStore+LArFebRodMap')]
       tool.InitializeForWriting = InitializeForWriting
       return tool
diff --git a/LArCalorimeter/LArCnv/LArByteStream/src/LArRawDataContByteStreamTool.cxx b/LArCalorimeter/LArCnv/LArByteStream/src/LArRawDataContByteStreamTool.cxx
index 17cbb683866e90ba9e2486bcb2ba349bb120be84..024fbb38ec2c74b1cf6b691509fd247643670de2 100644
--- a/LArCalorimeter/LArCnv/LArByteStream/src/LArRawDataContByteStreamTool.cxx
+++ b/LArCalorimeter/LArCnv/LArByteStream/src/LArRawDataContByteStreamTool.cxx
@@ -11,6 +11,8 @@
 #include "LArRawEvent/LArRawChannelContainer.h"
 #include "LArRawEvent/LArDigitContainer.h"
 #include "LArRawEvent/LArCalibDigitContainer.h"
+#include "LArRecConditions/LArCalibLineMapping.h"
+#include "LArCabling/LArOnOffIdMapping.h"
 
 #include "LArByteStream/LArRodBlockStructure.h"
 //#include "LArByteStream/LArRodBlockStructure_0.h"
@@ -64,8 +66,6 @@ LArRawDataContByteStreamTool::initialize()
   ATH_CHECK( toolSvc()->retrieveTool("LArRodDecoder",m_decoder) );
 
   if (m_initializeForWriting) {
-   ATH_CHECK( m_hid2re.initialize() );
-
    //Set LArRodBlockStructure according to jobOpts.
    switch(m_DSPRunMode)
      {case 0:  //Obsolete mode 
@@ -103,16 +103,17 @@ LArRawDataContByteStreamTool::initialize()
        break;
      }
 
-   // Set chosen RodBlockType
-   LArRodEncoder::setRodBlockStructure(m_RodBlockStructure);
-   ATH_MSG_INFO ( "Initialization done for reading and writing" );
+   ATH_CHECK( detStore()->retrieve (m_onlineHelper, "LArOnlineID") );
 
+   ATH_MSG_INFO ( "Initialization done for reading and writing" );
  }
   else {
     ATH_MSG_INFO ( "Initialization done for reading only" );
   }
 
   ATH_CHECK( m_caloNoiseKey.initialize (m_initializeForWriting) );
+  ATH_CHECK( m_onOffIdMappingKey.initialize (m_initializeForWriting) );
+  ATH_CHECK( m_febRodMappingKey.initialize (m_initializeForWriting) );
 
   return StatusCode::SUCCESS;  
 }
@@ -141,7 +142,10 @@ LArRawDataContByteStreamTool::WriteLArDigits(const LArDigitContainer* digitCont,
    ATH_MSG_ERROR ( "Null pointer passed to WriteLArDigit routine!" );
    return StatusCode::FAILURE;
  }
- if (!m_RodBlockStructure->canSetRawData() && !m_RodBlockStructure->canSetRawDataFixed()) {
+
+ std::unique_ptr<LArRodBlockStructure> blstruct = makeRodBlockStructure();
+
+ if (!blstruct->canSetRawData() && !blstruct->canSetRawDataFixed()) {
    ATH_MSG_DEBUG ( "This instance of LArRodBlockStructure can't hold LArDigits!" );
    return StatusCode::FAILURE;
  }
@@ -154,13 +158,28 @@ LArRawDataContByteStreamTool::WriteLArDigits(const LArDigitContainer* digitCont,
  LArDigitContainer::const_iterator it_b=digitCont->begin();
  LArDigitContainer::const_iterator it_e=digitCont->end();
  if (it_b==it_e) {
-   ATH_MSG_WARNING ( "Attempt to persitify a empty LArDigitContainer to ByteStream" );
+   ATH_MSG_WARNING ( "Attempt to persistify a empty LArDigitContainer to ByteStream" );
    return StatusCode::SUCCESS;
  }
 
+ const CaloDetDescrManager* calodd = nullptr;
+ ATH_CHECK( detStore()->retrieve (calodd, "CaloMgr") );
+ const EventContext& ctx = Gaudi::Hive::currentContext();
+ SG::ReadCondHandle<LArOnOffIdMapping> onOffMapping (m_onOffIdMappingKey, ctx);
+ SG::ReadCondHandle<LArFebRodMapping> febRodMapping (m_febRodMappingKey, ctx);
+ const Hid2RESrcID& hid2re = getHid2RESrcID (**febRodMapping);
+
  std::map<uint32_t, LArRodEncoder> mapEncoder; 
+
+ auto getEncoder = [&] (uint32_t reid) -> LArRodEncoder&
+                   { return mapEncoder.try_emplace (reid,
+                                                    *m_onlineHelper,
+                                                    *calodd,
+                                                    **onOffMapping,
+                                                    blstruct.get()).first->second; };
+
  unsigned n=0;
- if (m_RodBlockStructure->canSetRawDataFixed() && checkGainConsistency(digitCont))
+ if (blstruct->canSetRawDataFixed() && checkGainConsistency(digitCont))
    {//Set fixed gain raw data
      int fixgain=(*it_b)->gain();
      ATH_MSG_DEBUG(" number of Digits in LArDigitContainer for gain " << fixgain << ": " 
@@ -169,29 +188,29 @@ LArRawDataContByteStreamTool::WriteLArDigits(const LArDigitContainer* digitCont,
      for(; it_b!=it_e; ++it_b){
        const LArDigit* digit = *it_b; 
        HWIdentifier  chid = digit->hardwareID() ; 
-       uint32_t reid      = m_hid2re.getRodID( chid ); 
-       mapEncoder[reid].add(digit, fixgain);
+       uint32_t reid      = hid2re.getRodID( **febRodMapping, chid );
+       getEncoder(reid).add (digit, fixgain);
        n++;
      }  
      ATH_MSG_VERBOSE(" number of channels in the LArDigitContainer for gain " 
                      << fixgain << ": "<<n );
    } // end if
  else 
-   if (m_RodBlockStructure->canSetRawData()) { //Set free gain raw data
+   if (blstruct->canSetRawData()) { //Set free gain raw data
      ATH_MSG_DEBUG(" number of channels in LArDigit container: "<< digitCont->size() );
 
       // Sorting Channels by ROD
       for(; it_b!=it_e; ++it_b){
 	const LArDigit* digit = *it_b; 
 	HWIdentifier  chid = digit->hardwareID() ; 
-	uint32_t reid      = m_hid2re.getRodID( chid ); 
-	mapEncoder[reid].add(digit);
+	uint32_t reid      = hid2re.getRodID( **febRodMapping, chid ); 
+	getEncoder(reid).add (digit);
 	n++;
       }  
       ATH_MSG_VERBOSE(" number of channels added to framgent: "<<n );
      }//  end else-if(can set Raw data)
 
- SG::ReadCondHandle<CaloNoise> noise (m_caloNoiseKey);
+ SG::ReadCondHandle<CaloNoise> noise (m_caloNoiseKey, ctx);
 
  // Now loop over map and fill all ROD Data Blocks
  std::map<uint32_t,LArRodEncoder>::iterator it  =mapEncoder.begin(); 
@@ -224,7 +243,10 @@ LArRawDataContByteStreamTool::WriteLArCalibDigits(const LArCalibDigitContainer*
    ATH_MSG_DEBUG ( "Null pointer passed to WriteLArCalibDigit routine!" );
    return StatusCode::FAILURE;
  }
- if (!m_RodBlockStructure->canSetCalibration()|| !m_RodBlockStructure->canSetRawDataFixed()) {
+
+ std::unique_ptr<LArRodBlockStructure> blstruct = makeRodBlockStructure();
+
+ if (!blstruct->canSetCalibration()|| !blstruct->canSetRawDataFixed()) {
    ATH_MSG_DEBUG ( "This instance of LArRodBlockStructure can't hold LArCalibDigits!" );
    return StatusCode::FAILURE;
  }
@@ -245,7 +267,22 @@ LArRawDataContByteStreamTool::WriteLArCalibDigits(const LArCalibDigitContainer*
    return StatusCode::FAILURE;
  }
 
+ const CaloDetDescrManager* calodd = nullptr;
+ ATH_CHECK( detStore()->retrieve (calodd, "CaloMgr") );
+ const EventContext& ctx = Gaudi::Hive::currentContext();
+ SG::ReadCondHandle<LArOnOffIdMapping> onOffMapping (m_onOffIdMappingKey, ctx);
+ SG::ReadCondHandle<LArFebRodMapping> febRodMapping (m_febRodMappingKey, ctx);
+ const Hid2RESrcID& hid2re = getHid2RESrcID (**febRodMapping);
+
  std::map<uint32_t, LArRodEncoder> mapEncoder; 
+
+ auto getEncoder = [&] (uint32_t reid) -> LArRodEncoder&
+                   { return mapEncoder.try_emplace (reid,
+                                                    *m_onlineHelper,
+                                                    *calodd,
+                                                    **onOffMapping,
+                                                    blstruct.get()).first->second; };
+
  unsigned n=0;
  int fixgain=(*it_b)->gain();
  
@@ -253,15 +290,15 @@ LArRawDataContByteStreamTool::WriteLArCalibDigits(const LArCalibDigitContainer*
  for(; it_b!=it_e; ++it_b){
    const LArCalibDigit* digit = *it_b; 
    HWIdentifier  chid = digit->hardwareID() ; 
-   uint32_t reid      = m_hid2re.getRodID( chid ); 
-   mapEncoder[reid].add(digit, fixgain);
+   uint32_t reid      = hid2re.getRodID( **febRodMapping, chid );
+   getEncoder(reid).add (digit, fixgain);
    n++;
  } 
  
  ATH_MSG_VERBOSE(" number of channels in the LArCalibDigitContainer for gain " 
                  << fixgain << ": "<<n );
 
- SG::ReadCondHandle<CaloNoise> noise (m_caloNoiseKey);
+ SG::ReadCondHandle<CaloNoise> noise (m_caloNoiseKey, ctx);
 
  // Now loop over map and fill all ROD Data Blocks
  std::map<uint32_t,LArRodEncoder>::iterator it  =mapEncoder.begin(); 
@@ -290,7 +327,10 @@ LArRawDataContByteStreamTool::WriteLArRawChannels(const LArRawChannelContainer*
    ATH_MSG_DEBUG ( "Null pointer passed to WriteLArCalibDigit routine!" );
   return StatusCode::FAILURE;
  }
- if (!m_RodBlockStructure->canSetEnergy()) {
+
+ std::unique_ptr<LArRodBlockStructure> blstruct = makeRodBlockStructure();
+
+ if (!blstruct->canSetEnergy()) {
    ATH_MSG_DEBUG ( "This instance of LArRodBlockStructure can't hold LArRawChannels!" );
     return StatusCode::FAILURE;
  }
@@ -305,7 +345,23 @@ LArRawDataContByteStreamTool::WriteLArRawChannels(const LArRawChannelContainer*
    ATH_MSG_WARNING ( "Attempt to persistify a empty LArDigitContainer to ByteStream" );
    return StatusCode::SUCCESS;
  }
+
+ const CaloDetDescrManager* calodd = nullptr;
+ ATH_CHECK( detStore()->retrieve (calodd, "CaloMgr") );
+ const EventContext& ctx = Gaudi::Hive::currentContext();
+ SG::ReadCondHandle<LArOnOffIdMapping> onOffMapping (m_onOffIdMappingKey, ctx);
+ SG::ReadCondHandle<LArFebRodMapping> febRodMapping (m_febRodMappingKey, ctx);
+ const Hid2RESrcID& hid2re = getHid2RESrcID (**febRodMapping);
+
  std::map<uint32_t, LArRodEncoder> mapEncoder; 
+
+ auto getEncoder = [&] (uint32_t reid) -> LArRodEncoder&
+                   { return mapEncoder.try_emplace (reid,
+                                                    *m_onlineHelper,
+                                                    *calodd,
+                                                    **onOffMapping,
+                                                    blstruct.get()).first->second; };
+
  //LArRodEncoder* Encoder = NULL;
  //uint32_t last_reid(0x0);
  //unsigned n=0; //For debug only
@@ -313,44 +369,44 @@ LArRawDataContByteStreamTool::WriteLArRawChannels(const LArRawChannelContainer*
  for(; it!=it_e; ++it){
      const LArRawChannel& rawChan = *it; 
      HWIdentifier  chid = rawChan.channelID() ; 
-     uint32_t reid      = m_hid2re.getRodID( chid ); 
+     uint32_t reid      = hid2re.getRodID( **febRodMapping, chid ); 
 
 /*
      if ( reid != last_reid ) {
 	last_reid = reid;
 	// The guy does not exist
 	// This will create it
-	mapEncoder[reid].add(&rawChan);
+	getEncoder(reid).add(&rawChan);
 	// This will get its address
 	Encoder = &(mapEncoder[reid]);
      } else Encoder->add(&rawChan) ; // Encoder already there
 */
-     mapEncoder[reid].add(&rawChan);
+     getEncoder(reid).add (&rawChan);
    } 
    // I may want to also include the digits
    if ( m_includeDigits ) {
-	const DataHandle<LArDigitContainer> digitCont;
+        const LArDigitContainer* digitCont = nullptr;
 	if ( evtStore()->retrieve(digitCont,m_DigitContName).isFailure() ){
           ATH_MSG_ERROR ( "Digits required but not really found" );
 	} else {
-	  if ( m_RodBlockStructure->canIncludeRawData() ){
+	  if ( blstruct->canIncludeRawData() ){
 	   LArDigitContainer::const_iterator it_b=digitCont->begin();
 	   LArDigitContainer::const_iterator it_e=digitCont->end();
 	   if (it_b==it_e) {
-             ATH_MSG_WARNING ( "Attempt to persitify a empty LArDigitContainer to ByteStream" );
+             ATH_MSG_WARNING ( "Attempt to persistify a empty LArDigitContainer to ByteStream" );
 	   }
 	   for(; it_b!=it_e; ++it_b){
 		const LArDigit* digit = *it_b;
 		HWIdentifier  chid = digit->hardwareID() ;
-		uint32_t reid      = m_hid2re.getRodID( chid );
+		uint32_t reid      = hid2re.getRodID( **febRodMapping, chid );
 		// Lets use anygain for the moment
-		mapEncoder[reid].add(digit);
+		getEncoder(reid).add (digit);
      	   }
 	  } // End of check whether format allows to include RawData
 	} // Finish checking for Digit container in SG
    } // End of check for digits inclusion
 
- SG::ReadCondHandle<CaloNoise> noise (m_caloNoiseKey);
+ SG::ReadCondHandle<CaloNoise> noise (m_caloNoiseKey, ctx);
       
  // Now loop over map and fill all ROD Data Blocks
  std::map<uint32_t,LArRodEncoder>::iterator it_m  =mapEncoder.begin(); 
@@ -397,3 +453,62 @@ LArRawDataContByteStreamTool::prepareRobIndex(const RawEvent* re,
   }
   return StatusCode::SUCCESS;
 }
+
+
+/** Construct a RodBlockStructure instance of the proper concrete type. */
+std::unique_ptr<LArRodBlockStructure>
+LArRawDataContByteStreamTool::makeRodBlockStructure() const
+{
+  switch(m_DSPRunMode) {
+  case 0:  // Obsolete; shouldn't get here.
+    std::abort();
+
+  case 2:  //Transparent mode, DSP just copies FEB-data                                            
+    ATH_MSG_DEBUG ( "Set Rod Block Type to LArRodBlockTransparent (#2)" );
+    return std::make_unique<LArRodBlockTransparentV0<LArRodBlockHeaderTransparentV0> >();
+    break;
+
+  case 7: //Calibration mode
+    ATH_MSG_DEBUG ( "Set Rod Block Type to LArRodBlockCalibration (#7)" );
+    return std::make_unique<LArRodBlockCalibrationV0<LArRodBlockHeaderCalibrationV0> >();
+    break;
+
+  case 4: //Physics assembly mode
+    if ( m_RodBlockVersion == 10 ){
+      ATH_MSG_DEBUG ( "Set Rod Block Type to LArRodBlockPhysics (#5)" );
+      return std::make_unique<LArRodBlockPhysicsV5>();
+    }
+    else if ( m_RodBlockVersion == 12 ){
+      ATH_MSG_DEBUG ( "Set Rod Block Type to LArRodBlockPhysics (#6)" );
+      return std::make_unique<LArRodBlockPhysicsV6>();
+    }
+    else {
+      ATH_MSG_DEBUG ( "Set Rod Block Type to LArRodBlockPhysics (#4)" );
+      return std::make_unique<LArRodBlockPhysicsV0>();
+    }
+    break;
+
+  case 5: //Physics assembly mode
+    ATH_MSG_DEBUG ( "Set Rod Block Type to LArRodBlockPhysics (#5)" );
+    return std::make_unique<LArRodBlockPhysicsV3>();
+
+  default:
+    ATH_MSG_WARNING ( "DSP runmode " << m_DSPRunMode << " is unknown. Using physics assembly mode (#4) by default" );
+    return std::make_unique<LArRodBlockPhysicsV0>();
+  }
+}
+
+
+const Hid2RESrcID&
+LArRawDataContByteStreamTool::getHid2RESrcID (const LArFebRodMapping& rodMapping) const
+{
+  if (!m_hid2re) {
+    auto hid2re = std::make_unique<Hid2RESrcID>();
+    if (hid2re->initialize (rodMapping).isFailure()) {
+      std::abort();
+    }
+    m_hid2re.set (std::move (hid2re));
+  }
+  return *m_hid2re.get();
+}
+
diff --git a/LArCalorimeter/LArCnv/LArByteStream/src/LArRodEncoder.cxx b/LArCalorimeter/LArCnv/LArByteStream/src/LArRodEncoder.cxx
index 20eeeea42a51c5afe7460826bc0d6938ec3ab23a..7182e95be34fa3b4c161467bdd683ae3b08d2bd9 100644
--- a/LArCalorimeter/LArCnv/LArByteStream/src/LArRodEncoder.cxx
+++ b/LArCalorimeter/LArCnv/LArByteStream/src/LArRodEncoder.cxx
@@ -15,65 +15,17 @@
 #include <Identifier/HWIdentifier.h>
 #include "CaloInterface/ICaloNoiseTool.h"
 
-// static variables
-LArCablingLegacyService*    LArRodEncoder::m_cablingSvc=NULL;
-const LArOnlineID*    LArRodEncoder::m_onlineHelper=NULL; 
-LArRodBlockStructure* LArRodEncoder::m_BlStruct=NULL;
-const CaloDetDescrManager* LArRodEncoder::m_CaloDetDescrManager=NULL;
-
-void LArRodEncoder::setRodBlockStructure(LArRodBlockStructure* BlStructPtr)
-{
-  m_BlStruct=BlStructPtr; 
-}
-
 
 // constructor 
-LArRodEncoder::LArRodEncoder()
+LArRodEncoder::LArRodEncoder (const LArOnlineID& onlineHelper,
+                              const CaloDetDescrManager& calodd,
+                              const LArOnOffIdMapping& onOffIdMapping,
+                              LArRodBlockStructure* BlStruct)
+  : m_onlineHelper (onlineHelper),
+    m_CaloDetDescrManager (calodd),
+    m_onOffIdMapping (onOffIdMapping),
+    m_BlStruct (BlStruct)
 {
-  if(m_cablingSvc==NULL || m_onlineHelper==NULL) {
-    // Message service
-    IMessageSvc*  msgSvc;
-    StatusCode sc = Gaudi::svcLocator()->service( "MessageSvc", msgSvc  );
-    MsgStream log(msgSvc, "LArRodEncoder");
-    if ( log.level() <= MSG::DEBUG )
-      log << MSG::DEBUG << "initialize" << endmsg;
-    // Cabling Service
-    IToolSvc* toolSvc;
-    sc   = Gaudi::svcLocator()->service( "ToolSvc",toolSvc  );
-    if(sc.isSuccess())
-      {
-	sc = 
-	  toolSvc->retrieveTool("LArCablingLegacyService",m_cablingSvc);
-      } else {  // check if it fails
-        // what do you want to do if it fails...
-	log << MSG::FATAL << "Could not get LArCablingService !" << endmsg;
-	exit(1);
-      }
-    //m_cablingSvc = LArCablingService::getInstance(); 
-    // retrieve onlineHelper
-    const LArOnlineID* online_id = 0;
-    StoreGateSvc* detStore = 0;
-    sc =Gaudi::svcLocator()->service( "DetectorStore", detStore );
-    if (sc.isFailure()) {
-      log << MSG::ERROR << "Unable to locate DetectorStore" << endmsg;
-      exit(1);
-    } else {
-      if ( log.level() <= MSG::INFO ) 
-        log << MSG::INFO << "Successfully located DetectorStore" << endmsg;
-    }     
-    sc = detStore->retrieve(online_id, "LArOnlineID");
-    if (sc.isFailure()) {
-      log << MSG::FATAL << "Could not get LArOnlineID helper !" << endmsg;
-      exit(1);
-    } 
-    else {
-      m_onlineHelper=online_id;
-      if ( log.level() <= MSG::DEBUG ) 
-        log << MSG::DEBUG << " Found the LArOnlineID helper. " << endmsg;
-    }
-  }
-
-  m_CaloDetDescrManager = CaloDetDescrManager::instance();
 }
 
 // destructor 
@@ -85,28 +37,28 @@ LArRodEncoder::~LArRodEncoder()
 // Add LArRawChannel
 void LArRodEncoder::add(const LArRawChannel* rc)
 {
- uint32_t FEB_ID = (m_onlineHelper->feb_Id(rc->channelID()).get_identifier32().get_compact());
+ uint32_t FEB_ID = (m_onlineHelper.feb_Id(rc->channelID()).get_identifier32().get_compact());
  if ( m_mFEB[FEB_ID].vLArRC.empty() ){
 	m_mFEB[FEB_ID].vLArRC.resize(128,0);
 	//for(int i=0;i<128;i++) m_mFEB[FEB_ID].vLArRC.push_back(0);
  }
- uint32_t chan = m_BlStruct->FebToRodChannel(m_onlineHelper->channel( rc->channelID() ) );
+ uint32_t chan = m_BlStruct->FebToRodChannel(m_onlineHelper.channel( rc->channelID() ) );
  m_mFEB[FEB_ID].vLArRC[chan]=rc;
 }
 
 // Add free gain digits
 void LArRodEncoder::add(const LArDigit* dg)
-{uint32_t FEB_ID = (m_onlineHelper->feb_Id(dg->hardwareID()).get_identifier32().get_compact());
+{uint32_t FEB_ID = (m_onlineHelper.feb_Id(dg->hardwareID()).get_identifier32().get_compact());
  m_mFEB[FEB_ID].vLArDigit.push_back(dg);
 }
 //Add fixed gain digits
 void LArRodEncoder::add(const LArDigit* dg, const int gain)
-{uint32_t FEB_ID = (m_onlineHelper->feb_Id(dg->hardwareID()).get_identifier32().get_compact());
+{uint32_t FEB_ID = (m_onlineHelper.feb_Id(dg->hardwareID()).get_identifier32().get_compact());
  m_mFEB[FEB_ID].vLArDigitFixed[gain].push_back(dg);
 }
 //Add calibration digits
 void LArRodEncoder::add(const LArCalibDigit* dg, const int gain)
-{uint32_t FEB_ID = (m_onlineHelper->feb_Id(dg->hardwareID()).get_identifier32().get_compact());
+{uint32_t FEB_ID = (m_onlineHelper.feb_Id(dg->hardwareID()).get_identifier32().get_compact());
  m_mFEB[FEB_ID].vLArCalibDigit[gain].push_back(dg);
 }
 
@@ -154,7 +106,7 @@ void LArRodEncoder::fillROD(std::vector<uint32_t>& v, MsgStream& logstr, const C
 
         for (const LArRawChannel *theChannel : it->second.vLArRC) {
 	  if ( theChannel != nullptr ){
-	  int cId =  m_onlineHelper->channel(theChannel->hardwareID());
+	  int cId =  m_onlineHelper.channel(theChannel->hardwareID());
 
 	  int e=theChannel->energy();
           uint32_t quality = theChannel->quality();
@@ -162,9 +114,9 @@ void LArRodEncoder::fillROD(std::vector<uint32_t>& v, MsgStream& logstr, const C
 				    quality,theChannel->gain());
 	  
 	  // you convert from hardwareID to offline channle ID hash (???)
-	  myofflineID = m_cablingSvc->cnvToIdentifier(theChannel->hardwareID()) ;
+	  myofflineID = m_onOffIdMapping.cnvToIdentifier(theChannel->hardwareID()) ;
 	  //std::cout << "Got Offile id 0x" << std::hex << myofflineID.get_compact() << std::dec << std::endl;
-          const CaloDetDescrElement* caloDDE = m_CaloDetDescrManager->get_element(myofflineID);
+          const CaloDetDescrElement* caloDDE = m_CaloDetDescrManager.get_element(myofflineID);
 	  // This is probably NOT what one wants. You want the cell gain!
           double cellnoise = noise.getNoise(myofflineID,theChannel->gain());
           if( e > (nsigma*cellnoise) && (quality != 65535 ) ){
@@ -189,7 +141,7 @@ void LArRodEncoder::fillROD(std::vector<uint32_t>& v, MsgStream& logstr, const C
       // Order channels according to ROD numbering
       m_BlStruct->sortDataVector(it->second.vLArDigit);
       for (const LArDigit* digit : it->second.vLArDigit) {
-        int cId =  m_onlineHelper->channel(digit->hardwareID());
+        int cId =  m_onlineHelper.channel(digit->hardwareID());
         m_BlStruct->setRawData(cId, digit->samples(), digit->gain());
       } // end of for digits
     } // End of can Include Raw Data check
@@ -203,7 +155,7 @@ void LArRodEncoder::fillROD(std::vector<uint32_t>& v, MsgStream& logstr, const C
       if(digit_it!=digit_it_end) { //Container not empty
 	m_BlStruct->setNumberOfSamples((*digit_it)->samples().size());
 	for (;digit_it!=digit_it_end;++digit_it)  {
-	  int cId =  m_onlineHelper->channel((*digit_it)->hardwareID());
+	  int cId =  m_onlineHelper.channel((*digit_it)->hardwareID());
 	  //cId = m_BlStruct->FebToRodChannel(cId);
 	  m_BlStruct->setRawData(cId, (*digit_it)->samples(), (*digit_it)->gain());
 	} 
@@ -221,7 +173,7 @@ void LArRodEncoder::fillROD(std::vector<uint32_t>& v, MsgStream& logstr, const C
 	if(digit_it!=digit_it_end) {//Container not empty
 	  m_BlStruct->setNumberOfSamples((*digit_it)->samples().size());
 	  for (;digit_it!=digit_it_end;++digit_it)  {
-	    int cId =  m_onlineHelper->channel((*digit_it)->hardwareID()); 
+	    int cId =  m_onlineHelper.channel((*digit_it)->hardwareID()); 
 	    //cId = m_BlStruct->FebToRodChannel(cId);
 	    m_BlStruct->setRawDataFixed(cId, (*digit_it)->samples(), (*digit_it)->gain());
 	  }
@@ -241,7 +193,7 @@ void LArRodEncoder::fillROD(std::vector<uint32_t>& v, MsgStream& logstr, const C
 	    m_BlStruct->setDelay((*digit_it)->delay());
 	    m_BlStruct->setDAC((*digit_it)->DAC());
 	    for (;digit_it!=digit_it_end;++digit_it) { 
-	      int cId =  m_onlineHelper->channel((*digit_it)->hardwareID()); 
+	      int cId =  m_onlineHelper.channel((*digit_it)->hardwareID()); 
 	      //cId = m_BlStruct->FebToRodChannel(cId);
 	      m_BlStruct->setRawDataFixed(cId, (*digit_it)->samples(), (*digit_it)->gain());
 	      if ((*digit_it)->isPulsed())
@@ -263,7 +215,7 @@ void LArRodEncoder::fillROD(std::vector<uint32_t>& v, MsgStream& logstr, const C
 	  m_BlStruct->setDAC((*digit_it)->DAC());
 	  m_BlStruct->setDelay((*digit_it)->delay());
 	  for (;digit_it!=digit_it_end;digit_it++) { 
-	    int cId =  m_cablingSvc->channel((*digit_it)->channelID()); 
+	    int cId =  m_cablingSvc.channel((*digit_it)->channelID()); 
 	    cId = m_BlStruct->FebToRodChannel(cId);
 	    m_BlStruct->setRawData(cId, (*digit_it)->samples(), (*digit_it)->gain());
 	    m_BlStruct->setIsPulsed(cId);
diff --git a/LArCalorimeter/LArDigitization/src/LArHitEMap.cxx b/LArCalorimeter/LArDigitization/src/LArHitEMap.cxx
index ad87463246f1f3501641daf0c0c8157b76563ec5..b685dfb7aab466cb5b51edc5405c4bc31d33062a 100644
--- a/LArCalorimeter/LArDigitization/src/LArHitEMap.cxx
+++ b/LArCalorimeter/LArDigitization/src/LArHitEMap.cxx
@@ -90,15 +90,13 @@ bool LArHitEMap::BuildWindows(const McEventCollection* mcCollptr,
     McEventCollection::const_iterator itr;
 //    std::cout << " start loop over particles " << std::endl;
     for (itr = mcCollptr->begin(); itr!=mcCollptr->end(); ++itr) {
-      HepMC::GenEvent::particle_const_iterator itrPart;
-      for (itrPart = (*itr)->particles_begin(); itrPart!=(*itr)->particles_end(); ++itrPart )
+      for (auto part: *(*itr))
       {
-         HepMC::GenParticle *part=*itrPart;
          //works only for photons(22) and electrons(11) primary particle from Geant (status>1000)
          // with pt>5 GeV
 // GU 20-june-2006 use barcode between 10001 and 20000 to select primary particles //AV2020: not sure if it works
-         if(   (part->pdg_id()==22 || abs(part->pdg_id())==11 || part->pdg_id()==111) 
-            && part->barcode()>10000 && part->barcode()<20000
+         if(   (part->pdg_id()==22 || std::abs(part->pdg_id())==11 || part->pdg_id()==111) 
+            && HepMC::barcode(part)>10000 && HepMC::barcode(part)<20000
             && part->momentum().perp()> ptmin)
          {
 //          std::cout << "good particle found ! " << part->pdg_id() << std::endl;
diff --git a/LArCalorimeter/LArG4/LArG4FastSimulation/src/LArFastShowerTool.h b/LArCalorimeter/LArG4/LArG4FastSimulation/src/LArFastShowerTool.h
index 88a951f42271bc0997357cab576f8bf721f9d76d..81697a3ac1c51c218797c1f8a1e8f806c0b8b8bb 100644
--- a/LArCalorimeter/LArG4/LArG4FastSimulation/src/LArFastShowerTool.h
+++ b/LArCalorimeter/LArG4/LArG4FastSimulation/src/LArFastShowerTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef LARG4FASTSIMULATION_LARFASTSHOWERTOOL_H
@@ -16,8 +16,6 @@
 // STL headers
 #include <string>
 
-class G4FastSimulationModel;
-
 /// NEEDS DOCUMENTATION
 class LArFastShowerTool: public FastSimulationBase
 {
diff --git a/LArCalorimeter/LArG4/LArG4H6SD/src/RadLenNtuple.cc b/LArCalorimeter/LArG4/LArG4H6SD/src/RadLenNtuple.cc
index 3aad0fdc4e9883e41718f80566235238242366dd..1c450b3ff53e0fd0bdd0c80f6a00952dd5982dbe 100644
--- a/LArCalorimeter/LArG4/LArG4H6SD/src/RadLenNtuple.cc
+++ b/LArCalorimeter/LArG4/LArG4H6SD/src/RadLenNtuple.cc
@@ -39,7 +39,11 @@ namespace G4UA
 
     if (m_mcEvtColl.isValid()) {
       McEventCollection::const_iterator iEvt = m_mcEvtColl->begin();
+#ifdef HEPMC3
+      auto p = (*iEvt)->particles().begin();
+#else
       HepMC::GenEvent::particle_const_iterator p = (*iEvt)->particles_begin();
+#endif
       m_xcoord = (*p)->production_vertex()->position().x();
     }
    
diff --git a/LArCalorimeter/LArG4/LArG4Validation/src/AODReader.cxx b/LArCalorimeter/LArG4/LArG4Validation/src/AODReader.cxx
index f639b09fb78dabe77ff64fcbf5093d4ee9a015c1..a7659ba0f597223ea337211f5b425c30b2d3a7ea 100644
--- a/LArCalorimeter/LArG4/LArG4Validation/src/AODReader.cxx
+++ b/LArCalorimeter/LArG4/LArG4Validation/src/AODReader.cxx
@@ -126,11 +126,11 @@ StatusCode AODReader::execute()
   ElectronContainer::const_iterator elecItr       = elecTES->begin();
   ElectronContainer::const_iterator elecItrE      = elecTES->end();
   
-  HepMC::GenParticle * trPart = 0;
+  HepMC::GenParticlePtr trPart{nullptr};
   if (mcEvtColl) {
 	  McEventCollection::const_iterator mcTrPart = mcEvtColl->begin();
 	  if (mcTrPart != mcEvtColl->end()) {
-		  trPart = (*mcTrPart)->barcode_to_particle(10001);
+		  trPart = HepMC::barcode_to_particle((*mcTrPart),10001);
 		  if (!trPart) {
 			  msg(MSG::WARNING) << "Not a single particle event. Truth information won't be available" << endmsg;
 		  }
diff --git a/LArCalorimeter/LArG4/LArG4Validation/src/SingleTrackValidation.cxx b/LArCalorimeter/LArG4/LArG4Validation/src/SingleTrackValidation.cxx
index 08f8be0c04d73a7f99da21ecb032be645378fb61..68424cb9602bf522943974c4a4b30f680ebe0f6c 100755
--- a/LArCalorimeter/LArG4/LArG4Validation/src/SingleTrackValidation.cxx
+++ b/LArCalorimeter/LArG4/LArG4Validation/src/SingleTrackValidation.cxx
@@ -320,7 +320,11 @@ StatusCode SingleTrackValidation::execute() {
   for (e=mcEvent->begin();e!=mcEvent->end();e++) {
     
     // Get just the primary, call it "theParticle"
+#ifdef HEPMC3
+   HepMC::ConstGenParticlePtr theParticle = (*e)->particles().front();
+#else
     const HepMC::GenParticle *theParticle= *((**e).particles_begin());
+#endif
 
     // Fetch whatever particle properties will be used in the following:
     const HepPDT::ParticleDataTable * dataTable = m_c->partPropSvc->PDT();
diff --git a/LArCalorimeter/LArMonitoring/share/LArReco_fromraw.py b/LArCalorimeter/LArMonitoring/share/LArReco_fromraw.py
index d118853fe8d52eb3f0fbb67dc068f0ed48efcc82..e375c697c79c6b8baeed3f997cda47754194b666 100644
--- a/LArCalorimeter/LArMonitoring/share/LArReco_fromraw.py
+++ b/LArCalorimeter/LArMonitoring/share/LArReco_fromraw.py
@@ -157,10 +157,8 @@ include("LArCellRec/LArCollisionTime_jobOptions.py")
 from TriggerJobOpts.TriggerFlags import TriggerFlags as tf
 tf.readBS.set_Value_and_Lock(True)
 tf.doLVL1.set_Value_and_Lock(False)
-tf.doLVL2.set_Value_and_Lock(False)
-tf.doEF.set_Value_and_Lock(False)
+tf.doHLT.set_Value_and_Lock(False)
 tf.doL1Topo.set_Value_and_Lock(False)
-tf.readLVL1Calo.set_Value_and_Lock(True)
 tf.enableMonitoring.set_Value_and_Lock(False)
 tf.doID.set_Value_and_Lock(False)
 tf.doMuon.set_Value_and_Lock(False)
diff --git a/LArCalorimeter/LArRecUtils/src/LArFCalTowerBuilderTool.cxx b/LArCalorimeter/LArRecUtils/src/LArFCalTowerBuilderTool.cxx
index 16111c893386e9562f964dece89e42ca435acaa0..60a29da2467c82125fb97944a3d382fe3ada9469 100644
--- a/LArCalorimeter/LArRecUtils/src/LArFCalTowerBuilderTool.cxx
+++ b/LArCalorimeter/LArRecUtils/src/LArFCalTowerBuilderTool.cxx
@@ -60,7 +60,7 @@ StatusCode LArFCalTowerBuilderTool::initializeTool(){
 inline
 void
 LArFCalTowerBuilderTool::addTower (const tower_iterator& t,
-                                   const CaloCellContainer* cells,
+                                   const ElementLink<CaloCellContainer>& cellsEL,
                                    CaloTower* tower) const
 {
   LArFCalTowerStore::cell_iterator firstC = m_cellStore.firstCellofTower(t);
@@ -68,6 +68,7 @@ LArFCalTowerBuilderTool::addTower (const tower_iterator& t,
   // here get needed size of this vector and use it to reserve tower size.
   int ts=  m_cellStore.towerSize(t);
   double wsumE = tower->getBasicEnergy(); // this is not 0 since some towers already have cells from other calos.
+  const CaloCellContainer* cells = cellsEL.getDataPtr();
   for (; firstC != lastC; ++firstC) {
 
     unsigned int ci = firstC->first;
@@ -79,7 +80,7 @@ LArFCalTowerBuilderTool::addTower (const tower_iterator& t,
     // get weights
     if (cellPtr) {
       wsumE += weightC * cellPtr->e();					// Summ up weighted energies .
-      tower->addUniqueCellNoKine(cells, cndx, weightC, ts); // add cells to tower.
+      tower->addUniqueCellNoKine(cellsEL, cndx, weightC, ts); // add cells to tower.
     }
   }
   tower->setE(wsumE);  // update tower kinematics.
@@ -89,7 +90,7 @@ LArFCalTowerBuilderTool::addTower (const tower_iterator& t,
 inline
 void
 LArFCalTowerBuilderTool::iterateFull (CaloTowerContainer* towers,
-                                      const CaloCellContainer* cells) const
+                                      const ElementLink<CaloCellContainer>& cellsEL) const
 {
   size_t sz = towers->size();
   assert(m_cellStore.size() ==  sz);
@@ -97,7 +98,7 @@ LArFCalTowerBuilderTool::iterateFull (CaloTowerContainer* towers,
 
   for (unsigned int t = 0; t < sz; ++t, ++tower_it) {
     CaloTower* aTower = towers->getTower(t);
-    addTower (tower_it, cells, aTower);
+    addTower (tower_it, cellsEL, aTower);
   }
 }
 
@@ -105,7 +106,7 @@ LArFCalTowerBuilderTool::iterateFull (CaloTowerContainer* towers,
 inline
 void
 LArFCalTowerBuilderTool::iterateSubSeg (CaloTowerContainer* towers,
-                                        const CaloCellContainer* cells,
+                                        const ElementLink<CaloCellContainer>& cellsEL,
                                         const CaloTowerSeg::SubSeg* subseg) const
 {
   size_t sz = towers->size();
@@ -114,7 +115,7 @@ LArFCalTowerBuilderTool::iterateSubSeg (CaloTowerContainer* towers,
 
   for (unsigned int t = 0; t < sz; ++t, ++tower_it) {
     CaloTower* aTower = towers->getTower(tower_it.itower());
-    addTower (tower_it, cells, aTower);
+    addTower (tower_it, cellsEL, aTower);
   }
 }
 
@@ -154,11 +155,11 @@ LArFCalTowerBuilderTool::execute(CaloTowerContainer* theTowers,
   // register this calorimeter
   theTowers->setCalo(m_caloIndex);
 
-  
+  const ElementLink<CaloCellContainer> cellsEL (*theCells, 0);
   if (subseg)
-    iterateSubSeg (theTowers, theCells, subseg);
+    iterateSubSeg (theTowers, cellsEL, subseg);
   else
-    iterateFull (theTowers, theCells);
+    iterateFull (theTowers, cellsEL);
 
   return StatusCode::SUCCESS;
 }
diff --git a/LArCalorimeter/LArRecUtils/src/LArFCalTowerBuilderTool.h b/LArCalorimeter/LArRecUtils/src/LArFCalTowerBuilderTool.h
index b15765434b1fb5a7f58312a712875c8ea3264baf..306a3f0bd7307ce7ceb1cdfef0e0de8d89c63265 100644
--- a/LArCalorimeter/LArRecUtils/src/LArFCalTowerBuilderTool.h
+++ b/LArCalorimeter/LArRecUtils/src/LArFCalTowerBuilderTool.h
@@ -72,12 +72,12 @@ private:
   typedef LArFCalTowerStore::tower_iterator tower_iterator;
 
   void addTower (const tower_iterator& t,
-                 const CaloCellContainer* cells,
+                 const ElementLink<CaloCellContainer>& cellsEL,
                  CaloTower* tower) const;
   void iterateFull (CaloTowerContainer* towers,
-                    const CaloCellContainer* cells) const;
+                    const ElementLink<CaloCellContainer>& cellsEL) const;
   void iterateSubSeg (CaloTowerContainer* towers,
-                      const CaloCellContainer* cells,
+                      const ElementLink<CaloCellContainer>& cellsEL,
                       const CaloTowerSeg::SubSeg* subseg) const;
 
 
diff --git a/LumiBlock/LumiCalc/LumiCalc/CoolQuery.h b/LumiBlock/LumiCalc/LumiCalc/CoolQuery.h
index b59d75a04ac477db1afeba8a22b69df2cae68c34..3f86f363e04073575b2a337578b66f3e4531a6b3 100644
--- a/LumiBlock/LumiCalc/LumiCalc/CoolQuery.h
+++ b/LumiBlock/LumiCalc/LumiCalc/CoolQuery.h
@@ -14,9 +14,7 @@
 #include "CoolKernel/IFolderSet.h"
 #include "CoolKernel/IObject.h"
 #include "CoolKernel/IObjectIterator.h"
-#include "CoolKernel/Exception.h"
 #include "CoolKernel/pointers.h"
-#include "CoolKernel/IDatabaseSvc.h"
 #include "CoolApplication/DatabaseSvcFactory.h"
 #include "LumiCalc/ReplicaSorter.h"
 
@@ -45,15 +43,9 @@
 #include <vector>
 #include <map>
 
-// boost includes
-//#include <boost/unordered_map.hpp>
-
 // logger
 #include "GoodRunsLists/TMsgLogger.h"
 
-// magic includes
-//#include <magic.h>
-
 //================================================
 // Simple class to hold
 
diff --git a/MagneticField/MagFieldConditions/MagFieldConditions/AtlasFieldCacheCondObj.h b/MagneticField/MagFieldConditions/MagFieldConditions/AtlasFieldCacheCondObj.h
index 61e5be32d80b329fb1d83330a6713e884437dc26..895c203e2a189c37c88986ed0553d47758c77243 100644
--- a/MagneticField/MagFieldConditions/MagFieldConditions/AtlasFieldCacheCondObj.h
+++ b/MagneticField/MagFieldConditions/MagFieldConditions/AtlasFieldCacheCondObj.h
@@ -59,7 +59,6 @@ AtlasFieldCacheCondObj::getInitializedCache (MagField::AtlasFieldCache& cache) c
 
 #include "AthenaKernel/CLASS_DEF.h"
 CLASS_DEF( AtlasFieldCacheCondObj, 258146572, 1)
-#include "AthenaKernel/CondCont.h"
 CONDCONT_DEF (AtlasFieldCacheCondObj, 3622068);
 
 
diff --git a/MagneticField/MagFieldConditions/MagFieldConditions/AtlasFieldMapCondObj.h b/MagneticField/MagFieldConditions/MagFieldConditions/AtlasFieldMapCondObj.h
index 3f197a6bffc96a2303f60fdfc0dd4e9f6153c65b..458cefafeeb1f4601c45acfa7b5f0888125aa76b 100644
--- a/MagneticField/MagFieldConditions/MagFieldConditions/AtlasFieldMapCondObj.h
+++ b/MagneticField/MagFieldConditions/MagFieldConditions/AtlasFieldMapCondObj.h
@@ -30,7 +30,6 @@ private:
 
 #include "AthenaKernel/CLASS_DEF.h"
 CLASS_DEF( AtlasFieldMapCondObj, 122915602, 1)
-#include "AthenaKernel/CondCont.h"
 CONDCONT_DEF (AtlasFieldMapCondObj, 249359246);
 
 
diff --git a/MagneticField/MagFieldServices/CMakeLists.txt b/MagneticField/MagFieldServices/CMakeLists.txt
index ebf11dfafe4e445ffb0e875c8d797578a388980f..bf30009392e58f5cca7a4408049ff7b237ef6bed 100644
--- a/MagneticField/MagFieldServices/CMakeLists.txt
+++ b/MagneticField/MagFieldServices/CMakeLists.txt
@@ -12,7 +12,7 @@ atlas_add_component( MagFieldServices
                      src/*.cxx
                      src/components/*.cxx
                      INCLUDE_DIRS ${ROOT_INCLUDE_DIRS} ${CLHEP_INCLUDE_DIRS}
-                     LINK_LIBRARIES ${CLHEP_LIBRARIES} ${ROOT_LIBRARIES} AthenaBaseComps AthenaPoolUtilities CxxUtils EventInfo GaudiKernel MagFieldConditions MagFieldElements MagFieldInterfaces PathResolver StoreGateLib )
+                     LINK_LIBRARIES ${CLHEP_LIBRARIES} ${ROOT_LIBRARIES} AthenaBaseComps AthenaPoolUtilities CxxUtils EventInfoMgtLib GaudiKernel MagFieldConditions MagFieldElements MagFieldInterfaces PathResolver StoreGateLib )
 
 # Install files from the package:
 atlas_install_headers( MagFieldServices )
diff --git a/MagneticField/MagFieldServices/MagFieldServices/AtlasFieldMapCondAlg.h b/MagneticField/MagFieldServices/MagFieldServices/AtlasFieldMapCondAlg.h
index 51004fa0c054561502570d993bd19b4c3dd7d99d..ff64c6948b473e0ed267122e58bd6244d922f816 100644
--- a/MagneticField/MagFieldServices/MagFieldServices/AtlasFieldMapCondAlg.h
+++ b/MagneticField/MagFieldServices/MagFieldServices/AtlasFieldMapCondAlg.h
@@ -16,7 +16,6 @@
 #include "StoreGate/WriteCondHandleKey.h"
 #include "AthenaPoolUtilities/CondAttrListCollection.h"
 #include "GaudiKernel/ICondSvc.h"
-#include "EventInfo/TagInfo.h"
 
 // #include "MagFieldInterfaces/IMTMagFieldSvc.h"
 
@@ -115,11 +114,6 @@ namespace MagField {
 
         ServiceHandle<ICondSvc> m_condSvc { this, 
                                             "CondSvc", "CondSvc", "conditions service" };
-
-        // TagInfo object - used to get currents via TagInfoMgr
-        SG::ReadHandleKey<TagInfo> m_tagInfoKey {this,
-                                                 "TagInfo", "DetectorStore+ProcessingTags", "tag info key"};
-
     };
 }
 
diff --git a/MagneticField/MagFieldServices/src/AtlasFieldMapCondAlg.cxx b/MagneticField/MagFieldServices/src/AtlasFieldMapCondAlg.cxx
index 4726d17f0d73826ef760503f13d3a0c3edb2e610..61d3ba3de80bc87cadbd5567a0f455fe9971ae0e 100644
--- a/MagneticField/MagFieldServices/src/AtlasFieldMapCondAlg.cxx
+++ b/MagneticField/MagFieldServices/src/AtlasFieldMapCondAlg.cxx
@@ -21,8 +21,8 @@
 // PathResolver
 #include "PathResolver/PathResolver.h"
 
-// TagInfo for special case of turning off toroid or solenoid
-#include "EventInfo/TagInfo.h"
+// For TagInfo access for special case of turning off toroid or solenoid
+#include "EventInfoMgt/ITagInfoMgr.h"
 
 // ROOT
 #include "TFile.h"
@@ -47,9 +47,6 @@ MagField::AtlasFieldMapCondAlg::initialize() {
     // Read Handle for the current
     ATH_CHECK( m_currInputKey.initialize (!m_loadMapOnStart && m_useMapsFromCOOL) );
 
-    // Read Handle for tagInfo
-    ATH_CHECK( m_tagInfoKey.initialize() );
-
     // Output handle for the field map
     ATH_CHECK( m_mapCondObjOutputKey.initialize() );
 
@@ -291,35 +288,31 @@ MagField::AtlasFieldMapCondAlg::updateFieldMap(const EventContext& ctx, Cache& c
 
     if (m_useMapsFromCOOL) {
     
-        // TagInfo object - used to get currents via TagInfoMgr
-        SG::ReadHandle<TagInfo> tagInfoH{m_tagInfoKey, ctx}; 
-        if (tagInfoH.isValid()) {
-            ATH_MSG_INFO("updateFieldMap: tagInfoH " << tagInfoH.fullKey() << " is valid. ");
-            int i = 0;
-            bool resetCurrentsFromTagInfo = false;
-            for ( const auto& tag : tagInfoH->getTags() ) {
-                ATH_MSG_DEBUG("updateFieldMap: i, tags: " << i << " " << tag.first << " " << tag.second);
-                ++i;
-                if (tag.first == "MapSoleCurrent") {
-                    cache.m_mapSoleCurrent = std::stof(tag.second);
-                    resetCurrentsFromTagInfo = true;
-                    ATH_MSG_INFO("updateFieldMap: found MapSoleCurrent in TagInfo, setting the solenoid current "
-                                 << cache.m_mapSoleCurrent);
-                }
-                else 
-                    if (tag.first == "MapToroCurrent") {
-                        cache.m_mapToroCurrent = std::stof(tag.second);
-                        resetCurrentsFromTagInfo = true;
-                        ATH_MSG_INFO("updateFieldMap: found MapToroCurrent in TagInfo, setting the toroid current "
-                                     << cache.m_mapToroCurrent);
-                    }
-            }
-            if (resetCurrentsFromTagInfo) ATH_MSG_INFO("updateFieldMap: reset currents from TagInfo");
-            else                          ATH_MSG_INFO("updateFieldMap: DID NOT reset currents from TagInfo");
-        }  
-        else {
-            ATH_MSG_INFO("updateFieldMap: tagInfoH " << tagInfoH.fullKey() << " is NOT valid. ");
-        }
+       // get currents via TagInfoMgr
+       ServiceHandle<ITagInfoMgr> tagInfoMgr("TagInfoMgr", name());
+       if( tagInfoMgr.retrieve().isSuccess() ) {
+          ATH_MSG_INFO("updateFieldMap: found TagInfoMgr ");
+          bool resetCurrentsFromTagInfo = false;
+          std::string mapSoleCurrent = tagInfoMgr->findTag("MapSoleCurrent");
+          if( not mapSoleCurrent.empty() ) {
+             cache.m_mapSoleCurrent = std::stof(mapSoleCurrent);
+             resetCurrentsFromTagInfo = true;
+             ATH_MSG_INFO("updateFieldMap: found MapSoleCurrent in TagInfo, setting the solenoid current "
+                          << cache.m_mapSoleCurrent);
+          }
+          std::string mapToroCurrent = tagInfoMgr->findTag("MapToroCurrent");
+          if( not mapToroCurrent.empty() ) {
+             cache.m_mapToroCurrent = std::stof(mapToroCurrent);
+             resetCurrentsFromTagInfo = true;
+             ATH_MSG_INFO("updateFieldMap: found MapToroCurrent in TagInfo, setting the toroid current "
+                          << cache.m_mapToroCurrent);
+          }
+          if (resetCurrentsFromTagInfo) ATH_MSG_INFO("updateFieldMap: reset currents from TagInfo");
+          else                          ATH_MSG_INFO("updateFieldMap: DID NOT reset currents from TagInfo");
+       }
+       else {
+          ATH_MSG_INFO("updateFieldMap: TagInfoMgr NOT found. ");
+       }
     }
 
     // Select map file according to the value of the currents which indicate which map is 'on'
diff --git a/MuonSpectrometer/MuonCablings/MuonCablingServers/CMakeLists.txt b/MuonSpectrometer/MuonCablings/MuonCablingServers/CMakeLists.txt
index 7e27061b3f0afd3850d2a697b1aa146785cc040c..037c2fcc81178015fd6965d68cf949460bb7c409 100644
--- a/MuonSpectrometer/MuonCablings/MuonCablingServers/CMakeLists.txt
+++ b/MuonSpectrometer/MuonCablings/MuonCablingServers/CMakeLists.txt
@@ -10,11 +10,11 @@ atlas_add_library( MuonCablingServersLib
                    src/*.cxx
                    PUBLIC_HEADERS MuonCablingServers
                    LINK_LIBRARIES AthenaBaseComps AthenaKernel GaudiKernel RPCcablingInterfaceLib TGCcablingInterfaceLib StoreGateLib SGtests
-                   PRIVATE_LINK_LIBRARIES EventInfo EventInfoMgtLib )
+                   PRIVATE_LINK_LIBRARIES EventInfoMgtLib )
 
 atlas_add_component( MuonCablingServers
                      src/components/*.cxx
-                     LINK_LIBRARIES AthenaBaseComps AthenaKernel GaudiKernel RPCcablingInterfaceLib TGCcablingInterfaceLib StoreGateLib SGtests EventInfo MuonCablingServersLib )
+                     LINK_LIBRARIES AthenaBaseComps AthenaKernel GaudiKernel RPCcablingInterfaceLib TGCcablingInterfaceLib StoreGateLib SGtests EventInfoMgtLib MuonCablingServersLib )
 
 # Install files from the package:
 atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
diff --git a/MuonSpectrometer/MuonCablings/MuonCablingServers/MuonCablingServers/ICallBackRPCcablingServerSvc.h b/MuonSpectrometer/MuonCablings/MuonCablingServers/MuonCablingServers/ICallBackRPCcablingServerSvc.h
deleted file mode 100644
index f9f53e003e6fbc3202dc37d015ff0c60dcc72f9d..0000000000000000000000000000000000000000
--- a/MuonSpectrometer/MuonCablings/MuonCablingServers/MuonCablingServers/ICallBackRPCcablingServerSvc.h
+++ /dev/null
@@ -1,22 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#ifndef ICallBackRPCcablingServerSvc_H
-#define ICallBackRPCcablingServerSvc_H
-
-#ifndef LVL1_STANDALONE
-
-#include "AthenaKernel/IOVSvcDefs.h"
-
-class ICallBackRPCcablingServerSvc : virtual public IInterface 
-{
-    public:
-    virtual bool isConfigured(void) const=0;  
-    virtual StatusCode compareTags(IOVSVC_CALLBACK_ARGS)=0;
-
-};
- 
-#endif
-
-#endif  //ICallBackRPCcablingServerSvc_H
diff --git a/MuonSpectrometer/MuonCablings/MuonCablingServers/MuonCablingServers/RPCcablingServerSvc.h b/MuonSpectrometer/MuonCablings/MuonCablingServers/MuonCablingServers/RPCcablingServerSvc.h
index fd0b9983a94f98ad976be24eae4ede80f770b7a3..0b5e765dfa1e62bffd5b088af8eca0aecebf789d 100644
--- a/MuonSpectrometer/MuonCablings/MuonCablingServers/MuonCablingServers/RPCcablingServerSvc.h
+++ b/MuonSpectrometer/MuonCablings/MuonCablingServers/MuonCablingServers/RPCcablingServerSvc.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef RPCcablingServerSvc_H
@@ -9,17 +9,14 @@
 
 #include "AthenaBaseComps/AthService.h"
 #include "RPCcablingInterface/IRPCcablingServerSvc.h"
-#include "MuonCablingServers/ICallBackRPCcablingServerSvc.h"
+#include "EventInfoMgt/ITagInfoMgr.h"
 
 #include <atomic>
 
-class StoreGateSvc;
-class ITagInfoMgr;
-
-
 
 class RPCcablingServerSvc : public AthService, 
-                            virtual public IRPCcablingServerSvc, virtual public ICallBackRPCcablingServerSvc 
+                            virtual public IRPCcablingServerSvc,
+                            virtual public ITagInfoMgr::Listener
 {
     private:
     BooleanProperty m_atlas;
@@ -27,7 +24,6 @@ class RPCcablingServerSvc : public AthService,
     bool m_forcedUse;
     BooleanProperty m_useMuonRPC_CablingSvc;
 
-    StoreGateSvc* m_pDetStore;        // The Transient Detector Store Service
     ITagInfoMgr*  m_tagInfoMgr;                   // Tag Info Manager
     
 
@@ -43,9 +39,11 @@ class RPCcablingServerSvc : public AthService,
     // Interface implementation
     virtual StatusCode giveCabling(const IRPCcablingSvc*&) const;
     virtual bool isAtlas(void) const;
-    virtual bool isConfigured(void) const {return m_tagsCompared;}
+    // ITagInfoMgr callback
+    virtual void tagInfoUpdated() override final { compareTags().ignore(); }
 
-    virtual StatusCode compareTags(IOVSVC_CALLBACK_ARGS);
+    bool isConfigured(void) const {return m_tagsCompared;}
+    StatusCode compareTags();
 
 };
  
diff --git a/MuonSpectrometer/MuonCablings/MuonCablingServers/src/RPCcablingServerSvc.cxx b/MuonSpectrometer/MuonCablings/MuonCablingServers/src/RPCcablingServerSvc.cxx
index 2b1fb236a584cf0a526d36617f5c5d730cd223f1..36bd4892cee8b43df798bc35c4b2a95ccf35fefe 100644
--- a/MuonSpectrometer/MuonCablings/MuonCablingServers/src/RPCcablingServerSvc.cxx
+++ b/MuonSpectrometer/MuonCablings/MuonCablingServers/src/RPCcablingServerSvc.cxx
@@ -4,17 +4,10 @@
 
 #include "MuonCablingServers/RPCcablingServerSvc.h"
 
-#include "StoreGate/StoreGateSvc.h"
-
-#include "EventInfo/TagInfo.h"
-#include "EventInfoMgt/ITagInfoMgr.h"
-
-
 
 RPCcablingServerSvc::RPCcablingServerSvc(const std::string& name, ISvcLocator* sl) : 
   AthService( name, sl ),
   m_tagsCompared(false),
-  m_pDetStore(0),
   m_tagInfoMgr(0)
 {
 // these JO are not effective anymore, kept temporarely to avoid to change the config. pythons
@@ -48,43 +41,20 @@ RPCcablingServerSvc::initialize() {
     ATH_MSG_DEBUG ( "initializing ..." );
 
     ATH_CHECK( AthService::initialize() );
-    ATH_CHECK( service("DetectorStore", m_pDetStore ) );
 
-    StatusCode sc;
     if(m_forcedUse) { 
 	// Selected cabling is used without comparison 
         m_tagsCompared = true;
-        sc = StatusCode::SUCCESS;
     } 
     else 
     { 
-	// The cabling to be used and the cabling in tag info will be compared by compareTags method
-	// **** **** **** TagInfo **** **** ****
-	const DataHandle<TagInfo> tagInfoH;
-	std::string tagInfoKey = "";
-	// get the key
-	sc = service("TagInfoMgr", m_tagInfoMgr);
-	if(sc.isFailure() || m_tagInfoMgr==0) {
-          ATH_MSG_WARNING ( " Unable to locate TagInfoMgr service" );
-	} else {
-	    tagInfoKey = m_tagInfoMgr->tagInfoKey();
-	}
-
-        if(m_pDetStore->regFcn(&ICallBackRPCcablingServerSvc::compareTags,
-                               dynamic_cast<ICallBackRPCcablingServerSvc*>(this),
-                               tagInfoH, 
-                               tagInfoKey) 
-           != StatusCode::SUCCESS) {
-          ATH_MSG_WARNING 
-            ( "Cannot register compareTags function for key "  << tagInfoKey );
-        } else {
-          ATH_MSG_DEBUG 
-            ( "Registered compareTags callback for key: " << tagInfoKey );
-        }
+       // The cabling to be used and the cabling in tag info will be compared by compareTags method
+       ATH_CHECK( service("TagInfoMgr", m_tagInfoMgr) );
+       m_tagInfoMgr->addListener(this);
     }
 
     ATH_MSG_DEBUG ( "... done!" );
-    return sc;
+    return StatusCode::SUCCESS;
 }
 
 StatusCode
@@ -133,39 +103,24 @@ RPCcablingServerSvc::isAtlas() const {
 
 
 StatusCode 
-RPCcablingServerSvc::compareTags(IOVSVC_CALLBACK_ARGS)
+RPCcablingServerSvc::compareTags()
 {
-    
     ATH_MSG_INFO ( "compareTags() callback triggered" );
     
-    // Get TagInfo and retrieve tags
-    const TagInfo* tagInfo = 0;
-    StatusCode sc= m_pDetStore->retrieve(tagInfo);
-    
-    std::string cablingType;
+    std::string cablingType = m_tagInfoMgr->findInputTag("RPC_CablingType");
+    ATH_MSG_INFO( "RPC_CablingType from TagInfo: " << cablingType );
     
-    if (sc.isFailure() || tagInfo==0) {
-      ATH_MSG_INFO
-        ( "No TagInfo in DetectorStore while attempting to compare tags" 
-          );
-    } else {
-        tagInfo->findInputTag("RPC_CablingType", cablingType);        
-        ATH_MSG_INFO 
-          ( "RPC_CablingType from TagInfo: " << cablingType );
-	
-	if(cablingType=="") {
-            // assume it is SIM in case the call-back is active
-            //            cablingType="RPCcablingSim";
-            cablingType="MuonRPC_Cabling";
-        }
-        
-	// check cablingType
-        if (cablingType != "MuonRPC_Cabling"){
-          ATH_MSG_ERROR( "RPC_CablingType from TagInfo is "
-                         << cablingType
-                         << "  , incompatible with present cabling package MuonRPC_Cabling" );
-          return StatusCode::FAILURE;
-        }
+    if(cablingType=="") {
+       // assume it is SIM in case the call-back is active
+       //            cablingType="RPCcablingSim";
+       cablingType="MuonRPC_Cabling";
+    }
+    // check cablingType
+    if (cablingType != "MuonRPC_Cabling"){
+       ATH_MSG_ERROR( "RPC_CablingType from TagInfo is "
+                      << cablingType
+                      << "  , incompatible with present cabling package MuonRPC_Cabling" );
+       return StatusCode::FAILURE;
     }
     m_tagsCompared=true;
     return StatusCode::SUCCESS;
diff --git a/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/CMakeLists.txt b/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/CMakeLists.txt
index cb508de6fefd395603772b1f8cab4a59817c3089..56309bff5d4935222e1d9e9b228777c0523d3031 100644
--- a/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/CMakeLists.txt
+++ b/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/CMakeLists.txt
@@ -9,10 +9,10 @@ atlas_subdir( MuonMDT_Cabling )
 atlas_add_library( MuonMDT_CablingLib
                    src/*.cxx
                    PUBLIC_HEADERS MuonMDT_Cabling
-                   LINK_LIBRARIES AthenaBaseComps AthenaKernel GaudiKernel StoreGateLib SGtests MuonIdHelpersLib MuonCondInterface MuonCablingData AthenaPoolUtilities
-                   PRIVATE_LINK_LIBRARIES  Identifier EventInfo MuonCondSvcLib PathResolver EventInfoMgtLib )
+                   LINK_LIBRARIES AthenaBaseComps AthenaKernel GaudiKernel StoreGateLib SGtests MuonIdHelpersLib MuonCondInterface MuonCablingData AthenaPoolUtilities EventInfoMgtLib
+                   PRIVATE_LINK_LIBRARIES  Identifier MuonCondSvcLib PathResolver )
 
 atlas_add_component( MuonMDT_Cabling
                      src/components/*.cxx
-                     LINK_LIBRARIES GaudiKernel MuonMDT_CablingLib )
+                     LINK_LIBRARIES GaudiKernel EventInfoMgtLib MuonMDT_CablingLib )
 
diff --git a/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/MuonMDT_Cabling/MuonMDT_CablingSvc.h b/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/MuonMDT_Cabling/MuonMDT_CablingSvc.h
index 83770fdca77d7eb08603fd61bd15f53f1fc02bae..9969f1b82fc1b2bade820b7b379a24b937ce533f 100644
--- a/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/MuonMDT_Cabling/MuonMDT_CablingSvc.h
+++ b/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/MuonMDT_Cabling/MuonMDT_CablingSvc.h
@@ -5,17 +5,16 @@
 #ifndef MUONMDT_CABLING_MUONMDT_CABLINGSVC_H
 #define MUONMDT_CABLING_MUONMDT_CABLINGSVC_H
 
-#include "AthenaKernel/IOVSvcDefs.h"
 #include "AthenaBaseComps/AthService.h"
 #include "GaudiKernel/IInterface.h"
 #include "GaudiKernel/ToolHandle.h"
 #include "GaudiKernel/ServiceHandle.h"
+#include "EventInfoMgt/ITagInfoMgr.h"
 
 class MuonMDT_CablingMap;
 class MdtMezzanineType;
 class StoreGateSvc;
 class IMDTCablingDbTool;
-class ITagInfoMgr;
 class IdentifierHash;
 
 #include <list>
@@ -23,8 +22,10 @@ class IdentifierHash;
 
 static const InterfaceID IID_IMuonMDT_CablingSvc("MuonMDT_CablingSvc", 1, 0);
 
-class MuonMDT_CablingSvc : public AthService  {
 
+class MuonMDT_CablingSvc : public AthService ,
+			   virtual public ITagInfoMgr::Listener
+{
  public:
 
   MuonMDT_CablingSvc(const std::string& name,ISvcLocator* sl);
@@ -99,7 +100,10 @@ class MuonMDT_CablingSvc : public AthService  {
 		   uint8_t& tdcId, uint8_t& channelId);
 
 
-  virtual StatusCode compareTags(IOVSVC_CALLBACK_ARGS);
+   // TagInfoMgr callback
+   virtual void tagInfoUpdated() override final { compareTags().ignore(); }
+
+   StatusCode compareTags();
 
   /** Returns true if we're using the old (non-DB) cabling*/
   bool usingOldCabling() const;
diff --git a/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/src/MuonMDT_CablingSvc.cxx b/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/src/MuonMDT_CablingSvc.cxx
index 23b380bbf59239a9e4c8f18942741c24d732bd1e..d5f66c5c7d1db0d93b2f7d2073176274f389edfa 100644
--- a/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/src/MuonMDT_CablingSvc.cxx
+++ b/MuonSpectrometer/MuonCablings/MuonMDT_Cabling/src/MuonMDT_CablingSvc.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "MuonMDT_Cabling/MuonMDT_CablingSvc.h"
@@ -18,8 +18,6 @@
 #include "MuonCondInterface/IMDTCablingDbTool.h"
 #include "AthenaPoolUtilities/CondAttrListCollection.h"
 
-#include "EventInfo/TagInfo.h"
-#include "EventInfoMgt/ITagInfoMgr.h"
 
 MuonMDT_CablingSvc::MuonMDT_CablingSvc(const std::string& svcName,ISvcLocator* sl) :
 AthService(svcName,sl),
@@ -81,23 +79,8 @@ StatusCode MuonMDT_CablingSvc::initialize()
         msg(MSG::DEBUG)<< "'ForcedUse' property is set to 'True', so disabling the callback. Configuration fixed to: "<<(m_useOldCabling ? "'Old MDT Cabling'" : "'New MDT Cabling'") << endmsg;     
     } else { 
         // The cabling to be used and the cabling in tag info will be compared by compareTags method
-        const DataHandle<TagInfo> tagInfoH;
-        std::string tagInfoKey = "";
-       // get the key
-        if(m_tagInfoMgr.retrieve().isFailure() || m_tagInfoMgr==0) {
-            msg(MSG::WARNING) << " Unable to locate TagInfoMgr service" << endmsg; 
-        } else {
-            tagInfoKey = m_tagInfoMgr->tagInfoKey();
-        }
-        if(m_detStore->regFcn(&MuonMDT_CablingSvc::compareTags,
-            this,
-            tagInfoH, 
-            tagInfoKey) 
-        != StatusCode::SUCCESS) {
-            msg(MSG::WARNING)<< "Cannot register compareTags function for key "  << tagInfoKey << endmsg;
-        } else {
-            msg(MSG::DEBUG)<< "Registered compareTags callback for key: " << tagInfoKey << endmsg;
-        }
+       ATH_CHECK( m_tagInfoMgr.retrieve() );
+       m_tagInfoMgr->addListener(this);
     }
 
   /** Get a pointer to the old cabling if needed */
@@ -169,7 +152,7 @@ StatusCode MuonMDT_CablingSvc::initialize()
 /** Finalization method */
 StatusCode MuonMDT_CablingSvc::finalize()
 {
-    return StatusCode::SUCCESS;
+   return StatusCode::SUCCESS;
 }
 
 
@@ -186,8 +169,7 @@ StatusCode MuonMDT_CablingSvc::queryInterface(const InterfaceID& riid, void** pp
     return StatusCode::SUCCESS;
 } 
 
-StatusCode 
-    MuonMDT_CablingSvc::compareTags(IOVSVC_CALLBACK_ARGS)
+StatusCode MuonMDT_CablingSvc::compareTags()
 {
     StatusCode sc;
     msg(MSG::DEBUG) << "compareTags() callback triggered. Current configuration is: "<<(m_useOldCabling ? "OldMDT_Cabling" : "NewMDT_Cabling") << endmsg;
@@ -199,46 +181,32 @@ StatusCode
         return StatusCode::SUCCESS;
     }
 
-    // Get TagInfo and retrieve tags
-    const TagInfo* tagInfo = 0;
-    StoreGateSvc* detStore=0;
-    sc = serviceLocator()->service("DetectorStore", detStore);
-    sc= detStore->retrieve(tagInfo);
+    std::string cablingType = m_tagInfoMgr->findInputTag("MDT_CablingType");
+    msg(MSG::DEBUG)<< "MDT_CablingType from TagInfo: " << cablingType << endmsg;
 
-    std::string cablingType;
+    // either have empty cabling tag and set to old cabling, or new and don't use old cabling
+    bool tagMatch = (cablingType=="" && m_useOldCabling) || (cablingType == "NewMDT_Cabling"&& !m_useOldCabling);
 
-    if (sc.isFailure() || tagInfo==0) {
-        msg(MSG::WARNING)<< "No TagInfo in DetectorStore while attempting to compare tags. Will use current configuration: "<<(m_useOldCabling ? "OldMDT_Cabling" : "NewMDT_Cabling") << endmsg;
-        return StatusCode::RECOVERABLE;
-    } else {
-        tagInfo->findInputTag("MDT_CablingType", cablingType);
-
-        msg(MSG::DEBUG)<< "MDT_CablingType from TagInfo: " << cablingType << endmsg;
-
-	// either have empty cabling tag and set to old cabling, or new and don't use old cabling
-        bool tagMatch = (cablingType=="" && m_useOldCabling) || (cablingType == "NewMDT_Cabling"&& !m_useOldCabling);  
-
-        if (!tagMatch) {
-          // Trying to use wrong cabling map! Flip configuration
+    if (!tagMatch) {
+       // Trying to use wrong cabling map! Flip configuration
      
-         if (m_useOldCabling) {
-            m_useOldCabling = false;
-            m_firstAccess=true;
-            //retrieve tool now to avoid unpleasent surprises later!
-            if ( m_dbTool.retrieve().isFailure()) {
-               msg(MSG::WARNING)<< "Could not find tool " << m_dbTool << ". Exiting."<< endmsg;
-               return StatusCode::FAILURE;
-            }
-          } else {
-            m_useOldCabling = true;
-            m_firstAccess=false;
+       if (m_useOldCabling) {
+          m_useOldCabling = false;
+          m_firstAccess=true;
+          //retrieve tool now to avoid unpleasent surprises later!
+          if ( m_dbTool.retrieve().isFailure()) {
+             msg(MSG::WARNING)<< "Could not find tool " << m_dbTool << ". Exiting."<< endmsg;
+             return StatusCode::FAILURE;
           }
-
-          msg(MSG::INFO)<< "MDT_CablingType : " << cablingType << " is mismatched "
-            << "with configuration of this service ."
-            << "m_useOldCabling flag is flipped to " << (m_useOldCabling ? "true" : "false") << " ." 
-            << endmsg; 
-        }
+       } else {
+          m_useOldCabling = true;
+          m_firstAccess=false;
+       }
+
+       msg(MSG::INFO)<< "MDT_CablingType : " << cablingType << " is mismatched "
+                     << "with configuration of this service ."
+                     << "m_useOldCabling flag is flipped to " << (m_useOldCabling ? "true" : "false") << " ."
+                     << endmsg;
     }
 
     msg(MSG::INFO)<< "compareTags() callback determined that the taginfo for MDT cabling is: "<< cablingType << " (blank = old). Current configuration is: "
diff --git a/MuonSpectrometer/MuonCnv/MuonByteStreamCnvTest/CMakeLists.txt b/MuonSpectrometer/MuonCnv/MuonByteStreamCnvTest/CMakeLists.txt
index 9b5aa850b53e874322eb3a84facd2572954c7114..2d70053641422e41b9c735ad5384e16842a526b9 100644
--- a/MuonSpectrometer/MuonCnv/MuonByteStreamCnvTest/CMakeLists.txt
+++ b/MuonSpectrometer/MuonCnv/MuonByteStreamCnvTest/CMakeLists.txt
@@ -10,7 +10,7 @@ atlas_add_library( MuonByteStreamCnvTestLib
                    src/*.cxx
                    PUBLIC_HEADERS MuonByteStreamCnvTest
                    LINK_LIBRARIES AthenaBaseComps GaudiKernel MuonReadoutGeometry MuonRDO StoreGateLib SGtests RPCcablingInterfaceLib TrigT1RPChardwareLib TrigT1RPClogicLib MuonMDT_CablingLib TGCcablingInterfaceLib MuonIdHelpersLib RPC_CondCablingLib MuonDigToolInterfacesLib CscCalibToolsLib MuonDigitContainer
-                   PRIVATE_LINK_LIBRARIES EventInfo MuonPrepRawData MuonCablingData MuonMDT_CnvToolsLib MuonMM_CnvToolsLib MuonCSC_CnvToolsLib MuonRPC_CnvToolsLib MuonTGC_CnvToolsLib MuonSTGC_CnvToolsLib EventInfoMgtLib )
+                   PRIVATE_LINK_LIBRARIES MuonPrepRawData MuonCablingData MuonMDT_CnvToolsLib MuonMM_CnvToolsLib MuonCSC_CnvToolsLib MuonRPC_CnvToolsLib MuonTGC_CnvToolsLib MuonSTGC_CnvToolsLib EventInfoMgtLib )
 
 atlas_add_component( MuonByteStreamCnvTest
                      src/components/*.cxx
diff --git a/MuonSpectrometer/MuonCnv/MuonByteStreamCnvTest/src/MdtDigitToMdtRDO.cxx b/MuonSpectrometer/MuonCnv/MuonByteStreamCnvTest/src/MdtDigitToMdtRDO.cxx
index 7d26d9ffd4fd9d8d0ec4502faece58980a99e47c..ba019a80ce4963c19c47919b7c94ef6096169c44 100644
--- a/MuonSpectrometer/MuonCnv/MuonByteStreamCnvTest/src/MdtDigitToMdtRDO.cxx
+++ b/MuonSpectrometer/MuonCnv/MuonByteStreamCnvTest/src/MdtDigitToMdtRDO.cxx
@@ -205,13 +205,13 @@ StatusCode MdtDigitToMdtRDO::fill_MDTdata(const EventContext& ctx) const {
           // as long as there is no BIS sMDT cabling, to avoid a hard crash, replace the tubeNumber
           // of tubes not covered in the cabling by 1
           if (m_idHelperSvc->mdtIdHelper().stationName(channelId)==1
-             && std::abs(m_idHelperSvc->mdtIdHelper().stationEta(channelId))>6
              && m_idHelperSvc->issMdt(channelId)) {
+             unsigned int theLayer = (layer==4) ? 3 : layer;
              if (!bisWarningPrinted) {
-               ATH_MSG_WARNING("Found BIS sMDT with tubeLayer="<<layer<<" and tubeNumber="<<tube<<". Setting to 1,1 until a proper cabling is implemented, cf. ATLASRECTS-5804");
+               ATH_MSG_WARNING("Found BIS sMDT with tubeLayer="<<layer<<" and tubeNumber="<<tube<<". Setting to "<<theLayer<<",1 until a proper cabling is implemented, cf. ATLASRECTS-5804");
                bisWarningPrinted.store(true, std::memory_order_relaxed);
              }
-             cabling = readCdo->getOnlineId(name, eta, phi, multilayer, 1, 1,subsystem, mrod, link, tdc, channel);
+             cabling = readCdo->getOnlineId(name, eta, phi, multilayer, theLayer, 1,subsystem, mrod, link, tdc, channel);
           }
           if (!cabling) {
             ATH_MSG_ERROR( "MDTcabling can't return an online ID for the channel : "  );
diff --git a/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/MuonCondSvc/TGCTriggerData.h b/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/MuonCondSvc/TGCTriggerData.h
index 984c4c4661b184f95df2123a9a0878f2d4ea793c..2f926924555d63e59d30ffac5764a291b92946f2 100644
--- a/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/MuonCondSvc/TGCTriggerData.h
+++ b/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/MuonCondSvc/TGCTriggerData.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TGCTRIGGERDATA_H
@@ -9,71 +9,112 @@
 #include "AthenaKernel/CLASS_DEF.h"
 #include <string>
 #include <map>
-#include <fstream>
-
-class TGCTriggerData {
-
-  friend class TGCTriggerDbAlg;
-
-  public:
-
-    enum {CW_BW=0, CW_EIFI=1, CW_TILE=2, CW_NUM=3}; 
-    enum {N_PT_THRESH=6,
-          N_SIDE=2,
-          N_OCTANT=8,
-          N_ENDCAP_SSC=19,
-          N_ENDCAP_SECTOR=48,
-          N_ROI_IN_SSC=8,
-          N_EIFI_INPUT=4,
-          N_EIFI_REGION=2,
-          N_EIFI_READOUT=2,
-          N_EIFI_TRIGBIT=4,
-          N_TILE_INPUT=4};
-
-    TGCTriggerData();
-    virtual ~TGCTriggerData();
-
-    std::string getData(int cwtype, std::string file) const;
-    std::string getData(int cwtype, int channel) const;
-    std::string getFile(int cwtype, int channel) const;
-    std::string getVersion(int cwtype, int channel = 0) const;
-    std::string getType(int cwtype, int channel = 0) const;
-    bool isActive(int cwtype, int channel = 0) const;
-
-    std::map<int, std::map<int,int> > getReadMapBw(int side, int octantId, int pt) const;
-
-    bool getTrigBitEifi(int side, int slot, int ssc, int sectorId, int reg, int read, int bit) const;  
-    int getFlagPtEifi(int side, int pt, int ssc, int sectorId) const;  
-    int getFlagRoiEifi(int side, int roi, int ssc, int sectorId) const;  
-
-    int getTrigMaskTile(int slot, int ssc, int sectorId, int side) const;  
-    int getFlagPtTile(int pt, int ssc, int sectorId, int side) const;  
-    int getFlagRoiTile(int roi, int ssc, int sectorId, int side) const;  
-
-  private:
-
-    std::map<std::string, std::string> m_datamap[CW_NUM];
-    std::vector<std::string> m_data[CW_NUM];
-    std::vector<std::string> m_file[CW_NUM];
-    std::vector<std::string> m_version[CW_NUM];
-    std::vector<std::string> m_type[CW_NUM];
-    std::vector<bool>        m_active[CW_NUM];
-  
-    std::map<int, std::map<int,int> > m_readmap_bw[N_SIDE][N_OCTANT][N_PT_THRESH];
-
-    bool m_trigbit_eifi[N_SIDE][N_EIFI_INPUT][N_ENDCAP_SSC][N_ENDCAP_SECTOR][N_EIFI_REGION][N_EIFI_READOUT][N_EIFI_TRIGBIT];
-    int  m_flagpt_eifi[N_SIDE][N_PT_THRESH][N_ENDCAP_SSC][N_ENDCAP_SECTOR];
-    int  m_flagroi_eifi[N_SIDE][N_ROI_IN_SSC][N_ENDCAP_SSC][N_ENDCAP_SECTOR];
-
-    int m_trigbit_tile[N_TILE_INPUT][N_ENDCAP_SSC][N_ENDCAP_SECTOR][N_SIDE]; 
-    int m_flagpt_tile[N_PT_THRESH][N_ENDCAP_SSC][N_ENDCAP_SECTOR][N_SIDE];
-    int m_flagroi_tile[N_ROI_IN_SSC][N_ENDCAP_SSC][N_ENDCAP_SECTOR][N_SIDE];
+#include <vector>
+
+class TGCTriggerData
+{
+ friend class TGCTriggerDbAlg;
+
+ public:
+  enum {CW_BW=0, CW_EIFI=1, CW_TILE=2, CW_NUM=3};
+  enum {N_PT_THRESH=6,
+        N_SIDE=2,
+        N_OCTANT=8,
+        N_ENDCAP_SSC=19,
+        N_ENDCAP_SECTOR=48,
+        N_ROI_IN_SSC=8,
+        N_EIFI_INPUT=4,
+        N_EIFI_REGION=2,
+        N_EIFI_READOUT=2,
+        N_EIFI_TRIGBIT=4,
+        N_TILE_INPUT=4};
+  enum {COIN_HH=0x0, COIN_HL=0x1, COIN_LH=0x2, COIN_LL=0x3};
+
+  TGCTriggerData();
+  virtual ~TGCTriggerData();
+
+  std::string getData(int cwtype, std::string file) const;
+  std::string getData(int cwtype, int channel) const;
+  std::string getFile(int cwtype, int channel) const;
+  std::string getVersion(int cwtype, int channel = 0) const;
+  std::string getType(int cwtype, int channel = 0) const;
+  bool isActive(int cwtype, int channel = 0) const;
+
+  const std::map<unsigned short, std::map<unsigned short, unsigned char>>& getPtMapBw(const unsigned char side, const unsigned char octant) const;
+
+  unsigned short getTrigBitEifi(int side, int slot, int ssc, int sectorId) const;
+  unsigned char getFlagPtEifi(int side, int ssc, int sectorId) const;
+  unsigned char getFlagRoiEifi(int side, int ssc, int sectorId) const;
+
+  unsigned short getTrigMaskTile(int ssc, int sectorId, int side) const;
+  unsigned char getFlagPtTile(int ssc, int sectorId, int side) const;
+  unsigned char getFlagRoiTile(int ssc, int sectorId, int side) const;
+
+ private:
+  std::map<std::string, std::string> m_datamap[CW_NUM];
+  std::vector<std::string> m_data[CW_NUM];
+  std::vector<std::string> m_file[CW_NUM];
+  std::vector<std::string> m_version[CW_NUM];
+  std::vector<std::string> m_type[CW_NUM];
+  std::vector<bool>        m_active[CW_NUM];
+
+  /** Contents of Run-2 BW-CW LUT
+   *  ===========================
+   *     map<OCTANT, map<SUBSECADDR, map<DELTAADDR, PTVALUE> > >
+   *  where
+   *   OCTANT     |  4 bits | unsigned char  | side(A=0, C=1)<<3 & octant(0...7)
+   *   SUBSECADDR | 16 bits | unsigned short | consists of type, phimod2, module, and roi
+   *   DELTAADDR  |  9 bits | unsigned short | DR(0...0x1f for -15...15)<<4 & DPhi(0...0xf for -7...7)
+   *   PTVALUE    |  3 bits | unsigned char  | pT value (0x0 and 0x7 is no cand.)
+   *
+   *  for SUBSECADDR
+   *  | 15 | 14 | 13 |    12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
+   *  |  0 |  type   | phimod2 |      module     |              RoI              |
+   *  where type = 0x0 (HH), 0x1 (HL), 0x2 (LH), 0x3 (LL): HL means 3-station-wire and 2-station-strip.
+   *  This may reduce the malloc size when the fullCW option is not used.
+   */
+  std::map<unsigned char, std::map<unsigned short, std::map<unsigned short, unsigned char>>> m_ptmap_bw;
+
+//  std::map<int, std::map<int,int> > m_readmap_bw[N_SIDE][N_OCTANT][N_PT_THRESH];
+
+  /** Bit information of Run-2 EIFI-LUT
+   *  =================================
+   *  bits for each input
+   *  |                   EI                ||           FI                  |
+   *  |       Strip       |        Wire     ||     Strip     |     Wire      |
+   *  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 || 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
+   *  | <--L   phi   S--> | <--L  eta  S--> || <--L phi S--> | <--L eta  S-->|
+   *  where each sensor consists of 4 bits information.
+   *
+   *  Note: Only if fullCW option is true, the different db file per side is read.
+   *        Therefore, the contents are stored by std::vector of side index (A=0, C=1).
+   */
+  std::vector<unsigned short> m_trigbit_eifi[N_ENDCAP_SECTOR][N_ENDCAP_SSC][N_EIFI_INPUT];
+  std::vector<unsigned char> m_flagpt_eifi[N_ENDCAP_SECTOR][N_ENDCAP_SSC];   //< bits for applied pT (N_PT_THRESH)
+  std::vector<unsigned char> m_flagroi_eifi[N_ENDCAP_SECTOR][N_ENDCAP_SSC];  //< bits for applied RoI in SSC (N_ROI_IN_SSC)
+
+  /** Bit information of Run-2 Tile-LUT
+   *  =================================
+   *  bits for each input
+   *  | Module D (Tile=3) || Module C (Tile=2) || Module B (Tile=1) || Module A (Tile=0) |
+   *  | 15 | 14 | 13 | 12 || 11 | 10 |  9 |  8 || 7 |  6 |  5  |  4 || 3 |  2 |  1  |  0 |
+   *  |  0 | LH | D56| D6 ||  0 | LH | D56| D6 || 0 | LH | D56 | D6 || 0 | LH | D56 | D6 |
+   *  for each Module:
+   *   [1:0] hit with cell information: D6=0x1, D56=0x3
+   *   [2]   Low/High threshold: 1 = H, 0=L
+   *   e.g.) 0x7 = D5+D6 energy exceeds the high threshold
+   *
+   *   Note: One db file consists of whole sector information as a fullCW.
+   */
+  unsigned short m_trigbit_tile[N_ENDCAP_SSC][N_ENDCAP_SECTOR][N_SIDE];
+  unsigned char m_flagpt_tile[N_ENDCAP_SSC][N_ENDCAP_SECTOR][N_SIDE];   //< bits for applied pT (N_PT_THRESH)
+  unsigned char m_flagroi_tile[N_ENDCAP_SSC][N_ENDCAP_SECTOR][N_SIDE];  //< bits for applied RoI in SSC (N_ROI_IN_SSC)
 
 };
 
-CLASS_DEF(TGCTriggerData, 72345188, 1)
+CLASS_DEF(TGCTriggerData, 72345188, 2)
 
 #include "AthenaKernel/CondCont.h"
-CLASS_DEF(CondCont<TGCTriggerData>, 96649668, 1)
+CLASS_DEF(CondCont<TGCTriggerData>, 96649668, 2)
 
 #endif // TGCTRIGGERDATA_H
diff --git a/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/MuonCondSvc/TGCTriggerDbAlg.h b/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/MuonCondSvc/TGCTriggerDbAlg.h
index 435af98cf29ffccbdab743e8a6404e3c26bbeb49..9b0625987b5a7a6ddbeae0332c5b4144b07dbfb7 100644
--- a/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/MuonCondSvc/TGCTriggerDbAlg.h
+++ b/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/MuonCondSvc/TGCTriggerDbAlg.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TGCTRIGGERDBALG_H
@@ -12,10 +12,9 @@
 #include "AthenaPoolUtilities/CondAttrListCollection.h"
 #include "MuonCondSvc/TGCTriggerData.h"
 
-class TGCTriggerDbAlg: public AthAlgorithm {
-
+class TGCTriggerDbAlg: public AthAlgorithm
+{
   public:
-
     TGCTriggerDbAlg (const std::string& name, ISvcLocator* pSvcLocator);
     virtual ~TGCTriggerDbAlg() = default;
     virtual StatusCode initialize() override;
@@ -23,13 +22,11 @@ class TGCTriggerDbAlg: public AthAlgorithm {
     virtual StatusCode finalize() override;
  
   protected:
-
-    enum {TMap_HH=0, TMap_HL, TMap_LH, TMap_LL, N_TMap};
-    int getTYPE(int lDR, int hDR, int lDPhi, int hDPhi) const;
-    int SUBSECTORADD(int ssid, int modid, int phimod2, int type) const;
+    char getTYPE(const short lDR, const short hDR, const short lDPhi, const short hDPhi) const;
+    unsigned short getRoIAddr(const char type, const unsigned char phimod2, 
+                              const unsigned short module, const unsigned short roi) const;
  
   private:
-    
     void loadParameters(TGCTriggerData* writeCdo,
                         const CondAttrListCollection* readKey,
                         int cw_type);
@@ -38,7 +35,6 @@ class TGCTriggerDbAlg: public AthAlgorithm {
     void fillTrigBitEifi(TGCTriggerData* writeCdo);
     void fillTrigBitTile(TGCTriggerData* writeCdo);
 
-
     SG::ReadCondHandleKey<CondAttrListCollection> m_readKey_bw;
     SG::ReadCondHandleKey<CondAttrListCollection> m_readKey_eifi;
     SG::ReadCondHandleKey<CondAttrListCollection> m_readKey_tile;
diff --git a/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/src/TGCTriggerData.cxx b/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/src/TGCTriggerData.cxx
index 709a6ce885f9f421470067bf05398e88b5f734c7..6a015fcbe01bf5736d67724005fa61ed45186cb7 100644
--- a/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/src/TGCTriggerData.cxx
+++ b/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/src/TGCTriggerData.cxx
@@ -1,19 +1,15 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "MuonCondSvc/TGCTriggerData.h"
 #include "AthenaBaseComps/AthMessaging.h"
 
 TGCTriggerData::TGCTriggerData()
-{  
-}
-
+{}
 
 TGCTriggerData::~TGCTriggerData()
-{  
-}
-
+{}
 
 std::string TGCTriggerData::getData(int cwtype, std::string file) const {
   auto itr = m_datamap[cwtype].find(file);
@@ -47,30 +43,43 @@ bool TGCTriggerData::isActive(int cwtype, int channel) const {
   return m_active[cwtype][channel];
 }
 
-std::map<int, std::map<int,int> > TGCTriggerData::getReadMapBw(int side, int octantId, int pt) const {
-  return m_readmap_bw[side][octantId][pt];
+const std::map<unsigned short, std::map<unsigned short, unsigned char>>& TGCTriggerData::getPtMapBw(const unsigned char side, const unsigned char octant) const
+{
+  unsigned char octantbit = (side<<3) + octant;
+  std::map<unsigned char, std::map<unsigned short, std::map<unsigned short, unsigned char>>>::const_iterator it = m_ptmap_bw.find(octantbit);
+  if(it == m_ptmap_bw.end()) return m_ptmap_bw.find(0)->second;  // also for non-full-CW
+  return it->second;
 }
 
-bool TGCTriggerData::getTrigBitEifi(int side, int slot, int ssc, int sectorId, int reg, int read, int bit) const {
-  return m_trigbit_eifi[side][slot][ssc][sectorId][reg][read][bit];
+unsigned short TGCTriggerData::getTrigBitEifi(int side, int slot, int ssc, int sectorId) const
+{
+  if(m_active[CW_EIFI][0] == false) return 0;   // not required EIFI coincidence.
+  int sideindex = (this->getType(CW_EIFI) != "full") ? 0 : side;
+  return m_trigbit_eifi[sectorId][ssc][slot][sideindex];
 }
 
-int TGCTriggerData::getFlagPtEifi(int side, int pt, int ssc, int sectorId) const {
-  return m_flagpt_eifi[side][pt][ssc][sectorId];
+unsigned char TGCTriggerData::getFlagPtEifi(int side, int ssc, int sectorId) const
+{
+  if(m_active[CW_EIFI][0] == false) return 0;   // not required EIFI coincidence.
+  int sideindex = (this->getType(CW_EIFI) != "full") ? 0 : side;
+  return m_flagpt_eifi[sectorId][ssc][sideindex];
 }
 
-int TGCTriggerData::getFlagRoiEifi(int side, int roi, int ssc, int sectorId) const {
-  return m_flagroi_eifi[side][roi][ssc][sectorId];
+unsigned char TGCTriggerData::getFlagRoiEifi(int side, int ssc, int sectorId) const
+{
+  if(m_active[CW_EIFI][0] == false) return 0;   // not required EIFI coincidence.
+  int sideindex = (this->getType(CW_EIFI) != "full") ? 0 : side;
+  return m_flagroi_eifi[sectorId][ssc][sideindex];
 }
 
-int TGCTriggerData::getTrigMaskTile(int slot, int ssc, int sectorId, int side) const {
-  return m_trigbit_tile[slot][ssc][sectorId][side];
+unsigned short TGCTriggerData::getTrigMaskTile(int ssc, int sectorId, int side) const {
+  return m_trigbit_tile[ssc][sectorId][side];
 }
 
-int TGCTriggerData::getFlagPtTile(int pt, int ssc, int sectorId, int side) const {
-  return m_flagpt_tile[pt][ssc][sectorId][side];
+unsigned char TGCTriggerData::getFlagPtTile(int ssc, int sectorId, int side) const {
+  return m_flagpt_tile[ssc][sectorId][side];
 }
 
-int TGCTriggerData::getFlagRoiTile(int roi, int ssc, int sectorId, int side) const {
-  return m_flagroi_tile[roi][ssc][sectorId][side];
+unsigned char TGCTriggerData::getFlagRoiTile(int ssc, int sectorId, int side) const {
+  return m_flagroi_tile[ssc][sectorId][side];
 }
diff --git a/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/src/TGCTriggerDbAlg.cxx b/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/src/TGCTriggerDbAlg.cxx
index 1428146329f4c85c4320f590586305c4202bb34d..90ce64629775056d15027bc3d2c4765a9fd83723 100644
--- a/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/src/TGCTriggerDbAlg.cxx
+++ b/MuonSpectrometer/MuonConditions/MuonCondGeneral/MuonCondSvc/src/TGCTriggerDbAlg.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "MuonCondSvc/TGCTriggerDbAlg.h"
@@ -180,127 +180,142 @@ void TGCTriggerDbAlg::loadParameters(TGCTriggerData* writeCdo,
 }
 
 
-void TGCTriggerDbAlg::fillReadMapBw(TGCTriggerData* writeCdo) {
+void TGCTriggerDbAlg::fillReadMapBw(TGCTriggerData* writeCdo)
+{
+  for(auto peroctant : writeCdo->m_ptmap_bw) {
+    for(auto persubsec : peroctant.second) persubsec.second.clear();
+  }
 
   if (!writeCdo->isActive(TGCTriggerData::CW_BW)) {
     return;
   }
 
-  const int NMODULETYPE = 12;
-  const int NSIDE = 2;
-  const int NOCTANT = 8;
-  const int DROFFSET= -15;
- 
-  const int ModuleNumber[NMODULETYPE]       = {0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8};
-  const std::string ModuleName[NMODULETYPE] = {"0","1","2a","2b","3","4","5a","5b","6","7","8a","8b"};
-  const std::string SideName[NSIDE]         = {"A","C"};
-  const std::string OctantName[NOCTANT]     = {"0", "1", "2", "3", "4", "5", "6", "7"};
+  bool fullCW = (writeCdo->getType(TGCTriggerData::CW_BW) == "full");
+  std::string vername = writeCdo->getVersion(TGCTriggerData::CW_BW);
 
-  std::string fn, fullName, tag;
-  int ssId, ptLevel, bit, mod;
+  const int kNMODULETYPE = 12;
+  const unsigned short modulenumber[kNMODULETYPE]    = {0, 1, 2, 2, 3, 4, 5, 5, 6, 7, 8, 8};
+  const std::string modulename[kNMODULETYPE]         = {"0","1","2a","2b","3","4","5a","5b","6","7","8a","8b"};
+  const std::string sidename[TGCTriggerData::N_SIDE] = {"A","C"};
 
-  bool fullCW = (writeCdo->getType(TGCTriggerData::CW_BW) == "full" );
-  std::string verName = writeCdo->getVersion(TGCTriggerData::CW_BW);
+  for(size_t iSide = 0; iSide < TGCTriggerData::N_SIDE; iSide++) {
+    for(size_t iOctant = 0; iOctant < TGCTriggerData::N_OCTANT; iOctant++) {
 
-  for  (int iSide = 0; iSide < NSIDE; iSide++) {
-    for  (int iOctant = 0; iOctant < NOCTANT; iOctant++) {
-      for (int iModule = 0; iModule < NMODULETYPE; iModule++) {
+      std::map<unsigned short, std::map<unsigned short, unsigned char>> per_octant;
+      //   SUBSECADDR | 16 bits | unsigned int  |
 
-        int phimod2 = ModuleName[iModule].find("b") != std::string::npos ? 1 : 0;
-        std::ostringstream modName;
-        std::string fn = "RPhiCoincidenceMap.mod"
-                         + ModuleName[iModule] + "." + verName +"._12.db";
-    
-        if (fullCW) {
-          if ((iSide >= 0) && (iSide < NSIDE) && (iOctant>=0) && (iOctant < NOCTANT)) {
-            fn = "RPhiCoincidenceMap."
-                      + SideName[iSide] + OctantName[iOctant]
-                      + ".mod" + ModuleName[iModule]
-                      + "." + verName +"._12.db";
-          }
-        }
-
-        int type = -1;
-        int lDR, hDR, lDPhi, hDPhi;
-
-        std::string data = writeCdo->getData(TGCTriggerData::CW_BW, fn);
+      for(int iModule = 0; iModule < kNMODULETYPE; iModule++) {
+
+        std::ostringstream dbname;
+        dbname << "RPhiCoincidenceMap.";
+        if (fullCW) dbname << sidename[iSide] << iOctant << ".";
+        dbname << "mod" << modulename[iModule] + "." + vername +"._12.db";
+
+        std::string data = writeCdo->getData(TGCTriggerData::CW_BW, dbname.str());
         std::istringstream stream(data);
 
         char delimiter = '\n';
-        std::string field;
+        std::string field, tag;
+        unsigned char phimod2 = modulename[iModule].find("b") != std::string::npos ? 1 : 0;
+
+        std::map<unsigned short, unsigned char> pt_by_delta;
 
         while (std::getline(stream, field, delimiter)) {
 
           std::istringstream header(field);
           header>>tag;
-          if (tag == "#") { // read header part.     
+
+          if (tag == "#") { // read header part.
+            unsigned short ssId, mod;
+            short lDR, hDR, lDPhi, hDPhi;
+            unsigned short ptLevel;
             header>>ptLevel>>ssId>>mod>>lDR>>hDR>>lDPhi>>hDPhi;
-            type = getTYPE( lDR, hDR, lDPhi, hDPhi );
+
+            char type = getTYPE( lDR, hDR, lDPhi, hDPhi );
 
             // check moduleNumber and ptLevel
-            if (mod != ModuleNumber[iModule] || ptLevel > TGCTriggerData::N_PT_THRESH || type < 0 ) {
+            if (mod != modulenumber[iModule] || ptLevel > TGCTriggerData::N_PT_THRESH || type < 0 ) {
               ATH_MSG_WARNING("Invalid configuration of DB file.");
               break;
             }
 
+            unsigned short roiaddr = getRoIAddr(type, phimod2, mod, ssId);
+
             // get window data
             std::getline(stream, field, delimiter);
             std::istringstream cont(field);
-            std::map<int, int> aWindow;
 
-            for (int ir = 0; ir <= hDR-DROFFSET; ir++) {
+            for (unsigned short ir = 0; ir < 31; ir++) {
+              unsigned int bit;
               cont>>bit;
               if (bit == 0) continue; // none of window is opened in this dR
-              aWindow[ir+DROFFSET] = bit;
+
+              for(unsigned short iphi=0; iphi<15; iphi++) {
+                unsigned short delta = (ir<<4) + iphi;
+                if(bit>>iphi & 0x1) pt_by_delta[delta] = (unsigned char)(ptLevel & 0x7);
+              }
+            }
+            if((ptLevel&0x7) == 0x6) {
+              per_octant[roiaddr] = pt_by_delta;
+              pt_by_delta.clear();
             }
 
-            int addr = SUBSECTORADD(ssId,mod,phimod2,type);
-            if (writeCdo->m_readmap_bw[iSide][iOctant][ptLevel-1].find(addr)!=writeCdo->m_readmap_bw[iSide][iOctant][ptLevel-1].end()) {
-              ATH_MSG_WARNING("This subsector was already reserved.");
+          }   // end of if(tag)...
+        }   // end of while(getline...)
+      }   // end of for(iModule)
 
-            } else {
-              writeCdo->m_readmap_bw[iSide][iOctant][ptLevel-1][addr] = aWindow; 
-            }
-          } 
-        }
-      }
-    }
-  }
+      unsigned char octantbit = iSide<<3 & iOctant;
+      writeCdo->m_ptmap_bw[octantbit] = per_octant;
+
+      if(!fullCW) break;
+    }   // end of for(iOctant)
+    if(!fullCW) break;
+  }   // end of for(iSide)
 }
 
-int TGCTriggerDbAlg::getTYPE(int lDR, int hDR, int lDPhi, int hDPhi ) const {
-  int type = -1;
-  if ( (lDR==-15) && (hDR==15) && (lDPhi==-7) && (hDPhi==7))      type = TGCTriggerDbAlg::TMap_HH;
-  else if ( (lDR==-15) && (hDR==15) && (lDPhi==-3) && (hDPhi==3)) type = TGCTriggerDbAlg::TMap_HL;
-  else if ( (lDR==-7) && (hDR==7) && (lDPhi==-7) && (hDPhi==7))   type = TGCTriggerDbAlg::TMap_LH;
-  else if ( (lDR==-7) && (hDR==7) && (lDPhi==-3) && (hDPhi==3))   type = TGCTriggerDbAlg::TMap_LL;
+char TGCTriggerDbAlg::getTYPE(const short lDR, const short hDR, const short lDPhi, const short hDPhi) const
+{
+  char type = -1;
+  if ( (lDR==-15) && (hDR==15) && (lDPhi==-7) && (hDPhi==7))      type = TGCTriggerData::COIN_HH;
+  else if ( (lDR==-15) && (hDR==15) && (lDPhi==-3) && (hDPhi==3)) type = TGCTriggerData::COIN_HL;
+  else if ( (lDR==-7) && (hDR==7) && (lDPhi==-7) && (hDPhi==7))   type = TGCTriggerData::COIN_LH;
+  else if ( (lDR==-7) && (hDR==7) && (lDPhi==-3) && (hDPhi==3))   type = TGCTriggerData::COIN_LL;
   return type;
 }
 
-int TGCTriggerDbAlg::SUBSECTORADD(int ssid, int modid, int phimod2, int type) const { 
-  return (ssid+(modid<<8)+(phimod2<<12) + (type<<16) ); 
+unsigned short TGCTriggerDbAlg::getRoIAddr(const char type, const unsigned char phimod2,
+                                           const unsigned short module, const unsigned short roi) const
+{
+  return (type<<13) + ((phimod2&0x1)<<12) + ((module&0xf)<<8) + roi;
 }
 
-void TGCTriggerDbAlg::fillTrigBitEifi(TGCTriggerData* writeCdo) {
+void TGCTriggerDbAlg::fillTrigBitEifi(TGCTriggerData* writeCdo)
+{
+  // remove all entries
+  for(size_t sector=0; sector<TGCTriggerData::N_ENDCAP_SECTOR; sector++) {
+    for(size_t ssc=0; ssc<TGCTriggerData::N_ENDCAP_SSC; ssc++) {
+      for(size_t pos=0; pos<TGCTriggerData::N_EIFI_INPUT; pos++) writeCdo->m_trigbit_eifi[sector][ssc][pos].clear();
+      writeCdo->m_flagpt_eifi[sector][ssc].clear();
+      writeCdo->m_flagroi_eifi[sector][ssc].clear();
+    }
+  }
 
   if (!writeCdo->isActive(TGCTriggerData::CW_EIFI)) {
     return;
   }
 
-  const int NSIDE = 2;
-  const std::string SideName[NSIDE] = {"A","C"};
-  
   bool fullCW = (writeCdo->getType(TGCTriggerData::CW_EIFI) == "full");
-  std::string verName = writeCdo->getVersion(TGCTriggerData::CW_EIFI);
+  std::string vername = writeCdo->getVersion(TGCTriggerData::CW_EIFI);
+  const std::string sidename[TGCTriggerData::N_SIDE] = {"A","C"};
 
-  for (int iSide = 0; iSide < NSIDE; iSide++) {
+  for (int iSide = 0; iSide < TGCTriggerData::N_SIDE; iSide++) {
 
     std::string dbname="";
     if (!fullCW) {
-      dbname = "InnerCoincidenceMap." + verName + "._12.db";
+      dbname = "InnerCoincidenceMap." + vername + "._12.db";
     } else {
-      dbname = "InnerCoincidenceMap." + SideName[iSide]
-               + "." + verName + "._12.db";
+      dbname = "InnerCoincidenceMap." + sidename[iSide]
+               + "." + vername + "._12.db";
     }
 
     std::string data = writeCdo->getData(TGCTriggerData::CW_EIFI, dbname);
@@ -313,16 +328,11 @@ void TGCTriggerDbAlg::fillTrigBitEifi(TGCTriggerData* writeCdo) {
     while (std::getline(stream, field, delimiter)) {
       int sectorId = -1;
       int sscId    = -1;
-      int use[TGCTriggerData::N_PT_THRESH]  = {0, 0, 0, 0, 0, 0};
-      int roi[TGCTriggerData::N_ROI_IN_SSC] = {1, 1, 1, 1, 1, 1, 1, 1};
+
       std::istringstream header(field);
       header >> tag;
       if(tag=="#"){ // read header part.
-        header >> sectorId >> sscId
-               >> use[0] >> use[1] >> use[2]
-               >> use[3] >> use[4] >> use[5]
-               >> roi[0] >> roi[1] >> roi[2] >> roi[3]
-               >> roi[4] >> roi[5] >> roi[6] >> roi[7];
+        header >> sectorId >> sscId;
       }
 
       if (sectorId < 0 || sectorId >= TGCTriggerData::N_ENDCAP_SECTOR ||
@@ -331,43 +341,45 @@ void TGCTriggerDbAlg::fillTrigBitEifi(TGCTriggerData* writeCdo) {
         return;
       }
 
+      unsigned char flag_pt = 0x0;
       for (size_t pt = 0; pt < TGCTriggerData::N_PT_THRESH; pt++){
-        writeCdo->m_flagpt_eifi[iSide][pt][sscId][sectorId] = use[pt];
+        unsigned char use;
+        header  >> use;
+        flag_pt |= (use&0x1)<<pt;
       }
+      writeCdo->m_flagpt_eifi[sectorId][sscId].push_back(flag_pt);
+
+      unsigned char flag_roi = 0x0;
       for (size_t pos = 0; pos < TGCTriggerData::N_ROI_IN_SSC; pos++){
-        writeCdo->m_flagroi_eifi[iSide][pos][sscId][sectorId] = roi[pos];
+        unsigned char use;
+        header >> use;
+        flag_roi |= (use&0x1)<<pos;
       }
+      writeCdo->m_flagroi_eifi[sectorId][sscId].push_back(flag_roi);
 
       std::getline(stream, field, delimiter);
       std::istringstream cont(field);
-      unsigned int word;
       for(size_t pos=0; pos < TGCTriggerData::N_EIFI_INPUT; pos++){
+        unsigned int word;
         cont >> word;
-
-        unsigned int tstBit =1;
-        for (unsigned int region = 0; region < TGCTriggerData::N_EIFI_REGION; region++) {
-          for (unsigned int readout = 0; readout < TGCTriggerData::N_EIFI_READOUT; readout++) {
-            for (unsigned int iBit = 0; iBit < TGCTriggerData::N_EIFI_TRIGBIT; iBit++) {
-              writeCdo->m_trigbit_eifi[iSide][pos][sscId][sectorId][region][readout][iBit] = ((tstBit & word) !=0 );
-              tstBit = tstBit*2;
-            }
-          }
-        }
+        writeCdo->m_trigbit_eifi[sectorId][sscId][pos].push_back(word);
       }
-    }
-  } 
-}
+    }  // end of while(std::geline(...))
 
-void TGCTriggerDbAlg::fillTrigBitTile(TGCTriggerData* writeCdo) {
+    if (!fullCW) break;
 
+  }  // end of for(iSide)
+}
+
+void TGCTriggerDbAlg::fillTrigBitTile(TGCTriggerData* writeCdo)
+{
   if (!writeCdo->isActive(TGCTriggerData::CW_TILE)) {
     return;
   }
 
-  std::string verName = writeCdo->getVersion(TGCTriggerData::CW_TILE);
+  std::string vername = writeCdo->getVersion(TGCTriggerData::CW_TILE);
 
-  std::string dbname="";
-  dbname = "TileMuCoincidenceMap." + verName + "._12.db";
+  std::string dbname = "TileMuCoincidenceMap." + vername + "._12.db";
 
   std::string data = writeCdo->getData(TGCTriggerData::CW_TILE, dbname);
   std::istringstream stream(data);
@@ -380,39 +392,42 @@ void TGCTriggerDbAlg::fillTrigBitTile(TGCTriggerData* writeCdo) {
     int sideId = -1;
     int sectorId = -1;
     int sscId    = -1;
-    int use[TGCTriggerData::N_PT_THRESH] = {0, 0, 0, 0, 0, 0};
-    int roi[TGCTriggerData::N_ROI_IN_SSC] = {1, 1, 1, 1, 1, 1, 1, 1};
 
     std::istringstream header(field);
     header >> tag;
     if (tag=="#"){ // read header part.
-      header >> sideId >> sectorId >> sscId
-             >> use[0] >> use[1] >> use[2]
-             >> use[3] >> use[4] >> use[5]
-             >> roi[0] >> roi[1] >> roi[2] >> roi[3]
-             >> roi[4] >> roi[5] >> roi[6] >> roi[7];
+      header >> sideId >> sectorId >> sscId;
     }
 
-    if (sideId < 0   || sideId >= TGCTriggerData::N_SIDE ||
-      sectorId < 0 || sectorId >= TGCTriggerData::N_ENDCAP_SECTOR ||
-      sscId < 0    || sscId >= TGCTriggerData::N_ENDCAP_SSC ) {
-        ATH_MSG_WARNING("Invalid configuration of DB file.");
-        return;
+    if(sideId < 0   || sideId >= TGCTriggerData::N_SIDE ||
+       sectorId < 0 || sectorId >= TGCTriggerData::N_ENDCAP_SECTOR ||
+       sscId < 0    || sscId >= TGCTriggerData::N_ENDCAP_SSC ) {
+      ATH_MSG_WARNING("Invalid configuration of DB file.");
+      return;
     }
 
+    writeCdo->m_flagpt_tile[sscId][sectorId][sideId] = 0x0;
     for (size_t pt = 0; pt < TGCTriggerData::N_PT_THRESH; pt++){
-      writeCdo->m_flagpt_tile[pt][sscId][sectorId][sideId]   = use[pt];
+      unsigned char use;
+      header >> use;
+      writeCdo->m_flagpt_tile[sscId][sectorId][sideId] |= (use&0x1)<<pt;
     }
+
+    writeCdo->m_flagroi_tile[sscId][sectorId][sideId] = 0x0;
     for (size_t pos=0; pos< TGCTriggerData::N_ROI_IN_SSC; pos++){
-      writeCdo->m_flagroi_tile[pos][sscId][sectorId][sideId] = roi[pos];
+      unsigned char use;
+      header >> use;
+      writeCdo->m_flagroi_tile[sscId][sectorId][sideId] |= (use&0x1)<<pos;
     }
 
     std::getline(stream, field, delimiter);
     std::istringstream cont(field);
-    unsigned int word;
+    writeCdo->m_trigbit_tile[sscId][sectorId][sideId] = 0x0;
     for(size_t pos=0; pos < TGCTriggerData::N_TILE_INPUT; pos++){
+      unsigned short word;
       cont >> word;
-      writeCdo->m_trigbit_tile[pos][sscId][sectorId][sideId] = word;
+      writeCdo->m_trigbit_tile[sscId][sectorId][sideId] |= (word & 0xf)<<(pos*4);
     }
   }
+
 }
diff --git a/MuonSpectrometer/MuonConfig/share/MuonDataDecodeTest.ref b/MuonSpectrometer/MuonConfig/share/MuonDataDecodeTest.ref
index 25dd304d912e8c4e4be6b7f7cc3835732ae19d0d..e9e7a6f8744a3541209096bf3aec0cf1f0485c53 100644
--- a/MuonSpectrometer/MuonConfig/share/MuonDataDecodeTest.ref
+++ b/MuonSpectrometer/MuonConfig/share/MuonDataDecodeTest.ref
@@ -4,6 +4,7 @@ Beam.Energy                              : [function]
 Beam.NumberOfCollisions                  : [function]
 Beam.Type                                : [function]
 Beam.estimatedLuminosity                 : [function]
+Common.MsgSourceLength                   : 50
 Common.Project                           : 'Athena'
 Common.bunchCrossingSource               : [function]
 Common.doExpressProcessing               : False
@@ -28,6 +29,7 @@ IOVDb.GlobalTag                          : 'CONDBR2-BLKPA-2018-13'
 Input.Collections                        : [function]
 Input.Files                              : ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1']
 Input.Format                             : [function]
+Input.LumiBlockNumber                    : [function]
 Input.ProjectName                        : [function]
 Input.RunNumber                          : [function]
 Input.SecondaryCollections               : [function]
@@ -62,6 +64,7 @@ DQ                        :                           __dq : AthenaConfiguration
 Detector                  :                     __detector : AthenaConfiguration/AllConfigFlags.py
 Digitization              :                 __digitization : AthenaConfiguration/AllConfigFlags.py
 Egamma                    :                       __egamma : AthenaConfiguration/AllConfigFlags.py
+ITk                       :                          __itk : AthenaConfiguration/AllConfigFlags.py
 InDet                     :                        __indet : AthenaConfiguration/AllConfigFlags.py
 LAr                       :                          __lar : AthenaConfiguration/AllConfigFlags.py
 MET                       :                          __met : AthenaConfiguration/AllConfigFlags.py
@@ -74,18 +77,24 @@ Sim                       :                   __simulation : AthenaConfiguration
 Tile                      :                         __tile : AthenaConfiguration/AllConfigFlags.py
 Trigger                   :                      __trigger : AthenaConfiguration/AllConfigFlags.py
 Py:Athena            INFO About to setup Raw data decoding
-Py:Athena            INFO using release [WorkDir-22.0.18] [x86_64-centos7-gcc8-opt] [removeDuplicateProp/12d6dd5] -- built on [2020-09-17T1141]
+Py:Athena            INFO using release [WorkDir-22.0.22] [x86_64-centos7-gcc8-opt] [MainServiceMsgFormat/f665cad] -- built on [2020-12-03T1657]
 Py:AutoConfigFlags    INFO Obtaining metadata of auto-configuration by peeking into /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1
 Py:MetaReader        INFO Current mode used: peeker
 Py:MetaReader        INFO Current filenames: ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1']
-Py:ConfigurableDb    INFO Read module info for 5566 configurables from 4 genConfDb files
-Py:ConfigurableDb    INFO No duplicates have been found: that's good !
-EventInfoMgtInit: Got release version  Athena-22.0.18
-Py:IOVDbSvc.CondDB    INFO Setting up conditions DB access to instance OFLP200
 Py:Athena            INFO Print Config
 Py:ComponentAccumulator    INFO Event Inputs
 Py:ComponentAccumulator    INFO Event Algorithm Sequences
-Py:ComponentAccumulator    INFO AthSequencer('AthAlgSeq', Sequential=True, Members=[RpcRawDataProvider('RpcRawDataProvider', ProviderTool=RPC_RawDataProviderToolMT('RPC_RawDataProviderToolMT', Decoder=RpcROD_Decoder('RpcROD_Decoder'), RdoLocation='RPCPAD')), TgcRawDataProvider('TgcRawDataProvider', ProviderTool=TGC_RawDataProviderToolMT('TGC_RawDataProviderToolMT', Decoder=TGC_RodDecoderReadout('TgcROD_Decoder'), RdoLocation='TGCRDO')), MdtRawDataProvider('MdtRawDataProvider', ProviderTool=MDT_RawDataProviderToolMT('MDT_RawDataProviderToolMT', Decoder=MdtROD_Decoder('MdtROD_Decoder'), RdoLocation='MDTCSM')), CscRawDataProvider('CscRawDataProvider', ProviderTool=CSC_RawDataProviderToolMT('CSC_RawDataProviderToolMT', Decoder=CscROD_Decoder('CscROD_Decoder'), RdoLocation='CSCRDO')), RpcRdoToRpcPrepData('RpcRdoToRpcPrepData', DecodingTool=RpcRdoToPrepDataToolMT('RpcRdoToRpcPrepDataTool'), PrintPrepData=False, RegSel_RPC=RegSelTool('RegSelTool_RPC', RegSelLUT='RegSelLUTCondData_RPC', Initialised=True)), TgcRdoToTgcPrepData('TgcRdoToTgcPrepData', DecodingTool=TgcRdoToPrepDataToolMT('TgcRdoToTgcPrepDataTool'), PrintPrepData=False, RegSel_TGC=RegSelTool('RegSelTool_TGC', RegSelLUT='RegSelLUTCondData_TGC', Initialised=True)), MdtRdoToMdtPrepData('MdtRdoToMdtPrepData', DecodingTool=MdtRdoToPrepDataToolMT('MdtRdoToMdtPrepDataTool'), PrintPrepData=False, RegSel_MDT=RegSelTool('RegSelTool_MDT', RegSelLUT='RegSelLUTCondData_MDT', Initialised=True)), CscRdoToCscPrepData('CscRdoToCscPrepData', CscRdoToCscPrepDataTool=CscRdoToCscPrepDataToolMT('CscRdoToCscPrepDataTool'), PrintPrepData=False, RegSel_CSC=RegSelTool('RegSelTool_CSC', RegSelLUT='RegSelLUTCondData_CSC', Initialised=True)), CscThresholdClusterBuilder('CscThresholdClusterBuilder', cluster_builder=CscThresholdClusterBuilderTool('CscThresholdClusterBuilderTool'))])
+Py:ComponentAccumulator    INFO Top sequence 0
+Py:ComponentAccumulator    INFO \__ AthAlgSeq (seq: SEQ AND)
+Py:ComponentAccumulator    INFO    \__ Muon::RpcRawDataProvider/RpcRawDataProvider (alg)
+Py:ComponentAccumulator    INFO    \__ Muon::TgcRawDataProvider/TgcRawDataProvider (alg)
+Py:ComponentAccumulator    INFO    \__ Muon::MdtRawDataProvider/MdtRawDataProvider (alg)
+Py:ComponentAccumulator    INFO    \__ Muon::CscRawDataProvider/CscRawDataProvider (alg)
+Py:ComponentAccumulator    INFO    \__ RpcRdoToRpcPrepData/RpcRdoToRpcPrepData (alg)
+Py:ComponentAccumulator    INFO    \__ TgcRdoToTgcPrepData/TgcRdoToTgcPrepData (alg)
+Py:ComponentAccumulator    INFO    \__ MdtRdoToMdtPrepData/MdtRdoToMdtPrepData (alg)
+Py:ComponentAccumulator    INFO    \__ CscRdoToCscPrepData/CscRdoToCscPrepData (alg)
+Py:ComponentAccumulator    INFO    \__ CscThresholdClusterBuilder/CscThresholdClusterBuilder (alg)
 Py:ComponentAccumulator    INFO Condition Algorithms
 Py:ComponentAccumulator    INFO  \__ CondInputLoader (cond alg)
 Py:ComponentAccumulator    INFO  \__ MuonAlignmentCondAlg (cond alg)
@@ -117,7 +126,7 @@ Py:ComponentAccumulator    INFO ]
 Py:ComponentAccumulator    INFO Private Tools
 Py:ComponentAccumulator    INFO [
 Py:ComponentAccumulator    INFO ]
-Py:ComponentAccumulator    INFO TheApp properties
+Py:ComponentAccumulator    INFO theApp properties
 Py:ComponentAccumulator    INFO   EvtSel : EventSelector
 Py:Athena            INFO Save Config
 
@@ -125,357 +134,342 @@ JOs reading stage finished, launching CARunner from pickle file
 
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v34r0)
-                                          running on pcaz004 on Thu Sep 17 11:43:35 2020
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on pcaz001 on Thu Dec  3 17:40:29 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-CoreDumpSvc          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
-ClassIDSvc           INFO  getRegistryEntries: read 4008 CLIDRegistry entries for module ALL
-MetaDataSvc          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
-PoolSvc              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
-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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-09-16T2101/Athena/22.0.18/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
-DBReplicaSvc         INFO Total of 10 servers found for host pcaz004.dyndns.cern.ch [ATLF ATLAS_COOLPROD atlas_dd ATLAS_CONFIG INT8R INTR ATONR_COOL ATONR_CONF DEVDB11 ATLF ]
-DBReplicaSvc         INFO COOL SQLite replicas will be excluded if matching pattern /DBRelease/
-PoolSvc              INFO Successfully setup replica sorting algorithm
-PoolSvc              INFO Setting up APR FileCatalog and Streams
-PoolSvc              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_comcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_comcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
-ToolSvc.ByteStr...   INFO Initializing ToolSvc.ByteStreamMetadataTool - package version ByteStreamCnvSvc-00-00-00
-MetaDataSvc          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool','ByteStreamMetadataTool/ByteStreamMetadataTool'])
-OutputStreamSeq...   INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
-ByteStreamAddre...   INFO Initializing ByteStreamAddressProviderSvc - package version ByteStreamCnvSvcBase-00-00-00
-ByteStreamAddre...   INFO initialized 
-ByteStreamAddre...   INFO -- Will fill Store with id =  0
-IOVDbSvc             INFO Opened read transaction for POOL PersistencySvc
-IOVDbSvc             INFO Only 5 POOL conditions files will be open at once
-IOVDbSvc             INFO Cache alignment will be done in 3 slices
-IOVDbSvc             INFO Global tag: CONDBR2-BLKPA-2018-13 set from joboptions
-IOVDbFolder          INFO Inputfile tag override disabled for /GLOBAL/BField/Maps
-IOVDbSvc             INFO Initialised with 10 connections and 29 folders
-IOVDbSvc             INFO Service IOVDbSvc initialised successfully
-ClassIDSvc           INFO  getRegistryEntries: read 2789 CLIDRegistry entries for module ALL
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_MUONALIGN/CONDBR2
-IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
-IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
-IOVDbSvc             INFO Opening COOL connection for COOLONL_RPC/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_MUONALIGN/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_TGC/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLONL_RPC/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_MDT/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLONL_TGC/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_GLOBAL/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLONL_MDT/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_DCS/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLONL_GLOBAL/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_RPC/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_DCS/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_MDT/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_RPC/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_CSC/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_MDT/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_CSC/CONDBR2
-IOVDbSvc             INFO Added taginfo remove for /CSC/FTHOLD
-IOVDbSvc             INFO Added taginfo remove for /CSC/NOISE
-IOVDbSvc             INFO Added taginfo remove for /CSC/PED
-IOVDbSvc             INFO Added taginfo remove for /CSC/PSLOPE
-IOVDbSvc             INFO Added taginfo remove for /CSC/RMS
-IOVDbSvc             INFO Added taginfo remove for /CSC/STAT
-IOVDbSvc             INFO Added taginfo remove for /CSC/T0BASE
-IOVDbSvc             INFO Added taginfo remove for /CSC/T0PHASE
-IOVDbSvc             INFO Added taginfo remove for /EXT/DCS/MAGNETS/SENSORDATA
-IOVDbSvc             INFO Added taginfo remove for /GLOBAL/BField/Maps
-IOVDbSvc             INFO Added taginfo remove for /MDT/CABLING/MAP_SCHEMA
-IOVDbSvc             INFO Added taginfo remove for /MDT/CABLING/MEZZANINE_SCHEMA
-IOVDbSvc             INFO Added taginfo remove for /MDT/RTBLOB
-IOVDbSvc             INFO Added taginfo remove for /MDT/T0BLOB
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/CSC/ILINES
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/MDT/ASBUILTPARAMS
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/MDT/BARREL
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/MDT/ENDCAP/SIDEA
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/MDT/ENDCAP/SIDEC
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/TGC/SIDEA
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/TGC/SIDEC
-IOVDbSvc             INFO Added taginfo remove for /RPC/CABLING/MAP_SCHEMA
-IOVDbSvc             INFO Added taginfo remove for /RPC/CABLING/MAP_SCHEMA_CORR
-IOVDbSvc             INFO Added taginfo remove for /RPC/DCS/DeadRopanels
-IOVDbSvc             INFO Added taginfo remove for /RPC/DCS/OffRopanels
-IOVDbSvc             INFO Added taginfo remove for /RPC/DQMF/ELEMENT_STATUS
-IOVDbSvc             INFO Added taginfo remove for /RPC/TRIGGER/CM_THR_ETA
-IOVDbSvc             INFO Added taginfo remove for /RPC/TRIGGER/CM_THR_PHI
-IOVDbSvc             INFO Added taginfo remove for /TGC/CABLING/MAP_SCHEMA
-GeoModelSvc          INFO Explicitly initializing DetDescrCnvSvc
-DetDescrCnvSvc       INFO  initializing 
-DetDescrCnvSvc       INFO Found DetectorStore service
-DetDescrCnvSvc       INFO  filling proxies for detector managers 
-DetDescrCnvSvc       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
-GeoModelSvc.Muo...   INFO Initializing ...
-GeoModelSvc::RD...WARNING  Getting PixTBMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting PixTBMaterials with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMaterials with default tag
-MuonGeoModel         INFO MuonDetectorFactory - constructor  MuonSystem OuterRadius 13000 Length 22030
-GeoModelSvc.Muo...   INFO create MuonDetectorTool - package version = MuonGeoModel-00-00-00
-GeoModelSvc.Muo...   INFO (from GeoModelSvc)    AtlasVersion = <ATLAS-R2-2016-01-00-01>  MuonVersion = <>
-GeoModelSvc.Muo...   INFO Keys for Muon Switches are  (key) ATLAS-R2-2016-01-00-01 (node) ATLAS
-GeoModelSvc.Muo...   INFO (from GeoModelSvc) in AtlasVersion = <ATLAS-R2-2016-01-00-01>  default MuonVersion is <MuonSpectrometer-R.08.01>
-GeoModelSvc.Muo...   INFO Properties have been set as follows: 
-GeoModelSvc.Muo...   INFO     LayoutName                     R
-GeoModelSvc.Muo...   INFO     IncludeCutouts                 0
-GeoModelSvc.Muo...   INFO     IncludeCutoutsBog              0
-GeoModelSvc.Muo...   INFO     IncludeCtbBis                  0
-GeoModelSvc.Muo...   INFO     ControlAlines                  111111
-GeoModelSvc.Muo...   INFO     MinimalGeoFlag                 0
-GeoModelSvc.Muo...   INFO     EnableCscIntAlignment          1
-GeoModelSvc.Muo...   INFO     EnableCscIntAlignmentFromGM    0
-GeoModelSvc.Muo...   INFO     ControlCscIntAlines            111111
-GeoModelSvc.Muo...   INFO     EnableMdtDeformations          1
-GeoModelSvc.Muo...   INFO     EnableMdtAsBuiltParameters     1
-MuGM:MuonFactory     INFO MuonLayout set to <R.08.01> = Development version for DC3 - infrastructures 
-MuGM:MuonFactory     INFO                    BOG cutouts are activated 1 , all other cutouts are disabled 1
-MuGM:MuonFactory     INFO Manager created for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
-MuonGeoModel.MYSQL   INFO GeometryVersion set to <R.08.01>
-MuGM:MuonFactory     INFO Mysql helper class created here for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
-EventPersistenc...   INFO Added successfully Conversion service:ByteStreamCnvSvc
-EventPersistenc...   INFO Added successfully Conversion service:DetDescrCnvSvc
-MDT_IDDetDescrCnv    INFO in createObj: creating a MdtIdHelper object in the detector store
-IdDictDetDescrCnv    INFO in initialize
-IdDictDetDescrCnv    INFO in createObj: creating a IdDictManager object in the detector store
-IdDictDetDescrCnv    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
-IdDictDetDescrCnv    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
-IdDictDetDescrCnv    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Found id dicts:
-IdDictDetDescrCnv    INFO Using dictionary tag: null
-IdDictDetDescrCnv    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
+CoreDumpSvc                                          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
+ClassIDSvc                                           INFO  getRegistryEntries: read 3909 CLIDRegistry entries for module ALL
+MetaDataSvc                                          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
+PoolSvc                                              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
+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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
+DBReplicaSvc                                         INFO Total of 10 servers found for host pcaz001.dyndns.cern.ch [ATLF ATLAS_COOLPROD atlas_dd ATLAS_CONFIG INT8R INTR ATONR_COOL ATONR_CONF DEVDB11 ATLF ]
+DBReplicaSvc                                         INFO COOL SQLite replicas will be excluded if matching pattern /DBRelease/
+PoolSvc                                              INFO Successfully setup replica sorting algorithm
+PoolSvc                                              INFO Setting up APR FileCatalog and Streams
+PoolSvc                                              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_comcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_comcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
+DbSession                                            INFO     Open     DbSession    
+Domain[ROOT_All]                                     INFO >   Access   DbDomain     READ      [ROOT_All] 
+ToolSvc.ByteStreamMetadataTool                       INFO Initializing ToolSvc.ByteStreamMetadataTool - package version ByteStreamCnvSvc-00-00-00
+MetaDataSvc                                          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool','ByteStreamMetadataTool/ByteStreamMetadataTool'])
+OutputStreamSequencerSvc                             INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.ByteStreamMetadataTool
+ByteStreamAddressProviderSvc                         INFO Initializing ByteStreamAddressProviderSvc - package version ByteStreamCnvSvcBase-00-00-00
+ByteStreamAddressProviderSvc                         INFO initialized 
+ByteStreamAddressProviderSvc                         INFO -- Will fill Store with id =  0
+TagInfoMgr                                           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
+IOVDbSvc                                             INFO Only 5 POOL conditions files will be open at once
+IOVDbSvc                                             INFO Cache alignment will be done in 3 slices
+IOVDbSvc                                             INFO Global tag: CONDBR2-BLKPA-2018-13 set from joboptions
+IOVDbFolder                                          INFO Inputfile tag override disabled for /GLOBAL/BField/Maps
+IOVDbSvc                                             INFO Initialised with 10 connections and 29 folders
+IOVDbSvc                                             INFO Service IOVDbSvc initialised successfully
+IOVDbSvc                                             INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+ClassIDSvc                                           INFO  getRegistryEntries: read 2787 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_MUONALIGN/CONDBR2
+IOVSvc                                               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool                                    INFO IOVRanges will be checked at every Event
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_RPC/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_MUONALIGN/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_TGC/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLONL_RPC/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_MDT/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLONL_TGC/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_GLOBAL/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLONL_MDT/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_DCS/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLONL_GLOBAL/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_RPC/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_DCS/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_MDT/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_RPC/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_CSC/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_MDT/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_CSC/CONDBR2
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/FTHOLD
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/NOISE
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/PED
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/PSLOPE
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/RMS
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/STAT
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/T0BASE
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/T0PHASE
+IOVDbSvc                                             INFO Added taginfo remove for /EXT/DCS/MAGNETS/SENSORDATA
+IOVDbSvc                                             INFO Added taginfo remove for /GLOBAL/BField/Maps
+IOVDbSvc                                             INFO Added taginfo remove for /MDT/CABLING/MAP_SCHEMA
+IOVDbSvc                                             INFO Added taginfo remove for /MDT/CABLING/MEZZANINE_SCHEMA
+IOVDbSvc                                             INFO Added taginfo remove for /MDT/RTBLOB
+IOVDbSvc                                             INFO Added taginfo remove for /MDT/T0BLOB
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/CSC/ILINES
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/MDT/ASBUILTPARAMS
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/MDT/BARREL
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/MDT/ENDCAP/SIDEA
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/MDT/ENDCAP/SIDEC
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/TGC/SIDEA
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/TGC/SIDEC
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/CABLING/MAP_SCHEMA
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/CABLING/MAP_SCHEMA_CORR
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/DCS/DeadRopanels
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/DCS/OffRopanels
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/DQMF/ELEMENT_STATUS
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/TRIGGER/CM_THR_ETA
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/TRIGGER/CM_THR_PHI
+IOVDbSvc                                             INFO Added taginfo remove for /TGC/CABLING/MAP_SCHEMA
+DetDescrCnvSvc                                       INFO  initializing 
+DetDescrCnvSvc                                       INFO Found DetectorStore service
+DetDescrCnvSvc                                       INFO  filling proxies for detector managers 
+DetDescrCnvSvc                                       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
+GeoModelSvc.MuonDetectorTool                         INFO Initializing ...
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMaterials with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMaterials with default tag
+MuonGeoModel                                         INFO MuonDetectorFactory - constructor  MuonSystem OuterRadius 13000 Length 22030
+GeoModelSvc.MuonDetectorTool                         INFO create MuonDetectorTool - package version = MuonGeoModel-00-00-00
+GeoModelSvc.MuonDetectorTool                         INFO (from GeoModelSvc)    AtlasVersion = <ATLAS-R2-2016-01-00-01>  MuonVersion = <>
+GeoModelSvc.MuonDetectorTool                         INFO Keys for Muon Switches are  (key) ATLAS-R2-2016-01-00-01 (node) ATLAS
+GeoModelSvc.MuonDetectorTool                         INFO (from GeoModelSvc) in AtlasVersion = <ATLAS-R2-2016-01-00-01>  default MuonVersion is <MuonSpectrometer-R.08.01>
+GeoModelSvc.MuonDetectorTool                         INFO Properties have been set as follows: 
+GeoModelSvc.MuonDetectorTool                         INFO     LayoutName                     R
+GeoModelSvc.MuonDetectorTool                         INFO     IncludeCutouts                 0
+GeoModelSvc.MuonDetectorTool                         INFO     IncludeCutoutsBog              0
+GeoModelSvc.MuonDetectorTool                         INFO     IncludeCtbBis                  0
+GeoModelSvc.MuonDetectorTool                         INFO     ControlAlines                  111111
+GeoModelSvc.MuonDetectorTool                         INFO     MinimalGeoFlag                 0
+GeoModelSvc.MuonDetectorTool                         INFO     EnableCscIntAlignment          1
+GeoModelSvc.MuonDetectorTool                         INFO     EnableCscIntAlignmentFromGM    0
+GeoModelSvc.MuonDetectorTool                         INFO     ControlCscIntAlines            111111
+GeoModelSvc.MuonDetectorTool                         INFO     EnableMdtDeformations          1
+GeoModelSvc.MuonDetectorTool                         INFO     EnableMdtAsBuiltParameters     1
+MuGM:MuonFactory                                     INFO MuonLayout set to <R.08.01> = Development version for DC3 - infrastructures 
+MuGM:MuonFactory                                     INFO                    BOG cutouts are activated 1 , all other cutouts are disabled 1
+MuGM:MuonFactory                                     INFO Manager created for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
+MuonGeoModel.MYSQL                                   INFO GeometryVersion set to <R.08.01>
+MuGM:MuonFactory                                     INFO Mysql helper class created here for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
+EventPersistencySvc                                  INFO Added successfully Conversion service:ByteStreamCnvSvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:DetDescrCnvSvc
+MDT_IDDetDescrCnv                                    INFO in createObj: creating a MdtIdHelper object in the detector store
+IdDictDetDescrCnv                                    INFO in initialize
+IdDictDetDescrCnv                                    INFO in createObj: creating a IdDictManager object in the detector store
+IdDictDetDescrCnv                                    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
+IdDictDetDescrCnv                                    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
+IdDictDetDescrCnv                                    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Found id dicts:
+IdDictDetDescrCnv                                    INFO Using dictionary tag: null
+IdDictDetDescrCnv                                    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find mm region index: group, region size 0 0
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find stgc region index: group, region size 0 0
 AtlasDetectorID::initLevelsFromDict - there are no sTGC entries in the dictionary! 
 AtlasDetectorID::initLevelsFromDict - there are no MM entries in the dictionary! 
  AtlasDetectorID::initialize_from_dictionary - OK 
-MdtIdHelper          INFO MultiRange built successfully to Technology: MultiRange size is 210
-MdtIdHelper          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 241
-MdtIdHelper          INFO MultiRange built successfully to tube: MultiRange size is 241
-MdtIdHelper          INFO Initializing MDT hash indices ... 
-MdtIdHelper          INFO The element hash max is 1188
-MdtIdHelper          INFO The detector element hash max is 2328
-MdtIdHelper          INFO Initializing MDT hash indices for finding neighbors ... 
-MuGM:MuonFactory     INFO MDTIDHELPER retrieved from DetStore
-RPC_IDDetDescrCnv    INFO in createObj: creating a RpcIdHelper object in the detector store
+MdtIdHelper                                          INFO MultiRange built successfully to Technology: MultiRange size is 210
+MdtIdHelper                                          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 241
+MdtIdHelper                                          INFO MultiRange built successfully to tube: MultiRange size is 241
+MdtIdHelper                                          INFO Initializing MDT hash indices ... 
+MdtIdHelper                                          INFO The element hash max is 1188
+MdtIdHelper                                          INFO The detector element hash max is 2328
+MdtIdHelper                                          INFO Initializing MDT hash indices for finding neighbors ... 
+MuGM:MuonFactory                                     INFO MDTIDHELPER retrieved from DetStore
+RPC_IDDetDescrCnv                                    INFO in createObj: creating a RpcIdHelper object in the detector store
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find mm region index: group, region size 0 0
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find stgc region index: group, region size 0 0
 AtlasDetectorID::initLevelsFromDict - there are no sTGC entries in the dictionary! 
 AtlasDetectorID::initLevelsFromDict - there are no MM entries in the dictionary! 
  AtlasDetectorID::initialize_from_dictionary - OK 
-RpcIdHelper          INFO MultiRange built successfully to doubletR: MultiRange size is 241
-RpcIdHelper          INFO MultiRange built successfully to detectorElement: DetectorElement MultiRange size is 241
-RpcIdHelper          INFO MultiRange built successfully to rpcStrip: MultiRange size is 241
-RpcIdHelper          INFO Initializing RPC hash indices ... 
-RpcIdHelper          INFO The element hash max is 600
-RpcIdHelper          INFO The detector element hash max is 1122
-RpcIdHelper          INFO Initializing RPC hash indices for finding neighbors ... 
-MuGM:MuonFactory     INFO RPCIDHELPER retrieved from DetStore
-TGC_IDDetDescrCnv    INFO in createObj: creating a TgcIdHelper object in the detector store
+RpcIdHelper                                          INFO MultiRange built successfully to doubletR: MultiRange size is 241
+RpcIdHelper                                          INFO MultiRange built successfully to detectorElement: DetectorElement MultiRange size is 241
+RpcIdHelper                                          INFO MultiRange built successfully to rpcStrip: MultiRange size is 241
+RpcIdHelper                                          INFO Initializing RPC hash indices ... 
+RpcIdHelper                                          INFO The element hash max is 600
+RpcIdHelper                                          INFO The detector element hash max is 1122
+RpcIdHelper                                          INFO Initializing RPC hash indices for finding neighbors ... 
+MuGM:MuonFactory                                     INFO RPCIDHELPER retrieved from DetStore
+TGC_IDDetDescrCnv                                    INFO in createObj: creating a TgcIdHelper object in the detector store
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find mm region index: group, region size 0 0
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find stgc region index: group, region size 0 0
 AtlasDetectorID::initLevelsFromDict - there are no sTGC entries in the dictionary! 
 AtlasDetectorID::initLevelsFromDict - there are no MM entries in the dictionary! 
  AtlasDetectorID::initialize_from_dictionary - OK 
-TgcIdHelper          INFO MultiRange built successfully to Technology: MultiRange size is 210
-TgcIdHelper          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 210
-TgcIdHelper          INFO MultiRange built successfully to channel: MultiRange size is 241
-TgcIdHelper          INFO Initializing TGC hash indices ... 
-TgcIdHelper          INFO The element hash max is 1578
-TgcIdHelper          INFO The detector element hash max is 1578
-TgcIdHelper          INFO Initializing TGC hash indices for finding neighbors ... 
-MuGM:MuonFactory     INFO TGCIDHELPER retrieved from DetStore
-CSC_IDDetDescrCnv    INFO in createObj: creating a CcscIdHelper object in the detector store
+TgcIdHelper                                          INFO MultiRange built successfully to Technology: MultiRange size is 210
+TgcIdHelper                                          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 210
+TgcIdHelper                                          INFO MultiRange built successfully to channel: MultiRange size is 241
+TgcIdHelper                                          INFO Initializing TGC hash indices ... 
+TgcIdHelper                                          INFO The element hash max is 1578
+TgcIdHelper                                          INFO The detector element hash max is 1578
+TgcIdHelper                                          INFO Initializing TGC hash indices for finding neighbors ... 
+MuGM:MuonFactory                                     INFO TGCIDHELPER retrieved from DetStore
+CSC_IDDetDescrCnv                                    INFO in createObj: creating a CcscIdHelper object in the detector store
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find mm region index: group, region size 0 0
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find stgc region index: group, region size 0 0
 AtlasDetectorID::initLevelsFromDict - there are no sTGC entries in the dictionary! 
 AtlasDetectorID::initLevelsFromDict - there are no MM entries in the dictionary! 
  AtlasDetectorID::initialize_from_dictionary - OK 
-CscIdHelper          INFO MultiRange built successfully to Technology: MultiRange size is 210
-CscIdHelper          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 237
-CscIdHelper          INFO MultiRange built successfully to cscStrip: MultiRange size is 241
-CscIdHelper          INFO Initializing CSC hash indices ... 
-CscIdHelper          INFO The element hash max is 32
-CscIdHelper          INFO The detector element hash max is 64
-CscIdHelper          INFO The channel hash max is 61440
-CscIdHelper          INFO Initializing CSC hash indices for finding neighbors ... 
-MuGM:MuonFactory     INFO CSCIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO  **************** MuonDetectorFactory001 ************************
-MuGM:MuonFactory     INFO  *** Start building the Muon Geometry Tree **********************
-MuGM:RDBReadAtlas    INFO Start retriving dbObjects with tag = <ATLAS-R2-2016-01-00-01> node <ATLAS>
-RDBAccessSvc      WARNING Could not get the tag for XtomoData node. Returning 0 pointer to IRDBQuery
-MuGM:RDBReadAtlas    INFO After getQuery XtomoData
+CscIdHelper                                          INFO MultiRange built successfully to Technology: MultiRange size is 210
+CscIdHelper                                          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 237
+CscIdHelper                                          INFO MultiRange built successfully to cscStrip: MultiRange size is 241
+CscIdHelper                                          INFO Initializing CSC hash indices ... 
+CscIdHelper                                          INFO The element hash max is 32
+CscIdHelper                                          INFO The detector element hash max is 64
+CscIdHelper                                          INFO The channel hash max is 61440
+CscIdHelper                                          INFO Initializing CSC hash indices for finding neighbors ... 
+MuGM:MuonFactory                                     INFO CSCIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO  **************** MuonDetectorFactory001 ************************
+MuGM:MuonFactory                                     INFO  *** Start building the Muon Geometry Tree **********************
+MuGM:RDBReadAtlas                                    INFO Start retriving dbObjects with tag = <ATLAS-R2-2016-01-00-01> node <ATLAS>
+RDBAccessSvc                                      WARNING Could not get the tag for XtomoData node. Returning 0 pointer to IRDBQuery
+MuGM:RDBReadAtlas                                    INFO After getQuery XtomoData
 In DblQ00Xtomo(data)
 No XtomoData table in the MuonDD Database
-MuGM:RDBReadAtlas    INFO After new DblQ00Xtomo
-MuGM:RDBReadAtlas    INFO No Ascii aszt input found: looking for A-lines in ORACLE
-MuGM:RDBReadAtlas    INFO ASZT table found in Oracle
-MuGM:RDBReadAtlas    INFO ASZT size is 32
-MuGM:RDBReadAtlas    INFO No Ascii iacsc input found: looking for A-lines in ORACLE
-RDBAccessSvc      WARNING Could not get the tag for ISZT node. Returning 0 pointer to IRDBQuery
-MuGM:RDBReadAtlas    INFO No ISZT table in Oracle
-MuGM:RDBReadAtlas    INFO Access granted for all dbObjects needed by muon detectors
-MuonGeoModel.MYSQL   INFO LayoutName (from DBAM) set to <R.08>  -- relevant for CTB2004
-MuGM:ProcStations    INFO  Processing Stations and Components
-MuGM:ProcStations    INFO  Processing Stations and Components DONE
-MuGM:ProcTechnol.s   INFO nMDT 13 nCSC 2 nTGC 22 nRPC 25
-MuGM:ProcTechnol.s   INFO nDED 2 nSUP 4 nSPA 2
-MuGM:ProcTechnol.s   INFO nCHV 7 nCRO 7 nCMI 6 nLBI 6
-MuGM:ProcPosition    INFO  *** N. of stations positioned in the setup 234
-MuGM:ProcPosition    INFO  *** N. of stations described in mysql      234
-MuGM:ProcPosition    INFO  *** N. of types  32 size of jtypvec 32
-MuGM:ProcPosition    INFO  *** : 234 kinds of stations (type*sub_type) 
-MuGM:ProcPosition    INFO  *** : 1758 physical stations in space - according to the MuonDD DataBase
-MuGM:ProcCutouts     INFO  Processing Cutouts for geometry layout R.08
-MuGM:ProcCutouts     INFO  Processing Cutouts DONE
-MuGM:RDBReadAtlas    INFO  ProcessTGCreadout - version 7 wirespacing 1.8
-MuGM:RDBReadAtlas    INFO Intermediate Objects built from primary numbers
-MuGM:MuonFactory     INFO  theMaterialManager retrieven successfully from the DetStore
-MuGM:MuonFactory     INFO MuonSystem description from OracleTag=<ATLAS-R2-2016-01-00-01> and node=<ATLAS>
-MuGM:MuonFactory     INFO  TreeTop added to the Manager
-MuGM:MuonFactory     INFO  Muon Layout R.08.01
-MuGM:MuonFactory     INFO Fine Clash Fixing disabled: (should be ON/OFF for Simulation/Reconstruction)
-MuGM:MuonFactory     INFO  **************** MuonDetectorFactory001 ****************************
-MuGM:MuonFactory     INFO  *** The Muon Chamber Geometry Tree is built with 
-MuGM:MuonFactory     INFO  *** 1758 child volumes 
-MuGM:MuonFactory     INFO  *** 1839 independent elements and 
-MuGM:MuonFactory     INFO  *** 11473 elements cloned or shared 
-MuGM:MuonFactory     INFO  *** 234 kinds of stations
-MuGM:MuonFactory     INFO  *** 1758 stations with alignable transforms
-MuGM:MuonFactory     INFO  *** 148 stations are described as Assemblies
-MuGM:MuonFactory     INFO  *** 1758 MuonStations 
-MuGM:MuonFactory     INFO  *** 	 2324 MDT Readout Elements 	 1186 MDT Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 32 CSC Readout Elements 	 32 CSC Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 1122 RPC Readout Elements 	 600 RPC Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 1578 TGC Readout Elements 	 1578 TGC Detector Elements 
-MuGM:MuonFactory     INFO  ********************************************************************
-MuGM:MuonFactory     INFO  *** Inert Material built according to DB switches and config. ****** 
-MuGM:MuonFactory     INFO  *** The Muon Geometry Tree has 1758 child vol.s in total ********
-MuGM:MuonFactory     INFO  ********************************************************************
+MuGM:RDBReadAtlas                                    INFO After new DblQ00Xtomo
+MuGM:RDBReadAtlas                                    INFO No Ascii aszt input found: looking for A-lines in ORACLE
+MuGM:RDBReadAtlas                                    INFO ASZT table found in Oracle
+MuGM:RDBReadAtlas                                    INFO ASZT size is 32
+MuGM:RDBReadAtlas                                    INFO No Ascii iacsc input found: looking for A-lines in ORACLE
+RDBAccessSvc                                      WARNING Could not get the tag for ISZT node. Returning 0 pointer to IRDBQuery
+MuGM:RDBReadAtlas                                    INFO No ISZT table in Oracle
+MuGM:RDBReadAtlas                                    INFO Access granted for all dbObjects needed by muon detectors
+MuonGeoModel.MYSQL                                   INFO LayoutName (from DBAM) set to <R.08>  -- relevant for CTB2004
+MuGM:ProcStations                                    INFO  Processing Stations and Components
+MuGM:ProcStations                                    INFO  Processing Stations and Components DONE
+MuGM:ProcTechnol.s                                   INFO nMDT 13 nCSC 2 nTGC 22 nRPC 25
+MuGM:ProcTechnol.s                                   INFO nDED 2 nSUP 4 nSPA 2
+MuGM:ProcTechnol.s                                   INFO nCHV 7 nCRO 7 nCMI 6 nLBI 6
+MuGM:ProcPosition                                    INFO  *** N. of stations positioned in the setup 234
+MuGM:ProcPosition                                    INFO  *** N. of stations described in mysql      234
+MuGM:ProcPosition                                    INFO  *** N. of types  32 size of jtypvec 32
+MuGM:ProcPosition                                    INFO  *** : 234 kinds of stations (type*sub_type) 
+MuGM:ProcPosition                                    INFO  *** : 1758 physical stations in space - according to the MuonDD DataBase
+MuGM:ProcCutouts                                     INFO  Processing Cutouts for geometry layout R.08
+MuGM:ProcCutouts                                     INFO  Processing Cutouts DONE
+MuGM:RDBReadAtlas                                    INFO  ProcessTGCreadout - version 7 wirespacing 1.8
+MuGM:RDBReadAtlas                                    INFO Intermediate Objects built from primary numbers
+MuGM:MuonFactory                                     INFO  theMaterialManager retrieven successfully from the DetStore
+MuGM:MuonFactory                                     INFO MuonSystem description from OracleTag=<ATLAS-R2-2016-01-00-01> and node=<ATLAS>
+MuGM:MuonFactory                                     INFO  TreeTop added to the Manager
+MuGM:MuonFactory                                     INFO  Muon Layout R.08.01
+MuGM:MuonFactory                                     INFO Fine Clash Fixing disabled: (should be ON/OFF for Simulation/Reconstruction)
+MuGM:MuonFactory                                     INFO  **************** MuonDetectorFactory001 ****************************
+MuGM:MuonFactory                                     INFO  *** The Muon Chamber Geometry Tree is built with 
+MuGM:MuonFactory                                     INFO  *** 1758 child volumes 
+MuGM:MuonFactory                                     INFO  *** 1839 independent elements and 
+MuGM:MuonFactory                                     INFO  *** 11473 elements cloned or shared 
+MuGM:MuonFactory                                     INFO  *** 234 kinds of stations
+MuGM:MuonFactory                                     INFO  *** 1758 stations with alignable transforms
+MuGM:MuonFactory                                     INFO  *** 148 stations are described as Assemblies
+MuGM:MuonFactory                                     INFO  *** 1758 MuonStations 
+MuGM:MuonFactory                                     INFO  *** 	 2324 MDT Readout Elements 	 1186 MDT Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 32 CSC Readout Elements 	 32 CSC Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 1122 RPC Readout Elements 	 600 RPC Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 1578 TGC Readout Elements 	 1578 TGC Detector Elements 
+MuGM:MuonFactory                                     INFO  ********************************************************************
+MuGM:MuonFactory                                     INFO  *** Inert Material built according to DB switches and config. ****** 
+MuGM:MuonFactory                                     INFO  *** The Muon Geometry Tree has 1758 child vol.s in total ********
+MuGM:MuonFactory                                     INFO  ********************************************************************
 
-MGM::MuonDetect...   INFO Init A/B Line Containers - done - size is respectively 1758/0
-MGM::MuonDetect...   INFO Init of CSC I-Lines will be done via Conditions DB
-MGM::MuonDetect...   INFO Init I-Line Container - done - size is respectively 128
-MGM::MuonDetect...   INFO I-Line for CSC wire layers loaded (Csc Internal Alignment)
-MGM::MuonDetect...   INFO According to configuration they WILL be used 
-MGM::MuonDetect...   INFO Filling cache
-GeoModelSvc          INFO GeoModelSvc.MuonDetectorTool	 SZ= 228524Kb 	 Time = 0.94S
-ClassIDSvc           INFO  getRegistryEntries: read 4462 CLIDRegistry entries for module ALL
-AGDDtoGeoSvc         INFO  this is AGDDtoGeoSvc::initialize()
-AGDDtoGeoSvc.Mu...   INFO  initializing AGDD builder
-AGDDtoGeoSvc.Mu...   INFO  XML file 
-AGDDtoGeoSvc.Mu...   INFO  ---------
-AGDDtoGeoSvc.Mu...   INFO  Sections 
-AGDDtoGeoSvc.Mu...   INFO  ---------
-AGDDtoGeoSvc.Mu...   INFO  Volumes 
-AGDDtoGeoSvc.Mu...   INFO  ---------
-AGDDtoGeoSvc.Mu...   INFO MuonAGDDTool::initialize
-AGDDtoGeoSvc.Mu...   INFO AGDDtoGeoSvc.MuonSpectrometer::construct()
-AGDDtoGeoSvc.Mu...   INFO  Reading AGDD2GeoSwitches flags 
-AGDDtoGeoSvc.Mu...   INFO  ----> ECT_Toroids
-AGDDtoGeoSvc.Mu...   INFO  ----> BAR_Toroid
-AGDDtoGeoSvc.Mu...   INFO  ----> Feet
-AGDDtoGeoSvc.Mu...   INFO  ----> RailAssembly
-AGDDtoGeoSvc.Mu...   INFO  ----> JFSH_Shield
-AGDDtoGeoSvc.Mu...   INFO  ----> JDSH_Shield
-AGDDtoGeoSvc.Mu...   INFO  ----> JTSH_Shield
-AGDDtoGeoSvc.Mu...   INFO  ----> pp2
-AGDDtoGeoSvc.Mu...   INFO  ----> MBAP_AccessPlatform
-AGDDtoGeoSvc.Mu...   INFO  ----> MBWH_BigWheels
-AGDDtoGeoSvc.Mu...   INFO  ----> SADL_CalorimeterSaddle
-AGDDtoGeoSvc.Mu...   INFO  ----> TBWH_BigWheels
-AGDDtoGeoSvc.Mu...   INFO  ----> TGC3_BigWheels
-AGDDtoGeoSvc.Mu...   INFO  ----> TGC1_BigWheels
-AGDDtoGeoSvc.Mu...   INFO  ----> MDTRail
-AGDDtoGeoSvc.Mu...   INFO  ----> servicesAtZ0
-AGDDtoGeoSvc.Mu...   INFO  ----> HFTruckRail
-AGDDtoGeoSvc.Mu...   INFO  ----> RUN2_Services
-AGDDtoGeoSvc.Mu...   INFO  now reading AGDD blob 
-AGDDtoGeoSvc.Mu...   INFO  now dumping the flags 
-AGDDtoGeoSvc.Mu...   INFO 		----- ECT_Toroids ECT_Toroids
-AGDDtoGeoSvc.Mu...   INFO 		----- BAR_Toroid BAR_Toroid
-AGDDtoGeoSvc.Mu...   INFO 		----- Feet Feet
-AGDDtoGeoSvc.Mu...   INFO 		----- RailAssembly RailAssembly
-AGDDtoGeoSvc.Mu...   INFO 		----- JFSH_Shield JFSH_Shield
-AGDDtoGeoSvc.Mu...   INFO 		----- JDSH_Shield JDSH_Shield
-AGDDtoGeoSvc.Mu...   INFO 		----- JTSH_Shield JTSH_Shield
-AGDDtoGeoSvc.Mu...   INFO 		----- pp2 pp2
-AGDDtoGeoSvc.Mu...   INFO 		----- MBAP_AccessPlatform MBAP_AccessPlatform
-AGDDtoGeoSvc.Mu...   INFO 		----- MBWH_BigWheels MBWH_BigWheels
-AGDDtoGeoSvc.Mu...   INFO 		----- SADL_CalorimeterSaddle SADL_CalorimeterSaddle
-AGDDtoGeoSvc.Mu...   INFO 		----- TBWH_BigWheels TBWH_BigWheels
-AGDDtoGeoSvc.Mu...   INFO 		----- TGC3_BigWheels TGC3_BigWheels
-AGDDtoGeoSvc.Mu...   INFO 		----- TGC1_BigWheels TGC1_BigWheels
-AGDDtoGeoSvc.Mu...   INFO 		----- MDTRail MDTRail
-AGDDtoGeoSvc.Mu...   INFO 		----- servicesAtZ0 servicesAtZ0
-AGDDtoGeoSvc.Mu...   INFO 		----- HFTruckRail HFTruckRail
-AGDDtoGeoSvc.Mu...   INFO 		----- RUN2_Services RUN2_Services
-AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 1315 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 251 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 310 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 242 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 1064 CLIDRegistry entries for module ALL
-CondInputLoader      INFO Initializing CondInputLoader...
-CondInputLoader      INFO Adding base classes:
+MGM::MuonDetectorManager                             INFO Init A/B Line Containers - done - size is respectively 1758/0
+MGM::MuonDetectorManager                             INFO Init of CSC I-Lines will be done via Conditions DB
+MGM::MuonDetectorManager                             INFO Init I-Line Container - done - size is respectively 128
+MGM::MuonDetectorManager                             INFO I-Line for CSC wire layers loaded (Csc Internal Alignment)
+MGM::MuonDetectorManager                             INFO According to configuration they WILL be used 
+MGM::MuonDetectorManager                             INFO Filling cache
+GeoModelSvc                                          INFO GeoModelSvc.MuonDetectorTool	 SZ= 245440Kb 	 Time = 2.59S
+ClassIDSvc                                           INFO  getRegistryEntries: read 4462 CLIDRegistry entries for module ALL
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.MuonDetectorTool
+AGDDtoGeoSvc                                         INFO  this is AGDDtoGeoSvc::initialize()
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  initializing AGDD builder
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  XML file 
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ---------
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  Sections 
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ---------
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  Volumes 
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ---------
+AGDDtoGeoSvc.MuonSpectrometer                        INFO MuonAGDDTool::initialize
+AGDDtoGeoSvc.MuonSpectrometer                        INFO AGDDtoGeoSvc.MuonSpectrometer::construct()
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  Reading AGDD2GeoSwitches flags 
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> ECT_Toroids
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> BAR_Toroid
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> Feet
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> RailAssembly
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> JFSH_Shield
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> JDSH_Shield
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> JTSH_Shield
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> pp2
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> MBAP_AccessPlatform
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> MBWH_BigWheels
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> SADL_CalorimeterSaddle
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> TBWH_BigWheels
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> TGC3_BigWheels
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> TGC1_BigWheels
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> MDTRail
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> servicesAtZ0
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> HFTruckRail
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> RUN2_Services
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  now reading AGDD blob 
+AGDDtoGeoSvc                                         INFO   AlgTool: AGDDtoGeoSvc.MuonSpectrometer
+AthenaEventLoopMgr                                   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 1315 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 251 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 310 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 242 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 1064 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO Initializing CondInputLoader...
+CondInputLoader                                      INFO Adding base classes:
   +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/FTHOLD' )   ->
   +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/NOISE' )   ->
   +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/PED' )   ->
@@ -504,7 +498,7 @@ CondInputLoader      INFO Adding base classes:
   +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/DQMF/ELEMENT_STATUS' )   ->
   +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/TRIGGER/CM_THR_ETA' )   ->
   +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/TRIGGER/CM_THR_PHI' )   ->
-CondInputLoader      INFO Will create WriteCondHandle dependencies for the following DataObjects:
+CondInputLoader                                      INFO Will create WriteCondHandle dependencies for the following DataObjects:
     +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/FTHOLD' ) 
     +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/NOISE' ) 
     +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/PED' ) 
@@ -533,202 +527,206 @@ CondInputLoader      INFO Will create WriteCondHandle dependencies for the follo
     +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/DQMF/ELEMENT_STATUS' ) 
     +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/TRIGGER/CM_THR_ETA' ) 
     +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/TRIGGER/CM_THR_PHI' ) 
-MuonAlignmentCo...   INFO Initilalizing
-MuonAlignmentCo...   INFO In initialize ---- # of folders registered is 7
-MuonAlignmentCo...   INFO geometry version from the MuonDetectorManager = R.08.01
-MuonDetectorCon...   INFO Initializing ...
-AtlasFieldMapCo...   INFO Initialize: Key  ( 'AtlasFieldMapCondObj' , 'ConditionStore+fieldMapCondObj' )  has been succesfully registered 
-AtlasFieldMapCo...   INFO Initialize: Will update the field map from conditions
-AtlasFieldCache...   INFO Initialize: Key  ( 'AtlasFieldCacheCondObj' , 'ConditionStore+fieldCondObj' )  has been succesfully registered 
-AtlasFieldCache...   INFO Initialize: Will update current from conditions
-AtlasFieldCache...   INFO Initialize: useDCS, useSoleCurrent, useToroCurrent. 1,  'UseSoleCurrent':7730.0000,  'UseToroCurrent':20400.000 LockMapCurrents 0
-RegSelCondAlg_RPC    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_RPC'
-RegSelCondAlg_TGC    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_TGC'
-RegSelCondAlg_MDT    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_MDT'
-RegSelCondAlg_CSC    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_CSC'
-ClassIDSvc           INFO  getRegistryEntries: read 8930 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 683 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 1588 CLIDRegistry entries for module ALL
-RpcRawDataProvider   INFO RpcRawDataProvider::initialize
-RpcRawDataProvider   INFO  'DoSeededDecoding':False
-ClassIDSvc           INFO  getRegistryEntries: read 990 CLIDRegistry entries for module ALL
-ROBDataProviderSvc   INFO Initializing ROBDataProviderSvc - package version ByteStreamCnvSvcBase-00-00-00
-ROBDataProviderSvc   INFO  ---> Filter out empty ROB fragments                               =  'filterEmptyROB':False
-ROBDataProviderSvc   INFO  ---> Filter out specific ROBs by Status Code: # ROBs = 0
-ROBDataProviderSvc   INFO  ---> Filter out Sub Detector ROBs by Status Code: # Sub Detectors = 0
-RpcRawDataProvi...   INFO initialize() successful in RpcRawDataProvider.RPC_RawDataProviderToolMT
-TgcRawDataProvider   INFO TgcRawDataProvider::initialize
-TgcRawDataProvider   INFO  'DoSeededDecoding':False
-ClassIDSvc           INFO  getRegistryEntries: read 1240 CLIDRegistry entries for module ALL
-TgcRawDataProvi...   INFO initialize() successful in TgcRawDataProvider.TGC_RawDataProviderToolMT.TgcROD_Decoder
-MuonTGC_CablingSvc   INFO for 1/12 sector initialize
-MuonTGC_Cabling...   INFO initialize
-ToolSvc.TGCCabl...   INFO initialize
-ToolSvc.TGCCabl...   INFO readTGCMap from text
-ToolSvc.TGCCabl...   INFO readTGCMap found file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-09-16T2101/Athena/22.0.18/InstallArea/x86_64-centos7-gcc8-opt/share/ASD2PP_diff_12_ONL.db
-ToolSvc.TGCCabl...   INFO giveASD2PP_DIFF_12 (m_ASD2PP_DIFF_12 is not NULL)
-TgcRawDataProvi...   INFO initialize() successful in TgcRawDataProvider.TGC_RawDataProviderToolMT
-MdtRawDataProvider   INFO MdtRawDataProvider::initialize
-MdtRawDataProvider   INFO  'DoSeededDecoding':False
-ClassIDSvc           INFO  getRegistryEntries: read 1427 CLIDRegistry entries for module ALL
-MdtRawDataProvi...   INFO Retrieved service ROBDataProviderSvc = ServiceHandle('ROBDataProviderSvc')
-MdtRawDataProvi...   INFO Processing configuration for layouts with BME chambers.
-MdtRawDataProvi...   INFO Processing configuration for layouts with BMG chambers.
-MdtRawDataProvi...   INFO Retrieved tool Decoder = PrivateToolHandle('MdtROD_Decoder/MdtROD_Decoder')
-MdtRawDataProvi...   INFO initialize() successful in MdtRawDataProvider.MDT_RawDataProviderToolMT
-ClassIDSvc           INFO  getRegistryEntries: read 1008 CLIDRegistry entries for module ALL
-CscRawDataProvi...   INFO Retrieved service ServiceHandle('ROBDataProviderSvc')
-CscRawDataProvi...   INFO Retrieved tool Decoder = PrivateToolHandle('Muon::CscROD_Decoder/CscROD_Decoder')
-CscRawDataProvi...   INFO initialize() successful in CscRawDataProvider.CSC_RawDataProviderToolMT
-ClassIDSvc           INFO  getRegistryEntries: read 54 CLIDRegistry entries for module ALL
-RpcRdoToRpcPrep...   INFO package version = MuonRPC_CnvTools-00-00-00
-RpcRdoToRpcPrep...   INFO properties are 
-RpcRdoToRpcPrep...   INFO produceRpcCoinDatafromTriggerWords 1
-RpcRdoToRpcPrep...   INFO reduceCablingOverlap               1
-RpcRdoToRpcPrep...   INFO solvePhiAmbiguities                1
-RpcRdoToRpcPrep...   INFO timeShift                          -12.5
-RpcRdoToRpcPrep...   INFO etaphi_coincidenceTime             20
-RpcRdoToRpcPrep...   INFO overlap_timeTolerance              10
-RpcRdoToRpcPrep...   INFO Correct prd time from cool db      0
-MuonRPC_CablingSvc   INFO Initializing MuonRPC_CablingSvc - package version MuonRPC_Cabling-00-00-00
-ToolSvc.RPCCabl...   INFO Initializing - folders names are: conf /RPC/CABLING/MAP_SCHEMA / corr /RPC/CABLING/MAP_SCHEMA_CORR
-MuonRPC_CablingSvc   INFO RPCCablingDbTool retrieved with handle TheRpcCablingDbTool = PublicToolHandle('RPCCablingDbTool/RPCCablingDbTool')
-MuonRPC_CablingSvc   INFO Register call-back  against 2 folders listed below 
-MuonRPC_CablingSvc   INFO  Folder n. 1 </RPC/CABLING/MAP_SCHEMA>     found in the DetStore
-ClassIDSvc           INFO  getRegistryEntries: read 242 CLIDRegistry entries for module ALL
-MuonRPC_CablingSvc   INFO initMappingModel registered for call-back against folder </RPC/CABLING/MAP_SCHEMA>
-MuonRPC_CablingSvc   INFO  Folder n. 2 </RPC/CABLING/MAP_SCHEMA_CORR>     found in the DetStore
-MuonRPC_CablingSvc   INFO initMappingModel registered for call-back against folder </RPC/CABLING/MAP_SCHEMA_CORR>
-MuonRPC_CablingSvc   INFO RPCTriggerDbTool retrieved with statusCode = SUCCESS pointer = TheRpcTriggerDbTool = PublicToolHandle('RPCTriggerDbTool')
-MuonRPC_CablingSvc   INFO Register call-back  against 2 folders listed below 
-MuonRPC_CablingSvc   INFO  Folder n. 1 </RPC/TRIGGER/CM_THR_ETA>     found in the DetStore
-MuonRPC_CablingSvc   INFO initTrigRoadsModel registered for call-back against folder </RPC/TRIGGER/CM_THR_ETA>
-MuonRPC_CablingSvc   INFO  Folder n. 2 </RPC/TRIGGER/CM_THR_PHI>     found in the DetStore
-MuonRPC_CablingSvc   INFO initTrigRoadsModel registered for call-back against folder </RPC/TRIGGER/CM_THR_PHI>
-RpcRdoToRpcPrep...   INFO Retrieved DecodingTool = PrivateToolHandle('Muon::RpcRdoToPrepDataToolMT/RpcRdoToRpcPrepDataTool')
-ClassIDSvc           INFO  getRegistryEntries: read 169 CLIDRegistry entries for module ALL
-TgcRdoToTgcPrep...   INFO initialize() successful in TgcRdoToTgcPrepData.TgcRdoToTgcPrepDataTool
-TgcRdoToTgcPrep...   INFO Retrieved DecodingTool = PrivateToolHandle('Muon::TgcRdoToPrepDataToolMT/TgcRdoToTgcPrepDataTool')
-MdtRdoToMdtPrep...   INFO Processing configuration for layouts with BMG chambers.
-MdtRdoToMdtPrep...   INFO Processing configuration for layouts with BME chambers.
-MdtRdoToMdtPrep...   INFO Processing configuration for layouts with BMG chambers.
-MdtRdoToMdtPrep...   INFO Retrieved DecodingTool = PrivateToolHandle('Muon::MdtRdoToPrepDataToolMT/MdtRdoToMdtPrepDataTool')
-ClassIDSvc           INFO  getRegistryEntries: read 116 CLIDRegistry entries for module ALL
-CscRdoToCscPrep...   INFO Retrieved CscRdoToCscPrepDataTool = PrivateToolHandle('Muon::CscRdoToCscPrepDataToolMT/CscRdoToCscPrepDataTool')
-ByteStreamInputSvc   INFO Initializing ByteStreamInputSvc - package version ByteStreamCnvSvc-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 452 CLIDRegistry entries for module ALL
-EventSelector        INFO reinitialization...
-AthenaEventLoopMgr   INFO Setup EventSelector service EventSelector
-ApplicationMgr       INFO Application Manager Initialized successfully
-ApplicationMgr    SUCCESS ****************************** Algorithm Sequence ****************************
-ApplicationMgr    SUCCESS AthSequencer/AthMasterSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthAlgEvtSeq
-ApplicationMgr    SUCCESS           AthSequencer/AthBeginSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg1
-ApplicationMgr    SUCCESS           AthSequencer/AthAllAlgSeq
-ApplicationMgr    SUCCESS                AthSequencer/AthCondSeq
-ApplicationMgr    SUCCESS                     CondInputLoader/CondInputLoader
-ApplicationMgr    SUCCESS                     MuonAlignmentCondAlg/MuonAlignmentCondAlg
-ApplicationMgr    SUCCESS                     MuonDetectorCondAlg/MuonDetectorCondAlg
-ApplicationMgr    SUCCESS                     RpcCablingCondAlg/RpcCablingCondAlg
-ApplicationMgr    SUCCESS                     MuonMDT_CablingAlg/MuonMDT_CablingAlg
-ApplicationMgr    SUCCESS                     MagField::AtlasFieldMapCondAlg/AtlasFieldMapCondAlg
-ApplicationMgr    SUCCESS                     MagField::AtlasFieldCacheCondAlg/AtlasFieldCacheCondAlg
-ApplicationMgr    SUCCESS                     RpcCondDbAlg/RpcCondDbAlg
-ApplicationMgr    SUCCESS                     RPC_RegSelCondAlg/RegSelCondAlg_RPC
-ApplicationMgr    SUCCESS                     TGC_RegSelCondAlg/RegSelCondAlg_TGC
-ApplicationMgr    SUCCESS                     MdtCalibDbAlg/MdtCalibDbAlg
-ApplicationMgr    SUCCESS                     MDT_RegSelCondAlg/RegSelCondAlg_MDT
-ApplicationMgr    SUCCESS                     CscCondDbAlg/CscCondDbAlg
-ApplicationMgr    SUCCESS                     CSC_RegSelCondAlg/RegSelCondAlg_CSC
-ApplicationMgr    SUCCESS                AthSequencer/AthAlgSeq
-ApplicationMgr    SUCCESS                     Muon::RpcRawDataProvider/RpcRawDataProvider
-ApplicationMgr    SUCCESS                     Muon::TgcRawDataProvider/TgcRawDataProvider
-ApplicationMgr    SUCCESS                     Muon::MdtRawDataProvider/MdtRawDataProvider
-ApplicationMgr    SUCCESS                     Muon::CscRawDataProvider/CscRawDataProvider
-ApplicationMgr    SUCCESS                     RpcRdoToRpcPrepData/RpcRdoToRpcPrepData
-ApplicationMgr    SUCCESS                     TgcRdoToTgcPrepData/TgcRdoToTgcPrepData
-ApplicationMgr    SUCCESS                     MdtRdoToMdtPrepData/MdtRdoToMdtPrepData
-ApplicationMgr    SUCCESS                     CscRdoToCscPrepData/CscRdoToCscPrepData
-ApplicationMgr    SUCCESS                     CscThresholdClusterBuilder/CscThresholdClusterBuilder
-ApplicationMgr    SUCCESS           AthSequencer/AthEndSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg2
-ApplicationMgr    SUCCESS      AthSequencer/AthOutSeq
-ApplicationMgr    SUCCESS ******************************************************************************
-ByteStreamInputSvc   INFO Picked valid file: /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/FTHOLD'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/NOISE'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/PED'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/PSLOPE'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/RMS'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/STAT'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/T0BASE'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/T0PHASE'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/EXT/DCS/MAGNETS/SENSORDATA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/GLOBAL/BField/Maps'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/CABLING/MAP_SCHEMA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/CABLING/MEZZANINE_SCHEMA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/RTBLOB'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/T0BLOB'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/CSC/ILINES'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ASBUILTPARAMS'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/BARREL'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEC'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/TGC/SIDEA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/TGC/SIDEC'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/CABLING/MAP_SCHEMA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/CABLING/MAP_SCHEMA_CORR'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DCS/DeadRopanels'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DCS/OffRopanels'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DQMF/ELEMENT_STATUS'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/TRIGGER/CM_THR_ETA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/TRIGGER/CM_THR_PHI'
-ApplicationMgr       INFO Application Manager Started successfully
-EventInfoByteSt...   INFO IsSimulation : 0
-EventInfoByteSt...   INFO IsTestbeam : 0
-EventInfoByteSt...   INFO IsCalibration : 0
-AthenaEventLoopMgr   INFO   ===>>>  start of run 327265    <<<===
-EventPersistenc...   INFO Added successfully Conversion service:TagInfoMgr
-IOVDbSvc             INFO Opening COOL connection for COOLONL_RPC/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCCablingMapSchema_2016_2017_01 for folder /RPC/CABLING/MAP_SCHEMA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCCablingMapSchemaCorr_2016_2017_01 for folder /RPC/CABLING/MAP_SCHEMA_CORR
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCTriggerCMThrEta_RUN1-RUN2-HI-02 for folder /RPC/TRIGGER/CM_THR_ETA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCTriggerCMThrPhi_RUN1-RUN2-HI-02 for folder /RPC/TRIGGER/CM_THR_PHI
-IOVDbSvc             INFO Disconnecting from COOLONL_RPC/CONDBR2
-EventPersistenc...   INFO Added successfully Conversion service:AthenaPoolCnvSvc
-MuonRPC_CablingSvc   INFO initMappingModel has been called
-MuonRPC_CablingSvc   INFO ToolHandle in initMappingModel - <TheRpcCablingDbTool = PublicToolHandle('RPCCablingDbTool/RPCCablingDbTool')>
-MuonRPC_CablingSvc   INFO Retrieving cabling singleton; to create an empty one or to get the existing one
-RPCcabling           INFO CablingRPC---singleton constructor ---- this must be executed just once
-RPCcabling           INFO CablingRPC---The singleton will fill the maps from the COOL streams
-RPCcabling           INFO CablingRPC---InitMaps from COOL cannot be executed NOW: empty string
-RPCcabling           INFO CablingRPC---The singleton is created here
-RPCcabling           INFO CablingRPC--- cacheCleared: s_status = 0
-MuonRPC_CablingSvc   INFO Cabling singleton cache has been cleared
-MuonRPC_CablingSvc   INFO  Trigger roads will be loaded from COOL
-ToolSvc.RPCCabl...   INFO LoadParameters /RPC/CABLING/MAP_SCHEMA I=2 
-ToolSvc.RPCCabl...   INFO loadRPCMap --- Load Map from DB
-ToolSvc.RPCCabl...   INFO Try to read from folder </RPC/CABLING/MAP_SCHEMA>
-ToolSvc.RPCCabl...   INFO  CondAttrListCollection from DB folder have been obtained with size 1
-ToolSvc.RPCCabl...   INFO After Reading folder, Configuration string size is 222202
-ToolSvc.RPCCabl...   INFO LoadParameters /RPC/CABLING/MAP_SCHEMA_CORR I=2 
-ToolSvc.RPCCabl...   INFO loadRPCCorr --- Load Corrections from DB
-ToolSvc.RPCCabl...   INFO Try to read from folder </RPC/CABLING/MAP_SCHEMA_CORR>
-ToolSvc.RPCCabl...   INFO  CondAttrListCollection from DB folder have been obtained with size 1
-ToolSvc.RPCCabl...   INFO After Reading folder, Correction string size is 29369
-MuonRPC_CablingSvc   INFO  InitMappingModel: Trigger roads not yet loaded from COOL - postpone cabling initialization 
-MuonRPC_CablingSvc   INFO initTrigRoadsModel has been called
-MuonRPC_CablingSvc   INFO  Trigger roads will be loaded from COOL
-MuonRPC_CablingSvc   INFO Retrieve the pointer to the cabling singleton 
-RPCcabling           INFO CablingRPC--- cacheCleared: s_status = 0
-MuonRPC_CablingSvc   INFO Cabling singleton cache has been cleared
-ToolSvc.RPCTrig...   INFO LoadParameters /RPC/TRIGGER/CM_THR_ETA I=2 
-ToolSvc.RPCTrig...   INFO LoadParameters /RPC/TRIGGER/CM_THR_PHI I=2 
-MuonRPC_CablingSvc   INFO ======== RPC Trigger Roads from COOL - Header infos ========
-MuonRPC_CablingSvc   INFO 
+MuonAlignmentCondAlg                                 INFO Initilalizing
+MuonAlignmentCondAlg                                 INFO In initialize ---- # of folders registered is 7
+MuonAlignmentCondAlg                                 INFO geometry version from the MuonDetectorManager = R.08.01
+MuonDetectorCondAlg.MuonDetectorTool                 INFO Initializing ...
+AtlasFieldMapCondAlg                                 INFO Initialize: Key  ( 'AtlasFieldMapCondObj' , 'ConditionStore+fieldMapCondObj' )  has been succesfully registered 
+AtlasFieldMapCondAlg                                 INFO Initialize: Will update the field map from conditions
+AtlasFieldCacheCondAlg                               INFO Initialize: Key  ( 'AtlasFieldCacheCondObj' , 'ConditionStore+fieldCondObj' )  has been succesfully registered 
+AtlasFieldCacheCondAlg                               INFO Initialize: Will update current from conditions
+AtlasFieldCacheCondAlg                               INFO Initialize: useDCS, useSoleCurrent, useToroCurrent. 1,  'UseSoleCurrent':7730.0000,  'UseToroCurrent':20400.000 LockMapCurrents 0
+RegSelCondAlg_RPC                                    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_RPC'
+RegSelCondAlg_TGC                                    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_TGC'
+RegSelCondAlg_MDT                                    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_MDT'
+RegSelCondAlg_CSC                                    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_CSC'
+ClassIDSvc                                           INFO  getRegistryEntries: read 8995 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 683 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 1588 CLIDRegistry entries for module ALL
+RpcRawDataProvider                                   INFO RpcRawDataProvider::initialize
+RpcRawDataProvider                                   INFO  'DoSeededDecoding':False
+ClassIDSvc                                           INFO  getRegistryEntries: read 990 CLIDRegistry entries for module ALL
+ROBDataProviderSvc                                   INFO Initializing ROBDataProviderSvc - package version ByteStreamCnvSvcBase-00-00-00
+ROBDataProviderSvc                                   INFO  ---> Filter out empty ROB fragments                               =  'filterEmptyROB':False
+ROBDataProviderSvc                                   INFO  ---> Filter out specific ROBs by Status Code: # ROBs = 0
+ROBDataProviderSvc                                   INFO  ---> Filter out Sub Detector ROBs by Status Code: # Sub Detectors = 0
+RpcRawDataProvider.RPC_RawDataProviderToolMT         INFO initialize() successful in RpcRawDataProvider.RPC_RawDataProviderToolMT
+TgcRawDataProvider                                   INFO TgcRawDataProvider::initialize
+TgcRawDataProvider                                   INFO  'DoSeededDecoding':False
+ClassIDSvc                                           INFO  getRegistryEntries: read 1240 CLIDRegistry entries for module ALL
+TgcRawDataProvider.TGC_RawDataPro...TgcROD_Decoder   INFO initialize() successful in TgcRawDataProvider.TGC_RawDataProviderToolMT.TgcROD_Decoder
+MuonTGC_CablingSvc                                   INFO for 1/12 sector initialize
+MuonTGC_CablingSvc.TGCCablingDbTool                  INFO initialize
+ToolSvc.TGCCablingDbTool                             INFO initialize
+ToolSvc.TGCCablingDbTool                             INFO readTGCMap from text
+ToolSvc.TGCCablingDbTool                             INFO readTGCMap found file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/ASD2PP_diff_12_ONL.db
+ToolSvc.TGCCablingDbTool                             INFO giveASD2PP_DIFF_12 (m_ASD2PP_DIFF_12 is not NULL)
+MuonTGC_CablingSvc                                   INFO   AlgTool: MuonTGC_CablingSvc.TGCCablingDbTool
+TgcRawDataProvider.TGC_RawDataProviderToolMT         INFO initialize() successful in TgcRawDataProvider.TGC_RawDataProviderToolMT
+MdtRawDataProvider                                   INFO MdtRawDataProvider::initialize
+MdtRawDataProvider                                   INFO  'DoSeededDecoding':False
+ClassIDSvc                                           INFO  getRegistryEntries: read 1427 CLIDRegistry entries for module ALL
+MdtRawDataProvider.MDT_RawDataProviderToolMT         INFO Retrieved service ROBDataProviderSvc = ServiceHandle('ROBDataProviderSvc')
+MdtRawDataProvider.MDT_RawDataPro...MdtROD_Decoder   INFO Processing configuration for layouts with BME chambers.
+MdtRawDataProvider.MDT_RawDataPro...MdtROD_Decoder   INFO Processing configuration for layouts with BMG chambers.
+MdtRawDataProvider.MDT_RawDataProviderToolMT         INFO Retrieved tool Decoder = PrivateToolHandle('MdtROD_Decoder/MdtROD_Decoder')
+MdtRawDataProvider.MDT_RawDataProviderToolMT         INFO initialize() successful in MdtRawDataProvider.MDT_RawDataProviderToolMT
+ClassIDSvc                                           INFO  getRegistryEntries: read 1008 CLIDRegistry entries for module ALL
+CscRawDataProvider.CSC_RawDataProviderToolMT         INFO Retrieved service ServiceHandle('ROBDataProviderSvc')
+CscRawDataProvider.CSC_RawDataProviderToolMT         INFO Retrieved tool Decoder = PrivateToolHandle('Muon::CscROD_Decoder/CscROD_Decoder')
+CscRawDataProvider.CSC_RawDataProviderToolMT         INFO initialize() successful in CscRawDataProvider.CSC_RawDataProviderToolMT
+ClassIDSvc                                           INFO  getRegistryEntries: read 54 CLIDRegistry entries for module ALL
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO package version = MuonRPC_CnvTools-00-00-00
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO properties are 
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO produceRpcCoinDatafromTriggerWords 1
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO reduceCablingOverlap               1
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO solvePhiAmbiguities                1
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO timeShift                          -12.5
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO etaphi_coincidenceTime             20
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO overlap_timeTolerance              10
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO Correct prd time from cool db      0
+MuonRPC_CablingSvc                                   INFO Initializing MuonRPC_CablingSvc - package version MuonRPC_Cabling-00-00-00
+ToolSvc.RPCCablingDbTool                             INFO Initializing - folders names are: conf /RPC/CABLING/MAP_SCHEMA / corr /RPC/CABLING/MAP_SCHEMA_CORR
+MuonRPC_CablingSvc                                   INFO RPCCablingDbTool retrieved with handle TheRpcCablingDbTool = PublicToolHandle('RPCCablingDbTool/RPCCablingDbTool')
+MuonRPC_CablingSvc                                   INFO Register call-back  against 2 folders listed below 
+MuonRPC_CablingSvc                                   INFO  Folder n. 1 </RPC/CABLING/MAP_SCHEMA>     found in the DetStore
+ClassIDSvc                                           INFO  getRegistryEntries: read 242 CLIDRegistry entries for module ALL
+MuonRPC_CablingSvc                                   INFO initMappingModel registered for call-back against folder </RPC/CABLING/MAP_SCHEMA>
+MuonRPC_CablingSvc                                   INFO  Folder n. 2 </RPC/CABLING/MAP_SCHEMA_CORR>     found in the DetStore
+MuonRPC_CablingSvc                                   INFO initMappingModel registered for call-back against folder </RPC/CABLING/MAP_SCHEMA_CORR>
+MuonRPC_CablingSvc                                   INFO RPCTriggerDbTool retrieved with statusCode = SUCCESS pointer = TheRpcTriggerDbTool = PublicToolHandle('RPCTriggerDbTool')
+MuonRPC_CablingSvc                                   INFO Register call-back  against 2 folders listed below 
+MuonRPC_CablingSvc                                   INFO  Folder n. 1 </RPC/TRIGGER/CM_THR_ETA>     found in the DetStore
+MuonRPC_CablingSvc                                   INFO initTrigRoadsModel registered for call-back against folder </RPC/TRIGGER/CM_THR_ETA>
+MuonRPC_CablingSvc                                   INFO  Folder n. 2 </RPC/TRIGGER/CM_THR_PHI>     found in the DetStore
+MuonRPC_CablingSvc                                   INFO initTrigRoadsModel registered for call-back against folder </RPC/TRIGGER/CM_THR_PHI>
+MuonRPC_CablingSvc                                   INFO   AlgTool: ToolSvc.RPCCablingDbTool
+MuonRPC_CablingSvc                                   INFO   AlgTool: ToolSvc.RPCTriggerDbTool
+RpcRdoToRpcPrepData                                  INFO Retrieved DecodingTool = PrivateToolHandle('Muon::RpcRdoToPrepDataToolMT/RpcRdoToRpcPrepDataTool')
+ClassIDSvc                                           INFO  getRegistryEntries: read 169 CLIDRegistry entries for module ALL
+TgcRdoToTgcPrepData.TgcRdoToTgcPrepDataTool          INFO initialize() successful in TgcRdoToTgcPrepData.TgcRdoToTgcPrepDataTool
+TgcRdoToTgcPrepData                                  INFO Retrieved DecodingTool = PrivateToolHandle('Muon::TgcRdoToPrepDataToolMT/TgcRdoToTgcPrepDataTool')
+MdtRdoToMdtPrepData.MdtRdoToM...MdtCalibrationTool   INFO Processing configuration for layouts with BMG chambers.
+MdtRdoToMdtPrepData.MdtRdoToMdtPrepDataTool          INFO Processing configuration for layouts with BME chambers.
+MdtRdoToMdtPrepData.MdtRdoToMdtPrepDataTool          INFO Processing configuration for layouts with BMG chambers.
+MdtRdoToMdtPrepData                                  INFO Retrieved DecodingTool = PrivateToolHandle('Muon::MdtRdoToPrepDataToolMT/MdtRdoToMdtPrepDataTool')
+ClassIDSvc                                           INFO  getRegistryEntries: read 116 CLIDRegistry entries for module ALL
+CscRdoToCscPrepData                                  INFO Retrieved CscRdoToCscPrepDataTool = PrivateToolHandle('Muon::CscRdoToCscPrepDataToolMT/CscRdoToCscPrepDataTool')
+ByteStreamInputSvc                                   INFO Initializing ByteStreamInputSvc - package version ByteStreamCnvSvc-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 452 CLIDRegistry entries for module ALL
+EventSelector                                        INFO reinitialization...
+AthenaEventLoopMgr                                   INFO Setup EventSelector service EventSelector
+ApplicationMgr                                       INFO Application Manager Initialized successfully
+ApplicationMgr                                    SUCCESS ****************************** Algorithm Sequence ****************************
+ApplicationMgr                                    SUCCESS AthSequencer/AthMasterSeq
+ApplicationMgr                                    SUCCESS      AthSequencer/AthAlgEvtSeq
+ApplicationMgr                                    SUCCESS           AthSequencer/AthBeginSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg1
+ApplicationMgr                                    SUCCESS           AthSequencer/AthAllAlgSeq
+ApplicationMgr                                    SUCCESS                AthSequencer/AthCondSeq
+ApplicationMgr                                    SUCCESS                     CondInputLoader/CondInputLoader
+ApplicationMgr                                    SUCCESS                     MuonAlignmentCondAlg/MuonAlignmentCondAlg
+ApplicationMgr                                    SUCCESS                     MuonDetectorCondAlg/MuonDetectorCondAlg
+ApplicationMgr                                    SUCCESS                     RpcCablingCondAlg/RpcCablingCondAlg
+ApplicationMgr                                    SUCCESS                     MuonMDT_CablingAlg/MuonMDT_CablingAlg
+ApplicationMgr                                    SUCCESS                     MagField::AtlasFieldMapCondAlg/AtlasFieldMapCondAlg
+ApplicationMgr                                    SUCCESS                     MagField::AtlasFieldCacheCondAlg/AtlasFieldCacheCondAlg
+ApplicationMgr                                    SUCCESS                     RpcCondDbAlg/RpcCondDbAlg
+ApplicationMgr                                    SUCCESS                     RPC_RegSelCondAlg/RegSelCondAlg_RPC
+ApplicationMgr                                    SUCCESS                     TGC_RegSelCondAlg/RegSelCondAlg_TGC
+ApplicationMgr                                    SUCCESS                     MdtCalibDbAlg/MdtCalibDbAlg
+ApplicationMgr                                    SUCCESS                     MDT_RegSelCondAlg/RegSelCondAlg_MDT
+ApplicationMgr                                    SUCCESS                     CscCondDbAlg/CscCondDbAlg
+ApplicationMgr                                    SUCCESS                     CSC_RegSelCondAlg/RegSelCondAlg_CSC
+ApplicationMgr                                    SUCCESS                AthSequencer/AthAlgSeq
+ApplicationMgr                                    SUCCESS                     Muon::RpcRawDataProvider/RpcRawDataProvider
+ApplicationMgr                                    SUCCESS                     Muon::TgcRawDataProvider/TgcRawDataProvider
+ApplicationMgr                                    SUCCESS                     Muon::MdtRawDataProvider/MdtRawDataProvider
+ApplicationMgr                                    SUCCESS                     Muon::CscRawDataProvider/CscRawDataProvider
+ApplicationMgr                                    SUCCESS                     RpcRdoToRpcPrepData/RpcRdoToRpcPrepData
+ApplicationMgr                                    SUCCESS                     TgcRdoToTgcPrepData/TgcRdoToTgcPrepData
+ApplicationMgr                                    SUCCESS                     MdtRdoToMdtPrepData/MdtRdoToMdtPrepData
+ApplicationMgr                                    SUCCESS                     CscRdoToCscPrepData/CscRdoToCscPrepData
+ApplicationMgr                                    SUCCESS                     CscThresholdClusterBuilder/CscThresholdClusterBuilder
+ApplicationMgr                                    SUCCESS           AthSequencer/AthEndSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg2
+ApplicationMgr                                    SUCCESS      AthSequencer/AthOutSeq
+ApplicationMgr                                    SUCCESS ******************************************************************************
+ByteStreamInputSvc                                   INFO Picked valid file: /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/FTHOLD'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/NOISE'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/PED'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/PSLOPE'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/RMS'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/STAT'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/T0BASE'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/T0PHASE'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/EXT/DCS/MAGNETS/SENSORDATA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/GLOBAL/BField/Maps'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/CABLING/MAP_SCHEMA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/CABLING/MEZZANINE_SCHEMA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/RTBLOB'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/T0BLOB'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/CSC/ILINES'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ASBUILTPARAMS'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/BARREL'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEC'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/TGC/SIDEA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/TGC/SIDEC'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/CABLING/MAP_SCHEMA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/CABLING/MAP_SCHEMA_CORR'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DCS/DeadRopanels'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DCS/OffRopanels'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DQMF/ELEMENT_STATUS'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/TRIGGER/CM_THR_ETA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/TRIGGER/CM_THR_PHI'
+ApplicationMgr                                       INFO Application Manager Started successfully
+EventInfoByteStreamAuxCnv                            INFO IsSimulation : 0
+EventInfoByteStreamAuxCnv                            INFO IsTestbeam : 0
+EventInfoByteStreamAuxCnv                            INFO IsCalibration : 0
+AthenaEventLoopMgr                                   INFO   ===>>>  start of run 327265    <<<===
+EventPersistencySvc                                  INFO Added successfully Conversion service:TagInfoMgr
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_RPC/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCCablingMapSchema_2016_2017_01 for folder /RPC/CABLING/MAP_SCHEMA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCCablingMapSchemaCorr_2016_2017_01 for folder /RPC/CABLING/MAP_SCHEMA_CORR
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCTriggerCMThrEta_RUN1-RUN2-HI-02 for folder /RPC/TRIGGER/CM_THR_ETA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCTriggerCMThrPhi_RUN1-RUN2-HI-02 for folder /RPC/TRIGGER/CM_THR_PHI
+IOVDbSvc                                             INFO Disconnecting from COOLONL_RPC/CONDBR2
+IOVDbSvc                                             INFO Opened read transaction for POOL PersistencySvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:AthenaPoolCnvSvc
+MuonRPC_CablingSvc                                   INFO initMappingModel has been called
+MuonRPC_CablingSvc                                   INFO ToolHandle in initMappingModel - <TheRpcCablingDbTool = PublicToolHandle('RPCCablingDbTool/RPCCablingDbTool')>
+MuonRPC_CablingSvc                                   INFO Retrieving cabling singleton; to create an empty one or to get the existing one
+RPCcabling                                           INFO CablingRPC---singleton constructor ---- this must be executed just once
+RPCcabling                                           INFO CablingRPC---The singleton will fill the maps from the COOL streams
+RPCcabling                                           INFO CablingRPC---InitMaps from COOL cannot be executed NOW: empty string
+RPCcabling                                           INFO CablingRPC---The singleton is created here
+RPCcabling                                           INFO CablingRPC--- cacheCleared: s_status = 0
+MuonRPC_CablingSvc                                   INFO Cabling singleton cache has been cleared
+MuonRPC_CablingSvc                                   INFO  Trigger roads will be loaded from COOL
+ToolSvc.RPCCablingDbTool                             INFO LoadParameters /RPC/CABLING/MAP_SCHEMA I=2 
+ToolSvc.RPCCablingDbTool                             INFO loadRPCMap --- Load Map from DB
+ToolSvc.RPCCablingDbTool                             INFO Try to read from folder </RPC/CABLING/MAP_SCHEMA>
+ToolSvc.RPCCablingDbTool                             INFO  CondAttrListCollection from DB folder have been obtained with size 1
+ToolSvc.RPCCablingDbTool                             INFO After Reading folder, Configuration string size is 222202
+ToolSvc.RPCCablingDbTool                             INFO LoadParameters /RPC/CABLING/MAP_SCHEMA_CORR I=2 
+ToolSvc.RPCCablingDbTool                             INFO loadRPCCorr --- Load Corrections from DB
+ToolSvc.RPCCablingDbTool                             INFO Try to read from folder </RPC/CABLING/MAP_SCHEMA_CORR>
+ToolSvc.RPCCablingDbTool                             INFO  CondAttrListCollection from DB folder have been obtained with size 1
+ToolSvc.RPCCablingDbTool                             INFO After Reading folder, Correction string size is 29369
+MuonRPC_CablingSvc                                   INFO  InitMappingModel: Trigger roads not yet loaded from COOL - postpone cabling initialization 
+MuonRPC_CablingSvc                                   INFO initTrigRoadsModel has been called
+MuonRPC_CablingSvc                                   INFO  Trigger roads will be loaded from COOL
+MuonRPC_CablingSvc                                   INFO Retrieve the pointer to the cabling singleton 
+RPCcabling                                           INFO CablingRPC--- cacheCleared: s_status = 0
+MuonRPC_CablingSvc                                   INFO Cabling singleton cache has been cleared
+ToolSvc.RPCTriggerDbTool                             INFO LoadParameters /RPC/TRIGGER/CM_THR_ETA I=2 
+ToolSvc.RPCTriggerDbTool                             INFO LoadParameters /RPC/TRIGGER/CM_THR_PHI I=2 
+MuonRPC_CablingSvc                                   INFO ======== RPC Trigger Roads from COOL - Header infos ========
+MuonRPC_CablingSvc                                   INFO 
 RPC LVL1 Configuration 10.6 with roads from Feb 2012
 L1 THRESHOLDS:   MU4 MU6 MU10 MU11 MU15 MU20
 Road version: "road_files_120209"
@@ -739,18 +737,18 @@ eta high-pt    mu11  mu15   mu20
 phi high-pt    mu11  mu15   mu15
 
 
-RPCcabling           INFO CablingRPC---InitMaps from COOL: going to read configuration
-RPCcabling           INFO CablingRPC--->> RPC cabling map from COOL <<
-RPCcabling           INFO CablingRPC--- ReadConf: map has size 222202
-RPCcabling           INFO CablingRPC--- ReadConf: map n. of lines read is 924
-RPCcabling           INFO CablingRPC--- ReadConf: version is 5.0 Atlas R_07_03_RUN2ver104
-RPCcabling           INFO CablingRPC--- buildRDOmap
-RPCcabling           INFO CablingRPC---InitMaps from COOL: going to read corrections to configuration
-RPCcabling           INFO CablingRPC--->> RPC cabling corrections from COOL <<
-RPCcabling           INFO CablingRPC--- ReadCorr: CorrMap has size 29369
-RPCcabling           INFO CablingRPC--- ReadConf: CorrMap n. of lines read is 743
-RPCcabling           INFO CablingRPC---InitMaps from COOL - maps have been parsed
-MuonRPC_CablingSvc   INFO InitTrigRoadsModel: RPC cabling model is loaded!
+RPCcabling                                           INFO CablingRPC---InitMaps from COOL: going to read configuration
+RPCcabling                                           INFO CablingRPC--->> RPC cabling map from COOL <<
+RPCcabling                                           INFO CablingRPC--- ReadConf: map has size 222202
+RPCcabling                                           INFO CablingRPC--- ReadConf: map n. of lines read is 924
+RPCcabling                                           INFO CablingRPC--- ReadConf: version is 5.0 Atlas R_07_03_RUN2ver104
+RPCcabling                                           INFO CablingRPC--- buildRDOmap
+RPCcabling                                           INFO CablingRPC---InitMaps from COOL: going to read corrections to configuration
+RPCcabling                                           INFO CablingRPC--->> RPC cabling corrections from COOL <<
+RPCcabling                                           INFO CablingRPC--- ReadCorr: CorrMap has size 29369
+RPCcabling                                           INFO CablingRPC--- ReadConf: CorrMap n. of lines read is 743
+RPCcabling                                           INFO CablingRPC---InitMaps from COOL - maps have been parsed
+MuonRPC_CablingSvc                                   INFO InitTrigRoadsModel: RPC cabling model is loaded!
 Level-1 configuration database version 5.0 Atlas R_07_03_RUN2ver104 read.
 Contains 26 Trigger Sector Types:
 negative sectors  0 - 15 ==> 18  2 24  3 19  2 24  4 20  2 24  1 18  5 25  6 
@@ -758,351 +756,351 @@ negative sectors 16 - 31 ==> 21 13 26  6 21  7 16  8 14  7 16  6 21 13 26  1
 positive sectors 32 - 47 ==>  9 24  2 22  9 24  2 23 10 24  2 18  1 25  5 18 
 positive sectors 48 - 63 ==>  1 26 13 21  6 17 12 15 11 17 12 21  6 26 13 22 
 
-MuonRPC_CablingSvc   INFO buildOfflineOnlineMap
-MuonRPC_CablingSvc   INFO Applying FeetPadThresholds : 0,2,5
-MuonRPC_CablingSvc   INFO MuonRPC_CablingSvc initialized succesfully
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186525031, run #327265 0 events processed so far  <<<===
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_CSC/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscFthold-RUN2-BLK-UPD1-007-00 for folder /CSC/FTHOLD
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscNoise-RUN2-BLK-UPD1-007-00 for folder /CSC/NOISE
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscPed-RUN2-BLK-UPD1-007-00 for folder /CSC/PED
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscPslope-RUN2-BLK-UPD1-000-00 for folder /CSC/PSLOPE
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscRms-RUN2-BLK-UPD1-003-00 for folder /CSC/RMS
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscStat-RUN2-BLK-UPD1-008-00 for folder /CSC/STAT
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscT0base-RUN2-BLK-UPD1-001-00 for folder /CSC/T0BASE
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscT0phase-RUN2-BLK-UPD2-001-00 for folder /CSC/T0PHASE
-IOVDbSvc             INFO Disconnecting from COOLOFL_CSC/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_DCS/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_DCS/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_GLOBAL/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to BFieldMap-Run1-14m-v01 for folder /GLOBAL/BField/Maps
-IOVDbSvc             INFO Disconnecting from COOLONL_GLOBAL/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_MDT/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTCablingMapSchema_BMG_01 for folder /MDT/CABLING/MAP_SCHEMA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTCablingMezzanineSchema_M5-RUN2 for folder /MDT/CABLING/MEZZANINE_SCHEMA
-IOVDbSvc             INFO Disconnecting from COOLONL_MDT/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_MDT/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTRT-RUN2-UPD4-21 for folder /MDT/RTBLOB
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTT0-RUN2-UPD4-21 for folder /MDT/T0BLOB
-IOVDbSvc             INFO Disconnecting from COOLOFL_MDT/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_MUONALIGN/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignCscIlines-UPD1-02 for folder /MUONALIGN/CSC/ILINES
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMdtAsbuiltparams-RUN2-BA_ONLY-UPD4-00 for folder /MUONALIGN/MDT/ASBUILTPARAMS
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTBarrelAlign-RUN2-BA_ROLLING_11-BLKP-UPD4-00 for folder /MUONALIGN/MDT/BARREL
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTEndCapAAlign-RUN2-ECA_ROLLING_2015_03_01-UPD4-02 for folder /MUONALIGN/MDT/ENDCAP/SIDEA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTEndCapCAlign-RUN2-ECC_ROLLING_2015_03_01-UPD4-02 for folder /MUONALIGN/MDT/ENDCAP/SIDEC
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignTGCEndCapAAlign-RUN2-TGCA_ROLLING_2011_01-ES1-UPD1-03 for folder /MUONALIGN/TGC/SIDEA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignTGCEndCapCAlign-RUN2-TGCC_ROLLING_2011_01-ES1-UPD1-03 for folder /MUONALIGN/TGC/SIDEC
-IOVDbSvc             INFO Disconnecting from COOLOFL_MUONALIGN/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_RPC/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCDQMFElementStatus_Run1_UPD4-RUN2-01 for folder /RPC/DQMF/ELEMENT_STATUS
-IOVDbSvc             INFO Disconnecting from COOLOFL_RPC/CONDBR2
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/CSC/ILINES>
-MuonAlignmentCo...   INFO Size of CSC/ILINES CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/CSC/ILINES' )  readCscILinesCdo->size()= 1
-MuonAlignmentCo...   INFO Range of CSC/ILINES input is {[0,0,t:1425168000] - [t:4294967294.854775807]}
-MuonAlignmentCo...   INFO recorded new CscInternalAlignmentMapContainer with range {[0,0,t:1425168000] - [t:4294967294.854775807]} into Conditions Store
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ASBUILTPARAMS>
-MuonAlignmentCo...   INFO Size of MDT/ASBUILTPARAMS CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ASBUILTPARAMS' )  ->size()= 1
-MuonAlignmentCo...   INFO Range of MDT/ASBUILTPARAMS input is {[0,0,t:0] - [t:4294967294.854775807]}
-MuonAlignmentCo...   INFO recorded new MdtAsBuiltMapContainer with range {[0,0,t:0] - [t:4294967294.854775807]} into Conditions Store
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/MDT/BARREL>
-MuonAlignmentCo...   INFO Size of /MUONALIGN/MDT/BARREL CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/BARREL' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/MDT/BARREL input is, ALines: {[0,0,t:1497851700] - [t:1498737300]} BLines: {[0,0,t:1497851700] - [t:1498737300]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/MDT/BARREL have IoV = 195569
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/BARREL> loaded
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEA>
-MuonAlignmentCo...   INFO Size of /MUONALIGN/MDT/ENDCAP/SIDEA CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEA' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/MDT/ENDCAP/SIDEA input is, ALines: {[0,0,t:1497891240] - [t:1497898380]} BLines: {[0,0,t:1497891240] - [t:1497898380]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/MDT/ENDCAP/SIDEA have IoV = 195588
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEA> loaded
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEC>
-MuonAlignmentCo...   INFO Size of /MUONALIGN/MDT/ENDCAP/SIDEC CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEC' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/MDT/ENDCAP/SIDEC input is, ALines: {[0,0,t:1497892260] - [t:1497899460]} BLines: {[0,0,t:1497892260] - [t:1497899460]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/MDT/ENDCAP/SIDEC have IoV = 195599
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEC> loaded
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/TGC/SIDEA>
-MuonAlignmentCo...   INFO No BLines decoding will be attempted for folder named /MUONALIGN/TGC/SIDEA
-MuonAlignmentCo...   INFO Size of /MUONALIGN/TGC/SIDEA CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/TGC/SIDEA' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/TGC/SIDEA input is, ALines: {[0,0,t:0] - [t:4294967294.854775807]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/TGC/SIDEA have IoV = 82360
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/TGC/SIDEA> loaded
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/TGC/SIDEC>
-MuonAlignmentCo...   INFO No BLines decoding will be attempted for folder named /MUONALIGN/TGC/SIDEC
-MuonAlignmentCo...   INFO Size of /MUONALIGN/TGC/SIDEC CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/TGC/SIDEC' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/TGC/SIDEC input is, ALines: {[0,0,t:0] - [t:4294967294.854775807]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/TGC/SIDEC have IoV = 82359
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/TGC/SIDEC> loaded
-MuonAlignmentCo...   INFO recorded new ALineMapContainer with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
-MuonAlignmentCo...   INFO recorded new BLineMapContainer with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
-MuonGeoModel         INFO MuonDetectorFactory - constructor  MuonSystem OuterRadius 13000 Length 22030
-MuonDetectorCon...   INFO create MuonDetectorTool - package version = MuonGeoModel-00-00-00
-MuonDetectorCon...   INFO (from GeoModelSvc)    AtlasVersion = <ATLAS-R2-2016-01-00-01>  MuonVersion = <>
-MuonDetectorCon...   INFO Keys for Muon Switches are  (key) ATLAS-R2-2016-01-00-01 (node) ATLAS
-MuonDetectorCon...   INFO (from GeoModelSvc) in AtlasVersion = <ATLAS-R2-2016-01-00-01>  default MuonVersion is <MuonSpectrometer-R.08.01>
-MuonDetectorCon...   INFO Properties have been set as follows: 
-MuonDetectorCon...   INFO     LayoutName                     R
-MuonDetectorCon...   INFO     IncludeCutouts                 0
-MuonDetectorCon...   INFO     IncludeCutoutsBog              0
-MuonDetectorCon...   INFO     IncludeCtbBis                  0
-MuonDetectorCon...   INFO     ControlAlines                  111111
-MuonDetectorCon...   INFO     MinimalGeoFlag                 0
-MuonDetectorCon...   INFO     EnableCscIntAlignment          1
-MuonDetectorCon...   INFO     EnableCscIntAlignmentFromGM    0
-MuonDetectorCon...   INFO     ControlCscIntAlines            111111
-MuonDetectorCon...   INFO     EnableMdtDeformations          1
-MuonDetectorCon...   INFO     EnableMdtAsBuiltParameters     1
-MuGM:MuonFactory     INFO MuonLayout set to <R.08.01> = Development version for DC3 - infrastructures 
-MuGM:MuonFactory     INFO                    BOG cutouts are activated 1 , all other cutouts are disabled 1
-MuGM:MuonFactory     INFO Manager created for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
-MuonGeoModel.MYSQL   INFO GeometryVersion set to <R.08.01>
-MuGM:MuonFactory     INFO Mysql helper class created here for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
-MuGM:MuonFactory     INFO MDTIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO RPCIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO TGCIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO CSCIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO  **************** MuonDetectorFactory001 ************************
-MuGM:MuonFactory     INFO  *** Start building the Muon Geometry Tree **********************
-MuGM:RDBReadAtlas    INFO Start retriving dbObjects with tag = <ATLAS-R2-2016-01-00-01> node <ATLAS>
-RDBAccessSvc      WARNING Could not get the tag for XtomoData node. Returning 0 pointer to IRDBQuery
-MuGM:RDBReadAtlas    INFO After getQuery XtomoData
+MuonRPC_CablingSvc                                   INFO buildOfflineOnlineMap
+MuonRPC_CablingSvc                                   INFO Applying FeetPadThresholds : 0,2,5
+MuonRPC_CablingSvc                                   INFO MuonRPC_CablingSvc initialized succesfully
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186525031, run #327265 0 events processed so far  <<<===
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_CSC/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscFthold-RUN2-BLK-UPD1-007-00 for folder /CSC/FTHOLD
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscNoise-RUN2-BLK-UPD1-007-00 for folder /CSC/NOISE
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscPed-RUN2-BLK-UPD1-007-00 for folder /CSC/PED
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscPslope-RUN2-BLK-UPD1-000-00 for folder /CSC/PSLOPE
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscRms-RUN2-BLK-UPD1-003-00 for folder /CSC/RMS
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscStat-RUN2-BLK-UPD1-008-00 for folder /CSC/STAT
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscT0base-RUN2-BLK-UPD1-001-00 for folder /CSC/T0BASE
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscT0phase-RUN2-BLK-UPD2-001-00 for folder /CSC/T0PHASE
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_CSC/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_DCS/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_DCS/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_GLOBAL/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to BFieldMap-Run1-14m-v01 for folder /GLOBAL/BField/Maps
+IOVDbSvc                                             INFO Disconnecting from COOLONL_GLOBAL/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_MDT/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTCablingMapSchema_BMG_01 for folder /MDT/CABLING/MAP_SCHEMA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTCablingMezzanineSchema_M5-RUN2 for folder /MDT/CABLING/MEZZANINE_SCHEMA
+IOVDbSvc                                             INFO Disconnecting from COOLONL_MDT/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_MDT/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTRT-RUN2-UPD4-21 for folder /MDT/RTBLOB
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTT0-RUN2-UPD4-21 for folder /MDT/T0BLOB
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_MDT/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_MUONALIGN/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignCscIlines-UPD1-02 for folder /MUONALIGN/CSC/ILINES
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMdtAsbuiltparams-RUN2-BA_ONLY-UPD4-00 for folder /MUONALIGN/MDT/ASBUILTPARAMS
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTBarrelAlign-RUN2-BA_ROLLING_11-BLKP-UPD4-00 for folder /MUONALIGN/MDT/BARREL
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTEndCapAAlign-RUN2-ECA_ROLLING_2015_03_01-UPD4-02 for folder /MUONALIGN/MDT/ENDCAP/SIDEA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTEndCapCAlign-RUN2-ECC_ROLLING_2015_03_01-UPD4-02 for folder /MUONALIGN/MDT/ENDCAP/SIDEC
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignTGCEndCapAAlign-RUN2-TGCA_ROLLING_2011_01-ES1-UPD1-03 for folder /MUONALIGN/TGC/SIDEA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignTGCEndCapCAlign-RUN2-TGCC_ROLLING_2011_01-ES1-UPD1-03 for folder /MUONALIGN/TGC/SIDEC
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_MUONALIGN/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_RPC/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCDQMFElementStatus_Run1_UPD4-RUN2-01 for folder /RPC/DQMF/ELEMENT_STATUS
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_RPC/CONDBR2
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/CSC/ILINES>
+MuonAlignmentCondAlg                                 INFO Size of CSC/ILINES CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/CSC/ILINES' )  readCscILinesCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of CSC/ILINES input is {[0,0,t:1425168000] - [t:4294967294.854775807]}
+MuonAlignmentCondAlg                                 INFO recorded new CscInternalAlignmentMapContainer with range {[0,0,t:1425168000] - [t:4294967294.854775807]} into Conditions Store
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ASBUILTPARAMS>
+MuonAlignmentCondAlg                                 INFO Size of MDT/ASBUILTPARAMS CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ASBUILTPARAMS' )  ->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of MDT/ASBUILTPARAMS input is {[0,0,t:0] - [t:4294967294.854775807]}
+MuonAlignmentCondAlg                                 INFO recorded new MdtAsBuiltMapContainer with range {[0,0,t:0] - [t:4294967294.854775807]} into Conditions Store
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/MDT/BARREL>
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/MDT/BARREL CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/BARREL' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/MDT/BARREL input is, ALines: {[0,0,t:1497851700] - [t:1498737300]} BLines: {[0,0,t:1497851700] - [t:1498737300]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/MDT/BARREL have IoV = 195569
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/BARREL> loaded
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEA>
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/MDT/ENDCAP/SIDEA CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEA' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/MDT/ENDCAP/SIDEA input is, ALines: {[0,0,t:1497891240] - [t:1497898380]} BLines: {[0,0,t:1497891240] - [t:1497898380]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/MDT/ENDCAP/SIDEA have IoV = 195588
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEA> loaded
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEC>
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/MDT/ENDCAP/SIDEC CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEC' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/MDT/ENDCAP/SIDEC input is, ALines: {[0,0,t:1497892260] - [t:1497899460]} BLines: {[0,0,t:1497892260] - [t:1497899460]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/MDT/ENDCAP/SIDEC have IoV = 195599
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEC> loaded
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/TGC/SIDEA>
+MuonAlignmentCondAlg                                 INFO No BLines decoding will be attempted for folder named /MUONALIGN/TGC/SIDEA
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/TGC/SIDEA CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/TGC/SIDEA' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/TGC/SIDEA input is, ALines: {[0,0,t:0] - [t:4294967294.854775807]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/TGC/SIDEA have IoV = 82360
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/TGC/SIDEA> loaded
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/TGC/SIDEC>
+MuonAlignmentCondAlg                                 INFO No BLines decoding will be attempted for folder named /MUONALIGN/TGC/SIDEC
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/TGC/SIDEC CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/TGC/SIDEC' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/TGC/SIDEC input is, ALines: {[0,0,t:0] - [t:4294967294.854775807]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/TGC/SIDEC have IoV = 82359
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/TGC/SIDEC> loaded
+MuonAlignmentCondAlg                                 INFO recorded new ALineMapContainer with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
+MuonAlignmentCondAlg                                 INFO recorded new BLineMapContainer with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
+MuonGeoModel                                         INFO MuonDetectorFactory - constructor  MuonSystem OuterRadius 13000 Length 22030
+MuonDetectorCondAlg.MuonDetectorTool                 INFO create MuonDetectorTool - package version = MuonGeoModel-00-00-00
+MuonDetectorCondAlg.MuonDetectorTool                 INFO (from GeoModelSvc)    AtlasVersion = <ATLAS-R2-2016-01-00-01>  MuonVersion = <>
+MuonDetectorCondAlg.MuonDetectorTool                 INFO Keys for Muon Switches are  (key) ATLAS-R2-2016-01-00-01 (node) ATLAS
+MuonDetectorCondAlg.MuonDetectorTool                 INFO (from GeoModelSvc) in AtlasVersion = <ATLAS-R2-2016-01-00-01>  default MuonVersion is <MuonSpectrometer-R.08.01>
+MuonDetectorCondAlg.MuonDetectorTool                 INFO Properties have been set as follows: 
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     LayoutName                     R
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     IncludeCutouts                 0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     IncludeCutoutsBog              0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     IncludeCtbBis                  0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     ControlAlines                  111111
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     MinimalGeoFlag                 0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     EnableCscIntAlignment          1
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     EnableCscIntAlignmentFromGM    0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     ControlCscIntAlines            111111
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     EnableMdtDeformations          1
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     EnableMdtAsBuiltParameters     1
+MuGM:MuonFactory                                     INFO MuonLayout set to <R.08.01> = Development version for DC3 - infrastructures 
+MuGM:MuonFactory                                     INFO                    BOG cutouts are activated 1 , all other cutouts are disabled 1
+MuGM:MuonFactory                                     INFO Manager created for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
+MuonGeoModel.MYSQL                                   INFO GeometryVersion set to <R.08.01>
+MuGM:MuonFactory                                     INFO Mysql helper class created here for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
+MuGM:MuonFactory                                     INFO MDTIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO RPCIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO TGCIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO CSCIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO  **************** MuonDetectorFactory001 ************************
+MuGM:MuonFactory                                     INFO  *** Start building the Muon Geometry Tree **********************
+MuGM:RDBReadAtlas                                    INFO Start retriving dbObjects with tag = <ATLAS-R2-2016-01-00-01> node <ATLAS>
+RDBAccessSvc                                      WARNING Could not get the tag for XtomoData node. Returning 0 pointer to IRDBQuery
+MuGM:RDBReadAtlas                                    INFO After getQuery XtomoData
 In DblQ00Xtomo(data)
 No XtomoData table in the MuonDD Database
-MuGM:RDBReadAtlas    INFO After new DblQ00Xtomo
-MuGM:RDBReadAtlas    INFO No Ascii aszt input found: looking for A-lines in ORACLE
-MuGM:RDBReadAtlas    INFO ASZT table found in Oracle
-MuGM:RDBReadAtlas    INFO ASZT size is 32
-MuGM:RDBReadAtlas    INFO No Ascii iacsc input found: looking for A-lines in ORACLE
-RDBAccessSvc      WARNING Could not get the tag for ISZT node. Returning 0 pointer to IRDBQuery
-MuGM:RDBReadAtlas    INFO No ISZT table in Oracle
-MuGM:RDBReadAtlas    INFO Access granted for all dbObjects needed by muon detectors
-MuonGeoModel.MYSQL   INFO LayoutName (from DBAM) set to <R.08>  -- relevant for CTB2004
-MuGM:ProcStations    INFO  Processing Stations and Components
-MuGM:ProcStations    INFO  Processing Stations and Components DONE
-MuGM:ProcTechnol.s   INFO nMDT 26 nCSC 4 nTGC 44 nRPC 50
-MuGM:ProcTechnol.s   INFO nDED 4 nSUP 8 nSPA 4
-MuGM:ProcTechnol.s   INFO nCHV 14 nCRO 14 nCMI 12 nLBI 12
-MuGM:ProcPosition    INFO  *** N. of stations positioned in the setup 234
-MuGM:ProcPosition    INFO  *** N. of stations described in mysql      234
-MuGM:ProcPosition    INFO  *** N. of types  32 size of jtypvec 32
-MuGM:ProcPosition    INFO  *** : 234 kinds of stations (type*sub_type) 
-MuGM:ProcPosition    INFO  *** : 1758 physical stations in space - according to the MuonDD DataBase
-MuGM:ProcCutouts     INFO  Processing Cutouts for geometry layout R.08
-MuGM:ProcCutouts     INFO  Processing Cutouts DONE
-MuGM:RDBReadAtlas    INFO  ProcessTGCreadout - version 7 wirespacing 1.8
-MuGM:RDBReadAtlas    INFO Intermediate Objects built from primary numbers
-MuGM:MuonFactory     INFO  theMaterialManager retrieven successfully from the DetStore
-MuGM:MuonFactory     INFO MuonSystem description from OracleTag=<ATLAS-R2-2016-01-00-01> and node=<ATLAS>
-MuGM:MuonFactory     INFO  TreeTop added to the Manager
-MuGM:MuonFactory     INFO  Muon Layout R.08.01
-MuGM:MuonFactory     INFO Fine Clash Fixing disabled: (should be ON/OFF for Simulation/Reconstruction)
-MuGM:MuonFactory     INFO  **************** MuonDetectorFactory001 ****************************
-MuGM:MuonFactory     INFO  *** The Muon Chamber Geometry Tree is built with 
-MuGM:MuonFactory     INFO  *** 1758 child volumes 
-MuGM:MuonFactory     INFO  *** 1839 independent elements and 
-MuGM:MuonFactory     INFO  *** 11473 elements cloned or shared 
-MuGM:MuonFactory     INFO  *** 234 kinds of stations
-MuGM:MuonFactory     INFO  *** 1758 stations with alignable transforms
-MuGM:MuonFactory     INFO  *** 148 stations are described as Assemblies
-MuGM:MuonFactory     INFO  *** 1758 MuonStations 
-MuGM:MuonFactory     INFO  *** 	 2324 MDT Readout Elements 	 1186 MDT Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 32 CSC Readout Elements 	 32 CSC Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 1122 RPC Readout Elements 	 600 RPC Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 1578 TGC Readout Elements 	 1578 TGC Detector Elements 
-MuGM:MuonFactory     INFO  ********************************************************************
-MuGM:MuonFactory     INFO  *** Inert Material built according to DB switches and config. ****** 
-MuGM:MuonFactory     INFO  *** The Muon Geometry Tree has 1758 child vol.s in total ********
-MuGM:MuonFactory     INFO  ********************************************************************
+MuGM:RDBReadAtlas                                    INFO After new DblQ00Xtomo
+MuGM:RDBReadAtlas                                    INFO No Ascii aszt input found: looking for A-lines in ORACLE
+MuGM:RDBReadAtlas                                    INFO ASZT table found in Oracle
+MuGM:RDBReadAtlas                                    INFO ASZT size is 32
+MuGM:RDBReadAtlas                                    INFO No Ascii iacsc input found: looking for A-lines in ORACLE
+RDBAccessSvc                                      WARNING Could not get the tag for ISZT node. Returning 0 pointer to IRDBQuery
+MuGM:RDBReadAtlas                                    INFO No ISZT table in Oracle
+MuGM:RDBReadAtlas                                    INFO Access granted for all dbObjects needed by muon detectors
+MuonGeoModel.MYSQL                                   INFO LayoutName (from DBAM) set to <R.08>  -- relevant for CTB2004
+MuGM:ProcStations                                    INFO  Processing Stations and Components
+MuGM:ProcStations                                    INFO  Processing Stations and Components DONE
+MuGM:ProcTechnol.s                                   INFO nMDT 26 nCSC 4 nTGC 44 nRPC 50
+MuGM:ProcTechnol.s                                   INFO nDED 4 nSUP 8 nSPA 4
+MuGM:ProcTechnol.s                                   INFO nCHV 14 nCRO 14 nCMI 12 nLBI 12
+MuGM:ProcPosition                                    INFO  *** N. of stations positioned in the setup 234
+MuGM:ProcPosition                                    INFO  *** N. of stations described in mysql      234
+MuGM:ProcPosition                                    INFO  *** N. of types  32 size of jtypvec 32
+MuGM:ProcPosition                                    INFO  *** : 234 kinds of stations (type*sub_type) 
+MuGM:ProcPosition                                    INFO  *** : 1758 physical stations in space - according to the MuonDD DataBase
+MuGM:ProcCutouts                                     INFO  Processing Cutouts for geometry layout R.08
+MuGM:ProcCutouts                                     INFO  Processing Cutouts DONE
+MuGM:RDBReadAtlas                                    INFO  ProcessTGCreadout - version 7 wirespacing 1.8
+MuGM:RDBReadAtlas                                    INFO Intermediate Objects built from primary numbers
+MuGM:MuonFactory                                     INFO  theMaterialManager retrieven successfully from the DetStore
+MuGM:MuonFactory                                     INFO MuonSystem description from OracleTag=<ATLAS-R2-2016-01-00-01> and node=<ATLAS>
+MuGM:MuonFactory                                     INFO  TreeTop added to the Manager
+MuGM:MuonFactory                                     INFO  Muon Layout R.08.01
+MuGM:MuonFactory                                     INFO Fine Clash Fixing disabled: (should be ON/OFF for Simulation/Reconstruction)
+MuGM:MuonFactory                                     INFO  **************** MuonDetectorFactory001 ****************************
+MuGM:MuonFactory                                     INFO  *** The Muon Chamber Geometry Tree is built with 
+MuGM:MuonFactory                                     INFO  *** 1758 child volumes 
+MuGM:MuonFactory                                     INFO  *** 1839 independent elements and 
+MuGM:MuonFactory                                     INFO  *** 11473 elements cloned or shared 
+MuGM:MuonFactory                                     INFO  *** 234 kinds of stations
+MuGM:MuonFactory                                     INFO  *** 1758 stations with alignable transforms
+MuGM:MuonFactory                                     INFO  *** 148 stations are described as Assemblies
+MuGM:MuonFactory                                     INFO  *** 1758 MuonStations 
+MuGM:MuonFactory                                     INFO  *** 	 2324 MDT Readout Elements 	 1186 MDT Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 32 CSC Readout Elements 	 32 CSC Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 1122 RPC Readout Elements 	 600 RPC Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 1578 TGC Readout Elements 	 1578 TGC Detector Elements 
+MuGM:MuonFactory                                     INFO  ********************************************************************
+MuGM:MuonFactory                                     INFO  *** Inert Material built according to DB switches and config. ****** 
+MuGM:MuonFactory                                     INFO  *** The Muon Geometry Tree has 1758 child vol.s in total ********
+MuGM:MuonFactory                                     INFO  ********************************************************************
 
-MGM::MuonDetect...   INFO Init A/B Line Containers - done - size is respectively 1758/0
-MGM::MuonDetect...   INFO Init of CSC I-Lines will be done via Conditions DB
-MGM::MuonDetect...   INFO Init I-Line Container - done - size is respectively 128
-MGM::MuonDetect...   INFO I-Line for CSC wire layers loaded (Csc Internal Alignment)
-MGM::MuonDetect...   INFO According to configuration they WILL be used 
-MGM::MuonDetect...   INFO Filling cache
-MGM::MuonDetect...   INFO temporary CSC I-line container with size = 128
-MGM::MuonDetect...   INFO # of CSC I-lines read from the ILineMapContainer in StoreGate is 128
-MGM::MuonDetect...   INFO # of deltaTransforms updated according to A-lines             is 128
-MGM::MuonDetect...   INFO # of entries in the CSC I-lines historical container          is 128
-MGM::MuonDetect...   INFO temporary As-Built container with size = 628
-MGM::MuonDetect...   INFO # of MDT As-Built read from the MdtAsBuiltMapContainer in StoreGate is 628
-MGM::MuonDetect...   INFO # of deltaTransforms updated according to As-Built                  is 628
-MGM::MuonDetect...   INFO # of entries in the MdtAsBuilt historical container                 is 628
-MGM::MuonDetect...   INFO temporary A-line container with size = 2694
-MGM::MuonDetect...   INFO # of A-lines read from the ALineMapContainer in StoreGate is 2694
-MGM::MuonDetect...   INFO # of deltaTransforms updated according to A-lines         is 2694
-MGM::MuonDetect...   INFO # of entries in the A-lines historical container          is 2814
-MGM::MuonDetect...   INFO In updateDeformations()
-MGM::MuonDetect...   INFO temporary B-line container with size = 1206
-MGM::MuonDetect...   INFO # of B-lines read from the ALineMapContainer in StoreGate   is 1206
-MGM::MuonDetect...   INFO # of deform-Transforms updated according to B-lines         is 1174
-MGM::MuonDetect...   INFO # of entries in the B-lines historical container            is 1174
-MuonDetectorCon...   INFO recorded new MuonDetectorManager with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
-RpcCablingCondAlg    INFO maps configuration have been parsed
-RpcCablingCondAlg    INFO recorded new RpcCablingCondData with range {[315000,l:0] - [999999,l:0]}
-MuonMDT_CablingAlg   INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/CABLING/MEZZANINE_SCHEMA' )  readCdoMez->size()= 24
-MuonMDT_CablingAlg   INFO Range of input is {[0,l:0] - [INVALID]}
-MuonMDT_CablingAlg   INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/CABLING/MAP_SCHEMA' )  readCdoMap->size()= 2312
-MuonMDT_CablingAlg   INFO Range of input is {[327264,l:4294640031] - [327265,l:4294640030]}
-MuonMDT_CablingAlg   INFO recorded new MuonMDT_CablingMap with range {[327264,t:0,l:4294640031] - [327265,l:4294640030]} into Conditions Store
-AtlasFieldMapCo...   INFO updateFieldMap: Update map from conditions
-AtlasFieldMapCo...   INFO updateFieldMap: Update map from conditions: Range of input/output is {[0,l:0] - [INVALID]}
-AtlasFieldMapCo...   INFO updateFieldMap: reading magnetic field map filenames from COOL
-AtlasFieldMapCo...   INFO updateFieldMap: found map of type GlobalMap with soleCur=7730 toroCur=20400 (path file:MagneticFieldMaps/bfieldmap_7730_20400_14m.root)
-AtlasFieldMapCo...   INFO updateFieldMap: found map of type SolenoidMap with soleCur=7730 toroCur=0 (path file:MagneticFieldMaps/bfieldmap_7730_0_14m.root)
-AtlasFieldMapCo...   INFO updateFieldMap: found map of type ToroidMap with soleCur=0 toroCur=20400 (path file:MagneticFieldMaps/bfieldmap_0_20400_14m.root)
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Range of input currents is {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Attempt 1 at reading currents from DCS (using channel name)
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_Current , 1 , 7729.99
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_SCurrent , 2 , 7730
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_Current , 3 , 20399.9
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_SCurrent , 4 , 20397.7
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Currents read from DCS - solenoid 7729.99 toroid 20399.9
-AtlasFieldMapCo...   INFO updateFieldMap: currents are OK, will use nominal maps
-AtlasFieldMapCo...   INFO updateFieldMap: tagInfoH  ( 'TagInfo' , 'DetectorStore+ProcessingTags' )  is valid. 
-AtlasFieldMapCo...   INFO updateFieldMap: DID NOT reset currents from TagInfo
-AtlasFieldMapCo...   INFO updateFieldMap: Set map currents from FieldSvc: solenoid/toroid 7730,20400
-AtlasFieldMapCo...   INFO updateFieldMap: Use map file MagneticFieldMaps/bfieldmap_7730_20400_14m.root
-AtlasFieldMapCo...   INFO updateFieldMap: Initialized the field map from /cvmfs/atlas.cern.ch/repo/sw/database/GroupData/MagneticFieldMaps/bfieldmap_7730_20400_14m.root
-AtlasFieldMapCo...   INFO execute: solenoid zone id  7000
-AtlasFieldMapCo...   INFO execute: recorded AtlasFieldMapCondObj with EventRange {[0,l:0] - [INVALID]}
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Range of input/output is {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Attempt 1 at reading currents from DCS (using channel name)
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_Current , 1 , 7729.99
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_SCurrent , 2 , 7730
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_Current , 3 , 20399.9
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_SCurrent , 4 , 20397.7
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Currents read from DCS - solenoid 7729.99 toroid 20399.9
-AtlasFieldCache...   INFO scaleField: Solenoid field scale factor 1. Desired current and map current: 7729.99,7730
-AtlasFieldCache...   INFO scaleField: Toroid field scale factor 1. Desired current and map current: 20399.9,20400
-AtlasFieldCache...   INFO execute: initialized AtlasFieldCacheCondObj and cache with SFs - sol/tor 1/1, EventRange {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
-AtlasFieldCache...   INFO execute: solenoid zone id  7000
-RegSelCondAlg_RPC    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_RPC'
-RegSelCondAlg_TGC    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_TGC'
-MdtCalibDbAlg        INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/RTBLOB' )  readCdoRt->size()= 1186
-MdtCalibDbAlg        INFO Range of input is {[327265,l:0] - [327342,l:0]}
-MdtCalibDbAlg        INFO MdtCalibDbAlg::loadRt Read 1188RTs from COOL
-MdtCalibDbAlg        INFO recorded new MdtRtRelationCollection with range {[327265,l:0] - [327342,l:0]} into Conditions Store
-MdtCalibDbAlg        INFO recorded new MdtCorFuncSetCollection with range {[327265,l:0] - [327342,l:0]} into Conditions Store
-MdtCalibDbAlg        INFO Ignoring nonexistant station in calibration DB: MuonSpectrometer BML -6 stationPhi 7 MDT multiLayer 1 tubeLayer 1 tube 1
-MdtCalibDbAlg        INFO Ignoring nonexistant station in calibration DB: MuonSpectrometer BML stationEta 6 stationPhi 7 MDT multiLayer 1 tubeLayer 1 tube 1
-MdtCalibDbAlg        INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/T0BLOB' )  readCdoTube->size()= 1186
-MdtCalibDbAlg        INFO Range of input is {[319000,l:0] - [INVALID]}
-MdtCalibDbAlg        INFO recorded new MdtTubeCalibContainerCollection with range {[319000,l:0] - [INVALID]} into Conditions Store
-RegSelCondAlg_MDT    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_MDT'
-RegSelCondAlg_CSC    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_CSC'
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186525031, run #327265 1 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186524665, run #327265 1 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186524665, run #327265 2 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186542447, run #327265 2 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186542447, run #327265 3 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186543405, run #327265 3 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186543405, run #327265 4 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186548387, run #327265 4 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186548387, run #327265 5 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186515186, run #327265 5 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186515186, run #327265 6 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186556019, run #327265 6 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186556019, run #327265 7 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186542866, run #327265 7 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186542866, run #327265 8 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186537901, run #327265 8 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186537901, run #327265 9 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186517811, run #327265 9 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186517811, run #327265 10 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186534221, run #327265 10 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186534221, run #327265 11 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186540986, run #327265 11 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186540986, run #327265 12 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186535104, run #327265 12 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186535104, run #327265 13 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186539903, run #327265 13 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186539903, run #327265 14 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186552713, run #327265 14 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186552713, run #327265 15 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186524730, run #327265 15 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186524730, run #327265 16 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186547632, run #327265 16 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186547632, run #327265 17 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186555621, run #327265 17 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186555621, run #327265 18 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186568452, run #327265 18 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186568452, run #327265 19 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186580451, run #327265 19 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186580451, run #327265 20 events processed so far  <<<===
-Domain[ROOT_All]     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
-ApplicationMgr       INFO Application Manager Stopped successfully
-IncidentProcAlg1     INFO Finalize
-CondInputLoader      INFO Finalizing CondInputLoader...
-IncidentProcAlg2     INFO Finalize
-IOVDbFolder          INFO Folder /CSC/FTHOLD (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/322656 ((     0.06 ))s
-IOVDbFolder          INFO Folder /CSC/NOISE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/350062 ((     0.06 ))s
-IOVDbFolder          INFO Folder /CSC/PED (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/411187 ((     0.07 ))s
-IOVDbFolder          INFO Folder /CSC/PSLOPE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/353376 ((     0.03 ))s
-IOVDbFolder          INFO Folder /CSC/RMS (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/411395 ((     0.04 ))s
-IOVDbFolder          INFO Folder /CSC/STAT (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/230496 ((     0.04 ))s
-IOVDbFolder          INFO Folder /CSC/T0BASE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/314380 ((     0.02 ))s
-IOVDbFolder          INFO Folder /CSC/T0PHASE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/3136 ((     0.03 ))s
-IOVDbFolder          INFO Folder /EXT/DCS/MAGNETS/SENSORDATA (AttrListColl) db-read 1/1 objs/chan/bytes 4/4/20 ((     0.04 ))s
-IOVDbFolder          INFO Folder /GLOBAL/BField/Maps (AttrListColl) db-read 1/1 objs/chan/bytes 3/3/202 ((     0.03 ))s
-IOVDbFolder          INFO Folder /MDT/CABLING/MAP_SCHEMA (AttrListColl) db-read 1/1 objs/chan/bytes 2312/2437/216520 ((     0.13 ))s
-IOVDbFolder          INFO Folder /MDT/CABLING/MEZZANINE_SCHEMA (AttrListColl) db-read 1/1 objs/chan/bytes 24/24/288 ((     0.02 ))s
-IOVDbFolder          INFO Folder /MDT/RTBLOB (AttrListColl) db-read 1/1 objs/chan/bytes 2372/1186/2251209 ((     0.13 ))s
-IOVDbFolder          INFO Folder /MDT/T0BLOB (AttrListColl) db-read 1/1 objs/chan/bytes 1186/1186/1374284 ((     0.12 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/CSC/ILINES (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/10814 ((     0.03 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/MDT/ASBUILTPARAMS (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/128992 ((     0.02 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/MDT/BARREL (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/140293 ((     0.04 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/MDT/ENDCAP/SIDEA (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/65494 ((     0.04 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/MDT/ENDCAP/SIDEC (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/65497 ((     0.04 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/TGC/SIDEA (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/165643 ((     0.03 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/TGC/SIDEC (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/165643 ((     0.03 ))s
-IOVDbFolder          INFO Folder /RPC/CABLING/MAP_SCHEMA (AttrListColl) db-read 1/2 objs/chan/bytes 1/1/222235 ((     0.06 ))s
-IOVDbFolder          INFO Folder /RPC/CABLING/MAP_SCHEMA_CORR (AttrListColl) db-read 1/2 objs/chan/bytes 1/1/29402 ((     0.04 ))s
-IOVDbFolder          INFO Folder /RPC/DCS/DeadRopanels (AttrListColl) db-read 1/1 objs/chan/bytes 32/48/6200 ((     0.00 ))s
-IOVDbFolder          INFO Folder /RPC/DCS/OffRopanels (AttrListColl) db-read 1/1 objs/chan/bytes 4/48/16 ((     0.00 ))s
-IOVDbFolder          INFO Folder /RPC/DQMF/ELEMENT_STATUS (AttrListColl) db-read 1/1 objs/chan/bytes 8320/8320/6180700 ((     0.18 ))s
-IOVDbFolder          INFO Folder /RPC/TRIGGER/CM_THR_ETA (AttrListColl) db-read 1/2 objs/chan/bytes 1613/1613/7562651 ((     0.10 ))s
-IOVDbFolder          INFO Folder /RPC/TRIGGER/CM_THR_PHI (AttrListColl) db-read 1/2 objs/chan/bytes 1612/1612/8096306 ((     0.07 ))s
-IOVDbFolder          INFO Folder /TGC/CABLING/MAP_SCHEMA (AttrListColl) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
-IOVDbSvc             INFO  bytes in ((      1.49 ))s
-IOVDbSvc             INFO Connection sqlite://;schema=mycool.db;dbname=CONDBR2 : nConnect: 0 nFolders: 0 ReadTime: ((     0.00 ))s
-IOVDbSvc             INFO Connection COOLOFL_MUONALIGN/CONDBR2 : nConnect: 2 nFolders: 7 ReadTime: ((     0.23 ))s
-IOVDbSvc             INFO Connection COOLONL_RPC/CONDBR2 : nConnect: 2 nFolders: 4 ReadTime: ((     0.27 ))s
-IOVDbSvc             INFO Connection COOLONL_TGC/CONDBR2 : nConnect: 1 nFolders: 1 ReadTime: ((     0.00 ))s
-IOVDbSvc             INFO Connection COOLONL_MDT/CONDBR2 : nConnect: 2 nFolders: 2 ReadTime: ((     0.15 ))s
-IOVDbSvc             INFO Connection COOLONL_GLOBAL/CONDBR2 : nConnect: 2 nFolders: 1 ReadTime: ((     0.03 ))s
-IOVDbSvc             INFO Connection COOLOFL_DCS/CONDBR2 : nConnect: 2 nFolders: 3 ReadTime: ((     0.04 ))s
-IOVDbSvc             INFO Connection COOLOFL_RPC/CONDBR2 : nConnect: 2 nFolders: 1 ReadTime: ((     0.18 ))s
-IOVDbSvc             INFO Connection COOLOFL_MDT/CONDBR2 : nConnect: 2 nFolders: 2 ReadTime: ((     0.25 ))s
-IOVDbSvc             INFO Connection COOLOFL_CSC/CONDBR2 : nConnect: 2 nFolders: 8 ReadTime: ((     0.34 ))s
-ToolSvc              INFO Removing all tools created by ToolSvc
-TgcRdoToTgcPrep...   INFO finalize(): input RDOs->output PRDs [Hit: 6807->6807, Tracklet: 28->28, TrackletEIFI: 692->692, HiPt: 4031->4031, SL: 3->3]
-MdtRawDataProvi...   INFO Fraction of fills that use the cache = 0
-ToolSvc.TGCCabl...   INFO finalize
-MuonTGC_Cabling...   INFO finalize
-TgcRawDataProvi...   INFO Fraction of fills that use the cache = 0
-RpcROD_Decoder:...   INFO  ============ FINAL RPC DATA FORMAT STAT. =========== 
-RpcROD_Decoder:...   INFO  RX Header Errors.............0
-RpcROD_Decoder:...   INFO  RX SubHeader Errors..........0
-RpcROD_Decoder:...   INFO  PAD Header Errors............0
-RpcROD_Decoder:...   INFO  PAD/SL SubHeader Errors......0
-RpcROD_Decoder:...   INFO  CM Header Errors.............0
-RpcROD_Decoder:...   INFO  CM SubHeader Errors..........0
-RpcROD_Decoder:...   INFO  CM Footer Errors.............0
-RpcROD_Decoder:...   INFO  PAD PreFooter Errors.........0
-RpcROD_Decoder:...   INFO  PAD Footer Errors............0
-RpcROD_Decoder:...   INFO  SL Header Errors.............0
-RpcROD_Decoder:...   INFO  SL Footer Errors.............0
-RpcROD_Decoder:...   INFO  RX Footer Errors.............0
-RpcROD_Decoder:...   INFO  CRC8 check Failures..........0
-RpcROD_Decoder:...   INFO  ==================================================== 
-ToolSvc.ByteStr...   INFO in finalize()
-IdDictDetDescrCnv    INFO in finalize
-*****Chrono*****     INFO ****************************************************************************************************
-*****Chrono*****     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
-*****Chrono*****     INFO ****************************************************************************************************
-cObj_ALL             INFO Time User   : Tot=    0 [us] Ave/Min/Max=       0(+-       0)/       0/       0 [us] #= 32
-ChronoStatSvc        INFO Time User   : Tot= 15.1  [s]  #=  1
-*****Chrono*****     INFO ****************************************************************************************************
-ChronoStatSvc.f...   INFO  Service finalized successfully 
-ApplicationMgr       INFO Application Manager Finalized successfully
-ApplicationMgr       INFO Application Manager Terminated successfully
+MGM::MuonDetectorManager                             INFO Init A/B Line Containers - done - size is respectively 1758/0
+MGM::MuonDetectorManager                             INFO Init of CSC I-Lines will be done via Conditions DB
+MGM::MuonDetectorManager                             INFO Init I-Line Container - done - size is respectively 128
+MGM::MuonDetectorManager                             INFO I-Line for CSC wire layers loaded (Csc Internal Alignment)
+MGM::MuonDetectorManager                             INFO According to configuration they WILL be used 
+MGM::MuonDetectorManager                             INFO Filling cache
+MGM::MuonDetectorManager                             INFO temporary CSC I-line container with size = 128
+MGM::MuonDetectorManager                             INFO # of CSC I-lines read from the ILineMapContainer in StoreGate is 128
+MGM::MuonDetectorManager                             INFO # of deltaTransforms updated according to A-lines             is 128
+MGM::MuonDetectorManager                             INFO # of entries in the CSC I-lines historical container          is 128
+MGM::MuonDetectorManager                             INFO temporary As-Built container with size = 628
+MGM::MuonDetectorManager                             INFO # of MDT As-Built read from the MdtAsBuiltMapContainer in StoreGate is 628
+MGM::MuonDetectorManager                             INFO # of deltaTransforms updated according to As-Built                  is 628
+MGM::MuonDetectorManager                             INFO # of entries in the MdtAsBuilt historical container                 is 628
+MGM::MuonDetectorManager                             INFO temporary A-line container with size = 2694
+MGM::MuonDetectorManager                             INFO # of A-lines read from the ALineMapContainer in StoreGate is 2694
+MGM::MuonDetectorManager                             INFO # of deltaTransforms updated according to A-lines         is 2694
+MGM::MuonDetectorManager                             INFO # of entries in the A-lines historical container          is 2814
+MGM::MuonDetectorManager                             INFO In updateDeformations()
+MGM::MuonDetectorManager                             INFO temporary B-line container with size = 1206
+MGM::MuonDetectorManager                             INFO # of B-lines read from the ALineMapContainer in StoreGate   is 1206
+MGM::MuonDetectorManager                             INFO # of deform-Transforms updated according to B-lines         is 1174
+MGM::MuonDetectorManager                             INFO # of entries in the B-lines historical container            is 1174
+MuonDetectorCondAlg                                  INFO recorded new MuonDetectorManager with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
+RpcCablingCondAlg                                    INFO maps configuration have been parsed
+RpcCablingCondAlg                                    INFO recorded new RpcCablingCondData with range {[315000,l:0] - [999999,l:0]}
+MuonMDT_CablingAlg                                   INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/CABLING/MEZZANINE_SCHEMA' )  readCdoMez->size()= 24
+MuonMDT_CablingAlg                                   INFO Range of input is {[0,l:0] - [INVALID]}
+MuonMDT_CablingAlg                                   INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/CABLING/MAP_SCHEMA' )  readCdoMap->size()= 2312
+MuonMDT_CablingAlg                                   INFO Range of input is {[327264,l:4294640031] - [327265,l:4294640030]}
+MuonMDT_CablingAlg                                   INFO recorded new MuonMDT_CablingMap with range {[327264,t:0,l:4294640031] - [327265,l:4294640030]} into Conditions Store
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Update map from conditions
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Update map from conditions: Range of input/output is {[0,l:0] - [INVALID]}
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: reading magnetic field map filenames from COOL
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: found map of type GlobalMap with soleCur=7730 toroCur=20400 (path file:MagneticFieldMaps/bfieldmap_7730_20400_14m.root)
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: found map of type SolenoidMap with soleCur=7730 toroCur=0 (path file:MagneticFieldMaps/bfieldmap_7730_0_14m.root)
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: found map of type ToroidMap with soleCur=0 toroCur=20400 (path file:MagneticFieldMaps/bfieldmap_0_20400_14m.root)
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Range of input currents is {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Attempt 1 at reading currents from DCS (using channel name)
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_Current , 1 , 7729.99
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_SCurrent , 2 , 7730
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_Current , 3 , 20399.9
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_SCurrent , 4 , 20397.7
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Currents read from DCS - solenoid 7729.99 toroid 20399.9
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: currents are OK, will use nominal maps
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: tagInfoH  ( 'TagInfo' , 'DetectorStore+ProcessingTags' )  is valid. 
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: DID NOT reset currents from TagInfo
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Set map currents from FieldSvc: solenoid/toroid 7730,20400
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Use map file MagneticFieldMaps/bfieldmap_7730_20400_14m.root
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Initialized the field map from /cvmfs/atlas.cern.ch/repo/sw/database/GroupData/MagneticFieldMaps/bfieldmap_7730_20400_14m.root
+AtlasFieldMapCondAlg                                 INFO execute: solenoid zone id  7000
+AtlasFieldMapCondAlg                                 INFO execute: recorded AtlasFieldMapCondObj with EventRange {[0,l:0] - [INVALID]}
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Range of input/output is {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Attempt 1 at reading currents from DCS (using channel name)
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_Current , 1 , 7729.99
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_SCurrent , 2 , 7730
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_Current , 3 , 20399.9
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_SCurrent , 4 , 20397.7
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Currents read from DCS - solenoid 7729.99 toroid 20399.9
+AtlasFieldCacheCondAlg                               INFO scaleField: Solenoid field scale factor 1. Desired current and map current: 7729.99,7730
+AtlasFieldCacheCondAlg                               INFO scaleField: Toroid field scale factor 1. Desired current and map current: 20399.9,20400
+AtlasFieldCacheCondAlg                               INFO execute: initialized AtlasFieldCacheCondObj and cache with SFs - sol/tor 1/1, EventRange {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
+AtlasFieldCacheCondAlg                               INFO execute: solenoid zone id  7000
+RegSelCondAlg_RPC                                    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_RPC'
+RegSelCondAlg_TGC                                    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_TGC'
+MdtCalibDbAlg                                        INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/RTBLOB' )  readCdoRt->size()= 1186
+MdtCalibDbAlg                                        INFO Range of input is {[327265,l:0] - [327342,l:0]}
+MdtCalibDbAlg                                        INFO MdtCalibDbAlg::loadRt Read 1188RTs from COOL
+MdtCalibDbAlg                                        INFO recorded new MdtRtRelationCollection with range {[327265,l:0] - [327342,l:0]} into Conditions Store
+MdtCalibDbAlg                                        INFO recorded new MdtCorFuncSetCollection with range {[327265,l:0] - [327342,l:0]} into Conditions Store
+MdtCalibDbAlg                                        INFO Ignoring nonexistant station in calibration DB: MuonSpectrometer BML -6 stationPhi 7 MDT multiLayer 1 tubeLayer 1 tube 1
+MdtCalibDbAlg                                        INFO Ignoring nonexistant station in calibration DB: MuonSpectrometer BML stationEta 6 stationPhi 7 MDT multiLayer 1 tubeLayer 1 tube 1
+MdtCalibDbAlg                                        INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/T0BLOB' )  readCdoTube->size()= 1186
+MdtCalibDbAlg                                        INFO Range of input is {[319000,l:0] - [INVALID]}
+MdtCalibDbAlg                                        INFO recorded new MdtTubeCalibContainerCollection with range {[319000,l:0] - [INVALID]} into Conditions Store
+RegSelCondAlg_MDT                                    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_MDT'
+RegSelCondAlg_CSC                                    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_CSC'
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186525031, run #327265 1 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186524665, run #327265 1 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186524665, run #327265 2 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186542447, run #327265 2 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186542447, run #327265 3 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186543405, run #327265 3 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186543405, run #327265 4 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186548387, run #327265 4 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186548387, run #327265 5 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186515186, run #327265 5 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186515186, run #327265 6 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186556019, run #327265 6 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186556019, run #327265 7 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186542866, run #327265 7 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186542866, run #327265 8 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186537901, run #327265 8 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186537901, run #327265 9 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186517811, run #327265 9 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186517811, run #327265 10 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186534221, run #327265 10 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186534221, run #327265 11 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186540986, run #327265 11 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186540986, run #327265 12 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186535104, run #327265 12 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186535104, run #327265 13 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186539903, run #327265 13 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186539903, run #327265 14 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186552713, run #327265 14 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186552713, run #327265 15 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186524730, run #327265 15 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186524730, run #327265 16 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186547632, run #327265 16 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186547632, run #327265 17 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186555621, run #327265 17 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186555621, run #327265 18 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186568452, run #327265 18 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186568452, run #327265 19 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186580451, run #327265 19 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186580451, run #327265 20 events processed so far  <<<===
+Domain[ROOT_All]                                     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
+ApplicationMgr                                       INFO Application Manager Stopped successfully
+IncidentProcAlg1                                     INFO Finalize
+CondInputLoader                                      INFO Finalizing CondInputLoader...
+IncidentProcAlg2                                     INFO Finalize
+IdDictDetDescrCnv                                    INFO in finalize
+IOVDbFolder                                          INFO Folder /CSC/FTHOLD (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/322656 ((     0.08 ))s
+IOVDbFolder                                          INFO Folder /CSC/NOISE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/350062 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /CSC/PED (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/411187 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /CSC/PSLOPE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/353376 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /CSC/RMS (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/411395 ((     0.43 ))s
+IOVDbFolder                                          INFO Folder /CSC/STAT (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/230496 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /CSC/T0BASE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/314380 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /CSC/T0PHASE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/3136 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /EXT/DCS/MAGNETS/SENSORDATA (AttrListColl) db-read 1/1 objs/chan/bytes 4/4/20 ((     0.07 ))s
+IOVDbFolder                                          INFO Folder /GLOBAL/BField/Maps (AttrListColl) db-read 1/1 objs/chan/bytes 3/3/202 ((     0.34 ))s
+IOVDbFolder                                          INFO Folder /MDT/CABLING/MAP_SCHEMA (AttrListColl) db-read 1/1 objs/chan/bytes 2312/2437/216520 ((     0.25 ))s
+IOVDbFolder                                          INFO Folder /MDT/CABLING/MEZZANINE_SCHEMA (AttrListColl) db-read 1/1 objs/chan/bytes 24/24/288 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /MDT/RTBLOB (AttrListColl) db-read 1/1 objs/chan/bytes 2372/1186/2251209 ((     0.23 ))s
+IOVDbFolder                                          INFO Folder /MDT/T0BLOB (AttrListColl) db-read 1/1 objs/chan/bytes 1186/1186/1374284 ((     0.12 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/CSC/ILINES (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/10814 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/MDT/ASBUILTPARAMS (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/128992 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/MDT/BARREL (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/140293 ((     0.18 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/MDT/ENDCAP/SIDEA (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/65494 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/MDT/ENDCAP/SIDEC (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/65497 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/TGC/SIDEA (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/165643 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/TGC/SIDEC (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/165643 ((     0.05 ))s
+IOVDbFolder                                          INFO Folder /RPC/CABLING/MAP_SCHEMA (AttrListColl) db-read 1/2 objs/chan/bytes 1/1/222235 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /RPC/CABLING/MAP_SCHEMA_CORR (AttrListColl) db-read 1/2 objs/chan/bytes 1/1/29402 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /RPC/DCS/DeadRopanels (AttrListColl) db-read 1/1 objs/chan/bytes 32/48/6200 ((     0.00 ))s
+IOVDbFolder                                          INFO Folder /RPC/DCS/OffRopanels (AttrListColl) db-read 1/1 objs/chan/bytes 4/48/16 ((     0.00 ))s
+IOVDbFolder                                          INFO Folder /RPC/DQMF/ELEMENT_STATUS (AttrListColl) db-read 1/1 objs/chan/bytes 8320/8320/6180700 ((     1.00 ))s
+IOVDbFolder                                          INFO Folder /RPC/TRIGGER/CM_THR_ETA (AttrListColl) db-read 1/2 objs/chan/bytes 1613/1613/7562651 ((     0.21 ))s
+IOVDbFolder                                          INFO Folder /RPC/TRIGGER/CM_THR_PHI (AttrListColl) db-read 1/2 objs/chan/bytes 1612/1612/8096306 ((     0.21 ))s
+IOVDbFolder                                          INFO Folder /TGC/CABLING/MAP_SCHEMA (AttrListColl) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
+IOVDbSvc                                             INFO  bytes in ((      3.56 ))s
+IOVDbSvc                                             INFO Connection sqlite://;schema=mycool.db;dbname=CONDBR2 : nConnect: 0 nFolders: 0 ReadTime: ((     0.00 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_MUONALIGN/CONDBR2 : nConnect: 2 nFolders: 7 ReadTime: ((     0.38 ))s
+IOVDbSvc                                             INFO Connection COOLONL_RPC/CONDBR2 : nConnect: 2 nFolders: 4 ReadTime: ((     0.48 ))s
+IOVDbSvc                                             INFO Connection COOLONL_TGC/CONDBR2 : nConnect: 1 nFolders: 1 ReadTime: ((     0.00 ))s
+IOVDbSvc                                             INFO Connection COOLONL_MDT/CONDBR2 : nConnect: 2 nFolders: 2 ReadTime: ((     0.28 ))s
+IOVDbSvc                                             INFO Connection COOLONL_GLOBAL/CONDBR2 : nConnect: 2 nFolders: 1 ReadTime: ((     0.34 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_DCS/CONDBR2 : nConnect: 2 nFolders: 3 ReadTime: ((     0.08 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_RPC/CONDBR2 : nConnect: 2 nFolders: 1 ReadTime: ((     1.00 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_MDT/CONDBR2 : nConnect: 2 nFolders: 2 ReadTime: ((     0.35 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_CSC/CONDBR2 : nConnect: 2 nFolders: 8 ReadTime: ((     0.66 ))s
+ToolSvc                                              INFO Removing all tools created by ToolSvc
+TgcRdoToTgcPrepData.TgcRdoToTgcPrepDataTool          INFO finalize(): input RDOs->output PRDs [Hit: 6807->6807, Tracklet: 28->28, TrackletEIFI: 692->692, HiPt: 4031->4031, SL: 3->3]
+MdtRawDataProvider.MDT_RawDataPro...MdtROD_Decoder   INFO Fraction of fills that use the cache = 0
+ToolSvc.TGCCablingDbTool                             INFO finalize
+MuonTGC_CablingSvc.TGCCablingDbTool                  INFO finalize
+TgcRawDataProvider.TGC_RawDataPro...TgcROD_Decoder   INFO Fraction of fills that use the cache = 0
+RpcROD_Decoder::printcheckformat                     INFO  ============ FINAL RPC DATA FORMAT STAT. =========== 
+RpcROD_Decoder::printcheckformat                     INFO  RX Header Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  RX SubHeader Errors..........0
+RpcROD_Decoder::printcheckformat                     INFO  PAD Header Errors............0
+RpcROD_Decoder::printcheckformat                     INFO  PAD/SL SubHeader Errors......0
+RpcROD_Decoder::printcheckformat                     INFO  CM Header Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  CM SubHeader Errors..........0
+RpcROD_Decoder::printcheckformat                     INFO  CM Footer Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  PAD PreFooter Errors.........0
+RpcROD_Decoder::printcheckformat                     INFO  PAD Footer Errors............0
+RpcROD_Decoder::printcheckformat                     INFO  SL Header Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  SL Footer Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  RX Footer Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  CRC8 check Failures..........0
+RpcROD_Decoder::printcheckformat                     INFO  ==================================================== 
+ToolSvc.ByteStreamMetadataTool                       INFO in finalize()
+*****Chrono*****                                     INFO ****************************************************************************************************
+*****Chrono*****                                     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
+*****Chrono*****                                     INFO ****************************************************************************************************
+cObj_ALL                                             INFO Time User   : Tot=    0 [us] Ave/Min/Max=       0(+-       0)/       0/       0 [us] #= 32
+ChronoStatSvc                                        INFO Time User   : Tot= 30.9  [s]  #=  1
+*****Chrono*****                                     INFO ****************************************************************************************************
+ChronoStatSvc.finalize()                             INFO  Service finalized successfully 
+ApplicationMgr                                       INFO Application Manager Finalized successfully
+ApplicationMgr                                       INFO Application Manager Terminated successfully
diff --git a/MuonSpectrometer/MuonConfig/share/MuonDataDecodeTest_Cache.ref b/MuonSpectrometer/MuonConfig/share/MuonDataDecodeTest_Cache.ref
index 9f298ca189847decc06d0c495534d99facff13fd..d7a1d812ea108811b1a8a339107ba602f8680741 100644
--- a/MuonSpectrometer/MuonConfig/share/MuonDataDecodeTest_Cache.ref
+++ b/MuonSpectrometer/MuonConfig/share/MuonDataDecodeTest_Cache.ref
@@ -4,6 +4,7 @@ Beam.Energy                              : [function]
 Beam.NumberOfCollisions                  : [function]
 Beam.Type                                : [function]
 Beam.estimatedLuminosity                 : [function]
+Common.MsgSourceLength                   : 50
 Common.Project                           : 'Athena'
 Common.bunchCrossingSource               : [function]
 Common.doExpressProcessing               : False
@@ -28,6 +29,7 @@ IOVDb.GlobalTag                          : 'CONDBR2-BLKPA-2018-13'
 Input.Collections                        : [function]
 Input.Files                              : ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1']
 Input.Format                             : [function]
+Input.LumiBlockNumber                    : [function]
 Input.ProjectName                        : [function]
 Input.RunNumber                          : [function]
 Input.SecondaryCollections               : [function]
@@ -62,6 +64,7 @@ DQ                        :                           __dq : AthenaConfiguration
 Detector                  :                     __detector : AthenaConfiguration/AllConfigFlags.py
 Digitization              :                 __digitization : AthenaConfiguration/AllConfigFlags.py
 Egamma                    :                       __egamma : AthenaConfiguration/AllConfigFlags.py
+ITk                       :                          __itk : AthenaConfiguration/AllConfigFlags.py
 InDet                     :                        __indet : AthenaConfiguration/AllConfigFlags.py
 LAr                       :                          __lar : AthenaConfiguration/AllConfigFlags.py
 MET                       :                          __met : AthenaConfiguration/AllConfigFlags.py
@@ -74,18 +77,25 @@ Sim                       :                   __simulation : AthenaConfiguration
 Tile                      :                         __tile : AthenaConfiguration/AllConfigFlags.py
 Trigger                   :                      __trigger : AthenaConfiguration/AllConfigFlags.py
 Py:Athena            INFO About to setup Raw data decoding
-Py:Athena            INFO using release [WorkDir-22.0.18] [x86_64-centos7-gcc8-opt] [removeDuplicateProp/12d6dd5] -- built on [2020-09-17T1141]
+Py:Athena            INFO using release [WorkDir-22.0.22] [x86_64-centos7-gcc8-opt] [MainServiceMsgFormat/f665cad] -- built on [2020-12-03T1657]
 Py:AutoConfigFlags    INFO Obtaining metadata of auto-configuration by peeking into /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1
 Py:MetaReader        INFO Current mode used: peeker
 Py:MetaReader        INFO Current filenames: ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1']
-Py:ConfigurableDb    INFO Read module info for 5566 configurables from 4 genConfDb files
-Py:ConfigurableDb    INFO No duplicates have been found: that's good !
-EventInfoMgtInit: Got release version  Athena-22.0.18
-Py:IOVDbSvc.CondDB    INFO Setting up conditions DB access to instance OFLP200
 Py:Athena            INFO Print Config
 Py:ComponentAccumulator    INFO Event Inputs
 Py:ComponentAccumulator    INFO Event Algorithm Sequences
-Py:ComponentAccumulator    INFO AthSequencer('AthAlgSeq', Sequential=True, Members=[MuonCacheCreator('MuonCacheCreator', MdtCsmCacheKey='MdtCsmRdoCache', CscCacheKey='CscRdoCache', RpcCacheKey='RpcRdoCache', TgcCacheKey='TgcRdoCache'), RpcRawDataProvider('RpcRawDataProvider', ProviderTool=RPC_RawDataProviderToolMT('RPC_RawDataProviderToolMT', Decoder=RpcROD_Decoder('RpcROD_Decoder'), RdoLocation='RPCPAD', RpcContainerCacheKey='RpcRdoCache', WriteOutRpcSectorLogic=False), RoIs='HLT_MURoIs'), TgcRawDataProvider('TgcRawDataProvider', ProviderTool=TGC_RawDataProviderToolMT('TGC_RawDataProviderToolMT', Decoder=TGC_RodDecoderReadout('TgcROD_Decoder'), RdoLocation='TGCRDO', TgcContainerCacheKey='TgcRdoCache')), MdtRawDataProvider('MdtRawDataProvider', ProviderTool=MDT_RawDataProviderToolMT('MDT_RawDataProviderToolMT', Decoder=MdtROD_Decoder('MdtROD_Decoder'), RdoLocation='MDTCSM', CsmContainerCacheKey='MdtCsmRdoCache')), CscRawDataProvider('CscRawDataProvider', ProviderTool=CSC_RawDataProviderToolMT('CSC_RawDataProviderToolMT', Decoder=CscROD_Decoder('CscROD_Decoder'), RdoLocation='CSCRDO', CscContainerCacheKey='CscRdoCache')), RpcRdoToRpcPrepData('RpcRdoToRpcPrepData', DecodingTool=RpcRdoToPrepDataToolMT('RpcRdoToRpcPrepDataTool'), PrintPrepData=False, RegSel_RPC=RegSelTool('RegSelTool_RPC', RegSelLUT='RegSelLUTCondData_RPC', Initialised=True)), TgcRdoToTgcPrepData('TgcRdoToTgcPrepData', DecodingTool=TgcRdoToPrepDataToolMT('TgcRdoToTgcPrepDataTool'), PrintPrepData=False, RegSel_TGC=RegSelTool('RegSelTool_TGC', RegSelLUT='RegSelLUTCondData_TGC', Initialised=True)), MdtRdoToMdtPrepData('MdtRdoToMdtPrepData', DecodingTool=MdtRdoToPrepDataToolMT('MdtRdoToMdtPrepDataTool'), PrintPrepData=False, RegSel_MDT=RegSelTool('RegSelTool_MDT', RegSelLUT='RegSelLUTCondData_MDT', Initialised=True)), CscRdoToCscPrepData('CscRdoToCscPrepData', CscRdoToCscPrepDataTool=CscRdoToCscPrepDataToolMT('CscRdoToCscPrepDataTool'), PrintPrepData=False, RegSel_CSC=RegSelTool('RegSelTool_CSC', RegSelLUT='RegSelLUTCondData_CSC', Initialised=True)), CscThresholdClusterBuilder('CscThresholdClusterBuilder', cluster_builder=CscThresholdClusterBuilderTool('CscThresholdClusterBuilderTool'))])
+Py:ComponentAccumulator    INFO Top sequence 0
+Py:ComponentAccumulator    INFO \__ AthAlgSeq (seq: SEQ AND)
+Py:ComponentAccumulator    INFO    \__ MuonCacheCreator/MuonCacheCreator (alg)
+Py:ComponentAccumulator    INFO    \__ Muon::RpcRawDataProvider/RpcRawDataProvider (alg)
+Py:ComponentAccumulator    INFO    \__ Muon::TgcRawDataProvider/TgcRawDataProvider (alg)
+Py:ComponentAccumulator    INFO    \__ Muon::MdtRawDataProvider/MdtRawDataProvider (alg)
+Py:ComponentAccumulator    INFO    \__ Muon::CscRawDataProvider/CscRawDataProvider (alg)
+Py:ComponentAccumulator    INFO    \__ RpcRdoToRpcPrepData/RpcRdoToRpcPrepData (alg)
+Py:ComponentAccumulator    INFO    \__ TgcRdoToTgcPrepData/TgcRdoToTgcPrepData (alg)
+Py:ComponentAccumulator    INFO    \__ MdtRdoToMdtPrepData/MdtRdoToMdtPrepData (alg)
+Py:ComponentAccumulator    INFO    \__ CscRdoToCscPrepData/CscRdoToCscPrepData (alg)
+Py:ComponentAccumulator    INFO    \__ CscThresholdClusterBuilder/CscThresholdClusterBuilder (alg)
 Py:ComponentAccumulator    INFO Condition Algorithms
 Py:ComponentAccumulator    INFO  \__ CondInputLoader (cond alg)
 Py:ComponentAccumulator    INFO  \__ MuonAlignmentCondAlg (cond alg)
@@ -117,7 +127,7 @@ Py:ComponentAccumulator    INFO ]
 Py:ComponentAccumulator    INFO Private Tools
 Py:ComponentAccumulator    INFO [
 Py:ComponentAccumulator    INFO ]
-Py:ComponentAccumulator    INFO TheApp properties
+Py:ComponentAccumulator    INFO theApp properties
 Py:ComponentAccumulator    INFO   EvtSel : EventSelector
 Py:Athena            INFO Save Config
 
@@ -125,357 +135,342 @@ JOs reading stage finished, launching CARunner from pickle file
 
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v34r0)
-                                          running on pcaz004 on Thu Sep 17 11:43:58 2020
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on pcaz001 on Thu Dec  3 17:41:23 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-CoreDumpSvc          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
-ClassIDSvc           INFO  getRegistryEntries: read 4008 CLIDRegistry entries for module ALL
-MetaDataSvc          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
-PoolSvc              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
-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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-09-16T2101/Athena/22.0.18/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
-DBReplicaSvc         INFO Total of 10 servers found for host pcaz004.dyndns.cern.ch [ATLF ATLAS_COOLPROD atlas_dd ATLAS_CONFIG INT8R INTR ATONR_COOL ATONR_CONF DEVDB11 ATLF ]
-DBReplicaSvc         INFO COOL SQLite replicas will be excluded if matching pattern /DBRelease/
-PoolSvc              INFO Successfully setup replica sorting algorithm
-PoolSvc              INFO Setting up APR FileCatalog and Streams
-PoolSvc              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_comcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_comcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
-ToolSvc.ByteStr...   INFO Initializing ToolSvc.ByteStreamMetadataTool - package version ByteStreamCnvSvc-00-00-00
-MetaDataSvc          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool','ByteStreamMetadataTool/ByteStreamMetadataTool'])
-OutputStreamSeq...   INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
-ByteStreamAddre...   INFO Initializing ByteStreamAddressProviderSvc - package version ByteStreamCnvSvcBase-00-00-00
-ByteStreamAddre...   INFO initialized 
-ByteStreamAddre...   INFO -- Will fill Store with id =  0
-IOVDbSvc             INFO Opened read transaction for POOL PersistencySvc
-IOVDbSvc             INFO Only 5 POOL conditions files will be open at once
-IOVDbSvc             INFO Cache alignment will be done in 3 slices
-IOVDbSvc             INFO Global tag: CONDBR2-BLKPA-2018-13 set from joboptions
-IOVDbFolder          INFO Inputfile tag override disabled for /GLOBAL/BField/Maps
-IOVDbSvc             INFO Initialised with 10 connections and 29 folders
-IOVDbSvc             INFO Service IOVDbSvc initialised successfully
-ClassIDSvc           INFO  getRegistryEntries: read 2789 CLIDRegistry entries for module ALL
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_MUONALIGN/CONDBR2
-IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
-IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
-IOVDbSvc             INFO Opening COOL connection for COOLONL_RPC/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_MUONALIGN/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_TGC/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLONL_RPC/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_MDT/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLONL_TGC/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_GLOBAL/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLONL_MDT/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_DCS/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLONL_GLOBAL/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_RPC/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_DCS/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_MDT/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_RPC/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_CSC/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_MDT/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_CSC/CONDBR2
-IOVDbSvc             INFO Added taginfo remove for /CSC/FTHOLD
-IOVDbSvc             INFO Added taginfo remove for /CSC/NOISE
-IOVDbSvc             INFO Added taginfo remove for /CSC/PED
-IOVDbSvc             INFO Added taginfo remove for /CSC/PSLOPE
-IOVDbSvc             INFO Added taginfo remove for /CSC/RMS
-IOVDbSvc             INFO Added taginfo remove for /CSC/STAT
-IOVDbSvc             INFO Added taginfo remove for /CSC/T0BASE
-IOVDbSvc             INFO Added taginfo remove for /CSC/T0PHASE
-IOVDbSvc             INFO Added taginfo remove for /EXT/DCS/MAGNETS/SENSORDATA
-IOVDbSvc             INFO Added taginfo remove for /GLOBAL/BField/Maps
-IOVDbSvc             INFO Added taginfo remove for /MDT/CABLING/MAP_SCHEMA
-IOVDbSvc             INFO Added taginfo remove for /MDT/CABLING/MEZZANINE_SCHEMA
-IOVDbSvc             INFO Added taginfo remove for /MDT/RTBLOB
-IOVDbSvc             INFO Added taginfo remove for /MDT/T0BLOB
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/CSC/ILINES
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/MDT/ASBUILTPARAMS
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/MDT/BARREL
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/MDT/ENDCAP/SIDEA
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/MDT/ENDCAP/SIDEC
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/TGC/SIDEA
-IOVDbSvc             INFO Added taginfo remove for /MUONALIGN/TGC/SIDEC
-IOVDbSvc             INFO Added taginfo remove for /RPC/CABLING/MAP_SCHEMA
-IOVDbSvc             INFO Added taginfo remove for /RPC/CABLING/MAP_SCHEMA_CORR
-IOVDbSvc             INFO Added taginfo remove for /RPC/DCS/DeadRopanels
-IOVDbSvc             INFO Added taginfo remove for /RPC/DCS/OffRopanels
-IOVDbSvc             INFO Added taginfo remove for /RPC/DQMF/ELEMENT_STATUS
-IOVDbSvc             INFO Added taginfo remove for /RPC/TRIGGER/CM_THR_ETA
-IOVDbSvc             INFO Added taginfo remove for /RPC/TRIGGER/CM_THR_PHI
-IOVDbSvc             INFO Added taginfo remove for /TGC/CABLING/MAP_SCHEMA
-GeoModelSvc          INFO Explicitly initializing DetDescrCnvSvc
-DetDescrCnvSvc       INFO  initializing 
-DetDescrCnvSvc       INFO Found DetectorStore service
-DetDescrCnvSvc       INFO  filling proxies for detector managers 
-DetDescrCnvSvc       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
-GeoModelSvc.Muo...   INFO Initializing ...
-GeoModelSvc::RD...WARNING  Getting PixTBMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting PixTBMaterials with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMaterials with default tag
-MuonGeoModel         INFO MuonDetectorFactory - constructor  MuonSystem OuterRadius 13000 Length 22030
-GeoModelSvc.Muo...   INFO create MuonDetectorTool - package version = MuonGeoModel-00-00-00
-GeoModelSvc.Muo...   INFO (from GeoModelSvc)    AtlasVersion = <ATLAS-R2-2016-01-00-01>  MuonVersion = <>
-GeoModelSvc.Muo...   INFO Keys for Muon Switches are  (key) ATLAS-R2-2016-01-00-01 (node) ATLAS
-GeoModelSvc.Muo...   INFO (from GeoModelSvc) in AtlasVersion = <ATLAS-R2-2016-01-00-01>  default MuonVersion is <MuonSpectrometer-R.08.01>
-GeoModelSvc.Muo...   INFO Properties have been set as follows: 
-GeoModelSvc.Muo...   INFO     LayoutName                     R
-GeoModelSvc.Muo...   INFO     IncludeCutouts                 0
-GeoModelSvc.Muo...   INFO     IncludeCutoutsBog              0
-GeoModelSvc.Muo...   INFO     IncludeCtbBis                  0
-GeoModelSvc.Muo...   INFO     ControlAlines                  111111
-GeoModelSvc.Muo...   INFO     MinimalGeoFlag                 0
-GeoModelSvc.Muo...   INFO     EnableCscIntAlignment          1
-GeoModelSvc.Muo...   INFO     EnableCscIntAlignmentFromGM    0
-GeoModelSvc.Muo...   INFO     ControlCscIntAlines            111111
-GeoModelSvc.Muo...   INFO     EnableMdtDeformations          1
-GeoModelSvc.Muo...   INFO     EnableMdtAsBuiltParameters     1
-MuGM:MuonFactory     INFO MuonLayout set to <R.08.01> = Development version for DC3 - infrastructures 
-MuGM:MuonFactory     INFO                    BOG cutouts are activated 1 , all other cutouts are disabled 1
-MuGM:MuonFactory     INFO Manager created for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
-MuonGeoModel.MYSQL   INFO GeometryVersion set to <R.08.01>
-MuGM:MuonFactory     INFO Mysql helper class created here for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
-EventPersistenc...   INFO Added successfully Conversion service:ByteStreamCnvSvc
-EventPersistenc...   INFO Added successfully Conversion service:DetDescrCnvSvc
-MDT_IDDetDescrCnv    INFO in createObj: creating a MdtIdHelper object in the detector store
-IdDictDetDescrCnv    INFO in initialize
-IdDictDetDescrCnv    INFO in createObj: creating a IdDictManager object in the detector store
-IdDictDetDescrCnv    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
-IdDictDetDescrCnv    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
-IdDictDetDescrCnv    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Found id dicts:
-IdDictDetDescrCnv    INFO Using dictionary tag: null
-IdDictDetDescrCnv    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
+CoreDumpSvc                                          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
+ClassIDSvc                                           INFO  getRegistryEntries: read 3909 CLIDRegistry entries for module ALL
+MetaDataSvc                                          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
+PoolSvc                                              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
+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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
+DBReplicaSvc                                         INFO Total of 10 servers found for host pcaz001.dyndns.cern.ch [ATLF ATLAS_COOLPROD atlas_dd ATLAS_CONFIG INT8R INTR ATONR_COOL ATONR_CONF DEVDB11 ATLF ]
+DBReplicaSvc                                         INFO COOL SQLite replicas will be excluded if matching pattern /DBRelease/
+PoolSvc                                              INFO Successfully setup replica sorting algorithm
+PoolSvc                                              INFO Setting up APR FileCatalog and Streams
+PoolSvc                                              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_comcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_comcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
+DbSession                                            INFO     Open     DbSession    
+Domain[ROOT_All]                                     INFO >   Access   DbDomain     READ      [ROOT_All] 
+ToolSvc.ByteStreamMetadataTool                       INFO Initializing ToolSvc.ByteStreamMetadataTool - package version ByteStreamCnvSvc-00-00-00
+MetaDataSvc                                          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool','ByteStreamMetadataTool/ByteStreamMetadataTool'])
+OutputStreamSequencerSvc                             INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.ByteStreamMetadataTool
+ByteStreamAddressProviderSvc                         INFO Initializing ByteStreamAddressProviderSvc - package version ByteStreamCnvSvcBase-00-00-00
+ByteStreamAddressProviderSvc                         INFO initialized 
+ByteStreamAddressProviderSvc                         INFO -- Will fill Store with id =  0
+TagInfoMgr                                           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
+IOVDbSvc                                             INFO Only 5 POOL conditions files will be open at once
+IOVDbSvc                                             INFO Cache alignment will be done in 3 slices
+IOVDbSvc                                             INFO Global tag: CONDBR2-BLKPA-2018-13 set from joboptions
+IOVDbFolder                                          INFO Inputfile tag override disabled for /GLOBAL/BField/Maps
+IOVDbSvc                                             INFO Initialised with 10 connections and 29 folders
+IOVDbSvc                                             INFO Service IOVDbSvc initialised successfully
+IOVDbSvc                                             INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+ClassIDSvc                                           INFO  getRegistryEntries: read 2787 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_MUONALIGN/CONDBR2
+IOVSvc                                               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool                                    INFO IOVRanges will be checked at every Event
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_RPC/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_MUONALIGN/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_TGC/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLONL_RPC/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_MDT/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLONL_TGC/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_GLOBAL/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLONL_MDT/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_DCS/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLONL_GLOBAL/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_RPC/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_DCS/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_MDT/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_RPC/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_CSC/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_MDT/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_CSC/CONDBR2
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/FTHOLD
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/NOISE
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/PED
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/PSLOPE
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/RMS
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/STAT
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/T0BASE
+IOVDbSvc                                             INFO Added taginfo remove for /CSC/T0PHASE
+IOVDbSvc                                             INFO Added taginfo remove for /EXT/DCS/MAGNETS/SENSORDATA
+IOVDbSvc                                             INFO Added taginfo remove for /GLOBAL/BField/Maps
+IOVDbSvc                                             INFO Added taginfo remove for /MDT/CABLING/MAP_SCHEMA
+IOVDbSvc                                             INFO Added taginfo remove for /MDT/CABLING/MEZZANINE_SCHEMA
+IOVDbSvc                                             INFO Added taginfo remove for /MDT/RTBLOB
+IOVDbSvc                                             INFO Added taginfo remove for /MDT/T0BLOB
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/CSC/ILINES
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/MDT/ASBUILTPARAMS
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/MDT/BARREL
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/MDT/ENDCAP/SIDEA
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/MDT/ENDCAP/SIDEC
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/TGC/SIDEA
+IOVDbSvc                                             INFO Added taginfo remove for /MUONALIGN/TGC/SIDEC
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/CABLING/MAP_SCHEMA
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/CABLING/MAP_SCHEMA_CORR
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/DCS/DeadRopanels
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/DCS/OffRopanels
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/DQMF/ELEMENT_STATUS
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/TRIGGER/CM_THR_ETA
+IOVDbSvc                                             INFO Added taginfo remove for /RPC/TRIGGER/CM_THR_PHI
+IOVDbSvc                                             INFO Added taginfo remove for /TGC/CABLING/MAP_SCHEMA
+DetDescrCnvSvc                                       INFO  initializing 
+DetDescrCnvSvc                                       INFO Found DetectorStore service
+DetDescrCnvSvc                                       INFO  filling proxies for detector managers 
+DetDescrCnvSvc                                       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
+GeoModelSvc.MuonDetectorTool                         INFO Initializing ...
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMaterials with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMaterials with default tag
+MuonGeoModel                                         INFO MuonDetectorFactory - constructor  MuonSystem OuterRadius 13000 Length 22030
+GeoModelSvc.MuonDetectorTool                         INFO create MuonDetectorTool - package version = MuonGeoModel-00-00-00
+GeoModelSvc.MuonDetectorTool                         INFO (from GeoModelSvc)    AtlasVersion = <ATLAS-R2-2016-01-00-01>  MuonVersion = <>
+GeoModelSvc.MuonDetectorTool                         INFO Keys for Muon Switches are  (key) ATLAS-R2-2016-01-00-01 (node) ATLAS
+GeoModelSvc.MuonDetectorTool                         INFO (from GeoModelSvc) in AtlasVersion = <ATLAS-R2-2016-01-00-01>  default MuonVersion is <MuonSpectrometer-R.08.01>
+GeoModelSvc.MuonDetectorTool                         INFO Properties have been set as follows: 
+GeoModelSvc.MuonDetectorTool                         INFO     LayoutName                     R
+GeoModelSvc.MuonDetectorTool                         INFO     IncludeCutouts                 0
+GeoModelSvc.MuonDetectorTool                         INFO     IncludeCutoutsBog              0
+GeoModelSvc.MuonDetectorTool                         INFO     IncludeCtbBis                  0
+GeoModelSvc.MuonDetectorTool                         INFO     ControlAlines                  111111
+GeoModelSvc.MuonDetectorTool                         INFO     MinimalGeoFlag                 0
+GeoModelSvc.MuonDetectorTool                         INFO     EnableCscIntAlignment          1
+GeoModelSvc.MuonDetectorTool                         INFO     EnableCscIntAlignmentFromGM    0
+GeoModelSvc.MuonDetectorTool                         INFO     ControlCscIntAlines            111111
+GeoModelSvc.MuonDetectorTool                         INFO     EnableMdtDeformations          1
+GeoModelSvc.MuonDetectorTool                         INFO     EnableMdtAsBuiltParameters     1
+MuGM:MuonFactory                                     INFO MuonLayout set to <R.08.01> = Development version for DC3 - infrastructures 
+MuGM:MuonFactory                                     INFO                    BOG cutouts are activated 1 , all other cutouts are disabled 1
+MuGM:MuonFactory                                     INFO Manager created for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
+MuonGeoModel.MYSQL                                   INFO GeometryVersion set to <R.08.01>
+MuGM:MuonFactory                                     INFO Mysql helper class created here for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
+EventPersistencySvc                                  INFO Added successfully Conversion service:ByteStreamCnvSvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:DetDescrCnvSvc
+MDT_IDDetDescrCnv                                    INFO in createObj: creating a MdtIdHelper object in the detector store
+IdDictDetDescrCnv                                    INFO in initialize
+IdDictDetDescrCnv                                    INFO in createObj: creating a IdDictManager object in the detector store
+IdDictDetDescrCnv                                    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
+IdDictDetDescrCnv                                    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
+IdDictDetDescrCnv                                    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Found id dicts:
+IdDictDetDescrCnv                                    INFO Using dictionary tag: null
+IdDictDetDescrCnv                                    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find mm region index: group, region size 0 0
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find stgc region index: group, region size 0 0
 AtlasDetectorID::initLevelsFromDict - there are no sTGC entries in the dictionary! 
 AtlasDetectorID::initLevelsFromDict - there are no MM entries in the dictionary! 
  AtlasDetectorID::initialize_from_dictionary - OK 
-MdtIdHelper          INFO MultiRange built successfully to Technology: MultiRange size is 210
-MdtIdHelper          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 241
-MdtIdHelper          INFO MultiRange built successfully to tube: MultiRange size is 241
-MdtIdHelper          INFO Initializing MDT hash indices ... 
-MdtIdHelper          INFO The element hash max is 1188
-MdtIdHelper          INFO The detector element hash max is 2328
-MdtIdHelper          INFO Initializing MDT hash indices for finding neighbors ... 
-MuGM:MuonFactory     INFO MDTIDHELPER retrieved from DetStore
-RPC_IDDetDescrCnv    INFO in createObj: creating a RpcIdHelper object in the detector store
+MdtIdHelper                                          INFO MultiRange built successfully to Technology: MultiRange size is 210
+MdtIdHelper                                          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 241
+MdtIdHelper                                          INFO MultiRange built successfully to tube: MultiRange size is 241
+MdtIdHelper                                          INFO Initializing MDT hash indices ... 
+MdtIdHelper                                          INFO The element hash max is 1188
+MdtIdHelper                                          INFO The detector element hash max is 2328
+MdtIdHelper                                          INFO Initializing MDT hash indices for finding neighbors ... 
+MuGM:MuonFactory                                     INFO MDTIDHELPER retrieved from DetStore
+RPC_IDDetDescrCnv                                    INFO in createObj: creating a RpcIdHelper object in the detector store
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find mm region index: group, region size 0 0
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find stgc region index: group, region size 0 0
 AtlasDetectorID::initLevelsFromDict - there are no sTGC entries in the dictionary! 
 AtlasDetectorID::initLevelsFromDict - there are no MM entries in the dictionary! 
  AtlasDetectorID::initialize_from_dictionary - OK 
-RpcIdHelper          INFO MultiRange built successfully to doubletR: MultiRange size is 241
-RpcIdHelper          INFO MultiRange built successfully to detectorElement: DetectorElement MultiRange size is 241
-RpcIdHelper          INFO MultiRange built successfully to rpcStrip: MultiRange size is 241
-RpcIdHelper          INFO Initializing RPC hash indices ... 
-RpcIdHelper          INFO The element hash max is 600
-RpcIdHelper          INFO The detector element hash max is 1122
-RpcIdHelper          INFO Initializing RPC hash indices for finding neighbors ... 
-MuGM:MuonFactory     INFO RPCIDHELPER retrieved from DetStore
-TGC_IDDetDescrCnv    INFO in createObj: creating a TgcIdHelper object in the detector store
+RpcIdHelper                                          INFO MultiRange built successfully to doubletR: MultiRange size is 241
+RpcIdHelper                                          INFO MultiRange built successfully to detectorElement: DetectorElement MultiRange size is 241
+RpcIdHelper                                          INFO MultiRange built successfully to rpcStrip: MultiRange size is 241
+RpcIdHelper                                          INFO Initializing RPC hash indices ... 
+RpcIdHelper                                          INFO The element hash max is 600
+RpcIdHelper                                          INFO The detector element hash max is 1122
+RpcIdHelper                                          INFO Initializing RPC hash indices for finding neighbors ... 
+MuGM:MuonFactory                                     INFO RPCIDHELPER retrieved from DetStore
+TGC_IDDetDescrCnv                                    INFO in createObj: creating a TgcIdHelper object in the detector store
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find mm region index: group, region size 0 0
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find stgc region index: group, region size 0 0
 AtlasDetectorID::initLevelsFromDict - there are no sTGC entries in the dictionary! 
 AtlasDetectorID::initLevelsFromDict - there are no MM entries in the dictionary! 
  AtlasDetectorID::initialize_from_dictionary - OK 
-TgcIdHelper          INFO MultiRange built successfully to Technology: MultiRange size is 210
-TgcIdHelper          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 210
-TgcIdHelper          INFO MultiRange built successfully to channel: MultiRange size is 241
-TgcIdHelper          INFO Initializing TGC hash indices ... 
-TgcIdHelper          INFO The element hash max is 1578
-TgcIdHelper          INFO The detector element hash max is 1578
-TgcIdHelper          INFO Initializing TGC hash indices for finding neighbors ... 
-MuGM:MuonFactory     INFO TGCIDHELPER retrieved from DetStore
-CSC_IDDetDescrCnv    INFO in createObj: creating a CcscIdHelper object in the detector store
+TgcIdHelper                                          INFO MultiRange built successfully to Technology: MultiRange size is 210
+TgcIdHelper                                          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 210
+TgcIdHelper                                          INFO MultiRange built successfully to channel: MultiRange size is 241
+TgcIdHelper                                          INFO Initializing TGC hash indices ... 
+TgcIdHelper                                          INFO The element hash max is 1578
+TgcIdHelper                                          INFO The detector element hash max is 1578
+TgcIdHelper                                          INFO Initializing TGC hash indices for finding neighbors ... 
+MuGM:MuonFactory                                     INFO TGCIDHELPER retrieved from DetStore
+CSC_IDDetDescrCnv                                    INFO in createObj: creating a CcscIdHelper object in the detector store
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find mm region index: group, region size 0 0
 AtlasDetectorIDHelper::initialize_from_dictionary - Warning: unable to find stgc region index: group, region size 0 0
 AtlasDetectorID::initLevelsFromDict - there are no sTGC entries in the dictionary! 
 AtlasDetectorID::initLevelsFromDict - there are no MM entries in the dictionary! 
  AtlasDetectorID::initialize_from_dictionary - OK 
-CscIdHelper          INFO MultiRange built successfully to Technology: MultiRange size is 210
-CscIdHelper          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 237
-CscIdHelper          INFO MultiRange built successfully to cscStrip: MultiRange size is 241
-CscIdHelper          INFO Initializing CSC hash indices ... 
-CscIdHelper          INFO The element hash max is 32
-CscIdHelper          INFO The detector element hash max is 64
-CscIdHelper          INFO The channel hash max is 61440
-CscIdHelper          INFO Initializing CSC hash indices for finding neighbors ... 
-MuGM:MuonFactory     INFO CSCIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO  **************** MuonDetectorFactory001 ************************
-MuGM:MuonFactory     INFO  *** Start building the Muon Geometry Tree **********************
-MuGM:RDBReadAtlas    INFO Start retriving dbObjects with tag = <ATLAS-R2-2016-01-00-01> node <ATLAS>
-RDBAccessSvc      WARNING Could not get the tag for XtomoData node. Returning 0 pointer to IRDBQuery
-MuGM:RDBReadAtlas    INFO After getQuery XtomoData
+CscIdHelper                                          INFO MultiRange built successfully to Technology: MultiRange size is 210
+CscIdHelper                                          INFO MultiRange built successfully to detector element: Multilayer MultiRange size is 237
+CscIdHelper                                          INFO MultiRange built successfully to cscStrip: MultiRange size is 241
+CscIdHelper                                          INFO Initializing CSC hash indices ... 
+CscIdHelper                                          INFO The element hash max is 32
+CscIdHelper                                          INFO The detector element hash max is 64
+CscIdHelper                                          INFO The channel hash max is 61440
+CscIdHelper                                          INFO Initializing CSC hash indices for finding neighbors ... 
+MuGM:MuonFactory                                     INFO CSCIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO  **************** MuonDetectorFactory001 ************************
+MuGM:MuonFactory                                     INFO  *** Start building the Muon Geometry Tree **********************
+MuGM:RDBReadAtlas                                    INFO Start retriving dbObjects with tag = <ATLAS-R2-2016-01-00-01> node <ATLAS>
+RDBAccessSvc                                      WARNING Could not get the tag for XtomoData node. Returning 0 pointer to IRDBQuery
+MuGM:RDBReadAtlas                                    INFO After getQuery XtomoData
 In DblQ00Xtomo(data)
 No XtomoData table in the MuonDD Database
-MuGM:RDBReadAtlas    INFO After new DblQ00Xtomo
-MuGM:RDBReadAtlas    INFO No Ascii aszt input found: looking for A-lines in ORACLE
-MuGM:RDBReadAtlas    INFO ASZT table found in Oracle
-MuGM:RDBReadAtlas    INFO ASZT size is 32
-MuGM:RDBReadAtlas    INFO No Ascii iacsc input found: looking for A-lines in ORACLE
-RDBAccessSvc      WARNING Could not get the tag for ISZT node. Returning 0 pointer to IRDBQuery
-MuGM:RDBReadAtlas    INFO No ISZT table in Oracle
-MuGM:RDBReadAtlas    INFO Access granted for all dbObjects needed by muon detectors
-MuonGeoModel.MYSQL   INFO LayoutName (from DBAM) set to <R.08>  -- relevant for CTB2004
-MuGM:ProcStations    INFO  Processing Stations and Components
-MuGM:ProcStations    INFO  Processing Stations and Components DONE
-MuGM:ProcTechnol.s   INFO nMDT 13 nCSC 2 nTGC 22 nRPC 25
-MuGM:ProcTechnol.s   INFO nDED 2 nSUP 4 nSPA 2
-MuGM:ProcTechnol.s   INFO nCHV 7 nCRO 7 nCMI 6 nLBI 6
-MuGM:ProcPosition    INFO  *** N. of stations positioned in the setup 234
-MuGM:ProcPosition    INFO  *** N. of stations described in mysql      234
-MuGM:ProcPosition    INFO  *** N. of types  32 size of jtypvec 32
-MuGM:ProcPosition    INFO  *** : 234 kinds of stations (type*sub_type) 
-MuGM:ProcPosition    INFO  *** : 1758 physical stations in space - according to the MuonDD DataBase
-MuGM:ProcCutouts     INFO  Processing Cutouts for geometry layout R.08
-MuGM:ProcCutouts     INFO  Processing Cutouts DONE
-MuGM:RDBReadAtlas    INFO  ProcessTGCreadout - version 7 wirespacing 1.8
-MuGM:RDBReadAtlas    INFO Intermediate Objects built from primary numbers
-MuGM:MuonFactory     INFO  theMaterialManager retrieven successfully from the DetStore
-MuGM:MuonFactory     INFO MuonSystem description from OracleTag=<ATLAS-R2-2016-01-00-01> and node=<ATLAS>
-MuGM:MuonFactory     INFO  TreeTop added to the Manager
-MuGM:MuonFactory     INFO  Muon Layout R.08.01
-MuGM:MuonFactory     INFO Fine Clash Fixing disabled: (should be ON/OFF for Simulation/Reconstruction)
-MuGM:MuonFactory     INFO  **************** MuonDetectorFactory001 ****************************
-MuGM:MuonFactory     INFO  *** The Muon Chamber Geometry Tree is built with 
-MuGM:MuonFactory     INFO  *** 1758 child volumes 
-MuGM:MuonFactory     INFO  *** 1839 independent elements and 
-MuGM:MuonFactory     INFO  *** 11473 elements cloned or shared 
-MuGM:MuonFactory     INFO  *** 234 kinds of stations
-MuGM:MuonFactory     INFO  *** 1758 stations with alignable transforms
-MuGM:MuonFactory     INFO  *** 148 stations are described as Assemblies
-MuGM:MuonFactory     INFO  *** 1758 MuonStations 
-MuGM:MuonFactory     INFO  *** 	 2324 MDT Readout Elements 	 1186 MDT Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 32 CSC Readout Elements 	 32 CSC Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 1122 RPC Readout Elements 	 600 RPC Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 1578 TGC Readout Elements 	 1578 TGC Detector Elements 
-MuGM:MuonFactory     INFO  ********************************************************************
-MuGM:MuonFactory     INFO  *** Inert Material built according to DB switches and config. ****** 
-MuGM:MuonFactory     INFO  *** The Muon Geometry Tree has 1758 child vol.s in total ********
-MuGM:MuonFactory     INFO  ********************************************************************
+MuGM:RDBReadAtlas                                    INFO After new DblQ00Xtomo
+MuGM:RDBReadAtlas                                    INFO No Ascii aszt input found: looking for A-lines in ORACLE
+MuGM:RDBReadAtlas                                    INFO ASZT table found in Oracle
+MuGM:RDBReadAtlas                                    INFO ASZT size is 32
+MuGM:RDBReadAtlas                                    INFO No Ascii iacsc input found: looking for A-lines in ORACLE
+RDBAccessSvc                                      WARNING Could not get the tag for ISZT node. Returning 0 pointer to IRDBQuery
+MuGM:RDBReadAtlas                                    INFO No ISZT table in Oracle
+MuGM:RDBReadAtlas                                    INFO Access granted for all dbObjects needed by muon detectors
+MuonGeoModel.MYSQL                                   INFO LayoutName (from DBAM) set to <R.08>  -- relevant for CTB2004
+MuGM:ProcStations                                    INFO  Processing Stations and Components
+MuGM:ProcStations                                    INFO  Processing Stations and Components DONE
+MuGM:ProcTechnol.s                                   INFO nMDT 13 nCSC 2 nTGC 22 nRPC 25
+MuGM:ProcTechnol.s                                   INFO nDED 2 nSUP 4 nSPA 2
+MuGM:ProcTechnol.s                                   INFO nCHV 7 nCRO 7 nCMI 6 nLBI 6
+MuGM:ProcPosition                                    INFO  *** N. of stations positioned in the setup 234
+MuGM:ProcPosition                                    INFO  *** N. of stations described in mysql      234
+MuGM:ProcPosition                                    INFO  *** N. of types  32 size of jtypvec 32
+MuGM:ProcPosition                                    INFO  *** : 234 kinds of stations (type*sub_type) 
+MuGM:ProcPosition                                    INFO  *** : 1758 physical stations in space - according to the MuonDD DataBase
+MuGM:ProcCutouts                                     INFO  Processing Cutouts for geometry layout R.08
+MuGM:ProcCutouts                                     INFO  Processing Cutouts DONE
+MuGM:RDBReadAtlas                                    INFO  ProcessTGCreadout - version 7 wirespacing 1.8
+MuGM:RDBReadAtlas                                    INFO Intermediate Objects built from primary numbers
+MuGM:MuonFactory                                     INFO  theMaterialManager retrieven successfully from the DetStore
+MuGM:MuonFactory                                     INFO MuonSystem description from OracleTag=<ATLAS-R2-2016-01-00-01> and node=<ATLAS>
+MuGM:MuonFactory                                     INFO  TreeTop added to the Manager
+MuGM:MuonFactory                                     INFO  Muon Layout R.08.01
+MuGM:MuonFactory                                     INFO Fine Clash Fixing disabled: (should be ON/OFF for Simulation/Reconstruction)
+MuGM:MuonFactory                                     INFO  **************** MuonDetectorFactory001 ****************************
+MuGM:MuonFactory                                     INFO  *** The Muon Chamber Geometry Tree is built with 
+MuGM:MuonFactory                                     INFO  *** 1758 child volumes 
+MuGM:MuonFactory                                     INFO  *** 1839 independent elements and 
+MuGM:MuonFactory                                     INFO  *** 11473 elements cloned or shared 
+MuGM:MuonFactory                                     INFO  *** 234 kinds of stations
+MuGM:MuonFactory                                     INFO  *** 1758 stations with alignable transforms
+MuGM:MuonFactory                                     INFO  *** 148 stations are described as Assemblies
+MuGM:MuonFactory                                     INFO  *** 1758 MuonStations 
+MuGM:MuonFactory                                     INFO  *** 	 2324 MDT Readout Elements 	 1186 MDT Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 32 CSC Readout Elements 	 32 CSC Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 1122 RPC Readout Elements 	 600 RPC Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 1578 TGC Readout Elements 	 1578 TGC Detector Elements 
+MuGM:MuonFactory                                     INFO  ********************************************************************
+MuGM:MuonFactory                                     INFO  *** Inert Material built according to DB switches and config. ****** 
+MuGM:MuonFactory                                     INFO  *** The Muon Geometry Tree has 1758 child vol.s in total ********
+MuGM:MuonFactory                                     INFO  ********************************************************************
 
-MGM::MuonDetect...   INFO Init A/B Line Containers - done - size is respectively 1758/0
-MGM::MuonDetect...   INFO Init of CSC I-Lines will be done via Conditions DB
-MGM::MuonDetect...   INFO Init I-Line Container - done - size is respectively 128
-MGM::MuonDetect...   INFO I-Line for CSC wire layers loaded (Csc Internal Alignment)
-MGM::MuonDetect...   INFO According to configuration they WILL be used 
-MGM::MuonDetect...   INFO Filling cache
-GeoModelSvc          INFO GeoModelSvc.MuonDetectorTool	 SZ= 228460Kb 	 Time = 0.92S
-ClassIDSvc           INFO  getRegistryEntries: read 4462 CLIDRegistry entries for module ALL
-AGDDtoGeoSvc         INFO  this is AGDDtoGeoSvc::initialize()
-AGDDtoGeoSvc.Mu...   INFO  initializing AGDD builder
-AGDDtoGeoSvc.Mu...   INFO  XML file 
-AGDDtoGeoSvc.Mu...   INFO  ---------
-AGDDtoGeoSvc.Mu...   INFO  Sections 
-AGDDtoGeoSvc.Mu...   INFO  ---------
-AGDDtoGeoSvc.Mu...   INFO  Volumes 
-AGDDtoGeoSvc.Mu...   INFO  ---------
-AGDDtoGeoSvc.Mu...   INFO MuonAGDDTool::initialize
-AGDDtoGeoSvc.Mu...   INFO AGDDtoGeoSvc.MuonSpectrometer::construct()
-AGDDtoGeoSvc.Mu...   INFO  Reading AGDD2GeoSwitches flags 
-AGDDtoGeoSvc.Mu...   INFO  ----> ECT_Toroids
-AGDDtoGeoSvc.Mu...   INFO  ----> BAR_Toroid
-AGDDtoGeoSvc.Mu...   INFO  ----> Feet
-AGDDtoGeoSvc.Mu...   INFO  ----> RailAssembly
-AGDDtoGeoSvc.Mu...   INFO  ----> JFSH_Shield
-AGDDtoGeoSvc.Mu...   INFO  ----> JDSH_Shield
-AGDDtoGeoSvc.Mu...   INFO  ----> JTSH_Shield
-AGDDtoGeoSvc.Mu...   INFO  ----> pp2
-AGDDtoGeoSvc.Mu...   INFO  ----> MBAP_AccessPlatform
-AGDDtoGeoSvc.Mu...   INFO  ----> MBWH_BigWheels
-AGDDtoGeoSvc.Mu...   INFO  ----> SADL_CalorimeterSaddle
-AGDDtoGeoSvc.Mu...   INFO  ----> TBWH_BigWheels
-AGDDtoGeoSvc.Mu...   INFO  ----> TGC3_BigWheels
-AGDDtoGeoSvc.Mu...   INFO  ----> TGC1_BigWheels
-AGDDtoGeoSvc.Mu...   INFO  ----> MDTRail
-AGDDtoGeoSvc.Mu...   INFO  ----> servicesAtZ0
-AGDDtoGeoSvc.Mu...   INFO  ----> HFTruckRail
-AGDDtoGeoSvc.Mu...   INFO  ----> RUN2_Services
-AGDDtoGeoSvc.Mu...   INFO  now reading AGDD blob 
-AGDDtoGeoSvc.Mu...   INFO  now dumping the flags 
-AGDDtoGeoSvc.Mu...   INFO 		----- ECT_Toroids ECT_Toroids
-AGDDtoGeoSvc.Mu...   INFO 		----- BAR_Toroid BAR_Toroid
-AGDDtoGeoSvc.Mu...   INFO 		----- Feet Feet
-AGDDtoGeoSvc.Mu...   INFO 		----- RailAssembly RailAssembly
-AGDDtoGeoSvc.Mu...   INFO 		----- JFSH_Shield JFSH_Shield
-AGDDtoGeoSvc.Mu...   INFO 		----- JDSH_Shield JDSH_Shield
-AGDDtoGeoSvc.Mu...   INFO 		----- JTSH_Shield JTSH_Shield
-AGDDtoGeoSvc.Mu...   INFO 		----- pp2 pp2
-AGDDtoGeoSvc.Mu...   INFO 		----- MBAP_AccessPlatform MBAP_AccessPlatform
-AGDDtoGeoSvc.Mu...   INFO 		----- MBWH_BigWheels MBWH_BigWheels
-AGDDtoGeoSvc.Mu...   INFO 		----- SADL_CalorimeterSaddle SADL_CalorimeterSaddle
-AGDDtoGeoSvc.Mu...   INFO 		----- TBWH_BigWheels TBWH_BigWheels
-AGDDtoGeoSvc.Mu...   INFO 		----- TGC3_BigWheels TGC3_BigWheels
-AGDDtoGeoSvc.Mu...   INFO 		----- TGC1_BigWheels TGC1_BigWheels
-AGDDtoGeoSvc.Mu...   INFO 		----- MDTRail MDTRail
-AGDDtoGeoSvc.Mu...   INFO 		----- servicesAtZ0 servicesAtZ0
-AGDDtoGeoSvc.Mu...   INFO 		----- HFTruckRail HFTruckRail
-AGDDtoGeoSvc.Mu...   INFO 		----- RUN2_Services RUN2_Services
-AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 1315 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 251 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 310 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 242 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 1064 CLIDRegistry entries for module ALL
-CondInputLoader      INFO Initializing CondInputLoader...
-CondInputLoader      INFO Adding base classes:
+MGM::MuonDetectorManager                             INFO Init A/B Line Containers - done - size is respectively 1758/0
+MGM::MuonDetectorManager                             INFO Init of CSC I-Lines will be done via Conditions DB
+MGM::MuonDetectorManager                             INFO Init I-Line Container - done - size is respectively 128
+MGM::MuonDetectorManager                             INFO I-Line for CSC wire layers loaded (Csc Internal Alignment)
+MGM::MuonDetectorManager                             INFO According to configuration they WILL be used 
+MGM::MuonDetectorManager                             INFO Filling cache
+GeoModelSvc                                          INFO GeoModelSvc.MuonDetectorTool	 SZ= 245548Kb 	 Time = 2.49S
+ClassIDSvc                                           INFO  getRegistryEntries: read 4462 CLIDRegistry entries for module ALL
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.MuonDetectorTool
+AGDDtoGeoSvc                                         INFO  this is AGDDtoGeoSvc::initialize()
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  initializing AGDD builder
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  XML file 
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ---------
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  Sections 
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ---------
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  Volumes 
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ---------
+AGDDtoGeoSvc.MuonSpectrometer                        INFO MuonAGDDTool::initialize
+AGDDtoGeoSvc.MuonSpectrometer                        INFO AGDDtoGeoSvc.MuonSpectrometer::construct()
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  Reading AGDD2GeoSwitches flags 
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> ECT_Toroids
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> BAR_Toroid
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> Feet
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> RailAssembly
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> JFSH_Shield
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> JDSH_Shield
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> JTSH_Shield
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> pp2
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> MBAP_AccessPlatform
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> MBWH_BigWheels
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> SADL_CalorimeterSaddle
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> TBWH_BigWheels
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> TGC3_BigWheels
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> TGC1_BigWheels
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> MDTRail
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> servicesAtZ0
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> HFTruckRail
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  ----> RUN2_Services
+AGDDtoGeoSvc.MuonSpectrometer                        INFO  now reading AGDD blob 
+AGDDtoGeoSvc                                         INFO   AlgTool: AGDDtoGeoSvc.MuonSpectrometer
+AthenaEventLoopMgr                                   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 1315 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 251 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 310 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 242 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 1064 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO Initializing CondInputLoader...
+CondInputLoader                                      INFO Adding base classes:
   +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/FTHOLD' )   ->
   +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/NOISE' )   ->
   +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/PED' )   ->
@@ -504,7 +499,7 @@ CondInputLoader      INFO Adding base classes:
   +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/DQMF/ELEMENT_STATUS' )   ->
   +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/TRIGGER/CM_THR_ETA' )   ->
   +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/TRIGGER/CM_THR_PHI' )   ->
-CondInputLoader      INFO Will create WriteCondHandle dependencies for the following DataObjects:
+CondInputLoader                                      INFO Will create WriteCondHandle dependencies for the following DataObjects:
     +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/FTHOLD' ) 
     +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/NOISE' ) 
     +  ( 'CondAttrListCollection' , 'ConditionStore+/CSC/PED' ) 
@@ -533,203 +528,207 @@ CondInputLoader      INFO Will create WriteCondHandle dependencies for the follo
     +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/DQMF/ELEMENT_STATUS' ) 
     +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/TRIGGER/CM_THR_ETA' ) 
     +  ( 'CondAttrListCollection' , 'ConditionStore+/RPC/TRIGGER/CM_THR_PHI' ) 
-MuonAlignmentCo...   INFO Initilalizing
-MuonAlignmentCo...   INFO In initialize ---- # of folders registered is 7
-MuonAlignmentCo...   INFO geometry version from the MuonDetectorManager = R.08.01
-MuonDetectorCon...   INFO Initializing ...
-AtlasFieldMapCo...   INFO Initialize: Key  ( 'AtlasFieldMapCondObj' , 'ConditionStore+fieldMapCondObj' )  has been succesfully registered 
-AtlasFieldMapCo...   INFO Initialize: Will update the field map from conditions
-AtlasFieldCache...   INFO Initialize: Key  ( 'AtlasFieldCacheCondObj' , 'ConditionStore+fieldCondObj' )  has been succesfully registered 
-AtlasFieldCache...   INFO Initialize: Will update current from conditions
-AtlasFieldCache...   INFO Initialize: useDCS, useSoleCurrent, useToroCurrent. 1,  'UseSoleCurrent':7730.0000,  'UseToroCurrent':20400.000 LockMapCurrents 0
-RegSelCondAlg_RPC    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_RPC'
-RegSelCondAlg_TGC    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_TGC'
-RegSelCondAlg_MDT    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_MDT'
-RegSelCondAlg_CSC    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_CSC'
-ClassIDSvc           INFO  getRegistryEntries: read 8930 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 683 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 1588 CLIDRegistry entries for module ALL
-RpcRawDataProvider   INFO RpcRawDataProvider::initialize
-RpcRawDataProvider   INFO  'DoSeededDecoding':False
-ClassIDSvc           INFO  getRegistryEntries: read 990 CLIDRegistry entries for module ALL
-ROBDataProviderSvc   INFO Initializing ROBDataProviderSvc - package version ByteStreamCnvSvcBase-00-00-00
-ROBDataProviderSvc   INFO  ---> Filter out empty ROB fragments                               =  'filterEmptyROB':False
-ROBDataProviderSvc   INFO  ---> Filter out specific ROBs by Status Code: # ROBs = 0
-ROBDataProviderSvc   INFO  ---> Filter out Sub Detector ROBs by Status Code: # Sub Detectors = 0
-RpcRawDataProvi...   INFO initialize() successful in RpcRawDataProvider.RPC_RawDataProviderToolMT
-TgcRawDataProvider   INFO TgcRawDataProvider::initialize
-TgcRawDataProvider   INFO  'DoSeededDecoding':False
-ClassIDSvc           INFO  getRegistryEntries: read 1240 CLIDRegistry entries for module ALL
-TgcRawDataProvi...   INFO initialize() successful in TgcRawDataProvider.TGC_RawDataProviderToolMT.TgcROD_Decoder
-MuonTGC_CablingSvc   INFO for 1/12 sector initialize
-MuonTGC_Cabling...   INFO initialize
-ToolSvc.TGCCabl...   INFO initialize
-ToolSvc.TGCCabl...   INFO readTGCMap from text
-ToolSvc.TGCCabl...   INFO readTGCMap found file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-09-16T2101/Athena/22.0.18/InstallArea/x86_64-centos7-gcc8-opt/share/ASD2PP_diff_12_ONL.db
-ToolSvc.TGCCabl...   INFO giveASD2PP_DIFF_12 (m_ASD2PP_DIFF_12 is not NULL)
-TgcRawDataProvi...   INFO initialize() successful in TgcRawDataProvider.TGC_RawDataProviderToolMT
-MdtRawDataProvider   INFO MdtRawDataProvider::initialize
-MdtRawDataProvider   INFO  'DoSeededDecoding':False
-ClassIDSvc           INFO  getRegistryEntries: read 1427 CLIDRegistry entries for module ALL
-MdtRawDataProvi...   INFO Retrieved service ROBDataProviderSvc = ServiceHandle('ROBDataProviderSvc')
-MdtRawDataProvi...   INFO Processing configuration for layouts with BME chambers.
-MdtRawDataProvi...   INFO Processing configuration for layouts with BMG chambers.
-MdtRawDataProvi...   INFO Retrieved tool Decoder = PrivateToolHandle('MdtROD_Decoder/MdtROD_Decoder')
-MdtRawDataProvi...   INFO initialize() successful in MdtRawDataProvider.MDT_RawDataProviderToolMT
-ClassIDSvc           INFO  getRegistryEntries: read 1008 CLIDRegistry entries for module ALL
-CscRawDataProvi...   INFO Retrieved service ServiceHandle('ROBDataProviderSvc')
-CscRawDataProvi...   INFO Retrieved tool Decoder = PrivateToolHandle('Muon::CscROD_Decoder/CscROD_Decoder')
-CscRawDataProvi...   INFO initialize() successful in CscRawDataProvider.CSC_RawDataProviderToolMT
-ClassIDSvc           INFO  getRegistryEntries: read 54 CLIDRegistry entries for module ALL
-RpcRdoToRpcPrep...   INFO package version = MuonRPC_CnvTools-00-00-00
-RpcRdoToRpcPrep...   INFO properties are 
-RpcRdoToRpcPrep...   INFO produceRpcCoinDatafromTriggerWords 1
-RpcRdoToRpcPrep...   INFO reduceCablingOverlap               1
-RpcRdoToRpcPrep...   INFO solvePhiAmbiguities                1
-RpcRdoToRpcPrep...   INFO timeShift                          -12.5
-RpcRdoToRpcPrep...   INFO etaphi_coincidenceTime             20
-RpcRdoToRpcPrep...   INFO overlap_timeTolerance              10
-RpcRdoToRpcPrep...   INFO Correct prd time from cool db      0
-MuonRPC_CablingSvc   INFO Initializing MuonRPC_CablingSvc - package version MuonRPC_Cabling-00-00-00
-ToolSvc.RPCCabl...   INFO Initializing - folders names are: conf /RPC/CABLING/MAP_SCHEMA / corr /RPC/CABLING/MAP_SCHEMA_CORR
-MuonRPC_CablingSvc   INFO RPCCablingDbTool retrieved with handle TheRpcCablingDbTool = PublicToolHandle('RPCCablingDbTool/RPCCablingDbTool')
-MuonRPC_CablingSvc   INFO Register call-back  against 2 folders listed below 
-MuonRPC_CablingSvc   INFO  Folder n. 1 </RPC/CABLING/MAP_SCHEMA>     found in the DetStore
-ClassIDSvc           INFO  getRegistryEntries: read 242 CLIDRegistry entries for module ALL
-MuonRPC_CablingSvc   INFO initMappingModel registered for call-back against folder </RPC/CABLING/MAP_SCHEMA>
-MuonRPC_CablingSvc   INFO  Folder n. 2 </RPC/CABLING/MAP_SCHEMA_CORR>     found in the DetStore
-MuonRPC_CablingSvc   INFO initMappingModel registered for call-back against folder </RPC/CABLING/MAP_SCHEMA_CORR>
-MuonRPC_CablingSvc   INFO RPCTriggerDbTool retrieved with statusCode = SUCCESS pointer = TheRpcTriggerDbTool = PublicToolHandle('RPCTriggerDbTool')
-MuonRPC_CablingSvc   INFO Register call-back  against 2 folders listed below 
-MuonRPC_CablingSvc   INFO  Folder n. 1 </RPC/TRIGGER/CM_THR_ETA>     found in the DetStore
-MuonRPC_CablingSvc   INFO initTrigRoadsModel registered for call-back against folder </RPC/TRIGGER/CM_THR_ETA>
-MuonRPC_CablingSvc   INFO  Folder n. 2 </RPC/TRIGGER/CM_THR_PHI>     found in the DetStore
-MuonRPC_CablingSvc   INFO initTrigRoadsModel registered for call-back against folder </RPC/TRIGGER/CM_THR_PHI>
-RpcRdoToRpcPrep...   INFO Retrieved DecodingTool = PrivateToolHandle('Muon::RpcRdoToPrepDataToolMT/RpcRdoToRpcPrepDataTool')
-ClassIDSvc           INFO  getRegistryEntries: read 169 CLIDRegistry entries for module ALL
-TgcRdoToTgcPrep...   INFO initialize() successful in TgcRdoToTgcPrepData.TgcRdoToTgcPrepDataTool
-TgcRdoToTgcPrep...   INFO Retrieved DecodingTool = PrivateToolHandle('Muon::TgcRdoToPrepDataToolMT/TgcRdoToTgcPrepDataTool')
-MdtRdoToMdtPrep...   INFO Processing configuration for layouts with BMG chambers.
-MdtRdoToMdtPrep...   INFO Processing configuration for layouts with BME chambers.
-MdtRdoToMdtPrep...   INFO Processing configuration for layouts with BMG chambers.
-MdtRdoToMdtPrep...   INFO Retrieved DecodingTool = PrivateToolHandle('Muon::MdtRdoToPrepDataToolMT/MdtRdoToMdtPrepDataTool')
-ClassIDSvc           INFO  getRegistryEntries: read 116 CLIDRegistry entries for module ALL
-CscRdoToCscPrep...   INFO Retrieved CscRdoToCscPrepDataTool = PrivateToolHandle('Muon::CscRdoToCscPrepDataToolMT/CscRdoToCscPrepDataTool')
-ByteStreamInputSvc   INFO Initializing ByteStreamInputSvc - package version ByteStreamCnvSvc-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 452 CLIDRegistry entries for module ALL
-EventSelector        INFO reinitialization...
-AthenaEventLoopMgr   INFO Setup EventSelector service EventSelector
-ApplicationMgr       INFO Application Manager Initialized successfully
-ApplicationMgr    SUCCESS ****************************** Algorithm Sequence ****************************
-ApplicationMgr    SUCCESS AthSequencer/AthMasterSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthAlgEvtSeq
-ApplicationMgr    SUCCESS           AthSequencer/AthBeginSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg1
-ApplicationMgr    SUCCESS           AthSequencer/AthAllAlgSeq
-ApplicationMgr    SUCCESS                AthSequencer/AthCondSeq
-ApplicationMgr    SUCCESS                     CondInputLoader/CondInputLoader
-ApplicationMgr    SUCCESS                     MuonAlignmentCondAlg/MuonAlignmentCondAlg
-ApplicationMgr    SUCCESS                     MuonDetectorCondAlg/MuonDetectorCondAlg
-ApplicationMgr    SUCCESS                     RpcCablingCondAlg/RpcCablingCondAlg
-ApplicationMgr    SUCCESS                     MuonMDT_CablingAlg/MuonMDT_CablingAlg
-ApplicationMgr    SUCCESS                     MagField::AtlasFieldMapCondAlg/AtlasFieldMapCondAlg
-ApplicationMgr    SUCCESS                     MagField::AtlasFieldCacheCondAlg/AtlasFieldCacheCondAlg
-ApplicationMgr    SUCCESS                     RpcCondDbAlg/RpcCondDbAlg
-ApplicationMgr    SUCCESS                     RPC_RegSelCondAlg/RegSelCondAlg_RPC
-ApplicationMgr    SUCCESS                     TGC_RegSelCondAlg/RegSelCondAlg_TGC
-ApplicationMgr    SUCCESS                     MdtCalibDbAlg/MdtCalibDbAlg
-ApplicationMgr    SUCCESS                     MDT_RegSelCondAlg/RegSelCondAlg_MDT
-ApplicationMgr    SUCCESS                     CscCondDbAlg/CscCondDbAlg
-ApplicationMgr    SUCCESS                     CSC_RegSelCondAlg/RegSelCondAlg_CSC
-ApplicationMgr    SUCCESS                AthSequencer/AthAlgSeq
-ApplicationMgr    SUCCESS                     MuonCacheCreator/MuonCacheCreator
-ApplicationMgr    SUCCESS                     Muon::RpcRawDataProvider/RpcRawDataProvider
-ApplicationMgr    SUCCESS                     Muon::TgcRawDataProvider/TgcRawDataProvider
-ApplicationMgr    SUCCESS                     Muon::MdtRawDataProvider/MdtRawDataProvider
-ApplicationMgr    SUCCESS                     Muon::CscRawDataProvider/CscRawDataProvider
-ApplicationMgr    SUCCESS                     RpcRdoToRpcPrepData/RpcRdoToRpcPrepData
-ApplicationMgr    SUCCESS                     TgcRdoToTgcPrepData/TgcRdoToTgcPrepData
-ApplicationMgr    SUCCESS                     MdtRdoToMdtPrepData/MdtRdoToMdtPrepData
-ApplicationMgr    SUCCESS                     CscRdoToCscPrepData/CscRdoToCscPrepData
-ApplicationMgr    SUCCESS                     CscThresholdClusterBuilder/CscThresholdClusterBuilder
-ApplicationMgr    SUCCESS           AthSequencer/AthEndSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg2
-ApplicationMgr    SUCCESS      AthSequencer/AthOutSeq
-ApplicationMgr    SUCCESS ******************************************************************************
-ByteStreamInputSvc   INFO Picked valid file: /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/FTHOLD'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/NOISE'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/PED'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/PSLOPE'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/RMS'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/STAT'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/T0BASE'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/T0PHASE'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/EXT/DCS/MAGNETS/SENSORDATA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/GLOBAL/BField/Maps'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/CABLING/MAP_SCHEMA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/CABLING/MEZZANINE_SCHEMA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/RTBLOB'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/T0BLOB'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/CSC/ILINES'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ASBUILTPARAMS'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/BARREL'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEC'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/TGC/SIDEA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/TGC/SIDEC'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/CABLING/MAP_SCHEMA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/CABLING/MAP_SCHEMA_CORR'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DCS/DeadRopanels'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DCS/OffRopanels'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DQMF/ELEMENT_STATUS'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/TRIGGER/CM_THR_ETA'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/TRIGGER/CM_THR_PHI'
-ApplicationMgr       INFO Application Manager Started successfully
-EventInfoByteSt...   INFO IsSimulation : 0
-EventInfoByteSt...   INFO IsTestbeam : 0
-EventInfoByteSt...   INFO IsCalibration : 0
-AthenaEventLoopMgr   INFO   ===>>>  start of run 327265    <<<===
-EventPersistenc...   INFO Added successfully Conversion service:TagInfoMgr
-IOVDbSvc             INFO Opening COOL connection for COOLONL_RPC/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCCablingMapSchema_2016_2017_01 for folder /RPC/CABLING/MAP_SCHEMA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCCablingMapSchemaCorr_2016_2017_01 for folder /RPC/CABLING/MAP_SCHEMA_CORR
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCTriggerCMThrEta_RUN1-RUN2-HI-02 for folder /RPC/TRIGGER/CM_THR_ETA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCTriggerCMThrPhi_RUN1-RUN2-HI-02 for folder /RPC/TRIGGER/CM_THR_PHI
-IOVDbSvc             INFO Disconnecting from COOLONL_RPC/CONDBR2
-EventPersistenc...   INFO Added successfully Conversion service:AthenaPoolCnvSvc
-MuonRPC_CablingSvc   INFO initMappingModel has been called
-MuonRPC_CablingSvc   INFO ToolHandle in initMappingModel - <TheRpcCablingDbTool = PublicToolHandle('RPCCablingDbTool/RPCCablingDbTool')>
-MuonRPC_CablingSvc   INFO Retrieving cabling singleton; to create an empty one or to get the existing one
-RPCcabling           INFO CablingRPC---singleton constructor ---- this must be executed just once
-RPCcabling           INFO CablingRPC---The singleton will fill the maps from the COOL streams
-RPCcabling           INFO CablingRPC---InitMaps from COOL cannot be executed NOW: empty string
-RPCcabling           INFO CablingRPC---The singleton is created here
-RPCcabling           INFO CablingRPC--- cacheCleared: s_status = 0
-MuonRPC_CablingSvc   INFO Cabling singleton cache has been cleared
-MuonRPC_CablingSvc   INFO  Trigger roads will be loaded from COOL
-ToolSvc.RPCCabl...   INFO LoadParameters /RPC/CABLING/MAP_SCHEMA I=2 
-ToolSvc.RPCCabl...   INFO loadRPCMap --- Load Map from DB
-ToolSvc.RPCCabl...   INFO Try to read from folder </RPC/CABLING/MAP_SCHEMA>
-ToolSvc.RPCCabl...   INFO  CondAttrListCollection from DB folder have been obtained with size 1
-ToolSvc.RPCCabl...   INFO After Reading folder, Configuration string size is 222202
-ToolSvc.RPCCabl...   INFO LoadParameters /RPC/CABLING/MAP_SCHEMA_CORR I=2 
-ToolSvc.RPCCabl...   INFO loadRPCCorr --- Load Corrections from DB
-ToolSvc.RPCCabl...   INFO Try to read from folder </RPC/CABLING/MAP_SCHEMA_CORR>
-ToolSvc.RPCCabl...   INFO  CondAttrListCollection from DB folder have been obtained with size 1
-ToolSvc.RPCCabl...   INFO After Reading folder, Correction string size is 29369
-MuonRPC_CablingSvc   INFO  InitMappingModel: Trigger roads not yet loaded from COOL - postpone cabling initialization 
-MuonRPC_CablingSvc   INFO initTrigRoadsModel has been called
-MuonRPC_CablingSvc   INFO  Trigger roads will be loaded from COOL
-MuonRPC_CablingSvc   INFO Retrieve the pointer to the cabling singleton 
-RPCcabling           INFO CablingRPC--- cacheCleared: s_status = 0
-MuonRPC_CablingSvc   INFO Cabling singleton cache has been cleared
-ToolSvc.RPCTrig...   INFO LoadParameters /RPC/TRIGGER/CM_THR_ETA I=2 
-ToolSvc.RPCTrig...   INFO LoadParameters /RPC/TRIGGER/CM_THR_PHI I=2 
-MuonRPC_CablingSvc   INFO ======== RPC Trigger Roads from COOL - Header infos ========
-MuonRPC_CablingSvc   INFO 
+MuonAlignmentCondAlg                                 INFO Initilalizing
+MuonAlignmentCondAlg                                 INFO In initialize ---- # of folders registered is 7
+MuonAlignmentCondAlg                                 INFO geometry version from the MuonDetectorManager = R.08.01
+MuonDetectorCondAlg.MuonDetectorTool                 INFO Initializing ...
+AtlasFieldMapCondAlg                                 INFO Initialize: Key  ( 'AtlasFieldMapCondObj' , 'ConditionStore+fieldMapCondObj' )  has been succesfully registered 
+AtlasFieldMapCondAlg                                 INFO Initialize: Will update the field map from conditions
+AtlasFieldCacheCondAlg                               INFO Initialize: Key  ( 'AtlasFieldCacheCondObj' , 'ConditionStore+fieldCondObj' )  has been succesfully registered 
+AtlasFieldCacheCondAlg                               INFO Initialize: Will update current from conditions
+AtlasFieldCacheCondAlg                               INFO Initialize: useDCS, useSoleCurrent, useToroCurrent. 1,  'UseSoleCurrent':7730.0000,  'UseToroCurrent':20400.000 LockMapCurrents 0
+RegSelCondAlg_RPC                                    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_RPC'
+RegSelCondAlg_TGC                                    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_TGC'
+RegSelCondAlg_MDT                                    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_MDT'
+RegSelCondAlg_CSC                                    INFO MuonRegSelCondAlg::initialize() 'ConditionStore+RegSelLUTCondData_CSC'
+ClassIDSvc                                           INFO  getRegistryEntries: read 8995 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 683 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 1588 CLIDRegistry entries for module ALL
+RpcRawDataProvider                                   INFO RpcRawDataProvider::initialize
+RpcRawDataProvider                                   INFO  'DoSeededDecoding':False
+ClassIDSvc                                           INFO  getRegistryEntries: read 990 CLIDRegistry entries for module ALL
+ROBDataProviderSvc                                   INFO Initializing ROBDataProviderSvc - package version ByteStreamCnvSvcBase-00-00-00
+ROBDataProviderSvc                                   INFO  ---> Filter out empty ROB fragments                               =  'filterEmptyROB':False
+ROBDataProviderSvc                                   INFO  ---> Filter out specific ROBs by Status Code: # ROBs = 0
+ROBDataProviderSvc                                   INFO  ---> Filter out Sub Detector ROBs by Status Code: # Sub Detectors = 0
+RpcRawDataProvider.RPC_RawDataProviderToolMT         INFO initialize() successful in RpcRawDataProvider.RPC_RawDataProviderToolMT
+TgcRawDataProvider                                   INFO TgcRawDataProvider::initialize
+TgcRawDataProvider                                   INFO  'DoSeededDecoding':False
+ClassIDSvc                                           INFO  getRegistryEntries: read 1240 CLIDRegistry entries for module ALL
+TgcRawDataProvider.TGC_RawDataPro...TgcROD_Decoder   INFO initialize() successful in TgcRawDataProvider.TGC_RawDataProviderToolMT.TgcROD_Decoder
+MuonTGC_CablingSvc                                   INFO for 1/12 sector initialize
+MuonTGC_CablingSvc.TGCCablingDbTool                  INFO initialize
+ToolSvc.TGCCablingDbTool                             INFO initialize
+ToolSvc.TGCCablingDbTool                             INFO readTGCMap from text
+ToolSvc.TGCCablingDbTool                             INFO readTGCMap found file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/ASD2PP_diff_12_ONL.db
+ToolSvc.TGCCablingDbTool                             INFO giveASD2PP_DIFF_12 (m_ASD2PP_DIFF_12 is not NULL)
+MuonTGC_CablingSvc                                   INFO   AlgTool: MuonTGC_CablingSvc.TGCCablingDbTool
+TgcRawDataProvider.TGC_RawDataProviderToolMT         INFO initialize() successful in TgcRawDataProvider.TGC_RawDataProviderToolMT
+MdtRawDataProvider                                   INFO MdtRawDataProvider::initialize
+MdtRawDataProvider                                   INFO  'DoSeededDecoding':False
+ClassIDSvc                                           INFO  getRegistryEntries: read 1427 CLIDRegistry entries for module ALL
+MdtRawDataProvider.MDT_RawDataProviderToolMT         INFO Retrieved service ROBDataProviderSvc = ServiceHandle('ROBDataProviderSvc')
+MdtRawDataProvider.MDT_RawDataPro...MdtROD_Decoder   INFO Processing configuration for layouts with BME chambers.
+MdtRawDataProvider.MDT_RawDataPro...MdtROD_Decoder   INFO Processing configuration for layouts with BMG chambers.
+MdtRawDataProvider.MDT_RawDataProviderToolMT         INFO Retrieved tool Decoder = PrivateToolHandle('MdtROD_Decoder/MdtROD_Decoder')
+MdtRawDataProvider.MDT_RawDataProviderToolMT         INFO initialize() successful in MdtRawDataProvider.MDT_RawDataProviderToolMT
+ClassIDSvc                                           INFO  getRegistryEntries: read 1008 CLIDRegistry entries for module ALL
+CscRawDataProvider.CSC_RawDataProviderToolMT         INFO Retrieved service ServiceHandle('ROBDataProviderSvc')
+CscRawDataProvider.CSC_RawDataProviderToolMT         INFO Retrieved tool Decoder = PrivateToolHandle('Muon::CscROD_Decoder/CscROD_Decoder')
+CscRawDataProvider.CSC_RawDataProviderToolMT         INFO initialize() successful in CscRawDataProvider.CSC_RawDataProviderToolMT
+ClassIDSvc                                           INFO  getRegistryEntries: read 54 CLIDRegistry entries for module ALL
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO package version = MuonRPC_CnvTools-00-00-00
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO properties are 
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO produceRpcCoinDatafromTriggerWords 1
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO reduceCablingOverlap               1
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO solvePhiAmbiguities                1
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO timeShift                          -12.5
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO etaphi_coincidenceTime             20
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO overlap_timeTolerance              10
+RpcRdoToRpcPrepData.RpcRdoToRpcPrepDataTool          INFO Correct prd time from cool db      0
+MuonRPC_CablingSvc                                   INFO Initializing MuonRPC_CablingSvc - package version MuonRPC_Cabling-00-00-00
+ToolSvc.RPCCablingDbTool                             INFO Initializing - folders names are: conf /RPC/CABLING/MAP_SCHEMA / corr /RPC/CABLING/MAP_SCHEMA_CORR
+MuonRPC_CablingSvc                                   INFO RPCCablingDbTool retrieved with handle TheRpcCablingDbTool = PublicToolHandle('RPCCablingDbTool/RPCCablingDbTool')
+MuonRPC_CablingSvc                                   INFO Register call-back  against 2 folders listed below 
+MuonRPC_CablingSvc                                   INFO  Folder n. 1 </RPC/CABLING/MAP_SCHEMA>     found in the DetStore
+ClassIDSvc                                           INFO  getRegistryEntries: read 242 CLIDRegistry entries for module ALL
+MuonRPC_CablingSvc                                   INFO initMappingModel registered for call-back against folder </RPC/CABLING/MAP_SCHEMA>
+MuonRPC_CablingSvc                                   INFO  Folder n. 2 </RPC/CABLING/MAP_SCHEMA_CORR>     found in the DetStore
+MuonRPC_CablingSvc                                   INFO initMappingModel registered for call-back against folder </RPC/CABLING/MAP_SCHEMA_CORR>
+MuonRPC_CablingSvc                                   INFO RPCTriggerDbTool retrieved with statusCode = SUCCESS pointer = TheRpcTriggerDbTool = PublicToolHandle('RPCTriggerDbTool')
+MuonRPC_CablingSvc                                   INFO Register call-back  against 2 folders listed below 
+MuonRPC_CablingSvc                                   INFO  Folder n. 1 </RPC/TRIGGER/CM_THR_ETA>     found in the DetStore
+MuonRPC_CablingSvc                                   INFO initTrigRoadsModel registered for call-back against folder </RPC/TRIGGER/CM_THR_ETA>
+MuonRPC_CablingSvc                                   INFO  Folder n. 2 </RPC/TRIGGER/CM_THR_PHI>     found in the DetStore
+MuonRPC_CablingSvc                                   INFO initTrigRoadsModel registered for call-back against folder </RPC/TRIGGER/CM_THR_PHI>
+MuonRPC_CablingSvc                                   INFO   AlgTool: ToolSvc.RPCCablingDbTool
+MuonRPC_CablingSvc                                   INFO   AlgTool: ToolSvc.RPCTriggerDbTool
+RpcRdoToRpcPrepData                                  INFO Retrieved DecodingTool = PrivateToolHandle('Muon::RpcRdoToPrepDataToolMT/RpcRdoToRpcPrepDataTool')
+ClassIDSvc                                           INFO  getRegistryEntries: read 169 CLIDRegistry entries for module ALL
+TgcRdoToTgcPrepData.TgcRdoToTgcPrepDataTool          INFO initialize() successful in TgcRdoToTgcPrepData.TgcRdoToTgcPrepDataTool
+TgcRdoToTgcPrepData                                  INFO Retrieved DecodingTool = PrivateToolHandle('Muon::TgcRdoToPrepDataToolMT/TgcRdoToTgcPrepDataTool')
+MdtRdoToMdtPrepData.MdtRdoToM...MdtCalibrationTool   INFO Processing configuration for layouts with BMG chambers.
+MdtRdoToMdtPrepData.MdtRdoToMdtPrepDataTool          INFO Processing configuration for layouts with BME chambers.
+MdtRdoToMdtPrepData.MdtRdoToMdtPrepDataTool          INFO Processing configuration for layouts with BMG chambers.
+MdtRdoToMdtPrepData                                  INFO Retrieved DecodingTool = PrivateToolHandle('Muon::MdtRdoToPrepDataToolMT/MdtRdoToMdtPrepDataTool')
+ClassIDSvc                                           INFO  getRegistryEntries: read 116 CLIDRegistry entries for module ALL
+CscRdoToCscPrepData                                  INFO Retrieved CscRdoToCscPrepDataTool = PrivateToolHandle('Muon::CscRdoToCscPrepDataToolMT/CscRdoToCscPrepDataTool')
+ByteStreamInputSvc                                   INFO Initializing ByteStreamInputSvc - package version ByteStreamCnvSvc-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 452 CLIDRegistry entries for module ALL
+EventSelector                                        INFO reinitialization...
+AthenaEventLoopMgr                                   INFO Setup EventSelector service EventSelector
+ApplicationMgr                                       INFO Application Manager Initialized successfully
+ApplicationMgr                                    SUCCESS ****************************** Algorithm Sequence ****************************
+ApplicationMgr                                    SUCCESS AthSequencer/AthMasterSeq
+ApplicationMgr                                    SUCCESS      AthSequencer/AthAlgEvtSeq
+ApplicationMgr                                    SUCCESS           AthSequencer/AthBeginSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg1
+ApplicationMgr                                    SUCCESS           AthSequencer/AthAllAlgSeq
+ApplicationMgr                                    SUCCESS                AthSequencer/AthCondSeq
+ApplicationMgr                                    SUCCESS                     CondInputLoader/CondInputLoader
+ApplicationMgr                                    SUCCESS                     MuonAlignmentCondAlg/MuonAlignmentCondAlg
+ApplicationMgr                                    SUCCESS                     MuonDetectorCondAlg/MuonDetectorCondAlg
+ApplicationMgr                                    SUCCESS                     RpcCablingCondAlg/RpcCablingCondAlg
+ApplicationMgr                                    SUCCESS                     MuonMDT_CablingAlg/MuonMDT_CablingAlg
+ApplicationMgr                                    SUCCESS                     MagField::AtlasFieldMapCondAlg/AtlasFieldMapCondAlg
+ApplicationMgr                                    SUCCESS                     MagField::AtlasFieldCacheCondAlg/AtlasFieldCacheCondAlg
+ApplicationMgr                                    SUCCESS                     RpcCondDbAlg/RpcCondDbAlg
+ApplicationMgr                                    SUCCESS                     RPC_RegSelCondAlg/RegSelCondAlg_RPC
+ApplicationMgr                                    SUCCESS                     TGC_RegSelCondAlg/RegSelCondAlg_TGC
+ApplicationMgr                                    SUCCESS                     MdtCalibDbAlg/MdtCalibDbAlg
+ApplicationMgr                                    SUCCESS                     MDT_RegSelCondAlg/RegSelCondAlg_MDT
+ApplicationMgr                                    SUCCESS                     CscCondDbAlg/CscCondDbAlg
+ApplicationMgr                                    SUCCESS                     CSC_RegSelCondAlg/RegSelCondAlg_CSC
+ApplicationMgr                                    SUCCESS                AthSequencer/AthAlgSeq
+ApplicationMgr                                    SUCCESS                     MuonCacheCreator/MuonCacheCreator
+ApplicationMgr                                    SUCCESS                     Muon::RpcRawDataProvider/RpcRawDataProvider
+ApplicationMgr                                    SUCCESS                     Muon::TgcRawDataProvider/TgcRawDataProvider
+ApplicationMgr                                    SUCCESS                     Muon::MdtRawDataProvider/MdtRawDataProvider
+ApplicationMgr                                    SUCCESS                     Muon::CscRawDataProvider/CscRawDataProvider
+ApplicationMgr                                    SUCCESS                     RpcRdoToRpcPrepData/RpcRdoToRpcPrepData
+ApplicationMgr                                    SUCCESS                     TgcRdoToTgcPrepData/TgcRdoToTgcPrepData
+ApplicationMgr                                    SUCCESS                     MdtRdoToMdtPrepData/MdtRdoToMdtPrepData
+ApplicationMgr                                    SUCCESS                     CscRdoToCscPrepData/CscRdoToCscPrepData
+ApplicationMgr                                    SUCCESS                     CscThresholdClusterBuilder/CscThresholdClusterBuilder
+ApplicationMgr                                    SUCCESS           AthSequencer/AthEndSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg2
+ApplicationMgr                                    SUCCESS      AthSequencer/AthOutSeq
+ApplicationMgr                                    SUCCESS ******************************************************************************
+ByteStreamInputSvc                                   INFO Picked valid file: /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/FTHOLD'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/NOISE'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/PED'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/PSLOPE'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/RMS'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/STAT'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/T0BASE'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CSC/T0PHASE'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/EXT/DCS/MAGNETS/SENSORDATA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/GLOBAL/BField/Maps'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/CABLING/MAP_SCHEMA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/CABLING/MEZZANINE_SCHEMA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/RTBLOB'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MDT/T0BLOB'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/CSC/ILINES'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ASBUILTPARAMS'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/BARREL'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEC'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/TGC/SIDEA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/MUONALIGN/TGC/SIDEC'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/CABLING/MAP_SCHEMA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/CABLING/MAP_SCHEMA_CORR'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DCS/DeadRopanels'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DCS/OffRopanels'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/DQMF/ELEMENT_STATUS'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/TRIGGER/CM_THR_ETA'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/RPC/TRIGGER/CM_THR_PHI'
+ApplicationMgr                                       INFO Application Manager Started successfully
+EventInfoByteStreamAuxCnv                            INFO IsSimulation : 0
+EventInfoByteStreamAuxCnv                            INFO IsTestbeam : 0
+EventInfoByteStreamAuxCnv                            INFO IsCalibration : 0
+AthenaEventLoopMgr                                   INFO   ===>>>  start of run 327265    <<<===
+EventPersistencySvc                                  INFO Added successfully Conversion service:TagInfoMgr
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_RPC/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCCablingMapSchema_2016_2017_01 for folder /RPC/CABLING/MAP_SCHEMA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCCablingMapSchemaCorr_2016_2017_01 for folder /RPC/CABLING/MAP_SCHEMA_CORR
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCTriggerCMThrEta_RUN1-RUN2-HI-02 for folder /RPC/TRIGGER/CM_THR_ETA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCTriggerCMThrPhi_RUN1-RUN2-HI-02 for folder /RPC/TRIGGER/CM_THR_PHI
+IOVDbSvc                                             INFO Disconnecting from COOLONL_RPC/CONDBR2
+IOVDbSvc                                             INFO Opened read transaction for POOL PersistencySvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:AthenaPoolCnvSvc
+MuonRPC_CablingSvc                                   INFO initMappingModel has been called
+MuonRPC_CablingSvc                                   INFO ToolHandle in initMappingModel - <TheRpcCablingDbTool = PublicToolHandle('RPCCablingDbTool/RPCCablingDbTool')>
+MuonRPC_CablingSvc                                   INFO Retrieving cabling singleton; to create an empty one or to get the existing one
+RPCcabling                                           INFO CablingRPC---singleton constructor ---- this must be executed just once
+RPCcabling                                           INFO CablingRPC---The singleton will fill the maps from the COOL streams
+RPCcabling                                           INFO CablingRPC---InitMaps from COOL cannot be executed NOW: empty string
+RPCcabling                                           INFO CablingRPC---The singleton is created here
+RPCcabling                                           INFO CablingRPC--- cacheCleared: s_status = 0
+MuonRPC_CablingSvc                                   INFO Cabling singleton cache has been cleared
+MuonRPC_CablingSvc                                   INFO  Trigger roads will be loaded from COOL
+ToolSvc.RPCCablingDbTool                             INFO LoadParameters /RPC/CABLING/MAP_SCHEMA I=2 
+ToolSvc.RPCCablingDbTool                             INFO loadRPCMap --- Load Map from DB
+ToolSvc.RPCCablingDbTool                             INFO Try to read from folder </RPC/CABLING/MAP_SCHEMA>
+ToolSvc.RPCCablingDbTool                             INFO  CondAttrListCollection from DB folder have been obtained with size 1
+ToolSvc.RPCCablingDbTool                             INFO After Reading folder, Configuration string size is 222202
+ToolSvc.RPCCablingDbTool                             INFO LoadParameters /RPC/CABLING/MAP_SCHEMA_CORR I=2 
+ToolSvc.RPCCablingDbTool                             INFO loadRPCCorr --- Load Corrections from DB
+ToolSvc.RPCCablingDbTool                             INFO Try to read from folder </RPC/CABLING/MAP_SCHEMA_CORR>
+ToolSvc.RPCCablingDbTool                             INFO  CondAttrListCollection from DB folder have been obtained with size 1
+ToolSvc.RPCCablingDbTool                             INFO After Reading folder, Correction string size is 29369
+MuonRPC_CablingSvc                                   INFO  InitMappingModel: Trigger roads not yet loaded from COOL - postpone cabling initialization 
+MuonRPC_CablingSvc                                   INFO initTrigRoadsModel has been called
+MuonRPC_CablingSvc                                   INFO  Trigger roads will be loaded from COOL
+MuonRPC_CablingSvc                                   INFO Retrieve the pointer to the cabling singleton 
+RPCcabling                                           INFO CablingRPC--- cacheCleared: s_status = 0
+MuonRPC_CablingSvc                                   INFO Cabling singleton cache has been cleared
+ToolSvc.RPCTriggerDbTool                             INFO LoadParameters /RPC/TRIGGER/CM_THR_ETA I=2 
+ToolSvc.RPCTriggerDbTool                             INFO LoadParameters /RPC/TRIGGER/CM_THR_PHI I=2 
+MuonRPC_CablingSvc                                   INFO ======== RPC Trigger Roads from COOL - Header infos ========
+MuonRPC_CablingSvc                                   INFO 
 RPC LVL1 Configuration 10.6 with roads from Feb 2012
 L1 THRESHOLDS:   MU4 MU6 MU10 MU11 MU15 MU20
 Road version: "road_files_120209"
@@ -740,18 +739,18 @@ eta high-pt    mu11  mu15   mu20
 phi high-pt    mu11  mu15   mu15
 
 
-RPCcabling           INFO CablingRPC---InitMaps from COOL: going to read configuration
-RPCcabling           INFO CablingRPC--->> RPC cabling map from COOL <<
-RPCcabling           INFO CablingRPC--- ReadConf: map has size 222202
-RPCcabling           INFO CablingRPC--- ReadConf: map n. of lines read is 924
-RPCcabling           INFO CablingRPC--- ReadConf: version is 5.0 Atlas R_07_03_RUN2ver104
-RPCcabling           INFO CablingRPC--- buildRDOmap
-RPCcabling           INFO CablingRPC---InitMaps from COOL: going to read corrections to configuration
-RPCcabling           INFO CablingRPC--->> RPC cabling corrections from COOL <<
-RPCcabling           INFO CablingRPC--- ReadCorr: CorrMap has size 29369
-RPCcabling           INFO CablingRPC--- ReadConf: CorrMap n. of lines read is 743
-RPCcabling           INFO CablingRPC---InitMaps from COOL - maps have been parsed
-MuonRPC_CablingSvc   INFO InitTrigRoadsModel: RPC cabling model is loaded!
+RPCcabling                                           INFO CablingRPC---InitMaps from COOL: going to read configuration
+RPCcabling                                           INFO CablingRPC--->> RPC cabling map from COOL <<
+RPCcabling                                           INFO CablingRPC--- ReadConf: map has size 222202
+RPCcabling                                           INFO CablingRPC--- ReadConf: map n. of lines read is 924
+RPCcabling                                           INFO CablingRPC--- ReadConf: version is 5.0 Atlas R_07_03_RUN2ver104
+RPCcabling                                           INFO CablingRPC--- buildRDOmap
+RPCcabling                                           INFO CablingRPC---InitMaps from COOL: going to read corrections to configuration
+RPCcabling                                           INFO CablingRPC--->> RPC cabling corrections from COOL <<
+RPCcabling                                           INFO CablingRPC--- ReadCorr: CorrMap has size 29369
+RPCcabling                                           INFO CablingRPC--- ReadConf: CorrMap n. of lines read is 743
+RPCcabling                                           INFO CablingRPC---InitMaps from COOL - maps have been parsed
+MuonRPC_CablingSvc                                   INFO InitTrigRoadsModel: RPC cabling model is loaded!
 Level-1 configuration database version 5.0 Atlas R_07_03_RUN2ver104 read.
 Contains 26 Trigger Sector Types:
 negative sectors  0 - 15 ==> 18  2 24  3 19  2 24  4 20  2 24  1 18  5 25  6 
@@ -759,351 +758,351 @@ negative sectors 16 - 31 ==> 21 13 26  6 21  7 16  8 14  7 16  6 21 13 26  1
 positive sectors 32 - 47 ==>  9 24  2 22  9 24  2 23 10 24  2 18  1 25  5 18 
 positive sectors 48 - 63 ==>  1 26 13 21  6 17 12 15 11 17 12 21  6 26 13 22 
 
-MuonRPC_CablingSvc   INFO buildOfflineOnlineMap
-MuonRPC_CablingSvc   INFO Applying FeetPadThresholds : 0,2,5
-MuonRPC_CablingSvc   INFO MuonRPC_CablingSvc initialized succesfully
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186525031, run #327265 0 events processed so far  <<<===
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_CSC/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscFthold-RUN2-BLK-UPD1-007-00 for folder /CSC/FTHOLD
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscNoise-RUN2-BLK-UPD1-007-00 for folder /CSC/NOISE
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscPed-RUN2-BLK-UPD1-007-00 for folder /CSC/PED
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscPslope-RUN2-BLK-UPD1-000-00 for folder /CSC/PSLOPE
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscRms-RUN2-BLK-UPD1-003-00 for folder /CSC/RMS
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscStat-RUN2-BLK-UPD1-008-00 for folder /CSC/STAT
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscT0base-RUN2-BLK-UPD1-001-00 for folder /CSC/T0BASE
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscT0phase-RUN2-BLK-UPD2-001-00 for folder /CSC/T0PHASE
-IOVDbSvc             INFO Disconnecting from COOLOFL_CSC/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_DCS/CONDBR2
-IOVDbSvc             INFO Disconnecting from COOLOFL_DCS/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_GLOBAL/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to BFieldMap-Run1-14m-v01 for folder /GLOBAL/BField/Maps
-IOVDbSvc             INFO Disconnecting from COOLONL_GLOBAL/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLONL_MDT/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTCablingMapSchema_BMG_01 for folder /MDT/CABLING/MAP_SCHEMA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTCablingMezzanineSchema_M5-RUN2 for folder /MDT/CABLING/MEZZANINE_SCHEMA
-IOVDbSvc             INFO Disconnecting from COOLONL_MDT/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_MDT/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTRT-RUN2-UPD4-21 for folder /MDT/RTBLOB
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTT0-RUN2-UPD4-21 for folder /MDT/T0BLOB
-IOVDbSvc             INFO Disconnecting from COOLOFL_MDT/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_MUONALIGN/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignCscIlines-UPD1-02 for folder /MUONALIGN/CSC/ILINES
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMdtAsbuiltparams-RUN2-BA_ONLY-UPD4-00 for folder /MUONALIGN/MDT/ASBUILTPARAMS
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTBarrelAlign-RUN2-BA_ROLLING_11-BLKP-UPD4-00 for folder /MUONALIGN/MDT/BARREL
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTEndCapAAlign-RUN2-ECA_ROLLING_2015_03_01-UPD4-02 for folder /MUONALIGN/MDT/ENDCAP/SIDEA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTEndCapCAlign-RUN2-ECC_ROLLING_2015_03_01-UPD4-02 for folder /MUONALIGN/MDT/ENDCAP/SIDEC
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignTGCEndCapAAlign-RUN2-TGCA_ROLLING_2011_01-ES1-UPD1-03 for folder /MUONALIGN/TGC/SIDEA
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignTGCEndCapCAlign-RUN2-TGCC_ROLLING_2011_01-ES1-UPD1-03 for folder /MUONALIGN/TGC/SIDEC
-IOVDbSvc             INFO Disconnecting from COOLOFL_MUONALIGN/CONDBR2
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_RPC/CONDBR2
-IOVDbFolder          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCDQMFElementStatus_Run1_UPD4-RUN2-01 for folder /RPC/DQMF/ELEMENT_STATUS
-IOVDbSvc             INFO Disconnecting from COOLOFL_RPC/CONDBR2
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/CSC/ILINES>
-MuonAlignmentCo...   INFO Size of CSC/ILINES CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/CSC/ILINES' )  readCscILinesCdo->size()= 1
-MuonAlignmentCo...   INFO Range of CSC/ILINES input is {[0,0,t:1425168000] - [t:4294967294.854775807]}
-MuonAlignmentCo...   INFO recorded new CscInternalAlignmentMapContainer with range {[0,0,t:1425168000] - [t:4294967294.854775807]} into Conditions Store
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ASBUILTPARAMS>
-MuonAlignmentCo...   INFO Size of MDT/ASBUILTPARAMS CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ASBUILTPARAMS' )  ->size()= 1
-MuonAlignmentCo...   INFO Range of MDT/ASBUILTPARAMS input is {[0,0,t:0] - [t:4294967294.854775807]}
-MuonAlignmentCo...   INFO recorded new MdtAsBuiltMapContainer with range {[0,0,t:0] - [t:4294967294.854775807]} into Conditions Store
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/MDT/BARREL>
-MuonAlignmentCo...   INFO Size of /MUONALIGN/MDT/BARREL CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/BARREL' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/MDT/BARREL input is, ALines: {[0,0,t:1497851700] - [t:1498737300]} BLines: {[0,0,t:1497851700] - [t:1498737300]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/MDT/BARREL have IoV = 195569
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/BARREL> loaded
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEA>
-MuonAlignmentCo...   INFO Size of /MUONALIGN/MDT/ENDCAP/SIDEA CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEA' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/MDT/ENDCAP/SIDEA input is, ALines: {[0,0,t:1497891240] - [t:1497898380]} BLines: {[0,0,t:1497891240] - [t:1497898380]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/MDT/ENDCAP/SIDEA have IoV = 195588
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEA> loaded
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEC>
-MuonAlignmentCo...   INFO Size of /MUONALIGN/MDT/ENDCAP/SIDEC CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEC' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/MDT/ENDCAP/SIDEC input is, ALines: {[0,0,t:1497892260] - [t:1497899460]} BLines: {[0,0,t:1497892260] - [t:1497899460]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/MDT/ENDCAP/SIDEC have IoV = 195599
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEC> loaded
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/TGC/SIDEA>
-MuonAlignmentCo...   INFO No BLines decoding will be attempted for folder named /MUONALIGN/TGC/SIDEA
-MuonAlignmentCo...   INFO Size of /MUONALIGN/TGC/SIDEA CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/TGC/SIDEA' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/TGC/SIDEA input is, ALines: {[0,0,t:0] - [t:4294967294.854775807]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/TGC/SIDEA have IoV = 82360
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/TGC/SIDEA> loaded
-MuonAlignmentCo...   INFO Load alignment parameters from DB folder </MUONALIGN/TGC/SIDEC>
-MuonAlignmentCo...   INFO No BLines decoding will be attempted for folder named /MUONALIGN/TGC/SIDEC
-MuonAlignmentCo...   INFO Size of /MUONALIGN/TGC/SIDEC CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/TGC/SIDEC' )  readCdo->size()= 1
-MuonAlignmentCo...   INFO Range of /MUONALIGN/TGC/SIDEC input is, ALines: {[0,0,t:0] - [t:4294967294.854775807]}
-MuonAlignmentCo...   INFO Data read from folder /MUONALIGN/TGC/SIDEC have IoV = 82359
-MuonAlignmentCo...   INFO A- and B-Lines parameters from DB folder </MUONALIGN/TGC/SIDEC> loaded
-MuonAlignmentCo...   INFO recorded new ALineMapContainer with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
-MuonAlignmentCo...   INFO recorded new BLineMapContainer with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
-MuonGeoModel         INFO MuonDetectorFactory - constructor  MuonSystem OuterRadius 13000 Length 22030
-MuonDetectorCon...   INFO create MuonDetectorTool - package version = MuonGeoModel-00-00-00
-MuonDetectorCon...   INFO (from GeoModelSvc)    AtlasVersion = <ATLAS-R2-2016-01-00-01>  MuonVersion = <>
-MuonDetectorCon...   INFO Keys for Muon Switches are  (key) ATLAS-R2-2016-01-00-01 (node) ATLAS
-MuonDetectorCon...   INFO (from GeoModelSvc) in AtlasVersion = <ATLAS-R2-2016-01-00-01>  default MuonVersion is <MuonSpectrometer-R.08.01>
-MuonDetectorCon...   INFO Properties have been set as follows: 
-MuonDetectorCon...   INFO     LayoutName                     R
-MuonDetectorCon...   INFO     IncludeCutouts                 0
-MuonDetectorCon...   INFO     IncludeCutoutsBog              0
-MuonDetectorCon...   INFO     IncludeCtbBis                  0
-MuonDetectorCon...   INFO     ControlAlines                  111111
-MuonDetectorCon...   INFO     MinimalGeoFlag                 0
-MuonDetectorCon...   INFO     EnableCscIntAlignment          1
-MuonDetectorCon...   INFO     EnableCscIntAlignmentFromGM    0
-MuonDetectorCon...   INFO     ControlCscIntAlines            111111
-MuonDetectorCon...   INFO     EnableMdtDeformations          1
-MuonDetectorCon...   INFO     EnableMdtAsBuiltParameters     1
-MuGM:MuonFactory     INFO MuonLayout set to <R.08.01> = Development version for DC3 - infrastructures 
-MuGM:MuonFactory     INFO                    BOG cutouts are activated 1 , all other cutouts are disabled 1
-MuGM:MuonFactory     INFO Manager created for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
-MuonGeoModel.MYSQL   INFO GeometryVersion set to <R.08.01>
-MuGM:MuonFactory     INFO Mysql helper class created here for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
-MuGM:MuonFactory     INFO MDTIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO RPCIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO TGCIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO CSCIDHELPER retrieved from DetStore
-MuGM:MuonFactory     INFO  **************** MuonDetectorFactory001 ************************
-MuGM:MuonFactory     INFO  *** Start building the Muon Geometry Tree **********************
-MuGM:RDBReadAtlas    INFO Start retriving dbObjects with tag = <ATLAS-R2-2016-01-00-01> node <ATLAS>
-RDBAccessSvc      WARNING Could not get the tag for XtomoData node. Returning 0 pointer to IRDBQuery
-MuGM:RDBReadAtlas    INFO After getQuery XtomoData
+MuonRPC_CablingSvc                                   INFO buildOfflineOnlineMap
+MuonRPC_CablingSvc                                   INFO Applying FeetPadThresholds : 0,2,5
+MuonRPC_CablingSvc                                   INFO MuonRPC_CablingSvc initialized succesfully
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186525031, run #327265 0 events processed so far  <<<===
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_CSC/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscFthold-RUN2-BLK-UPD1-007-00 for folder /CSC/FTHOLD
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscNoise-RUN2-BLK-UPD1-007-00 for folder /CSC/NOISE
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscPed-RUN2-BLK-UPD1-007-00 for folder /CSC/PED
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscPslope-RUN2-BLK-UPD1-000-00 for folder /CSC/PSLOPE
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscRms-RUN2-BLK-UPD1-003-00 for folder /CSC/RMS
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscStat-RUN2-BLK-UPD1-008-00 for folder /CSC/STAT
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscT0base-RUN2-BLK-UPD1-001-00 for folder /CSC/T0BASE
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to CscT0phase-RUN2-BLK-UPD2-001-00 for folder /CSC/T0PHASE
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_CSC/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_DCS/CONDBR2
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_DCS/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_GLOBAL/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to BFieldMap-Run1-14m-v01 for folder /GLOBAL/BField/Maps
+IOVDbSvc                                             INFO Disconnecting from COOLONL_GLOBAL/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLONL_MDT/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTCablingMapSchema_BMG_01 for folder /MDT/CABLING/MAP_SCHEMA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTCablingMezzanineSchema_M5-RUN2 for folder /MDT/CABLING/MEZZANINE_SCHEMA
+IOVDbSvc                                             INFO Disconnecting from COOLONL_MDT/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_MDT/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTRT-RUN2-UPD4-21 for folder /MDT/RTBLOB
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MDTT0-RUN2-UPD4-21 for folder /MDT/T0BLOB
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_MDT/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_MUONALIGN/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignCscIlines-UPD1-02 for folder /MUONALIGN/CSC/ILINES
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMdtAsbuiltparams-RUN2-BA_ONLY-UPD4-00 for folder /MUONALIGN/MDT/ASBUILTPARAMS
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTBarrelAlign-RUN2-BA_ROLLING_11-BLKP-UPD4-00 for folder /MUONALIGN/MDT/BARREL
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTEndCapAAlign-RUN2-ECA_ROLLING_2015_03_01-UPD4-02 for folder /MUONALIGN/MDT/ENDCAP/SIDEA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignMDTEndCapCAlign-RUN2-ECC_ROLLING_2015_03_01-UPD4-02 for folder /MUONALIGN/MDT/ENDCAP/SIDEC
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignTGCEndCapAAlign-RUN2-TGCA_ROLLING_2011_01-ES1-UPD1-03 for folder /MUONALIGN/TGC/SIDEA
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to MuonAlignTGCEndCapCAlign-RUN2-TGCC_ROLLING_2011_01-ES1-UPD1-03 for folder /MUONALIGN/TGC/SIDEC
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_MUONALIGN/CONDBR2
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_RPC/CONDBR2
+IOVDbFolder                                          INFO HVS tag CONDBR2-BLKPA-2018-13 resolved to RPCDQMFElementStatus_Run1_UPD4-RUN2-01 for folder /RPC/DQMF/ELEMENT_STATUS
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_RPC/CONDBR2
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/CSC/ILINES>
+MuonAlignmentCondAlg                                 INFO Size of CSC/ILINES CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/CSC/ILINES' )  readCscILinesCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of CSC/ILINES input is {[0,0,t:1425168000] - [t:4294967294.854775807]}
+MuonAlignmentCondAlg                                 INFO recorded new CscInternalAlignmentMapContainer with range {[0,0,t:1425168000] - [t:4294967294.854775807]} into Conditions Store
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ASBUILTPARAMS>
+MuonAlignmentCondAlg                                 INFO Size of MDT/ASBUILTPARAMS CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ASBUILTPARAMS' )  ->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of MDT/ASBUILTPARAMS input is {[0,0,t:0] - [t:4294967294.854775807]}
+MuonAlignmentCondAlg                                 INFO recorded new MdtAsBuiltMapContainer with range {[0,0,t:0] - [t:4294967294.854775807]} into Conditions Store
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/MDT/BARREL>
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/MDT/BARREL CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/BARREL' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/MDT/BARREL input is, ALines: {[0,0,t:1497851700] - [t:1498737300]} BLines: {[0,0,t:1497851700] - [t:1498737300]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/MDT/BARREL have IoV = 195569
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/BARREL> loaded
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEA>
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/MDT/ENDCAP/SIDEA CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEA' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/MDT/ENDCAP/SIDEA input is, ALines: {[0,0,t:1497891240] - [t:1497898380]} BLines: {[0,0,t:1497891240] - [t:1497898380]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/MDT/ENDCAP/SIDEA have IoV = 195588
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEA> loaded
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEC>
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/MDT/ENDCAP/SIDEC CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/MDT/ENDCAP/SIDEC' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/MDT/ENDCAP/SIDEC input is, ALines: {[0,0,t:1497892260] - [t:1497899460]} BLines: {[0,0,t:1497892260] - [t:1497899460]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/MDT/ENDCAP/SIDEC have IoV = 195599
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/MDT/ENDCAP/SIDEC> loaded
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/TGC/SIDEA>
+MuonAlignmentCondAlg                                 INFO No BLines decoding will be attempted for folder named /MUONALIGN/TGC/SIDEA
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/TGC/SIDEA CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/TGC/SIDEA' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/TGC/SIDEA input is, ALines: {[0,0,t:0] - [t:4294967294.854775807]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/TGC/SIDEA have IoV = 82360
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/TGC/SIDEA> loaded
+MuonAlignmentCondAlg                                 INFO Load alignment parameters from DB folder </MUONALIGN/TGC/SIDEC>
+MuonAlignmentCondAlg                                 INFO No BLines decoding will be attempted for folder named /MUONALIGN/TGC/SIDEC
+MuonAlignmentCondAlg                                 INFO Size of /MUONALIGN/TGC/SIDEC CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MUONALIGN/TGC/SIDEC' )  readCdo->size()= 1
+MuonAlignmentCondAlg                                 INFO Range of /MUONALIGN/TGC/SIDEC input is, ALines: {[0,0,t:0] - [t:4294967294.854775807]}
+MuonAlignmentCondAlg                                 INFO Data read from folder /MUONALIGN/TGC/SIDEC have IoV = 82359
+MuonAlignmentCondAlg                                 INFO A- and B-Lines parameters from DB folder </MUONALIGN/TGC/SIDEC> loaded
+MuonAlignmentCondAlg                                 INFO recorded new ALineMapContainer with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
+MuonAlignmentCondAlg                                 INFO recorded new BLineMapContainer with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
+MuonGeoModel                                         INFO MuonDetectorFactory - constructor  MuonSystem OuterRadius 13000 Length 22030
+MuonDetectorCondAlg.MuonDetectorTool                 INFO create MuonDetectorTool - package version = MuonGeoModel-00-00-00
+MuonDetectorCondAlg.MuonDetectorTool                 INFO (from GeoModelSvc)    AtlasVersion = <ATLAS-R2-2016-01-00-01>  MuonVersion = <>
+MuonDetectorCondAlg.MuonDetectorTool                 INFO Keys for Muon Switches are  (key) ATLAS-R2-2016-01-00-01 (node) ATLAS
+MuonDetectorCondAlg.MuonDetectorTool                 INFO (from GeoModelSvc) in AtlasVersion = <ATLAS-R2-2016-01-00-01>  default MuonVersion is <MuonSpectrometer-R.08.01>
+MuonDetectorCondAlg.MuonDetectorTool                 INFO Properties have been set as follows: 
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     LayoutName                     R
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     IncludeCutouts                 0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     IncludeCutoutsBog              0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     IncludeCtbBis                  0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     ControlAlines                  111111
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     MinimalGeoFlag                 0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     EnableCscIntAlignment          1
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     EnableCscIntAlignmentFromGM    0
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     ControlCscIntAlines            111111
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     EnableMdtDeformations          1
+MuonDetectorCondAlg.MuonDetectorTool                 INFO     EnableMdtAsBuiltParameters     1
+MuGM:MuonFactory                                     INFO MuonLayout set to <R.08.01> = Development version for DC3 - infrastructures 
+MuGM:MuonFactory                                     INFO                    BOG cutouts are activated 1 , all other cutouts are disabled 1
+MuGM:MuonFactory                                     INFO Manager created for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
+MuonGeoModel.MYSQL                                   INFO GeometryVersion set to <R.08.01>
+MuGM:MuonFactory                                     INFO Mysql helper class created here for geometry version R.08.01 from DB MuonVersion <MuonSpectrometer-R.08.01>
+MuGM:MuonFactory                                     INFO MDTIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO RPCIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO TGCIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO CSCIDHELPER retrieved from DetStore
+MuGM:MuonFactory                                     INFO  **************** MuonDetectorFactory001 ************************
+MuGM:MuonFactory                                     INFO  *** Start building the Muon Geometry Tree **********************
+MuGM:RDBReadAtlas                                    INFO Start retriving dbObjects with tag = <ATLAS-R2-2016-01-00-01> node <ATLAS>
+RDBAccessSvc                                      WARNING Could not get the tag for XtomoData node. Returning 0 pointer to IRDBQuery
+MuGM:RDBReadAtlas                                    INFO After getQuery XtomoData
 In DblQ00Xtomo(data)
 No XtomoData table in the MuonDD Database
-MuGM:RDBReadAtlas    INFO After new DblQ00Xtomo
-MuGM:RDBReadAtlas    INFO No Ascii aszt input found: looking for A-lines in ORACLE
-MuGM:RDBReadAtlas    INFO ASZT table found in Oracle
-MuGM:RDBReadAtlas    INFO ASZT size is 32
-MuGM:RDBReadAtlas    INFO No Ascii iacsc input found: looking for A-lines in ORACLE
-RDBAccessSvc      WARNING Could not get the tag for ISZT node. Returning 0 pointer to IRDBQuery
-MuGM:RDBReadAtlas    INFO No ISZT table in Oracle
-MuGM:RDBReadAtlas    INFO Access granted for all dbObjects needed by muon detectors
-MuonGeoModel.MYSQL   INFO LayoutName (from DBAM) set to <R.08>  -- relevant for CTB2004
-MuGM:ProcStations    INFO  Processing Stations and Components
-MuGM:ProcStations    INFO  Processing Stations and Components DONE
-MuGM:ProcTechnol.s   INFO nMDT 26 nCSC 4 nTGC 44 nRPC 50
-MuGM:ProcTechnol.s   INFO nDED 4 nSUP 8 nSPA 4
-MuGM:ProcTechnol.s   INFO nCHV 14 nCRO 14 nCMI 12 nLBI 12
-MuGM:ProcPosition    INFO  *** N. of stations positioned in the setup 234
-MuGM:ProcPosition    INFO  *** N. of stations described in mysql      234
-MuGM:ProcPosition    INFO  *** N. of types  32 size of jtypvec 32
-MuGM:ProcPosition    INFO  *** : 234 kinds of stations (type*sub_type) 
-MuGM:ProcPosition    INFO  *** : 1758 physical stations in space - according to the MuonDD DataBase
-MuGM:ProcCutouts     INFO  Processing Cutouts for geometry layout R.08
-MuGM:ProcCutouts     INFO  Processing Cutouts DONE
-MuGM:RDBReadAtlas    INFO  ProcessTGCreadout - version 7 wirespacing 1.8
-MuGM:RDBReadAtlas    INFO Intermediate Objects built from primary numbers
-MuGM:MuonFactory     INFO  theMaterialManager retrieven successfully from the DetStore
-MuGM:MuonFactory     INFO MuonSystem description from OracleTag=<ATLAS-R2-2016-01-00-01> and node=<ATLAS>
-MuGM:MuonFactory     INFO  TreeTop added to the Manager
-MuGM:MuonFactory     INFO  Muon Layout R.08.01
-MuGM:MuonFactory     INFO Fine Clash Fixing disabled: (should be ON/OFF for Simulation/Reconstruction)
-MuGM:MuonFactory     INFO  **************** MuonDetectorFactory001 ****************************
-MuGM:MuonFactory     INFO  *** The Muon Chamber Geometry Tree is built with 
-MuGM:MuonFactory     INFO  *** 1758 child volumes 
-MuGM:MuonFactory     INFO  *** 1839 independent elements and 
-MuGM:MuonFactory     INFO  *** 11473 elements cloned or shared 
-MuGM:MuonFactory     INFO  *** 234 kinds of stations
-MuGM:MuonFactory     INFO  *** 1758 stations with alignable transforms
-MuGM:MuonFactory     INFO  *** 148 stations are described as Assemblies
-MuGM:MuonFactory     INFO  *** 1758 MuonStations 
-MuGM:MuonFactory     INFO  *** 	 2324 MDT Readout Elements 	 1186 MDT Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 32 CSC Readout Elements 	 32 CSC Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 1122 RPC Readout Elements 	 600 RPC Detector Elements 
-MuGM:MuonFactory     INFO  *** 	 1578 TGC Readout Elements 	 1578 TGC Detector Elements 
-MuGM:MuonFactory     INFO  ********************************************************************
-MuGM:MuonFactory     INFO  *** Inert Material built according to DB switches and config. ****** 
-MuGM:MuonFactory     INFO  *** The Muon Geometry Tree has 1758 child vol.s in total ********
-MuGM:MuonFactory     INFO  ********************************************************************
+MuGM:RDBReadAtlas                                    INFO After new DblQ00Xtomo
+MuGM:RDBReadAtlas                                    INFO No Ascii aszt input found: looking for A-lines in ORACLE
+MuGM:RDBReadAtlas                                    INFO ASZT table found in Oracle
+MuGM:RDBReadAtlas                                    INFO ASZT size is 32
+MuGM:RDBReadAtlas                                    INFO No Ascii iacsc input found: looking for A-lines in ORACLE
+RDBAccessSvc                                      WARNING Could not get the tag for ISZT node. Returning 0 pointer to IRDBQuery
+MuGM:RDBReadAtlas                                    INFO No ISZT table in Oracle
+MuGM:RDBReadAtlas                                    INFO Access granted for all dbObjects needed by muon detectors
+MuonGeoModel.MYSQL                                   INFO LayoutName (from DBAM) set to <R.08>  -- relevant for CTB2004
+MuGM:ProcStations                                    INFO  Processing Stations and Components
+MuGM:ProcStations                                    INFO  Processing Stations and Components DONE
+MuGM:ProcTechnol.s                                   INFO nMDT 26 nCSC 4 nTGC 44 nRPC 50
+MuGM:ProcTechnol.s                                   INFO nDED 4 nSUP 8 nSPA 4
+MuGM:ProcTechnol.s                                   INFO nCHV 14 nCRO 14 nCMI 12 nLBI 12
+MuGM:ProcPosition                                    INFO  *** N. of stations positioned in the setup 234
+MuGM:ProcPosition                                    INFO  *** N. of stations described in mysql      234
+MuGM:ProcPosition                                    INFO  *** N. of types  32 size of jtypvec 32
+MuGM:ProcPosition                                    INFO  *** : 234 kinds of stations (type*sub_type) 
+MuGM:ProcPosition                                    INFO  *** : 1758 physical stations in space - according to the MuonDD DataBase
+MuGM:ProcCutouts                                     INFO  Processing Cutouts for geometry layout R.08
+MuGM:ProcCutouts                                     INFO  Processing Cutouts DONE
+MuGM:RDBReadAtlas                                    INFO  ProcessTGCreadout - version 7 wirespacing 1.8
+MuGM:RDBReadAtlas                                    INFO Intermediate Objects built from primary numbers
+MuGM:MuonFactory                                     INFO  theMaterialManager retrieven successfully from the DetStore
+MuGM:MuonFactory                                     INFO MuonSystem description from OracleTag=<ATLAS-R2-2016-01-00-01> and node=<ATLAS>
+MuGM:MuonFactory                                     INFO  TreeTop added to the Manager
+MuGM:MuonFactory                                     INFO  Muon Layout R.08.01
+MuGM:MuonFactory                                     INFO Fine Clash Fixing disabled: (should be ON/OFF for Simulation/Reconstruction)
+MuGM:MuonFactory                                     INFO  **************** MuonDetectorFactory001 ****************************
+MuGM:MuonFactory                                     INFO  *** The Muon Chamber Geometry Tree is built with 
+MuGM:MuonFactory                                     INFO  *** 1758 child volumes 
+MuGM:MuonFactory                                     INFO  *** 1839 independent elements and 
+MuGM:MuonFactory                                     INFO  *** 11473 elements cloned or shared 
+MuGM:MuonFactory                                     INFO  *** 234 kinds of stations
+MuGM:MuonFactory                                     INFO  *** 1758 stations with alignable transforms
+MuGM:MuonFactory                                     INFO  *** 148 stations are described as Assemblies
+MuGM:MuonFactory                                     INFO  *** 1758 MuonStations 
+MuGM:MuonFactory                                     INFO  *** 	 2324 MDT Readout Elements 	 1186 MDT Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 32 CSC Readout Elements 	 32 CSC Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 1122 RPC Readout Elements 	 600 RPC Detector Elements 
+MuGM:MuonFactory                                     INFO  *** 	 1578 TGC Readout Elements 	 1578 TGC Detector Elements 
+MuGM:MuonFactory                                     INFO  ********************************************************************
+MuGM:MuonFactory                                     INFO  *** Inert Material built according to DB switches and config. ****** 
+MuGM:MuonFactory                                     INFO  *** The Muon Geometry Tree has 1758 child vol.s in total ********
+MuGM:MuonFactory                                     INFO  ********************************************************************
 
-MGM::MuonDetect...   INFO Init A/B Line Containers - done - size is respectively 1758/0
-MGM::MuonDetect...   INFO Init of CSC I-Lines will be done via Conditions DB
-MGM::MuonDetect...   INFO Init I-Line Container - done - size is respectively 128
-MGM::MuonDetect...   INFO I-Line for CSC wire layers loaded (Csc Internal Alignment)
-MGM::MuonDetect...   INFO According to configuration they WILL be used 
-MGM::MuonDetect...   INFO Filling cache
-MGM::MuonDetect...   INFO temporary CSC I-line container with size = 128
-MGM::MuonDetect...   INFO # of CSC I-lines read from the ILineMapContainer in StoreGate is 128
-MGM::MuonDetect...   INFO # of deltaTransforms updated according to A-lines             is 128
-MGM::MuonDetect...   INFO # of entries in the CSC I-lines historical container          is 128
-MGM::MuonDetect...   INFO temporary As-Built container with size = 628
-MGM::MuonDetect...   INFO # of MDT As-Built read from the MdtAsBuiltMapContainer in StoreGate is 628
-MGM::MuonDetect...   INFO # of deltaTransforms updated according to As-Built                  is 628
-MGM::MuonDetect...   INFO # of entries in the MdtAsBuilt historical container                 is 628
-MGM::MuonDetect...   INFO temporary A-line container with size = 2694
-MGM::MuonDetect...   INFO # of A-lines read from the ALineMapContainer in StoreGate is 2694
-MGM::MuonDetect...   INFO # of deltaTransforms updated according to A-lines         is 2694
-MGM::MuonDetect...   INFO # of entries in the A-lines historical container          is 2814
-MGM::MuonDetect...   INFO In updateDeformations()
-MGM::MuonDetect...   INFO temporary B-line container with size = 1206
-MGM::MuonDetect...   INFO # of B-lines read from the ALineMapContainer in StoreGate   is 1206
-MGM::MuonDetect...   INFO # of deform-Transforms updated according to B-lines         is 1174
-MGM::MuonDetect...   INFO # of entries in the B-lines historical container            is 1174
-MuonDetectorCon...   INFO recorded new MuonDetectorManager with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
-RpcCablingCondAlg    INFO maps configuration have been parsed
-RpcCablingCondAlg    INFO recorded new RpcCablingCondData with range {[315000,l:0] - [999999,l:0]}
-MuonMDT_CablingAlg   INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/CABLING/MEZZANINE_SCHEMA' )  readCdoMez->size()= 24
-MuonMDT_CablingAlg   INFO Range of input is {[0,l:0] - [INVALID]}
-MuonMDT_CablingAlg   INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/CABLING/MAP_SCHEMA' )  readCdoMap->size()= 2312
-MuonMDT_CablingAlg   INFO Range of input is {[327264,l:4294640031] - [327265,l:4294640030]}
-MuonMDT_CablingAlg   INFO recorded new MuonMDT_CablingMap with range {[327264,t:0,l:4294640031] - [327265,l:4294640030]} into Conditions Store
-AtlasFieldMapCo...   INFO updateFieldMap: Update map from conditions
-AtlasFieldMapCo...   INFO updateFieldMap: Update map from conditions: Range of input/output is {[0,l:0] - [INVALID]}
-AtlasFieldMapCo...   INFO updateFieldMap: reading magnetic field map filenames from COOL
-AtlasFieldMapCo...   INFO updateFieldMap: found map of type GlobalMap with soleCur=7730 toroCur=20400 (path file:MagneticFieldMaps/bfieldmap_7730_20400_14m.root)
-AtlasFieldMapCo...   INFO updateFieldMap: found map of type SolenoidMap with soleCur=7730 toroCur=0 (path file:MagneticFieldMaps/bfieldmap_7730_0_14m.root)
-AtlasFieldMapCo...   INFO updateFieldMap: found map of type ToroidMap with soleCur=0 toroCur=20400 (path file:MagneticFieldMaps/bfieldmap_0_20400_14m.root)
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Range of input currents is {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Attempt 1 at reading currents from DCS (using channel name)
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_Current , 1 , 7729.99
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_SCurrent , 2 , 7730
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_Current , 3 , 20399.9
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_SCurrent , 4 , 20397.7
-AtlasFieldMapCo...   INFO checkCurrentFromConditions: Currents read from DCS - solenoid 7729.99 toroid 20399.9
-AtlasFieldMapCo...   INFO updateFieldMap: currents are OK, will use nominal maps
-AtlasFieldMapCo...   INFO updateFieldMap: tagInfoH  ( 'TagInfo' , 'DetectorStore+ProcessingTags' )  is valid. 
-AtlasFieldMapCo...   INFO updateFieldMap: DID NOT reset currents from TagInfo
-AtlasFieldMapCo...   INFO updateFieldMap: Set map currents from FieldSvc: solenoid/toroid 7730,20400
-AtlasFieldMapCo...   INFO updateFieldMap: Use map file MagneticFieldMaps/bfieldmap_7730_20400_14m.root
-AtlasFieldMapCo...   INFO updateFieldMap: Initialized the field map from /cvmfs/atlas.cern.ch/repo/sw/database/GroupData/MagneticFieldMaps/bfieldmap_7730_20400_14m.root
-AtlasFieldMapCo...   INFO execute: solenoid zone id  7000
-AtlasFieldMapCo...   INFO execute: recorded AtlasFieldMapCondObj with EventRange {[0,l:0] - [INVALID]}
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Range of input/output is {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Attempt 1 at reading currents from DCS (using channel name)
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_Current , 1 , 7729.99
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_SCurrent , 2 , 7730
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_Current , 3 , 20399.9
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_SCurrent , 4 , 20397.7
-AtlasFieldCache...   INFO UpdateCurrentFromConditions: Currents read from DCS - solenoid 7729.99 toroid 20399.9
-AtlasFieldCache...   INFO scaleField: Solenoid field scale factor 1. Desired current and map current: 7729.99,7730
-AtlasFieldCache...   INFO scaleField: Toroid field scale factor 1. Desired current and map current: 20399.9,20400
-AtlasFieldCache...   INFO execute: initialized AtlasFieldCacheCondObj and cache with SFs - sol/tor 1/1, EventRange {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
-AtlasFieldCache...   INFO execute: solenoid zone id  7000
-RegSelCondAlg_RPC    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_RPC'
-RegSelCondAlg_TGC    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_TGC'
-MdtCalibDbAlg        INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/RTBLOB' )  readCdoRt->size()= 1186
-MdtCalibDbAlg        INFO Range of input is {[327265,l:0] - [327342,l:0]}
-MdtCalibDbAlg        INFO MdtCalibDbAlg::loadRt Read 1188RTs from COOL
-MdtCalibDbAlg        INFO recorded new MdtRtRelationCollection with range {[327265,l:0] - [327342,l:0]} into Conditions Store
-MdtCalibDbAlg        INFO recorded new MdtCorFuncSetCollection with range {[327265,l:0] - [327342,l:0]} into Conditions Store
-MdtCalibDbAlg        INFO Ignoring nonexistant station in calibration DB: MuonSpectrometer BML -6 stationPhi 7 MDT multiLayer 1 tubeLayer 1 tube 1
-MdtCalibDbAlg        INFO Ignoring nonexistant station in calibration DB: MuonSpectrometer BML stationEta 6 stationPhi 7 MDT multiLayer 1 tubeLayer 1 tube 1
-MdtCalibDbAlg        INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/T0BLOB' )  readCdoTube->size()= 1186
-MdtCalibDbAlg        INFO Range of input is {[319000,l:0] - [INVALID]}
-MdtCalibDbAlg        INFO recorded new MdtTubeCalibContainerCollection with range {[319000,l:0] - [INVALID]} into Conditions Store
-RegSelCondAlg_MDT    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_MDT'
-RegSelCondAlg_CSC    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_CSC'
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186525031, run #327265 1 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186524665, run #327265 1 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186524665, run #327265 2 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186542447, run #327265 2 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186542447, run #327265 3 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186543405, run #327265 3 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186543405, run #327265 4 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186548387, run #327265 4 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186548387, run #327265 5 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186515186, run #327265 5 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186515186, run #327265 6 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186556019, run #327265 6 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186556019, run #327265 7 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186542866, run #327265 7 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186542866, run #327265 8 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186537901, run #327265 8 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186537901, run #327265 9 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186517811, run #327265 9 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186517811, run #327265 10 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186534221, run #327265 10 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186534221, run #327265 11 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186540986, run #327265 11 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186540986, run #327265 12 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186535104, run #327265 12 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186535104, run #327265 13 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186539903, run #327265 13 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186539903, run #327265 14 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186552713, run #327265 14 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186552713, run #327265 15 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186524730, run #327265 15 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186524730, run #327265 16 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186547632, run #327265 16 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186547632, run #327265 17 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186555621, run #327265 17 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186555621, run #327265 18 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186568452, run #327265 18 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186568452, run #327265 19 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #186580451, run #327265 19 events processed so far  <<<===
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #186580451, run #327265 20 events processed so far  <<<===
-Domain[ROOT_All]     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
-ApplicationMgr       INFO Application Manager Stopped successfully
-IncidentProcAlg1     INFO Finalize
-CondInputLoader      INFO Finalizing CondInputLoader...
-IncidentProcAlg2     INFO Finalize
-IOVDbFolder          INFO Folder /CSC/FTHOLD (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/322656 ((     0.03 ))s
-IOVDbFolder          INFO Folder /CSC/NOISE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/350062 ((     0.02 ))s
-IOVDbFolder          INFO Folder /CSC/PED (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/411187 ((     0.03 ))s
-IOVDbFolder          INFO Folder /CSC/PSLOPE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/353376 ((     0.02 ))s
-IOVDbFolder          INFO Folder /CSC/RMS (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/411395 ((     0.03 ))s
-IOVDbFolder          INFO Folder /CSC/STAT (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/230496 ((     0.02 ))s
-IOVDbFolder          INFO Folder /CSC/T0BASE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/314380 ((     0.02 ))s
-IOVDbFolder          INFO Folder /CSC/T0PHASE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/3136 ((     0.02 ))s
-IOVDbFolder          INFO Folder /EXT/DCS/MAGNETS/SENSORDATA (AttrListColl) db-read 1/1 objs/chan/bytes 4/4/20 ((     0.02 ))s
-IOVDbFolder          INFO Folder /GLOBAL/BField/Maps (AttrListColl) db-read 1/1 objs/chan/bytes 3/3/202 ((     0.05 ))s
-IOVDbFolder          INFO Folder /MDT/CABLING/MAP_SCHEMA (AttrListColl) db-read 1/1 objs/chan/bytes 2312/2437/216520 ((     0.13 ))s
-IOVDbFolder          INFO Folder /MDT/CABLING/MEZZANINE_SCHEMA (AttrListColl) db-read 1/1 objs/chan/bytes 24/24/288 ((     0.01 ))s
-IOVDbFolder          INFO Folder /MDT/RTBLOB (AttrListColl) db-read 1/1 objs/chan/bytes 2372/1186/2251209 ((     0.12 ))s
-IOVDbFolder          INFO Folder /MDT/T0BLOB (AttrListColl) db-read 1/1 objs/chan/bytes 1186/1186/1374284 ((     0.06 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/CSC/ILINES (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/10814 ((     0.02 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/MDT/ASBUILTPARAMS (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/128992 ((     0.02 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/MDT/BARREL (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/140293 ((     0.02 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/MDT/ENDCAP/SIDEA (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/65494 ((     0.02 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/MDT/ENDCAP/SIDEC (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/65497 ((     0.04 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/TGC/SIDEA (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/165643 ((     0.03 ))s
-IOVDbFolder          INFO Folder /MUONALIGN/TGC/SIDEC (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/165643 ((     0.03 ))s
-IOVDbFolder          INFO Folder /RPC/CABLING/MAP_SCHEMA (AttrListColl) db-read 1/2 objs/chan/bytes 1/1/222235 ((     0.03 ))s
-IOVDbFolder          INFO Folder /RPC/CABLING/MAP_SCHEMA_CORR (AttrListColl) db-read 1/2 objs/chan/bytes 1/1/29402 ((     0.02 ))s
-IOVDbFolder          INFO Folder /RPC/DCS/DeadRopanels (AttrListColl) db-read 1/1 objs/chan/bytes 32/48/6200 ((     0.01 ))s
-IOVDbFolder          INFO Folder /RPC/DCS/OffRopanels (AttrListColl) db-read 1/1 objs/chan/bytes 4/48/16 ((     0.01 ))s
-IOVDbFolder          INFO Folder /RPC/DQMF/ELEMENT_STATUS (AttrListColl) db-read 1/1 objs/chan/bytes 8320/8320/6180700 ((     0.15 ))s
-IOVDbFolder          INFO Folder /RPC/TRIGGER/CM_THR_ETA (AttrListColl) db-read 1/2 objs/chan/bytes 1613/1613/7562651 ((     0.09 ))s
-IOVDbFolder          INFO Folder /RPC/TRIGGER/CM_THR_PHI (AttrListColl) db-read 1/2 objs/chan/bytes 1612/1612/8096306 ((     0.06 ))s
-IOVDbFolder          INFO Folder /TGC/CABLING/MAP_SCHEMA (AttrListColl) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
-IOVDbSvc             INFO  bytes in ((      1.13 ))s
-IOVDbSvc             INFO Connection sqlite://;schema=mycool.db;dbname=CONDBR2 : nConnect: 0 nFolders: 0 ReadTime: ((     0.00 ))s
-IOVDbSvc             INFO Connection COOLOFL_MUONALIGN/CONDBR2 : nConnect: 2 nFolders: 7 ReadTime: ((     0.17 ))s
-IOVDbSvc             INFO Connection COOLONL_RPC/CONDBR2 : nConnect: 2 nFolders: 4 ReadTime: ((     0.21 ))s
-IOVDbSvc             INFO Connection COOLONL_TGC/CONDBR2 : nConnect: 1 nFolders: 1 ReadTime: ((     0.00 ))s
-IOVDbSvc             INFO Connection COOLONL_MDT/CONDBR2 : nConnect: 2 nFolders: 2 ReadTime: ((     0.15 ))s
-IOVDbSvc             INFO Connection COOLONL_GLOBAL/CONDBR2 : nConnect: 2 nFolders: 1 ReadTime: ((     0.05 ))s
-IOVDbSvc             INFO Connection COOLOFL_DCS/CONDBR2 : nConnect: 2 nFolders: 3 ReadTime: ((     0.04 ))s
-IOVDbSvc             INFO Connection COOLOFL_RPC/CONDBR2 : nConnect: 2 nFolders: 1 ReadTime: ((     0.15 ))s
-IOVDbSvc             INFO Connection COOLOFL_MDT/CONDBR2 : nConnect: 2 nFolders: 2 ReadTime: ((     0.18 ))s
-IOVDbSvc             INFO Connection COOLOFL_CSC/CONDBR2 : nConnect: 2 nFolders: 8 ReadTime: ((     0.19 ))s
-ToolSvc              INFO Removing all tools created by ToolSvc
-TgcRdoToTgcPrep...   INFO finalize(): input RDOs->output PRDs [Hit: 6807->6807, Tracklet: 28->28, TrackletEIFI: 692->692, HiPt: 4031->4031, SL: 3->3]
-MdtRawDataProvi...   INFO Fraction of fills that use the cache = 0
-ToolSvc.TGCCabl...   INFO finalize
-MuonTGC_Cabling...   INFO finalize
-TgcRawDataProvi...   INFO Fraction of fills that use the cache = 0
-RpcROD_Decoder:...   INFO  ============ FINAL RPC DATA FORMAT STAT. =========== 
-RpcROD_Decoder:...   INFO  RX Header Errors.............0
-RpcROD_Decoder:...   INFO  RX SubHeader Errors..........0
-RpcROD_Decoder:...   INFO  PAD Header Errors............0
-RpcROD_Decoder:...   INFO  PAD/SL SubHeader Errors......0
-RpcROD_Decoder:...   INFO  CM Header Errors.............0
-RpcROD_Decoder:...   INFO  CM SubHeader Errors..........0
-RpcROD_Decoder:...   INFO  CM Footer Errors.............0
-RpcROD_Decoder:...   INFO  PAD PreFooter Errors.........0
-RpcROD_Decoder:...   INFO  PAD Footer Errors............0
-RpcROD_Decoder:...   INFO  SL Header Errors.............0
-RpcROD_Decoder:...   INFO  SL Footer Errors.............0
-RpcROD_Decoder:...   INFO  RX Footer Errors.............0
-RpcROD_Decoder:...   INFO  CRC8 check Failures..........0
-RpcROD_Decoder:...   INFO  ==================================================== 
-ToolSvc.ByteStr...   INFO in finalize()
-IdDictDetDescrCnv    INFO in finalize
-*****Chrono*****     INFO ****************************************************************************************************
-*****Chrono*****     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
-*****Chrono*****     INFO ****************************************************************************************************
-cObj_ALL             INFO Time User   : Tot=    0 [us] Ave/Min/Max=       0(+-       0)/       0/       0 [us] #= 32
-ChronoStatSvc        INFO Time User   : Tot= 14.9  [s]  #=  1
-*****Chrono*****     INFO ****************************************************************************************************
-ChronoStatSvc.f...   INFO  Service finalized successfully 
-ApplicationMgr       INFO Application Manager Finalized successfully
-ApplicationMgr       INFO Application Manager Terminated successfully
+MGM::MuonDetectorManager                             INFO Init A/B Line Containers - done - size is respectively 1758/0
+MGM::MuonDetectorManager                             INFO Init of CSC I-Lines will be done via Conditions DB
+MGM::MuonDetectorManager                             INFO Init I-Line Container - done - size is respectively 128
+MGM::MuonDetectorManager                             INFO I-Line for CSC wire layers loaded (Csc Internal Alignment)
+MGM::MuonDetectorManager                             INFO According to configuration they WILL be used 
+MGM::MuonDetectorManager                             INFO Filling cache
+MGM::MuonDetectorManager                             INFO temporary CSC I-line container with size = 128
+MGM::MuonDetectorManager                             INFO # of CSC I-lines read from the ILineMapContainer in StoreGate is 128
+MGM::MuonDetectorManager                             INFO # of deltaTransforms updated according to A-lines             is 128
+MGM::MuonDetectorManager                             INFO # of entries in the CSC I-lines historical container          is 128
+MGM::MuonDetectorManager                             INFO temporary As-Built container with size = 628
+MGM::MuonDetectorManager                             INFO # of MDT As-Built read from the MdtAsBuiltMapContainer in StoreGate is 628
+MGM::MuonDetectorManager                             INFO # of deltaTransforms updated according to As-Built                  is 628
+MGM::MuonDetectorManager                             INFO # of entries in the MdtAsBuilt historical container                 is 628
+MGM::MuonDetectorManager                             INFO temporary A-line container with size = 2694
+MGM::MuonDetectorManager                             INFO # of A-lines read from the ALineMapContainer in StoreGate is 2694
+MGM::MuonDetectorManager                             INFO # of deltaTransforms updated according to A-lines         is 2694
+MGM::MuonDetectorManager                             INFO # of entries in the A-lines historical container          is 2814
+MGM::MuonDetectorManager                             INFO In updateDeformations()
+MGM::MuonDetectorManager                             INFO temporary B-line container with size = 1206
+MGM::MuonDetectorManager                             INFO # of B-lines read from the ALineMapContainer in StoreGate   is 1206
+MGM::MuonDetectorManager                             INFO # of deform-Transforms updated according to B-lines         is 1174
+MGM::MuonDetectorManager                             INFO # of entries in the B-lines historical container            is 1174
+MuonDetectorCondAlg                                  INFO recorded new MuonDetectorManager with range {[0,0,t:1497892260,l:0] - [t:1497898380]} into Conditions Store
+RpcCablingCondAlg                                    INFO maps configuration have been parsed
+RpcCablingCondAlg                                    INFO recorded new RpcCablingCondData with range {[315000,l:0] - [999999,l:0]}
+MuonMDT_CablingAlg                                   INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/CABLING/MEZZANINE_SCHEMA' )  readCdoMez->size()= 24
+MuonMDT_CablingAlg                                   INFO Range of input is {[0,l:0] - [INVALID]}
+MuonMDT_CablingAlg                                   INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/CABLING/MAP_SCHEMA' )  readCdoMap->size()= 2312
+MuonMDT_CablingAlg                                   INFO Range of input is {[327264,l:4294640031] - [327265,l:4294640030]}
+MuonMDT_CablingAlg                                   INFO recorded new MuonMDT_CablingMap with range {[327264,t:0,l:4294640031] - [327265,l:4294640030]} into Conditions Store
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Update map from conditions
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Update map from conditions: Range of input/output is {[0,l:0] - [INVALID]}
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: reading magnetic field map filenames from COOL
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: found map of type GlobalMap with soleCur=7730 toroCur=20400 (path file:MagneticFieldMaps/bfieldmap_7730_20400_14m.root)
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: found map of type SolenoidMap with soleCur=7730 toroCur=0 (path file:MagneticFieldMaps/bfieldmap_7730_0_14m.root)
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: found map of type ToroidMap with soleCur=0 toroCur=20400 (path file:MagneticFieldMaps/bfieldmap_0_20400_14m.root)
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Range of input currents is {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Attempt 1 at reading currents from DCS (using channel name)
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_Current , 1 , 7729.99
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_SCurrent , 2 , 7730
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_Current , 3 , 20399.9
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_SCurrent , 4 , 20397.7
+AtlasFieldMapCondAlg                                 INFO checkCurrentFromConditions: Currents read from DCS - solenoid 7729.99 toroid 20399.9
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: currents are OK, will use nominal maps
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: tagInfoH  ( 'TagInfo' , 'DetectorStore+ProcessingTags' )  is valid. 
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: DID NOT reset currents from TagInfo
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Set map currents from FieldSvc: solenoid/toroid 7730,20400
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Use map file MagneticFieldMaps/bfieldmap_7730_20400_14m.root
+AtlasFieldMapCondAlg                                 INFO updateFieldMap: Initialized the field map from /cvmfs/atlas.cern.ch/repo/sw/database/GroupData/MagneticFieldMaps/bfieldmap_7730_20400_14m.root
+AtlasFieldMapCondAlg                                 INFO execute: solenoid zone id  7000
+AtlasFieldMapCondAlg                                 INFO execute: recorded AtlasFieldMapCondObj with EventRange {[0,l:0] - [INVALID]}
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Range of input/output is {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Attempt 1 at reading currents from DCS (using channel name)
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_Current , 1 , 7729.99
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] CentralSol_SCurrent , 2 , 7730
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_Current , 3 , 20399.9
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Trying to read from DCS: [channel name, index, value] Toroids_SCurrent , 4 , 20397.7
+AtlasFieldCacheCondAlg                               INFO UpdateCurrentFromConditions: Currents read from DCS - solenoid 7729.99 toroid 20399.9
+AtlasFieldCacheCondAlg                               INFO scaleField: Solenoid field scale factor 1. Desired current and map current: 7729.99,7730
+AtlasFieldCacheCondAlg                               INFO scaleField: Toroid field scale factor 1. Desired current and map current: 20399.9,20400
+AtlasFieldCacheCondAlg                               INFO execute: initialized AtlasFieldCacheCondObj and cache with SFs - sol/tor 1/1, EventRange {[0,0,t:1497895317.371000000] - [t:1497898549.609000000]}
+AtlasFieldCacheCondAlg                               INFO execute: solenoid zone id  7000
+RegSelCondAlg_RPC                                    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_RPC'
+RegSelCondAlg_TGC                                    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_TGC'
+MdtCalibDbAlg                                        INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/RTBLOB' )  readCdoRt->size()= 1186
+MdtCalibDbAlg                                        INFO Range of input is {[327265,l:0] - [327342,l:0]}
+MdtCalibDbAlg                                        INFO MdtCalibDbAlg::loadRt Read 1188RTs from COOL
+MdtCalibDbAlg                                        INFO recorded new MdtRtRelationCollection with range {[327265,l:0] - [327342,l:0]} into Conditions Store
+MdtCalibDbAlg                                        INFO recorded new MdtCorFuncSetCollection with range {[327265,l:0] - [327342,l:0]} into Conditions Store
+MdtCalibDbAlg                                        INFO Ignoring nonexistant station in calibration DB: MuonSpectrometer BML -6 stationPhi 7 MDT multiLayer 1 tubeLayer 1 tube 1
+MdtCalibDbAlg                                        INFO Ignoring nonexistant station in calibration DB: MuonSpectrometer BML stationEta 6 stationPhi 7 MDT multiLayer 1 tubeLayer 1 tube 1
+MdtCalibDbAlg                                        INFO Size of CondAttrListCollection  ( 'CondAttrListCollection' , 'ConditionStore+/MDT/T0BLOB' )  readCdoTube->size()= 1186
+MdtCalibDbAlg                                        INFO Range of input is {[319000,l:0] - [INVALID]}
+MdtCalibDbAlg                                        INFO recorded new MdtTubeCalibContainerCollection with range {[319000,l:0] - [INVALID]} into Conditions Store
+RegSelCondAlg_MDT                                    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_MDT'
+RegSelCondAlg_CSC                                    INFO RegSelCondAlg LUT recorded: 'ConditionStore+RegSelLUTCondData_CSC'
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186525031, run #327265 1 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186524665, run #327265 1 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186524665, run #327265 2 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186542447, run #327265 2 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186542447, run #327265 3 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186543405, run #327265 3 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186543405, run #327265 4 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186548387, run #327265 4 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186548387, run #327265 5 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186515186, run #327265 5 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186515186, run #327265 6 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186556019, run #327265 6 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186556019, run #327265 7 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186542866, run #327265 7 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186542866, run #327265 8 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186537901, run #327265 8 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186537901, run #327265 9 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186517811, run #327265 9 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186517811, run #327265 10 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186534221, run #327265 10 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186534221, run #327265 11 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186540986, run #327265 11 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186540986, run #327265 12 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186535104, run #327265 12 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186535104, run #327265 13 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186539903, run #327265 13 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186539903, run #327265 14 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186552713, run #327265 14 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186552713, run #327265 15 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186524730, run #327265 15 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186524730, run #327265 16 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186547632, run #327265 16 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186547632, run #327265 17 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186555621, run #327265 17 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186555621, run #327265 18 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186568452, run #327265 18 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186568452, run #327265 19 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #186580451, run #327265 19 events processed so far  <<<===
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #186580451, run #327265 20 events processed so far  <<<===
+Domain[ROOT_All]                                     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
+ApplicationMgr                                       INFO Application Manager Stopped successfully
+IncidentProcAlg1                                     INFO Finalize
+CondInputLoader                                      INFO Finalizing CondInputLoader...
+IncidentProcAlg2                                     INFO Finalize
+IdDictDetDescrCnv                                    INFO in finalize
+IOVDbFolder                                          INFO Folder /CSC/FTHOLD (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/322656 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /CSC/NOISE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/350062 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /CSC/PED (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/411187 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /CSC/PSLOPE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/353376 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /CSC/RMS (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/411395 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /CSC/STAT (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/230496 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /CSC/T0BASE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/314380 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /CSC/T0PHASE (AttrListColl) db-read 1/1 objs/chan/bytes 32/32/3136 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /EXT/DCS/MAGNETS/SENSORDATA (AttrListColl) db-read 1/1 objs/chan/bytes 4/4/20 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /GLOBAL/BField/Maps (AttrListColl) db-read 1/1 objs/chan/bytes 3/3/202 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /MDT/CABLING/MAP_SCHEMA (AttrListColl) db-read 1/1 objs/chan/bytes 2312/2437/216520 ((     0.27 ))s
+IOVDbFolder                                          INFO Folder /MDT/CABLING/MEZZANINE_SCHEMA (AttrListColl) db-read 1/1 objs/chan/bytes 24/24/288 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /MDT/RTBLOB (AttrListColl) db-read 1/1 objs/chan/bytes 2372/1186/2251209 ((     0.23 ))s
+IOVDbFolder                                          INFO Folder /MDT/T0BLOB (AttrListColl) db-read 1/1 objs/chan/bytes 1186/1186/1374284 ((     0.12 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/CSC/ILINES (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/10814 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/MDT/ASBUILTPARAMS (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/128992 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/MDT/BARREL (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/140293 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/MDT/ENDCAP/SIDEA (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/65494 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/MDT/ENDCAP/SIDEC (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/65497 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/TGC/SIDEA (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/165643 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /MUONALIGN/TGC/SIDEC (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/165643 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /RPC/CABLING/MAP_SCHEMA (AttrListColl) db-read 1/2 objs/chan/bytes 1/1/222235 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /RPC/CABLING/MAP_SCHEMA_CORR (AttrListColl) db-read 1/2 objs/chan/bytes 1/1/29402 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /RPC/DCS/DeadRopanels (AttrListColl) db-read 1/1 objs/chan/bytes 32/48/6200 ((     0.00 ))s
+IOVDbFolder                                          INFO Folder /RPC/DCS/OffRopanels (AttrListColl) db-read 1/1 objs/chan/bytes 4/48/16 ((     0.00 ))s
+IOVDbFolder                                          INFO Folder /RPC/DQMF/ELEMENT_STATUS (AttrListColl) db-read 1/1 objs/chan/bytes 8320/8320/6180700 ((     0.45 ))s
+IOVDbFolder                                          INFO Folder /RPC/TRIGGER/CM_THR_ETA (AttrListColl) db-read 1/2 objs/chan/bytes 1613/1613/7562651 ((     0.21 ))s
+IOVDbFolder                                          INFO Folder /RPC/TRIGGER/CM_THR_PHI (AttrListColl) db-read 1/2 objs/chan/bytes 1612/1612/8096306 ((     0.18 ))s
+IOVDbFolder                                          INFO Folder /TGC/CABLING/MAP_SCHEMA (AttrListColl) db-read 0/0 objs/chan/bytes 0/1/0 ((     0.00 ))s
+IOVDbSvc                                             INFO  bytes in ((      2.03 ))s
+IOVDbSvc                                             INFO Connection sqlite://;schema=mycool.db;dbname=CONDBR2 : nConnect: 0 nFolders: 0 ReadTime: ((     0.00 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_MUONALIGN/CONDBR2 : nConnect: 2 nFolders: 7 ReadTime: ((     0.17 ))s
+IOVDbSvc                                             INFO Connection COOLONL_RPC/CONDBR2 : nConnect: 2 nFolders: 4 ReadTime: ((     0.45 ))s
+IOVDbSvc                                             INFO Connection COOLONL_TGC/CONDBR2 : nConnect: 1 nFolders: 1 ReadTime: ((     0.00 ))s
+IOVDbSvc                                             INFO Connection COOLONL_MDT/CONDBR2 : nConnect: 2 nFolders: 2 ReadTime: ((     0.30 ))s
+IOVDbSvc                                             INFO Connection COOLONL_GLOBAL/CONDBR2 : nConnect: 2 nFolders: 1 ReadTime: ((     0.03 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_DCS/CONDBR2 : nConnect: 2 nFolders: 3 ReadTime: ((     0.05 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_RPC/CONDBR2 : nConnect: 2 nFolders: 1 ReadTime: ((     0.45 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_MDT/CONDBR2 : nConnect: 2 nFolders: 2 ReadTime: ((     0.35 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_CSC/CONDBR2 : nConnect: 2 nFolders: 8 ReadTime: ((     0.23 ))s
+ToolSvc                                              INFO Removing all tools created by ToolSvc
+TgcRdoToTgcPrepData.TgcRdoToTgcPrepDataTool          INFO finalize(): input RDOs->output PRDs [Hit: 6807->6807, Tracklet: 28->28, TrackletEIFI: 692->692, HiPt: 4031->4031, SL: 3->3]
+MdtRawDataProvider.MDT_RawDataPro...MdtROD_Decoder   INFO Fraction of fills that use the cache = 0
+ToolSvc.TGCCablingDbTool                             INFO finalize
+MuonTGC_CablingSvc.TGCCablingDbTool                  INFO finalize
+TgcRawDataProvider.TGC_RawDataPro...TgcROD_Decoder   INFO Fraction of fills that use the cache = 0
+RpcROD_Decoder::printcheckformat                     INFO  ============ FINAL RPC DATA FORMAT STAT. =========== 
+RpcROD_Decoder::printcheckformat                     INFO  RX Header Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  RX SubHeader Errors..........0
+RpcROD_Decoder::printcheckformat                     INFO  PAD Header Errors............0
+RpcROD_Decoder::printcheckformat                     INFO  PAD/SL SubHeader Errors......0
+RpcROD_Decoder::printcheckformat                     INFO  CM Header Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  CM SubHeader Errors..........0
+RpcROD_Decoder::printcheckformat                     INFO  CM Footer Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  PAD PreFooter Errors.........0
+RpcROD_Decoder::printcheckformat                     INFO  PAD Footer Errors............0
+RpcROD_Decoder::printcheckformat                     INFO  SL Header Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  SL Footer Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  RX Footer Errors.............0
+RpcROD_Decoder::printcheckformat                     INFO  CRC8 check Failures..........0
+RpcROD_Decoder::printcheckformat                     INFO  ==================================================== 
+ToolSvc.ByteStreamMetadataTool                       INFO in finalize()
+*****Chrono*****                                     INFO ****************************************************************************************************
+*****Chrono*****                                     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
+*****Chrono*****                                     INFO ****************************************************************************************************
+cObj_ALL                                             INFO Time User   : Tot=    0 [us] Ave/Min/Max=       0(+-       0)/       0/       0 [us] #= 32
+ChronoStatSvc                                        INFO Time User   : Tot= 30.4  [s]  #=  1
+*****Chrono*****                                     INFO ****************************************************************************************************
+ChronoStatSvc.finalize()                             INFO  Service finalized successfully 
+ApplicationMgr                                       INFO Application Manager Finalized successfully
+ApplicationMgr                                       INFO Application Manager Terminated successfully
diff --git a/MuonSpectrometer/MuonDigitization/RPC_Digitization/CMakeLists.txt b/MuonSpectrometer/MuonDigitization/RPC_Digitization/CMakeLists.txt
index 87afd7ad28c867be687fd3edbf504f0b7b021bbf..4f40278131ba8b5c6bcf31eb3a2ecb27005a720c 100755
--- a/MuonSpectrometer/MuonDigitization/RPC_Digitization/CMakeLists.txt
+++ b/MuonSpectrometer/MuonDigitization/RPC_Digitization/CMakeLists.txt
@@ -16,7 +16,7 @@ atlas_add_component( RPC_Digitization
                      src/*.cxx
                      src/components/*.cxx
                      INCLUDE_DIRS ${AIDA_INCLUDE_DIRS} ${Boost_INCLUDE_DIRS} ${CORAL_INCLUDE_DIRS} ${CLHEP_INCLUDE_DIRS} 
-                     LINK_LIBRARIES ${Boost_LIBRARIES} ${CORAL_LIBRARIES} ${CLHEP_LIBRARIES} AtlasHepMCLib AthenaBaseComps PileUpToolsLib xAODEventInfo GaudiKernel MuonSimData MuonSimEvent HitManagement AthenaKernel EventInfo GeneratorObjects MuonCondInterface MuonCondData MuonReadoutGeometry MuonDigitContainer MuonIdHelpersLib PathResolver GeometryDBSvcLib EventInfoMgtLib )
+                     LINK_LIBRARIES ${Boost_LIBRARIES} ${CORAL_LIBRARIES} ${CLHEP_LIBRARIES} AtlasHepMCLib AthenaBaseComps PileUpToolsLib xAODEventInfo GaudiKernel MuonSimData MuonSimEvent HitManagement AthenaKernel GeneratorObjects MuonCondInterface MuonCondData MuonReadoutGeometry MuonDigitContainer MuonIdHelpersLib PathResolver GeometryDBSvcLib EventInfoMgtLib )
 
 # Install files from the package:
 atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
diff --git a/MuonSpectrometer/MuonDigitization/RPC_Digitization/src/RpcDigitizationTool.cxx b/MuonSpectrometer/MuonDigitization/RPC_Digitization/src/RpcDigitizationTool.cxx
index fbf744756cb06b318052e63fbc7a09c75da4c3a8..d335e4450cda2c20663b52c63f4561b5124fb9fe 100644
--- a/MuonSpectrometer/MuonDigitization/RPC_Digitization/src/RpcDigitizationTool.cxx
+++ b/MuonSpectrometer/MuonDigitization/RPC_Digitization/src/RpcDigitizationTool.cxx
@@ -44,7 +44,6 @@
 //Core includes
 #include "PathResolver/PathResolver.h"
 #include "AIDA/IHistogram1D.h"
-#include "EventInfo/TagInfo.h"
 #include "EventInfoMgt/ITagInfoMgr.h"
 
 #include <string>
diff --git a/MuonSpectrometer/MuonIdHelpersAlgs/MuonIdHelpersAlgs/ATLAS_CHECK_THREAD_SAFETY b/MuonSpectrometer/MuonIdHelpersAlgs/MuonIdHelpersAlgs/ATLAS_CHECK_THREAD_SAFETY
old mode 100755
new mode 100644
diff --git a/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTGRecTools/share/MuonHolesSearch_jobOptions.py b/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTGRecTools/share/MuonHolesSearch_jobOptions.py
index 561b2a56376a946154517809fc30de134d558fd0..0af5e7ab4c3115c5fed6bf01133c44390c11df06 100644
--- a/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTGRecTools/share/MuonHolesSearch_jobOptions.py
+++ b/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTGRecTools/share/MuonHolesSearch_jobOptions.py
@@ -18,8 +18,7 @@ MuonTrackingGeometrySvc = TrackingGeometrySvc( name ="MuonTrackingGeometrySvc",
                                                TrackingGeometryName = "MuonStandaloneTrackingGeometry",
                                                GeometryBuilder = MuonStandAloneGeometryBuilder,
                                                BuildGeometryFromTagInfo = True ,
-                                               AssignMaterialFromCOOL = False,
-                                               CallbackStringCheck = True )
+                                               AssignMaterialFromCOOL = False)
 
 from AthenaCommon.AppMgr import ServiceMgr as svcMgr
 svcMgr += MuonTrackingGeometrySvc
diff --git a/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTGRecTools/share/MuonTGRec_jobOptions.py b/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTGRecTools/share/MuonTGRec_jobOptions.py
index 535dcad92b49bedb252c5bf6017261e7bb1c3e47..009d381a288ba81a0b2a13b07e7819c26255aba3 100644
--- a/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTGRecTools/share/MuonTGRec_jobOptions.py
+++ b/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTGRecTools/share/MuonTGRec_jobOptions.py
@@ -18,8 +18,7 @@ MuonTrackingGeometrySvc = TrackingGeometrySvc( name ="MuonTrackingGeometrySvc",
                                                TrackingGeometryName = "MuonStandaloneTrackingGeometry",
                                                GeometryBuilder = MuonStandAloneGeometryBuilder,
                                                BuildGeometryFromTagInfo = True ,
-                                               AssignMaterialFromCOOL = False,
-                                               CallbackStringCheck = True )
+                                               AssignMaterialFromCOOL = False)
 
 from AthenaCommon.AppMgr import ServiceMgr as svcMgr
 svcMgr += MuonTrackingGeometrySvc
diff --git a/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTrackSummaryHelperTool/src/MuonTrackSummaryHelperTool.h b/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTrackSummaryHelperTool/src/MuonTrackSummaryHelperTool.h
index 2b072f2b099c76feedcd42283ce1bb8733adbd4d..879a5f3f0feac53b350af49e7dca0d217aadfdc2 100755
--- a/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTrackSummaryHelperTool/src/MuonTrackSummaryHelperTool.h
+++ b/MuonSpectrometer/MuonReconstruction/MuonRecTools/MuonTrackSummaryHelperTool/src/MuonTrackSummaryHelperTool.h
@@ -45,58 +45,38 @@ namespace Muon {
         
     virtual StatusCode initialize() override;
 
-    using IExtendedTrackSummaryHelperTool::analyse;    
-    using IExtendedTrackSummaryHelperTool::updateSharedHitCount;    
+    using IExtendedTrackSummaryHelperTool::analyse;
+    using IExtendedTrackSummaryHelperTool::updateSharedHitCount;
+    using IExtendedTrackSummaryHelperTool::addDetailedTrackSummary;
     virtual void analyse(
-                         const Trk::Track& trk,
-                         const Trk::RIO_OnTrack* rot,
-                         const Trk::TrackStateOnSurface* tsos,
-                         std::vector<int>& information,
-                         std::bitset<Trk::numberOfDetectorTypes>& hitPattern  ) const override;
-
-    virtual void analyse( 
-                         const Trk::Track& trk,
-                         const Trk::CompetingRIOsOnTrack* crot,
-                         const Trk::TrackStateOnSurface* tsos,
-                         std::vector<int>& information,
-                         std::bitset<Trk::numberOfDetectorTypes>& hitPattern ) const override;
+      const Trk::Track& trk,
+      const Trk::RIO_OnTrack* rot,
+      const Trk::TrackStateOnSurface* tsos,
+      std::vector<int>& information,
+      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override final;
 
     virtual void analyse(
-                         const Trk::Track& trk,
-                         const Trk::PRDtoTrackMap *prd_to_track_map,
-                         const Trk::RIO_OnTrack* rot,
-                         const Trk::TrackStateOnSurface* tsos,
-                         std::vector<int>& information,
-                         std::bitset<Trk::numberOfDetectorTypes>& hitPattern  ) const override {
-      (void) prd_to_track_map;
-      analyse(trk,rot,tsos,information,hitPattern);
-    }
-
-    virtual void analyse(
-                         const Trk::Track& trk,
-                         const Trk::PRDtoTrackMap *prd_to_track_map,
-                         const Trk::CompetingRIOsOnTrack* crot,
-                         const Trk::TrackStateOnSurface* tsos,
-                         std::vector<int>& information,
-                         std::bitset<Trk::numberOfDetectorTypes>& hitPattern ) const override {
-      (void) prd_to_track_map;
-      analyse(trk,crot,tsos,information, hitPattern);
-    }
-
-    virtual
-    void searchForHoles(
-                        const Trk::Track& track,
-                        std::vector<int>& information, Trk::ParticleHypothesis hyp) const override;
-
-    virtual
-    void updateSharedHitCount(const Trk::Track&,
-                              const Trk::PRDtoTrackMap *,
-                              Trk::TrackSummary&) const override  {};
-
-    virtual
-    void addDetailedTrackSummary( const Trk::Track& track, Trk::TrackSummary& summary ) const override;
-
-private:
+      const Trk::Track& trk,
+      const Trk::CompetingRIOsOnTrack* crot,
+      const Trk::TrackStateOnSurface* tsos,
+      std::vector<int>& information,
+      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override final;
+
+    virtual void searchForHoles(
+      const Trk::Track& track,
+      std::vector<int>& information,
+      Trk::ParticleHypothesis hyp) const override final;
+
+    virtual void updateSharedHitCount(
+      const Trk::Track&,
+      const Trk::PRDtoTrackMap*,
+      Trk::TrackSummary&) const override final{};
+
+    virtual void addDetailedTrackSummary(
+      const Trk::Track& track,
+      Trk::TrackSummary& summary) const override final;
+
+  private:
 
     const MdtPrepDataCollection* findMdtPrdCollection( const Identifier& chId ) const;
     void calculateRoadHits(Trk::MuonTrackSummary::ChamberHitSummary& chamberHitSummary, const Trk::TrackParameters& pars) const;
diff --git a/MuonSpectrometer/MuonValidation/MuonDQA/MuonDQAMonitoring/share/MuonDQAMonitoring_CommRunsTier0.py b/MuonSpectrometer/MuonValidation/MuonDQA/MuonDQAMonitoring/share/MuonDQAMonitoring_CommRunsTier0.py
deleted file mode 100644
index da8d4924900f3923a78754eb9b834fb5c984f8ac..0000000000000000000000000000000000000000
--- a/MuonSpectrometer/MuonValidation/MuonDQA/MuonDQAMonitoring/share/MuonDQAMonitoring_CommRunsTier0.py
+++ /dev/null
@@ -1,525 +0,0 @@
-#======================================================================
-__doc__ = """This is an example steering jobOption file for RecExCommission run on MuonSystem in Release 14.X.Y.
-It sets default values for muonRecFlags, recFlags, globalflags, DetFlags."""
-#======================================================================
-# Example JobOPt to monitor Muon Technical(Px) and Commissioning(Mx) Runs
-# Last modified Nectarios.Chr. Benekos (UIUC) <Nectarios.Benekos@cern.ch>
-#======================================================================
-# this version is for the setup we will use for M6 Feb run reprocessing!
-#======================================================================
-#####
-### athena.py -c "CollData=True" -b ../share/MuonDQAMonitoring_CommRunsTier0.py > log_collisions | tee
-#####
-include( "RecExCommission/RecExCommissionFlags_jobOptions.py" )
-#======================================================================
-import os
-from AthenaCommon.JobProperties import jobproperties
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from RecExConfig.RecFlags import jobproperties, rec
-from AthenaCommon.BFieldFlags import jobproperties
-from AthenaCommon.BeamFlags import jobproperties
-from AthenaCommon.AlgSequence import AlgSequence
-topSequence = AlgSequence()
-#======================================================================
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.ID_setOff()
-DetFlags.detdescr.ID_setOn()
-DetFlags.Calo_setOff()
-DetFlags.detdescr.Calo_setOn()
-DetFlags.Muon_setOn()
-# --- printout
-DetFlags.Print()
-#======================================================================
-from RecExConfig.RecFlags import rec as recFlags 
-recFlags.Commissioning=True
-recFlags.oldRecExCommissionConfig = False
-recFlags.oldFlagTopSteering = False
-recFlags.ScopingLevel = 4 
-#======================================================================
-# choose what detector to turn on:
-recFlags.doInDet = False
-recFlags.doLArg  = False
-recFlags.doTile  = False
-#======================================================================
-# Only Muons
-recFlags.doMuon                 = True 
-recFlags.doMuonCombined         = False
-recFlags.doHist                 = True
-#======================================================================
-recFlags.doInDet                = False
-recFlags.doCalo                 = False
-recFlags.doLArg                 = False
-recFlags.doTile                 = False
-recFlags.readESD                = False
-recFlags.doESD                  = True
-recFlags.doWriteESD             = True
-recFlags.doCBNT                 = False
-recFlags.doWriteAOD             = False
-recFlags.doWriteTAG             = False
-recFlags.doJiveXML              = False
-recFlags.doAOD                  = False
-recFlags.doAODall               = False
-recFlags.doTrigger              = False
-recFlags.doPerfMon              = False
-recFlags.doHeavyIon             = False
-recFlags.doEgamma               = False
-recFlags.doTau                  = False
-recFlags.doHeavyIon             = False
-recFlags.doJetMissingETTag      = False
-recFlags.doPersint              = False
-recFlags.doMonitoring           = True
-#======================================================================
-#If True monitor software performance, see https://twiki.cern.ch/twiki/bin/view/Atlas/PerfMonComps
-recFlags.doPerfMon=True 
-recFlags.doDetailedPerfMon=True
-rec.lock_JobProperties()
-#======================================================================
-# Set default recAlgsFlags
-#======================================================================
-from RecExConfig.RecAlgsFlags import recAlgs as recAlgsFlags
-recAlgsFlags.doMuonIDStandAlone = False # extrapolate Moore tracks to the IP
-recAlgsFlags.doMuonIDCombined   = False # combined reconstruction with MuIDCombined
-recAlgsFlags.doStaco            = False # combined reconstruction with Staco
-recAlgsFlags.doMuTag            = False # muon identification with MuTag (requires Muonboy and Staco)
-recAlgsFlags.doMuGirl           = False # muon identification with MuGirl
-recAlgsFlags.doTrigger          = False
-recAlgsFlags.doTrackRecordFilter = True # filter truth muons getting into the spectrometer
-recAlgsFlags.doTileMuID         = False
-recAlgsFlags.doCaloTrkMuId      = False
-recAlgsFlags.doMissingET        = False
-recAlgsFlags.doObjMissingET     = False
-recAlgsFlags.doMissingETSig     = False
-recAlgsFlags.doEFlow            = False
-recAlgsFlags.doEFlowJet         = False
-recAlgsFlags.doAtlfast          = False
-#======================================================================
-# Set default globalflags
-#======================================================================
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.DetGeo      = 'commis'
-globalflags.DataSource.set_Value_and_Lock('data')
-globalflags.InputFormat = 'bytestream' 
-globalflags.Luminosity  = 'zero'
-#==========  Switch to the desired algorithms =========================
-ATLASCosmicFlags.doLVL1Calo=False
-ATLASCosmicFlags.doCTPMon = False
-ATLASCosmicFlags.doHLT  = False
-ATLASCosmicFlags.doCombinedFit = False
-ATLASCosmicFlags.doDQMonitoring = False
-## hack to turn off hlt met monitoring
-HLTMonDoMET = False
-ATLASCosmicFlags.UseDCS = False
-ATLASCosmicFlags.doFilteredESD = False  
-ATLASCosmicFlags.OnlineJiveXML = False
-ATLASCosmicFlags.AtlantisGeometry = False
-ATLASCosmicFlags.CaloDetailedJiveXML = False 
-ATLASCosmicFlags.doPersint = False
-#======================================================================
-# Setup Internal flags for the Muon DQA Monitoring (defaults values)
-from MuonDQAMonFlags.MuonDQAFlags import MuonDQAFlags as MuonDQAFlags
-from AthenaCommon import CfgMgr
-from AthenaMonitoring.DQMonFlags import DQMonFlags
-DQMonFlags.doGlobalMon = False
-DQMonFlags.doLVL1CaloMon = False
-DQMonFlags.doCTPMon = False
-DQMonFlags.doHLTMon = False
-DQMonFlags.doPixelMon = False
-DQMonFlags.doSCTMon = False
-DQMonFlags.doTRTMon = False
-DQMonFlags.doInDetGlobalMon = False
-DQMonFlags.doInDetAlignMon = False
-DQMonFlags.doInDetPerfMon = False
-DQMonFlags.doTileMon = False
-DQMonFlags.doLArMon = False
-DQMonFlags.doEgammaMon = False
-DQMonFlags.doMissingEtMon = False
-DQMonFlags.doTauMon = False
-DQMonFlags.doJetMon = False
-DQMonFlags.doJetTagMon = False
-DQMonFlags.doMuonCombinedMon = False
-#-----------------------------------------------------------------
-DQMonFlags.doMuonRawMon = True
-DQMonFlags.doMuonTrackMon = True
-DQMonFlags.doMuonSegmentMon = True
-DQMonFlags.doMuonAlignMon = True
-DQMonFlags.doMuonPhysicsMon = False
-
-# --- Callgrind Tool
-MuonDQAFlags.doCallgrind = False #False 
-
-# --- CPU and txt files
-MuonDQAFlags.doCpuMuonMon = True
-MuonDQAFlags.doMuonDQAPerfMonitoring = True
-#----------------------------------------------------------------- 
-##if you want to run Hephaestus Tool
-### https://twiki.cern.ch/twiki/bin/view/Atlas/UsingHephaestus
-MuonDQAFlags.doMuonDQAHephTool = False
-#----------------------------------------------------------------- 
-MuonDQAFlags.doAuditor = True
-MuonDQAFlags.doFinalCPU = False  
-MuonDQAFlags.doDumpFile = False
-MuonDQAFlags.doSimpleFile = True
-
-# --- Muon Monitoring options
-MuonDQAFlags.doMuonMonitoring = True
-ATLASCosmicFlags.doMuonMon = True
-
-# --- Muon EventInfo Monitoring option
-MuonDQAFlags.doMuonEvtMon = True
-ATLASCosmicFlags.doMuonEvtMon = True
-
-# --- Muon Hit Monitoring options
-ATLASCosmicFlags.doMuonHitMon = True
-# --- for each subdetector
-ATLASCosmicFlags.doMDTMon = True
-ATLASCosmicFlags.doRPCMon = True
-ATLASCosmicFlags.doRPCL1Mon = True
-ATLASCosmicFlags.doMDTRPCMon = True
-ATLASCosmicFlags.doTGCMon = True
-ATLASCosmicFlags.doTGCL1Mon = True
-ATLASCosmicFlags.doMDTTGCL1Mon = True   
-# --- Temporary for M8---------------
-ATLASCosmicFlags.doCSCMon = False
-MuonDQAFlags.doCSCMon = False
-# --- Temporary for M8---------------
-
-## --- Muon Segment Monitoring options
-ATLASCosmicFlags.doMuonSegmMon = True
-#
-## --- MuonTrk Monitoring options
-ATLASCosmicFlags.doMuonTrackMon = True
-## --- MuonTrk Trigger Aware Monitoring options
-MuonDQAFlags.MuonTrkMonDoTrigger = False
-#
-## --- Muon Trk Alignement Monitoring
-MuonDQAFlags.doMuonTrkAlignMon = True
-ATLASCosmicFlags.doMuonTrkAlignMon = True
-#
-## --- MuonTrk Monitoring options
-ATLASCosmicFlags.doMuonPhysMon = False
-#======================================================================
-
-if not 'Field' in dir():
-    Field = False
-if not 'noField' in dir():
-    noField = False
-if not 'BeamGas' in dir():
-    BeamGas = False
-if not 'BeamHalo' in dir():
-    BeamHalo = False
-if not 'SimBeamGas' in dir():
-    SimBeamGas = False
-if not 'SimBeamHalo' in dir():
-    SimBeamHalo = False
-if not 'CollData' in dir():
-    CollData = False   
-#======================================================================
-# Muon Monitoring Hist output
-if not 'MuonSystem' in dir():
-    MuonSystem = "ALL"        
-#======================================================================    
-#if BeamHalo or BeamGas or SimBeamHalo or SimBeamGas:
-#    jobproperties.Beam.beamType.set_Value_and_Lock("singlebeam")
-#else:
-#    jobproperties.Beam.beamType.set_Value_and_Lock("cosmics")
-#
-#if SimBeamHalo or SimBeamGas:
-#    globalflags.DataSource = 'geant4'
-#    globalflags.InputFormat = 'pool'
-#======================================================================
-#-----------------------------------------------------------------
-# Setup Internal flags for the Muon Spectrometer (defaults values)
-#-----------------------------------------------------------------
-from MuonRecExample.MuonRecFlags import muonRecFlags
-muonRecFlags.doMoore = True
-muonRecFlags.doMuonboy = True
-muonRecFlags.doCSCs=False
-#======================================================================
-# Set properly beam type, DataSource, InputFormat, Detector Description, Conditions Tag
-if globalflags.DataSource() == 'data':
-    recFlags.doTruth = False
-    jobproperties.Beam.beamType.set_Value_and_Lock("singlebeam")
-    globalflags.InputFormat.set_Value_and_Lock('bytestream')
-    globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-04-00-00')
-    globalflags.ConditionsTag.set_Value_and_Lock('COMCOND-ES1C-000-00')
-else :
-    globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-02-01-00')
-    globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIM-00-00-00')
-
-if globalflags.DataSource() == 'data' and globalflags.InputFormat == 'bytestream':
-    if muonRecFlags.doCSCs():
-        athenaCommonFlags.BSRDOInput.set_Value_and_Lock(['/castor/cern.ch/grid/atlas/DAQ/2008/91897/physics_TGCwBeam/daq.ATLAS.0091897.physics.TGCwBeam.LB0001.SFO-1._0001.data'])
-    else:
-        athenaCommonFlags.BSRDOInput.set_Value_and_Lock(['/castor/cern.ch/grid/atlas/DAQ/2008/87863/physics_BPTX/daq.NoTag.0087863.physics.BPTX.LB0000.SFO-1._0001.data'])
-
-if SimBeamHalo:
-    globalflags.DetDescrVersion ='ATLAS-CSC-02-02-00'
-    athenaCommonFlags.PoolRDOInput = ["rfio:/castor/cern.ch/user/d/dellacqu/beamHalo_digits.pool.root"]
-    ATLASCosmicFlags.IOVDbSvcGlobalTagSim = 'OFLCOND-CSC-00-01-07'
-    ATLASCosmicFlags.IOVDbSvcGlobalTagSimOverride = True
-if SimBeamGas:
-    globalflags.DetDescrVersion ='ATLAS-CSC-01-02-00'
-    athenaCommonFlags.PoolRDOInput = ["/afs/cern.ch/user/g/gencomm/w0/RTT_INPUT_DATA/BeamGas/hijing.O.digit._00430.pool.root"]
-    jobproperties.BField.solenoidOn=True
-    jobproperties.BField.barrelToroidOn=True
-    jobproperties.BField.endcapToroidOn=True        
-if BeamGas:
-    ATLASCosmicFlags.CosmicSetup = "M8"
-    globalflags.DetDescrVersion = 'ATLAS-Comm-09-00-00'
-    ATLASCosmicFlags.IOVDbSvcGlobalTagData = 'COMCOND-006-01'
-    athenaCommonFlags.BSRDOInput = [
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-1.0001.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-1.0005.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-1.0007.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-1.0017.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-1.0022.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-1.0023.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-2.0017.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-2.0018.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-2.0019.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-3.0004.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-3.0007.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-3.0008.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-4.0008.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-4.0009.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-5.0005.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-5.0006.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-5.0007.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-5.0010.data",
-        "/castor/cern.ch/user/m/muoncomm/SingleBeam/run87764/run87764.MBTS_BCM_LUCID.LB0000.SFO-5.0021.data"
-        ]    
-    jobproperties.BField.solenoidOn=False
-    jobproperties.BField.barrelToroidOn=True
-    jobproperties.BField.endcapToroidOn=True
-
-MuonDQAFlags.doM8=True
-if MuonDQAFlags.doM8:
-    ATLASCosmicFlags.CosmicSetup = "ATLAS"
-    ATLASCosmicFlags.doMasking=False
-    include ("RecExCommission/GetInputFiles.py")
-    if CollData:
-        if not 'RunNumberList' in dir():
-            RunNumberList = [ 87863 ] 
-        if not 'FilePrefix' in dir():
-            FilePrefix = "daq.NoTag" 
-        if not 'Partition' in dir():
-            Partition      = "BPTX"
-        if not 'Trigger' in dir():
-            Trigger = "*.physics."+Partition
-        if not 'InputDir' in dir():
-            InputDir = "/castor/cern.ch/grid/atlas/DAQ/2008/"+str(RunNumberList[0])+"/physics_"+Partition	
-        BSRDOInput = []
-        for RunNumber in RunNumberList:
-            InputFiles = GetInputFilesFromTokens(InputDir,RunNumber,FilePrefix,Trigger)
-        print "Input files:"
-        athenaCommonFlags.BSRDOInput.set_Value_and_Lock(InputFiles)
-        print athenaCommonFlags.BSRDOInput
-        ATLASCosmicFlags.NumFile = []
-        # Detector description #jamie, use version with field (even though solenoid is off)
-        globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-04-00-00')
-        globalflags.ConditionsTag.set_Value_and_Lock('COMCOND-ES1C-000-00')
-        # for running over data with field on need this to be setto true
-        from AthenaCommon.BFieldFlags import jobproperties
-        jobproperties.BField.solenoidOn.set_Value_and_Lock(False)
-        jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-        jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-    if Field:
-        globalflags.DetDescrVersion ='ATLAS-Comm-09-00-00'
-        ATLASCosmicFlags.IOVDbSvcGlobalTagData = 'COMCOND-006-00'  #Database
-        ATLASCosmicFlags.Magnet = False
-        ATLASCosmicFlags.MagnetToroid = True
-        jobproperties.BField.solenoidOn = False
-        jobproperties.BField.barrelToroidOn = True
-        jobproperties.BField.endcapToroidOn = True
-        if not 'RunNumberList' in dir():
-            RunNumberList = [ 82075 ] # for M8 ###====LIST of GOOD M7 runs====> /afs/cern.ch/atlas/project/tzero/prod1/goodruns and https://twiki.cern.ch/twiki/bin/view/Atlas/M7MuonRunList
-        if not 'FilePrefix' in dir():
-            FilePrefix = "daq.ATLAS" # for M8
-        if not 'Partition' in dir():
-            Partition      = "HLT_Cosmics_MU3"   # for M7,M8 | physics.HLT_Cosmics_MU3 | physics.HLT_Cosmics
-        if not 'Trigger' in dir():
-            Trigger = "*.physics."+Partition
-        if not 'InputDir' in dir():
-            InputDir = "/castor/cern.ch/grid/atlas/DAQ/2008/"+str(RunNumberList[0])+"/physics_"+Partition # for M8	
-        BSRDOInput = []
-        for RunNumber in RunNumberList:
-            InputFiles = GetInputFilesFromTokens(InputDir,RunNumber,FilePrefix,Trigger)
-        print "Input files:"
-        athenaCommonFlags.BSRDOInput=InputFiles
-        print athenaCommonFlags.BSRDOInput
-        ATLASCosmicFlags.NumFile = []
-    if noField:
-        globalflags.DetDescrVersion = 'ATLAS-CommNF-09-00-00'      # Detector description
-        ATLASCosmicFlags.IOVDbSvcGlobalTagData = 'COMCOND-006-00'  #Database
-        jobproperties.BField.solenoidOn = False
-        jobproperties.BField.barrelToroidOn = False
-        jobproperties.BField.endcapToroidOn = False
-        if not 'RunNumberList' in dir():
-            RunNumberList = [ 77168 ] # for M8 ###====LIST of GOOD M7 runs====> /afs/cern.ch/atlas/project/tzero/prod1/goodruns and https://twiki.cern.ch/twiki/bin/view/Atlas/M7MuonRunList
-        if not 'FilePrefix' in dir():
-            FilePrefix = "daq.ATLAS" # for M8
-        if not 'Partition' in dir():
-            Partition      = "HLT_Cosmics_MU3"   # for M7,M8 | physics.HLT_Cosmics_MU3 | physics.HLT_Cosmics
-        if not 'Trigger' in dir():
-            Trigger = "*.physics."+Partition
-        if not 'InputDir' in dir():
-            InputDir = "/castor/cern.ch/grid/atlas/DAQ/2008/"+str(RunNumberList[0])+"/physics_"+Partition # for M8	
-        BSRDOInput = []
-        for RunNumber in RunNumberList:
-            InputFiles = GetInputFilesFromTokens(InputDir,RunNumber,FilePrefix,Trigger)
-        print "Input files:"
-        athenaCommonFlags.BSRDOInput=InputFiles
-        print athenaCommonFlags.BSRDOInput
-        ATLASCosmicFlags.NumFile = []
-
-###############################################################
-#
-#  Configuration jobOptions file
-#
-###############################################################  
-#=======================Output Files===================================
-if Field or noField or CollData:
-    DQMonFlags.histogramFile = MuonSystem+"MuonMonitoring_"+str(ATLASCosmicFlags.CosmicSetup)+"Setup_"+str(RunNumber)+".root"
-    athenaCommonFlags.PoolESDOutput = MuonSystem+"MuonMonitoringESD_"+str(ATLASCosmicFlags.CosmicSetup)+"_"+str(RunNumber)+".pool.root"
-    ATLASCosmicFlags.FilteredESDOutputFile = MuonSystem+"MuonMonitoringESD_Filtered"+str(ATLASCosmicFlags.CosmicSetup)+"_"+str(RunNumber)+".pool.root"
-    
-if BeamHalo or BeamGas:
-    recFlags.RootHistoOutput = MuonSystem+"MuonMonitoring_BeamHalo.root"
-    athenaCommonFlags.PoolESDOutput = MuonSystem+"MuonMonitoringESD_BeamHalo.pool.root"
-    ATLASCosmicFlags.FilteredESDOutputFile = MuonSystem+"MuonMonitoringESD_Filtered_BeamHalo.pool.root"
-
-if SimBeamHalo or SimBeamGas:
-    recFlags.RootHistoOutput = MuonSystem+"MuonMonitoring_SimBeamHalo.root"
-    athenaCommonFlags.PoolESDOutput = MuonSystem+"MuonMonitoringESD_SimBeamHalo.pool.root"
-    ATLASCosmicFlags.FilteredESDOutputFile = MuonSystem+"MuonMonitoringESD_Filtered_SimBeamHalo.pool.root"
- 
-#======================================================================
-#Steering flags
-#======================================================================
-athenaCommonFlags.EvtMax.set_Value_and_Lock(10)
-athenaCommonFlags.SkipEvents.set_Value_and_Lock(0)
-#======================================================================
-if 'doAuditors' in dir():
-    from RecExConfig.RecFlags  import jobproperties
-    jobproperties.Rec.doNameAuditor.set_Value(True)
-#====================================================================== 
-#=BEGINNN=====================================================================
-# the main jobOpt
-if BeamGas:
-    include( "RecExCommission/RecExCommission_SingleBeamtopOptions.py" )
-else:
-    include( "RecExCommission/RecExCommission.py" )
-    include ("RecExCommon/RecExCommon_topOptions.py")
-#==ENDDDDD====================================================================
- 
-####Change Collections####################
-#if MuonDQAFlags.doMuonTrackMon:
-#    ToolSvc += CfgMgr.MuonMonTrkSummary(MuonTrackCollections=["MooreTrackParticles" ,"MuonboyTrackParticles"])
-#    ToolSvc += CfgMgr.MuonTrackValidation(MuonTrackCollections=["MooreTrackParticles" ,"MuonboyTrackParticles"])
-#    ToolSvc += CfgMgr.MuonAlignMonGenericTracks(MuonTrackCollections=["MooreTrackParticles" ,"MuonboyTrackParticles"])     
-
-###############################################################
-#
-#  Configuration jobOptions file
-#
-###############################################################
-#--------------------------------------------------------------
-# Performace monitoring (CPU and Memory)
-#--------------------------------------------------------------
-if MuonDQAFlags.doCpuMuonMon:
-    include("MuonDQAMonitoring/MuonDQAMonitoring_CpuPerfMon.py")
-    jobproperties.PerfMonFlags.OutputFile = MuonSystem+"muondqa.perfmon.pmon.gz"
-    
-#if recFlags.doPerfMon:
-#    from PerfMonComps.PerfMonFlags import jobproperties
-#    jobproperties.PerfMonFlags.doPerEvtLeakCheck = True
-
-if MuonDQAFlags.doMuonDQAPerfMonitoring and MuonDQAFlags.doMuonDQAHephTool:
-    from PerfMonComps.PerfMonFlags import jobproperties
-    jobproperties.PerfMonFlags.doPerEvtLeakCheck = True
-#--------------------------------------------------------------
-# Valgrind- Callgrind
-#--------------------------------------------------------------
-if MuonDQAFlags.doCallgrind:
-     from Valkyrie.ValkyrieConf import ValgrindSvc
-     valgrindSvc = ValgrindSvc( OutputLevel = VERBOSE )
-     if ATLASCosmicFlags.doMuonHitMon:
-         valgrindSvc.ProfiledAlgs += MuonDQAFlags.CallgrindHitAlgs
-         valgrindSvc.IgnoreFirstNEvents = MuonDQAFlags.CallgrindSkip      # to start instrumentation after the second event only
-     if ATLASCosmicFlags.doMuonTrackMon:
-         valgrindSvc.ProfiledAlgs += MuonDQAFlags.CallgrindTrkAlgs
-         valgrindSvc.IgnoreFirstNEvents = MuonDQAFlags.CallgrindSkip      # to start instrumentation after the second event only
-     if ATLASCosmicFlags.doMuonSegmMon:
-         valgrindSvc.ProfiledAlgs += MuonDQAFlags.CallgrindSegmAlgs
-         valgrindSvc.IgnoreFirstNEvents = MuonDQAFlags.CallgrindSkip      # to start instrumentation after the second event only          
-     # Add service and turn on auditing
-     svcMgr += valgrindSvc
-     theApp.CreateSvc += [svcMgr.ValgrindSvc.getFullJobOptName()]
-     theApp.AuditAlgorithms = True
-     theApp.AuditTools      = True
-     theApp.AuditServices   = True
-# -------------------------------------------------------------
-#Output level
-# -------------------------------------------------------------
-# --------------For RawData Monitoring----------------------------
-if MuonDQAFlags.doMuonHitMon:
-    #ToolSvc += CfgMgr.MDTRawDataBSValAlg(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.MDTRawDataESDValAlg(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.RPCRawDataValAlg(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.MDTvsRPCRawDataValAlg(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.RPCLV1RawDataValAlg(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.TGCRawDataESDValAlg(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.TGCLV1RawDataESDValAlg(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.MDTvsTGCRawDataESDValAlg(OutputLevel = INFO)
-    if MuonDQAFlags.doCSCMon:
-        #ToolSvc += CfgMgr.CSCPrdValAlg(OutputLevel = INFO)
-        #ToolSvc += CfgMgr.CSCRdoValAlg(OutputLevel = INFO)
-        #ToolSvc += CfgMgr.CSCClusterTree(OutputLevel = INFO)
-        #ToolSvc += CfgMgr.CSCClusterValAlg(OutputLevel = INFO)
-# --------------For MuonSegment Monitoring------------------------    
-if MuonDQAFlags.doMuonSegmMon:
-    #ToolSvc += CfgMgr.MuonSegmValidation(OutputLevel = INFO)
-# --------------For MuonTrk Alignment Monitoring------------------------    
-if MuonDQAFlags.doMuonTrkAlignMon:
-    #ToolSvc += CfgMgr.MuonAlignValidation(OutputLevel = INFO)
-# --------------For MuonTrk Monitoring----------------------------
-# --------------For No Trigger MuonTrk Monitoring-----------------
-if MuonDQAFlags.doMuonTrackMon and not MuonDQAFlags.MuonTrkMonDoTrigger:
-    #ToolSvc += CfgMgr.MuonSelectedTracksMon(OutputLevel = INFO) 
-    #ToolSvc += CfgMgr.MuonGenericTracksMon(OutputLevel = INFO) 
-# --------------For TriggerAware MuonTrk Monitoring---------------
-if MuonDQAFlags.doMuonTrackMon and MuonDQAFlags.MuonTrkMonDoTrigger:
-    ### UseTriggerVector =True
-    #ToolSvc += CfgMgr.MuonSelectedTracksMon_Trig(OutputLevel = INFO) 
-    #ToolSvc += CfgMgr.MuonGenericTracksMon_Trig(OutputLevel = INFO)     
-    ### UseTriggerVector = False
-    #ToolSvc += CfgMgr.MuonSelectedTracksMon_trigmu10(OutputLevel = INFO) 
-    #ToolSvc += CfgMgr.MuonSelectedTracksMon_trigmu20(OutputLevel = INFO)         
-    #ToolSvc += CfgMgr.MuonSelectedTracksMon_trigmu40(OutputLevel = INFO) 
-    #ToolSvc += CfgMgr.MuonSelectedTracksMon_trig2mu10(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.MuonGenericTracksMon_trigmu10(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.MuonGenericTracksMon_trigmu20(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.MuonGenericTracksMon_trigmu40(OutputLevel = INFO)
-    #ToolSvc += CfgMgr.MuonGenericTracksMon_trig2mu10(OutputLevel = INFO)     
-# --------------For MuonEventInfo Monitoring----------------------------
-if MuonDQAFlags.doMuonEvtMon:
-    #ToolSvc += CfgMgr.MuonDQA__MuonEventInfoMonTool(OutputLevel = INFO)  
-#--------------------------------------------------------------------------- 
-Service( "THistSvc" ).OutputLevel = WARNING
-#--------------------------------------------------------------------------- 
-# THIS IS TEMPORY HACK TO GET RID OF MUON ERRORS BEING PRINTED FOR EVERY EVENT
-# NEED A REAL FIX 
-#--------------------------------------------------------------------------- 
-Algorithm("TgcRdoToTgcPrepData").OutputLevel = ERROR
-#--------------------------------------------------------------------------- 
-print "List all DLL"
-print theApp.Dlls
-print "List all ExtSvc"
-print theApp.ExtSvc
-print "List of all top algorithms"
-print theApp.TopAlg
-#--------------------------------------------------------------------------- 
-print topSequence
-print ServiceMgr
-print #ToolSvc
-#======================================================================
diff --git a/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.digi.py b/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.digi.py
index 0538b88bf44f35fd2a4361cbcf1c47eeaf858340..3b9a71d29f57e4d5bb619a7a06c873d41e651127 100644
--- a/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.digi.py
+++ b/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.digi.py
@@ -1,7 +1,8 @@
-#job options to activate the dump of the NSWPRDVal nTuple
-#This file can be used with Digi_tf by specifying --postinclude MuonPRDTest/NSWPRDValAlg.digi.py
-#It dumps Truth, MuEntry and Hits, Digits, SDOs and RDOs for MM and sTGC
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
+# jobOptions to activate the dump of the NSWPRDValAlg nTuple
+# This file can be used with Digi_tf by specifying --postInclude MuonPRDTest/NSWPRDValAlg.digi.py
+# It dumps Truth, MuEntry and Hits, Digits, SDOs and RDOs for MM and sTGC
 
 #-----------------------------------------------------------------------------
 # Algorithms
diff --git a/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.reco.py b/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.reco.py
index 91eada721c3cd21635020df9e16a340f2dee02e6..0fd541c00a35b61034e6b7ae53bdbb512b57867c 100644
--- a/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.reco.py
+++ b/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.reco.py
@@ -1,8 +1,9 @@
-#job options to activate the dump of the NSWPRDVal nTuple
-#This file can be used with Reco_tf by specifying --postinclude MuonPRDTest/NSWPRDValAlg.reco.py
-#It dumps Truth, MuEntry and Hits, Digits, SDOs, RDOs and PRDs for MM and sTGC
-#It should only be used with Reco since the alg crashes in the absence of PRDs
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
+# jobOptions to activate the dump of the NSWPRDValAlg nTuple
+# This file can be used with Reco_tf by specifying --postInclude MuonPRDTest/NSWPRDValAlg.reco.py
+# It dumps Truth, MuEntry and Hits, Digits, SDOs, RDOs and PRDs for MM and sTGC
+# It should only be used with Reco since the alg crashes in the absence of PRDs
 
 #-----------------------------------------------------------------------------
 # Algorithms
diff --git a/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.sim.py b/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.sim.py
new file mode 100644
index 0000000000000000000000000000000000000000..e81dab998ed8b15dd1f2d84898aefe664bac5ea4
--- /dev/null
+++ b/MuonSpectrometer/MuonValidation/MuonPRDTest/share/NSWPRDValAlg.sim.py
@@ -0,0 +1,30 @@
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+
+# jobOptions to activate the dump of the NSWPRDValAlg nTuple
+# This file can be used with Sim_tf by specifying --postInclude MuonPRDTest/NSWPRDValAlg.sim.py
+# It dumps Truth, MuEntry and Hits, for MDT, RPC, MM and sTGC
+
+#-----------------------------------------------------------------------------
+# Algorithms
+#-----------------------------------------------------------------------------
+from AthenaCommon.AlgSequence import AlgSequence
+job = AlgSequence()
+from MuonPRDTest.MuonPRDTestConf import *
+
+job+=NSWPRDValAlg('NSWPRDValAlg', OutputLevel = WARNING)
+NSWPRDValAlg.OutputLevel = INFO
+NSWPRDValAlg.doTruth = True
+
+NSWPRDValAlg.doMuEntry = True
+
+NSWPRDValAlg.doMDTHit= True
+NSWPRDValAlg.doRPCHit= True
+NSWPRDValAlg.doMMHit = True
+NSWPRDValAlg.doSTGCHit = True
+
+#-----------------------------------------------------------------------------
+# save ROOT histograms and Tuple
+#-----------------------------------------------------------------------------
+from GaudiSvc.GaudiSvcConf import THistSvc
+ServiceMgr += THistSvc()
+ServiceMgr.THistSvc.Output = [ "NSWPRDValAlg DATAFILE='NSWPRDValAlg.sim.ntuple.root' OPT='RECREATE'" ]
diff --git a/MuonSpectrometer/MuonValidation/MuonPRDTest/src/TruthVariables.cxx b/MuonSpectrometer/MuonValidation/MuonPRDTest/src/TruthVariables.cxx
index c93e1db106c6ab294d3874245304c83da80bee8e..da776767426dfce3e159d2dab09ace6077a0cf5f 100644
--- a/MuonSpectrometer/MuonValidation/MuonPRDTest/src/TruthVariables.cxx
+++ b/MuonSpectrometer/MuonValidation/MuonPRDTest/src/TruthVariables.cxx
@@ -27,11 +27,14 @@ StatusCode TruthVariables::fillVariables(const MuonGM::MuonDetectorManager* Muon
   unsigned int nSubEvents = 0;
   for(auto it : *truthContainer) {
     const HepMC::GenEvent *subEvent = it;
-
+#ifdef HEPMC3
+    for(auto vertex :  subEvent->vertices()) {
+#else
     // Vertex 
     HepMC::ConstGenEventVertexRange vertex_range = subEvent->vertex_range();
     for(auto vit : vertex_range) {
       const HepMC::GenVertex *vertex = vit;
+#endif
       const HepMC::FourVector position = vertex->position();
       m_Truth_vertexX->push_back(position.x());
       m_Truth_vertexY->push_back(position.y());
@@ -41,10 +44,14 @@ StatusCode TruthVariables::fillVariables(const MuonGM::MuonDetectorManager* Muon
       m_Truth_nVertices++;
     }
 
+#ifdef HEPMC3
+    for(auto particle :  subEvent->particles()) {
+#else
     // Particle 
     HepMC::ConstGenEventParticleRange particle_range = subEvent->particle_range();
     for(auto pit : particle_range) {
       const HepMC::GenParticle *particle = pit;
+#endif
       const HepMC::FourVector momentum = particle->momentum();
       m_Truth_particlePt->push_back(momentum.perp());
       m_Truth_particleEta->push_back(momentum.eta());
@@ -53,10 +60,10 @@ StatusCode TruthVariables::fillVariables(const MuonGM::MuonDetectorManager* Muon
       m_Truth_particleM->push_back(momentum.m());
       m_Truth_particlePdg_id->push_back(particle->pdg_id());
       m_Truth_particleStatus->push_back(particle->status());
-      m_Truth_particleBarcode->push_back(particle->barcode());
-      HepMC::GenVertex* production_vertex = particle->production_vertex();
+      m_Truth_particleBarcode->push_back(HepMC::barcode(particle));
+      auto production_vertex = particle->production_vertex();
       m_Truth_particleProduction_vertex_id->push_back(production_vertex ? production_vertex->id() : -1);
-      HepMC::GenVertex* end_vertex = particle->end_vertex();
+      auto end_vertex = particle->end_vertex();
       m_Truth_particleEnd_vertex_id->push_back(end_vertex ? end_vertex->id() : -1);
       m_Truth_nParticles++;
     }
diff --git a/PhysicsAnalysis/AnalysisCommon/AODSelect/CMakeLists.txt b/PhysicsAnalysis/AnalysisCommon/AODSelect/CMakeLists.txt
index 24e23726258436512f0881d6f12de531057c1a52..f7b7f31d1487f66e547d46765bc62f1f17c14e7c 100644
--- a/PhysicsAnalysis/AnalysisCommon/AODSelect/CMakeLists.txt
+++ b/PhysicsAnalysis/AnalysisCommon/AODSelect/CMakeLists.txt
@@ -1,12 +1,10 @@
-################################################################################
-# Package: AODSelect
-################################################################################
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 # Declare the package name:
 atlas_subdir( AODSelect )
 
 # Install files from the package:
-atlas_install_python_modules( python/*.py )
+atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 atlas_install_joboptions( share/*.py )
 atlas_install_scripts( share/PrintAODSelect.py )
 
diff --git a/PhysicsAnalysis/AnalysisCommon/AODSelect/python/AODSelectFlags.py b/PhysicsAnalysis/AnalysisCommon/AODSelect/python/AODSelectFlags.py
index 9d683fb4ba729c59e3cdae435196723bf876e06a..b3863c8962a6311d865c171eb923cc223ea220b4 100644
--- a/PhysicsAnalysis/AnalysisCommon/AODSelect/python/AODSelectFlags.py
+++ b/PhysicsAnalysis/AnalysisCommon/AODSelect/python/AODSelectFlags.py
@@ -1,4 +1,4 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 # =============================================================================
 # Name:        AODSelectFlags
@@ -17,7 +17,6 @@ __author__  = "Karsten Koeneke <karsten.koeneke@cern.ch>"
 
 from AthenaCommon.JobProperties import JobProperty, JobPropertyContainer
 from AthenaCommon.JobProperties import jobproperties
-from RecExConfig.RecoFunctions import AddValidItemToList,RemoveValidItemFromList
 
 # =====================================================================
 # First define container for the D2PDMaker flags  
@@ -111,19 +110,19 @@ class buildingBaseProperty(JobProperty):
     outputCollectionPrefix     = ""
     def add(self, inputItem="", createOutputCollection=None, createOutputLinkCollection=None ):
         if self.is_locked():
-            self._log.info('The JobProperty %s is blocked' % self.__name__)
+            self._log.info('The JobProperty %s is blocked', self.__name__)
         else:
             if inputItem != "":
                 if not self.inputTypeAndKeyList.__contains__(inputItem): self.inputTypeAndKeyList.append(inputItem)
-                if createOutputCollection!=None: self.createOutputCollection = createOutputCollection or self.createOutputCollection
-                if createOutputLinkCollection!=None: self.createOutputLinkCollection = createOutputLinkCollection or self.createOutputLinkCollection
+                if createOutputCollection is not None: self.createOutputCollection = createOutputCollection or self.createOutputCollection
+                if createOutputLinkCollection is not None: self.createOutputLinkCollection = createOutputLinkCollection or self.createOutputLinkCollection
                 if len(self.inputTypeAndKeyList)>0 and ( self.createOutputCollection or self.createOutputLinkCollection ):
                     self.StoredValue = True
                     AODSelectFlags.doAODSelect = True
                     pass
                 pass
             else:
-                self._log.warning('We got an empty inputItem string for the JobProperty %s... doing nothing!' % self.__name__)
+                self._log.warning('We got an empty inputItem string for the JobProperty %s... doing nothing!', self.__name__)
                 pass
             pass
         return
@@ -138,7 +137,7 @@ class flaggingBaseProperty(JobProperty):
     varNameList         = []
     def add(self, inputItem="", varNameList=[] ):
         if self.is_locked():
-            self._log.info('The JobProperty %s is blocked' % self.__name__)
+            self._log.info('The JobProperty %s is blocked', self.__name__)
         else:
             if inputItem != "":
                 self.StoredValue = True
@@ -151,7 +150,7 @@ class flaggingBaseProperty(JobProperty):
                     pass
                 pass
             else:
-                self._log.warning('We got an empty inputItem string for the JobProperty %s... doing nothing!' % self.__name__)
+                self._log.warning('We got an empty inputItem string for the JobProperty %s... doing nothing!', self.__name__)
                 pass
             pass
         return
@@ -167,25 +166,25 @@ class matchingBaseProperty(JobProperty):
     defaultMatchToItem = ""
     def add(self, inputItem="", matchToItemList=[], matchDistanceList=[] ):
         if self.is_locked():
-            self._log.info('The JobProperty %s is blocked' % self.__name__)
+            self._log.info('The JobProperty %s is blocked', self.__name__)
         else:
             if inputItem == "":
-                self._log.warning('We got an empty inputItem string for the JobProperty %s... doing nothing!' % self.__name__)
+                self._log.warning('We got an empty inputItem string for the JobProperty %s... doing nothing!', self.__name__)
                 return
             if len(matchToItemList)==0 and self.defaultMatchToItem == "" :
-                self._log.warning('We got an empty matchToItemList for the JobProperty %s... doing nothing!' % self.__name__)
+                self._log.warning('We got an empty matchToItemList for the JobProperty %s... doing nothing!', self.__name__)
                 return
             if len(matchToItemList)!=0 and len(matchDistanceList)!=0 and len(matchToItemList)!=len(matchDistanceList):
                 self._log.warning("We got non-empty lists with different lenght for the ",
-                                  "JobProperty %s... doing nothing! len(matchToItemList)=%s, len(matchDistanceList)=%s"
-                                  % (self.__name__, len(matchToItemList), len(matchDistanceList)) )
+                                  "JobProperty %s... doing nothing! len(matchToItemList)=%s, len(matchDistanceList)=%s",
+                                  self.__name__, len(matchToItemList), len(matchDistanceList) )
                 return
             # OK, we seem to have correct inputs... now, update the information
             self.StoredValue = True
             AODSelectFlags.doAODSelect = True
             # Prepare the final list of pairs of [ matchToItem, matchDistance ]
             finalMatchToItemList = []
-            for idx in xrange( len(matchToItemList) ):
+            for idx in range( len(matchToItemList) ):
                 matchToItem = matchToItemList[idx]
                 if len(matchDistanceList)==0 :
                     finalMatchToItemList.append( [matchToItem, self.defaultDeltaR] )
@@ -194,7 +193,7 @@ class matchingBaseProperty(JobProperty):
                     finalMatchToItemList.append( [matchToItem, matchDistanceList[idx]] )
                     pass
                 pass
-            if self.matchingDictionary.has_key(inputItem):
+            if inputItem in self.matchingDictionary:
                 valueList = self.matchingDictionary[inputItem]
                 for newPair in finalMatchToItemList:
                     if not valueList.__contains__(newPair):
diff --git a/PhysicsAnalysis/AnalysisCommon/AODSelect/python/AODSelectHelpers.py b/PhysicsAnalysis/AnalysisCommon/AODSelect/python/AODSelectHelpers.py
index 3fb07777b55d299ec23c62f3ec878f670d9ef991..57ccbe1ab5c0e46b39d20f57a9abeff10b8b1ecd 100644
--- a/PhysicsAnalysis/AnalysisCommon/AODSelect/python/AODSelectHelpers.py
+++ b/PhysicsAnalysis/AnalysisCommon/AODSelect/python/AODSelectHelpers.py
@@ -21,8 +21,6 @@ from AthenaCommon.Logging import logging
 logAODSelect_helpers = logging.getLogger( 'AODSelect_helpers' )
 #logAODSelect_helpers.setLevel(logging.DEBUG)
 
-# Import the AODSelectFlags to steer the job
-from AODSelect.AODSelectFlags import AODSelectFlags
 from AthenaCommon import CfgMgr
 
 # Import the objKeyStore to be able to see what collections are available
@@ -73,10 +71,10 @@ class AODSelectConfiguration(object):
         if not aodSelectFlag:
             logAODSelect_helpers.warning( "You gave me an empty flag container... this won't work!" )
             return False
-        logAODSelect_helpers.debug( "Have inputTypeAndKeyList=%s, outputCollectionPrefix=%s, createOutputCollection=%s, createOutputLinkCollection=%s, selectorTool=%s "
-                                    % (aodSelectFlag.inputTypeAndKeyList,
+        logAODSelect_helpers.debug( "Have inputTypeAndKeyList=%s, outputCollectionPrefix=%s, createOutputCollection=%s, createOutputLinkCollection=%s, selectorTool=%s ",
+                                       aodSelectFlag.inputTypeAndKeyList,
                                        aodSelectFlag.outputCollectionPrefix, aodSelectFlag.createOutputCollection,
-                                       aodSelectFlag.createOutputLinkCollection, selectorTool ) )
+                                       aodSelectFlag.createOutputLinkCollection, selectorTool )
         for inputTypeAndKey in aodSelectFlag.inputTypeAndKeyList:
             # Prepare the names for this inputTypeAndKey
             inputType, inputKey = inputTypeAndKey.split("#")
@@ -93,10 +91,10 @@ class AODSelectConfiguration(object):
                 algConfigName = inputTypeAndKey
                 if index > 0: algConfigName = algConfigName + ("_%s" % index)
                 algConfig = self.findAlgConfig(algConfigName)
-                if algConfig != None:
+                if algConfig is not None:
                     # Check if it already has output (link) collections scheduled
                     if algConfig.outputCollection == algConfig.outputLinkCollection == "":
-                        logAODSelect_helpers.debug( "Modifying an existing AODSelectAlgConfig with name: %s" % algConfigName )
+                        logAODSelect_helpers.debug( "Modifying an existing AODSelectAlgConfig with name: %s", algConfigName )
                         algConfig.selectorToolList.append(selectorTool)
                         algConfig.outputCollection     = outCollKey
                         algConfig.outputLinkCollection = outLinkCollKey
@@ -110,7 +108,7 @@ class AODSelectConfiguration(object):
                     pass
                 else:
                     # Create a new one and add it
-                    logAODSelect_helpers.debug( "Adding a new AODSelectAlgConfig with name: %s" % algConfigName )
+                    logAODSelect_helpers.debug( "Adding a new AODSelectAlgConfig with name: %s", algConfigName )
                     algConfig = AODSelectAlgConfig(algConfigName)
                     algConfig.setInputTypeAndKey(inputTypeAndKey)
                     algConfig.selectorToolList.append(selectorTool)
@@ -144,18 +142,17 @@ class AODSelectConfiguration(object):
             return False
         for inputTypeAndKey in aodSelectFlag.inputTypeAndKeyList:
             algConfig = self.findAlgConfig(inputTypeAndKey)
-            if algConfig == None:
+            if algConfig is None:
                 # Create a new one and add it
-                logAODSelect_helpers.debug( "Adding a new AODSelectAlgConfig with name: %s" % inputTypeAndKey )
+                logAODSelect_helpers.debug( "Adding a new AODSelectAlgConfig with name: %s", inputTypeAndKey )
                 algConfig = AODSelectAlgConfig(inputTypeAndKey)
-                logAODSelect_helpers.debug( "Adding a new user data tool: %s" % userDataTool )
+                logAODSelect_helpers.debug( "Adding a new user data tool: %s", userDataTool )
                 algConfig.userDataToolList.append(userDataTool)
                 if logAODSelect_helpers.isEnabledFor(logging.DEBUG): algConfig.doPrint()
                 self.addAlgConfig(algConfig)
                 pass
             else:
-                logAODSelect_helpers.debug( "Adding a new user data tool of name %s to AODSelectAlgConfig with name: %s"
-                                            % (userDataTool, inputTypeAndKey) )
+                logAODSelect_helpers.debug( "Adding a new user data tool of name %s to AODSelectAlgConfig with name: %s", userDataTool, inputTypeAndKey )
                 algConfig.userDataToolList.append(userDataTool)
                 if logAODSelect_helpers.isEnabledFor(logging.DEBUG): algConfig.doPrint()
                 pass
@@ -181,7 +178,7 @@ class AODSelectConfiguration(object):
             logAODSelect_helpers.warning( "You gave me an empty inputTypeAndKey string... this won't work!" )
             return False
         if not inputTypeAndKey.__contains__("#"):
-            logAODSelect_helpers.warning( "The inputTypeAndKey string doesn't contain a '#', but it should: %s" % inputTypeAndKey )
+            logAODSelect_helpers.warning( "The inputTypeAndKey string doesn't contain a '#', but it should: %s", inputTypeAndKey )
             return False
         if not associationTool:
             logAODSelect_helpers.warning( "You gave me an empty associationTool... this won't work!" )
@@ -189,19 +186,19 @@ class AODSelectConfiguration(object):
         # Create the name of the associationMap container that will be created
         _tmpName = ((associationTool.getName()).split("__"))[-1]
         _outAssoName = (inputTypeAndKey.split("#"))[1] + "_MatchTo_" + _tmpName
-        logAODSelect_helpers.debug( "using inputTypeAndKey=%s, _tmpName=%s, _outAssoName=%s" % (inputTypeAndKey, _tmpName, _outAssoName ) )
+        logAODSelect_helpers.debug( "using inputTypeAndKey=%s, _tmpName=%s, _outAssoName=%s", inputTypeAndKey, _tmpName, _outAssoName )
         # Find the right AODSelectAlgConfig object
         algConfig = self.findAlgConfig(inputTypeAndKey)
-        if algConfig == None:
+        if algConfig is None:
             # Create a new one and add it
-            logAODSelect_helpers.debug( "Creating a new AODSelectAlgConfig with name=%s" % (inputTypeAndKey) )
+            logAODSelect_helpers.debug( "Creating a new AODSelectAlgConfig with name=%s", inputTypeAndKey )
             algConfig = AODSelectAlgConfig(inputTypeAndKey)
             algConfig.associationToolList.append(associationTool)
             algConfig.outputAssociationList.append(_outAssoName)
             self.addAlgConfig(algConfig)
             pass
         else:
-            logAODSelect_helpers.debug( "Using an existing AODSelectAlgConfig with name=%s" % (inputTypeAndKey) )
+            logAODSelect_helpers.debug( "Using an existing AODSelectAlgConfig with name=%s", inputTypeAndKey )
             algConfig.associationToolList.append(associationTool)
             algConfig.outputAssociationList.append(_outAssoName)
             pass
@@ -235,7 +232,7 @@ class AODSelectConfiguration(object):
             logAODSelect_helpers.debug( "Values of current AODSelectAlgConfig: " )
             if logAODSelect_helpers.isEnabledFor(logging.DEBUG): algConfig.doPrint()
             algName = "AODSelect_" + algConfig.name.split("#")[1] + "_SelectionAlg"
-            logAODSelect_helpers.debug( "Now creating an algorithm with name %s" % algName )
+            logAODSelect_helpers.debug( "Now creating an algorithm with name %s", algName )
             algClass = self.algDict[algConfig.inputType]
             alg = algClass( algName,
                             inputCollection                = algConfig.inputKey,
@@ -277,38 +274,38 @@ class AODSelectAlgConfig(object):
 
 
     def setInputTypeAndKey(self, inputTypeAndKey=None, inputKey=None):
-        if inputTypeAndKey == None:
+        if inputTypeAndKey is None:
             logAODSelect_helpers.warning( "Got an empty value in setInputTypeAndKey... exiting!" )
             return
         if inputTypeAndKey.__contains__("#"):
             self.inputTypeAndKey          = inputTypeAndKey
             self.inputType, self.inputKey = inputTypeAndKey.split("#")
-            logAODSelect_helpers.debug( "Setting inputTypeAndKey=%s, inputType=%s, inputKey=%s"
-                                        % (self.inputTypeAndKey, self.inputType, self.inputKey) )
+            logAODSelect_helpers.debug( "Setting inputTypeAndKey=%s, inputType=%s, inputKey=%s",
+                                        self.inputTypeAndKey, self.inputType, self.inputKey )
             return
-        elif inputKey != None:
+        elif inputKey is not None:
             self.inputTypeAndKey = inputTypeAndKey + "#" + inputKey
             self.inputType       = inputTypeAndKey
             self.inputKey        = inputKey
-            logAODSelect_helpers.debug( "Setting inputTypeAndKey=%s, inputType=%s, inputKey=%s"
-                                        % (self.inputTypeAndKey, self.inputType, self.inputKey) )
+            logAODSelect_helpers.debug( "Setting inputTypeAndKey=%s, inputType=%s, inputKey=%s",
+                                        self.inputTypeAndKey, self.inputType, self.inputKey )
             return
-        logAODSelect_helpers.warning( "Could not understand what to do with inputTypeAndKey=%s and inputKey=%s"
-                                      % (inputTypeAndKey, inputKey) )
+        logAODSelect_helpers.warning( "Could not understand what to do with inputTypeAndKey=%s and inputKey=%s",
+                                      inputTypeAndKey, inputKey )
         return
 
 
     def doPrint(self):
-        logAODSelect_helpers.info( "Found an AODSelectAlgConfig with name = %s" % self.name )
-        logAODSelect_helpers.info( "   and inputTypeAndKey       = %s" % self.inputTypeAndKey )
-        logAODSelect_helpers.info( "   and inputType             = %s" % self.inputType )
-        logAODSelect_helpers.info( "   and inputKey              = %s" % self.inputKey )
-        logAODSelect_helpers.info( "   and outputCollection      = %s" % self.outputCollection )
-        logAODSelect_helpers.info( "   and outputLinkCollection  = %s" % self.outputLinkCollection )
-        logAODSelect_helpers.info( "   and selectorToolList      = %s" % self.selectorToolList )
-        logAODSelect_helpers.info( "   and userDataToolList      = %s" % self.userDataToolList )
-        logAODSelect_helpers.info( "   and associationToolList   = %s" % self.associationToolList )
-        logAODSelect_helpers.info( "   and outputAssociationList = %s" % self.outputAssociationList )
+        logAODSelect_helpers.info( "Found an AODSelectAlgConfig with name = %s", self.name )
+        logAODSelect_helpers.info( "   and inputTypeAndKey       = %s", self.inputTypeAndKey )
+        logAODSelect_helpers.info( "   and inputType             = %s", self.inputType )
+        logAODSelect_helpers.info( "   and inputKey              = %s", self.inputKey )
+        logAODSelect_helpers.info( "   and outputCollection      = %s", self.outputCollection )
+        logAODSelect_helpers.info( "   and outputLinkCollection  = %s", self.outputLinkCollection )
+        logAODSelect_helpers.info( "   and selectorToolList      = %s", self.selectorToolList )
+        logAODSelect_helpers.info( "   and userDataToolList      = %s", self.userDataToolList )
+        logAODSelect_helpers.info( "   and associationToolList   = %s", self.associationToolList )
+        logAODSelect_helpers.info( "   and outputAssociationList = %s", self.outputAssociationList )
         return
 
     pass
diff --git a/PhysicsAnalysis/AnalysisCommon/AssociationUtils/Root/MuJetOverlapTool.cxx b/PhysicsAnalysis/AnalysisCommon/AssociationUtils/Root/MuJetOverlapTool.cxx
index 64c4a14e69c72b03fa8b2b4b9389a9e21672fd62..11f292444ed5061b85e941cfb5ddd5ed1b55a7fc 100644
--- a/PhysicsAnalysis/AnalysisCommon/AssociationUtils/Root/MuJetOverlapTool.cxx
+++ b/PhysicsAnalysis/AnalysisCommon/AssociationUtils/Root/MuJetOverlapTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 // System includes
@@ -172,8 +172,16 @@ namespace ORUtils
         // Don't reject jets with high track multiplicity and
         // high relative PT ratio
         bool highNumTrk = nTrk >= m_numJetTrk;
-        bool highRelPt = (muon->pt()/jet->pt() < m_muJetPtRatio ||
-                          muon->pt()/sumTrkPt < m_muJetTrkPtRatio);
+        bool highRelPt = false;
+
+	if (sumTrkPt < FLT_MIN){
+	  highRelPt = (muon->pt()/jet->pt() < m_muJetPtRatio);
+	}
+	else{
+	  highRelPt = (muon->pt()/jet->pt() < m_muJetPtRatio ||
+		       muon->pt()/sumTrkPt < m_muJetTrkPtRatio);
+	}
+
         if(highNumTrk && (!m_applyRelPt || highRelPt)) continue;
 
         if(m_dRMatchCone1->objectsMatch(*muon, *jet)){
diff --git a/PhysicsAnalysis/AnalysisCommon/ParticleBuilderOptions/CMakeLists.txt b/PhysicsAnalysis/AnalysisCommon/ParticleBuilderOptions/CMakeLists.txt
index 79be0526cbefa896e94eff23d2f6ee0b47d618da..04e0ca4d1a59e1e4c4dfb2cfbacbacecffd02df3 100644
--- a/PhysicsAnalysis/AnalysisCommon/ParticleBuilderOptions/CMakeLists.txt
+++ b/PhysicsAnalysis/AnalysisCommon/ParticleBuilderOptions/CMakeLists.txt
@@ -1,11 +1,8 @@
-################################################################################
-# Package: ParticleBuilderOptions
-################################################################################
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 # Declare the package name:
 atlas_subdir( ParticleBuilderOptions )
 
 # Install files from the package:
-atlas_install_python_modules( python/__init__.py python/AODFlags.py )
+atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 atlas_install_joboptions( share/*.py )
-
diff --git a/PhysicsAnalysis/AnalysisCommon/ParticleBuilderOptions/python/AODFlags.py b/PhysicsAnalysis/AnalysisCommon/ParticleBuilderOptions/python/AODFlags.py
index 7f4071058ee03af77e9d0192cbd60fd8bcba2ea1..79747bf2298ab15edd72470c26dfb49e145a8390 100755
--- a/PhysicsAnalysis/AnalysisCommon/ParticleBuilderOptions/python/AODFlags.py
+++ b/PhysicsAnalysis/AnalysisCommon/ParticleBuilderOptions/python/AODFlags.py
@@ -21,7 +21,6 @@ __doc__="AOD Building specific flags . "
 #=======================================================================
 from AthenaCommon.JobProperties import JobProperty, JobPropertyContainer
 from AthenaCommon.JobProperties import jobproperties
-from AthenaCommon.Constants import *
 
 #=======================================================================
 # Define AOD properties by class, keeping compatibily with
@@ -257,7 +256,7 @@ class AODFlagsContainer(JobPropertyContainer):
             o=self.__dict__.get(k)
             if hasattr(o,'StoredValue'):
                 if o.statusOn and o.allowedTypes==['bool']:
-                    if o.get_Value()==True:
+                    if o.get_Value() is True:
                         print (format % (o.__name__, "ON"))
                     else:
                         print (format % (o.__name__, "--"))
diff --git a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/CMakeLists.txt b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/CMakeLists.txt
index eef90fc570c5dc895b1866925ebd16399c80f88b..6fa96ca41a5072e718fd8537d098a26d49b96ca4 100644
--- a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/CMakeLists.txt
+++ b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/CMakeLists.txt
@@ -1,7 +1,4 @@
-# $Id: CMakeLists.txt 795961 2017-02-07 12:53:47Z jcatmore $
-################################################################################
-# Package: ThinningUtils
-################################################################################
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 # Declare the package name:
 atlas_subdir( ThinningUtils )
@@ -9,15 +6,15 @@ atlas_subdir( ThinningUtils )
 # Extra dependencies, based on the build environment:
 set( extra_libs )
 if( NOT XAOD_ANALYSIS )
-   set( extra_libs CaloEvent TrigDecisionToolLib )
+   set( extra_libs CaloEvent TrkTrack TrigDecisionToolLib )
 endif()
 
 # Component(s) in the package:
 atlas_add_component(ThinningUtils
    src/*.h src/*.cxx src/components/*.cxx
-   LINK_LIBRARIES AthLinks AthenaBaseComps AthenaKernel StoreGateLib SGtests EventInfo xAODBase
-   xAODCaloEvent xAODEgamma xAODJet xAODMuon xAODParticleEvent xAODTau
-   xAODTracking xAODTruth GaudiKernel InDetReadoutGeometry TRT_ReadoutGeometry ExpressionEvaluationLib TrkToolInterfaces MCTruthClassifierLib DerivationFrameworkInterfaces ${extra_libs})
+   LINK_LIBRARIES AthContainers AthLinks AthenaBaseComps StoreGateLib EventInfo xAODBase
+   xAODCaloEvent xAODEgamma xAODJet xAODMuon xAODParticleEvent xAODPFlow xAODTau
+   xAODTracking xAODTruth GaudiKernel InDetReadoutGeometry TRT_ReadoutGeometry ExpressionEvaluationLib MCTruthClassifierLib DerivationFrameworkInterfaces ${extra_libs})
 
 # Install files from the package:
-atlas_install_python_modules( python/*.py )
+atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
diff --git a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinInDetForwardTrackParticles.py b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinInDetForwardTrackParticles.py
index 299fca369b22c0ca46a137a96d84c5be3fd9e913..93d33ee337444768ef9ce29e2fd95a438459d20d 100644
--- a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinInDetForwardTrackParticles.py
+++ b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinInDetForwardTrackParticles.py
@@ -17,8 +17,7 @@ class ThinInDetForwardTrackParticles(Configured):
                                       and  any(InDetKeys.xAODForwardTrackParticleContainer() in elements
                                              for elements in inputFileSummary['eventdata_items']))
         if not have_InDetForwardParticles and ( not InDetFlags.doForwardTracks() or not InDetFlags.doParticleCreation() ) :
-            mlog.error("Not attempting to thin InDetForwardParticles, because the container %s does not seem to be available"
-                       % (InDetKeys.xAODForwardTrackParticleContainer()))
+            mlog.error("Not attempting to thin InDetForwardParticles, because the container %s does not seem to be available", InDetKeys.xAODForwardTrackParticleContainer())
             return True
 
         mlog.info('entering')
diff --git a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinNegativeEnergyNeutralPFOs.py b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinNegativeEnergyNeutralPFOs.py
index b56039744a6b65fd23a336d6f2b2a42b44cf7b55..3f1e500ae4c612dbe05ef5a10e1f28dd49794881 100644
--- a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinNegativeEnergyNeutralPFOs.py
+++ b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinNegativeEnergyNeutralPFOs.py
@@ -17,11 +17,13 @@ class ThinNegativeEnergyNeutralPFOs(Configured):
                 ThinNegativeEnergyNeutralPFOs = True,
                 StreamName = 'StreamAOD'
             )
+            from RecExConfig.ObjKeyStore import cfgKeyStore
+            if cfgKeyStore.isInInput('xAOD::FlowElementContainer', 'JetETMissNeutralFlowElements',):
+                theNegativeEnergyNeutralPFOsThinner.NeutralPFOsFEKey = "JetETMissNeutralFlowElements"
             print (theNegativeEnergyNeutralPFOsThinner)
 
             CHSnPFOsThinAlg = None
 
-            from RecExConfig.ObjKeyStore import cfgKeyStore
 
             from JetRec.JetRecFlags import jetFlags
             if (jetFlags.useTracks or
diff --git a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinTrkTrack.py b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinTrkTrack.py
index 670f3077cfbe68431fa0c9880dcf4b1806c7f676..1dc9bb3a58df59f6e1c1733f122c5f08b7077f99 100644
--- a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinTrkTrack.py
+++ b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/ThinTrkTrack.py
@@ -1,10 +1,7 @@
-# Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
-
-from __future__ import print_function
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 from RecExConfig.Configured import Configured
 from AthenaCommon.Logging import logging
-from AthenaCommon.AthenaCommonFlags  import athenaCommonFlags
 
 class ThinTrkTrack(Configured):    
     def configure(self):
@@ -28,8 +25,6 @@ class ThinTrkTrack(Configured):
                 GSFTrackKey="GSFTracks",
                 StreamName='StreamAOD')
             
-            from AthenaCommon.Constants import VERBOSE, DEBUG, INFO, ERROR           
-            #theTrkTrackThinner.OutputLevel=DEBUG            
             print (theTrkTrackThinner)
 
         except Exception:
diff --git a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/TrkTrackPostExecStream.py b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/TrkTrackPostExecStream.py
index 2e6f2d911e1c40fbcea889cd7cc5b08cd429b774..245ec4d1ad3068c3797ea40b5486f46a0bcf21c3 100644
--- a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/TrkTrackPostExecStream.py
+++ b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/python/TrkTrackPostExecStream.py
@@ -1,8 +1,7 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 from RecExConfig.Configured import Configured
 from AthenaCommon.Logging import logging
-from AthenaCommon.AthenaCommonFlags  import athenaCommonFlags
 
 class TrkTrackPostExecStream(Configured):
     
diff --git a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/src/ThinNegativeEnergyNeutralPFOsAlg.cxx b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/src/ThinNegativeEnergyNeutralPFOsAlg.cxx
index 42caf7ee5f6dac9db05fc098eb0b329559745283..c5ba04c5a0c7264100bfab1831fb69b2cc02af4c 100644
--- a/PhysicsAnalysis/AnalysisCommon/ThinningUtils/src/ThinNegativeEnergyNeutralPFOsAlg.cxx
+++ b/PhysicsAnalysis/AnalysisCommon/ThinningUtils/src/ThinNegativeEnergyNeutralPFOsAlg.cxx
@@ -102,7 +102,7 @@ StatusCode ThinNegativeEnergyNeutralPFOsAlg::execute()
 
     const EventContext& ctx = Gaudi::Hive::currentContext();
     
-    if(!m_neutralPFOsFEKey.key().empty()){
+    if(!m_neutralPFOsKey.key().empty()){
 
         // Retrieve the container
         SG::ThinningHandle<xAOD::PFOContainer> neutralPFOs (m_neutralPFOsKey, ctx);
diff --git a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/CaloCellD3PDObject.py b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/CaloCellD3PDObject.py
index f4f0e8af5cf90defb7508311a740ef5c1177450b..353b616e9ba628ee61e4827d324348c8b00bc2b5 100644
--- a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/CaloCellD3PDObject.py
+++ b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/CaloCellD3PDObject.py
@@ -6,7 +6,6 @@ import EventCommonD3PDMaker
 from D3PDMakerCoreComps.D3PDObject import D3PDObject
 from CaloIdentifier import SUBCALO
 from CaloD3PDMaker.makeCaloCellFilterAlg import makeCaloCellFilterAlg 
-from AthenaCommon.AppMgr import ServiceMgr as svcMgr
 
 prefix_to_det = {}
 prefix_to_det["cc_sel_"] = [SUBCALO.LAREM,SUBCALO.LARHEC,SUBCALO.LARFCAL,SUBCALO.TILE] 
@@ -102,9 +101,9 @@ def makeCaloCellD3PDObject (maker, prefix, object_name) :
                                 SavePositionInfo=True,
                                 )
 
-    from CaloTools.CaloNoiseToolDefault import CaloNoiseToolDefault
-    theCaloNoiseTool = CaloNoiseToolDefault()
-    svcMgr.ToolSvc+=theCaloNoiseTool
+    noiseType = "totalNoise"
+    from CaloTools.CaloNoiseCondAlg import CaloNoiseCondAlg
+    CaloNoiseCondAlg(noisetype=noiseType)
 
     cellD3PDObject.defineBlock (3, 'Detail3',
                                 CaloD3PDMaker.CaloCellDetailsFillerTool,
@@ -116,7 +115,7 @@ def makeCaloCellD3PDObject (maker, prefix, object_name) :
                                 SaveId =False,
                                 SavePositionInfo=False,
                                 SaveSigma = True,
-                                NoiseTool = theCaloNoiseTool
+                                CaloNoise = noiseType
                                 )
 
     # Raw eta/phi --- off by default.
@@ -160,11 +159,9 @@ def makeCaloCellSlimmedD3PDObject (maker, prefix, object_name) :
                                 WriteE  = True,  WriteM = False, WritePt = False)
 
 
-    from CaloTools.CaloNoiseToolDefault import CaloNoiseToolDefault
-    theCaloNoiseTool = CaloNoiseToolDefault()
-    svcMgr.ToolSvc+=theCaloNoiseTool
-
-
+    noiseType = "totalNoise"
+    from CaloTools.CaloNoiseCondAlg import CaloNoiseCondAlg
+    CaloNoiseCondAlg(noisetype=noiseType)
 
     cellD3PDObject.defineBlock (1, 'Detail1',
                                 CaloD3PDMaker.CaloCellDetailsFillerTool,
@@ -173,9 +170,9 @@ def makeCaloCellSlimmedD3PDObject (maker, prefix, object_name) :
                                 SaveSigma = True,
                                 SaveId = True,
                                 SaveDetInfo=True,
-                                NoiseTool = theCaloNoiseTool
+                                CaloNoise = noiseType
                                )
 
-    return cellD3PDObject 
+    return cellD3PDObject
 
 SelCaloCellSlimmedD3PDObject = makeCaloCellSlimmedD3PDObject(makeCellD3PDObject, 'cc_sel_', 'SelCaloCellSlimmedD3PDObject')
diff --git a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/MBTSTriggerBitsD3PDObject.py b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/MBTSTriggerBitsD3PDObject.py
deleted file mode 100644
index a7ff4de17e75267bd9898ceb7f82bf4a00c56bf1..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/MBTSTriggerBitsD3PDObject.py
+++ /dev/null
@@ -1,19 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# $Id$
-#
-# @file CaloD3PDMaker/python/MBTSTriggerBitsD3PDObject.py
-# @author scott snyder <snyder@bnl.gov>
-# @date Mar, 2010
-# @brief MBTS trigger bits.
-#
-
-import TriggerD3PDMaker
-from D3PDMakerCoreComps.D3PDObject import make_Void_D3PDObject
-
-MBTSTriggerBitsD3PDObject = \
-           make_Void_D3PDObject (default_object_name = 'MBTSTriggerBitsD3PDObject', default_name = 'MBTSTriggerBits')
-MBTSTriggerBitsD3PDObject.defineBlock (0, 'MBTSTriggerBits',
-                                       TriggerD3PDMaker.TriggerBitFillerTool,
-                                       Triggers = ['L1_MBTS_.*'])
-
diff --git a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/ZDCTriggerBitsD3PDObject.py b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/ZDCTriggerBitsD3PDObject.py
deleted file mode 100644
index b7f8b9e88df254f78202df3e619273d61cb878f8..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/ZDCTriggerBitsD3PDObject.py
+++ /dev/null
@@ -1,17 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# $Id$
-#
-# @file CaloD3PDMaker/python/ZDCTriggerBitsD3PDObject.py
-# @author scott snyder <snyder@bnl.gov>
-# @date Aug, 2010
-# @brief ZDC trigger bits.
-#
-
-
-from TriggerD3PDMaker.defineTriggerBits import defineTriggerBits
-from D3PDMakerCoreComps.D3PDObject      import make_Void_D3PDObject
-
-ZDCTriggerBitsD3PDObject = \
-           make_Void_D3PDObject (default_object_name = 'ZDCTriggerBitsD3PDObject', default_name = 'ZDCTriggerBits')
-defineTriggerBits (ZDCTriggerBitsD3PDObject, 0, 'L1_ZDC')
diff --git a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/makeCaloCellFilterAlg.py b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/makeCaloCellFilterAlg.py
index 8671615b15703fb4aa91882a4b19318dedeeb8bf..18288acd0988eff08b3ffa5f943688c234056797 100644
--- a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/makeCaloCellFilterAlg.py
+++ b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/python/makeCaloCellFilterAlg.py
@@ -1,7 +1,6 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 from CaloIdentifier import SUBCALO
-from AthenaCommon.AppMgr import ServiceMgr as svcMgr
 
 def makeCaloCellFilterAlg( CellsName = "AllCalo",
                            OutputCellsName="SelectedCells",
@@ -16,10 +15,10 @@ def makeCaloCellFilterAlg( CellsName = "AllCalo",
     caloCellFilter.CaloNums=CaloNums
     caloCellFilter.CaloSamplings=CaloSamplings
 
-    from CaloTools.CaloNoiseToolDefault import CaloNoiseToolDefault
-    theCaloNoiseTool = CaloNoiseToolDefault()
-    svcMgr.ToolSvc+=theCaloNoiseTool
-    caloCellFilter.NoiseTool = theCaloNoiseTool
+    noiseType = "totalNoise"
+    from CaloTools.CaloNoiseCondAlg import CaloNoiseCondAlg
+    CaloNoiseCondAlg(noisetype=noiseType)
+    caloCellFilter.CaloNoise = noiseType
 
     caloCellFilter.CellsName = CellsName
     caloCellFilter.OutputCellsName = OutputCellsName 
diff --git a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellDetailsFillerTool.cxx b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellDetailsFillerTool.cxx
index 956af17ff27fa1fa64965ed59a7cf0a81da71ca0..89354090bc3ba929ac3db1c9b5ec788d689708dc 100755
--- a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellDetailsFillerTool.cxx
+++ b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellDetailsFillerTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 // $Id$
@@ -24,7 +24,7 @@
 
 #include "CaloEvent/CaloCell.h"
 #include "AthenaKernel/errorcheck.h"
-#include "CaloInterface/ICaloNoiseTool.h"
+#include "StoreGate/ReadCondHandle.h"
 #include <sstream>
 #include <cmath>
 
@@ -45,7 +45,7 @@ CaloCellDetailsFillerTool::CaloCellDetailsFillerTool
 	m_saveDetInfo(false),m_saveTimeInfo(false),m_saveCellStatus(false),
 	m_saveId(false),m_savePosition(false), m_saveSigma(false),
     m_pb_tool("CaloBadChanTool"),
-    m_useNoiseTool(false)
+    m_useNoise(false)
 {
 
   declareProperty("SaveCellGain",m_saveCellGain);
@@ -58,7 +58,6 @@ CaloCellDetailsFillerTool::CaloCellDetailsFillerTool
   declareProperty("SaveSigma",m_saveSigma);
 
   declareProperty("BadChannelTool",m_pb_tool);
-  declareProperty("NoiseTool",m_noise_tool);
 
   m_fitQCells = 0;
   m_gainCells = 0;
@@ -102,14 +101,14 @@ StatusCode CaloCellDetailsFillerTool::book()
 
 
   // retrieve the noise tool
-  if(m_saveSigma) m_useNoiseTool = true;
-  if(m_useNoiseTool) {
-     if(!m_noise_tool.empty()){
-       CHECK (m_noise_tool.retrieve() );
+  if(m_saveSigma) m_useNoise = true;
+  if(m_useNoise) {
+    if(!m_caloNoiseKey.empty()){
+      ATH_CHECK( m_caloNoiseKey.initialize() );
     } else {
-       ATH_MSG_ERROR( "CellFillerTool::book() : m_noise_tool empty."
+       ATH_MSG_ERROR( "CellFillerTool::book() : CaloNoise empty."
                       << "Information on cell noise will not be stored" );
-      m_useNoiseTool = false;
+      m_useNoise = false;
     }
   }
 
@@ -151,7 +150,10 @@ StatusCode CaloCellDetailsFillerTool::fill ( const CaloCell& c)
   if (m_saveId)       *m_offId = id.get_identifier32().get_compact()     ;
   if (m_saveCellStatus)    *m_badCell = m_pb_tool->caloStatus(id).packedData() ;
 
-  if (m_useNoiseTool && m_saveSigma)  *m_sigma = m_noise_tool-> getNoise(cell);
+  if (m_useNoise && m_saveSigma) {
+    SG::ReadCondHandle<CaloNoise> caloNoise{m_caloNoiseKey};
+    *m_sigma = caloNoise-> getNoise(cell->ID(), cell->gain());
+  }
 
   return StatusCode::SUCCESS ;
 }
diff --git a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellDetailsFillerTool.h b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellDetailsFillerTool.h
index d10d7d5dde54ed13395e00a85c952bdd0a8f4760..44cbf6f9195d6ac2fd30d2ec7e389d6a710a0ce3 100755
--- a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellDetailsFillerTool.h
+++ b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellDetailsFillerTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef CALOD3PDMAKER_CALOCELLDETAILSFILLERTOOL_H
@@ -15,7 +15,8 @@
 #include "CaloEvent/CaloCellContainer.h"
 #include "GaudiKernel/ToolHandle.h" 
 #include "CaloConditions/ICaloBadChanTool.h"
-#include "CaloInterface/ICaloNoiseTool.h"
+#include "CaloConditions/CaloNoise.h"
+#include "StoreGate/ReadCondHandleKey.h"
 
 class LArEM_ID;
 class LArFCAL_ID;
@@ -71,10 +72,14 @@ private:
     bool m_saveSigma;
 
     ToolHandle<ICaloBadChanTool> m_pb_tool;
-    ToolHandle<ICaloNoiseTool> m_noise_tool;
+   /**
+    * @brief Key of the CaloNoise Conditions data object.
+    * Typical values are '"electronicNoise', 'pileupNoise', or '"totalNoise'
+    */
+   SG::ReadCondHandleKey<CaloNoise> m_caloNoiseKey{this,
+        "CaloNoise", "", "Calo noise object name"};
 
-
-    // variables to be in ntuple.  
+    // variables to be in ntuple.
 
     float * m_xCells;
     float * m_yCells;
@@ -87,7 +92,7 @@ private:
     unsigned int * m_offId;
     float * m_sigma;
 
-    bool m_useNoiseTool;
+    bool m_useNoise;
     
 
 };
diff --git a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellFilterAlg.cxx b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellFilterAlg.cxx
index a94c38f473b2bc780d5a693b71d2c1a40987254b..c2203e822bb819520265f311c1b4cc8107cdf371 100755
--- a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellFilterAlg.cxx
+++ b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellFilterAlg.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 // $Id$
@@ -10,15 +10,13 @@
 
 // Gaudi/Athena include(s):
 #include "AthenaKernel/errorcheck.h"
+#include "StoreGate/ReadCondHandle.h"
 
 // EDM include(s):
 #include "CaloEvent/CaloCellContainer.h"
 #include "CaloIdentifier/CaloID.h"
 #include "AthContainers/ConstDataVector.h"
 
-// Tool(s):
-#include "CaloInterface/ICaloNoiseTool.h"
-
 // Local include(s):
 #include "CaloCellFilterAlg.h"
 
@@ -33,7 +31,6 @@ CaloCellFilterAlg::CaloCellFilterAlg( const std::string& name,
      m_fcalid( 0 ),
      m_hecid( 0 ),
      m_tileid( 0 ),
-     m_noise_tool( "" ),
      m_caloSelection( false ),
      m_caloSamplingSelection( false ) {
 
@@ -51,8 +48,6 @@ CaloCellFilterAlg::CaloCellFilterAlg( const std::string& name,
    declareProperty( "CellSigmaCut", m_sigmaCut );
    // list of calo samplings to treat
    declareProperty( "CaloSamplings", m_caloSamplings );
-
-   declareProperty( "NoiseTool", m_noise_tool );
 }
 
 StatusCode CaloCellFilterAlg::initialize() {
@@ -78,9 +73,7 @@ StatusCode CaloCellFilterAlg::initialize() {
    CHECK( detStore()->retrieve( m_hecid ) );
    CHECK( detStore()->retrieve( m_tileid ) );
 
-   if( ! m_noise_tool.empty() ) {
-      CHECK( m_noise_tool.retrieve() );
-   }
+   ATH_CHECK( m_caloNoiseKey.initialize(SG::AllowEmpty) );
 
    const unsigned int nSubCalo = static_cast< int >( CaloCell_ID::NSUBCALO );
 
@@ -161,7 +154,7 @@ StatusCode CaloCellFilterAlg::execute() {
    int index = 0;
 
    bool useNoiseCut = false;
-   if( ! m_noise_tool.empty() ) useNoiseCut = true;
+   if( ! m_caloNoiseKey.empty() ) useNoiseCut = true;
 
    for( ; f_cell != l_cell; ++f_cell ) {
 
@@ -204,7 +197,8 @@ StatusCode CaloCellFilterAlg::execute() {
             }
 
             if( useNoiseCut ) {
-               float sigma = m_noise_tool->getNoise( cell );
+               SG::ReadCondHandle<CaloNoise> caloNoise{m_caloNoiseKey};
+               float sigma = caloNoise->getNoise( cell->ID(), cell->gain() );
                if( std::abs( e ) < sigma * m_sigmaCut ) continue;
             }
 
diff --git a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellFilterAlg.h b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellFilterAlg.h
index d1b8c99d4afc134d5725f0a2d297ebb6f56883ed..e26c6d33fd89d4c470ee94c171e5d6acb508eb80 100755
--- a/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellFilterAlg.h
+++ b/PhysicsAnalysis/D3PDMaker/CaloD3PDMaker/src/CaloCellFilterAlg.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-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 // $Id$
@@ -15,13 +15,14 @@
 // Gaudi/Athena include(s):
 #include "GaudiKernel/ToolHandle.h"
 #include "AthenaBaseComps/AthAlgorithm.h"
+#include "CaloConditions/CaloNoise.h"
+#include "StoreGate/ReadCondHandleKey.h"
 
 // Forward declaration(s):
 class LArEM_ID;
 class LArFCAL_ID;
 class LArHEC_ID;
 class TileID;
-class ICaloNoiseTool;
 
 /**
  *  @short Algorithm to filter CaloCellContainer
@@ -58,7 +59,12 @@ private:
    const LArHEC_ID  *m_hecid;
    const TileID     *m_tileid;    
 
-   ToolHandle< ICaloNoiseTool > m_noise_tool;
+   /**
+    * @brief Key of the CaloNoise Conditions data object.
+    * Typical values are '"electronicNoise', 'pileupNoise', or '"totalNoise'
+    */
+   SG::ReadCondHandleKey<CaloNoise> m_caloNoiseKey{this,
+        "CaloNoise", "", "Calo noise object name"};
 
    bool m_caloSelection;
    bool m_caloSamplingSelection;
diff --git a/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/python/CaloD3PD.py b/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/python/CaloD3PD.py
index c0a6074bf700e90ad48d2147571a0a9fb4f4ff6f..2ca3a1721723a71360e569375978afa61a86bed2 100644
--- a/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/python/CaloD3PD.py
+++ b/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/python/CaloD3PD.py
@@ -1,4 +1,4 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 # $Id: CaloD3PD.py 521798 2012-10-16 21:37:02Z ssnyder $
 #
@@ -11,9 +11,9 @@
 
 from EventCommonD3PDMaker.EventInfoD3PDObject     import EventInfoD3PDObject
 from CaloD3PDMaker.CaloCellD3PDObject             import SelCaloCellD3PDObject
-from CaloSysD3PDMaker.CaloInfoD3PDObject             import CaloInfoD3PDObject
-from CaloD3PDMaker.ClusterD3PDObject              import ClusterD3PDObject
-from CaloSysD3PDMaker.LArDigitD3PDObject             import LArDigitD3PDObject
+from CaloSysD3PDMaker.CaloInfoD3PDObject          import CaloInfoD3PDObject
+from CaloD3PDMaker.xAODClusterD3PDObject          import xAODClusterD3PDObject
+from CaloSysD3PDMaker.LArDigitD3PDObject          import LArDigitD3PDObject
 from D3PDMakerCoreComps.resolveSGKey              import testSGKey
 
 
@@ -40,7 +40,7 @@ def CaloD3PD (alg = None,
 
         alg += CaloInfoD3PDObject (10)
 
-        alg += ClusterD3PDObject (10)
+        alg += xAODClusterD3PDObject (10)
 
         lardigit_sgkey = 'LArDigitContainer_Thinned'
         if testSGKey ('LArDigitContainer', lardigit_sgkey):
diff --git a/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeCaloD3PD_topOptions.py b/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeCaloD3PD_topOptions.py
index 01240b9546752a792fb5a5664d6ea0bee7b67258..9895cb5f66e092df6102b7a64ea5bafbdb4dd395 100755
--- a/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeCaloD3PD_topOptions.py
+++ b/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeCaloD3PD_topOptions.py
@@ -43,7 +43,7 @@ rec.readAOD.set_Value_and_Lock(False)
 include ("RecExCommon/RecExCommon_topOptions.py")
 
 # D3PDMaker calo block
-from CaloD3PDMaker.CaloD3PD import CaloD3PD
+from CaloSysD3PDMaker.CaloD3PD import CaloD3PD
 alg = CaloD3PD(file = tuple_name, tuplename = 'caloD3PD')
 
 if readRaw :
diff --git a/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeCaloHitD3PD_topOptions.py b/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeCaloHitD3PD_topOptions.py
index 76cfcfbe08d013d69ba9e0b05dddfea6badb2e64..55e84683bca53b93ef1bed32aa20f866da18e8e5 100755
--- a/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeCaloHitD3PD_topOptions.py
+++ b/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeCaloHitD3PD_topOptions.py
@@ -8,7 +8,7 @@ from RecExConfig.RecFlags  import rec
 from AthenaCommon.BeamFlags import jobproperties
 from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
 from AthenaCommon.GlobalFlags import globalflags
-
+from D3PDMakerCoreComps.resolveSGKey import testSGKey
 
 athenaCommonFlags.PoolESDInput.set_Value_and_Lock(inputFiles)
 rec.readESD.set_Value_and_Lock(True)
@@ -57,3 +57,20 @@ include ("RecExCommon/RecExCommon_topOptions.py")
 from CaloSysD3PDMaker.CaloHitD3PD import CaloHitD3PD
 alg = CaloHitD3PD(file = outputNtupleFile, tuplename = 'calohitD3PD')
 
+if "writeCells" not in dir() :
+    writeCells = False
+
+if writeCells:
+    calocell_sgkey = 'AllCalo'
+    if testSGKey ('CaloCellContainer', calocell_sgkey):
+        from CaloSysD3PDMaker.CaloInfoD3PDObject import CaloInfoD3PDObject
+        alg += CaloInfoD3PDObject (10)
+        from CaloD3PDMaker.CaloCellD3PDObject import SelCaloCellD3PDObject
+        alg += SelCaloCellD3PDObject (10)
+        from CaloSysD3PDMaker.TileDetailsD3PDObject import TileDetailsD3PDObject
+        alg += TileDetailsD3PDObject ( 1, sgkey=calocell_sgkey, prefix='tile_', Kinematics_WriteEtaPhi=False)
+
+    calocluster_sgkey = 'CaloCalTopoClusters'
+    if testSGKey ('xAOD::CaloClusterContainer', calocluster_sgkey):
+        from CaloD3PDMaker.xAODClusterD3PDObject import xAODClusterD3PDObject
+        alg += xAODClusterD3PDObject (10)
diff --git a/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeSCD3PD_topOptions.py b/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeSCD3PD_topOptions.py
deleted file mode 100755
index 074e9cd58aa11b32aea6d4a141924aade968078f..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/D3PDMaker/CaloSysD3PDMaker/share/MakeSCD3PD_topOptions.py
+++ /dev/null
@@ -1,235 +0,0 @@
-# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-
-if "doSimpleSC" not in dir() : 
-     doSimpleSC = False
-
-
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.BeamFlags import jobproperties
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from AthenaCommon.GlobalFlags import globalflags
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-import math
-
-bdir = "/usatlas/u/flanni/bnl_local/"
-if "inputFile" not in dir():
-     inputFile = bdir + "mc12_14TeV.159000.ParticleGenerator_nu_E50.recon.ESD.e1564_s1499_s1504_r4327_tid01204497_00/ESD.01204497._005853.pool.root.1"
-
-athenaCommonFlags.FilesInput= [inputFile]
-athenaCommonFlags.EvtMax = -1
-
-from RecExConfig.RecFlags import rec
-rec.readESD.set_Value_and_Lock(True)
-if "outputFile" not in dir():
-     tuple_name = "test.scd3pd.root"
-else:
-    tuple_name = outputFile
-
-rec.doHist.set_Value_and_Lock(False)
-rec.doCBNT.set_Value_and_Lock(False)
-rec.doWriteTAGCOM.set_Value_and_Lock(False)
-rec.doWriteTAG.set_Value_and_Lock(False)
-rec.doWriteAOD.set_Value_and_Lock(False)
-rec.doAOD.set_Value_and_Lock(False)
-rec.doMonitoring.set_Value_and_Lock(False)
-rec.readAOD.set_Value_and_Lock(False)
-rec.doTruth.set_Value_and_Lock( True )
-rec.doTrigger.set_Value_and_Lock( True )
-
-#rec.AutoConfiguration.set_Value_and_Lock(['FieldAndGeo','BeamType', 'ConditionsTag', 'DoTruth', 'InputType']) 
-
-from D3PDMakerConfig.D3PDMakerFlags import D3PDMakerFlags
-D3PDMakerFlags.TruthSGKey = 'GEN_EVENT,GEN_AOD,TruthEvent'
-D3PDMakerFlags.DoTrigger = True
-D3PDMakerFlags.TruthWriteGeant.set_Value_and_Lock(True)
-D3PDMakerFlags.TruthWriteHadrons.set_Value_and_Lock(True)
-
-# RecExCommon
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-if doSimpleSC:
-     from LArL1Sim.LArL1SimConf import LArSCSimpleMaker
-     topSequence+=LArSCSimpleMaker()
-     
-
-# D3PDMaker calo block
-
-from D3PDMakerCoreComps.MakerAlg import *
-from CaloSysD3PDMaker.ClusterD3PDObject import *
-from CaloD3PDMaker.CaloCellD3PDObject import *
-from CaloSysD3PDMaker.CaloInfoD3PDObject import *
-from EventCommonD3PDMaker.EventInfoD3PDObject import *
-
-### L1Calo
-
-include("TileRecAlgs/TileCellToTTL1_jobOptions.py")
-
-from L1CaloD3PDMaker.L1CaloCPMHits_D3PDObject  import L1CaloCPMHits_D3PDObject
-from L1CaloD3PDMaker.L1CaloCPMRoI_D3PDObject   import L1CaloCPMRoI_D3PDObject
-from L1CaloD3PDMaker.L1CaloCPMTower_D3PDObject import L1CaloCPMTower_D3PDObject
-
-### L1Calo JEM
-from L1CaloD3PDMaker.L1CaloJEMEtSums_D3PDObject  import L1CaloJEMEtSums_D3PDObject
-from L1CaloD3PDMaker.L1CaloJEMHits_D3PDObject    import L1CaloJEMHits_D3PDObject
-from L1CaloD3PDMaker.L1CaloJEMRoI_D3PDObject     import L1CaloJEMRoI_D3PDObject
-from L1CaloD3PDMaker.L1CaloJetElement_D3PDObject import L1CaloJetElement_D3PDObject
-
-### L1Calo CMM
-from L1CaloD3PDMaker.L1CaloCMMCPHits_D3PDObject  import L1CaloCMMCPHits_D3PDObject
-from L1CaloD3PDMaker.L1CaloCMMEtSums_D3PDObject  import L1CaloCMMEtSums_D3PDObject
-from L1CaloD3PDMaker.L1CaloCMMJetHits_D3PDObject import L1CaloCMMJetHits_D3PDObject
-from L1CaloD3PDMaker.L1CaloCMMRoI_D3PDObject     import L1CaloCMMRoI_D3PDObject
-
-from L1CaloD3PDMaker.L1CaloPPM_D3PDObject import L1CaloPPM_D3PDObject
-dbTTreeName = 'L1CaloDB'
-from L1CaloD3PDMaker.L1CaloPPMdbMC_D3PDObject import L1CaloPPMdbMC_D3PDObject
-
-from CaloSysD3PDMaker.EMClusterD3PDObject           import EMClusterD3PDObject
-from CaloSysD3PDMaker.TowerD3PDObject               import TowerD3PDObject
-from egammaD3PDMaker.ElectronD3PDObject import *
-from egammaD3PDMaker.PhotonD3PDObject import *
-from TruthD3PDMaker.TruthParticleD3PDObject import *
-
-alg = MakerAlg("scD3PD", topSequence, file = tuple_name , D3PDSvc = 'D3PD::RootD3PDSvc')
-alg += EventInfoD3PDObject (10)
-alg += CaloInfoD3PDObject (10)
-alg += ElectronD3PDObject(1)
-alg += PhotonD3PDObject(1)
-alg += ClusterD3PDObject (10,sgkey="CaloCalTopoCluster")
-#alg += EMClusterD3PDObject (10)
-alg += TruthParticleD3PDObject (10)
-
-alg += L1CaloCPMHits_D3PDObject(level = 0, allowMissing = True)
-alg += L1CaloCPMRoI_D3PDObject(level = 0, allowMissing = True)
-alg += L1CaloCPMTower_D3PDObject( level=0, allowMissing = True  )
-
-alg += L1CaloJEMEtSums_D3PDObject(level = 0, allowMissing = True)
-alg += L1CaloJEMHits_D3PDObject(level = 0, allowMissing = True)
-alg += L1CaloJEMRoI_D3PDObject(level = 0, allowMissing = True)
-alg += L1CaloJetElement_D3PDObject(level = 0, allowMissing = True)
-
-alg += L1CaloCMMCPHits_D3PDObject(level = 0, allowMissing = True)
-alg += L1CaloCMMEtSums_D3PDObject(level = 0, allowMissing = True)
-alg += L1CaloCMMJetHits_D3PDObject(level = 0, allowMissing = True)
-alg += L1CaloCMMRoI_D3PDObject(level = 0, allowMissing = True)
-
-alg += L1CaloPPM_D3PDObject( 0 )
-
-myEtaCut = [0.4,0.5]
-myPhiCut = [-math.pi,math.pi]
-mySamplings = [1,2]
-myCalo=[1]
-
-from CaloSysD3PDMaker.SCD3PDObject import *
-
-#alg += AllSCD3PDObject(0, prefix='sc_')
-# alg += SCD3PDObject(0, CaloEtaCut=myEtaCut, CaloPhiCut=myPhiCut, CaloLayers=mySamplings, CaloDetectors=myCalo )
-#alg += SCD3PDObject(0, prefix='sc_ntld_') # equivalent to TileDLayerOption=False
-alg += SCD3PDObject(0, prefix='sc_', TileDLayerOption=True)
-alg += TowerD3PDObject (10)
-
-include('TrigEgammaD3PDMaker/Setup_RoILinksCnvTool_IBv2.py')
-from TriggerD3PDMaker.EmTauROID3PDObject import *
-from TrigEgammaD3PDMaker.TrigEgammaD3PD import *
-#alg += InitTrigD3PDObject(1)
-#if not hasattr( alg, "trig_L1_emtau_Filler" ):
-#     alg += EmTauROID3PDObject( 0, prefix="trig_L1_emtau", sgkey="LVL1_EMTAU")
-TrigEgammaD3PDObjects( alg, 1)
-from TrigJetD3PDMaker.TrigJetD3PD import *
-TrigJetD3PDObjects( alg, 1)
-from TrigMissingETD3PDMaker.TrigMETD3PD import TrigMETD3PDObjects
-TrigMETD3PDObjects(alg, 1)
-from TrigTauD3PDMaker.TrigTauD3PD import TrigTauD3PDObjects
-TrigTauD3PDObjects(alg, 0, False, False)
-from EventCommonD3PDMaker.LBMetadataConfig           import LBMetadataConfig
-from EventCommonD3PDMaker.CutFlowMetadataConfig        import CutFlowMetadataConfig
-from TriggerD3PDMaker.BunchStructureMetadata         import addBunchStructureMetadata
-alg.MetadataTools += [LBMetadataConfig()]
-alg.MetadataTools += [CutFlowMetadataConfig(alg)]
-addBunchStructureMetadata(alg)
-
-
-#-------------------------------------------------------------------------------
-def _args (level, name, kwin, **kw):
-    kw = kw.copy()
-    kw['level'] = level
-    for (k, v) in list(kwin.items()):
-        if k.startswith (name + '_'):
-            kw[k[len(name)+1:]] = v
-    return kw
-
-# MET objects
-from MissingETD3PDMaker.MissingETD3PDMakerFlags      import MissingETD3PDMakerFlags
-from MissingETD3PDMaker.MissingETD3PDObject          import MissingETD3PDObject
-from MissingETD3PDMaker.MissingETD3PDObject          import MissingETCompositionD3PDObject
-from MissingETD3PDMaker.MissingETGoodnessD3PDObject  import MissingETGoodnessD3PDObject
-from MissingETD3PDMaker.MissingETD3PDTriggerBitsObject import *
-MissingETD3PDMakerFlags.METDefaultJetPrefix = 'jet_AntiKt6LCTopo_MET_'
-MissingETD3PDMakerFlags.doMissingETRegions = True
-METIncludes =      ['MET_RefEle_Comps', 'MET_RefJet_Comps', 'MET_RefMuon_Comps', 'MET_SoftJets_Comps', 'MET_MuonBoy_Comps','MET_MuonBoy_Regions', 'MET_RefMuon_Staco_Comps', 'MET_RefMuon_Muid_Comps', 'MET_RefTau_Comps', 'MET_CellOut_Comps', 'MET_CellOut_Eflow_Comps', 'MET_LocHadTopo_Comps','MET_LocHadTopo_Regions', 'MET_Muon_Isol_Staco_Comps', 'MET_Muon_NonIsol_Staco_Comps', 'MET_Muon_Total_Staco_Comps', 'MET_Final_Comps', 'MET_Muon_Isol_Muid_Comps', 'MET_Muon_NonIsol_Muid_Comps', 'MET_Muon_Total_Muid_Comps', 'MET_Truth_Comps',  'MET_RefMuon_Track_Staco_Comps','MET_RefMuon_Track_Staco_Regions', 'MET_RefMuon_Track_Muid_Comps', 'MET_RefMuon_Track_Muid_Regions','MET_Track_Comps', 'MET_TopoObj_Comps', 'MET_RefFinal_em_Comps', 'MET_RefJet_em_Comps','MET_RefEle_em_Comps','MET_RefGamma_em_Comps', 'MET_RefTau_em_Comps', 'MET_CellOut_em' 'MET_RefMuon_Track_em_Comps', 'MET_SoftJets_em_Comps', 'MET_RefMuon_em_Comps', 'MET_Truth_NonInt', 'MET_Truth_NonInt_SumEt', 'MET_Truth_Int', 'MET_Truth_Int_SumEt', 'MET_RefEle_SumEt', 'MET_RefJet_SumEt', 'MET_RefMuon_SumEt', 'MET_SoftJets_SumEt', 'MET_MuonBoy_SumEt', 'MET_RefMuon_Staco_SumEt', 'MET_RefMuon_Muid_SumEt', 'MET_RefTau_SumEt', 'MET_CellOut_SumEt', 'MET_CellOut_Eflow_SumEt', 'MET_LocHadTopo_SumEt', 'MET_Muon_Isol_Staco_SumEt', 'MET_Muon_NonIsol_Staco_SumEt', 'MET_Muon_Total_Staco_SumEt', 'MET_Final_SumEt', 'MET_Muon_Isol_Muid_SumEt', 'MET_Muon_NonIsol_Muid_SumEt', 'MET_Muon_Total_Muid_SumEt', 'MET_Truth_SumEt',  'MET_RefMuon_Track_Staco_SumEt', 'MET_RefMuon_Track_Muid_SumEt', 'MET_Track_SumEt', 'MET_TopoObj_SumEt', 'MET_RefFinal_em_SumEt', 'MET_RefJet_em_SumEt','MET_RefEle_em_SumEt','MET_RefGamma_em_SumEt', 'MET_RefTau_em_SumEt', 'MET_CellOut_em' 'MET_RefMuon_Track_em_SumEt', 'MET_SoftJets_em_SumEt', 'MET_RefMuon_em_SumEt', 'MET_RefMuon_Track_Comps', 'MET_RefMuon_Track_SumEt', 'MET_Muon_Isol_Comps', 'MET_Muon_NonIsol_Comps', 'MET_Muon_Total_Comps','MET_Muon_Isol_SumEt', 'MET_Muon_NonIsol_SumEt', 'MET_Muon_Total_SumEt',  'MET_CellOut_Regions']
-
-METIncludes += [ 'MET_RefFinal_STVF','MET_CellOut_Eflow_STVF','MET_CellOut_Eflow_JetArea','MET_RefJet_JVF','MET_RefJet_JVFCut', 'MET_CellOut_Eflow_JetAreaJVF','MET_CellOut_Eflow_JetAreaRhoEta5JVF', 'MET_RefFinal_STVF_Comps' , 'MET_RefFinal_STVF_SumEt', ' MET_RefFinal_STVF_Regions']
-
-kw={}
-alg += MissingETD3PDObject(**_args (0, 'MissingEt', kw, allowMissing=True, include = METIncludes, exclude = ["MET_Cluster_Weights"]))
-
-#####Jet objects
-
-
-from JetD3PDMaker.JetD3PDObject                      import JetD3PDObject
-from JetD3PDMaker.JetD3PDMakerConf                   import *
-import JetD3PDMaker
-from JetRecTools.JetRecToolsConf                     import *
-from JetRec.JetMomentGetter                          import make_JetMomentGetter
-jetIncludes =      ['Kinematics','DQMoments','EMFraction','JESMoments','EMScale','JVtx','BTagDefault','BTag',
-                    'TrueFlavorComponents','Samplings','BTagComponents', 'Constituents', 'ConstituentScale','CaloQual',
-                    'AssocTrackCont']
-
-from QcdD3PDMaker.QcdD3PDMakerFlags  import QcdD3PDMakerFlags
-QcdD3PDMakerFlags.doHR.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doMuon.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doTau.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doElectron.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doPhoton.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doPhoton.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doTowerJet.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doTrackJet.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doGSCJet.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doTruthJet.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doMoreTrig.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doTrack.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doMET.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doClusterHad.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doMuonSpShower2.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doRecJet.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doRecJetOnlyAdditional.set_Value_and_Lock(False)
-#QcdD3PDMakerFlags.useSPESD.set_Value_and_Lock(False)
-QcdD3PDMakerFlags.doTopoJet.set_Value_and_Lock(True)
-QcdD3PDMakerFlags.doLCTopoJet.set_Value_and_Lock(True)
-
-# https://twiki.cern.ch/twiki/bin/viewauth/AtlasProtected/D3PDVariablesForPileup
-
-flags=QcdD3PDMakerFlags
-jetInclude=flags.jetInclude()
-#jetInclude+=['Samplings','BTagComponents','BTagDefault','BTag']  # for slim
-jetInclude += jetIncludes
-jetIncludeNew=flags.jetInclude()
-jetIncludeNew+=['BTagComponents','BTagDefault','BTag'] # for full
-jetExclude=flags.jetExclude()
-
-alg += JetD3PDObject(5, prefix = 'jet_AntiKt4TopoEM_',
-                     sgkey = 'AntiKt4TopoEMJets' )  
-alg += JetD3PDObject(5, prefix = 'jet_AntiKt4LCTopo_',
-                     sgkey = 'AntiKt4LCTopoJets' )  
-alg += JetD3PDObject(0, prefix = 'jet_AntiKt4Truth_',
-                     sgkey = 'AntiKt4TruthJets')  
-
-from QcdD3PDMaker.QcdEventShapeD3PDObject import EventShapeD3PDObject
-alg += EventShapeD3PDObject(**_args(0, 'rho', kw))
-
-
-#, include = jetInclude, exclude = jetExclude))
-
-        
-
-                                        
diff --git a/PhysicsAnalysis/D3PDMaker/D3PDMakerConfig/python/egammaD3PD.py b/PhysicsAnalysis/D3PDMaker/D3PDMakerConfig/python/egammaD3PD.py
index 6e7856d48593c87e243ece79a00b4fad4f185882..29bf2a9878c535195860bc009e0cfedcea3d6c2b 100644
--- a/PhysicsAnalysis/D3PDMaker/D3PDMakerConfig/python/egammaD3PD.py
+++ b/PhysicsAnalysis/D3PDMaker/D3PDMakerConfig/python/egammaD3PD.py
@@ -16,8 +16,6 @@ from MuonD3PDMaker.MuonD3PDObject             import MuonD3PDObject
 from JetD3PDMaker.JetD3PDObject               import JetD3PDObject
 from CaloD3PDMaker.MBTSD3PDObject             import MBTSD3PDObject
 from CaloD3PDMaker.MBTSTimeD3PDObject         import MBTSTimeD3PDObject
-# from CaloD3PDMaker.MBTSTriggerBitsD3PDObject  import MBTSTriggerBitsD3PDObject
-# from CaloD3PDMaker.ZDCTriggerBitsD3PDObject   import ZDCTriggerBitsD3PDObject
 from CaloD3PDMaker.LArCollisionTimeD3PDObject import LArCollisionTimeD3PDObject
 from CaloD3PDMaker.CollisionDecisionD3PDObject import CollisionDecisionD3PDObject
 from MissingETD3PDMaker.MissingETD3PDObject   import MissingETD3PDObject
@@ -293,8 +291,6 @@ def egammaD3PD (alg = None,
                                                          'DQMoments']))
     alg += MBTSD3PDObject             (**_args (level, 'MBTS', kw))
     alg += MBTSTimeD3PDObject         (**_args (level, 'MBTSTime', kw))
-    # alg += MBTSTriggerBitsD3PDObject  (**_args (level, 'MBTSTriggerBits', kw))
-    # alg += ZDCTriggerBitsD3PDObject   (**_args (level, 'ZDCTriggerBits', kw))
     alg += CollisionDecisionD3PDObject(**_args (level, 'CollisionDecision', kw))
     alg += MissingETD3PDObject (**_args (level, 'MissingET', kw,
                                          sgkey = 'MET_Core_AntiKt4EMTopo',
diff --git a/PhysicsAnalysis/D3PDMaker/TriggerD3PDMaker/python/TrigConfMetadata.py b/PhysicsAnalysis/D3PDMaker/TriggerD3PDMaker/python/TrigConfMetadata.py
index bbc000a87c1d9ff80cc5c9ed824d56929457266c..26b66437fe4413c4a6cf9efea6f7316508ae9792 100644
--- a/PhysicsAnalysis/D3PDMaker/TriggerD3PDMaker/python/TrigConfMetadata.py
+++ b/PhysicsAnalysis/D3PDMaker/TriggerD3PDMaker/python/TrigConfMetadata.py
@@ -1,6 +1,5 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-# $Id: TrigConfMetadata.py 618376 2014-09-24 15:33:35Z tamartin $
 #
 # This module holds the code that should be used to add trigger configuration
 # metadata to the D3PD.
@@ -74,10 +73,8 @@ def addTrigConfMetadata( d3pdalg = None, useTrigConfEventSummaries = False, doCo
             else: 
               logger.info( "TrigConfMetadataTool will use TriggerFlags flags for config" )
               from TriggerJobOpts.TriggerFlags import TriggerFlags
-              if TriggerFlags.doHLT() and not (TriggerFlags.doEF() or TriggerFlags.doLVL2()):
+              if TriggerFlags.doHLT():
                 _trigConfTool.keyConfig = "HLT_TrigMonConfigCollection_OPI_HLT_monitoring_config"
-              elif TriggerFlags.doEF() or TriggerFlags.doLVL2():
-                _trigConfTool.keyConfig = "HLT_TrigMonConfigCollection_OPI_EF_monitoring_config"
             logger.info( "TrigConfMetadataTool will use the StoreGate key " + _trigConfTool.keyConfig )
             d3pdalg.MetadataTools += [ _trigConfTool ]
     else:
diff --git a/PhysicsAnalysis/D3PDMaker/TruthD3PDAnalysis/src/SimpleTruthParticleFilterTool.cxx b/PhysicsAnalysis/D3PDMaker/TruthD3PDAnalysis/src/SimpleTruthParticleFilterTool.cxx
index 7ff4a1f18ba5e8b0171e76fbee66a0809654d5d7..997025e37b1f82d302b313f39a92c5a7ddcf52b1 100644
--- a/PhysicsAnalysis/D3PDMaker/TruthD3PDAnalysis/src/SimpleTruthParticleFilterTool.cxx
+++ b/PhysicsAnalysis/D3PDMaker/TruthD3PDAnalysis/src/SimpleTruthParticleFilterTool.cxx
@@ -46,12 +46,20 @@ SimpleTruthParticleFilterTool::isAccepted (const HepMC::GenParticle* p)
   bool last = std::abs(p->pdg_id())==15;
   if ( abs(p->pdg_id())==15 && p->status()!=1 && p->end_vertex() ){
     // Special handling for taus - take the ones that are last in the tau chain
+#ifdef HEPMC3
+    for (auto pit: p->end_vertex()->particles_out()){
+      if (!pit || std::abs(pit->pdg_id())!=15) continue;
+      last=false;
+      break;
+    }
+#else
     for (HepMC::GenVertex::particles_out_const_iterator pit=p->end_vertex()->particles_out_const_begin(); pit!=p->end_vertex()->particles_out_const_end();++pit){
       if (!(*pit) ||
           abs((*pit)->pdg_id())!=15) continue;
       last=false;
       break;
     }
+#endif    
     if (!last) return false;
   }
 
diff --git a/PhysicsAnalysis/D3PDMaker/TruthD3PDMaker/src/GenEventGetterFilterTool.cxx b/PhysicsAnalysis/D3PDMaker/TruthD3PDMaker/src/GenEventGetterFilterTool.cxx
index 207d15cd1a3cae923c7550e70c60b45f4e373fc9..978365b30056a6af9ad62cb81c51c6dfb41359d2 100644
--- a/PhysicsAnalysis/D3PDMaker/TruthD3PDMaker/src/GenEventGetterFilterTool.cxx
+++ b/PhysicsAnalysis/D3PDMaker/TruthD3PDMaker/src/GenEventGetterFilterTool.cxx
@@ -38,7 +38,11 @@ GenEventGetterFilterTool::GenEventGetterFilterTool
  */
 bool GenEventGetterFilterTool::filter (const HepMC::GenEvent* p) const
 {
+#ifdef HEPMC3
+  return ! p->particles().empty();
+#else
   return ! p->particles_empty();
+#endif
 }
 
 
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/CMakeLists.txt b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/CMakeLists.txt
index 8b7686551e098b9c9ecd0342d5c7a671fc895d03..fcd11a2d7a85e8430b5bec78722b0f57cdf47c9f 100644
--- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/CMakeLists.txt
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/CMakeLists.txt
@@ -11,9 +11,9 @@ atlas_add_component( DerivationFrameworkHiggs
                      src/*.cxx src/components/*.cxx
                      INCLUDE_DIRS ${CLHEP_INCLUDE_DIRS}
                      DEFINITIONS ${CLHEP_DEFINITIONS}
-                     LINK_LIBRARIES ${CLHEP_LIBRARIES} AthenaBaseComps DerivationFrameworkInterfaces TrigDecisionToolLib xAODEgamma xAODEventInfo xAODJet xAODMuon xAODTracking )
+                     LINK_LIBRARIES ${CLHEP_LIBRARIES} AthenaBaseComps DerivationFrameworkInterfaces TrigDecisionToolLib TruthRivetToolsLib TruthUtils PathResolver xAODEgamma xAODEventInfo xAODJet xAODMuon xAODTracking xAODTruth)
 
 # Install files from the package:
 atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 atlas_install_joboptions( share/*.py )
-
+atlas_install_data( share/*.cfg )
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/DerivationFrameworkHiggs/TruthCategoriesDecorator.h b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/DerivationFrameworkHiggs/TruthCategoriesDecorator.h
new file mode 100644
index 0000000000000000000000000000000000000000..206f6109c8a0d87da94e07445f58632ee7c931b3
--- /dev/null
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/DerivationFrameworkHiggs/TruthCategoriesDecorator.h
@@ -0,0 +1,87 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
+// Tool to decorate the EventInfo object with truth categories informations 
+// Authors: T. Guillemin, J. Lacey, D. Gillberg
+	
+#ifndef DerivationFrameworkHiggs_TruthCategoriesDecorator_H
+#define DerivationFrameworkHiggs_TruthCategoriesDecorator_H
+
+#include <string>
+#include <vector>
+#include <TEnv.h>
+#include <TString.h>
+#include <TSystem.h>
+
+#include "AthenaBaseComps/AthAlgTool.h"
+#include "GaudiKernel/ToolHandle.h"
+#include "DerivationFrameworkInterfaces/IAugmentationTool.h"
+
+// EDM: typedefs, so must be included and not forward-referenced
+#include "xAODTruth/TruthParticleContainer.h"
+#include "xAODEventInfo/EventInfo.h"
+
+// Note: must include TLorentzVector before the next one
+#include "TLorentzVector.h"
+#include "TruthRivetTools/HiggsTemplateCrossSectionsDefs.h"
+#include "xAODEventInfo/EventInfo.h"
+#include "xAODTruth/TruthEventContainer.h"
+#include "StoreGate/WriteDecorHandleKeyArray.h"
+
+class IHiggsTruthCategoryTool;
+class IxAODtoHepMCTool;
+
+namespace DerivationFramework {
+  
+  class TruthCategoriesDecorator : public AthAlgTool, public IAugmentationTool {
+        
+  public:
+    TruthCategoriesDecorator(const std::string& t, const std::string& n, const IInterface* p);
+    ~TruthCategoriesDecorator();
+    StatusCode initialize();
+    StatusCode finalize();
+    virtual StatusCode addBranches() const;
+
+  private:
+    ToolHandle<IxAODtoHepMCTool> m_xAODtoHepMCTool;
+    ToolHandle<IHiggsTruthCategoryTool> m_higgsTruthCatTool;
+
+    SG::WriteDecorHandleKeyArray<xAOD::EventInfo> m_eventInfoIntDecors{this, "EventInfoIntDecors", {}, "List of int EventInfo decorations to be filled"};
+    SG::WriteDecorHandleKeyArray<xAOD::EventInfo> m_eventInfoFloatDecors{this, "EventInfoFloatDecors", {}, "List of float EventInfo decorations to be filled"};
+    SG::WriteDecorHandleKeyArray<xAOD::EventInfo> m_eventInfoVectorFloatDecors{this, "EventInfoVectorFloatDecors", {}, "List of vector float EventInfo decorations to be filled"};
+    SG::ReadHandleKey<xAOD::TruthEventContainer> m_truthEventCont{this,"TruthEventCont","TruthEvents","truth event container"};
+    std::vector<std::string> m_eventInfoIntDecorNames;
+    std::vector<std::string> m_eventInfoFloatDecorNames;
+    std::vector<std::string> m_eventInfoVectorFloatDecorNames;
+
+    // Path to TEnv file containing MC-channel-numbre <-> HiggsProdMode map
+    TEnv *m_config;
+    std::string m_configPath;
+
+    // Detail level. Steers amount of decoration.
+    //  0: basic information. Categoization ints, Higgs prod mode, Njets, Higgs pT
+    //  1: the above + Higgs boson 4-vec + associated V 4-vec
+    //  2: the above + truth jets built excluding the Higgs boson decay
+    //  3: the above + 4-vector sum of all decay products from Higgs boson and V-boson
+    int m_detailLevel;
+    
+    // methods to locate the TEnv input file
+    bool fileExists(TString fileName) { return gSystem->AccessPathName(fileName) == false; }
+
+    // Converts a string to a vector of integers
+    std::vector<int> vectorize(TString string, TString sep=" ") const;
+  
+    // Method to access the production mode for a given MC channel number
+    HTXS::HiggsProdMode getHiggsProductionMode(uint32_t mc_channel_number,HTXS::tH_type &th_type) const;
+ 
+    // Methods for decoration of four vectors
+    float getFloatDecor(const std::string key, const TLorentzVector p4) const;
+    std::vector<float> getVectorFloatDecor(const std::string key, const std::vector<TLorentzVector> p4s) const;
+
+
+  }; /// class
+  
+} /// namespace
+
+#endif
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/python/TruthCategories.py b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/python/TruthCategories.py
new file mode 100644
index 0000000000000000000000000000000000000000..a3c3bbf93a93db7678bad236ebc4b976e747ff89
--- /dev/null
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/python/TruthCategories.py
@@ -0,0 +1,15 @@
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+
+from DerivationFrameworkCore.DerivationFrameworkMaster import DerivationFrameworkIsMonteCarlo,DerivationFrameworkJob
+from AthenaCommon.AppMgr import ToolSvc
+from AthenaCommon import CfgMgr
+
+if DerivationFrameworkIsMonteCarlo:
+
+    from DerivationFrameworkHiggs.DerivationFrameworkHiggsConf import DerivationFramework__TruthCategoriesDecorator
+    DFHTXSdecorator = DerivationFramework__TruthCategoriesDecorator(name = "DFHTXSdecorator")
+
+    ToolSvc += DFHTXSdecorator
+    DerivationFrameworkJob += CfgMgr.DerivationFramework__CommonAugmentation("TruthCategoriesCommonKernel",
+                                                                             AugmentationTools = [DFHTXSdecorator]
+                                                                             )
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/share/HiggsMCsamples.cfg b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/share/HiggsMCsamples.cfg
new file mode 100644
index 0000000000000000000000000000000000000000..ac0c2a1e12b3bc0a4636468d111f348d40c902ea
--- /dev/null
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/share/HiggsMCsamples.cfg
@@ -0,0 +1,267 @@
+######################################################
+#
+# List of MC channel number for each Higgs MC sample of a given production mode.
+# Used by the Higgs boson simplified template cross section tool (HTXS)
+#
+# If two derviations use the same MCID it only needs to be listed one time 
+# (but it doesn't hurt to have it listed several times, as long as it's only for one production mode of course ;)
+#
+# Note: this follows the TEnv format. A config key-nmae folowed by MCIDs as "values".
+# MCIDs shoudl be space-separated (sveral space charcters are fine).
+# When adding MC IDs to a existing config key you need to start with a + character
+#
+######################################################
+
+
+HTXS.MCsamples.GGF:    341272 342172
+HTXS.MCsamples.VBF:    20672
+HTXS.MCsamples.WH:     342284
+HTXS.MCsamples.QQ2ZH:  341463
+HTXS.MCsamples.GG2ZH:  341099
+HTXS.MCsamples.TTH:    341271 342561
+HTXS.MCsamples.THQB:   343269
+HTXS.MCsamples.WHT:    341997 346486
+HTXS.MCsamples.BBH:    342097
+
+###############
+#  HGam samples
+#  i.e. HIGG1D1, HIGG1D2
+#
+
+  # mH=125, and MPI_OFF
++HTXS.MCsamples.GGF:     341000 342560 343981 345316 345415 345416 345417 345944
+  # mH = 60, 80, 100, 105 ... 150 ... 2000
++HTXS.MCsamples.GGF:     342020 342023 342008 342057 342058 342059 342060 342061 342062 342063 342064 342010 342012 342013 342014 342015
++HTXS.MCsamples.GGF:	 341445
++HTXS.MCsamples.GGF:     342016 342017 342018 342019 342021 342022 342024 342007 342009 342011 342607 342608 342609 342610 342611 
+  # special samples
++HTXS.MCsamples.GGF:     342612 342613 342614 342615 343470 343471 343472 343473 343474 345307 345308 345309 345310 345311 345312 345313 345314 345306 345961 346665 346666 346667
+
++HTXS.MCsamples.VBF:     341001 342026 342065 342066 342067 342068 342069 342070 342071 342072 342034 342036 342029 342030 342031 342032
++HTXS.MCsamples.VBF:     342033 342035 342025 342027 342028 345041 345042 345434 345435 345436 345437 345438 345439 345440 345441 345442 345443 345444 345448 345449 345450 345451 345452 345453 345454 345455 345834 346214
+
++HTXS.MCsamples.WH:      341067 342260 342073 342074 342075 342076 342077 342078 342079 342080 342258 342259 342261
++HTXS.MCsamples.WH:	 342262 342263 342264 342265 342266 342267 342268 342269 345317 345318 345320 345321 345548 345549 345550 345551 345552 345553 345554 345555 345556 345557 345558 345559 345560 345561 345562 345563 345963 345964
+
++HTXS.MCsamples.QQ2ZH:   341068 342272 342081 342082 342083 342084 342085 342086 342087 342088 342270 342271 342273 342274 342275 342276
++HTXS.MCsamples.QQ2ZH:   342277 342278 342279 342280 342281 345319 345322 345200 345201 345202 345204 345207 345208 345209 345210 345965
+  # HIGG1 gg -> ZH 
++HTXS.MCsamples.GG2ZH: 345061 345266 345267 345268 345269 345270 345271 345272 345273
+  #mH125, Pythia, aMC@NLO+Py8, aMC@NLO+HwPP
++HTXS.MCsamples.TTH:     341069 343436 341081 345863 345934 345932 346189
+  # Py8 mH=60..2000 GeV
++HTXS.MCsamples.TTH:     342046 342048 342038 342041 342042 342043 342044 342045 342047 342037 342039 342040 
+  # aMC@NLO+HwPP mH=100..150 GeV
++HTXS.MCsamples.TTH:     341976 341977 341978 341979 341980 341981 341982 341983 341984 341985 346303 346304
+  # aMCnloPy8
++HTXS.MCsamples.BBH:     342097 342098 343080 343081 343085 343086 343072 345315
+  # aMCnloPy8
++HTXS.MCsamples.THQB:    341988 341989 341990 343266 343267 343268 345933 346188 346221
++HTXS.MCsamples.WHT:     341998 341999
+
+###############
+#  HZZ samples
+#  i.e. HIGG2D* derivation
+#
+# https://twiki.cern.ch/twiki/bin/view/AtlasProtected/HZZllllRun2MCSamplesMC15c_25ns
+# Signal Samples, low mass
+# ggF
++HTXS.MCsamples.GGF:    341471 341500 341502 341504 341505 341506 341508 341510 346695 346701
+# VBF
++HTXS.MCsamples.VBF:    341488 341513 341515 341517 341518 341519 341521 341523 346228 346696 346702
+# ZH
++HTXS.MCsamples.QQ2ZH:  341946 341947 341948 341975 346698 346704 346645
+# WH
++HTXS.MCsamples.WH:     341963 341964 341965 346699 346700 346705 346706 346646 346647
+# ttH
++HTXS.MCsamples.TTH:    342561 342562 342563 342564 342565 342566 342567 342568 342569 345046 345047 345048 345936 346340 346341 346342
+# ggF EFT
++HTXS.MCsamples.GGF:    344158 344159 344160 344161 344162 344163 344164 344165 344166 344167 344169 344170 
++HTXS.MCsamples.GGF:    346574 346575 346576 346577 346578
+# VBF EFT
++HTXS.MCsamples.VBF:    343247 343248 343249 343250 343251 343252 343253 343254 343255 343256 343257 343258 343259 343260 343261 343262
++HTXS.MCsamples.VBF:    346608 346609 346610 346611 346612 346613 346614 346615 346616 346617 346618 346619 346620 346621 346622 346623 346624 346625 346626 346627 346628 346629 346630 346631
++HTXS.MCsamples.VBF:    346579 346580 346581 346582
+# ttH EFT
++HTXS.MCsamples.TTH:    346585 346586
+# VH EFT
+#    skip because cannot be separated into WH and QQ2ZH
+#                       344135 344136 344137 344138 344139 344140 344141 344142 344143 344144 344145 344146 344147 344148 344149 344150 344151
+#
+
++HTXS.MCsamples.WHT:    345966 346511
++HTXS.MCsamples.THQB:   345967
+
+# ggF different masses
++HTXS.MCsamples.GGF:    345576 345577 345578 345579 345581 345582 345583
+
+# ttH MG5
++HTXS.MCsamples.TTH:    346062 346063 346064
+# tWH MG5
++HTXS.MCsamples.WHT:    346759
+# tHjb MG5
++HTXS.MCsamples.THQB:    346677
+
+# Signal Samples, high mass
+# ggF - narrow width
++HTXS.MCsamples.GGF:    341274 341275 341276 341277 341278 341279 341280 341281 341282 341283 341284 341285 341286 341287 341288 341289 341290 341291 341292
+# ggF - 5%, 10%, and 15% width
++HTXS.MCsamples.GGF:    343204 343205 343206 343207
++HTXS.MCsamples.GGF:    343208 343209 343210 343211
++HTXS.MCsamples.GGF:    343184 343185 343186 343187 343188 343189 343190 343191 343192 343193 343194 343195 343196 343197 343198 343199 343200 343201 343202 343203 
+# VBF
++HTXS.MCsamples.VBF:    341293 341294 341295 341296 341297 341298 341299 341300 341301 341302 341303 341304 341305 341306 341307 341308 341309 341310 341311 
+# ZH
++HTXS.MCsamples.QQ2ZH:  341886 341887 341888
+# WH
++HTXS.MCsamples.WH:     341889 341890 341891
+# ggF noTau
++HTXS.MCsamples.GGF:    341420
+# bbH noTau
++HTXS.MCsamples.BBH:    344967 344968 344969 344970 344971 344972 344973 344974 344975 344976 344977 344978 344979 344980
+# VBF EFT 
++HTXS.MCsamples.VBF:    345049
+# VH EFT
+#    skip because cannot be separated into WH and QQ2ZH
+#                       345050 345051 345052                         
+# ggH
++HTXS.MCsamples.GGF:    345060 
+# ZH
++HTXS.MCsamples.QQ2ZH:  345038
+# WH
++HTXS.MCsamples.WH:     345039 345040
+# VBF noTau
++HTXS.MCsamples.VBF:    345434 345435 345436 345437 345438 345439 345440 345441 345442 345443 345444
++HTXS.MCsamples.VBF:    344235
+
+# EFT VBF
++HTXS.MCsamples.VBF:    345355 345356 345357 345358 345359 345360 345361 345362 345363 345364 345365 345366 345367 345368 345369 345370 345371 345372 345373 345374
+# EFT WH
++HTXS.MCsamples.WH:     345375 345376 345377 345378 345379 345380 345381 345382 345383 345384 345385 345386 345387 345388 345389 345390 345391 345392 345393 345394
+# EFT ZH
++HTXS.MCsamples.QQ2ZH:  345395 345396 345397 345398 345399 345400 345401 345402 345403 345404 345405 345406 345407 345408 345409 345410 345411 345412 345413 345414
+
+# ggZH 
++HTXS.MCsamples.GG2ZH:  345066 346697 346703
+
+# Herwig
++HTXS.MCsamples.GGF:    346446 346797
++HTXS.MCsamples.VBF:    346447 346878
++HTXS.MCsamples.QQ2ZH:  346448 346879
++HTXS.MCsamples.WH:     346449 346450 346880 346881
++HTXS.MCsamples.WHT:     346883
++HTXS.MCsamples.GG2ZH:  346451 346882
++HTXS.MCsamples.TTH:    346452 346453 346454
+
+# llqq
+# ggZH125
++HTXS.MCsamples.GG2ZH:  341094 341095 341096 341097 341098 341099
+# WlvH125_bb
++HTXS.MCsamples.WH:     341100
+# ZvvH125_bb, ZllH125_bb
++HTXS.MCsamples.QQ2ZH:  341101 341102
+# WxH125J_MINLO
++HTXS.MCsamples.WH:     341178 341179 341181 341182
+# ggHXXXNW_ZZllqq
++HTXS.MCsamples.GGF:    341312 341313 341314 341315 341316 341317 341318 341319 341320 341321 341322 341323 341324 341325 341326 341327 341328 341329 341330
+# VBFHXXXNW_ZZllqq
++HTXS.MCsamples.VBF:    341331 341332 341333 341334 341335 341336 341337 341338 341339 341340 341341 341342 341343 341344 341345 341346 341347 341348 341349
+# ZHXXXNW_ZZllqq
++HTXS.MCsamples.QQ2ZH:  341892 341893 341894
+# WHXXXNW_ZZllqq
++HTXS.MCsamples.WH:     341895 341896 341897
+# ggF 15% width 
++HTXS.MCsamples.GGF:    342908 342909 342910 342911 342912 342913 342914 342915 342916 342917 342918 342919 342920 342921 342922 342923 342924 342925 342926
+# ggF  5% width 
++HTXS.MCsamples.GGF:    342927 342928 342929 342930
+# ggF 10% width 
++HTXS.MCsamples.GGF:    342931 342932 342933 342934
+# ggF narrow width
++HTXS.MCsamples.GGF:    343573
+# VBF narrow width
++HTXS.MCsamples.VBF:    343574
+# WH EFT
++HTXS.MCsamples.WH:     343608
+# ZH EFT
++HTXS.MCsamples.QQ2ZH:  343619
+# THQB
++HTXS.MCsamples.THQB:   346414 346415
+
+# Hinv
+# ZH
++HTXS.MCsamples.QQ2ZH: 346693
+# ggZH
++HTXS.MCsamples.GG2ZH: 346694
+
+###############
+#  HWW samples
+#  i.e. HIGG3D* derivation
+#
+
++HTXS.MCsamples.GGF:    341079 343393 341122 341195 345324 345339 346802
+
++HTXS.MCsamples.VBF:    341080 341155 341206 345323 345340 345948 346877
+
++HTXS.MCsamples.WH:    342684 342685 342686 342687 342688 342689 342690 342816 342817 342818 342820 342821 342822 341421
++HTXS.MCsamples.WH:    341422 341423 341424 341425 341426 341427 341428 341429 341430 341431 3414232 341433 341434 341435 
++HTXS.MCsamples.WH:    34142136 343275 343276 343323 343345 345325 345326 345327 345433 345341
+
++HTXS.MCsamples.QQ2ZH:   341449 341450 341451 341452 341453 341454 341455 341456 341457 341458 341459 341460 341461 343334 343356 345336 345337 345445 345446
+
+
+###############
+#  HLeptons samples
+#
+#
++HTXS.MCsamples.GGF: 341122 341079 344092 341124 341905 341906 341907 342300 342301 344084 344088 341123 341902 341903 341904 342282 342302 341225 345120 345121 345122 345123 345126 345127 345128 345124 345125 345097 342178 345697 345698 345699 346564
++HTXS.MCsamples.VBF: 341155 341080 344093 341157 341911 341912 341913 344085 344089 341156 341908 341909 341910 342283 341254  345073 345074 345075 345076 345077 345078 345106 342189 346190 346191 346192 346193
++HTXS.MCsamples.TTH: 342170 342171 342172 343365 343366 343367 344388 345672 345673 345674 345873 345874 345875 346343 346344 346345 346443 346444 346445 346346 346347 346348
++HTXS.MCsamples.WH: 344094 344086 344090 342284 343942 345211 345212 345213 345214 345215 345216 345104 345105 346324 346325
++HTXS.MCsamples.QQ2ZH: 344095 344087 344091 342285 343953 345217 345218 345219 345103 346326
++HTXS.MCsamples.GG2ZH: 341096 345098 346329
++HTXS.MCsamples.BBH: 345533 
+
+###############
+# Hbb samples
+#
+#
++HTXS.MCsamples.WH: 345053 345054 345109 345110 346395 346396 346723 346724
++HTXS.MCsamples.QQ2ZH: 345055 345056 345111 345112 346397 346398 346725 346726
++HTXS.MCsamples.GG2ZH: 345057 345058 345113 345114 346399 346400 346727 346728
+
+###############
+# VBF HInv samples
++HTXS.MCsamples.GGF: 346588
++HTXS.MCsamples.WH: 346605 346606
++HTXS.MCsamples.QQ2ZH: 346607 
++HTXS.MCsamples.GG2ZH: 345596
++HTXS.MCsamples.TTH: 346632 346633 346634
++HTXS.MCsamples.VBF: 346600 312243 308567 308276 308275 308277 308278 308279 308280 308281 308282 308283
+
+#
+###########
+# HTop (multilepton) samples
+# i.e. HIGG8D1 derivation
+#
+  # aMCnloPy8
++HTXS.MCsamples.WHT: 342000 342001 342002 342003 342004 342005 
+  # aMCnloHw++
++HTXS.MCsamples.THQB: 341991 341992 341993 341994 341995 341996 343270 343271 343272 343273 343274
+  # aMCnloHw++
++HTXS.MCsamples.TTH: 341177 341270 341271
+
+###########
+## add new ttH samples
++HTXS.MCsamples.TTH: 346526 346525
+
+## add new ttH CP samples
++HTXS.MCsamples.TTH: 346303 346304 346595 346596 346597 346598 346601 346189
+
+###############
+#  EFT samples
+#
++HTXS.MCsamples.WH: 343599 343601 343610 343611
++HTXS.MCsamples.QQ2ZH: 343629 343624 343631 343614 343621 
++HTXS.MCsamples.WH: 345785 345786 345791 345792 345797 345798 345803 345804 345809 345810 345815 345816 345821 345822 345827 345828
++HTXS.MCsamples.QQ2ZH: 345787 345788 345793 345794 345799 345800 345805 345806 345811 345812 345817 345818 345823 345824 345829 345830
++HTXS.MCsamples.GG2ZH: 345789 345790 345795 345796 345801 345802 345807 345808 345813 345814 345819 345820 345825 345826 345831 345832
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/src/TruthCategoriesDecorator.cxx b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/src/TruthCategoriesDecorator.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..864c59428a7c560981bcdc04ad18e5ee222f4d66
--- /dev/null
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/src/TruthCategoriesDecorator.cxx
@@ -0,0 +1,285 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
+
+#include "DerivationFrameworkHiggs/TruthCategoriesDecorator.h"
+#include "xAODTruth/TruthParticleContainer.h"
+#include "xAODTruth/TruthVertex.h"
+#include "xAODJet/JetContainer.h"
+#include "TruthUtils/PIDHelpers.h"
+#include "PathResolver/PathResolver.h"
+
+#include "GenInterfaces/IHiggsTruthCategoryTool.h"
+#include "GenInterfaces/IxAODtoHepMCTool.h"
+
+#include "CLHEP/Units/SystemOfUnits.h"
+
+// Note: must include TLorentzVector before the next one
+#include "TLorentzVector.h"
+#include "TruthRivetTools/HiggsTemplateCrossSectionsDefs.h"
+#include "StoreGate/WriteDecorHandle.h"
+
+#include <TObjString.h>
+#include <TObjArray.h>
+
+namespace DerivationFramework {
+  
+  TruthCategoriesDecorator::TruthCategoriesDecorator(const std::string& t, const std::string& n, const IInterface* p):
+    AthAlgTool(t,n,p),
+    m_xAODtoHepMCTool("xAODtoHepMCTool"), 
+    m_higgsTruthCatTool("HiggsTruthCategoryTool"),
+    m_config(nullptr),
+    m_configPath("")
+  {
+    declareInterface<DerivationFramework::IAugmentationTool>(this);
+    declareProperty("ConfigPath",m_configPath="DerivationFrameworkHiggs/HiggsMCsamples.cfg");
+    declareProperty("DetailLevel",m_detailLevel=3);
+  }
+  
+  TruthCategoriesDecorator::~TruthCategoriesDecorator() {}
+  
+
+  StatusCode TruthCategoriesDecorator::initialize() {
+    
+    ATH_MSG_INFO("Initialize " );
+
+    // FOR xAOD->HEPMC ::  xAODtoHepMC tool
+    ATH_CHECK(m_xAODtoHepMCTool.retrieve());
+ 
+    // Higgs truth category tool 
+    ATH_CHECK(m_higgsTruthCatTool.retrieve());
+
+    // Open the TEnv configuration file
+    m_config = new TEnv();
+    int status = m_config->ReadFile(PathResolverFindCalibFile(m_configPath).c_str(),EEnvLevel(0));
+    if ( status != 0 ) {
+      ATH_MSG_FATAL("Failed to open TEnv file "<<m_configPath);
+      return StatusCode::FAILURE;
+    }
+
+    //All the decorations we want to add go here
+    m_eventInfoIntDecorNames.push_back("HTXS_prodMode");
+    m_eventInfoIntDecorNames.push_back("HTXS_errorCode");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage0_Category");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_Category_pTjet25");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_Category_pTjet30");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_FineIndex_pTjet30");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_FineIndex_pTjet25");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_2_Category_pTjet25");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_2_Category_pTjet30");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_2_FineIndex_pTjet30");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_2_FineIndex_pTjet25");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_2_Fine_Category_pTjet25");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_2_Fine_Category_pTjet30");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_2_Fine_FineIndex_pTjet25");
+    m_eventInfoIntDecorNames.push_back("HTXS_Stage1_2_Fine_FineIndex_pTjet30");
+    m_eventInfoIntDecorNames.push_back("HTXS_Njets_pTjet25");
+    m_eventInfoIntDecorNames.push_back("HTXS_Njets_pTjet30");
+    m_eventInfoIntDecorNames.push_back("HTXS_isZ2vvDecay");
+
+    m_eventInfoFloatDecorNames.push_back("HTXS_Higgs_pt");
+    std::string fourvecconts[4]={"_pt","_eta","_phi","_m"};
+    for(int i=0;i<4;i++){
+      m_eventInfoFloatDecorNames.push_back("HTXS_Higgs"+fourvecconts[i]);
+      m_eventInfoFloatDecorNames.push_back("HTXS_V"+fourvecconts[i]);
+      m_eventInfoFloatDecorNames.push_back("HTXS_Higgs_Decay"+fourvecconts[i]);
+      m_eventInfoFloatDecorNames.push_back("HTXS_V_Decay"+fourvecconts[i]);
+      m_eventInfoVectorFloatDecorNames.push_back("HTXS_V_jets25"+fourvecconts[i]);
+      m_eventInfoVectorFloatDecorNames.push_back("HTXS_V_jets30"+fourvecconts[i]);
+    }
+
+    for(auto name : m_eventInfoIntDecorNames) m_eventInfoIntDecors.emplace_back("EventInfo."+name);
+    for(auto name : m_eventInfoFloatDecorNames) m_eventInfoFloatDecors.emplace_back("EventInfo."+name);
+    for(auto name : m_eventInfoVectorFloatDecorNames) m_eventInfoVectorFloatDecors.emplace_back("EventInfo."+name);
+
+    ATH_CHECK(m_eventInfoIntDecors.initialize());
+    ATH_CHECK(m_eventInfoFloatDecors.initialize());
+    ATH_CHECK(m_eventInfoVectorFloatDecors.initialize());
+    ATH_CHECK(m_truthEventCont.initialize());
+    return StatusCode::SUCCESS;
+  }
+  
+  StatusCode TruthCategoriesDecorator::finalize(){
+    if(m_config) delete m_config;
+    return StatusCode::SUCCESS;
+  }
+
+  // Converts a string of numbers - separated by "sep" to a vector of integers
+  // sep is by default any number of space characters
+  std::vector<int> TruthCategoriesDecorator::vectorize(TString str, TString sep) const {
+    std::vector<int> result;
+    TObjArray *strings = str.Tokenize(sep.Data());
+    if (strings->GetEntries()==0) { delete strings; return result; }
+    TIter istr(strings);
+    while (TObjString* os=(TObjString*)istr()) {
+      result.push_back(atol(os->GetString()));
+    }
+    delete strings;
+    return result;
+  }
+
+  
+
+  HTXS::HiggsProdMode TruthCategoriesDecorator::getHiggsProductionMode(uint32_t mc_channel_number, HTXS::tH_type &th_type) const {
+    if (m_config==nullptr) {
+      ATH_MSG_ERROR("TEnv file pointer is NULL? Bad configuration.");
+      return HTXS::HiggsProdMode::UNKNOWN;
+    }
+
+    for (TString prodMode:{"GGF","VBF","WH","QQ2ZH","GG2ZH","TTH","BBH","TH","THQB","WHT"}) {
+
+      // loop over each mcID belonging to the production mode
+      for ( int mcID : vectorize(m_config->GetValue("HTXS.MCsamples."+prodMode,"")) ){
+        if (mcID==(int)mc_channel_number) {
+          ATH_MSG_INFO("Higgs production for MC channel number "<<mc_channel_number<<" mode is "<<prodMode);
+          // gah, need to convert
+          if (prodMode=="GGF"  ) return HTXS::HiggsProdMode::GGF;
+          if (prodMode=="VBF"  ) return HTXS::HiggsProdMode::VBF;
+          if (prodMode=="WH"   ) return HTXS::HiggsProdMode::WH;
+          if (prodMode=="QQ2ZH") return HTXS::HiggsProdMode::QQ2ZH;
+          if (prodMode=="GG2ZH") return HTXS::HiggsProdMode::GG2ZH;
+          if (prodMode=="TTH"  ) return HTXS::HiggsProdMode::TTH;
+          if (prodMode=="BBH"  ) return HTXS::HiggsProdMode::BBH;
+          if (prodMode=="TH"   ) return HTXS::HiggsProdMode::TH;
+          if (prodMode=="THQB" ) { th_type = HTXS::tH_type::THQB; return HTXS::HiggsProdMode::TH; }
+          if (prodMode=="WHT"  ) { th_type = HTXS::tH_type::TWH; return HTXS::HiggsProdMode::TH; }
+        }
+      }
+    }
+    // This is perfectly fine if we aren't running on a Higgs sample
+    ATH_MSG_INFO("Did not manage to extract Higgs production mode for MC channel number " << 
+                    mc_channel_number << ". HTXS categorization will hence not be derived.");
+    return HTXS::HiggsProdMode::UNKNOWN;
+  }
+
+  float TruthCategoriesDecorator::getFloatDecor(const std::string key, const TLorentzVector p4) const {
+    if(key.find("_pt")!=std::string::npos) return p4.Pt()*CLHEP::GeV;
+    else if(key.find("_eta")!=std::string::npos) return p4.Eta();
+    else if(key.find("_phi")!=std::string::npos) return p4.Phi();
+    else return p4.M()*CLHEP::GeV;
+  }
+
+  std::vector<float> TruthCategoriesDecorator::getVectorFloatDecor(const std::string key, const std::vector<TLorentzVector> p4s) const {
+    std::vector<float> vec;
+    if(key.find("_pt")!=std::string::npos){
+      for (auto p4:p4s) vec.push_back(p4.Pt()*CLHEP::GeV);
+    }
+    else if(key.find("_eta")!=std::string::npos){
+      for (auto p4:p4s) vec.push_back(p4.Eta());
+    }
+    else if(key.find("_phi")!=std::string::npos){
+      for (auto p4:p4s) vec.push_back(p4.Phi());
+    }
+    else if(key.find("_m")!=std::string::npos){
+      for (auto p4:p4s) vec.push_back(p4.M()*CLHEP::GeV);
+    }
+    return vec;
+  }
+
+
+  StatusCode TruthCategoriesDecorator::addBranches() const{
+
+    // Get a handle so we can retrieve the eventInfo information
+    SG::WriteDecorHandle<xAOD::EventInfo, int> prodModeHandle(m_eventInfoIntDecors.at(0));
+
+    // Extract the prodocution mode the first time 
+    static bool first = true;
+    static HTXS::HiggsProdMode prodMode = HTXS::HiggsProdMode::UNKNOWN;
+    static HTXS::tH_type th_type = HTXS::tH_type::noTH;
+    if (first) {
+      uint32_t mcChannelNumber = prodModeHandle->mcChannelNumber();
+      if(mcChannelNumber==0) mcChannelNumber = prodModeHandle->runNumber(); // EVNT input
+      prodMode = getHiggsProductionMode(mcChannelNumber,th_type);
+      first = false;
+    }
+
+    // If the production mode is unkown, the categorization will return -99
+    // Set HTXS_prodMode decoration to indicate that HTXS categorization was indeed run
+    if ( prodMode == HTXS::HiggsProdMode::UNKNOWN) {
+      //cheating a bit here, prodMode is the first decorator
+      prodModeHandle(0) = (int)prodMode;
+      return StatusCode::SUCCESS;
+    }
+
+    // Retrieve the xAOD truth
+    SG::ReadHandle<xAOD::TruthEventContainer> truthEventCont(m_truthEventCont);
+
+    // convert xAOD -> HepMC
+    std::vector<HepMC::GenEvent> hepmc_evts = m_xAODtoHepMCTool->getHepMCEvents( truthEventCont.cptr(), prodModeHandle.cptr() );
+
+    if (hepmc_evts.size()==0) {
+      // ANGRY MESSAGE HERE
+      return StatusCode::FAILURE;
+    }
+
+    // classify event according to simplified template cross section
+    HTXS::HiggsClassification *htxs =  m_higgsTruthCatTool->getHiggsTruthCategoryObject(hepmc_evts[0],prodMode);
+
+    // Decorate
+    prodModeHandle(0)=(int)htxs->prodMode;
+    for( auto& key : m_eventInfoIntDecors){
+      //already did this one
+      if(key.key().find("HTXS_prodMode")!=std::string::npos) continue;
+      SG::WriteDecorHandle<xAOD::EventInfo, int> handle(key);
+      if(key.key().find("HTXS_errorCode")!=std::string::npos) handle(0) = (int)htxs->errorCode;
+      else if(key.key().find("HTXS_Stage0_Category")!=std::string::npos) handle(0) = (int)htxs->stage0_cat;
+      // Stage-1 binning
+      else if(key.key().find("HTXS_Stage1_Category_pTjet25")!=std::string::npos) handle(0) = (int)htxs->stage1_cat_pTjet25GeV;
+      else if(key.key().find("HTXS_Stage1_Category_pTjet30")!=std::string::npos) handle(0) = (int)htxs->stage1_cat_pTjet30GeV;
+      else if(key.key().find("HTXS_Stage1_FineIndex_pTjet25")!=std::string::npos) handle(0) = HTXSstage1_to_HTXSstage1FineIndex(*htxs,th_type);
+      else if(key.key().find("HTXS_Stage1_FineIndex_pTjet30")!=std::string::npos) handle(0) = HTXSstage1_to_HTXSstage1FineIndex(*htxs,th_type,true);
+      // Stage-1.2 binning
+      else if(key.key().find("HTXS_Stage1_2_Category_pTjet25")!=std::string::npos) handle(0) = (int)htxs->stage1_2_cat_pTjet25GeV;
+      else if(key.key().find("HTXS_Stage1_2_Category_pTjet30")!=std::string::npos) handle(0) = (int)htxs->stage1_2_cat_pTjet30GeV;
+      else if(key.key().find("HTXS_Stage1_2_FineIndex_pTjet25")!=std::string::npos) handle(0) = HTXSstage1_2_to_HTXSstage1_2_FineIndex(*htxs,th_type);
+      else if(key.key().find("HTXS_Stage1_2_FineIndex_pTjet30")!=std::string::npos) handle(0) = HTXSstage1_2_to_HTXSstage1_2_FineIndex(*htxs,th_type,true);
+      // Stage-1.2 finer binning
+      else if(key.key().find("HTXS_Stage1_2_Fine_Category_pTjet25")!=std::string::npos) handle(0) = (int)htxs->stage1_2_fine_cat_pTjet25GeV;
+      else if(key.key().find("HTXS_Stage1_2_Fine_Category_pTjet30")!=std::string::npos) handle(0) = (int)htxs->stage1_2_fine_cat_pTjet30GeV;
+      else if(key.key().find("HTXS_Stage1_2_Fine_FineIndex_pTjet25")!=std::string::npos) handle(0) = HTXSstage1_2_Fine_to_HTXSstage1_2_Fine_FineIndex(*htxs,th_type);
+      else if(key.key().find("HTXS_Stage1_2_Fine_FineIndex_pTjet30")!=std::string::npos) handle(0) = HTXSstage1_2_Fine_to_HTXSstage1_2_Fine_FineIndex(*htxs,th_type,true);
+      //Njets
+      else if(key.key().find("HTXS_Njets_pTjet25")!=std::string::npos) handle(0) = (int)htxs->jets25.size();
+      else if(key.key().find("HTXS_Njets_pTjet30")!=std::string::npos) handle(0) = (int)htxs->jets30.size();
+      else if(key.key().find("HTXS_isZ2vvDecay")!=std::string::npos) handle(0) = (bool)htxs->isZ2vvDecay;
+    }
+    for( auto& key : m_eventInfoFloatDecors){
+      SG::WriteDecorHandle<xAOD::EventInfo, float> handle(key);
+      // At the very least, save the Higgs boson pT
+      if(key.key().find("HTXS_Higgs_pt")!=std::string::npos){
+	if (m_detailLevel==0) handle(0) = htxs->higgs.Pt()*CLHEP::GeV;
+      }
+      // The Higgs and the associated V (last instances prior to decay)
+      else if(key.key().find("HTXS_Higgs")!=std::string::npos && key.key().find("decay")==std::string::npos){
+	if (m_detailLevel>0) handle(0)=getFloatDecor(key.key(),htxs->higgs);
+      }
+      else if(key.key().find("HTXS_V")!=std::string::npos && key.key().find("decay")==std::string::npos && key.key().find("jets")==std::string::npos){
+	if (m_detailLevel>0) handle(0)=getFloatDecor(key.key(),htxs->V);
+      }
+      // Everybody might not want this ... but good for validation
+      else if(key.key().find("HTXS_Higgs_decay")!=std::string::npos){
+	if (m_detailLevel>2) handle(0)=getFloatDecor(key.key(),htxs->p4decay_higgs);
+      }
+      else if(key.key().find("HTXS_V_decay")!=std::string::npos){
+	if (m_detailLevel>2) handle(0)=getFloatDecor(key.key(),htxs->p4decay_V);
+      }
+    }
+    for( auto& key : m_eventInfoVectorFloatDecors){
+      SG::WriteDecorHandle<xAOD::EventInfo, std::vector<float> > handle(key);
+      // Jets built excluding Higgs decay products
+      if(key.key().find("HTXS_V_jets25")!=std::string::npos){
+	if (m_detailLevel>1) handle(0)=getVectorFloatDecor(key.key(),htxs->jets25);
+      }
+      else if(key.key().find("HTXS_V_jets30")!=std::string::npos){
+        if (m_detailLevel>1) handle(0)=getVectorFloatDecor(key.key(),htxs->jets30);
+      }
+    }
+
+    delete htxs;
+
+    return StatusCode::SUCCESS;
+
+  } // addBranches
+  
+} // namespace
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/src/components/DerivationFrameworkHiggs_entries.cxx b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/src/components/DerivationFrameworkHiggs_entries.cxx
index f57ec57c534ef67394c84f00e2e911b4926d5009..4df39e7add8c0b0d3b31c2681bc885962e3c56b0 100644
--- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/src/components/DerivationFrameworkHiggs_entries.cxx
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkHiggs/src/components/DerivationFrameworkHiggs_entries.cxx
@@ -1,9 +1,11 @@
 #include "DerivationFrameworkHiggs/SkimmingToolHIGG1.h"
 #include "DerivationFrameworkHiggs/SkimmingToolHIGG2.h"
 #include "DerivationFrameworkHiggs/SkimmingToolHIGG5VBF.h"
+#include "DerivationFrameworkHiggs/TruthCategoriesDecorator.h"
 using namespace DerivationFramework;
 
 DECLARE_COMPONENT( SkimmingToolHIGG1 )
 DECLARE_COMPONENT( SkimmingToolHIGG2 )
 DECLARE_COMPONENT( SkimmingToolHIGG5VBF )
+DECLARE_COMPONENT( TruthCategoriesDecorator )
 
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkMCTruth/src/TruthClassificationDecorator.cxx b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkMCTruth/src/TruthClassificationDecorator.cxx
index fd60c91856d9327d007bf0694a7b5659b48a33e0..035be1d8d349d400bee5001f5da015b0cbe946ce 100644
--- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkMCTruth/src/TruthClassificationDecorator.cxx
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkMCTruth/src/TruthClassificationDecorator.cxx
@@ -73,22 +73,30 @@ StatusCode DerivationFramework::TruthClassificationDecorator::addBranches() cons
     SG::AuxElement::Decorator< unsigned int > typeDecorator("classifierParticleType");
     SG::AuxElement::Decorator< unsigned int > outcomeDecorator("classifierParticleOutCome");
 
+    SG::AuxElement::Decorator< unsigned int > classificationDecorator("Classification");
+
     for (unsigned int i=0; i<nParticles; ++i) {
 #ifdef MCTRUTHCLASSIFIER_CONST
         IMCTruthClassifier::Info info;
         std::pair<MCTruthPartClassifier::ParticleType, MCTruthPartClassifier::ParticleOrigin> classification = 
           m_classifier->particleTruthClassifier((*importedTruthParticles)[i], &info);
-        unsigned int particleOutCome = info.particleOutCome;
+          unsigned int particleOutCome = info.particleOutCome;
+
+	  unsigned int result = (unsigned int)m_classifier->classify((*importedTruthParticles)[i]);
 #else
         std::pair<MCTruthPartClassifier::ParticleType, MCTruthPartClassifier::ParticleOrigin> classification = 
         m_classifier->particleTruthClassifier((*importedTruthParticles)[i]);
         unsigned int particleOutCome = m_classifier->getParticleOutCome();
+
+	unsigned int result = (unsigned int)m_classifier->classify((*importedTruthParticles)[i]);
 #endif
         unsigned int particleType = classification.first;
         unsigned int particleOrigin = classification.second;
         typeDecorator(*((*importedTruthParticles)[i])) = particleType;
         originDecorator(*((*importedTruthParticles)[i])) = particleOrigin;
         outcomeDecorator(*((*importedTruthParticles)[i])) = particleOutCome;  
+
+	classificationDecorator(*((*importedTruthParticles)[i])) = result;
     }
 
     return StatusCode::SUCCESS;
diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkPhys/share/PHYSLITE.py b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkPhys/share/PHYSLITE.py
index 61f35465482fd6dd5beafdd24df3ff8112121d60..9f6be657cf9b6ee76ea5266493c7aa5d1344df94 100644
--- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkPhys/share/PHYSLITE.py
+++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkPhys/share/PHYSLITE.py
@@ -9,13 +9,13 @@ nanolog = Logging.logging.getLogger('PHYSLITE')
 
 from DerivationFrameworkCore.DerivationFrameworkMaster import *
 from DerivationFrameworkInDet.InDetCommon import *
-from DerivationFrameworkJetEtMiss.JetCommon import *
-from DerivationFrameworkJetEtMiss.ExtendedJetCommon import *
-from DerivationFrameworkJetEtMiss.METCommon import *
 from DerivationFrameworkEGamma.EGammaCommon import *
 from DerivationFrameworkEGamma.ElectronsCPDetailedContent import *
 from DerivationFrameworkMuons.MuonsCommon import *
 from DerivationFrameworkCore.WeightMetadata import *
+from DerivationFrameworkJetEtMiss.JetCommon import *
+from DerivationFrameworkJetEtMiss.ExtendedJetCommon import *
+from DerivationFrameworkJetEtMiss.METCommon import *
 from DerivationFrameworkFlavourTag.FlavourTagCommon import FlavorTagInit
 from DerivationFrameworkFlavourTag.HbbCommon import *
 from TriggerMenu.api.TriggerAPI import TriggerAPI
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/CMakeLists.txt b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/CMakeLists.txt
index 5505e4ba604a9bc873ae245d4120dd00bf3ac5e4..76dad01ad304c27c4370d7c49466a9e5967350bb 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/CMakeLists.txt
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/CMakeLists.txt
@@ -20,10 +20,10 @@ atlas_add_library( ElectronPhotonFourMomentumCorrectionLib
    INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
    PRIVATE_INCLUDE_DIRS ${Boost_INCLUDE_DIRS}
    LINK_LIBRARIES ${ROOT_LIBRARIES} AsgTools AsgMessagingLib xAODCaloEvent xAODEgamma
-   xAODEventInfo PATInterfaces EgammaAnalysisInterfacesLib PATCoreAcceptLib
+   xAODEventInfo PATInterfaces EgammaAnalysisInterfacesLib egammaUtils PATCoreAcceptLib
    xAODRootAccess xAODTracking
    PRIVATE_LINK_LIBRARIES ${Boost_LIBRARIES} AthLinks xAODMetaData egammaLayerRecalibTool
-   egammaMVACalibAnalysisLib egammaUtils PathResolver ${extra_libs} )
+   egammaMVACalibAnalysisLib PathResolver ${extra_libs} )
 
 if( NOT XAOD_STANDALONE )
    atlas_add_component( ElectronPhotonFourMomentumCorrection
@@ -65,16 +65,6 @@ if( XAOD_STANDALONE )
       xAODCaloEvent xAODCore PATInterfaces ElectronPhotonFourMomentumCorrectionLib )
 endif()
 
-# Test(s) in the package:
-if( XAOD_STANDALONE )
-   # FIX ME: these tests were temporarily disabled as they were
-   # failing in the nightlies.
-
-   # atlas_add_test( ut_test SCRIPT test/ut_test.py )
-   # atlas_add_test( ut_test_factory SCRIPT test/ut_test_factory.py )
-   # atlas_add_test( ut_test_resolution SCRIPT test/ut_test_resolution.py )
-endif()
-
 # Install files from the package:
 atlas_install_python_modules( python/*.py )
 atlas_install_joboptions( share/*.py )
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/EgammaCalibrationAndSmearingTool.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/EgammaCalibrationAndSmearingTool.h
index cf7d530c0b9b83d87866754c376f7dce35164422..c0b26dea71db2e859fa0d4dd7d325bf200710e4d 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/EgammaCalibrationAndSmearingTool.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/EgammaCalibrationAndSmearingTool.h
@@ -1,7 +1,5 @@
-// Dear Emacs, this is -*- C++ -*-
-
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 
@@ -57,7 +55,7 @@ namespace xAOD {
   inline float get_eta_calo(const xAOD::CaloCluster& cluster, int author, bool do_throw=false)
 	{
 	  double eta_calo;
-	  if(author== xAOD::EgammaParameters::AuthorFwdElectron){ 
+	  if(author== xAOD::EgammaParameters::AuthorFwdElectron){
             eta_calo = cluster.eta();
           }
 	  else if (cluster.retrieveMoment(xAOD::CaloCluster::ETACALOFRAME,
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/EgammaFactory.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/EgammaFactory.h
index 250038eb298b0a79513eec0b8f6c5b84a9c0f186..9ace3e35671c91fd5eacc64c7e4c76ace50de6fc 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/EgammaFactory.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/EgammaFactory.h
@@ -1,8 +1,8 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-// Dear emacs, this is -*-c++-*-
+
 #ifndef EGAMMAFACTORY_H
 #define EGAMMAFACTORY_H
 
@@ -49,7 +49,8 @@ public:
   xAOD::Photon* create_photon(float eta, float phi, float e0, float e1, float e2, float e3, float e, float rconv=0, float zconv=0);
   xAOD::Electron* create_electron(float eta, float phi, float e);
   xAOD::Electron* create_electron(float eta, float phi, float e0, float e1, float e2, float e3, float e);
-  xAOD::EventInfo* create_eventinfo(bool simulation, int runnumber, int eventnumber=1);
+    // TODO: fix mu
+  xAOD::EventInfo* create_eventinfo(bool simulation, int runnumber, int eventnumber=1, int average_interaction_per_crossing=20);
 private:
   xAOD::TStore m_store;  //!
   xAOD::CaloClusterContainer* m_clusters;  //!
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrectionDict.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrectionDict.h
index d4157b4d7136f2caeea24593d8cab3a5b4fbf031..7eeee582ca66a96980fb90db23551a6a466653b6 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrectionDict.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrectionDict.h
@@ -1,8 +1,8 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-// Dear emacs, this is -*-c++-*-
+
 //
 // Dictionary generation for this package
 //
@@ -12,6 +12,7 @@
 #define ELECTRONPHOTONFOURMOMENTUMCORRECTION_ELECTRONPHOTONFOURMOMENTUMCORRECTIONDICT_H
 
 
+#include "egammaUtils/eg_resolution.h"
 #include "ElectronPhotonFourMomentumCorrection/egammaEnergyCorrectionTool.h"
 #include "ElectronPhotonFourMomentumCorrection/EgammaCalibrationAndSmearingTool.h"
 #include "ElectronPhotonFourMomentumCorrection/EgammaFactory.h"
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/GainTool.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/GainTool.h
index 0ca13feab8aad6328a38a0c7d1e428b37c6709fd..56cee09544dcad2fd54671886b96b5d4ff644e9a 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/GainTool.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/GainTool.h
@@ -1,45 +1,45 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-#ifndef ELECTRONPHOTONFOURMOMENTUMCORRECTION_GAINTOOL_H
-#define ELECTRONPHOTONFOURMOMENTUMCORRECTION_GAINTOOL_H
-
-#include <string>
-#include <memory>
-#include <PATCore/PATCoreEnums.h>
-
-class TFile;
-class TF1;
-
-namespace egGain {
-
-  class GainTool {
-    
-  public:
-    GainTool(const std::string& filenameTO, const std::string& filenameVar);
-    void Init(const std::string& filenameTO, const std::string& filenameVar);
-    virtual ~GainTool();
-
-    double CorrectionGainTool(double eta_input, double energy_input, double energy_layer2_input,
-			      PATCore::ParticleType::Type ptype=PATCore::ParticleType::Electron);
-
-  private:
-    
-    static const int m_NUM_ETA_BINS=28;
-    static const int m_NUM_ENERGY_BINS=3;
-    static const int m_NUM_UNCONV_ENERGY_BINS=4;
-
-    std::unique_ptr <TFile> m_TOFile;
-    std::unique_ptr <TFile> m_varFile;    
-
-    TF1* m_funcTO[m_NUM_ETA_BINS]; 
-    TF1* m_funcG[m_NUM_ENERGY_BINS][m_NUM_ETA_BINS];
-    TF1* m_conv_funcG[m_NUM_ENERGY_BINS][m_NUM_ETA_BINS]; 
-    TF1* m_unconv_funcG[m_NUM_UNCONV_ENERGY_BINS][m_NUM_ETA_BINS]; 
-    
-  };
-  
-  
-} 
-#endif
+#ifndef ELECTRONPHOTONFOURMOMENTUMCORRECTION_GAINTOOL_H
+#define ELECTRONPHOTONFOURMOMENTUMCORRECTION_GAINTOOL_H
+
+#include <string>
+#include <memory>
+#include <PATCore/PATCoreEnums.h>
+
+class TFile;
+class TF1;
+
+namespace egGain {
+
+  class GainTool {
+
+  public:
+    GainTool(const std::string& filenameTO, const std::string& filenameVar);
+    void Init(const std::string& filenameTO, const std::string& filenameVar);
+    virtual ~GainTool();
+
+    double CorrectionGainTool(double eta_input, double energy_input, double energy_layer2_input,
+			      PATCore::ParticleType::Type ptype=PATCore::ParticleType::Electron);
+
+  private:
+
+    static const int m_NUM_ETA_BINS=28;
+    static const int m_NUM_ENERGY_BINS=3;
+    static const int m_NUM_UNCONV_ENERGY_BINS=4;
+
+    std::unique_ptr <TFile> m_TOFile;
+    std::unique_ptr <TFile> m_varFile;
+
+    TF1* m_funcTO[m_NUM_ETA_BINS];
+    TF1* m_funcG[m_NUM_ENERGY_BINS][m_NUM_ETA_BINS];
+    TF1* m_conv_funcG[m_NUM_ENERGY_BINS][m_NUM_ETA_BINS];
+    TF1* m_unconv_funcG[m_NUM_UNCONV_ENERGY_BINS][m_NUM_ETA_BINS];
+
+  };
+
+
+}
+#endif
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/GainUncertainty.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/GainUncertainty.h
index 4dd53f2ec5adbe8a587a10a7304b44948efd9629..317f5d8558c11218d98312f69dd6b4284cbdfb64 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/GainUncertainty.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/GainUncertainty.h
@@ -1,50 +1,48 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-#ifndef ELECTRONPHOTONFOURMOMENTUMCORRECTION_GAINUNCERTAINTYY_H
-#define ELECTRONPHOTONFOURMOMENTUMCORRECTION_GAINUNCERTAINTYY_H
-
-#include <AsgMessaging/AsgMessaging.h>
-#include <PATCore/PATCoreEnums.h>
-#include <memory>
-#include <string>
-
-
-class TFile;
-class TH1F;
-class TH1D;
-
-namespace egGain{
-
-class GainUncertainty : public asg::AsgMessaging {
-public:
-
-    GainUncertainty(std::string filename);
-    void Init(std::string filename);
-    ~GainUncertainty();
-
- // return relative uncertainty on energy from gain uncertainty
- // input etaCalo_input = eta in Calo frame
- //       et_input = Et in MeV
- //       ptype    = particle type
-
-  double getUncertainty(double etaCalo_input, double et_input, PATCore::ParticleType::Type ptype=PATCore::ParticleType::Electron) const;
-
-private:
-
-  static const int m_NUM_ETA_BINS=5;
-
-  std::unique_ptr<TFile> m_gainFile;
-
-  TH1F* m_alpha_specialGainRun;
-  TH1F* m_gain_impact_Zee;
-  TH1D* m_gain_Impact_elec[5];
-  TH1D* m_gain_Impact_conv[5];
-  TH1D* m_gain_Impact_unco[5];
-
-};
-
-}
-
-#endif
+#ifndef ELECTRONPHOTONFOURMOMENTUMCORRECTION_GAINUNCERTAINTYY_H
+#define ELECTRONPHOTONFOURMOMENTUMCORRECTION_GAINUNCERTAINTYY_H
+
+#include <AsgMessaging/AsgMessaging.h>
+#include <PATCore/PATCoreEnums.h>
+#include <memory>
+#include <string>
+
+
+class TFile;
+class TH1;
+
+namespace egGain{
+
+class GainUncertainty : public asg::AsgMessaging {
+public:
+
+    GainUncertainty(const std::string& filename);
+    ~GainUncertainty();
+
+ // return relative uncertainty on energy from gain uncertainty
+ // input etaCalo_input = eta in Calo frame
+ //       et_input = Et in MeV
+ //       ptype    = particle type
+
+  double getUncertainty(double etaCalo_input, double et_input, PATCore::ParticleType::Type ptype=PATCore::ParticleType::Electron) const;
+
+private:
+
+  static const int m_NUM_ETA_BINS=5;
+
+  std::unique_ptr<TFile> m_gainFile;
+
+  TH1* m_alpha_specialGainRun;
+  TH1* m_gain_impact_Zee;
+  TH1* m_gain_Impact_elec[5];
+  TH1* m_gain_Impact_conv[5];
+  TH1* m_gain_Impact_unco[5];
+
+};
+
+}
+
+#endif
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/IEgammaCalibrationAndSmearingTool.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/IEgammaCalibrationAndSmearingTool.h
index ed52291f80886184506a7db0e1fda491c10cf3f7..028d88d945fc0ffd7878c940cf5f623df4d9cc78 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/IEgammaCalibrationAndSmearingTool.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/IEgammaCalibrationAndSmearingTool.h
@@ -1,7 +1,5 @@
-// Dear Emacs, this is -*- C++ -*-
-
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 
@@ -10,6 +8,5 @@
 
 #include "EgammaAnalysisInterfaces/IEgammaCalibrationAndSmearingTool.h"
 #pragma message "In the process of moving the Interface part under PhysicsAnalysis/Interfaces/EgammaAnalysisInterfaces"
-#pragma GCC warning "TODO: Use the headers from EgammaAnalysisInterfaces"
 
 #endif
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/LArTemperatureCorrectionTool.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/LArTemperatureCorrectionTool.h
index adea579b920e4ea3aa22beba42108ac357dc9dbe..1769425b53e67d95ba5c1b6650d7267a7a1eb3d7 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/LArTemperatureCorrectionTool.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/LArTemperatureCorrectionTool.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef LARTEMPERATURECORRECTIONTOOL_H
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/e1hg_systematics.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/e1hg_systematics.h
index 84c60d8afcb06dcb3c7caafda59fc678d862f38d..913d9992aea323031140d1e8c8068fe1d6119f32 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/e1hg_systematics.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/e1hg_systematics.h
@@ -1,43 +1,43 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-#ifndef E1HG_SYSTEMATICS_H
-#define E1HG_SYSTEMATICS_H
-#include "TH1.h"
-#include "TFile.h"
-#include "TArrayD.h"
-
-/**
-  @class e1hg_Systematics
-  @brief get systematics from MG/HG layer 1 miscalibration assuming MG is correctly re-calibrated with muons
-
-*/
-
-class e1hg_systematics {
-
- public:
-  /** @brief constructor (initialization done there reading root files) */
-  e1hg_systematics();
-  ~e1hg_systematics();
-
-  /** 
-   @brief particle_type = 0 (electrons), 1 (unconv photons), 2 (conv photons) 
-   @brief energy = energy in MeV
-   @brief eta
-   @brief return value  alpha    Ebiased =  E*(1 + alpha)
-  */
-  double getAlpha(int particle_type, double energy, double eta, bool interpolate=false) const;
-
- private:
-
-  // histograms to store parameters
-  TH1D* m_helec[8];
-  TH1D* m_hphot[8];
-  TH1D* m_hphot2[8];
-  TFile* m_file0;
-  const TArrayD* m_etBins;
-
-};
-
-#endif
+#ifndef E1HG_SYSTEMATICS_H
+#define E1HG_SYSTEMATICS_H
+#include "TH1.h"
+#include "TFile.h"
+#include "TArrayD.h"
+
+/**
+  @class e1hg_Systematics
+  @brief get systematics from MG/HG layer 1 miscalibration assuming MG is correctly re-calibrated with muons
+
+*/
+
+class e1hg_systematics {
+
+ public:
+  /** @brief constructor (initialization done there reading root files) */
+  e1hg_systematics();
+  ~e1hg_systematics();
+
+  /**
+   @brief particle_type = 0 (electrons), 1 (unconv photons), 2 (conv photons)
+   @brief energy = energy in MeV
+   @brief eta
+   @brief return value  alpha    Ebiased =  E*(1 + alpha)
+  */
+  double getAlpha(int particle_type, double energy, double eta, bool interpolate=false) const;
+
+ private:
+
+  // histograms to store parameters
+  TH1D* m_helec[8];
+  TH1D* m_hphot[8];
+  TH1D* m_hphot2[8];
+  TFile* m_file0;
+  const TArrayD* m_etBins;
+
+};
+
+#endif
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/egammaEnergyCorrectionTool.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/egammaEnergyCorrectionTool.h
index 7abd7c637fccdf897cd6dc98ecf4b2315fcfbe3e..8b8a23fc810cf8306260f6dbb7faee4a8ca9f9df 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/egammaEnergyCorrectionTool.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/egammaEnergyCorrectionTool.h
@@ -1,8 +1,7 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-// Dear emacs, this is -*-c++-*-
 //////////////////////////////////////////////////////////////
 //
 // REWRITE - February 2013, Karsten Koeneke
@@ -30,18 +29,19 @@
 
 // ROOT includes
 #include "TRandom3.h"
-#include "TList.h"
-#include "TFile.h"
-#include "TGraphErrors.h"
-#include "TH1D.h"
-#include "TH2F.h"
 #include "TSystem.h"
-#include "TF1.h"
 
 // Forward declarations
 class eg_resolution;
 class get_MaterialResolutionEffect;
 class e1hg_systematics;
+
+class TH1;
+class TH2;
+class TAxis;
+class TFile;
+class TList;
+
 namespace egGain { class GainTool;            // run1 tool
                    class GainUncertainty;     // run2 tool
                  }
@@ -82,6 +82,8 @@ namespace egEnergyCorr {
       // IBL+PP0 for run 2
       MaterialIBLUp, MaterialIBLDown, MaterialPP0Up, MaterialPP0Down,
 
+      // Atlfast 2 resolution uncertainties
+      af2Up, af2Down,
 
       // to help with loops
       LastResolutionVariation
@@ -144,6 +146,12 @@ namespace egEnergyCorr {
       // ... Layer scale variations : data driven, uncorrelated vs eta
       PSUp, PSDown, S12Up, S12Down,
 
+      //PS correlated contribution
+      PSb12Up, PSb12Down,
+
+      // topo cluster threshold
+      topoClusterThresUp,topoClusterThresDown,
+
       // extra E12 for es2017 run2
       S12ExtraLastEtaBinRun2Up, S12ExtraLastEtaBinRun2Down,
 
@@ -162,6 +170,9 @@ namespace egEnergyCorr {
       // PP0
       MatPP0Up, MatPP0Down,
 
+      // AF2 systematics
+      af2Up, af2Down,
+
       // The following apply to photons only
 
       // ... Leakage
@@ -211,20 +222,33 @@ namespace egEnergyCorr {
     es2017,                 // Moriond 2017
     es2017_summer,          // Summer 2017
     es2017_summer_improved, // Recommendations for Higgs mass paper
+    es2017_summer_final,    // Final 20.7 recommendations
+
+    es2015_5TeV,            // For 2015 low mu 5 TeV runs
+
     es2017_R21_PRE,         // Pre-recommendations for release 21
-    
+
+    es2017_R21_v0,          // Release 21 model with layer calibration corrections from run 2, no global scale correction
+    es2017_R21_v1,          // Release 21 model July 2018 adding forward, AFII, mc16d/reproc data, new mat syst
+    es2017_R21_ofc0_v1,  // Release 21 model calibration extrapolated for OFC(mu=0), coveering 2015,2016,2017 and 2018 data
+    es2018_R21_v0,
+    es2018_R21_v1,     // model with new E1/E2 muon calibration from full run 2 low+high mu data
+
     UNDEFINED
 
   };
 
-  // Geometry dostortions
+  // Geometry distortions
 
   enum Geometry {
     ConfigA=0,     // 5% ID material scaling
     ConfigCD,      // 10% services scaling
     ConfigEL,      // +7.5%X0 in SCT/TRT endcap; 10%X0, radial, in cryostat
     ConfigFMX,     // +7.5%X0 on ID endplate; 5%X0, radial, between PS and Strips
-    ConfigGp       // all together
+    ConfigGp,      // all together
+    ConfigN,       // material between PS and calo in EndCap (only used for release 21)
+    ConfigIBL,     // IBL systematics in run 2 geometry
+    ConfigPP0      // PP0 systematics in run 2 geometry
   };
 
   // Measured material categories
@@ -308,26 +332,24 @@ namespace AtlasRoot {
                       egEnergyCorr::Resolution::resolutionType resType = egEnergyCorr::Resolution::SigmaEff90 ) const;
 
     // new for mc12c model. Return relative uncertainty on the resolution
-    double getResolutionError(double energy, double eta, double etaCalo, PATCore::ParticleType::Type ptype, egEnergyCorr::Resolution::Variation value,
+    double getResolutionError(PATCore::ParticleDataType::DataType dataType,double energy, double eta, double etaCalo, PATCore::ParticleType::Type ptype, egEnergyCorr::Resolution::Variation value,
                               egEnergyCorr::Resolution::resolutionType resType = egEnergyCorr::Resolution::Gaussian) const;
 
 
     std::string variationName(egEnergyCorr::Scale::Variation& var) const;
     std::string variationName(egEnergyCorr::Resolution::Variation& var) const;
 
-    static egEnergyCorr::Scale::Variation ScaleVariationFromString(std::string& var);
-    static egEnergyCorr::Resolution::Variation ResolutionVariationFromString(std::string& var);
 
     // convenient method for decorrelation of statistical error
-    const TAxis& get_ZeeStat_eta_axis() const { return *m_zeeNom->GetXaxis(); }
+    const TAxis& get_ZeeStat_eta_axis() const;
 
   private:
     // TODO: remove mutable
-    mutable egGain::GainTool* m_gain_tool;                    // run 1
-    egGain::GainUncertainty* m_gain_tool_run2;        // based on special run for run2
-    mutable eg_resolution* m_resolution_tool;
-    mutable get_MaterialResolutionEffect* m_getMaterialDelta;
-    mutable e1hg_systematics* m_e1hg_tool;
+    mutable std::unique_ptr<egGain::GainTool> m_gain_tool;                    // run 1
+    std::unique_ptr<egGain::GainUncertainty> m_gain_tool_run2;        // based on special run for run2
+    mutable std::unique_ptr<eg_resolution> m_resolution_tool;
+    mutable std::unique_ptr<get_MaterialResolutionEffect> m_getMaterialDelta;
+    mutable std::unique_ptr<e1hg_systematics> m_e1hg_tool;
 
     double getAlphaValue(long int runnumber, double cl_eta, double cl_etaCalo,
 			 double energy, double energyS2, double eraw,
@@ -356,7 +378,7 @@ namespace AtlasRoot {
     /// MC calibration corrections
 
 
-    double applyAFtoG4(double eta, PATCore::ParticleType::Type ptype) const;
+    double applyAFtoG4(double eta, double ptGeV, PATCore::ParticleType::Type ptype) const;
     double applyFStoG4(double eta) const;
 
     // functions for resolution uncertainty evaluation
@@ -400,6 +422,8 @@ namespace AtlasRoot {
     double getAlphaMaterial( double cl_eta, egEnergyCorr::MaterialCategory imat, PATCore::ParticleType::Type ptype,
 			     egEnergyCorr::Scale::Variation var = egEnergyCorr::Scale::Nominal, double varSF = 1. ) const;
 
+    double getMaterialEffect(egEnergyCorr::Geometry geo,PATCore::ParticleType::Type ptype,double cl_eta,double ET) const;
+
     double getMaterialNonLinearity( double cl_eta, double energy, egEnergyCorr::MaterialCategory imat, PATCore::ParticleType::Type ptype,
 				    egEnergyCorr::Scale::Variation var = egEnergyCorr::Scale::Nominal, double varSF = 1. ) const;
 
@@ -427,15 +451,15 @@ namespace AtlasRoot {
      @brief  Output : resolution_error = uncertainty on energy resolution in MeV from the systematics included according to bit mask
      @brief resolution_type 0=gaussian core, 1= sigma eff 80%, 2 = sigma eff 90%
   */
-    void getResolution_systematics(int particle_type, double energy, double eta, double etaCalo, int syst_mask, double& resolution, double& resolution_error,double& resolution_error_up, double & resolution_error_down, int resol_type=0) const;
+    void getResolution_systematics(int particle_type, double energy, double eta, double etaCalo, int syst_mask, double& resolution, double& resolution_error,double& resolution_error_up, double & resolution_error_down, int resol_type=0, bool fast=false) const;
 
     // approximate pileup noise contribution to the resolution
-    double pileUpTerm(double eta, int particle_type) const;
+    double pileUpTerm(double energy, double eta, int particle_type) const;
 
   private:
 
 
-    TFile* m_rootFile;
+    std::unique_ptr<TFile> m_rootFile;
     std::string m_rootFileName;
 
     mutable TRandom3   m_random3;
@@ -443,120 +467,147 @@ namespace AtlasRoot {
     unsigned int  m_begRunNumber;
     unsigned int  m_endRunNumber;
 
-    TH1D*         m_trkSyst;
-
-    TH1D*         m_aPSNom;
-    TH1D*         m_daPSCor;
-    TH1D*         m_aS12Nom;
-    TH1D*         m_daS12Cor;
-
-    TH1D*         m_zeeNom;
-    TH1D*         m_zeeNom_data2015;
-
-    TH1D*         m_zeeSyst;
-    TH1D*         m_zeePhys;
-    TH1*          m_uA2MeV_2015_first2weeks_correction;
-
-    TH1D*         m_resNom;
-    TH1D*         m_resSyst;
-    TH1D*         m_peakResData;
-    TH1D*         m_peakResMC;
-
-    TH1D*         m_dX_ID_Nom;
-
-    TH1D*         m_dX_IPPS_Nom;
-    TH1D*         m_dX_IPPS_LAr;
-
-    TH1D*         m_dX_IPAcc_Nom;
-    TH1D*         m_dX_IPAcc_G4;
-    TH1D*         m_dX_IPAcc_LAr;
-    TH1D*         m_dX_IPAcc_GL1;
-
-    TH1D*         m_dX_PSAcc_Nom;
-    TH1D*         m_dX_PSAcc_G4;
-    TH1D*         m_dX_PSAcc_LAr;
-
-    TAxis*        m_psElectronEtaBins;
-    TList*        m_psElectronGraphs;
-    TAxis*        m_psUnconvertedEtaBins;
-    TList*        m_psUnconvertedGraphs;
-    TAxis*        m_psConvertedEtaBins;
-    TList*        m_psConvertedGraphs;
-
-    TAxis*        m_E4ElectronEtaBins = nullptr;
-    TList*        m_E4ElectronGraphs = nullptr;
-    TAxis*        m_E4UnconvertedEtaBins = nullptr;
-    TList*        m_E4UnconvertedGraphs = nullptr;
-    TAxis*        m_E4ConvertedEtaBins = nullptr;
-    TList*        m_E4ConvertedGraphs = nullptr;
-
-    TAxis*        m_s12ElectronEtaBins;
-    TList*        m_s12ElectronGraphs;
-    TAxis*        m_s12UnconvertedEtaBins;
-    TList*        m_s12UnconvertedGraphs;
-    TAxis*        m_s12ConvertedEtaBins;
-    TList*        m_s12ConvertedGraphs;
-
-    TH1D*         m_pedestalL0;
-    TH1D*         m_pedestalL1;
-    TH1D*         m_pedestalL2;
-    TH1D*         m_pedestalL3;
-
-    TH1F*         m_pedestals_es2017;
-
-    TH2D*         m_convRadius;
-    TH1D*         m_convFakeRate;
-    TH1D*         m_convRecoEfficiency;
-
-    TH1D*         m_leakageConverted;
-    TH1D*         m_leakageUnconverted;
-
-    TH1D*         m_zeeES2Profile;
-
-    TH2D*         m_pp0_elec;
-    TH2D*         m_pp0_unconv;
-    TH2D*         m_pp0_conv;
-
-    TH1D*         m_wstot_slope_A_data;
-    TH1D*         m_wstot_slope_B_MC;
-    TH1D*         m_wstot_40GeV_data;
-    TH1D*         m_wstot_40GeV_MC;
-    TH1D*         m_wstot_pT_data_p0_electrons;
-    TH1D*         m_wstot_pT_data_p1_electrons;
-    TH1D*         m_wstot_pT_data_p0_unconverted_photons;
-    TH1D*         m_wstot_pT_data_p1_unconverted_photons;
-    TH1D*         m_wstot_pT_data_p0_converted_photons;
-    TH1D*         m_wstot_pT_data_p1_converted_photons;
-    TH1D*         m_wstot_pT_MC_p0_electrons;
-    TH1D*         m_wstot_pT_MC_p1_electrons;
-    TH1D*         m_wstot_pT_MC_p0_unconverted_photons;
-    TH1D*         m_wstot_pT_MC_p1_unconverted_photons;
-    TH1D*         m_wstot_pT_MC_p0_converted_photons;
-    TH1D*         m_wstot_pT_MC_p1_converted_photons;
-    
+   std::unique_ptr<TH1>         m_trkSyst;
+
+    std::unique_ptr<TH1>         m_aPSNom;
+    std::unique_ptr<TH1>         m_daPSCor;
+    std::unique_ptr<TH1>         m_daPSb12;
+    std::unique_ptr<TH1>         m_aS12Nom;
+    std::unique_ptr<TH1>         m_daS12Cor;
+
+    std::unique_ptr<TH1>         m_zeeNom;
+    std::unique_ptr<TH1>         m_zeeNom_data2015;
+    std::unique_ptr<TH1>         m_zeeNom_data2016;
+    std::unique_ptr<TH1>         m_zeeNom_data2017;
+    std::unique_ptr<TH1>         m_zeeNom_data2018;
+    std::unique_ptr<TH1>         m_zeeFwdk;
+    std::unique_ptr<TH1>         m_zeeFwdb;
+
+    std::unique_ptr<TH1>         m_zeeSyst;
+    std::unique_ptr<TH1>         m_zeePhys;
+    std::unique_ptr<TH1>         m_uA2MeV_2015_first2weeks_correction;
+
+    std::unique_ptr<TH1>         m_resNom;
+    std::unique_ptr<TH1>         m_resSyst;
+    std::unique_ptr<TH1>         m_peakResData;
+    std::unique_ptr<TH1>         m_peakResMC;
+
+    std::unique_ptr<TH1>         m_dX_ID_Nom;
+
+    std::unique_ptr<TH1>         m_dX_IPPS_Nom;
+    std::unique_ptr<TH1>         m_dX_IPPS_LAr;
+
+    std::unique_ptr<TH1>         m_dX_IPAcc_Nom;
+    std::unique_ptr<TH1>         m_dX_IPAcc_G4;
+    std::unique_ptr<TH1>         m_dX_IPAcc_LAr;
+    std::unique_ptr<TH1>         m_dX_IPAcc_GL1;
+
+    std::unique_ptr<TH1>         m_dX_PSAcc_Nom;
+    std::unique_ptr<TH1>         m_dX_PSAcc_G4;
+    std::unique_ptr<TH1>         m_dX_PSAcc_LAr;
+
+    std::unique_ptr<TAxis>        m_psElectronEtaBins;
+    std::unique_ptr<TList>        m_psElectronGraphs;
+    std::unique_ptr<TAxis>        m_psUnconvertedEtaBins;
+    std::unique_ptr<TList>        m_psUnconvertedGraphs;
+    std::unique_ptr<TAxis>        m_psConvertedEtaBins;
+    std::unique_ptr<TList>        m_psConvertedGraphs;
+
+    std::unique_ptr<TAxis>        m_E4ElectronEtaBins;
+    std::unique_ptr<TList>        m_E4ElectronGraphs;
+    std::unique_ptr<TAxis>        m_E4UnconvertedEtaBins;
+    std::unique_ptr<TList>        m_E4UnconvertedGraphs;
+    std::unique_ptr<TAxis>        m_E4ConvertedEtaBins;
+    std::unique_ptr<TList>        m_E4ConvertedGraphs;
+
+    std::unique_ptr<TAxis>        m_s12ElectronEtaBins;
+    std::unique_ptr<TList>        m_s12ElectronGraphs;
+    std::unique_ptr<TAxis>        m_s12UnconvertedEtaBins;
+    std::unique_ptr<TList>        m_s12UnconvertedGraphs;
+    std::unique_ptr<TAxis>        m_s12ConvertedEtaBins;
+    std::unique_ptr<TList>        m_s12ConvertedGraphs;
+
+    std::unique_ptr<TH1>         m_pedestalL0;
+    std::unique_ptr<TH1>         m_pedestalL1;
+    std::unique_ptr<TH1>         m_pedestalL2;
+    std::unique_ptr<TH1>         m_pedestalL3;
+
+    std::unique_ptr<TH1>         m_pedestals_es2017;
+
+    std::unique_ptr<TH1>         m_convRadius;
+    std::unique_ptr<TH1>         m_convFakeRate;
+    std::unique_ptr<TH1>         m_convRecoEfficiency;
+
+    std::unique_ptr<TH1>         m_leakageConverted;
+    std::unique_ptr<TH1>         m_leakageUnconverted;
+
+    std::unique_ptr<TH1>         m_zeeES2Profile;
+
+    std::unique_ptr<TH2>         m_pp0_elec;
+    std::unique_ptr<TH2>         m_pp0_unconv;
+    std::unique_ptr<TH2>         m_pp0_conv;
+
+    std::unique_ptr<TH1>         m_wstot_slope_A_data;
+    std::unique_ptr<TH1>         m_wstot_slope_B_MC;
+    std::unique_ptr<TH1>         m_wstot_pT_data_p0_electrons;
+    std::unique_ptr<TH1>         m_wstot_pT_data_p1_electrons;
+    std::unique_ptr<TH1>         m_wstot_pT_data_p0_unconverted_photons;
+    std::unique_ptr<TH1>         m_wstot_pT_data_p1_unconverted_photons;
+    std::unique_ptr<TH1>         m_wstot_pT_data_p0_converted_photons;
+    std::unique_ptr<TH1>         m_wstot_pT_data_p1_converted_photons;
+    std::unique_ptr<TH1>         m_wstot_pT_MC_p0_electrons;
+    std::unique_ptr<TH1>         m_wstot_pT_MC_p1_electrons;
+    std::unique_ptr<TH1>         m_wstot_pT_MC_p0_unconverted_photons;
+    std::unique_ptr<TH1>         m_wstot_pT_MC_p1_unconverted_photons;
+    std::unique_ptr<TH1>         m_wstot_pT_MC_p0_converted_photons;
+    std::unique_ptr<TH1>         m_wstot_pT_MC_p1_converted_photons;
+
     // Geometry distortion vectors (to be ordered as in the the Geometry enum!)
 
-    std::vector<TH1D*> m_matElectronScale;
-    std::vector<TH1D*> m_matUnconvertedScale;
-    std::vector<TH1D*> m_matConvertedScale;
-    std::vector<TH1F*> m_matElectronCstTerm;
-    std::vector<TH1D*> m_matX0Additions;
+    std::vector<std::unique_ptr<TH1>> m_matElectronScale;
+    std::vector<std::unique_ptr<TH1>> m_matUnconvertedScale;
+    std::vector<std::unique_ptr<TH1>> m_matConvertedScale;
+    std::vector<std::unique_ptr<TH1>> m_matElectronCstTerm;
+    std::vector<std::unique_ptr<TH1>> m_matX0Additions;
 
     // Non-linearity graphs
 
-    TAxis*              m_matElectronEtaBins;
-    std::vector<TList*> m_matElectronGraphs;
+    std::unique_ptr<TAxis>              m_matElectronEtaBins;
+    std::vector<std::unique_ptr<TList>> m_matElectronGraphs;
+
+    // 2D histograms for release 21 material systematics sensitivity parameterization
+    std::unique_ptr<TH2> m_electronBias_ConfigA;
+    std::unique_ptr<TH2> m_electronBias_ConfigEpLp;
+    std::unique_ptr<TH2> m_electronBias_ConfigFpMX;
+    std::unique_ptr<TH2> m_electronBias_ConfigN;
+    std::unique_ptr<TH2> m_electronBias_ConfigIBL;
+    std::unique_ptr<TH2> m_electronBias_ConfigPP0;
+    std::unique_ptr<TH2> m_unconvertedBias_ConfigA;
+    std::unique_ptr<TH2> m_unconvertedBias_ConfigEpLp;
+    std::unique_ptr<TH2> m_unconvertedBias_ConfigFpMX;
+    std::unique_ptr<TH2> m_unconvertedBias_ConfigN;
+    std::unique_ptr<TH2> m_unconvertedBias_ConfigIBL;
+    std::unique_ptr<TH2> m_unconvertedBias_ConfigPP0;
+    std::unique_ptr<TH2> m_convertedBias_ConfigA;
+    std::unique_ptr<TH2> m_convertedBias_ConfigEpLp;
+    std::unique_ptr<TH2> m_convertedBias_ConfigFpMX;
+    std::unique_ptr<TH2> m_convertedBias_ConfigN;
+    std::unique_ptr<TH2> m_convertedBias_ConfigIBL;
+    std::unique_ptr<TH2> m_convertedBias_ConfigPP0;
 
     // Fastsim -> Fullsim corrections
 
-    TH1D*         m_G4OverAFII_electron;
-    TH1D*         m_G4OverAFII_converted;
-    TH1D*         m_G4OverAFII_unconverted;
-    TH1D*         m_G4OverFrSh;
-
-    TH2F* m_G4OverAFII_resolution_electron;
-    TH2F* m_G4OverAFII_resolution_unconverted;
-    TH2F* m_G4OverAFII_resolution_converted;
+    std::unique_ptr<TH1>         m_G4OverAFII_electron;
+    std::unique_ptr<TH1>         m_G4OverAFII_converted;
+    std::unique_ptr<TH1>         m_G4OverAFII_unconverted;
+    std::unique_ptr<TH2>         m_G4OverAFII_electron_2D;
+    std::unique_ptr<TH2>         m_G4OverAFII_converted_2D;
+    std::unique_ptr<TH2>         m_G4OverAFII_unconverted_2D;
+    std::unique_ptr<TH1>         m_G4OverFrSh;
+
+    std::unique_ptr<TH2> m_G4OverAFII_resolution_electron;
+    std::unique_ptr<TH2> m_G4OverAFII_resolution_unconverted;
+    std::unique_ptr<TH2> m_G4OverAFII_resolution_converted;
 
     // Main ES model switch
 
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/get_MaterialResolutionEffect.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/get_MaterialResolutionEffect.h
index 9991efa21dacab3f044bfe66e0c3b9ca3ad613d2..e29f7602e8b83d14f9075beabef6efee8a22231c 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/get_MaterialResolutionEffect.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/get_MaterialResolutionEffect.h
@@ -1,20 +1,16 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef get_MaterialResolutionEffect_H
 #define get_MaterialResolutionEffect_H
-#include <stdlib.h>
-#include <math.h>
 #include <memory>
+#include <cstdlib>
+#include <cmath>
+#include <array>
 
 #include "AsgMessaging/AsgMessaging.h"
 
-#include "TH1.h"
-#include "TH2D.h"
-#include "TFile.h"
-#include "TArrayD.h"
-
 /**
   @class get_MaterialResolutionEffect
   @brief get resolution systematics from material effect (mc12c setup, MVA calibration)
@@ -24,6 +20,12 @@
 
 */
 
+class TH1;
+class TH2;
+class TFile;
+class TArrayD;
+
+
 class get_MaterialResolutionEffect : public asg::AsgMessaging {
 
  public:
@@ -44,12 +46,11 @@ class get_MaterialResolutionEffect : public asg::AsgMessaging {
  private:
 
   // histograms to store resolution parameters
-  TH1D* m_hSystPeak[4][8][3];
-  TH1D* m_hSystResol[4][8][3];
-  TH2D* m_hsyst_IBL_PP0[3];
+  std::array<std::array<std::array<std::unique_ptr<TH1>, 3>, 8>,4> m_hSystPeak;
+  std::array<std::array<std::array<std::unique_ptr<TH1>, 3>, 8>,4> m_hSystResol;
+  std::array<std::unique_ptr<TH2>, 3> m_hsyst_IBL_PP0;
   std::unique_ptr <TFile> m_file0;
-  //const TArrayD* m_etaBins;
-  const TArrayD* m_etBins;
+  const TArrayD* m_etBins; //A xistogram will own this
 
 
 };
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/selection.xml b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/selection.xml
index 9b0f78361db20c000c464b382e9604136fae2f52..a3fa90c9f8e24fae0a1830d93220cf7d9510571d 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/selection.xml
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/selection.xml
@@ -1,6 +1,5 @@
  <lcgdict>
 
-   <class name="CP::IEgammaCalibrationAndSmearingTool" />
    <class name="CP::EgammaCalibrationAndSmearingTool" />
 
    <class name="AtlasRoot::egammaEnergyCorrectionTool" />
@@ -20,4 +19,5 @@
    <class name="EgammaFactory" />
    <class name="LArTemperatureCorrectionTool" />
 
+
 </lcgdict>
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/systematics_S12.def b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/systematics_S12.def
new file mode 100644
index 0000000000000000000000000000000000000000..d95f1cac96383cecf875a9c8992efcd8d7241a21
--- /dev/null
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/ElectronPhotonFourMomentumCorrection/systematics_S12.def
@@ -0,0 +1,19 @@
+SYSMACRO(EG_SCALE_ZEESYST,        1, std::vector<double>(),        egEnergyCorr::Scale::ZeeSystUp,        egEnergyCorr::Scale::ZeeSystDown)
+SYSMACRO(EG_SCALE_LARCALIB,       0, decorrelation_bins_BE,        egEnergyCorr::Scale::LArCalibUp,       egEnergyCorr::Scale::LArCalibDown)
+SYSMACRO(EG_SCALE_LARUNCONVCALIB, 0, decorrelation_bins_BE,        egEnergyCorr::Scale::LArUnconvCalibUp, egEnergyCorr::Scale::LArUnconvCalibDown)
+SYSMACRO(EG_SCALE_LARELECCALIB,   1, std::vector<double>(),        egEnergyCorr::Scale::LArElecCalibUp,   egEnergyCorr::Scale::LArElecCalibDown)
+SYSMACRO(EG_SCALE_LARELECUNCONV,  0, decorrelation_bins_BE,        egEnergyCorr::Scale::LArElecUnconvUp,  egEnergyCorr::Scale::LArElecUnconvDown)
+SYSMACRO(EG_SCALE_G4,             1, std::vector<double>(),        egEnergyCorr::Scale::G4Up,             egEnergyCorr::Scale::G4Down)
+SYSMACRO(EG_SCALE_PS,             0, decorrelation_edges_MODULE,   egEnergyCorr::Scale::PSUp,             egEnergyCorr::Scale::PSDown)
+SYSMACRO(EG_SCALE_S12,            0, decorrelation_edges_S12,      egEnergyCorr::Scale::S12Up,            egEnergyCorr::Scale::S12Down);
+SYSMACRO(EG_SCALE_MATID,          0, decorrelation_edges_MATERIAL, egEnergyCorr::Scale::MatIDUp,          egEnergyCorr::Scale::MatIDDown);
+SYSMACRO(EG_SCALE_MATCRYO,        0, decorrelation_edges_TWELVE,   egEnergyCorr::Scale::MatCryoUp,        egEnergyCorr::Scale::MatCryoDown)
+SYSMACRO(EG_SCALE_MATCALO,        0, decorrelation_edges_TWELVE,   egEnergyCorr::Scale::MatCaloUp,        egEnergyCorr::Scale::MatCaloDown)
+SYSMACRO(EG_SCALE_L1GAIN,         1, std::vector<double>(),        egEnergyCorr::Scale::L1GainUp,         egEnergyCorr::Scale::L1GainDown)
+SYSMACRO(EG_SCALE_L2GAIN,         1, std::vector<double>(),        egEnergyCorr::Scale::L2GainUp,         egEnergyCorr::Scale::L2GainDown)
+SYSMACRO(EG_SCALE_PEDESTAL,       1, std::vector<double>(),        egEnergyCorr::Scale::PedestalUp,       egEnergyCorr::Scale::PedestalDown)
+SYSMACRO(PH_SCALE_LEAKAGEUNCONV,  1, std::vector<double>(),        egEnergyCorr::Scale::LeakageUnconvUp,  egEnergyCorr::Scale::LeakageUnconvDown)
+SYSMACRO(PH_SCALE_LEAKAGECONV,    1, std::vector<double>(),        egEnergyCorr::Scale::LeakageConvUp,    egEnergyCorr::Scale::LeakageConvDown)
+SYSMACRO(PH_SCALE_CONVEFFICIENCY, 1, std::vector<double>(),        egEnergyCorr::Scale::ConvEfficiencyUp, egEnergyCorr::Scale::ConvEfficiencyDown)
+SYSMACRO(PH_SCALE_CONVFAKERATE,   1, std::vector<double>(),        egEnergyCorr::Scale::ConvFakeRateUp,   egEnergyCorr::Scale::ConvFakeRateDown)
+SYSMACRO(PH_SCALE_CONVRADIUS,     1, std::vector<double>(),        egEnergyCorr::Scale::ConvRadiusUp,     egEnergyCorr::Scale::ConvRadiusDown)
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/EgammaCalibrationAndSmearingTool.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/EgammaCalibrationAndSmearingTool.cxx
index df8f2686cf82eb310fc2ee9730645d27ddcb8f24..0b582b9b794e07ff24c0f5d2c53b9cf6053f2f64 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/EgammaCalibrationAndSmearingTool.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/EgammaCalibrationAndSmearingTool.cxx
@@ -60,10 +60,16 @@ std::unique_ptr<egGain::GainTool> gainToolFactory(egEnergyCorr::ESModel model)
       return std::make_unique<egGain::GainTool>(gain_filename1, gain_filename2);
     }
     case egEnergyCorr::es2017:
-    case egEnergyCorr::es2017_summer: 
+    case egEnergyCorr::es2017_summer:
     case egEnergyCorr::es2017_summer_improved:
+    case egEnergyCorr::es2017_summer_final:
     case egEnergyCorr::es2017_R21_PRE:
-      return nullptr;  
+    case egEnergyCorr::es2017_R21_v0:
+    case egEnergyCorr::es2017_R21_v1:
+    case egEnergyCorr::es2017_R21_ofc0_v1:
+    case egEnergyCorr::es2018_R21_v0:
+    case egEnergyCorr::es2018_R21_v1:
+      return nullptr;
     default:
       return nullptr;
   }
@@ -97,9 +103,16 @@ std::unique_ptr<egammaMVATool> egammaMVAToolFactory(egEnergyCorr::ESModel model)
         case egEnergyCorr::es2017:
         case egEnergyCorr::es2017_summer:
         case egEnergyCorr::es2017_summer_improved:
+        case egEnergyCorr::es2017_summer_final:
+        case egEnergyCorr::es2015_5TeV:
           folder = "egammaMVACalib/offline/v4.0";
           break;
         case egEnergyCorr::es2017_R21_PRE:
+        case egEnergyCorr::es2017_R21_v0:
+        case egEnergyCorr::es2017_R21_v1:
+        case egEnergyCorr::es2017_R21_ofc0_v1:
+        case egEnergyCorr::es2018_R21_v0:
+        case egEnergyCorr::es2018_R21_v1:
 	  folder = "egammaMVACalib/offline/v7";
           break;
         default: folder = "";
@@ -134,13 +147,26 @@ std::unique_ptr<egammaLayerRecalibTool> egammaLayerRecalibToolFactory(egEnergyCo
     case egEnergyCorr::es2015c_summer:
     case egEnergyCorr::es2016PRE:
     case egEnergyCorr::es2017:
-    case egEnergyCorr::es2017_R21_PRE:  
+    case egEnergyCorr::es2015_5TeV:
+    case egEnergyCorr::es2017_R21_PRE:
       tune = "2012_alt_with_layer2";
       break;
     case egEnergyCorr::es2017_summer:
     case egEnergyCorr::es2017_summer_improved:
       tune = "es2017_20.7_improved";
       break;
+    case egEnergyCorr::es2017_summer_final:
+      tune = "es2017_20.7_final";
+      break;
+    case egEnergyCorr::es2017_R21_v0:
+    case egEnergyCorr::es2017_R21_v1:
+    case egEnergyCorr::es2017_R21_ofc0_v1:
+    case egEnergyCorr::es2018_R21_v0:
+      tune = "es2017_21.0_v0";
+      break;
+    case egEnergyCorr::es2018_R21_v1:
+      tune = "es2018_21.0_v0";
+      break;
     default:
       return nullptr;
   }
@@ -170,9 +196,16 @@ bool use_intermodule_correction(egEnergyCorr::ESModel model)
     case egEnergyCorr::es2015c_summer:
     case egEnergyCorr::es2016PRE:
     case egEnergyCorr::es2017:
-    case egEnergyCorr::es2017_summer:  
+    case egEnergyCorr::es2017_summer:
     case egEnergyCorr::es2017_summer_improved:
+    case egEnergyCorr::es2017_summer_final:
+    case egEnergyCorr::es2015_5TeV:
     case egEnergyCorr::es2017_R21_PRE:
+    case egEnergyCorr::es2017_R21_v0:
+    case egEnergyCorr::es2017_R21_v1:
+    case egEnergyCorr::es2017_R21_ofc0_v1:
+    case egEnergyCorr::es2018_R21_v0:
+    case egEnergyCorr::es2018_R21_v1:
       return true;
     case egEnergyCorr::UNDEFINED:  // TODO: find better logic
       return false;
@@ -209,8 +242,15 @@ bool is_run2(egEnergyCorr::ESModel model)
     case egEnergyCorr::es2016PRE:
     case egEnergyCorr::es2017:
     case egEnergyCorr::es2017_summer:
-    case egEnergyCorr::es2017_summer_improved:    
-    case egEnergyCorr::es2017_R21_PRE:  
+    case egEnergyCorr::es2017_summer_improved:
+    case egEnergyCorr::es2017_summer_final:
+    case egEnergyCorr::es2015_5TeV:
+    case egEnergyCorr::es2017_R21_PRE:
+    case egEnergyCorr::es2017_R21_v0:
+    case egEnergyCorr::es2017_R21_v1:
+    case egEnergyCorr::es2017_R21_ofc0_v1:
+    case egEnergyCorr::es2018_R21_v0:
+    case egEnergyCorr::es2018_R21_v1:
       return true;
     case egEnergyCorr::UNDEFINED:  // TODO: find better logic
       return false;
@@ -289,8 +329,15 @@ StatusCode EgammaCalibrationAndSmearingTool::initialize() {
   else if (m_ESModel == "es2016PRE") { m_TESModel = egEnergyCorr::es2016PRE; }
   else if (m_ESModel == "es2016data_mc15c") { m_TESModel = egEnergyCorr::es2017; }
   else if (m_ESModel == "es2016data_mc15c_summer") { m_TESModel = egEnergyCorr::es2017_summer; }
-  else if (m_ESModel == "es2016data_mc15c_summer_improved") { m_TESModel = egEnergyCorr::es2017_summer_improved; } 
+  else if (m_ESModel == "es2016data_mc15c_summer_improved") { m_TESModel = egEnergyCorr::es2017_summer_improved; }
+  else if (m_ESModel == "es2016data_mc15c_final") { m_TESModel = egEnergyCorr::es2017_summer_final; }
+  else if (m_ESModel == "es2015_5TeV") { m_TESModel = egEnergyCorr::es2015_5TeV; }
   else if (m_ESModel == "es2017_R21_PRE") { m_TESModel = egEnergyCorr::es2017_R21_PRE; }
+  else if (m_ESModel == "es2017_R21_v0") {m_TESModel = egEnergyCorr::es2017_R21_v0;}
+  else if (m_ESModel == "es2017_R21_v1") {m_TESModel = egEnergyCorr::es2017_R21_v1;}
+  else if (m_ESModel == "es2017_R21_ofc0_v1") {m_TESModel = egEnergyCorr::es2017_R21_ofc0_v1;}
+  else if (m_ESModel == "es2018_R21_v0") {m_TESModel = egEnergyCorr::es2018_R21_v0;}
+  else if (m_ESModel == "es2018_R21_v1") {m_TESModel = egEnergyCorr::es2018_R21_v1;}
   else if (m_ESModel.empty()) {
     ATH_MSG_ERROR("you must set ESModel property");
     return StatusCode::FAILURE;
@@ -423,7 +470,8 @@ StatusCode EgammaCalibrationAndSmearingTool::initialize() {
   }
 
   // configure layer recalibration tool
-  //For now: layer recalibration only needed before release 21
+  //For now: layer recalibration not applied to PRE release 21 (using run 1 based calibration applied at reco level)
+  //  for following R21 recommendations, need to apply the run2/run1 layer calibration ratio
   if (m_ESModel == "es2017_R21_PRE"){
     ATH_MSG_INFO("Layer recalibration already applied at cell level");
     m_useLayerCorrection = false;
@@ -439,7 +487,7 @@ StatusCode EgammaCalibrationAndSmearingTool::initialize() {
     }
     if (m_layer_recalibration_tool) { m_layer_recalibration_tool->msg().setLevel(this->msg().level()); }
   }
-  
+
   if (m_use_temp_correction201215 != AUTO) m_rootTool->use_temp_correction201215(m_use_temp_correction201215);
   if (m_use_uA2MeV_2015_first2weeks_correction != AUTO) m_rootTool->use_uA2MeV_2015_first2weeks_correction(m_use_uA2MeV_2015_first2weeks_correction);
   if (not m_use_full_statistical_error and m_decorrelation_model_scale == ScaleDecorrelation::FULL) { m_rootTool->useStatErrorScaling(true); }
@@ -448,7 +496,7 @@ StatusCode EgammaCalibrationAndSmearingTool::initialize() {
     ATH_MSG_ERROR("ep combination not supported yet");
     throw std::runtime_error("ep combination not supported yet");
   }
-  
+
   if (m_useIntermoduleCorrection == AUTO) { m_useIntermoduleCorrection = use_intermodule_correction(m_TESModel); }
   if (m_usePhiUniformCorrection == AUTO) { m_usePhiUniformCorrection = use_phi_uniform_correction(m_TESModel); }
   m_use_mapping_correction = not is_run2(m_TESModel);
@@ -503,18 +551,18 @@ StatusCode EgammaCalibrationAndSmearingTool::initialize() {
  * The typical scenario is :
  * For every IncidentType::BeginInputFile we can check for metadata
  * and try to employ them in determining the simulation Flavor.
- * If we found metadata 
+ * If we found metadata
  * set m_metadata_retrieved= True else set it to False
- * 
+ *
  * EndInputFile should not do something. As in any case we try for
  * each new IncidentType::BeginInputFile to do a retrieval
  *
  * The beginEvent should kick in only if the beginInputFile has
- * failed to find metadata . In which case we try to employ the event info 
- * 
+ * failed to find metadata . In which case we try to employ the event info
+ *
  * Asg/base class has our back in cases where the 1st beginEvent
  * happens before the 1st beginInputFile.
- * 
+ *
  * For this tool the apply correction is also using the EventInfo
  * to figure out data vs MC.
  */
@@ -522,7 +570,7 @@ StatusCode EgammaCalibrationAndSmearingTool::initialize() {
 StatusCode EgammaCalibrationAndSmearingTool::get_simflavour_from_metadata(PATCore::ParticleDataType::DataType& result) const
 {
 // adapted from https://svnweb.cern.ch/trac/atlasoff/browser/PhysicsAnalysis/AnalysisCommon/CPAnalysisExamples/trunk/Root/MetadataToolExample.cxx
-#ifndef XAOD_STANDALONE 
+#ifndef XAOD_STANDALONE
   //Try the Athena/POOL machinery
   std::string dataType("");
   if(AthAnalysisHelper::retrieveMetadata("/TagInfo", "project_name", dataType, inputMetaStore()).isSuccess()){
@@ -536,7 +584,7 @@ StatusCode EgammaCalibrationAndSmearingTool::get_simflavour_from_metadata(PATCor
           std::string simType("");
           ATH_CHECK(AthAnalysisHelper::retrieveMetadata("/Simulation/Parameters", "SimulationFlavour", simType, inputMetaStore()));
           boost::to_upper(simType);
-          result = (simType.find("ATLFASTII")==std::string::npos) ?  PATCore::ParticleDataType::Full : PATCore::ParticleDataType::Fast; 
+          result = (simType.find("ATLFASTII")==std::string::npos) ?  PATCore::ParticleDataType::Full : PATCore::ParticleDataType::Fast;
           return StatusCode::SUCCESS;
       }
   }
@@ -577,13 +625,13 @@ StatusCode EgammaCalibrationAndSmearingTool::beginInputFile()
   const StatusCode status_metadata = get_simflavour_from_metadata(data_flavour_metadata);
   if (status_metadata == StatusCode::SUCCESS) {
     m_metadata_retrieved = true;
-    ATH_MSG_DEBUG("metadata from new file: " << 
-            (data_flavour_metadata == PATCore::ParticleDataType::Data ? "data" : 
+    ATH_MSG_DEBUG("metadata from new file: " <<
+            (data_flavour_metadata == PATCore::ParticleDataType::Data ? "data" :
              (data_flavour_metadata == PATCore::ParticleDataType::Full ? "full simulation" : "fast simulation")));
 
     if (data_flavour_metadata != PATCore::ParticleDataType::Data) {
-        if (m_use_AFII == AUTO) { 
-            m_simulation = data_flavour_metadata; 
+        if (m_use_AFII == AUTO) {
+            m_simulation = data_flavour_metadata;
         }
         else { // user has set a preference
           // check if the preference is consistent and warn
@@ -611,7 +659,7 @@ StatusCode EgammaCalibrationAndSmearingTool::endInputFile() {
 }
 
 StatusCode EgammaCalibrationAndSmearingTool::beginEvent() {
-  
+
     if (m_metadata_retrieved) return StatusCode::SUCCESS;
 
     //determine MC/Data from evtInfo ... this will work for both athena and eventloop
@@ -702,7 +750,7 @@ CP::CorrectionCode EgammaCalibrationAndSmearingTool::correctedCopy(const xAOD::P
 double EgammaCalibrationAndSmearingTool::getEnergy(const xAOD::Photon& input)
 {
   xAOD::Photon* new_particle = nullptr;
-  ANA_CHECK_THROW (correctedCopy(input, new_particle));
+  ANA_CHECK_THROW(correctedCopy(input, new_particle));
   const double e = new_particle->e();
   delete new_particle;
   return e;
@@ -711,7 +759,7 @@ double EgammaCalibrationAndSmearingTool::getEnergy(const xAOD::Photon& input)
 double EgammaCalibrationAndSmearingTool::getEnergy(const xAOD::Electron& input)
 {
   xAOD::Electron* new_particle = nullptr;
-  ANA_CHECK_THROW (correctedCopy(input, new_particle));
+  ANA_CHECK_THROW(correctedCopy(input, new_particle));
   const double e = new_particle->e();
   delete new_particle;
   return e;
@@ -720,7 +768,7 @@ double EgammaCalibrationAndSmearingTool::getEnergy(const xAOD::Electron& input)
 
 CP::CorrectionCode EgammaCalibrationAndSmearingTool::applyCorrection(xAOD::Egamma & input, const xAOD::EventInfo& event_info)
 {
-  /* 
+  /*
    * Here we check for each event the kind of data DATA vs FullSim
    * The m_simulation flavour has already be determined from metadata
    */
@@ -838,7 +886,7 @@ CP::CorrectionCode EgammaCalibrationAndSmearingTool::applyCorrection(xAOD::Egamm
              oldtool_scale_flag_this_event(input, event_info),
              oldtool_resolution_flag_this_event(input, event_info),
              m_TResolutionType,
-	           m_varSF);
+	     m_varSF);
 
   ATH_MSG_DEBUG("energy after scale/systematic correction = " << boost::format("%.2f") % energy);
 
@@ -854,7 +902,7 @@ CP::CorrectionCode EgammaCalibrationAndSmearingTool::applyCorrection(xAOD::Egamm
 
 double EgammaCalibrationAndSmearingTool::getEnergy(xAOD::Egamma* p, const xAOD::EventInfo* event_info)
 {
-  ANA_CHECK_THROW (applyCorrection(*p, *event_info));
+  ANA_CHECK_THROW(applyCorrection(*p, *event_info));
   ATH_MSG_DEBUG("returning " << p->e());
   return p->e();
 }
@@ -910,13 +958,18 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
     // TODO: independet implementation of ALL UP looping on all the variations
     m_syst_description[CP::SystematicVariation("EG_SCALE_ALL", +1)] = SysInfo{always, egEnergyCorr::Scale::AllUp};
     m_syst_description[CP::SystematicVariation("EG_SCALE_ALL", -1)] = SysInfo{always, egEnergyCorr::Scale::AllDown};
+    // extra AF2 systematics in addition to the 1NP
+    if ( m_TESModel == egEnergyCorr::es2017_R21_v0  || m_TESModel == egEnergyCorr::es2017_R21_v1 || m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 || m_TESModel == egEnergyCorr::es2018_R21_v0 || m_TESModel == egEnergyCorr::es2018_R21_v1) {
+       m_syst_description[CP::SystematicVariation("EG_SCALE_AF2",+1)] =  SysInfo{always, egEnergyCorr::Scale::af2Up};
+       m_syst_description[CP::SystematicVariation("EG_SCALE_AF2",-1)] =  SysInfo{always, egEnergyCorr::Scale::af2Down};
+    }
   }
   else if (m_decorrelation_model_scale == ScaleDecorrelation::FULL_ETA_CORRELATED) {
     // all the physical effects separately, considered as fully correlated in eta
 
     // common systematics for all the esmodels
-    #define SYSMACRO(name, fullcorrelated, decorrelation, flagup, flagdown)                \
-      m_syst_description[CP::SystematicVariation(#name, +1)] = SysInfo{always, flagup};    \
+    #define SYSMACRO(name, fullcorrelated, decorrelation, flagup, flagdown) \
+      m_syst_description[CP::SystematicVariation(#name, +1)] = SysInfo{always, flagup}; \
       m_syst_description[CP::SystematicVariation(#name, -1)] = SysInfo{always, flagdown};
     #include "ElectronPhotonFourMomentumCorrection/systematics.def"
     #undef SYSMACRO
@@ -928,8 +981,9 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
     // additional systematics for S12 run2
     if (m_TESModel == egEnergyCorr::es2015PRE_res_improved or m_TESModel == egEnergyCorr::es2015PRE or
         m_TESModel == egEnergyCorr::es2015cPRE or m_TESModel == egEnergyCorr::es2015c_summer or
-        m_TESModel == egEnergyCorr::es2016PRE or m_TESModel == egEnergyCorr::es2017 or 
-	m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+        m_TESModel == egEnergyCorr::es2016PRE or m_TESModel == egEnergyCorr::es2017 or
+	m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved
+	or m_TESModel == egEnergyCorr::es2015_5TeV) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_LARCALIB_EXTRA2015PRE", +1)] = SysInfo{always, egEnergyCorr::Scale::LArCalibExtra2015PreUp};
       m_syst_description[CP::SystematicVariation("EG_SCALE_LARCALIB_EXTRA2015PRE", -1)] = SysInfo{always, egEnergyCorr::Scale::LArCalibExtra2015PreDown};
     }
@@ -943,26 +997,26 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
     }
 
     // additional systematic for S12 last eta bin run2
-    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2015_5TeV) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_S12EXTRALASTETABINRUN2", +1)] = SysInfo{always, egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Up};
       m_syst_description[CP::SystematicVariation("EG_SCALE_S12EXTRALASTETABINRUN2", -1)] = SysInfo{always, egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Down};
     }
 
     // additional systematic for PP0 region
-    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_summer_final or m_TESModel == egEnergyCorr::es2015_5TeV or m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or  m_TESModel == egEnergyCorr::es2018_R21_v1) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_MATPP0", +1)] = SysInfo{always, egEnergyCorr::Scale::MatPP0Up};
       m_syst_description[CP::SystematicVariation("EG_SCALE_MATPP0", -1)] = SysInfo{always, egEnergyCorr::Scale::MatPP0Down};
     }
 
     // systematic related to wtots1
-    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_summer_final or m_TESModel == egEnergyCorr::es2015_5TeV or m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or  m_TESModel == egEnergyCorr::es2018_R21_v1 ) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_WTOTS1", +1)] = SysInfo{always, egEnergyCorr::Scale::Wtots1Up};
       m_syst_description[CP::SystematicVariation("EG_SCALE_WTOTS1", -1)] = SysInfo{always, egEnergyCorr::Scale::Wtots1Down};
     }
 
     // systematic for the scintillators
     if (m_TESModel == egEnergyCorr::es2015cPRE or m_TESModel == egEnergyCorr::es2015c_summer or m_TESModel == egEnergyCorr::es2016PRE or m_TESModel == egEnergyCorr::es2017
-	or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+      or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_summer_final or m_TESModel == egEnergyCorr::es2015_5TeV or m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or  m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or m_TESModel == egEnergyCorr::es2018_R21_v1) {
       // scintillator systematics
       m_syst_description[CP::SystematicVariation("EG_SCALE_E4SCINTILLATOR", +1)] = SysInfo{always, egEnergyCorr::Scale::E4ScintillatorUp};
       m_syst_description[CP::SystematicVariation("EG_SCALE_E4SCINTILLATOR", -1)] = SysInfo{always, egEnergyCorr::Scale::E4ScintillatorDown};
@@ -973,6 +1027,26 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
       m_syst_description[CP::SystematicVariation("EG_SCALE_LARTEMPERATURE_EXTRA2016PRE", +1)] = SysInfo{always, egEnergyCorr::Scale::LArTemperature2016PreUp};
       m_syst_description[CP::SystematicVariation("EG_SCALE_LARTEMPERATURE_EXTRA2016PRE", -1)] = SysInfo{always, egEnergyCorr::Scale::LArTemperature2016PreDown};
     }
+
+    //PS correlated barrel uncertainty
+    if (m_TESModel == egEnergyCorr::es2017_summer_final or m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or m_TESModel == egEnergyCorr::es2018_R21_v1){
+      m_syst_description[CP::SystematicVariation("EG_SCALE_PS_BARREL_B12", +1)] = SysInfo{always, egEnergyCorr::Scale::PSb12Up};
+      m_syst_description[CP::SystematicVariation("EG_SCALE_PS_BARREL_B12", -1)] = SysInfo{always, egEnergyCorr::Scale::PSb12Down};
+    }
+
+    // topo clustr threshold systematics aded to release 21 recommendations
+    if ( m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or m_TESModel == egEnergyCorr::es2018_R21_v1){
+       m_syst_description[CP::SystematicVariation("EG_SCALE_TOPOCLUSTER_THRES",+1)] = SysInfo{always, egEnergyCorr::Scale::topoClusterThresUp};
+       m_syst_description[CP::SystematicVariation("EG_SCALE_TOPOCLUSTER_THRES",-1)] = SysInfo{always, egEnergyCorr::Scale::topoClusterThresDown};
+    }
+
+    // extra AF2 systematics for release 21 recommendations - Moriond 2018 - pending proper AF2 to FullSim correction with release 21
+    if ( m_TESModel == egEnergyCorr::es2017_R21_v0 || m_TESModel == egEnergyCorr::es2017_R21_v1 || m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 || m_TESModel == egEnergyCorr::es2018_R21_v0  ||  m_TESModel ==  egEnergyCorr::es2018_R21_v1){
+       m_syst_description[CP::SystematicVariation("EG_SCALE_AF2",+1)] =  SysInfo{always, egEnergyCorr::Scale::af2Up};
+       m_syst_description[CP::SystematicVariation("EG_SCALE_AF2",-1)] =  SysInfo{always, egEnergyCorr::Scale::af2Down};
+    }
+
+
   }
   else if (m_decorrelation_model_scale == ScaleDecorrelation::ONENP_PLUS_UNCONR) {
       // qsum of all variations correlated 8/13 TeV + uncorrelated (additional systematics for 2015PRE or 2016)
@@ -984,8 +1058,8 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
       #include "ElectronPhotonFourMomentumCorrection/systematics_1NPCOR_PLUS_UNCOR.def"
       #undef SYSMACRO
 
-    // additional systematic for S12 last eta bin run2
-    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+    // additional systematic for S12 last eta bin run2 - not needed anymore for last 20.7 model since it is part of bin per bin E1/E2 uncertainty in root file
+    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_S12EXTRALASTETABINRUN2", +1)] = SysInfo{always, egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Up};
       m_syst_description[CP::SystematicVariation("EG_SCALE_S12EXTRALASTETABINRUN2", -1)] = SysInfo{always, egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Down};
     }
@@ -998,6 +1072,19 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
     const std::vector<double> decorrelation_edges_MODULE = {0., 0.2, 0.4, 0.6, 0.8, 1.0, 1.2, 1.37, 1.52, 1.8};
     const std::vector<double> decorrelation_edges_MATERIAL = {0.0, 1.1, 1.5, 2.1, 2.5};
 
+    std::vector<double> decorrelation_edges_S12;
+    // for es2018_R21_v1 : 4 eta bins for muon E1/E2 uncertainty correlation
+    if (m_TESModel==  egEnergyCorr::es2018_R21_v1) {
+       decorrelation_edges_S12.resize(5);
+       decorrelation_edges_S12={0.,1.35,1.5,2.4,2.5};
+     }
+     // for previous run 2 muon calibration with 20.7, 5 eta bins for E1/E2 uncertainty correlation
+     else {
+       decorrelation_edges_S12.resize(6);
+       decorrelation_edges_S12={0., 0.6, 1.4, 1.5, 2.4, 2.5};
+     }
+
+    if(m_TESModel != egEnergyCorr::es2017_summer_final and m_TESModel != egEnergyCorr::es2017_R21_v0 and m_TESModel != egEnergyCorr::es2017_R21_v1 and m_TESModel != egEnergyCorr::es2017_R21_ofc0_v1 and m_TESModel != egEnergyCorr::es2018_R21_v0 and  m_TESModel != egEnergyCorr::es2018_R21_v1){
     #define SYSMACRO(name, fullcorrelated, decorrelation, flagup, flagdown)                \
     if (bool(fullcorrelated)) {                                                            \
       m_syst_description[CP::SystematicVariation(#name, +1)] = SysInfo{always, flagup};    \
@@ -1013,6 +1100,24 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
     }
     #include "ElectronPhotonFourMomentumCorrection/systematics.def"
     #undef SYSMACRO
+    }
+    else{
+    #define SYSMACRO(name, fullcorrelated, decorrelation, flagup, flagdown)                \
+    if (bool(fullcorrelated)) {                                                            \
+      m_syst_description[CP::SystematicVariation(#name, +1)] = SysInfo{always, flagup};    \
+      m_syst_description[CP::SystematicVariation(#name, -1)] = SysInfo{always, flagdown};  \
+    }                                                                                      \
+    else {                                                                                 \
+      int i = 0;                                                                           \
+      for (const auto& p : AbsEtaCaloPredicatesFactory(decorrelation)) {                       \
+        m_syst_description[CP::SystematicVariation(#name "__ETABIN" + std::to_string(i), +1)] = SysInfo{p, flagup};    \
+        m_syst_description[CP::SystematicVariation(#name "__ETABIN" + std::to_string(i), -1)] = SysInfo{p, flagdown};  \
+        i += 1;                                                                            \
+      }                                                                                    \
+    }
+    #include "ElectronPhotonFourMomentumCorrection/systematics_S12.def"
+    #undef SYSMACRO
+    }//else
 
     if (m_use_full_statistical_error) {
       // statistical error, decorrelate in *all* the bins
@@ -1038,7 +1143,8 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
     if (m_TESModel == egEnergyCorr::es2015PRE_res_improved or m_TESModel == egEnergyCorr::es2015PRE or
         m_TESModel == egEnergyCorr::es2015cPRE or m_TESModel == egEnergyCorr::es2015c_summer or
         m_TESModel == egEnergyCorr::es2016PRE or m_TESModel == egEnergyCorr::es2017
-	or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+	or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved
+	or m_TESModel == egEnergyCorr::es2015_5TeV) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_LARCALIB_EXTRA2015PRE__ETABIN0", +1)] = SysInfo{AbsEtaCaloPredicateFactory({0, 1.45}), egEnergyCorr::Scale::LArCalibExtra2015PreUp};
       m_syst_description[CP::SystematicVariation("EG_SCALE_LARCALIB_EXTRA2015PRE__ETABIN0", -1)] = SysInfo{AbsEtaCaloPredicateFactory({0, 1.45}), egEnergyCorr::Scale::LArCalibExtra2015PreDown};
       m_syst_description[CP::SystematicVariation("EG_SCALE_LARCALIB_EXTRA2015PRE__ETABIN1", +1)] = SysInfo{AbsEtaCaloPredicateFactory({1.45, 2.47}), egEnergyCorr::Scale::LArCalibExtra2015PreUp};
@@ -1058,13 +1164,13 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
     }
 
     // additional systematic for S12 last eta bin run2
-    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2015_5TeV) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_S12EXTRALASTETABINRUN2", +1)] = SysInfo{always, egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Up};
       m_syst_description[CP::SystematicVariation("EG_SCALE_S12EXTRALASTETABINRUN2", -1)] = SysInfo{always, egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Down};
     }
 
     // additional systematic for PP0 region
-    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_summer_final or m_TESModel == egEnergyCorr::es2015_5TeV or m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or  m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or m_TESModel == egEnergyCorr::es2018_R21_v1) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_MATPP0__ETABIN0", +1)] = SysInfo{AbsEtaCaloPredicateFactory(0, 1.5), egEnergyCorr::Scale::MatPP0Up};
       m_syst_description[CP::SystematicVariation("EG_SCALE_MATPP0__ETABIN1", +1)] = SysInfo{AbsEtaCaloPredicateFactory(1.5, 2.5), egEnergyCorr::Scale::MatPP0Up};
       m_syst_description[CP::SystematicVariation("EG_SCALE_MATPP0__ETABIN0", -1)] = SysInfo{AbsEtaCaloPredicateFactory(0, 1.5), egEnergyCorr::Scale::MatPP0Down};
@@ -1072,14 +1178,14 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
     }
 
     // systematic related to wtots1
-    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_summer_final or m_TESModel == egEnergyCorr::es2015_5TeV or m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or m_TESModel == egEnergyCorr::es2018_R21_v1) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_WTOTS1", +1)] = SysInfo{always, egEnergyCorr::Scale::Wtots1Up};
       m_syst_description[CP::SystematicVariation("EG_SCALE_WTOTS1", -1)] = SysInfo{always, egEnergyCorr::Scale::Wtots1Down};
     }
 
     // systematic for the scintillators
     if (m_TESModel == egEnergyCorr::es2015cPRE or m_TESModel == egEnergyCorr::es2015c_summer or m_TESModel == egEnergyCorr::es2016PRE or m_TESModel == egEnergyCorr::es2017
-	or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+    or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_summer_final or m_TESModel == egEnergyCorr::es2015_5TeV or m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or  m_TESModel == egEnergyCorr::es2018_R21_v1) {
       m_syst_description[CP::SystematicVariation("EG_SCALE_E4SCINTILLATOR__ETABIN0", +1)] = SysInfo{AbsEtaCaloPredicateFactory(1.4, 1.46), egEnergyCorr::Scale::E4ScintillatorUp};
       m_syst_description[CP::SystematicVariation("EG_SCALE_E4SCINTILLATOR__ETABIN1", +1)] = SysInfo{AbsEtaCaloPredicateFactory(1.46, 1.52), egEnergyCorr::Scale::E4ScintillatorUp};
       m_syst_description[CP::SystematicVariation("EG_SCALE_E4SCINTILLATOR__ETABIN2", +1)] = SysInfo{AbsEtaCaloPredicateFactory(1.52, 1.6), egEnergyCorr::Scale::E4ScintillatorUp};
@@ -1097,6 +1203,26 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
       m_syst_description[CP::SystematicVariation("EG_SCALE_LARTEMPERATURE_EXTRA2016PRE__ETABIN1", -1)] = SysInfo{AbsEtaCaloPredicateFactory(decorrelation_bins_BE[1]), egEnergyCorr::Scale::LArTemperature2016PreDown};
     }
 
+    //PS correlated barrel uncertainty
+    if (m_TESModel == egEnergyCorr::es2017_summer_final or m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or m_TESModel == egEnergyCorr::es2018_R21_v1){
+      m_syst_description[CP::SystematicVariation("EG_SCALE_PS_BARREL_B12", +1)] = SysInfo{always, egEnergyCorr::Scale::PSb12Up};
+      m_syst_description[CP::SystematicVariation("EG_SCALE_PS_BARREL_B12", -1)] = SysInfo{always, egEnergyCorr::Scale::PSb12Down};
+    }
+
+    // topo clustr threshold systematics aded to release 21 recommendations
+    if ( m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or m_TESModel == egEnergyCorr::es2018_R21_v1){
+       m_syst_description[CP::SystematicVariation("EG_SCALE_TOPOCLUSTER_THRES",+1)] = SysInfo{always, egEnergyCorr::Scale::topoClusterThresUp};
+       m_syst_description[CP::SystematicVariation("EG_SCALE_TOPOCLUSTER_THRES",-1)] = SysInfo{always, egEnergyCorr::Scale::topoClusterThresDown};
+    }
+
+    // extra AF2 systematics for release 21 recommendations - Moriond 2018 - pending proper AF2 to FullSim correction with release 21
+    if ( m_TESModel == egEnergyCorr::es2017_R21_v0  || m_TESModel == egEnergyCorr::es2017_R21_v1 ||  m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 || m_TESModel == egEnergyCorr::es2018_R21_v0 || m_TESModel ==  egEnergyCorr::es2018_R21_v1){
+       m_syst_description[CP::SystematicVariation("EG_SCALE_AF2",+1)] =  SysInfo{always, egEnergyCorr::Scale::af2Up};
+       m_syst_description[CP::SystematicVariation("EG_SCALE_AF2",-1)] =  SysInfo{always, egEnergyCorr::Scale::af2Down};
+    }
+
+
+
   }
   else {
     ATH_MSG_FATAL("scale decorrelation model invalid");
@@ -1122,11 +1248,15 @@ void EgammaCalibrationAndSmearingTool::setupSystematics() {
     m_syst_description_resolution[CP::SystematicVariation("EG_RESOLUTION_MATERIALCRYO", -1)] = egEnergyCorr::Resolution::MaterialCryoDown;
     m_syst_description_resolution[CP::SystematicVariation("EG_RESOLUTION_PILEUP", +1)] = egEnergyCorr::Resolution::PileUpUp;
     m_syst_description_resolution[CP::SystematicVariation("EG_RESOLUTION_PILEUP", -1)] = egEnergyCorr::Resolution::PileUpDown;
-    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_R21_PRE) {
+    if (m_TESModel == egEnergyCorr::es2017 or m_TESModel == egEnergyCorr::es2017_summer or m_TESModel == egEnergyCorr::es2017_summer_improved or m_TESModel == egEnergyCorr::es2017_summer_final or m_TESModel == egEnergyCorr::es2015_5TeV or m_TESModel == egEnergyCorr::es2017_R21_v0 or m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 or m_TESModel == egEnergyCorr::es2018_R21_v0 or m_TESModel == egEnergyCorr::es2018_R21_v1) {
       m_syst_description_resolution[CP::SystematicVariation("EG_RESOLUTION_MATERIALIBL", +1)] = egEnergyCorr::Resolution::MaterialIBLUp;
       m_syst_description_resolution[CP::SystematicVariation("EG_RESOLUTION_MATERIALIBL", -1)] = egEnergyCorr::Resolution::MaterialIBLDown;
       m_syst_description_resolution[CP::SystematicVariation("EG_RESOLUTION_MATERIALPP0", +1)] = egEnergyCorr::Resolution::MaterialPP0Up;
       m_syst_description_resolution[CP::SystematicVariation("EG_RESOLUTION_MATERIALPP0", -1)] = egEnergyCorr::Resolution::MaterialPP0Down;
+      if (m_TESModel == egEnergyCorr::es2017_R21_v1 || m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 || m_TESModel == egEnergyCorr::es2018_R21_v0 ||  m_TESModel == egEnergyCorr::es2018_R21_v1) {
+        m_syst_description_resolution[CP::SystematicVariation("EG_RESOLUTION_AF2", +1)] = egEnergyCorr::Resolution::af2Up;
+        m_syst_description_resolution[CP::SystematicVariation("EG_RESOLUTION_AF2", -1)] = egEnergyCorr::Resolution::af2Down;
+      }
     }
   }
   else {
@@ -1187,25 +1317,25 @@ StatusCode EgammaCalibrationAndSmearingTool::applySystematicVariation(const CP::
 
 double EgammaCalibrationAndSmearingTool::intermodule_correction(double Ecl,  double phi, double eta) const
 {
-    
+
   //Intermodule Widening Correction: E_corr = E / (a' - b' * ((1 / (1 + exp((phi_mod - 2 * pi / 32) * c))) * (1 / (1 + exp((phi_mod - 2 * pi / 32) * (d))))))
   //(phi_min, phi_max) : [a' = a / a, b' = b / a, c, d]
-  
+
   double Ecl_corr = 0.;
   int DivInt = 0;
   double pi = 3.1415926535897932384626433832795 ;
 
-  if ( m_TESModel == egEnergyCorr::es2017_summer_improved ) {
-    
+  if ( m_TESModel == egEnergyCorr::es2017_summer_improved || m_TESModel == egEnergyCorr::es2017_summer_final || m_TESModel == egEnergyCorr::es2017_R21_v0 || m_TESModel == egEnergyCorr::es2017_R21_v1 || m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 || m_TESModel == egEnergyCorr::es2018_R21_v0 || m_TESModel == egEnergyCorr::es2018_R21_v1) {
+
     double phi_mod = 0;
     if (phi < 0)
       phi_mod = fmod(phi, 2 * pi / 16.) + pi / 8.;
     else
       phi_mod = fmod(phi, 2 * pi / 16.);
-    
+
     //  The correction concerns only the barrel
     if(fabs(eta) <= 1.37){
-      
+
       if(phi< (-7 * pi / 8) && phi> (-1 * pi))
 	Ecl_corr = Ecl / (1-0.1086 * ((1 / (1 + exp((phi_mod- 2*pi/32.) * 175.2759))) * (1 / (1 + exp((phi_mod- 2*pi/32.) * (-189.3612))))));
       if(phi< (-6 * pi / 8) && phi> (-7 * pi / 8))
@@ -1239,34 +1369,34 @@ double EgammaCalibrationAndSmearingTool::intermodule_correction(double Ecl,  dou
       if(phi< (8 * pi / 8) && phi> (7 * pi / 8))
 	Ecl_corr = Ecl / (1-0.1001 * ((1 / (1 + exp((phi_mod- 2*pi/32.) * 199.1735))) * (1 / (1 + exp((phi_mod- 2*pi/32.) * (-176.4056))))));
     }
-    
-    
+
+
     //  No correction for the EC
     else{
       Ecl_corr = Ecl;
     }
-    
+
   }
-  
+
   else {
-    
+
     //  Definitions of module folding into four quarters (top, left, bottom and right)
-    
+
     DivInt =  (int) (phi / ((2 * pi) / 16.));
     double phi_mod = phi - DivInt * (2 * pi / 16.);
-    
-    
+
+
     //  Centring on the intermodule --> phi_mod will now be in [0,0.4]
     if (phi_mod < 0) phi_mod += pi / 8.;
-    
+
     //  The correction concerns only the barrel
     if(fabs(eta) <= 1.4){
-      
+
       //  Top quarter
       if(phi < (3 * pi) / 4. && phi >= pi / 4.){
 	Ecl_corr = Ecl / (1-0.131 * ((1 / (1 + exp((phi_mod-0.2) * 199.08))) * (1 / (1 + exp((phi_mod-0.2) * (-130.36))))));
       }
-      
+
       //  Right quarter
       if(phi < pi / 4. && phi >= -pi / 4.){
 	Ecl_corr = Ecl / (1-0.0879 * ((1 / (1 + exp((phi_mod-0.2) * 221.01))) * (1 / (1 + exp((phi_mod-0.2) * (-149.51))))));
@@ -1280,15 +1410,15 @@ double EgammaCalibrationAndSmearingTool::intermodule_correction(double Ecl,  dou
 	Ecl_corr = Ecl / (1-0.102 * ((1 / (1 + exp((phi_mod-0.2) * 235.37))) * (1 / (1 + exp((phi_mod-0.2) * (-219.04))))));
       }
     }
-    
+
     //  No correction for the EC
     else{
       Ecl_corr = Ecl;
     }
   }
-  
+
   return Ecl_corr;
-  
+
 }
 
 double EgammaCalibrationAndSmearingTool::correction_phi_unif(double eta, double phi) const
@@ -1303,48 +1433,48 @@ double EgammaCalibrationAndSmearingTool::correction_phi_unif(double eta, double
       else if (phi < (13 * PI / 32.) && phi > (12 * PI / 32.)) { Fcorr -= 0.035; }
     }
   }
-  
-  if ( m_TESModel == egEnergyCorr::es2017_summer_improved ) {
+
+  if ( m_TESModel == egEnergyCorr::es2017_summer_improved || m_TESModel == egEnergyCorr::es2017_summer_final || m_TESModel == egEnergyCorr::es2017_R21_v0 || m_TESModel == egEnergyCorr::es2017_R21_v1 or m_TESModel == egEnergyCorr::es2017_R21_ofc0_v1 || m_TESModel == egEnergyCorr::es2018_R21_v0 || m_TESModel == egEnergyCorr::es2018_R21_v1) {
 
     if(eta < 0.2 && eta > 0.) {
       if (phi < (-7 * 2 * PI / 32.) && phi > (-8 * 2 * PI / 32.)) { Fcorr = 1.016314; }
-    } 
-    
+    }
+
     else if (eta < 0.6 && eta > 0.4) {
       if (phi < 0 && phi > (-2 * PI / 32.)) { Fcorr = 1.041591; }
       else if (phi < (-4 * 2 * PI / 32.) && phi > (-5 * 2 * PI / 32.)) { Fcorr = 1.067346; }
     }
-    
+
     else if (eta < 0.8 && eta > 0.6) {
       if (phi < (7 * 2 * PI / 32.) && phi > (6 * 2 * PI / 32.)) { Fcorr = 1.027980; }
     }
-    
+
     else if (eta < 1.4 && eta > 1.2) {
       if (phi < (-9 * 2 * PI / 32.) && phi > (-10 * 2 * PI / 32.)) { Fcorr = 1.020299; }
       else if (phi < (-11 * 2 * PI / 32.) && phi > (-12 * 2 * PI / 32.)) { Fcorr = 1.051426; }
     }
-    
+
     else if (eta < 2.3 && eta > 2.1) {
       if (phi < (-12 * 2 * PI / 32.) && phi > (-13 * 2 * PI / 32.)) { Fcorr = 1.071695; }
     }
-    
+
     else if(eta < 0. && eta > -0.2) {
       if (phi < (-12 * 2 * PI / 32.) && phi > (-13 * 2 * PI / 32.)) { Fcorr = 1.008227; }
       else if (phi < (-8 * 2 * PI / 32.) && phi > (-9 * 2 * PI / 32.)) { Fcorr = 1.013929; }
     }
-    
+
     else if(eta < -0.2 && eta > -0.4) {
       if (phi < (-9 * 2 * PI / 32.) && phi > (-10 * 2 * PI / 32.)) { Fcorr = 1.015749; }
     }
-    
+
     else if(eta < -1.2 && eta > -1.4) {
       if (phi < (-6 * 2 * PI / 32.) && phi > (-7 * 2 * PI / 32.)) { Fcorr = 1.064954; }
     }
-    
+
     else if (eta < -1.6 && eta > -1.8 ) {
       if (phi < (9 * 2 * PI / 32.) && phi > (8 * 2 * PI / 32.)) { Fcorr = 1.027448; }
     }
-    
+
     else if(eta < -2.3 && eta > -2.5) {
       if (phi < (-8 * 2 * PI / 32.) && phi > (-9 * 2 * PI / 32.)) { Fcorr = 1.025882; }
       else if (phi < (5 * 2 * PI / 32.) && phi > (4 * 2 * PI / 32.)) { Fcorr = 1.036616; }
@@ -1352,9 +1482,9 @@ double EgammaCalibrationAndSmearingTool::correction_phi_unif(double eta, double
       else if (phi < (10 * 2 * PI / 32.) && phi > (9 * 2 * PI / 32.)) { Fcorr = 1.026856; }
       else if (phi < (11 * 2 * PI / 32.) && phi > (10 * 2 * PI / 32.)) { Fcorr = 0.994382; }
     }
-    
+
   } // es2017_summer_improved end
-  
+
   else{
     if (eta < 0.6 && eta > 0.4) {
       if (phi < 0 && phi > (-2 * PI / 32.)) { Fcorr = 1.028; }
@@ -1390,7 +1520,7 @@ double EgammaCalibrationAndSmearingTool::correction_phi_unif(double eta, double
       else if (phi < (11 * 2 * PI / 32.) && phi > (10 * 2 * PI / 32.)) { Fcorr = 1.020; }
     }
   }
-  
+
   return Fcorr;
 }
 
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/EgammaFactory.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/EgammaFactory.cxx
index 35ae16b405346a6e434b967b83eb0899ae42c03d..5d8bc56a147f4c42c242d542b81e916353378a02 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/EgammaFactory.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/EgammaFactory.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifdef XAOD_STANDALONE
@@ -116,13 +116,14 @@ EgammaFactory::~EgammaFactory()
   m_store.clear();
 }
 
-xAOD::EventInfo* EgammaFactory::create_eventinfo(bool simulation, int runnumber, int eventnumber)
+xAOD::EventInfo* EgammaFactory::create_eventinfo(bool simulation, int runnumber, int eventnumber, int average_interaction_per_crossing)
 {
   xAOD::EventInfo* ei= new xAOD::EventInfo();
   ei->makePrivateStore();
   ei->setRunNumber(runnumber);
   ei->setEventNumber(eventnumber);
   ei->setEventTypeBitmask(simulation);
+  ei->setAverageInteractionsPerCrossing(average_interaction_per_crossing);
   return ei;
 }
 
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/GainTool.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/GainTool.cxx
index 2c55f11797e517dcf9e70774b0f42bb191c460bc..5900ab49c2749ed51f949919be902a05dca22743 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/GainTool.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/GainTool.cxx
@@ -1,269 +1,268 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-#include <sstream>
-#include <cmath>
-#include <algorithm>
-#include <TF1.h>
-#include <TFile.h>
-
-#include <ElectronPhotonFourMomentumCorrection/GainTool.h>
-
-using namespace std;
-
-namespace egGain {
-  
-  GainTool::GainTool(const std::string& filenameTO, const std::string& filenameVar){
-    Init( filenameTO, filenameVar);
-  }
-    
-  GainTool::~GainTool() {
-    
-    for (int i=0;i<m_NUM_ETA_BINS;++i){
-      delete m_funcTO[i];
-
-      for (int j=0;j< m_NUM_ENERGY_BINS;++j){
-	delete m_funcG[j][i];
-	delete m_conv_funcG[j][i];	
-      }
-      for (int j=0;j< m_NUM_UNCONV_ENERGY_BINS;++j){
-	delete  m_unconv_funcG[j][i];
-      }
-    }
-    
-  }
-
-  void GainTool::Init(const std::string& filenameTO, const std::string& filenameVar){
-
-    m_TOFile = std::make_unique<TFile>(filenameTO.c_str() );
-    m_varFile = std::make_unique<TFile>(filenameVar.c_str());
-
-    for (int id = 0 ; id < m_NUM_ETA_BINS ; id++){
-      string etabin;
-      stringstream test;
-      test << id;
-      etabin = "finalFD"+test.str();
-      m_funcTO[id] =(TF1*)m_TOFile->Get(etabin.c_str());
-
-      string etabin1_P_elec;
-      string etabin2_P_elec;
-      string etabin3_P_elec;
-
-      string etabin1_M_elec;
-      string etabin2_M_elec;
-      string etabin3_M_elec;
-
-      string etabin1_P_conv;
-      string etabin2_P_conv;
-      string etabin3_P_conv;
-
-      string etabin1_M_conv;
-      string etabin2_M_conv;
-      string etabin3_M_conv;
-
-      string etabin1_P_unconv;
-      string etabin2_P_unconv;
-      string etabin3_P_unconv;
-      string etabin4_P_unconv;
-
-      string etabin1_M_unconv;
-      string etabin2_M_unconv;
-      string etabin3_M_unconv;
-      string etabin4_M_unconv;
-
-      stringstream testP;
-      testP << id-14;
-      stringstream testM;
-      testM << 13-id;
-
-      etabin1_P_elec = "elec_func1_"+testP.str();
-      etabin2_P_elec = "elec_func2_"+testP.str();
-      etabin3_P_elec = "elec_func3_"+testP.str();
-
-      etabin1_M_elec = "elec_func1_"+testM.str();
-      etabin2_M_elec= "elec_func2_"+testM.str();
-      etabin3_M_elec= "elec_func3_"+testM.str();
-
-      etabin1_P_conv = "phot_conv_func1_"+testP.str();
-      etabin2_P_conv = "phot_conv_func2_"+testP.str();
-      etabin3_P_conv = "phot_conv_func3_"+testP.str();
-
-      etabin1_M_conv = "phot_conv_func1_"+testM.str();
-      etabin2_M_conv = "phot_conv_func2_"+testM.str();
-      etabin3_M_conv = "phot_conv_func3_"+testM.str();
-
-      etabin1_P_unconv = "phot_unconv_func1_"+testP.str();
-      etabin2_P_unconv = "phot_unconv_func2_"+testP.str();
-      etabin3_P_unconv = "phot_unconv_func3_"+testP.str();
-      etabin4_P_unconv = "phot_unconv_func4_"+testP.str();
-
-      etabin1_M_unconv ="phot_unconv_func1_"+testM.str();
-      etabin2_M_unconv= "phot_unconv_func2_"+testM.str();
-      etabin3_M_unconv= "phot_unconv_func3_"+testM.str();
-      etabin4_M_unconv= "phot_unconv_func4_"+testM.str();
-
-      if(id<14){
-	m_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_M_elec.c_str());
-	m_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_M_elec.c_str());
-	m_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_M_elec.c_str());
-	
-	m_conv_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_M_conv.c_str());
-	m_conv_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_M_conv.c_str());
-	m_conv_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_M_conv.c_str());
-	
-	m_unconv_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_M_unconv.c_str());
-	m_unconv_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_M_unconv.c_str());
-	m_unconv_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_M_unconv.c_str());
-	m_unconv_funcG[3][id]=(TF1*)m_varFile->Get(etabin4_M_unconv.c_str());	
-      }
-
-      else {
-	m_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_P_elec.c_str());
-	m_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_P_elec.c_str());
-	m_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_P_elec.c_str());
-	
-	m_conv_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_P_conv.c_str());
-	m_conv_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_P_conv.c_str());
-	m_conv_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_P_conv.c_str());
-	
-	m_unconv_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_P_unconv.c_str());
-	m_unconv_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_P_unconv.c_str());
-	m_unconv_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_P_unconv.c_str());
-	m_unconv_funcG[3][id]=(TF1*)m_varFile->Get(etabin4_P_unconv.c_str());
-      }
-    }
-  }
-
-  double GainTool::CorrectionGainTool(double eta_input, double energy_input, double energy_layer2_input, PATCore::ParticleType::Type ptype){
-
-    double eta_low[28] = {-2.4,-2.32,-2.22,-2.12,-2.02,-1.92,-1.82,-1.72,-1.62,-1.37,-1.2,-0.8,-0.6,-0.4,0.,0.4,0.6,0.8,1.2,1.52,1.62,1.72,1.82,1.92,2.02,2.12,2.22,2.32};
-    double eta_high[28] = {-2.32,-2.22,-2.12,-2.02,-1.92,-1.82,-1.72,-1.62,-1.52,-1.2,-0.8,-0.6,-0.4,0,0.4,0.6,0.8,1.2,1.37,1.62,1.72,1.82,1.92,2.02,2.12,2.22,2.32,2.4};
-
-
-    double diffES[28] = {-0.0763457,0.198092,-0.0288093,-0.0808452,0.0271571,-0.0975428,-0.0164521,-0.0737317,0.136447,0.0352632,-0.00197711,0.0244447,-0.0641183,0.0810265,
-			   0.00735352,-0.013568,-0.0169185,-0.0142155,-0.0255637,0.0586014,-0.163098,0.0237162,-0.0690589,-0.0346536,-0.0886648,-0.0914096,0.0738988,-0.0376201};
-
-
-    double corrHG[28] = {-0.484364,0.263687,-0.037742,-0.0553371,-0.0640682,-0.201265,-0.176052,-0.206764,0.0224639,0.00855262,-0.00583258,0.00196343,-0.108951,0.0708467,
-			   -0.00438541,-0.0928867,-0.0487188,-0.0214743,-0.0619355,-0.055117,-0.297427,-0.0795861,-0.173311,-0.0905191,-0.297548,-0.147814,-0.0867268,-0.384337};
-
-    double corrMG[28]={-0.0160707,0.199527,-0.000845413,-0.0611091,0.0877896,0.0479742,0.141414,0.639507,0.72873,0.21984,0.0643192,0.146518,0.0279768,0.140151,0.0682126,
-			 0.167472,0.154887,0.122343,0.212282,0.657224,0.576652,0.135954,0.0798118,0.0167071,-0.0221686,-0.0398211,0.128146,-0.0226478};
-
-    double range_energy[28]={195.,180.,175.,160.,140.,145.,155.,155.,145.,140.,120.,90.,90.,75.,75.,90.,90.,120.,140.,145.,155.,155.,145.,140.,160.,175.,180.,195.};
-    
-    double corrM_G, corrE;
-    corrM_G =1;
-    corrE=0;
-
-    double energy_output;
-
-    TF1* funcG_com[m_NUM_ENERGY_BINS][m_NUM_ETA_BINS]={};
-
-    if (fabs(eta_input) > 2.4)
-      return energy_input*1000.;
-
-    int id_eta = -9999999;
-
-    for(int i = 0 ; i < 28 ; i++){
-      if( (eta_input >= eta_low[i]) && (eta_input <= eta_high[i]) ){
-	id_eta = i;
-	break;
-      }
-    }
-
-    if (id_eta < 0)
-      return energy_input*1000.;
-
-    if (ptype == PATCore::ParticleType::UnconvertedPhoton){
-      double norm_unconv=1.;
-      if (id_eta<17 && id_eta>10) norm_unconv = m_unconv_funcG[0][id_eta]->Eval(range_energy[id_eta]);
-      else if (id_eta<25 && id_eta>2) norm_unconv = m_unconv_funcG[1][id_eta]->Eval(range_energy[id_eta]);
-      else  norm_unconv = m_unconv_funcG[2][id_eta]->Eval(range_energy[id_eta]);
-
-      if (energy_input<92) corrM_G = (m_unconv_funcG[0][id_eta]->Eval(energy_input))/(norm_unconv);
-      else if (energy_input<160 && energy_input>=92) corrM_G = (m_unconv_funcG[1][id_eta]->Eval(energy_input))/(norm_unconv);
-      else if (energy_input<400 && energy_input>=160) corrM_G = (m_unconv_funcG[2][id_eta]->Eval(energy_input))/(norm_unconv);
-      else if (energy_input>=400) corrM_G = (m_unconv_funcG[3][id_eta]->Eval(energy_input))/(norm_unconv);
-    }
-
-    else if (ptype==PATCore::ParticleType::ConvertedPhoton){
-      funcG_com[0][id_eta]= m_conv_funcG[0][id_eta];
-      funcG_com[1][id_eta]= m_conv_funcG[1][id_eta];
-      funcG_com[2][id_eta]= m_conv_funcG[2][id_eta];
-    }
-    else if (ptype==PATCore::ParticleType::Electron){
-      funcG_com[0][id_eta]= m_funcG[0][id_eta];
-      funcG_com[1][id_eta]= m_funcG[1][id_eta];
-      funcG_com[2][id_eta]= m_funcG[2][id_eta];
-    }
-
-
-    if(ptype==PATCore::ParticleType::ConvertedPhoton || ptype==PATCore::ParticleType::Electron){
-      if(id_eta==12 || id_eta == 13 || id_eta == 14 || id_eta==15){
-	if (energy_input<105) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input<400 && energy_input>=105) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input>=400) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-      }
-
-      else if(id_eta == 11 || id_eta ==16){
-	if (energy_input<130) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input<440 && energy_input>=130) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input>=440) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-      }
-
-      else if(id_eta == 10 || id_eta ==17){
-	if (energy_input<190) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input<400 && energy_input>=190) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input>=400) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-      }
-
-      else if(id_eta == 9 || id_eta ==18){
-	if (energy_input<200) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input<480 && energy_input>=200) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input>=480) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-      }
-
-      else if(id_eta==7 || id_eta == 8 || id_eta ==19 || id_eta==20){
-	if (energy_input<250) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input<450 && energy_input>=250) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input>=450) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-      }
-
-      else if(id_eta == 6 || id_eta ==21){
-	if (energy_input<180) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input<385 && energy_input>=180) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input>=385) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-      }
-
-      else if(id_eta == 5 || id_eta ==22){
-	if (energy_input<165) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input<460 && energy_input>=165) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input>=460) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-      }
-
-      else if(id_eta == 4 || id_eta ==23){
-	if (energy_input<160) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input<450 && energy_input>=160) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input>=450) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-      }
-
-      else{
-	if (energy_input<200) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input<480 && energy_input>=200) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-	else if (energy_input>=480) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
-      }
-    }
-    
-    double ets2 = energy_layer2_input/cosh(eta_input);
-    double valTO = (m_funcTO[id_eta])->Eval(ets2);
-    if (valTO < 0) {
-      valTO=0;
-    }
-
-    corrE = -2 * energy_input* (((corrMG[id_eta]/91.2) - (diffES[id_eta]/91.2))*valTO*corrM_G + ((corrHG[id_eta]/91.2) - (diffES[id_eta]/91.2))*(1-valTO));
-    energy_output = (energy_input+corrE)*1000.;
-    return energy_output;
-  }
-}
+#include <sstream>
+#include <cmath>
+#include <algorithm>
+#include <TF1.h>
+#include <TFile.h>
+
+#include <ElectronPhotonFourMomentumCorrection/GainTool.h>
+
+using namespace std;
+
+namespace egGain {
+
+  GainTool::GainTool(const std::string& filenameTO, const std::string& filenameVar){
+    m_TOFile = 0;
+    m_varFile = 0;
+    Init( filenameTO, filenameVar);
+  }
+
+  GainTool::~GainTool() {
+
+    for (int i=0;i<m_NUM_ETA_BINS;++i){
+      delete m_funcTO[i];
+
+      for (int j=0;j< m_NUM_ENERGY_BINS;++j){
+	delete m_funcG[j][i];
+	delete m_conv_funcG[j][i];
+      }
+      for (int j=0;j< m_NUM_UNCONV_ENERGY_BINS;++j){
+	delete  m_unconv_funcG[j][i];
+      }
+    }
+
+  }
+
+  void GainTool::Init(const std::string& filenameTO, const std::string& filenameVar){
+
+    m_TOFile = std::make_unique<TFile>(filenameTO.c_str() );
+    m_varFile = std::make_unique<TFile>(filenameVar.c_str());
+
+    for (int id = 0 ; id < m_NUM_ETA_BINS ; id++){
+      string etabin;
+      stringstream test;
+      test << id;
+      etabin = "finalFD"+test.str();
+      m_funcTO[id] =(TF1*)m_TOFile->Get(etabin.c_str());
+
+      string etabin1_P_elec;
+      string etabin2_P_elec;
+      string etabin3_P_elec;
+
+      string etabin1_M_elec;
+      string etabin2_M_elec;
+      string etabin3_M_elec;
+
+      string etabin1_P_conv;
+      string etabin2_P_conv;
+      string etabin3_P_conv;
+
+      string etabin1_M_conv;
+      string etabin2_M_conv;
+      string etabin3_M_conv;
+
+      string etabin1_P_unconv;
+      string etabin2_P_unconv;
+      string etabin3_P_unconv;
+      string etabin4_P_unconv;
+
+      string etabin1_M_unconv;
+      string etabin2_M_unconv;
+      string etabin3_M_unconv;
+      string etabin4_M_unconv;
+
+      stringstream testP;
+      testP << id-14;
+      stringstream testM;
+      testM << 13-id;
+
+      etabin1_P_elec = "elec_func1_"+testP.str();
+      etabin2_P_elec = "elec_func2_"+testP.str();
+      etabin3_P_elec = "elec_func3_"+testP.str();
+
+      etabin1_M_elec = "elec_func1_"+testM.str();
+      etabin2_M_elec= "elec_func2_"+testM.str();
+      etabin3_M_elec= "elec_func3_"+testM.str();
+
+      etabin1_P_conv = "phot_conv_func1_"+testP.str();
+      etabin2_P_conv = "phot_conv_func2_"+testP.str();
+      etabin3_P_conv = "phot_conv_func3_"+testP.str();
+
+      etabin1_M_conv = "phot_conv_func1_"+testM.str();
+      etabin2_M_conv = "phot_conv_func2_"+testM.str();
+      etabin3_M_conv = "phot_conv_func3_"+testM.str();
+
+      etabin1_P_unconv = "phot_unconv_func1_"+testP.str();
+      etabin2_P_unconv = "phot_unconv_func2_"+testP.str();
+      etabin3_P_unconv = "phot_unconv_func3_"+testP.str();
+      etabin4_P_unconv = "phot_unconv_func4_"+testP.str();
+
+      etabin1_M_unconv ="phot_unconv_func1_"+testM.str();
+      etabin2_M_unconv= "phot_unconv_func2_"+testM.str();
+      etabin3_M_unconv= "phot_unconv_func3_"+testM.str();
+      etabin4_M_unconv= "phot_unconv_func4_"+testM.str();
+
+      if(id<14){
+	m_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_M_elec.c_str());
+	m_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_M_elec.c_str());
+	m_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_M_elec.c_str());
+
+	m_conv_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_M_conv.c_str());
+	m_conv_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_M_conv.c_str());
+	m_conv_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_M_conv.c_str());
+
+	m_unconv_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_M_unconv.c_str());
+	m_unconv_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_M_unconv.c_str());
+	m_unconv_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_M_unconv.c_str());
+	m_unconv_funcG[3][id]=(TF1*)m_varFile->Get(etabin4_M_unconv.c_str());
+      }
+
+      else {
+	m_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_P_elec.c_str());
+	m_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_P_elec.c_str());
+	m_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_P_elec.c_str());
+
+	m_conv_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_P_conv.c_str());
+	m_conv_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_P_conv.c_str());
+	m_conv_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_P_conv.c_str());
+
+	m_unconv_funcG[0][id]=(TF1*)m_varFile->Get(etabin1_P_unconv.c_str());
+	m_unconv_funcG[1][id]=(TF1*)m_varFile->Get(etabin2_P_unconv.c_str());
+	m_unconv_funcG[2][id]=(TF1*)m_varFile->Get(etabin3_P_unconv.c_str());
+	m_unconv_funcG[3][id]=(TF1*)m_varFile->Get(etabin4_P_unconv.c_str());
+      }
+    }
+  }
+
+  double GainTool::CorrectionGainTool(double eta_input, double energy_input, double energy_layer2_input, PATCore::ParticleType::Type ptype){
+
+    double eta_low[28] = {-2.4,-2.32,-2.22,-2.12,-2.02,-1.92,-1.82,-1.72,-1.62,-1.37,-1.2,-0.8,-0.6,-0.4,0.,0.4,0.6,0.8,1.2,1.52,1.62,1.72,1.82,1.92,2.02,2.12,2.22,2.32};
+    double eta_high[28] = {-2.32,-2.22,-2.12,-2.02,-1.92,-1.82,-1.72,-1.62,-1.52,-1.2,-0.8,-0.6,-0.4,0,0.4,0.6,0.8,1.2,1.37,1.62,1.72,1.82,1.92,2.02,2.12,2.22,2.32,2.4};
+
+
+    double diffES[28] = {-0.0763457,0.198092,-0.0288093,-0.0808452,0.0271571,-0.0975428,-0.0164521,-0.0737317,0.136447,0.0352632,-0.00197711,0.0244447,-0.0641183,0.0810265,
+			   0.00735352,-0.013568,-0.0169185,-0.0142155,-0.0255637,0.0586014,-0.163098,0.0237162,-0.0690589,-0.0346536,-0.0886648,-0.0914096,0.0738988,-0.0376201};
+
+
+    double corrHG[28] = {-0.484364,0.263687,-0.037742,-0.0553371,-0.0640682,-0.201265,-0.176052,-0.206764,0.0224639,0.00855262,-0.00583258,0.00196343,-0.108951,0.0708467,
+			   -0.00438541,-0.0928867,-0.0487188,-0.0214743,-0.0619355,-0.055117,-0.297427,-0.0795861,-0.173311,-0.0905191,-0.297548,-0.147814,-0.0867268,-0.384337};
+
+    double corrMG[28]={-0.0160707,0.199527,-0.000845413,-0.0611091,0.0877896,0.0479742,0.141414,0.639507,0.72873,0.21984,0.0643192,0.146518,0.0279768,0.140151,0.0682126,
+			 0.167472,0.154887,0.122343,0.212282,0.657224,0.576652,0.135954,0.0798118,0.0167071,-0.0221686,-0.0398211,0.128146,-0.0226478};
+
+    double range_energy[28]={195.,180.,175.,160.,140.,145.,155.,155.,145.,140.,120.,90.,90.,75.,75.,90.,90.,120.,140.,145.,155.,155.,145.,140.,160.,175.,180.,195.};
+
+    double corrM_G, corrE;
+    corrM_G =1;
+    corrE=0;
+
+    double energy_output;
+
+    TF1* funcG_com[m_NUM_ENERGY_BINS][m_NUM_ETA_BINS]={};
+
+    if (fabs(eta_input) > 2.4)
+      return energy_input*1000.;
+
+    int id_eta = -9999999;
+
+    for(int i = 0 ; i < 28 ; i++){
+      if( (eta_input >= eta_low[i]) && (eta_input <= eta_high[i]) ){
+	id_eta = i;
+	break;
+      }
+    }
+
+    if (ptype == PATCore::ParticleType::UnconvertedPhoton){
+      double norm_unconv=1.;
+      if (id_eta<17 && id_eta>10) norm_unconv = m_unconv_funcG[0][id_eta]->Eval(range_energy[id_eta]);
+      else if (id_eta<25 && id_eta>2) norm_unconv = m_unconv_funcG[1][id_eta]->Eval(range_energy[id_eta]);
+      else norm_unconv = m_unconv_funcG[2][id_eta]->Eval(range_energy[id_eta]);
+
+      if (energy_input<92) corrM_G = (m_unconv_funcG[0][id_eta]->Eval(energy_input))/(norm_unconv);
+      else if (energy_input<160 && energy_input>=92) corrM_G = (m_unconv_funcG[1][id_eta]->Eval(energy_input))/(norm_unconv);
+      else if (energy_input<400 && energy_input>=160) corrM_G = (m_unconv_funcG[2][id_eta]->Eval(energy_input))/(norm_unconv);
+      else if (energy_input>=400) corrM_G = (m_unconv_funcG[3][id_eta]->Eval(energy_input))/(norm_unconv);
+    }
+
+    else if (ptype==PATCore::ParticleType::ConvertedPhoton){
+      funcG_com[0][id_eta]= m_conv_funcG[0][id_eta];
+      funcG_com[1][id_eta]= m_conv_funcG[1][id_eta];
+      funcG_com[2][id_eta]= m_conv_funcG[2][id_eta];
+    }
+    else if (ptype==PATCore::ParticleType::Electron){
+      funcG_com[0][id_eta]= m_funcG[0][id_eta];
+      funcG_com[1][id_eta]= m_funcG[1][id_eta];
+      funcG_com[2][id_eta]= m_funcG[2][id_eta];
+    }
+
+
+    if(ptype==PATCore::ParticleType::ConvertedPhoton || ptype==PATCore::ParticleType::Electron){
+      if(id_eta==12 || id_eta == 13 || id_eta == 14 || id_eta==15){
+	if (energy_input<105) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input<400 && energy_input>=105) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input>=400) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+      }
+
+      else if(id_eta == 11 || id_eta ==16){
+	if (energy_input<130) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input<440 && energy_input>=130) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input>=440) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+      }
+
+      else if(id_eta == 10 || id_eta ==17){
+	if (energy_input<190) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input<400 && energy_input>=190) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input>=400) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+      }
+
+      else if(id_eta == 9 || id_eta ==18){
+	if (energy_input<200) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input<480 && energy_input>=200) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input>=480) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+      }
+
+      else if(id_eta==7 || id_eta == 8 || id_eta ==19 || id_eta==20){
+	if (energy_input<250) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input<450 && energy_input>=250) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input>=450) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+      }
+
+      else if(id_eta == 6 || id_eta ==21){
+	if (energy_input<180) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input<385 && energy_input>=180) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input>=385) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+      }
+
+      else if(id_eta == 5 || id_eta ==22){
+	if (energy_input<165) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input<460 && energy_input>=165) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input>=460) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+      }
+
+      else if(id_eta == 4 || id_eta ==23){
+	if (energy_input<160) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input<450 && energy_input>=160) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input>=450) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+      }
+
+      else{
+	if (energy_input<200) corrM_G = (funcG_com[0][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input<480 && energy_input>=200) corrM_G = (funcG_com[1][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+	else if (energy_input>=480) corrM_G = (funcG_com[2][id_eta]->Eval(energy_input))/(funcG_com[0][id_eta]->Eval(range_energy[id_eta]));
+      }
+    }
+
+    double ets2 = energy_layer2_input/cosh(eta_input);
+    double valTO = (m_funcTO[id_eta])->Eval(ets2);
+    if (valTO < 0) {
+      valTO=0;
+    }
+
+    corrE = -2 * energy_input* (((corrMG[id_eta]/91.2) - (diffES[id_eta]/91.2))*valTO*corrM_G + ((corrHG[id_eta]/91.2) - (diffES[id_eta]/91.2))*(1-valTO));
+    energy_output = (energy_input+corrE)*1000.;
+    return energy_output;
+  }
+}
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/GainUncertainty.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/GainUncertainty.cxx
index f3ac3656d2bd029d515d545f0f5c0ff4e133d87d..e56bd5d96de85e4c46525bf514bf6754b3145e64 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/GainUncertainty.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/GainUncertainty.cxx
@@ -1,86 +1,83 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-#include <ElectronPhotonFourMomentumCorrection/GainUncertainty.h>
-#include "PathResolver/PathResolver.h"
-#include <TH1F.h>
-#include <TH1D.h>
-#include <TFile.h>
-#include <iostream>
-
-
-namespace egGain {
-
-
-//--------------------------------------
-
-  GainUncertainty::GainUncertainty(std::string filename) : asg::AsgMessaging("GainUncertainty") {
-    
-    ATH_MSG_INFO("opening file " << filename);
-    m_gainFile = std::make_unique<TFile>(filename.c_str());
-
-    if (not (m_alpha_specialGainRun = (TH1F*)(m_gainFile->Get("alpha_specialGainRun")))) ATH_MSG_FATAL("cannot open histogram1");
-    if (not (m_gain_impact_Zee = (TH1F*)(m_gainFile->Get("gain_impact_Zee")))) ATH_MSG_FATAL("cannot open histogram2");
-    for (int i=0;i<m_NUM_ETA_BINS;i++) {
-     char name[60];
-     sprintf(name,"gain_Impact_elec_%d",i);
-     if (not (m_gain_Impact_elec[i] = (TH1D*)(m_gainFile->Get(name)))) ATH_MSG_FATAL("cannot open histogram3");
-     sprintf(name,"gain_Impact_conv_%d",i);
-     if (not (m_gain_Impact_conv[i] = (TH1D*)(m_gainFile->Get(name)))) ATH_MSG_FATAL("cannot open histogram4");
-     sprintf(name,"gain_Impact_unco_%d",i);
-     if (not (m_gain_Impact_unco[i]= (TH1D*)(m_gainFile->Get(name)))) ATH_MSG_FATAL("cannot open histogram5");
-    }
-    
-  }
-
-//----------------------------------------------
-
-  GainUncertainty::~GainUncertainty() {
-      delete m_alpha_specialGainRun;
-      delete m_gain_impact_Zee;
-      for (int i=0;i<m_NUM_ETA_BINS;i++) {
-        delete m_gain_Impact_elec[i];
-        delete m_gain_Impact_conv[i];
-        delete m_gain_Impact_unco[i];
-      }
-  }
-
-//----------------------------------------------
-
-    // returns relative uncertainty on energy
-
-  double GainUncertainty::getUncertainty(double etaCalo_input, double et_input,  PATCore::ParticleType::Type ptype) const {
-       double aeta=std::fabs(etaCalo_input);
-       int ibin=-1;
-       if (aeta<0.8) ibin=0;
-       else if (aeta<1.37) ibin=1;
-       else if (aeta<1.52) ibin=2;
-       else if (aeta<1.80) ibin=3;
-       else if (aeta<2.50) ibin=4;
-       if (ibin<0) return 0.;
-       
-       //Protection needed as the histograms stops at 1 TeV
-       if(et_input>999999.) et_input = 999999.;
-       
-//       std::cout << " --- in  GainUncertainty::getUncertainty " << etaCalo_input << " " << et_input << " " << ptype << " ibin " << ibin << std::endl;
-
-       double impact=0.;
-       if (ptype==PATCore::ParticleType::Electron) impact = m_gain_Impact_elec[ibin]->GetBinContent(m_gain_Impact_elec[ibin]->FindFixBin(0.001*et_input));
-       if (ptype==PATCore::ParticleType::ConvertedPhoton) impact = m_gain_Impact_conv[ibin]->GetBinContent(m_gain_Impact_conv[ibin]->FindFixBin(0.001*et_input));
-       if (ptype==PATCore::ParticleType::UnconvertedPhoton) impact = m_gain_Impact_unco[ibin]->GetBinContent(m_gain_Impact_unco[ibin]->FindFixBin(0.001*et_input));
-
-//       std::cout << " impact " << impact << std::endl;
-       double_t sigmaE = m_alpha_specialGainRun->GetBinContent(m_alpha_specialGainRun->FindFixBin(aeta))
-                        /m_gain_impact_Zee->GetBinContent(m_gain_impact_Zee->FindFixBin(aeta))
-                        *impact ;
-
-//       std::cout << " m_alpha_specialGainRun, m_gain_impact_Zee, impact , sigmaE " << m_alpha_specialGainRun->GetBinContent(m_alpha_specialGainRun->FindBin(aeta))
-//  << " " << m_gain_impact_Zee->GetBinContent(m_gain_impact_Zee->FindBin(aeta)) << " " << impact << " " << sigmaE << std::endl;
-
-       return sigmaE;
-
-  }
-
-
-}
+#include <ElectronPhotonFourMomentumCorrection/GainUncertainty.h>
+#include <TH1.h>
+#include <TFile.h>
+
+
+namespace egGain {
+
+
+//--------------------------------------
+
+  GainUncertainty::GainUncertainty(const std::string& filename) : asg::AsgMessaging("GainUncertainty") {
+
+    ATH_MSG_INFO("opening file " << filename);
+    m_gainFile.reset( TFile::Open( filename.c_str(), "READ" ) );
+
+    if (not (m_alpha_specialGainRun = (TH1*)(m_gainFile->Get("alpha_specialGainRun")))) ATH_MSG_FATAL("cannot open histogram1");
+    if (not (m_gain_impact_Zee = (TH1*)(m_gainFile->Get("gain_impact_Zee")))) ATH_MSG_FATAL("cannot open histogram2");
+    for (int i=0;i<m_NUM_ETA_BINS;i++) {
+     char name[60];
+     sprintf(name,"gain_Impact_elec_%d",i);
+     if (not (m_gain_Impact_elec[i] = (TH1*)(m_gainFile->Get(name)))) ATH_MSG_FATAL("cannot open histogram3");
+     sprintf(name,"gain_Impact_conv_%d",i);
+     if (not (m_gain_Impact_conv[i] = (TH1*)(m_gainFile->Get(name)))) ATH_MSG_FATAL("cannot open histogram4");
+     sprintf(name,"gain_Impact_unco_%d",i);
+     if (not (m_gain_Impact_unco[i]= (TH1*)(m_gainFile->Get(name)))) ATH_MSG_FATAL("cannot open histogram5");
+    }
+
+  }
+
+//----------------------------------------------
+
+  GainUncertainty::~GainUncertainty() {
+      delete m_alpha_specialGainRun;
+      delete m_gain_impact_Zee;
+      for (int i=0;i<m_NUM_ETA_BINS;i++) {
+        delete m_gain_Impact_elec[i];
+        delete m_gain_Impact_conv[i];
+        delete m_gain_Impact_unco[i];
+      }
+  }
+
+//----------------------------------------------
+
+    // returns relative uncertainty on energy
+
+  double GainUncertainty::getUncertainty(double etaCalo_input, double et_input,  PATCore::ParticleType::Type ptype) const {
+       double aeta=std::fabs(etaCalo_input);
+       int ibin=-1;
+       if (aeta<0.8) ibin=0;
+       else if (aeta<1.37) ibin=1;
+       else if (aeta<1.52) ibin=2;
+       else if (aeta<1.80) ibin=3;
+       else if (aeta<2.50) ibin=4;
+       if (ibin<0) return 0.;
+
+       //Protection needed as the histograms stops at 1 TeV
+       if(et_input>999999.) et_input = 999999.;
+
+//       std::cout << " --- in  GainUncertainty::getUncertainty " << etaCalo_input << " " << et_input << " " << ptype << " ibin " << ibin << std::endl;
+
+       double impact=0.;
+       if (ptype==PATCore::ParticleType::Electron) impact = m_gain_Impact_elec[ibin]->GetBinContent(m_gain_Impact_elec[ibin]->FindFixBin(0.001*et_input));
+       if (ptype==PATCore::ParticleType::ConvertedPhoton) impact = m_gain_Impact_conv[ibin]->GetBinContent(m_gain_Impact_conv[ibin]->FindFixBin(0.001*et_input));
+       if (ptype==PATCore::ParticleType::UnconvertedPhoton) impact = m_gain_Impact_unco[ibin]->GetBinContent(m_gain_Impact_unco[ibin]->FindFixBin(0.001*et_input));
+
+//       std::cout << " impact " << impact << std::endl;
+       double_t sigmaE = m_alpha_specialGainRun->GetBinContent(m_alpha_specialGainRun->FindFixBin(aeta))
+                        /m_gain_impact_Zee->GetBinContent(m_gain_impact_Zee->FindFixBin(aeta))
+                        *impact ;
+
+//       std::cout << " m_alpha_specialGainRun, m_gain_impact_Zee, impact , sigmaE " << m_alpha_specialGainRun->GetBinContent(m_alpha_specialGainRun->FindBin(aeta))
+//  << " " << m_gain_impact_Zee->GetBinContent(m_gain_impact_Zee->FindBin(aeta)) << " " << impact << " " << sigmaE << std::endl;
+
+       return sigmaE;
+
+  }
+
+
+}
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/LArTemperatureCorrectionTool.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/LArTemperatureCorrectionTool.cxx
index ac57cfa596c753e8f0bce6cbb9d97d0baf77f9d8..d05fa9ebc20b05fad5010c61910b0fb83725e53b 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/LArTemperatureCorrectionTool.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/LArTemperatureCorrectionTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include <TParameter.h>
@@ -20,9 +20,7 @@ LArTemperatureCorrectionTool::LArTemperatureCorrectionTool(const std::string& fi
   if (!m_file or m_file->IsZombie()) { ATH_MSG_ERROR("cannot open file"); }
 
   m_tree = dynamic_cast<TTree*>(m_file->Get("temperature"));
-  if ( m_tree == nullptr ) { 
-    throw std::runtime_error( "cannot find tree" );
-  }
+  if (!m_tree) { ATH_MSG_FATAL("cannot find tree"); }
 
   Int_t t_run = 0;
   m_tree->SetBranchAddress("run", &t_run);
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/e1hg_systematics.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/e1hg_systematics.cxx
index 6864be8740e34ae5c1d0782c885272e524609428..98a580c5295a2a511d4597671c152dd34006db16 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/e1hg_systematics.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/e1hg_systematics.cxx
@@ -1,105 +1,105 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-#include "ElectronPhotonFourMomentumCorrection/e1hg_systematics.h"
-#include "PathResolver/PathResolver.h"
-#include <stdlib.h>
-#include <math.h>
-
-#include "TAxis.h"
-#include "Riostream.h"
-
-#ifndef ROOTCORE
-#include "PathResolver/PathResolver.h"
-#endif
-
-e1hg_systematics::e1hg_systematics()
-{
-
-  m_file0 = TFile::Open( PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/e1hg_systematics_histos.root").c_str() );
-
-
-  for (Int_t ieta=0;ieta<8;ieta++) {
-     char name[60];
-     sprintf(name,"elec_%d",ieta);
-     m_helec[ieta] = (TH1D*) m_file0->Get(name);
-     sprintf(name,"unconv_%d",ieta);
-     m_hphot[ieta] = (TH1D*) m_file0->Get(name);
-     sprintf(name,"conv_%d",ieta);
-     m_hphot2[ieta] = (TH1D*) m_file0->Get(name);
-
-  }
-
-  TAxis* aa=m_helec[0]->GetXaxis();
-  m_etBins = aa->GetXbins();
-
-}
-
-//=========================================================================
-e1hg_systematics::~e1hg_systematics()
-{
-  m_file0->Close();
-}
-
-//============================================================================
-// inputs are particle_type (0=elec, 1=reco unconv photon, 2=reco conv photon)
-//            energy in MeV
-//            eta
-//
-// returned value is alpha = DeltaE / E
-//
-double e1hg_systematics::getAlpha(int particle_type, double energy, double eta, bool interpolate) const
-{
-
-   //cout << " in getDelta " << endl;
-   if (particle_type<0 || particle_type>2) return 0.;
-
-   float aeta=fabs(eta);
-   int ieta=0;
-   if (aeta<0.4) ieta=0;
-   else if (aeta<0.8) ieta=1;
-   else if (aeta<1.1) ieta=2;
-   else if (aeta<1.37) ieta=3;
-   else if (aeta<1.52) ieta=4;
-   else if (aeta<1.80) ieta=5;
-   else if (aeta<2.10) ieta=6;
-   else                ieta=7;
-
-
-   double energyGeV = energy*0.001;
-   double et = energyGeV/cosh(eta);
-
-   int ibinEt=m_etBins->GetSize()-2;
-   for (int i=1;i<m_etBins->GetSize();i++) {
-      if (et<m_etBins->GetAt(i)) {
-         ibinEt=i-1;
-         break;
-      }
-   }
-
-//   cout << " energy, et , ibinEt " << energyGeV << " " << et << " " << ibinEt << endl;
-
-   Double_t scale=0.;
-   //HACK: some ES model dependency needs to be introduced
-   /*Default up to es2017_summer
-     if (aeta<1.80) scale=0.;
-     else if (aeta<2.3) scale = 0.050*(aeta-1.8)/0.4 /0.05;
-     else scale=0.025/0.05;
-   */
-
-   if (aeta<1.80) scale=0.;
-   else if (aeta<2.3) scale = (0.050*(aeta-1.8)/0.4+0.025)/0.05;
-   else scale = 0.05/0.05;
-   
-   if( !interpolate ) {
-     if (particle_type==0) return scale*m_helec[ieta]->GetBinContent(ibinEt+1);
-     else if (particle_type==1) return scale*m_hphot[ieta]->GetBinContent(ibinEt+1);
-     else  return scale*m_hphot2[ieta]->GetBinContent(ibinEt+1); //This is 2, since if particle_type is not 0,1,2 we have returned 0 above
-   } else {
-     if (particle_type==0) return scale*m_helec[ieta]->Interpolate(et);
-     else if (particle_type==1) return scale*m_hphot[ieta]->Interpolate(et);
-     else  return scale*m_hphot2[ieta]->Interpolate(et); //This is 2, since if particle_type is not 0,1,2 we have returned 0
-   }
-
-}
+#include "ElectronPhotonFourMomentumCorrection/e1hg_systematics.h"
+#include "PathResolver/PathResolver.h"
+#include <stdlib.h>
+#include <math.h>
+
+#include "TAxis.h"
+#include "Riostream.h"
+
+#ifndef ROOTCORE
+#include "PathResolver/PathResolver.h"
+#endif
+
+e1hg_systematics::e1hg_systematics()
+{
+
+  m_file0 = TFile::Open( PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/e1hg_systematics_histos.root").c_str() );
+
+
+  for (Int_t ieta=0;ieta<8;ieta++) {
+     char name[60];
+     sprintf(name,"elec_%d",ieta);
+     m_helec[ieta] = (TH1D*) m_file0->Get(name);
+     sprintf(name,"unconv_%d",ieta);
+     m_hphot[ieta] = (TH1D*) m_file0->Get(name);
+     sprintf(name,"conv_%d",ieta);
+     m_hphot2[ieta] = (TH1D*) m_file0->Get(name);
+
+  }
+
+  TAxis* aa=m_helec[0]->GetXaxis();
+  m_etBins = aa->GetXbins();
+
+}
+
+//=========================================================================
+e1hg_systematics::~e1hg_systematics()
+{
+  m_file0->Close();
+}
+
+//============================================================================
+// inputs are particle_type (0=elec, 1=reco unconv photon, 2=reco conv photon)
+//            energy in MeV
+//            eta
+//
+// returned value is alpha = DeltaE / E
+//
+double e1hg_systematics::getAlpha(int particle_type, double energy, double eta, bool interpolate) const
+{
+
+   //cout << " in getDelta " << endl;
+   if (particle_type<0 || particle_type>2) return 0.;
+
+   float aeta=fabs(eta);
+   int ieta=0;
+   if (aeta<0.4) ieta=0;
+   else if (aeta<0.8) ieta=1;
+   else if (aeta<1.1) ieta=2;
+   else if (aeta<1.37) ieta=3;
+   else if (aeta<1.52) ieta=4;
+   else if (aeta<1.80) ieta=5;
+   else if (aeta<2.10) ieta=6;
+   else                ieta=7;
+
+
+   double energyGeV = energy*0.001;
+   double et = energyGeV/cosh(eta);
+
+   int ibinEt=m_etBins->GetSize()-2;
+   for (int i=1;i<m_etBins->GetSize();i++) {
+      if (et<m_etBins->GetAt(i)) {
+         ibinEt=i-1;
+         break;
+      }
+   }
+
+//   cout << " energy, et , ibinEt " << energyGeV << " " << et << " " << ibinEt << endl;
+
+   Double_t scale=0.;
+   //HACK: some ES model dependency needs to be introduced
+   /*Default up to es2017_summer
+     if (aeta<1.80) scale=0.;
+     else if (aeta<2.3) scale = 0.050*(aeta-1.8)/0.4 /0.05;
+     else scale=0.025/0.05;
+   */
+
+   if (aeta<1.80) scale=0.;
+   else if (aeta<2.3) scale = (0.050*(aeta-1.8)/0.4+0.025)/0.05;
+   else scale = 0.05/0.05;
+
+   if( !interpolate ) {
+     if (particle_type==0) return scale*m_helec[ieta]->GetBinContent(ibinEt+1);
+     else if (particle_type==1) return scale*m_hphot[ieta]->GetBinContent(ibinEt+1);
+     else  return scale*m_hphot2[ieta]->GetBinContent(ibinEt+1); //This is 2, since if particle_type is not 0,1,2 we have returned 0 above
+   } else {
+     if (particle_type==0) return scale*m_helec[ieta]->Interpolate(et);
+     else if (particle_type==1) return scale*m_hphot[ieta]->Interpolate(et);
+     else  return scale*m_hphot2[ieta]->Interpolate(et); //This is 2, since if particle_type is not 0,1,2 we have returned 0
+   }
+
+}
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/egammaEnergyCorrectionTool.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/egammaEnergyCorrectionTool.cxx
index 3253f9da912d08032c8746328042e13b5baf95db..46534de4455d8852b59c63cd00b4c64afb1fc0c6 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/egammaEnergyCorrectionTool.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/egammaEnergyCorrectionTool.cxx
@@ -1,8 +1,8 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-// Dear emacs, this is -*-c++-*-
+
 ///
 /// Implementation of energy scale uncertainties, for 2010 data and beyond
 ///
@@ -14,12 +14,20 @@
 
 #include <boost/format.hpp>
 
+#include "TH1.h"
+#include "TH2.h"
+#include "TF1.h"
+#include "TFile.h"
+#include "TList.h"
+#include "TGraphErrors.h"
+
+#include "egammaUtils/eg_resolution.h"
 #include "ElectronPhotonFourMomentumCorrection/egammaEnergyCorrectionTool.h"
 #include "ElectronPhotonFourMomentumCorrection/GainTool.h"
 #include "ElectronPhotonFourMomentumCorrection/get_MaterialResolutionEffect.h"
 #include "ElectronPhotonFourMomentumCorrection/e1hg_systematics.h"
 #include "ElectronPhotonFourMomentumCorrection/GainUncertainty.h"
-#include "egammaUtils/eg_resolution.h"
+
 
 #include "PathResolver/PathResolver.h"
 
@@ -65,120 +73,31 @@ namespace AtlasRoot {
   egammaEnergyCorrectionTool::egammaEnergyCorrectionTool()
     :
     asg::AsgMessaging("egammaEnergyCorrectionTool"),
-    m_rootFile (nullptr),
-    m_rootFileName (PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v13/egammaEnergyCorrectionData.root")),
+    m_rootFileName(PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v24/egammaEnergyCorrectionData.root")),
     m_esmodel(egEnergyCorr::UNDEFINED)
   {
+
+
+
     if (m_rootFileName.empty()) {
       ATH_MSG_FATAL("cannot find configuration file");
       throw std::runtime_error("cannot find file");
     }
-    
+
     m_begRunNumber = 0;
     m_endRunNumber = 0;
 
-    // corrections and systematics
-
-    m_aPSNom = nullptr;
-    m_daPSCor = nullptr;
-    m_aS12Nom = nullptr;
-    m_daS12Cor = nullptr;
-    m_zeeNom = nullptr;
-    m_zeeSyst = nullptr;
-    m_zeePhys = nullptr;
-    m_uA2MeV_2015_first2weeks_correction = nullptr;
-
-    m_zeeNom_data2015 = nullptr;  
-    m_wstot_slope_A_data = nullptr;
-    m_wstot_slope_B_MC = nullptr;
-    m_wstot_40GeV_data = nullptr;
-    m_wstot_40GeV_MC = nullptr;
-    m_wstot_pT_data_p0_electrons = nullptr; 
-    m_wstot_pT_data_p1_electrons = nullptr; 
-    m_wstot_pT_data_p0_unconverted_photons = nullptr;
-    m_wstot_pT_data_p1_unconverted_photons = nullptr;
-    m_wstot_pT_data_p0_converted_photons = nullptr;
-    m_wstot_pT_data_p1_converted_photons = nullptr;
-    m_wstot_pT_MC_p0_electrons = nullptr;
-    m_wstot_pT_MC_p1_electrons = nullptr;
-    m_wstot_pT_MC_p0_unconverted_photons = nullptr;
-    m_wstot_pT_MC_p1_unconverted_photons = nullptr;
-    m_wstot_pT_MC_p0_converted_photons = nullptr;
-    m_wstot_pT_MC_p1_converted_photons = nullptr;
-
-    m_resNom = nullptr;
-    m_resSyst = nullptr;
-
-    m_trkSyst = nullptr;
-
-    m_peakResData = nullptr;
-    m_peakResMC = nullptr;
-
-    m_dX_ID_Nom = nullptr;
-
-    m_dX_IPPS_Nom = nullptr;
-    m_dX_IPPS_LAr = nullptr;
-
-    m_dX_IPAcc_Nom = nullptr;
-    m_dX_IPAcc_LAr = nullptr;
-    m_dX_IPAcc_G4 = nullptr;
-    m_dX_IPAcc_GL1 = nullptr;
-
-    m_dX_PSAcc_Nom = nullptr;
-    m_dX_PSAcc_LAr = nullptr;
-    m_dX_PSAcc_G4 = nullptr;
-
-    m_psElectronEtaBins = nullptr;
-    m_psElectronGraphs = nullptr;
-    m_psUnconvertedEtaBins = nullptr;
-    m_psUnconvertedGraphs = nullptr;
-    m_psConvertedEtaBins = nullptr;
-    m_psConvertedGraphs = nullptr;
-
-    m_s12ElectronEtaBins = nullptr;
-    m_s12ElectronGraphs = nullptr;
-    m_s12UnconvertedEtaBins = nullptr;
-    m_s12UnconvertedGraphs = nullptr;
-    m_s12ConvertedEtaBins = nullptr;
-    m_s12ConvertedGraphs = nullptr;
-
-    m_pedestalL0 = nullptr;
-    m_pedestalL1 = nullptr;
-    m_pedestalL2 = nullptr;
-    m_pedestalL3 = nullptr;
-
-    m_pedestals_es2017 = nullptr;
-
-    m_convRadius = nullptr;
-    m_convFakeRate = nullptr;
-    m_convRecoEfficiency = nullptr;
-
-    m_leakageConverted = nullptr;
-    m_leakageUnconverted = nullptr;
-
-    m_zeeES2Profile = nullptr;
-
-    m_matElectronEtaBins = nullptr;
-
-    m_G4OverAFII_electron = nullptr;
-    m_G4OverAFII_unconverted = nullptr;
-    m_G4OverAFII_converted = nullptr;
-    m_G4OverAFII_resolution_electron = nullptr;
-    m_G4OverAFII_resolution_unconverted = nullptr;
-    m_G4OverAFII_resolution_converted = nullptr;
-
-    m_pp0_elec = m_pp0_conv = m_pp0_unconv = nullptr;
-
-    m_G4OverFrSh = nullptr;
+
+    /*
+     * All histogram vectors start empty
+     */
 
     m_use_new_resolution_model = false;
 
     // tools
 
-    m_gain_tool = nullptr;
-    m_gain_tool_run2 = nullptr;
     m_resolution_tool = nullptr;
-    m_getMaterialDelta = nullptr;
+    //m_getMaterialDelta = nullptr;
     m_e1hg_tool = nullptr;
 
     // switches
@@ -204,52 +123,6 @@ namespace AtlasRoot {
 
     // Clean up
 
-    if ( m_rootFile )                   delete m_rootFile;
-
-    if ( m_gain_tool )                  delete m_gain_tool;
-    if ( m_gain_tool_run2 )             delete m_gain_tool_run2;
-    if ( m_e1hg_tool )                  delete m_e1hg_tool;
-    if ( m_resolution_tool )            delete m_resolution_tool;
-    if ( m_getMaterialDelta)            delete m_getMaterialDelta;
-
-    if ( m_aPSNom )                     delete m_aPSNom;
-    if ( m_daPSCor )                    delete m_daPSCor;
-    if ( m_aS12Nom )                    delete m_aS12Nom;
-    if ( m_daS12Cor )                   delete m_daS12Cor;
-    if ( m_zeeNom )                     delete m_zeeNom;
-    if ( m_zeeSyst )                    delete m_zeeSyst;
-    if (m_uA2MeV_2015_first2weeks_correction) delete m_uA2MeV_2015_first2weeks_correction;
-    if ( m_zeePhys )                    delete m_zeePhys;
-    if ( m_resNom )                     delete m_resNom;
-    if ( m_resSyst )                    delete m_resSyst;
-    if ( m_peakResData )                delete m_peakResData;
-    if ( m_peakResMC )                  delete m_peakResMC;
-    if ( m_dX_ID_Nom )                  delete m_dX_ID_Nom;
-    if ( m_dX_IPPS_Nom )                delete m_dX_IPPS_Nom;
-    if ( m_dX_IPPS_LAr )                delete m_dX_IPPS_LAr;
-    if ( m_dX_IPAcc_Nom )               delete m_dX_IPAcc_Nom;
-    if ( m_dX_IPAcc_LAr )               delete m_dX_IPAcc_LAr;
-    if ( m_dX_IPAcc_G4 )                delete m_dX_IPAcc_G4;
-    if ( m_dX_IPAcc_GL1 )               delete m_dX_IPAcc_GL1;
-    if ( m_dX_PSAcc_Nom )               delete m_dX_PSAcc_Nom;
-    if ( m_dX_PSAcc_LAr )               delete m_dX_PSAcc_LAr;
-    if ( m_dX_PSAcc_G4 )                delete m_dX_PSAcc_G4;
-    if ( m_G4OverAFII_electron )        delete m_G4OverAFII_electron;
-    if ( m_G4OverAFII_converted )       delete m_G4OverAFII_converted;
-    if ( m_G4OverAFII_unconverted )     delete m_G4OverAFII_unconverted;
-    if ( m_G4OverAFII_resolution_electron )        delete m_G4OverAFII_resolution_electron;
-    if ( m_G4OverAFII_resolution_converted )       delete m_G4OverAFII_resolution_converted;
-    if ( m_G4OverAFII_resolution_unconverted )     delete m_G4OverAFII_resolution_unconverted;
-    if ( m_G4OverFrSh )                 delete m_G4OverFrSh;
-    if ( m_matElectronEtaBins )         delete m_matElectronEtaBins;
-    delete m_pp0_elec;
-    delete m_pp0_conv;
-    delete m_pp0_unconv;
-    delete m_pedestalL0;
-    delete m_pedestalL1;
-    delete m_pedestalL2;
-    delete m_pedestalL3;
-    delete m_pedestals_es2017;
   }
 
 
@@ -266,20 +139,20 @@ namespace AtlasRoot {
 
     ATH_MSG_DEBUG("initialize internal tool");
 
-    // Load the ROOT file
-    const char* fname(gSystem->ExpandPathName( m_rootFileName.c_str() ));
-    m_rootFile = TFile::Open( fname, "READ" );
+    // Load the ROOT filea
+
+    const std::unique_ptr<char[]> fname(gSystem->ExpandPathName(m_rootFileName.c_str()));
+    m_rootFile.reset(TFile::Open( fname.get(), "READ" ));
 
     if ( !m_rootFile ) {
       ATH_MSG_ERROR("no root file found");
-      delete fname;
       return 0;
     }
 
     // instantiate the resolution parametriaton
 
-    if (!m_getMaterialDelta)
-      m_getMaterialDelta = new get_MaterialResolutionEffect();
+    //`:if (!m_getMaterialDelta)
+    m_getMaterialDelta.reset( new get_MaterialResolutionEffect());
 
 
     // Energy corrections and systematic uncertainties
@@ -290,16 +163,17 @@ namespace AtlasRoot {
 
     if ( m_esmodel==egEnergyCorr::es2010 ) {
       m_use_new_resolution_model = false;
-      m_aPSNom      = (TH1D*) m_rootFile->Get("Scales/es2010/alphaPS_errTot");           m_aPSNom->SetDirectory(0);
-      m_aS12Nom     = (TH1D*) m_rootFile->Get("Scales/es2010/alphaS12_errTot");          m_aS12Nom->SetDirectory(0);
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get( "Scales/es2010/alphaPS_errTot" ) ) );
+      m_aPSNom->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2010/alphaS12_errTot")));          m_aS12Nom->SetDirectory(nullptr);
 
-      m_zeeNom      = (TH1D*) m_rootFile->Get("Scales/es2010/alphaZee_errStat");         m_zeeNom->SetDirectory(0);
-      m_zeeSyst     = (TH1D*) m_rootFile->Get("Scales/es2010/alphaZee_errSyst");         m_zeeSyst->SetDirectory(0);
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2010/alphaZee_errStat")));         m_zeeNom->SetDirectory(nullptr);
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2010/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
 
-      m_resNom      = (TH1D*) m_rootFile->Get("Resolution/es2010/ctZee_errStat");        m_resNom->SetDirectory(0);
-      m_resSyst     = (TH1D*) m_rootFile->Get("Resolution/es2010/ctZee_errSyst");        m_resSyst->SetDirectory(0);
-      m_peakResData = (TH1D*) m_rootFile->Get("Resolution/es2010/resZee_Data");          m_peakResData->SetDirectory(0);
-      m_peakResMC   = (TH1D*) m_rootFile->Get("Resolution/es2010/resZee_MC");            m_peakResMC->SetDirectory(0);
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2010/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2010/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
+      m_peakResData.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2010/resZee_Data")));          m_peakResData->SetDirectory(nullptr);
+      m_peakResMC.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2010/resZee_MC")));            m_peakResMC->SetDirectory(nullptr);
 
       m_begRunNumber = 152166;
       m_endRunNumber = 170482;
@@ -310,16 +184,16 @@ namespace AtlasRoot {
 
     } else if ( m_esmodel==egEnergyCorr::es2011c ) {
       m_use_new_resolution_model = false;
-      m_aPSNom      = (TH1D*) m_rootFile->Get("Scales/es2011c/alphaPS_errTot");          m_aPSNom->SetDirectory(0);
-      m_aS12Nom     = (TH1D*) m_rootFile->Get("Scales/es2011c/alphaS12_errTot");         m_aS12Nom->SetDirectory(0);
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011c/alphaPS_errTot")));          m_aPSNom->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011c/alphaS12_errTot")));         m_aS12Nom->SetDirectory(nullptr);
 
-      m_zeeNom      = (TH1D*) m_rootFile->Get("Scales/es2011c/alphaZee_errStat");        m_zeeNom->SetDirectory(0);
-      m_zeeSyst     = (TH1D*) m_rootFile->Get("Scales/es2011c/alphaZee_errSyst");        m_zeeSyst->SetDirectory(0);
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011c/alphaZee_errStat")));        m_zeeNom->SetDirectory(nullptr);
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011c/alphaZee_errSyst")));        m_zeeSyst->SetDirectory(nullptr);
 
-      m_resNom      = (TH1D*) m_rootFile->Get("Resolution/es2011c/ctZee_errStat");       m_resNom->SetDirectory(0);
-      m_resSyst     = (TH1D*) m_rootFile->Get("Resolution/es2011c/ctZee_errSyst");       m_resSyst->SetDirectory(0);
-      m_peakResData = (TH1D*) m_rootFile->Get("Resolution/es2011c/resZee_Data");         m_peakResData->SetDirectory(0);
-      m_peakResMC   = (TH1D*) m_rootFile->Get("Resolution/es2011c/resZee_MC");           m_peakResMC->SetDirectory(0);
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011c/ctZee_errStat")));       m_resNom->SetDirectory(nullptr);
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011c/ctZee_errSyst")));       m_resSyst->SetDirectory(nullptr);
+      m_peakResData.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011c/resZee_Data")));         m_peakResData->SetDirectory(nullptr);
+      m_peakResMC.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011c/resZee_MC")));           m_peakResMC->SetDirectory(nullptr);
 
       m_begRunNumber = 177531;
       m_endRunNumber = 194382;
@@ -331,61 +205,61 @@ namespace AtlasRoot {
 
     } else if ( m_esmodel==egEnergyCorr::es2011d || m_esmodel==egEnergyCorr::es2011dMedium || m_esmodel==egEnergyCorr::es2011dTight ) {
       m_use_new_resolution_model = true;
-      m_resolution_tool = new eg_resolution("run1");
-      m_aPSNom       = (TH1D*) m_rootFile->Get("Scales/es2011d/alphaPS_uncor");                 m_aPSNom->SetDirectory(0);
-      m_daPSCor      = (TH1D*) m_rootFile->Get("Scales/es2011d/dalphaPS_cor");                  m_daPSCor->SetDirectory(0);
-      m_aS12Nom      = (TH1D*) m_rootFile->Get("Scales/es2011d/alphaS12_uncor");                m_aS12Nom->SetDirectory(0);
-      m_daS12Cor     = (TH1D*) m_rootFile->Get("Scales/es2011d/dalphaS12_cor");                 m_daS12Cor->SetDirectory(0);
+      m_resolution_tool.reset(new eg_resolution("run1"));
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011d/alphaPS_uncor")));                 m_aPSNom->SetDirectory(nullptr);
+      m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011d/dalphaPS_cor")));                  m_daPSCor->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011d/alphaS12_uncor")));                m_aS12Nom->SetDirectory(nullptr);
+      m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011d/dalphaS12_cor")));                 m_daS12Cor->SetDirectory(nullptr);
 
-      m_trkSyst      = (TH1D*) m_rootFile->Get("Scales/es2011d/momentum_errSyst");              m_trkSyst->SetDirectory(0);
+      m_trkSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011d/momentum_errSyst")));              m_trkSyst->SetDirectory(nullptr);
 
       if( m_esmodel==egEnergyCorr::es2011d ) {
 
-        m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2011d/alphaZee_errStat");              m_zeeNom->SetDirectory(0);
-        m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2011d/alphaZee_errSyst");              m_zeeSyst->SetDirectory(0);
-        m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2011d/ctZee_errStat");             m_resNom->SetDirectory(0);
-        m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2011d/ctZee_errSyst");             m_resSyst->SetDirectory(0);
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011d/alphaZee_errStat")));              m_zeeNom->SetDirectory(nullptr);
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011d/alphaZee_errSyst")));              m_zeeSyst->SetDirectory(nullptr);
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011d/ctZee_errStat")));             m_resNom->SetDirectory(nullptr);
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011d/ctZee_errSyst")));             m_resSyst->SetDirectory(nullptr);
 
       } else if( m_esmodel==egEnergyCorr::es2011dMedium ) {
 
-        m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2011dMedium/alphaZee_errStat");        m_zeeNom->SetDirectory(0);
-        m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2011dMedium/alphaZee_errSyst");        m_zeeSyst->SetDirectory(0);
-        m_zeePhys      = (TH1D*) m_rootFile->Get("Scales/es2011dMedium/alphaZee_errPhys");        m_zeePhys->SetDirectory(0);
-        m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2011dMedium/ctZee_errStat");       m_resNom->SetDirectory(0);
-        m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2011dMedium/ctZee_errSyst");       m_resSyst->SetDirectory(0);
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011dMedium/alphaZee_errStat")));        m_zeeNom->SetDirectory(nullptr);
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011dMedium/alphaZee_errSyst")));        m_zeeSyst->SetDirectory(nullptr);
+        m_zeePhys.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011dMedium/alphaZee_errPhys")));        m_zeePhys->SetDirectory(nullptr);
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011dMedium/ctZee_errStat")));       m_resNom->SetDirectory(nullptr);
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011dMedium/ctZee_errSyst")));       m_resSyst->SetDirectory(nullptr);
 
       } else if( m_esmodel==egEnergyCorr::es2011dTight ) {
 
-        m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2011dTight/alphaZee_errStat");         m_zeeNom->SetDirectory(0);
-        m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2011dTight/alphaZee_errSyst");         m_zeeSyst->SetDirectory(0);
-        m_zeePhys      = (TH1D*) m_rootFile->Get("Scales/es2011dTight/alphaZee_errPhys");         m_zeePhys->SetDirectory(0);
-        m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2011dTight/ctZee_errStat");        m_resNom->SetDirectory(0);
-        m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2011dTight/ctZee_errSyst");        m_resSyst->SetDirectory(0);
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011dTight/alphaZee_errStat")));         m_zeeNom->SetDirectory(nullptr);
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011dTight/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
+        m_zeePhys.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2011dTight/alphaZee_errPhys")));         m_zeePhys->SetDirectory(nullptr);
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011dTight/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2011dTight/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
 
       }
 
-      m_pedestalL0   = (TH1D*) m_rootFile->Get("Pedestals/es2011d/pedestals_l0");               m_pedestalL0->SetDirectory(0);
-      m_pedestalL1   = (TH1D*) m_rootFile->Get("Pedestals/es2011d/pedestals_l1");               m_pedestalL1->SetDirectory(0);
-      m_pedestalL2   = (TH1D*) m_rootFile->Get("Pedestals/es2011d/pedestals_l2");               m_pedestalL2->SetDirectory(0);
-      m_pedestalL3   = (TH1D*) m_rootFile->Get("Pedestals/es2011d/pedestals_l3");               m_pedestalL3->SetDirectory(0);
+      m_pedestalL0.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2011d/pedestals_l0")));               m_pedestalL0->SetDirectory(nullptr);
+      m_pedestalL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2011d/pedestals_l1")));               m_pedestalL1->SetDirectory(nullptr);
+      m_pedestalL2.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2011d/pedestals_l2")));               m_pedestalL2->SetDirectory(nullptr);
+      m_pedestalL3.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2011d/pedestals_l3")));               m_pedestalL3->SetDirectory(nullptr);
 
-      m_dX_ID_Nom    = (TH1D*) m_rootFile->Get("Material/DX0_ConfigA");                         m_dX_ID_Nom->SetDirectory(0);
+      m_dX_ID_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/DX0_ConfigA")));                         m_dX_ID_Nom->SetDirectory(nullptr);
 
-      m_dX_IPPS_Nom  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor");   m_dX_IPPS_Nom->SetDirectory(0);
-      m_dX_IPPS_LAr  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr");     m_dX_IPPS_LAr->SetDirectory(0);
+      m_dX_IPPS_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor")));   m_dX_IPPS_Nom->SetDirectory(nullptr);
+      m_dX_IPPS_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr")));     m_dX_IPPS_LAr->SetDirectory(nullptr);
 
-      m_dX_IPAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor");  m_dX_IPAcc_Nom->SetDirectory(0);
-      m_dX_IPAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr");    m_dX_IPAcc_LAr->SetDirectory(0);
-      m_dX_IPAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4");     m_dX_IPAcc_G4->SetDirectory(0);
-      m_dX_IPAcc_GL1  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1");    m_dX_IPAcc_GL1->SetDirectory(0);
+      m_dX_IPAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor")));  m_dX_IPAcc_Nom->SetDirectory(nullptr);
+      m_dX_IPAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr")));    m_dX_IPAcc_LAr->SetDirectory(nullptr);
+      m_dX_IPAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4")));     m_dX_IPAcc_G4->SetDirectory(nullptr);
+      m_dX_IPAcc_GL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1")));    m_dX_IPAcc_GL1->SetDirectory(nullptr);
 
-      m_dX_PSAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor");  m_dX_PSAcc_Nom->SetDirectory(0);
-      m_dX_PSAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr");    m_dX_PSAcc_LAr->SetDirectory(0);
-      m_dX_PSAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4");     m_dX_PSAcc_G4->SetDirectory(0);
+      m_dX_PSAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor")));  m_dX_PSAcc_Nom->SetDirectory(nullptr);
+      m_dX_PSAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr")));    m_dX_PSAcc_LAr->SetDirectory(nullptr);
+      m_dX_PSAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4")));     m_dX_PSAcc_G4->SetDirectory(nullptr);
 
-      m_convRadius            = (TH2D*) m_rootFile->Get("Conversions/es2011d/convRadiusMigrations");  m_convRadius->SetDirectory(0);
-      m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2011d/convFakeRate");          m_convFakeRate->SetDirectory(0);
-      m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2011d/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);
+      m_convRadius.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2011d/convRadiusMigrations")));  m_convRadius->SetDirectory(nullptr);
+      m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2011d/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);
+      m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2011d/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);
 
       m_begRunNumber = 177531;
       m_endRunNumber = 194382;
@@ -393,25 +267,26 @@ namespace AtlasRoot {
 
       const std::string gain_filename1 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsTO.root");
       const std::string gain_filename2 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsG_all.root");
-      m_gain_tool = new egGain::GainTool(gain_filename1, gain_filename2);
+      m_gain_tool.reset(new egGain::GainTool(gain_filename1, gain_filename2));
+
 
-      m_e1hg_tool = new e1hg_systematics();
+      m_e1hg_tool.reset(new e1hg_systematics());
 
       // mc12a : crude MSc fix in G4; old geometry
       // All systematics as in 2010.
 
     } else if ( m_esmodel==egEnergyCorr::es2012a ) {
       m_use_new_resolution_model = false;
-      m_aPSNom      = (TH1D*) m_rootFile->Get("Scales/es2012a/alphaPS_errTot");          m_aPSNom->SetDirectory(0);
-      m_aS12Nom     = (TH1D*) m_rootFile->Get("Scales/es2012a/alphaS12_errTot");         m_aS12Nom->SetDirectory(0);
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012a/alphaPS_errTot")));          m_aPSNom->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012a/alphaS12_errTot")));         m_aS12Nom->SetDirectory(nullptr);
 
-      m_zeeNom      = (TH1D*) m_rootFile->Get("Scales/es2012a/alphaZee_errStat");        m_zeeNom->SetDirectory(0);
-      m_zeeSyst     = (TH1D*) m_rootFile->Get("Scales/es2012a/alphaZee_errSyst");        m_zeeSyst->SetDirectory(0);
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012a/alphaZee_errStat")));        m_zeeNom->SetDirectory(nullptr);
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012a/alphaZee_errSyst")));        m_zeeSyst->SetDirectory(nullptr);
 
-      m_resNom      = (TH1D*) m_rootFile->Get("Resolution/es2012a/ctZee_errStat");       m_resNom->SetDirectory(0);
-      m_resSyst     = (TH1D*) m_rootFile->Get("Resolution/es2012a/ctZee_errSyst");       m_resSyst->SetDirectory(0);
-      m_peakResData = (TH1D*) m_rootFile->Get("Resolution/es2012a/resZee_Data");         m_peakResData->SetDirectory(0);
-      m_peakResMC   = (TH1D*) m_rootFile->Get("Resolution/es2012a/resZee_MC");           m_peakResMC->SetDirectory(0);
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2012a/ctZee_errStat")));       m_resNom->SetDirectory(nullptr);
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2012a/ctZee_errSyst")));       m_resSyst->SetDirectory(nullptr);
+      m_peakResData.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2012a/resZee_Data")));         m_peakResData->SetDirectory(nullptr);
+      m_peakResMC.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2012a/resZee_MC")));           m_peakResMC->SetDirectory(nullptr);
 
       m_begRunNumber = 195847;
       m_endRunNumber = 219365;
@@ -421,93 +296,93 @@ namespace AtlasRoot {
 
     } else if (m_esmodel == egEnergyCorr::es2012c) {
       m_use_new_resolution_model = true;
-      m_resolution_tool = new eg_resolution("run1");
+      m_resolution_tool.reset(new eg_resolution("run1"));
 
-      m_aPSNom       = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaPS_uncor");                 m_aPSNom->SetDirectory(0);
-      m_daPSCor      = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaPS_cor");                  m_daPSCor->SetDirectory(0);
-      m_aS12Nom      = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaS12_uncor");                m_aS12Nom->SetDirectory(0);
-      m_daS12Cor     = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaS12_cor");                 m_daS12Cor->SetDirectory(0);
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaPS_uncor")));                 m_aPSNom->SetDirectory(nullptr);
+      m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaPS_cor")));                  m_daPSCor->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaS12_uncor")));                m_aS12Nom->SetDirectory(nullptr);
+      m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaS12_cor")));                 m_daS12Cor->SetDirectory(nullptr);
 
-      m_trkSyst      = (TH1D*) m_rootFile->Get("Scales/es2012c/momentum_errSyst");              m_trkSyst->SetDirectory(0);
+      m_trkSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/momentum_errSyst")));              m_trkSyst->SetDirectory(nullptr);
 
-      m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaZee_errStat");              m_zeeNom->SetDirectory(0);
-      m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaZee_errSyst");              m_zeeSyst->SetDirectory(0);
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaZee_errStat")));              m_zeeNom->SetDirectory(nullptr);
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaZee_errSyst")));              m_zeeSyst->SetDirectory(nullptr);
 
-      m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2012c/ctZee_errStat");             m_resNom->SetDirectory(0);
-      m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2012c/ctZee_errSyst");             m_resSyst->SetDirectory(0);
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2012c/ctZee_errStat")));             m_resNom->SetDirectory(nullptr);
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2012c/ctZee_errSyst")));             m_resSyst->SetDirectory(nullptr);
 
-      m_pedestalL0   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l0");               m_pedestalL0->SetDirectory(0);
-      m_pedestalL1   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l1");               m_pedestalL1->SetDirectory(0);
-      m_pedestalL2   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l2");               m_pedestalL2->SetDirectory(0);
-      m_pedestalL3   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l3");               m_pedestalL3->SetDirectory(0);
+      m_pedestalL0.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l0")));               m_pedestalL0->SetDirectory(nullptr);
+      m_pedestalL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l1")));               m_pedestalL1->SetDirectory(nullptr);
+      m_pedestalL2.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l2")));               m_pedestalL2->SetDirectory(nullptr);
+      m_pedestalL3.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l3")));               m_pedestalL3->SetDirectory(nullptr);
 
-      m_dX_ID_Nom    = (TH1D*) m_rootFile->Get("Material/DX0_ConfigA");                         m_dX_ID_Nom->SetDirectory(0);
+      m_dX_ID_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/DX0_ConfigA")));                         m_dX_ID_Nom->SetDirectory(nullptr);
 
-      m_dX_IPPS_Nom  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor");   m_dX_IPPS_Nom->SetDirectory(0);
-      m_dX_IPPS_LAr  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr");     m_dX_IPPS_LAr->SetDirectory(0);
+      m_dX_IPPS_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor")));   m_dX_IPPS_Nom->SetDirectory(nullptr);
+      m_dX_IPPS_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr")));     m_dX_IPPS_LAr->SetDirectory(nullptr);
 
-      m_dX_IPAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor");  m_dX_IPAcc_Nom->SetDirectory(0);
-      m_dX_IPAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr");    m_dX_IPAcc_LAr->SetDirectory(0);
-      m_dX_IPAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4");     m_dX_IPAcc_G4->SetDirectory(0);
-      m_dX_IPAcc_GL1  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1");    m_dX_IPAcc_GL1->SetDirectory(0);
+      m_dX_IPAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor")));  m_dX_IPAcc_Nom->SetDirectory(nullptr);
+      m_dX_IPAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr")));    m_dX_IPAcc_LAr->SetDirectory(nullptr);
+      m_dX_IPAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4")));     m_dX_IPAcc_G4->SetDirectory(nullptr);
+      m_dX_IPAcc_GL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1")));    m_dX_IPAcc_GL1->SetDirectory(nullptr);
 
-      m_dX_PSAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor");  m_dX_PSAcc_Nom->SetDirectory(0);
-      m_dX_PSAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr");    m_dX_PSAcc_LAr->SetDirectory(0);
-      m_dX_PSAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4");     m_dX_PSAcc_G4->SetDirectory(0);
+      m_dX_PSAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor")));  m_dX_PSAcc_Nom->SetDirectory(nullptr);
+      m_dX_PSAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr")));    m_dX_PSAcc_LAr->SetDirectory(nullptr);
+      m_dX_PSAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4")));     m_dX_PSAcc_G4->SetDirectory(nullptr);
 
-      m_convRadius            = (TH2D*) m_rootFile->Get("Conversions/es2012c/convRadiusMigrations");  m_convRadius->SetDirectory(0);
-      m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2012c/convFakeRate");          m_convFakeRate->SetDirectory(0);
-      m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2012c/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);
+      m_convRadius.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRadiusMigrations")));  m_convRadius->SetDirectory(nullptr);
+      m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);
+      m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);
 
       m_begRunNumber = 195847;
       m_endRunNumber = 219365;
 
       const std::string gain_filename1 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsTO.root");
       const std::string gain_filename2 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsG_all.root");
-      m_gain_tool = new egGain::GainTool(gain_filename1, gain_filename2);
+      m_gain_tool.reset(new egGain::GainTool(gain_filename1, gain_filename2));
 
-      m_e1hg_tool = new e1hg_systematics();
+      m_e1hg_tool.reset(new e1hg_systematics());
     }
     else if (m_esmodel == egEnergyCorr::es2012XX) {
       m_use_etaCalo_scales = true;
       m_use_new_resolution_model = true;
-      m_resolution_tool = new eg_resolution("run1");
+      m_resolution_tool.reset(new eg_resolution("run1"));
 
-      m_aPSNom       = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaPS_uncor");                 m_aPSNom->SetDirectory(0);
-      m_daPSCor      = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaPS_cor");                  m_daPSCor->SetDirectory(0);
-      m_aS12Nom      = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaS12_uncor");                m_aS12Nom->SetDirectory(0);
-      m_daS12Cor     = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaS12_cor");                 m_daS12Cor->SetDirectory(0);
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaPS_uncor")));                 m_aPSNom->SetDirectory(nullptr);
+      m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaPS_cor")));                  m_daPSCor->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaS12_uncor")));                m_aS12Nom->SetDirectory(nullptr);
+      m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaS12_cor")));                 m_daS12Cor->SetDirectory(nullptr);
 
-      m_trkSyst      = (TH1D*) m_rootFile->Get("Scales/es2012c/momentum_errSyst");              m_trkSyst->SetDirectory(0);
+      m_trkSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/momentum_errSyst")));              m_trkSyst->SetDirectory(nullptr);
 
-      m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2015PRE/alphaZee_errStat");        m_zeeNom->SetDirectory(0);
-      m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaZee_errSyst");              m_zeeSyst->SetDirectory(0);
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015PRE/alphaZee_errStat")));        m_zeeNom->SetDirectory(nullptr);
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaZee_errSyst")));              m_zeeSyst->SetDirectory(nullptr);
 
-      m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2015PRE/ctZee_errStat");       m_resNom->SetDirectory(0);
-      m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2012c/ctZee_errSyst");             m_resSyst->SetDirectory(0);
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015PRE/ctZee_errStat")));       m_resNom->SetDirectory(nullptr);
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2012c/ctZee_errSyst")));             m_resSyst->SetDirectory(nullptr);
 
-      m_pedestalL0   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l0");               m_pedestalL0->SetDirectory(0);
-      m_pedestalL1   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l1");               m_pedestalL1->SetDirectory(0);
-      m_pedestalL2   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l2");               m_pedestalL2->SetDirectory(0);
-      m_pedestalL3   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l3");               m_pedestalL3->SetDirectory(0);
+      m_pedestalL0.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l0")));               m_pedestalL0->SetDirectory(nullptr);
+      m_pedestalL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l1")));               m_pedestalL1->SetDirectory(nullptr);
+      m_pedestalL2.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l2")));               m_pedestalL2->SetDirectory(nullptr);
+      m_pedestalL3.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l3")));               m_pedestalL3->SetDirectory(nullptr);
 
-      m_dX_ID_Nom    = (TH1D*) m_rootFile->Get("Material/DX0_ConfigA");                         m_dX_ID_Nom->SetDirectory(0);
+      m_dX_ID_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/DX0_ConfigA")));                         m_dX_ID_Nom->SetDirectory(nullptr);
 
-      m_dX_IPPS_Nom  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor");   m_dX_IPPS_Nom->SetDirectory(0);
-      m_dX_IPPS_LAr  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr");     m_dX_IPPS_LAr->SetDirectory(0);
+      m_dX_IPPS_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor")));   m_dX_IPPS_Nom->SetDirectory(nullptr);
+      m_dX_IPPS_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr")));     m_dX_IPPS_LAr->SetDirectory(nullptr);
 
-      m_dX_IPAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor");  m_dX_IPAcc_Nom->SetDirectory(0);
-      m_dX_IPAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr");    m_dX_IPAcc_LAr->SetDirectory(0);
-      m_dX_IPAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4");     m_dX_IPAcc_G4->SetDirectory(0);
-      m_dX_IPAcc_GL1  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1");    m_dX_IPAcc_GL1->SetDirectory(0);
+      m_dX_IPAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor")));  m_dX_IPAcc_Nom->SetDirectory(nullptr);
+      m_dX_IPAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr")));    m_dX_IPAcc_LAr->SetDirectory(nullptr);
+      m_dX_IPAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4")));     m_dX_IPAcc_G4->SetDirectory(nullptr);
+      m_dX_IPAcc_GL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1")));    m_dX_IPAcc_GL1->SetDirectory(nullptr);
 
-      m_dX_PSAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor");  m_dX_PSAcc_Nom->SetDirectory(0);
-      m_dX_PSAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr");    m_dX_PSAcc_LAr->SetDirectory(0);
-      m_dX_PSAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4");     m_dX_PSAcc_G4->SetDirectory(0);
+      m_dX_PSAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor")));  m_dX_PSAcc_Nom->SetDirectory(nullptr);
+      m_dX_PSAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr")));    m_dX_PSAcc_LAr->SetDirectory(nullptr);
+      m_dX_PSAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4")));     m_dX_PSAcc_G4->SetDirectory(nullptr);
 
-      m_convRadius            = (TH2D*) m_rootFile->Get("Conversions/es2012c/convRadiusMigrations");  m_convRadius->SetDirectory(0);
-      m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2012c/convFakeRate");          m_convFakeRate->SetDirectory(0);
-      m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2012c/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);
+      m_convRadius.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRadiusMigrations")));  m_convRadius->SetDirectory(nullptr);
+      m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);
+      m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);
 
       m_begRunNumber = 195847;
       m_endRunNumber = 219365;
@@ -515,200 +390,200 @@ namespace AtlasRoot {
 
       const std::string gain_filename1 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsTO.root");
       const std::string gain_filename2 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsG_all.root");
-      m_gain_tool = new egGain::GainTool(gain_filename1, gain_filename2);
+      m_gain_tool.reset(new egGain::GainTool(gain_filename1, gain_filename2));
 
-      m_e1hg_tool = new e1hg_systematics();
+      m_e1hg_tool.reset(new e1hg_systematics());
     }
     else if (m_esmodel == egEnergyCorr::es2015PRE or m_esmodel == egEnergyCorr::es2015cPRE) {
       m_use_etaCalo_scales = true;
       m_use_new_resolution_model = true;
-      m_resolution_tool = new eg_resolution("run2_pre");
+      m_resolution_tool.reset( new eg_resolution("run2_pre")) ;
 
-      m_aPSNom       = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaPS_uncor");                 m_aPSNom->SetDirectory(0);
-      m_daPSCor      = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaPS_cor");                  m_daPSCor->SetDirectory(0);
-      m_aS12Nom      = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaS12_uncor");                m_aS12Nom->SetDirectory(0);
-      m_daS12Cor     = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaS12_cor");                 m_daS12Cor->SetDirectory(0);
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaPS_uncor")));                 m_aPSNom->SetDirectory(nullptr);
+      m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaPS_cor")));                  m_daPSCor->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaS12_uncor")));                m_aS12Nom->SetDirectory(nullptr);
+      m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaS12_cor")));                 m_daS12Cor->SetDirectory(nullptr);
 
-      m_trkSyst      = (TH1D*) m_rootFile->Get("Scales/es2012c/momentum_errSyst");              m_trkSyst->SetDirectory(0);
+      m_trkSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/momentum_errSyst")));              m_trkSyst->SetDirectory(nullptr);
 
-      m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2015PRE/alphaZee_errStat");        m_zeeNom->SetDirectory(0);
-      m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2015PRE/alphaZee_errSyst");              m_zeeSyst->SetDirectory(0);
-      m_uA2MeV_2015_first2weeks_correction = (TH1*) m_rootFile->Get("Scales/es2015PRE/histo_uA2MeV_week12"); m_uA2MeV_2015_first2weeks_correction->SetDirectory(0);
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015PRE/alphaZee_errStat")));        m_zeeNom->SetDirectory(nullptr);
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015PRE/alphaZee_errSyst")));              m_zeeSyst->SetDirectory(nullptr);
+      m_uA2MeV_2015_first2weeks_correction.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015PRE/histo_uA2MeV_week12"))); m_uA2MeV_2015_first2weeks_correction->SetDirectory(nullptr);
 
-      m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2015PRE/ctZee_errStat");       m_resNom->SetDirectory(0);
-      m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2015PRE/ctZee_errSyst");             m_resSyst->SetDirectory(0);
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015PRE/ctZee_errStat")));       m_resNom->SetDirectory(nullptr);
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015PRE/ctZee_errSyst")));             m_resSyst->SetDirectory(nullptr);
 
-      m_pedestalL0   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l0");               m_pedestalL0->SetDirectory(0);
-      m_pedestalL1   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l1");               m_pedestalL1->SetDirectory(0);
-      m_pedestalL2   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l2");               m_pedestalL2->SetDirectory(0);
-      m_pedestalL3   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l3");               m_pedestalL3->SetDirectory(0);
+      m_pedestalL0.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l0")));               m_pedestalL0->SetDirectory(nullptr);
+      m_pedestalL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l1")));               m_pedestalL1->SetDirectory(nullptr);
+      m_pedestalL2.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l2")));               m_pedestalL2->SetDirectory(nullptr);
+      m_pedestalL3.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l3")));               m_pedestalL3->SetDirectory(nullptr);
 
-      m_dX_ID_Nom    = (TH1D*) m_rootFile->Get("Material/DX0_ConfigA");                         m_dX_ID_Nom->SetDirectory(0);
+      m_dX_ID_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/DX0_ConfigA")));                         m_dX_ID_Nom->SetDirectory(nullptr);
 
-      m_dX_IPPS_Nom  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor");   m_dX_IPPS_Nom->SetDirectory(0);
-      m_dX_IPPS_LAr  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr");     m_dX_IPPS_LAr->SetDirectory(0);
+      m_dX_IPPS_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor")));   m_dX_IPPS_Nom->SetDirectory(nullptr);
+      m_dX_IPPS_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr")));     m_dX_IPPS_LAr->SetDirectory(nullptr);
 
-      m_dX_IPAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor");  m_dX_IPAcc_Nom->SetDirectory(0);
-      m_dX_IPAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr");    m_dX_IPAcc_LAr->SetDirectory(0);
-      m_dX_IPAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4");     m_dX_IPAcc_G4->SetDirectory(0);
-      m_dX_IPAcc_GL1  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1");    m_dX_IPAcc_GL1->SetDirectory(0);
+      m_dX_IPAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor")));  m_dX_IPAcc_Nom->SetDirectory(nullptr);
+      m_dX_IPAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr")));    m_dX_IPAcc_LAr->SetDirectory(nullptr);
+      m_dX_IPAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4")));     m_dX_IPAcc_G4->SetDirectory(nullptr);
+      m_dX_IPAcc_GL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1")));    m_dX_IPAcc_GL1->SetDirectory(nullptr);
 
-      m_dX_PSAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor");  m_dX_PSAcc_Nom->SetDirectory(0);
-      m_dX_PSAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr");    m_dX_PSAcc_LAr->SetDirectory(0);
-      m_dX_PSAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4");     m_dX_PSAcc_G4->SetDirectory(0);
+      m_dX_PSAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor")));  m_dX_PSAcc_Nom->SetDirectory(nullptr);
+      m_dX_PSAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr")));    m_dX_PSAcc_LAr->SetDirectory(nullptr);
+      m_dX_PSAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4")));     m_dX_PSAcc_G4->SetDirectory(nullptr);
 
-      m_convRadius            = (TH2D*) m_rootFile->Get("Conversions/es2012c/convRadiusMigrations");  m_convRadius->SetDirectory(0);
-      m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2012c/convFakeRate");          m_convFakeRate->SetDirectory(0);
-      m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2012c/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);
+      m_convRadius.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRadiusMigrations")));  m_convRadius->SetDirectory(nullptr);
+      m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);
+      m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);
 
       m_begRunNumber = 195847;
       m_endRunNumber = 219365;
 
-      m_G4OverAFII_resolution_electron = (TH2F*)m_rootFile->Get("FastSim/es2015/el_full_fast_resolution");
-      m_G4OverAFII_resolution_unconverted = (TH2F*)m_rootFile->Get("FastSim/es2015/ph_unconv_full_fast_resolution");
-      m_G4OverAFII_resolution_converted = (TH2F*)m_rootFile->Get("FastSim/es2015/ph_conv_full_fast_resolution");
+      m_G4OverAFII_resolution_electron.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/el_full_fast_resolution")));
+      m_G4OverAFII_resolution_unconverted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/ph_unconv_full_fast_resolution")));
+      m_G4OverAFII_resolution_converted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/ph_conv_full_fast_resolution")));
 
       assert(m_G4OverAFII_resolution_electron);
       assert(m_G4OverAFII_resolution_unconverted);
       assert(m_G4OverAFII_resolution_converted);
 
-      m_G4OverAFII_resolution_electron->SetDirectory(0);
-      m_G4OverAFII_resolution_unconverted->SetDirectory(0);
-      m_G4OverAFII_resolution_converted->SetDirectory(0);
+      m_G4OverAFII_resolution_electron->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_unconverted->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_converted->SetDirectory(nullptr);
 
       const std::string gain_filename1 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsTO.root");
       const std::string gain_filename2 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsG_all.root");
-      m_gain_tool = new egGain::GainTool(gain_filename1, gain_filename2);
+      m_gain_tool.reset(new egGain::GainTool(gain_filename1, gain_filename2));
 
-      m_e1hg_tool = new e1hg_systematics();
+      m_e1hg_tool.reset(new e1hg_systematics());
     }
 
     else if (m_esmodel == egEnergyCorr::es2015PRE_res_improved or m_esmodel == egEnergyCorr::es2015cPRE_res_improved) {
       m_use_etaCalo_scales = true;
       m_use_new_resolution_model = true;
-      m_resolution_tool = new eg_resolution("run2_pre");
+      m_resolution_tool.reset(new eg_resolution("run2_pre"));
 
-      m_aPSNom       = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaPS_uncor");                 m_aPSNom->SetDirectory(0);
-      m_daPSCor      = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaPS_cor");                  m_daPSCor->SetDirectory(0);
-      m_aS12Nom      = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaS12_uncor");                m_aS12Nom->SetDirectory(0);
-      m_daS12Cor     = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaS12_cor");                 m_daS12Cor->SetDirectory(0);
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaPS_uncor")));                 m_aPSNom->SetDirectory(nullptr);
+      m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaPS_cor")));                  m_daPSCor->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaS12_uncor")));                m_aS12Nom->SetDirectory(nullptr);
+      m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaS12_cor")));                 m_daS12Cor->SetDirectory(nullptr);
 
-      m_trkSyst      = (TH1D*) m_rootFile->Get("Scales/es2012c/momentum_errSyst");              m_trkSyst->SetDirectory(0);
+      m_trkSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/momentum_errSyst")));              m_trkSyst->SetDirectory(nullptr);
 
-      m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2015PRE/alphaZee_errStat");        m_zeeNom->SetDirectory(0);
-      m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2015PRE/alphaZee_errSyst");              m_zeeSyst->SetDirectory(0);
-      m_uA2MeV_2015_first2weeks_correction = (TH1*) m_rootFile->Get("Scales/es2015PRE/histo_uA2MeV_week12"); m_uA2MeV_2015_first2weeks_correction->SetDirectory(0);
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015PRE/alphaZee_errStat")));        m_zeeNom->SetDirectory(nullptr);
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015PRE/alphaZee_errSyst")));              m_zeeSyst->SetDirectory(nullptr);
+      m_uA2MeV_2015_first2weeks_correction.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015PRE/histo_uA2MeV_week12"))); m_uA2MeV_2015_first2weeks_correction->SetDirectory(nullptr);
 
-      m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2015PRE/ctZee_errStat");       m_resNom->SetDirectory(0);
-      m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2015PRE_res_improved/ctZee_errSyst");             m_resSyst->SetDirectory(0);
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015PRE/ctZee_errStat")));       m_resNom->SetDirectory(nullptr);
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015PRE_res_improved/ctZee_errSyst")));             m_resSyst->SetDirectory(nullptr);
 
-      m_pedestalL0   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l0");               m_pedestalL0->SetDirectory(0);
-      m_pedestalL1   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l1");               m_pedestalL1->SetDirectory(0);
-      m_pedestalL2   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l2");               m_pedestalL2->SetDirectory(0);
-      m_pedestalL3   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l3");               m_pedestalL3->SetDirectory(0);
+      m_pedestalL0.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l0")));               m_pedestalL0->SetDirectory(nullptr);
+      m_pedestalL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l1")));               m_pedestalL1->SetDirectory(nullptr);
+      m_pedestalL2.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l2")));               m_pedestalL2->SetDirectory(nullptr);
+      m_pedestalL3.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l3")));               m_pedestalL3->SetDirectory(nullptr);
 
-      m_dX_ID_Nom    = (TH1D*) m_rootFile->Get("Material/DX0_ConfigA");                         m_dX_ID_Nom->SetDirectory(0);
+      m_dX_ID_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/DX0_ConfigA")));                         m_dX_ID_Nom->SetDirectory(nullptr);
 
-      m_dX_IPPS_Nom  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor");   m_dX_IPPS_Nom->SetDirectory(0);
-      m_dX_IPPS_LAr  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr");     m_dX_IPPS_LAr->SetDirectory(0);
+      m_dX_IPPS_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor")));   m_dX_IPPS_Nom->SetDirectory(nullptr);
+      m_dX_IPPS_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr")));     m_dX_IPPS_LAr->SetDirectory(nullptr);
 
-      m_dX_IPAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor");  m_dX_IPAcc_Nom->SetDirectory(0);
-      m_dX_IPAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr");    m_dX_IPAcc_LAr->SetDirectory(0);
-      m_dX_IPAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4");     m_dX_IPAcc_G4->SetDirectory(0);
-      m_dX_IPAcc_GL1  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1");    m_dX_IPAcc_GL1->SetDirectory(0);
+      m_dX_IPAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor")));  m_dX_IPAcc_Nom->SetDirectory(nullptr);
+      m_dX_IPAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr")));    m_dX_IPAcc_LAr->SetDirectory(nullptr);
+      m_dX_IPAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4")));     m_dX_IPAcc_G4->SetDirectory(nullptr);
+      m_dX_IPAcc_GL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1")));    m_dX_IPAcc_GL1->SetDirectory(nullptr);
 
-      m_dX_PSAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor");  m_dX_PSAcc_Nom->SetDirectory(0);
-      m_dX_PSAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr");    m_dX_PSAcc_LAr->SetDirectory(0);
-      m_dX_PSAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4");     m_dX_PSAcc_G4->SetDirectory(0);
+      m_dX_PSAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor")));  m_dX_PSAcc_Nom->SetDirectory(nullptr);
+      m_dX_PSAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr")));    m_dX_PSAcc_LAr->SetDirectory(nullptr);
+      m_dX_PSAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4")));     m_dX_PSAcc_G4->SetDirectory(nullptr);
 
-      m_convRadius            = (TH2D*) m_rootFile->Get("Conversions/es2012c/convRadiusMigrations");  m_convRadius->SetDirectory(0);
-      m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2012c/convFakeRate");          m_convFakeRate->SetDirectory(0);
-      m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2012c/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);
+      m_convRadius.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRadiusMigrations")));  m_convRadius->SetDirectory(nullptr);
+      m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);
+      m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);
 
       m_begRunNumber = 195847;
       m_endRunNumber = 219365;
 
-      m_G4OverAFII_resolution_electron = (TH2F*)m_rootFile->Get("FastSim/es2015/el_full_fast_resolution");
-      m_G4OverAFII_resolution_unconverted = (TH2F*)m_rootFile->Get("FastSim/es2015/ph_unconv_full_fast_resolution");
-      m_G4OverAFII_resolution_converted = (TH2F*)m_rootFile->Get("FastSim/es2015/ph_conv_full_fast_resolution");
+      m_G4OverAFII_resolution_electron.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/el_full_fast_resolution")));
+      m_G4OverAFII_resolution_unconverted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/ph_unconv_full_fast_resolution")));
+      m_G4OverAFII_resolution_converted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/ph_conv_full_fast_resolution")));
 
       assert(m_G4OverAFII_resolution_electron);
       assert(m_G4OverAFII_resolution_unconverted);
       assert(m_G4OverAFII_resolution_converted);
 
-      m_G4OverAFII_resolution_electron->SetDirectory(0);
-      m_G4OverAFII_resolution_unconverted->SetDirectory(0);
-      m_G4OverAFII_resolution_converted->SetDirectory(0);
+      m_G4OverAFII_resolution_electron->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_unconverted->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_converted->SetDirectory(nullptr);
 
       const std::string gain_filename1 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsTO.root");
       const std::string gain_filename2 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsG_all.root");
-      m_gain_tool = new egGain::GainTool(gain_filename1, gain_filename2);
+      m_gain_tool.reset(new egGain::GainTool(gain_filename1, gain_filename2));
 
-      m_e1hg_tool = new e1hg_systematics();
+      m_e1hg_tool.reset(new e1hg_systematics());
     }
 
     else if (m_esmodel == egEnergyCorr::es2015c_summer) {
       m_use_etaCalo_scales = true;
       m_use_new_resolution_model = true;
-      m_resolution_tool = new eg_resolution("run2_pre");
+      m_resolution_tool.reset(new eg_resolution("run2_pre"));
 
-      m_aPSNom       = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaPS_uncor");                 m_aPSNom->SetDirectory(0);
-      m_daPSCor      = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaPS_cor");                  m_daPSCor->SetDirectory(0);
-      m_aS12Nom      = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaS12_uncor");                m_aS12Nom->SetDirectory(0);
-      m_daS12Cor     = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaS12_cor");                 m_daS12Cor->SetDirectory(0);
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaPS_uncor")));                 m_aPSNom->SetDirectory(nullptr);
+      m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaPS_cor")));                  m_daPSCor->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaS12_uncor")));                m_aS12Nom->SetDirectory(nullptr);
+      m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaS12_cor")));                 m_daS12Cor->SetDirectory(nullptr);
 
-      m_trkSyst      = (TH1D*) m_rootFile->Get("Scales/es2012c/momentum_errSyst");              m_trkSyst->SetDirectory(0);
+      m_trkSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/momentum_errSyst")));              m_trkSyst->SetDirectory(nullptr);
 
-      m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2015Summer/alphaZee_errStat");        m_zeeNom->SetDirectory(0);
-      m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2015Summer/alphaZee_errSyst");              m_zeeSyst->SetDirectory(0);
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015Summer/alphaZee_errStat")));        m_zeeNom->SetDirectory(nullptr);
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015Summer/alphaZee_errSyst")));              m_zeeSyst->SetDirectory(nullptr);
       m_uA2MeV_2015_first2weeks_correction = nullptr;
 
-      m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2015Summer/ctZee_errStat");       m_resNom->SetDirectory(0);
-      m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2015Summer/ctZee_errSyst");       m_resSyst->SetDirectory(0);
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015Summer/ctZee_errStat")));       m_resNom->SetDirectory(nullptr);
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015Summer/ctZee_errSyst")));       m_resSyst->SetDirectory(nullptr);
 
-      m_pedestalL0   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l0");               m_pedestalL0->SetDirectory(0);
-      m_pedestalL1   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l1");               m_pedestalL1->SetDirectory(0);
-      m_pedestalL2   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l2");               m_pedestalL2->SetDirectory(0);
-      m_pedestalL3   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l3");               m_pedestalL3->SetDirectory(0);
+      m_pedestalL0.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l0")));               m_pedestalL0->SetDirectory(nullptr);
+      m_pedestalL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l1")));               m_pedestalL1->SetDirectory(nullptr);
+      m_pedestalL2.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l2")));               m_pedestalL2->SetDirectory(nullptr);
+      m_pedestalL3.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l3")));               m_pedestalL3->SetDirectory(nullptr);
 
-      m_dX_ID_Nom    = (TH1D*) m_rootFile->Get("Material/DX0_ConfigA");                         m_dX_ID_Nom->SetDirectory(0);
+      m_dX_ID_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/DX0_ConfigA")));                         m_dX_ID_Nom->SetDirectory(nullptr);
 
-      m_dX_IPPS_Nom  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor");   m_dX_IPPS_Nom->SetDirectory(0);
-      m_dX_IPPS_LAr  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr");     m_dX_IPPS_LAr->SetDirectory(0);
+      m_dX_IPPS_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor")));   m_dX_IPPS_Nom->SetDirectory(nullptr);
+      m_dX_IPPS_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr")));     m_dX_IPPS_LAr->SetDirectory(nullptr);
 
-      m_dX_IPAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor");  m_dX_IPAcc_Nom->SetDirectory(0);
-      m_dX_IPAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr");    m_dX_IPAcc_LAr->SetDirectory(0);
-      m_dX_IPAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4");     m_dX_IPAcc_G4->SetDirectory(0);
-      m_dX_IPAcc_GL1  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1");    m_dX_IPAcc_GL1->SetDirectory(0);
+      m_dX_IPAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor")));  m_dX_IPAcc_Nom->SetDirectory(nullptr);
+      m_dX_IPAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr")));    m_dX_IPAcc_LAr->SetDirectory(nullptr);
+      m_dX_IPAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4")));     m_dX_IPAcc_G4->SetDirectory(nullptr);
+      m_dX_IPAcc_GL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1")));    m_dX_IPAcc_GL1->SetDirectory(nullptr);
 
-      m_dX_PSAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor");  m_dX_PSAcc_Nom->SetDirectory(0);
-      m_dX_PSAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr");    m_dX_PSAcc_LAr->SetDirectory(0);
-      m_dX_PSAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4");     m_dX_PSAcc_G4->SetDirectory(0);
+      m_dX_PSAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor")));  m_dX_PSAcc_Nom->SetDirectory(nullptr);
+      m_dX_PSAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr")));    m_dX_PSAcc_LAr->SetDirectory(nullptr);
+      m_dX_PSAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4")));     m_dX_PSAcc_G4->SetDirectory(nullptr);
 
-      m_convRadius            = (TH2D*) m_rootFile->Get("Conversions/es2012c/convRadiusMigrations");  m_convRadius->SetDirectory(0);
-      m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2012c/convFakeRate");          m_convFakeRate->SetDirectory(0);
-      m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2012c/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);
+      m_convRadius.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRadiusMigrations")));  m_convRadius->SetDirectory(nullptr);
+      m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);
+      m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);
 
       m_begRunNumber = 195847;
       m_endRunNumber = 219365;
 
-      m_G4OverAFII_resolution_electron = (TH2F*)m_rootFile->Get("FastSim/es2015/el_full_fast_resolution");
-      m_G4OverAFII_resolution_unconverted = (TH2F*)m_rootFile->Get("FastSim/es2015/ph_unconv_full_fast_resolution");
-      m_G4OverAFII_resolution_converted = (TH2F*)m_rootFile->Get("FastSim/es2015/ph_conv_full_fast_resolution");
+      m_G4OverAFII_resolution_electron.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/el_full_fast_resolution")));
+      m_G4OverAFII_resolution_unconverted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/ph_unconv_full_fast_resolution")));
+      m_G4OverAFII_resolution_converted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/ph_conv_full_fast_resolution")));
 
       assert(m_G4OverAFII_resolution_electron);
       assert(m_G4OverAFII_resolution_unconverted);
       assert(m_G4OverAFII_resolution_converted);
 
-      m_G4OverAFII_resolution_electron->SetDirectory(0);
-      m_G4OverAFII_resolution_unconverted->SetDirectory(0);
-      m_G4OverAFII_resolution_converted->SetDirectory(0);
+      m_G4OverAFII_resolution_electron->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_unconverted->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_converted->SetDirectory(nullptr);
 
       const std::string gain_filename1 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsTO.root");
       const std::string gain_filename2 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsG_all.root");
-      m_gain_tool = new egGain::GainTool(gain_filename1, gain_filename2);
+      m_gain_tool.reset(new egGain::GainTool(gain_filename1, gain_filename2));
 
-      m_e1hg_tool = new e1hg_systematics();
+      m_e1hg_tool.reset( new e1hg_systematics());
       m_use_temp_correction201215 = true;  // for eta > 2.5
       m_use_temp_correction201516 = false;
     }
@@ -716,267 +591,390 @@ namespace AtlasRoot {
     else if (m_esmodel == egEnergyCorr::es2016PRE) {
       m_use_etaCalo_scales = true;
       m_use_new_resolution_model = true;
-      m_resolution_tool = new eg_resolution("run2_pre");
+      m_resolution_tool.reset( new eg_resolution("run2_pre"));
 
-      m_aPSNom       = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaPS_uncor");                 m_aPSNom->SetDirectory(0);
-      m_daPSCor      = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaPS_cor");                  m_daPSCor->SetDirectory(0);
-      m_aS12Nom      = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaS12_uncor");                m_aS12Nom->SetDirectory(0);
-      m_daS12Cor     = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaS12_cor");                 m_daS12Cor->SetDirectory(0);
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaPS_uncor")));                 m_aPSNom->SetDirectory(nullptr);
+      m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaPS_cor")));                  m_daPSCor->SetDirectory(nullptr);
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaS12_uncor")));                m_aS12Nom->SetDirectory(nullptr);
+      m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaS12_cor")));                 m_daS12Cor->SetDirectory(nullptr);
 
-      m_trkSyst      = (TH1D*) m_rootFile->Get("Scales/es2012c/momentum_errSyst");              m_trkSyst->SetDirectory(0);
+      m_trkSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/momentum_errSyst")));              m_trkSyst->SetDirectory(nullptr);
 
-      m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2015Summer/alphaZee_errStat");         m_zeeNom->SetDirectory(0);
-      m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2015Summer/alphaZee_errSyst");         m_zeeSyst->SetDirectory(0);
-      m_uA2MeV_2015_first2weeks_correction = nullptr;
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015Summer/alphaZee_errStat")));         m_zeeNom->SetDirectory(nullptr);
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015Summer/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
 
-      m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2015Summer/ctZee_errStat");        m_resNom->SetDirectory(0);
-      m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2015Summer/ctZee_errSyst");        m_resSyst->SetDirectory(0);
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015Summer/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015Summer/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
 
-      m_pedestalL0   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l0");               m_pedestalL0->SetDirectory(0);
-      m_pedestalL1   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l1");               m_pedestalL1->SetDirectory(0);
-      m_pedestalL2   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l2");               m_pedestalL2->SetDirectory(0);
-      m_pedestalL3   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l3");               m_pedestalL3->SetDirectory(0);
+      m_pedestalL0.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l0")));               m_pedestalL0->SetDirectory(nullptr);
+      m_pedestalL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l1")));               m_pedestalL1->SetDirectory(nullptr);
+      m_pedestalL2.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l2")));               m_pedestalL2->SetDirectory(nullptr);
+      m_pedestalL3.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l3")));               m_pedestalL3->SetDirectory(nullptr);
 
-      m_dX_ID_Nom    = (TH1D*) m_rootFile->Get("Material/DX0_ConfigA");                         m_dX_ID_Nom->SetDirectory(0);
+      m_dX_ID_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/DX0_ConfigA")));                         m_dX_ID_Nom->SetDirectory(nullptr);
 
-      m_dX_IPPS_Nom  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor");   m_dX_IPPS_Nom->SetDirectory(0);
-      m_dX_IPPS_LAr  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr");     m_dX_IPPS_LAr->SetDirectory(0);
+      m_dX_IPPS_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor")));   m_dX_IPPS_Nom->SetDirectory(nullptr);
+      m_dX_IPPS_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr")));     m_dX_IPPS_LAr->SetDirectory(nullptr);
 
-      m_dX_IPAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor");  m_dX_IPAcc_Nom->SetDirectory(0);
-      m_dX_IPAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr");    m_dX_IPAcc_LAr->SetDirectory(0);
-      m_dX_IPAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4");     m_dX_IPAcc_G4->SetDirectory(0);
-      m_dX_IPAcc_GL1  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1");    m_dX_IPAcc_GL1->SetDirectory(0);
+      m_dX_IPAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor")));  m_dX_IPAcc_Nom->SetDirectory(nullptr);
+      m_dX_IPAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr")));    m_dX_IPAcc_LAr->SetDirectory(nullptr);
+      m_dX_IPAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4")));     m_dX_IPAcc_G4->SetDirectory(nullptr);
+      m_dX_IPAcc_GL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1")));    m_dX_IPAcc_GL1->SetDirectory(nullptr);
 
-      m_dX_PSAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor");  m_dX_PSAcc_Nom->SetDirectory(0);
-      m_dX_PSAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr");    m_dX_PSAcc_LAr->SetDirectory(0);
-      m_dX_PSAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4");     m_dX_PSAcc_G4->SetDirectory(0);
+      m_dX_PSAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor")));  m_dX_PSAcc_Nom->SetDirectory(nullptr);
+      m_dX_PSAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr")));    m_dX_PSAcc_LAr->SetDirectory(nullptr);
+      m_dX_PSAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4")));     m_dX_PSAcc_G4->SetDirectory(nullptr);
 
-      m_convRadius            = (TH2D*) m_rootFile->Get("Conversions/es2012c/convRadiusMigrations");  m_convRadius->SetDirectory(0);
-      m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2012c/convFakeRate");          m_convFakeRate->SetDirectory(0);
-      m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2012c/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);
+      m_convRadius.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRadiusMigrations")));  m_convRadius->SetDirectory(nullptr);
+      m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);
+      m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);
 
       m_begRunNumber = 195847;
       m_endRunNumber = 219365;
 
-      m_G4OverAFII_resolution_electron = (TH2F*)m_rootFile->Get("FastSim/es2015/el_full_fast_resolution");
-      m_G4OverAFII_resolution_unconverted = (TH2F*)m_rootFile->Get("FastSim/es2015/ph_unconv_full_fast_resolution");
-      m_G4OverAFII_resolution_converted = (TH2F*)m_rootFile->Get("FastSim/es2015/ph_conv_full_fast_resolution");
+      m_G4OverAFII_resolution_electron.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/el_full_fast_resolution")));
+      m_G4OverAFII_resolution_unconverted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/ph_unconv_full_fast_resolution")));
+      m_G4OverAFII_resolution_converted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2015/ph_conv_full_fast_resolution")));
 
       assert(m_G4OverAFII_resolution_electron);
       assert(m_G4OverAFII_resolution_unconverted);
       assert(m_G4OverAFII_resolution_converted);
 
-      m_G4OverAFII_resolution_electron->SetDirectory(0);
-      m_G4OverAFII_resolution_unconverted->SetDirectory(0);
-      m_G4OverAFII_resolution_converted->SetDirectory(0);
+      m_G4OverAFII_resolution_electron->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_unconverted->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_converted->SetDirectory(nullptr);
 
       const std::string gain_filename1 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsTO.root");
       const std::string gain_filename2 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsG_all.root");
-      m_gain_tool = new egGain::GainTool(gain_filename1, gain_filename2);
+      m_gain_tool.reset(new egGain::GainTool(gain_filename1, gain_filename2));
 
-      m_e1hg_tool = new e1hg_systematics();
+      m_e1hg_tool.reset( new e1hg_systematics());
       m_use_temp_correction201215 = true;  // for eta > 2.5
       m_use_temp_correction201516 = true;
     }
 
-    else if (m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE) {//add release 21 here for now
+    else if (m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved
+             or m_esmodel == egEnergyCorr::es2017_summer_final or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2017_R21_PRE
+             or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or  m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or  m_esmodel == egEnergyCorr::es2018_R21_v1) {//add release 21 here for now
       m_use_etaCalo_scales = true;
       m_use_new_resolution_model = true;
-      m_resolution_tool = new eg_resolution("run2_pre");
-
-      m_aPSNom       = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaPS_uncor");                 m_aPSNom->SetDirectory(0);
-      m_daPSCor      = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaPS_cor");                  m_daPSCor->SetDirectory(0);
-      m_aS12Nom      = (TH1D*) m_rootFile->Get("Scales/es2012c/alphaS12_uncor");                m_aS12Nom->SetDirectory(0);
-      m_daS12Cor     = (TH1D*) m_rootFile->Get("Scales/es2012c/dalphaS12_cor");                 m_daS12Cor->SetDirectory(0);
+      if (m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1)
+        m_resolution_tool.reset(new eg_resolution("run2_R21_v1"));
+      else
+        m_resolution_tool.reset(new eg_resolution("run2_pre"));
+
+      if(m_esmodel == egEnergyCorr::es2017_summer_final or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 ){
+        m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer_final/alphaPS_uncor")));       m_aPSNom->SetDirectory(nullptr);
+        m_daPSb12.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer_final/dalphaPS_b12")));        m_daPSb12->SetDirectory(nullptr);
+        m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaPS_cor")));                    m_daPSCor->SetDirectory(nullptr);
+        m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer_final/alphaS12_uncor")));      m_aS12Nom->SetDirectory(nullptr);
+        m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaS12_cor")));                   m_daS12Cor->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2018_R21_v1){
+        m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer_final/alphaPS_uncor")));       m_aPSNom->SetDirectory(nullptr);
+        m_daPSb12.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer_final/dalphaPS_b12")));        m_daPSb12->SetDirectory(nullptr);
+        m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaPS_cor")));                    m_daPSCor->SetDirectory(nullptr);
+        m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v1/alphaS12_uncor")));      m_aS12Nom->SetDirectory(nullptr);
+        m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaS12_cor")));                   m_daS12Cor->SetDirectory(nullptr);
+      }
+      else{
+        m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaPS_uncor")));                 m_aPSNom->SetDirectory(nullptr);
+        m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaPS_cor")));                  m_daPSCor->SetDirectory(nullptr);
+        m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/alphaS12_uncor")));                m_aS12Nom->SetDirectory(nullptr);
+        m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/dalphaS12_cor")));                 m_daS12Cor->SetDirectory(nullptr);
+      }
+      m_trkSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2012c/momentum_errSyst")));              m_trkSyst->SetDirectory(nullptr);
 
-      m_trkSyst      = (TH1D*) m_rootFile->Get("Scales/es2012c/momentum_errSyst");              m_trkSyst->SetDirectory(0);
-      
       if(m_esmodel == egEnergyCorr::es2017){
-      m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2017/alphaZee_errStat_period_2016");         m_zeeNom->SetDirectory(0);
-      m_zeeNom_data2015 = (TH1D*) m_rootFile->Get("Scales/es2017/alphaZee_errStat_period_2015");      m_zeeNom_data2015->SetDirectory(0);
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017/alphaZee_errStat_period_2016")));         m_zeeNom->SetDirectory(nullptr);
+        m_zeeNom_data2015.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017/alphaZee_errStat_period_2015")));      m_zeeNom_data2015->SetDirectory(nullptr);
       }
       else if(m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved){
-	m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2017_summer/alphaZee_errStat_period_2016");         m_zeeNom->SetDirectory(0); 
-	m_zeeNom_data2015 = (TH1D*) m_rootFile->Get("Scales/es2017_summer/alphaZee_errStat_period_2015");      m_zeeNom_data2015->SetDirectory(0);
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer/alphaZee_errStat_period_2016")));         m_zeeNom->SetDirectory(nullptr);
+        m_zeeNom_data2015.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer/alphaZee_errStat_period_2015")));      m_zeeNom_data2015->SetDirectory(nullptr);
+      }
+      else if(m_esmodel == egEnergyCorr::es2017_summer_final){
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer_final/alphaZee_errStat_period_2016")));         m_zeeNom->SetDirectory(nullptr);
+        m_zeeNom_data2015.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer_final/alphaZee_errStat_period_2015")));      m_zeeNom_data2015->SetDirectory(nullptr);
+      }
+      else if(m_esmodel == egEnergyCorr::es2015_5TeV){
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_5TeV/alphaZee_errStat_period_2015")));         m_zeeNom->SetDirectory(nullptr);
+        //Same histogram added twice for simplicity
+        m_zeeNom_data2015.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_5TeV/alphaZee_errStat_period_2015")));      m_zeeNom_data2015->SetDirectory(nullptr);
+      }
+      else if (m_esmodel==egEnergyCorr::es2017_R21_v0) {
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_v0/alphaZee_errStat_period_2017")));  m_zeeNom->SetDirectory(nullptr);
+        m_zeeNom_data2016.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_v0/alphaZee_errStat_period_2016")));  m_zeeNom_data2016->SetDirectory(nullptr);
+        m_zeeNom_data2015.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_v0/alphaZee_errStat_period_2015")));  m_zeeNom_data2015->SetDirectory(nullptr);
+      }
+      else if (m_esmodel==egEnergyCorr::es2017_R21_v1) {
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_v1/alphaZee_errStat_period_2017")));  m_zeeNom->SetDirectory(nullptr);
+        m_zeeNom_data2016.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_v1/alphaZee_errStat_period_2016")));  m_zeeNom_data2016->SetDirectory(nullptr);
+        m_zeeNom_data2015.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_v1/alphaZee_errStat_period_2015")));  m_zeeNom_data2015->SetDirectory(nullptr);
+        m_zeeFwdk.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_v1/alphaFwd_Finalk"))); m_zeeFwdk->SetDirectory(nullptr);
+        m_zeeFwdb.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_v1/alphaFwd_Finalb"))); m_zeeFwdb->SetDirectory(nullptr);
+      }
+      else if (m_esmodel==egEnergyCorr::es2017_R21_ofc0_v1) {
+        m_zeeNom.reset(dynamic_cast<TH1*> (m_rootFile->Get("Scales/es2017_R21_ofc0_v1/alphaZee_errStat_period_2017")));  m_zeeNom->SetDirectory(nullptr);
+        m_zeeNom_data2016.reset(dynamic_cast<TH1*> (m_rootFile->Get("Scales/es2017_R21_ofc0_v1/alphaZee_errStat_period_2016")));  m_zeeNom_data2016->SetDirectory(nullptr);
+        m_zeeNom_data2015.reset(dynamic_cast<TH1*> (m_rootFile->Get("Scales/es2017_R21_ofc0_v1/alphaZee_errStat_period_2015")));  m_zeeNom_data2015->SetDirectory(nullptr);
+        m_zeeNom_data2018.reset(dynamic_cast<TH1*> (m_rootFile->Get("Scales/es2017_R21_ofc0_v1/alphaZee_errStat_period_2018")));  m_zeeNom_data2018->SetDirectory(nullptr);
+        m_zeeFwdk.reset(dynamic_cast<TH1*> (m_rootFile->Get("Scales/es2017_R21_v1/alphaFwd_Finalk"))); m_zeeFwdk->SetDirectory(nullptr);
+        m_zeeFwdb.reset(dynamic_cast<TH1*> (m_rootFile->Get("Scales/es2017_R21_v1/alphaFwd_Finalb"))); m_zeeFwdb->SetDirectory(nullptr);
       }
+      else if (m_esmodel == egEnergyCorr::es2018_R21_v0){
+
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v0/alphaZee_errStat_period_2018")));  m_zeeNom->SetDirectory(nullptr);
+        m_zeeNom_data2017.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v0/alphaZee_errStat_period_2017")));  m_zeeNom_data2017->SetDirectory(nullptr);
+        m_zeeNom_data2016.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v0/alphaZee_errStat_period_2016")));  m_zeeNom_data2016->SetDirectory(nullptr);
+        m_zeeNom_data2015.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v0/alphaZee_errStat_period_2015")));  m_zeeNom_data2015->SetDirectory(nullptr);
+        m_zeeFwdk.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v0/alphaFwd_Finalk"))); m_zeeFwdk->SetDirectory(nullptr);
+        m_zeeFwdb.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v0/alphaFwd_Finalb"))); m_zeeFwdb->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2018_R21_v1) {
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v1/alphaZee_errStat_period_2018")));  m_zeeNom->SetDirectory(nullptr);
+        m_zeeNom_data2017.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v1/alphaZee_errStat_period_2017")));  m_zeeNom_data2017->SetDirectory(nullptr);
+        m_zeeNom_data2016.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v1/alphaZee_errStat_period_2016")));  m_zeeNom_data2016->SetDirectory(nullptr);
+        m_zeeNom_data2015.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v1/alphaZee_errStat_period_2015")));  m_zeeNom_data2015->SetDirectory(nullptr);
+        //same as in v0 model
+        m_zeeFwdk.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v0/alphaFwd_Finalk"))); m_zeeFwdk->SetDirectory(nullptr);
+        m_zeeFwdb.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v0/alphaFwd_Finalb"))); m_zeeFwdb->SetDirectory(nullptr);
+       }
+
+
       else{
-	m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2017_R21_PRE/alphaZee_errStat_period_2016");         m_zeeNom->SetDirectory(0);  
+        m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_PRE/alphaZee_errStat_period_2016")));         m_zeeNom->SetDirectory(nullptr);
         //SAME HISTO FOR 2015 FOR NOW
-	m_zeeNom_data2015 = (TH1D*) m_rootFile->Get("Scales/es2017_R21_PRE/alphaZee_errStat_period_2016");      m_zeeNom_data2015->SetDirectory(0);
+        m_zeeNom_data2015.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_PRE/alphaZee_errStat_period_2016")));      m_zeeNom_data2015->SetDirectory(nullptr);
       }
       if(m_esmodel == egEnergyCorr::es2017){
-	m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2017/alphaZee_errSyst");         m_zeeSyst->SetDirectory(0);
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
+      }
+      else if(m_esmodel == egEnergyCorr::es2017_summer_final){
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer_final/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
+      }
+      else if(m_esmodel == egEnergyCorr::es2015_5TeV){
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_5TeV/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2017_R21_v0) {
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer_final/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2017_R21_v1) {
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_v1/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1) {
+         m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_R21_ofc0_v1/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2018_R21_v0) {
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v0/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2018_R21_v1) {
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2018_R21_v1/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
       }
-      //else if(m_esmodel == egEnergyCorr::es2017_summer_improved){
-      //m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2017_summer_improved/alphaZee_errSyst");         m_zeeSyst->SetDirectory(0);
-      //}
       else{
-	m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2017_summer/alphaZee_errSyst");         m_zeeSyst->SetDirectory(0);
+        m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2017_summer/alphaZee_errSyst")));         m_zeeSyst->SetDirectory(nullptr);
       }
-      
+
       m_uA2MeV_2015_first2weeks_correction = nullptr;
       if(m_esmodel == egEnergyCorr::es2017){
-	m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2017/ctZee_errStat");        m_resNom->SetDirectory(0);
-      }
-      else if(m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved){
-	m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2017_summer/ctZee_errStat");        m_resNom->SetDirectory(0);
-      }
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);}
+      else if(m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2015_5TeV){
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_summer/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);}
+      else if(m_esmodel == egEnergyCorr::es2017_summer_final) {
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_summer_final/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);}
+      else if (m_esmodel==egEnergyCorr::es2017_R21_v0) {
+         m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_R21_v0/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);}
+      else if (m_esmodel==egEnergyCorr::es2017_R21_v1) {
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_R21_v1/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);}
+      else if (m_esmodel==egEnergyCorr::es2017_R21_ofc0_v1) {
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_R21_ofc0_v1/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);}
+      else if (m_esmodel==egEnergyCorr::es2018_R21_v0) {
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2018_R21_v0/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);}
+      else if (m_esmodel==egEnergyCorr::es2018_R21_v1) {
+         m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2018_R21_v1/ctZee_errStat")));        m_resNom->SetDirectory(nullptr); }
       else{
-	m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2017_R21_PRE/ctZee_errStat");        m_resNom->SetDirectory(0); 
+        m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_R21_PRE/ctZee_errStat")));        m_resNom->SetDirectory(nullptr);
       }
+
       if(m_esmodel == egEnergyCorr::es2017){
-	m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2017/ctZee_errSyst");        m_resSyst->SetDirectory(0);
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
+      }
+      else if(m_esmodel == egEnergyCorr::es2017_summer_final){
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_summer_final/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
+      }
+      else if(m_esmodel == egEnergyCorr::es2015_5TeV){
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2015_5TeV/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
       }
-      else{ 
-	m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2017_summer/ctZee_errSyst");        m_resSyst->SetDirectory(0);
+      else if (m_esmodel == egEnergyCorr::es2017_R21_v0) {
+         m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_summer_final/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2017_R21_v1) {
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_R21_v1/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1) {
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_R21_ofc0_v1/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2018_R21_v0) {
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2018_R21_v0/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
+      }
+      else if (m_esmodel == egEnergyCorr::es2018_R21_v1) {
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2018_R21_v1/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
+      }
+      else{
+        m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_summer/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
       }
       //else{
-      //m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2017_summer_improved/ctZee_errSyst");        m_resSyst->SetDirectory(0);
+      //m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2017_summer_improved/ctZee_errSyst")));        m_resSyst->SetDirectory(nullptr);
       //}
-      
-      m_pedestals_es2017 = get_object<TH1F>(*m_rootFile, "Pedestals/es2017/pedestals");          m_pedestals_es2017->SetDirectory(0);
 
-      m_dX_ID_Nom    = (TH1D*) m_rootFile->Get("Material/DX0_ConfigA");                         m_dX_ID_Nom->SetDirectory(0);
+      m_pedestals_es2017.reset( dynamic_cast< TH1* >(m_rootFile->Get("Pedestals/es2017/pedestals")));          m_pedestals_es2017->SetDirectory(nullptr);
+
+      m_dX_ID_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/DX0_ConfigA")));                         m_dX_ID_Nom->SetDirectory(nullptr);
 
-      m_dX_IPPS_Nom  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor");   m_dX_IPPS_Nom->SetDirectory(0);
-      m_dX_IPPS_LAr  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr");     m_dX_IPPS_LAr->SetDirectory(0);
+      m_dX_IPPS_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor")));   m_dX_IPPS_Nom->SetDirectory(nullptr);
+      m_dX_IPPS_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr")));     m_dX_IPPS_LAr->SetDirectory(nullptr);
 
-      m_dX_IPAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor");  m_dX_IPAcc_Nom->SetDirectory(0);
-      m_dX_IPAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr");    m_dX_IPAcc_LAr->SetDirectory(0);
-      m_dX_IPAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4");     m_dX_IPAcc_G4->SetDirectory(0);
-      m_dX_IPAcc_GL1  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1");    m_dX_IPAcc_GL1->SetDirectory(0);
+      m_dX_IPAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor")));  m_dX_IPAcc_Nom->SetDirectory(nullptr);
+      m_dX_IPAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr")));    m_dX_IPAcc_LAr->SetDirectory(nullptr);
+      m_dX_IPAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4")));     m_dX_IPAcc_G4->SetDirectory(nullptr);
+      m_dX_IPAcc_GL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1")));    m_dX_IPAcc_GL1->SetDirectory(nullptr);
 
-      m_dX_PSAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor");  m_dX_PSAcc_Nom->SetDirectory(0);
-      m_dX_PSAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr");    m_dX_PSAcc_LAr->SetDirectory(0);
-      m_dX_PSAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4");     m_dX_PSAcc_G4->SetDirectory(0);
+      m_dX_PSAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor")));  m_dX_PSAcc_Nom->SetDirectory(nullptr);
+      m_dX_PSAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr")));    m_dX_PSAcc_LAr->SetDirectory(nullptr);
+      m_dX_PSAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4")));     m_dX_PSAcc_G4->SetDirectory(nullptr);
 
-      m_convRadius            = (TH2D*) m_rootFile->Get("Conversions/es2012c/convRadiusMigrations");  m_convRadius->SetDirectory(0);
+      m_convRadius.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRadiusMigrations")));  m_convRadius->SetDirectory(nullptr);
       if(m_esmodel == egEnergyCorr::es2017){
-	m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2012c/convFakeRate");          m_convFakeRate->SetDirectory(0);
-	m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2012c/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);
+	m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);
+	m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);
       }
       else{
-	m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2017_summer/convFakeRate");          m_convFakeRate->SetDirectory(0); 
-        m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2017_summer/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);
+	m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2017_summer/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);
+        m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2017_summer/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);
       }
-      
+
       // TODO: change path when moving to calibarea
       // TODO: better package this somewhere
 
       const std::string filename_pp0 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/PP0sys.root");
-      
+
       TFile file_pp0(filename_pp0.c_str());
-      m_pp0_elec = get_object<TH2D>(file_pp0, "elec");
-      m_pp0_conv = get_object<TH2D>(file_pp0, "conv");
-      m_pp0_unconv = get_object<TH2D>(file_pp0, "unco");
+      m_pp0_elec.reset( dynamic_cast< TH2* >( file_pp0.Get("elec")));
+      m_pp0_conv.reset( dynamic_cast< TH2* >( file_pp0.Get("conv")));
+      m_pp0_unconv.reset( dynamic_cast< TH2* >( file_pp0.Get("unco")));
 
-      m_pp0_elec->SetDirectory(0);
-      m_pp0_unconv->SetDirectory(0);
-      m_pp0_conv->SetDirectory(0);
+      m_pp0_elec->SetDirectory(nullptr);
+      m_pp0_unconv->SetDirectory(nullptr);
+      m_pp0_conv->SetDirectory(nullptr);
 
       //similar case for wtots1
       const std::string filename_wstot = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/wstot_related_syst.root");
-      
+
 
       TFile file_wstot(filename_wstot.c_str());
-      m_wstot_slope_A_data = (TH1D*) file_wstot.Get("A_data"); m_wstot_slope_A_data->SetDirectory(0);
-      m_wstot_slope_B_MC = (TH1D*) file_wstot.Get("B_mc"); m_wstot_slope_B_MC->SetDirectory(0);
-      m_wstot_40GeV_data = (TH1D*) file_wstot.Get("wstot40_data"); m_wstot_40GeV_data->SetDirectory(0);
-      m_wstot_40GeV_MC = (TH1D*) file_wstot.Get("wstot40_mc"); m_wstot_40GeV_MC->SetDirectory(0);
-      m_wstot_pT_data_p0_electrons = (TH1D*) file_wstot.Get("wstot_pT_el_data_p0"); m_wstot_pT_data_p0_electrons->SetDirectory(0);
-      m_wstot_pT_data_p1_electrons = (TH1D*) file_wstot.Get("wstot_pT_el_data_p1"); m_wstot_pT_data_p1_electrons->SetDirectory(0);
-      m_wstot_pT_data_p0_unconverted_photons = (TH1D*) file_wstot.Get("wstot_pT_uc_data_p0"); m_wstot_pT_data_p0_unconverted_photons->SetDirectory(0);
-      m_wstot_pT_data_p1_unconverted_photons = (TH1D*) file_wstot.Get("wstot_pT_uc_data_p1"); m_wstot_pT_data_p1_unconverted_photons->SetDirectory(0);
-      m_wstot_pT_data_p0_converted_photons = (TH1D*) file_wstot.Get("wstot_pT_c_data_p0"); m_wstot_pT_data_p0_converted_photons->SetDirectory(0);
-      m_wstot_pT_data_p1_converted_photons = (TH1D*) file_wstot.Get("wstot_pT_c_data_p1"); m_wstot_pT_data_p1_converted_photons->SetDirectory(0);
-      m_wstot_pT_MC_p0_electrons = (TH1D*) file_wstot.Get("wstot_pT_el_mc_p0"); m_wstot_pT_MC_p0_electrons->SetDirectory(0);
-      m_wstot_pT_MC_p1_electrons = (TH1D*) file_wstot.Get("wstot_pT_el_mc_p1"); m_wstot_pT_MC_p1_electrons->SetDirectory(0);
-      m_wstot_pT_MC_p0_unconverted_photons = (TH1D*) file_wstot.Get("wstot_pT_ph_uc_mc_p0"); m_wstot_pT_MC_p0_unconverted_photons->SetDirectory(0);
-      m_wstot_pT_MC_p1_unconverted_photons = (TH1D*) file_wstot.Get("wstot_pT_ph_uc_mc_p1"); m_wstot_pT_MC_p1_unconverted_photons->SetDirectory(0);
-      m_wstot_pT_MC_p0_converted_photons = (TH1D*) file_wstot.Get("wstot_pT_ph_c_mc_p0"); m_wstot_pT_MC_p0_converted_photons->SetDirectory(0);
-      m_wstot_pT_MC_p1_converted_photons = (TH1D*) file_wstot.Get("wstot_pT_ph_c_mc_p1"); m_wstot_pT_MC_p1_converted_photons->SetDirectory(0);
+      m_wstot_slope_A_data.reset(  dynamic_cast< TH1* >( file_wstot.Get("A_data"))); m_wstot_slope_A_data->SetDirectory(nullptr);
+      m_wstot_slope_B_MC.reset(  dynamic_cast< TH1* >( file_wstot.Get("B_mc"))); m_wstot_slope_B_MC->SetDirectory(nullptr);
+      m_wstot_pT_data_p0_electrons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_el_data_p0"))); m_wstot_pT_data_p0_electrons->SetDirectory(nullptr);
+      m_wstot_pT_data_p1_electrons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_el_data_p1"))); m_wstot_pT_data_p1_electrons->SetDirectory(nullptr);
+      m_wstot_pT_data_p0_unconverted_photons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_uc_data_p0"))); m_wstot_pT_data_p0_unconverted_photons->SetDirectory(nullptr);
+      m_wstot_pT_data_p1_unconverted_photons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_uc_data_p1"))); m_wstot_pT_data_p1_unconverted_photons->SetDirectory(nullptr);
+      m_wstot_pT_data_p0_converted_photons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_c_data_p0"))); m_wstot_pT_data_p0_converted_photons->SetDirectory(nullptr);
+      m_wstot_pT_data_p1_converted_photons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_c_data_p1"))); m_wstot_pT_data_p1_converted_photons->SetDirectory(nullptr);
+      m_wstot_pT_MC_p0_electrons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_el_mc_p0"))); m_wstot_pT_MC_p0_electrons->SetDirectory(nullptr);
+      m_wstot_pT_MC_p1_electrons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_el_mc_p1"))); m_wstot_pT_MC_p1_electrons->SetDirectory(nullptr);
+      m_wstot_pT_MC_p0_unconverted_photons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_ph_uc_mc_p0"))); m_wstot_pT_MC_p0_unconverted_photons->SetDirectory(nullptr);
+      m_wstot_pT_MC_p1_unconverted_photons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_ph_uc_mc_p1"))); m_wstot_pT_MC_p1_unconverted_photons->SetDirectory(nullptr);
+      m_wstot_pT_MC_p0_converted_photons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_ph_c_mc_p0"))); m_wstot_pT_MC_p0_converted_photons->SetDirectory(nullptr);
+      m_wstot_pT_MC_p1_converted_photons.reset(  dynamic_cast< TH1* >( file_wstot.Get("wstot_pT_ph_c_mc_p1"))); m_wstot_pT_MC_p1_converted_photons->SetDirectory(nullptr);
 
       m_begRunNumber = 252604;
       m_endRunNumber = 314199;
 
-      m_G4OverAFII_resolution_electron = (TH2F*)m_rootFile->Get("FastSim/es2017/el_full_fast_resolution");
-      m_G4OverAFII_resolution_unconverted = (TH2F*)m_rootFile->Get("FastSim/es2017/ph_unconv_full_fast_resolution");
-      m_G4OverAFII_resolution_converted = (TH2F*)m_rootFile->Get("FastSim/es2017/ph_conv_full_fast_resolution");
-
+      if (m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) {
+         m_G4OverAFII_resolution_electron.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2017_v1/resol_Af2ToG4_elec_rel21")));
+         m_G4OverAFII_resolution_unconverted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2017_v1/resol_Af2ToG4_unco_rel21")));
+         m_G4OverAFII_resolution_converted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2017_v1/resol_Af2ToG4_conv_rel21")));
+      }
+      else {
+        m_G4OverAFII_resolution_electron.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2017/el_full_fast_resolution")));
+        m_G4OverAFII_resolution_unconverted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2017/ph_unconv_full_fast_resolution")));
+        m_G4OverAFII_resolution_converted.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2017/ph_conv_full_fast_resolution")));
+      }
       assert(m_G4OverAFII_resolution_electron);
       assert(m_G4OverAFII_resolution_unconverted);
       assert(m_G4OverAFII_resolution_converted);
 
-      m_G4OverAFII_resolution_electron->SetDirectory(0);
-      m_G4OverAFII_resolution_unconverted->SetDirectory(0);
-      m_G4OverAFII_resolution_converted->SetDirectory(0);
+      m_G4OverAFII_resolution_electron->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_unconverted->SetDirectory(nullptr);
+      m_G4OverAFII_resolution_converted->SetDirectory(nullptr);
 
       const std::string gain_filename1 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsTO.root");
       const std::string gain_filename2 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsG_all.root");
       m_gain_tool = nullptr;
 
       std::string gain_tool_run_2_filename;
-      if(m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_R21_PRE){
-	gain_tool_run_2_filename = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v11/gain_uncertainty_specialRun.root"); 
+      if(m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer
+         or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV ){
+        gain_tool_run_2_filename = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v11/gain_uncertainty_specialRun.root");
       }
       else{
-	gain_tool_run_2_filename = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v12/gain_uncertainty_specialRun.root");
+        gain_tool_run_2_filename = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v14/gain_uncertainty_specialRun.root");
       }
-      m_gain_tool_run2 = new egGain::GainUncertainty(gain_tool_run_2_filename);
-      
-      m_e1hg_tool = new e1hg_systematics();
+      m_gain_tool_run2.reset( new egGain::GainUncertainty(gain_tool_run_2_filename));
+
+      m_e1hg_tool.reset( new e1hg_systematics());
       m_use_temp_correction201215 = false;
       m_use_temp_correction201516 = false;
     }
 
     else if ( m_esmodel==egEnergyCorr::es2015_day0_3percent ) {
       m_use_new_resolution_model = true;
-      m_resolution_tool = new eg_resolution("run2_pre");
+      m_resolution_tool.reset(new eg_resolution("run2_pre"));
 
-      m_aPSNom       = (TH1D*) m_rootFile->Get("Scales/es2015_day0/alphaPS_uncor");             m_aPSNom->SetDirectory(0);         // old one
-      m_daPSCor      = (TH1D*) m_rootFile->Get("Scales/es2015_day0/dalphaPS_cor");              m_daPSCor->SetDirectory(0);        // old one
-      m_aS12Nom      = (TH1D*) m_rootFile->Get("Scales/es2015_day0/alphaS12_uncor");            m_aS12Nom->SetDirectory(0);        // old one
-      m_daS12Cor     = (TH1D*) m_rootFile->Get("Scales/es2015_day0/dalphaS12_cor");             m_daS12Cor->SetDirectory(0);       // old one
+      m_aPSNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_day0/alphaPS_uncor")));             m_aPSNom->SetDirectory(nullptr);         // old one
+      m_daPSCor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_day0/dalphaPS_cor")));              m_daPSCor->SetDirectory(nullptr);        // old one
+      m_aS12Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_day0/alphaS12_uncor")));            m_aS12Nom->SetDirectory(nullptr);        // old one
+      m_daS12Cor.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_day0/dalphaS12_cor")));             m_daS12Cor->SetDirectory(nullptr);       // old one
 
-      m_trkSyst      = (TH1D*) m_rootFile->Get("Scales/es2015_day0/momentum_errSyst");          m_trkSyst->SetDirectory(0);        // old one
+      m_trkSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_day0/momentum_errSyst")));          m_trkSyst->SetDirectory(nullptr);        // old one
 
-      m_zeeNom       = (TH1D*) m_rootFile->Get("Scales/es2015_day0/alphaZee_errStat");          m_zeeNom->SetDirectory(0);         // old one
-      m_zeeSyst      = (TH1D*) m_rootFile->Get("Scales/es2015_day0/alphaZee_errSyst");          m_zeeSyst->SetDirectory(0);        // old one
+      m_zeeNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_day0/alphaZee_errStat")));          m_zeeNom->SetDirectory(nullptr);         // old one
+      m_zeeSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Scales/es2015_day0/alphaZee_errSyst")));          m_zeeSyst->SetDirectory(nullptr);        // old one
 
-      m_resNom       = (TH1D*) m_rootFile->Get("Resolution/es2012c/ctZee_errStat");             m_resNom->SetDirectory(0);         // old one
-      m_resSyst      = (TH1D*) m_rootFile->Get("Resolution/es2012c/ctZee_errSyst");             m_resSyst->SetDirectory(0);        // old one
+      m_resNom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2012c/ctZee_errStat")));             m_resNom->SetDirectory(nullptr);         // old one
+      m_resSyst.reset( dynamic_cast< TH1* >( m_rootFile->Get("Resolution/es2012c/ctZee_errSyst")));             m_resSyst->SetDirectory(nullptr);        // old one
 
-      m_pedestalL0   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l0");               m_pedestalL0->SetDirectory(0);     // old one
-      m_pedestalL1   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l1");               m_pedestalL1->SetDirectory(0);     // old one
-      m_pedestalL2   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l2");               m_pedestalL2->SetDirectory(0);     // old one
-      m_pedestalL3   = (TH1D*) m_rootFile->Get("Pedestals/es2012c/pedestals_l3");               m_pedestalL3->SetDirectory(0);     // old one
+      m_pedestalL0.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l0")));               m_pedestalL0->SetDirectory(nullptr);     // old one
+      m_pedestalL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l1")));               m_pedestalL1->SetDirectory(nullptr);     // old one
+      m_pedestalL2.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l2")));               m_pedestalL2->SetDirectory(nullptr);     // old one
+      m_pedestalL3.reset( dynamic_cast< TH1* >( m_rootFile->Get("Pedestals/es2012c/pedestals_l3")));               m_pedestalL3->SetDirectory(nullptr);     // old one
 
-      m_dX_ID_Nom    = (TH1D*) m_rootFile->Get("Material/DX0_ConfigA");                         m_dX_ID_Nom->SetDirectory(0);      // old one
+      m_dX_ID_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/DX0_ConfigA")));                         m_dX_ID_Nom->SetDirectory(nullptr);      // old one
 
-      m_dX_IPPS_Nom  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor");   m_dX_IPPS_Nom->SetDirectory(0);    // old one
-      m_dX_IPPS_LAr  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr");     m_dX_IPPS_LAr->SetDirectory(0);    // old one
+      m_dX_IPPS_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errUncor")));   m_dX_IPPS_Nom->SetDirectory(nullptr);    // old one
+      m_dX_IPPS_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPPS_NewG_errLAr")));     m_dX_IPPS_LAr->SetDirectory(nullptr);    // old one
 
-      m_dX_IPAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor");  m_dX_IPAcc_Nom->SetDirectory(0);   // old one
-      m_dX_IPAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr");    m_dX_IPAcc_LAr->SetDirectory(0);   // old one
-      m_dX_IPAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4");     m_dX_IPAcc_G4->SetDirectory(0);    // old one
-      m_dX_IPAcc_GL1  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1");    m_dX_IPAcc_GL1->SetDirectory(0);  // old one
+      m_dX_IPAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errUncor")));  m_dX_IPAcc_Nom->SetDirectory(nullptr);   // old one
+      m_dX_IPAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errLAr")));    m_dX_IPAcc_LAr->SetDirectory(nullptr);   // old one
+      m_dX_IPAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errG4")));     m_dX_IPAcc_G4->SetDirectory(nullptr);    // old one
+      m_dX_IPAcc_GL1.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_IPAcc_NewG_errGL1")));    m_dX_IPAcc_GL1->SetDirectory(nullptr);  // old one
 
-      m_dX_PSAcc_Nom = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor");  m_dX_PSAcc_Nom->SetDirectory(0);   // old one
-      m_dX_PSAcc_LAr = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr");    m_dX_PSAcc_LAr->SetDirectory(0);   // old one
-      m_dX_PSAcc_G4  = (TH1D*) m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4");     m_dX_PSAcc_G4->SetDirectory(0);    // old one
+      m_dX_PSAcc_Nom.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errUncor")));  m_dX_PSAcc_Nom->SetDirectory(nullptr);   // old one
+      m_dX_PSAcc_LAr.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errLAr")));    m_dX_PSAcc_LAr->SetDirectory(nullptr);   // old one
+      m_dX_PSAcc_G4.reset( dynamic_cast< TH1* >( m_rootFile->Get("Material/Measured/DXerr_PSAcc_NewG_errG4")));     m_dX_PSAcc_G4->SetDirectory(nullptr);    // old one
 
-      m_convRadius            = (TH2D*) m_rootFile->Get("Conversions/es2012c/convRadiusMigrations");  m_convRadius->SetDirectory(0);          // old one
-      m_convFakeRate          = (TH1D*) m_rootFile->Get("Conversions/es2012c/convFakeRate");          m_convFakeRate->SetDirectory(0);        // old one
-      m_convRecoEfficiency    = (TH1D*) m_rootFile->Get("Conversions/es2012c/convRecoEfficiency");    m_convRecoEfficiency->SetDirectory(0);  // old one
+      m_convRadius.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRadiusMigrations")));  m_convRadius->SetDirectory(nullptr);          // old one
+      m_convFakeRate.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convFakeRate")));          m_convFakeRate->SetDirectory(nullptr);        // old one
+      m_convRecoEfficiency.reset( dynamic_cast< TH1* >( m_rootFile->Get("Conversions/es2012c/convRecoEfficiency")));    m_convRecoEfficiency->SetDirectory(nullptr);  // old one
 
       m_begRunNumber = 195847;
       m_endRunNumber = 219365;
 
       const std::string gain_filename1 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsTO.root");
       const std::string gain_filename2 = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/FunctionsG_all.root");
-      m_gain_tool = new egGain::GainTool(gain_filename1, gain_filename2);
+      m_gain_tool.reset( new egGain::GainTool(gain_filename1, gain_filename2));
 
-      m_e1hg_tool = new e1hg_systematics();
+      m_e1hg_tool.reset( new e1hg_systematics());
 
 
       // If we are here, fail      :
@@ -992,89 +990,162 @@ namespace AtlasRoot {
 
     if (m_esmodel == egEnergyCorr::es2015cPRE or m_esmodel == egEnergyCorr::es2015cPRE_res_improved or
         m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE or m_esmodel == egEnergyCorr::es2017
-	or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE)
+	or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final
+        or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1  or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1
+	or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2018_R21_v0 or  m_esmodel == egEnergyCorr::es2018_R21_v1)
     {
       // E4 systematics
-      m_E4ElectronEtaBins = get_object<TAxis>(*m_rootFile, "E4Recalibration/v4/electron_eta_axis");
-      m_E4ElectronGraphs = get_object<TList>(*m_rootFile, "E4Recalibration/v4/electron");
+      m_E4ElectronEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("E4Recalibration/v4/electron_eta_axis")));
+      m_E4ElectronGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("E4Recalibration/v4/electron")));m_E4ElectronGraphs->SetOwner();
       // for photons use the same as electrons
-      m_E4UnconvertedEtaBins = get_object<TAxis>(*m_rootFile, "E4Recalibration/v4/electron_eta_axis");
-      m_E4UnconvertedGraphs = get_object<TList>(*m_rootFile, "E4Recalibration/v4/electron");
-      m_E4ConvertedEtaBins = get_object<TAxis>(*m_rootFile, "E4Recalibration/v4/electron_eta_axis");
-      m_E4ConvertedGraphs = get_object<TList>(*m_rootFile, "E4Recalibration/v4/electron");
+      m_E4UnconvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("E4Recalibration/v4/electron_eta_axis")));
+      m_E4UnconvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("E4Recalibration/v4/electron")));m_E4UnconvertedGraphs->SetOwner();
+      m_E4ConvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("E4Recalibration/v4/electron_eta_axis")));
+      m_E4ConvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("E4Recalibration/v4/electron")));m_E4ConvertedGraphs->SetOwner();
     }
 
     // ... PS and S12 recalibration curves
     if (m_esmodel == egEnergyCorr::es2015PRE or m_esmodel == egEnergyCorr::es2015PRE_res_improved or
         m_esmodel == egEnergyCorr::es2015cPRE or m_esmodel == egEnergyCorr::es2015cPRE_res_improved or
         m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE or m_esmodel == egEnergyCorr::es2017
-	or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE) {
-
-      m_psElectronEtaBins =          get_object<TAxis>(*m_rootFile, "PSRecalibration/es2015PRE/ElectronAxis");
-      m_psElectronGraphs =           get_object<TList>(*m_rootFile, "PSRecalibration/es2015PRE/ElectronBiasPS");
-      m_psUnconvertedEtaBins =       get_object<TAxis>(*m_rootFile, "PSRecalibration/es2015PRE/UnconvertedAxis");
-      m_psUnconvertedGraphs =        get_object<TList>(*m_rootFile, "PSRecalibration/es2015PRE/UnconvertedBiasPS");
-      m_psConvertedEtaBins =         get_object<TAxis>(*m_rootFile, "PSRecalibration/es2015PRE/ConvertedAxis");
-      m_psConvertedGraphs =          get_object<TList>(*m_rootFile, "PSRecalibration/es2015PRE/ConvertedBiasPS");
-
-      m_s12ElectronEtaBins =         get_object<TAxis>(*m_rootFile, "S1Recalibration/es2015PRE/ElectronAxis");
-      m_s12ElectronGraphs =          get_object<TList>(*m_rootFile, "S1Recalibration/es2015PRE/ElectronBiasS1");
-      m_s12UnconvertedEtaBins =      get_object<TAxis>(*m_rootFile, "S1Recalibration/es2015PRE/UnconvertedAxis");
-      m_s12UnconvertedGraphs =       get_object<TList>(*m_rootFile, "S1Recalibration/es2015PRE/UnconvertedBiasS1");
-      m_s12ConvertedEtaBins =        get_object<TAxis>(*m_rootFile, "S1Recalibration/es2015PRE/ConvertedAxis");
-      m_s12ConvertedGraphs =         get_object<TList>(*m_rootFile, "S1Recalibration/es2015PRE/ConvertedBiasS1");
+	or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final
+        or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1
+	or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2018_R21_v0 or m_esmodel == egEnergyCorr::es2018_R21_v1) {
+
+      m_psElectronEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("PSRecalibration/es2015PRE/ElectronAxis")));
+      m_psElectronGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("PSRecalibration/es2015PRE/ElectronBiasPS")));m_psElectronGraphs->SetOwner();
+      m_psUnconvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("PSRecalibration/es2015PRE/UnconvertedAxis")));
+      m_psUnconvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("PSRecalibration/es2015PRE/UnconvertedBiasPS")));m_psUnconvertedGraphs->SetOwner();
+      m_psConvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("PSRecalibration/es2015PRE/ConvertedAxis")));
+      m_psConvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("PSRecalibration/es2015PRE/ConvertedBiasPS")));m_psConvertedGraphs->SetOwner();
+
+      m_s12ElectronEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("S1Recalibration/es2015PRE/ElectronAxis")));
+      m_s12ElectronGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("S1Recalibration/es2015PRE/ElectronBiasS1")));m_s12ElectronGraphs->SetOwner();
+      m_s12UnconvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("S1Recalibration/es2015PRE/UnconvertedAxis")));
+      m_s12UnconvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("S1Recalibration/es2015PRE/UnconvertedBiasS1")));m_s12UnconvertedGraphs->SetOwner();
+      m_s12ConvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("S1Recalibration/es2015PRE/ConvertedAxis")));
+      m_s12ConvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("S1Recalibration/es2015PRE/ConvertedBiasS1")));m_s12ConvertedGraphs->SetOwner();
     }
     else // run1
     {
-      m_psElectronEtaBins =          (TAxis*) m_rootFile->Get("PSRecalibration/ElectronAxis");
-      m_psElectronGraphs =           (TList*) m_rootFile->Get("PSRecalibration/ElectronBiasPS");
-      m_psUnconvertedEtaBins =       (TAxis*) m_rootFile->Get("PSRecalibration/UnconvertedAxis");
-      m_psUnconvertedGraphs =        (TList*) m_rootFile->Get("PSRecalibration/UnconvertedBiasPS");
-      m_psConvertedEtaBins =         (TAxis*) m_rootFile->Get("PSRecalibration/ConvertedAxis");
-      m_psConvertedGraphs =          (TList*) m_rootFile->Get("PSRecalibration/ConvertedBiasPS");
+      m_psElectronEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("PSRecalibration/ElectronAxis")));
+      m_psElectronGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("PSRecalibration/ElectronBiasPS")));m_psElectronGraphs->SetOwner();
+      m_psUnconvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("PSRecalibration/UnconvertedAxis")));
+      m_psUnconvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("PSRecalibration/UnconvertedBiasPS")));m_psUnconvertedGraphs->SetOwner();
+      m_psConvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("PSRecalibration/ConvertedAxis")));
+      m_psConvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("PSRecalibration/ConvertedBiasPS")));m_psConvertedGraphs->SetOwner();
 
-      m_s12ElectronEtaBins =         (TAxis*) m_rootFile->Get("S1Recalibration/ElectronAxis");
-      m_s12ElectronGraphs =          (TList*) m_rootFile->Get("S1Recalibration/ElectronBiasS1");
-      m_s12UnconvertedEtaBins =      (TAxis*) m_rootFile->Get("S1Recalibration/UnconvertedAxis");
-      m_s12UnconvertedGraphs =       (TList*) m_rootFile->Get("S1Recalibration/UnconvertedBiasS1");
-      m_s12ConvertedEtaBins =        (TAxis*) m_rootFile->Get("S1Recalibration/ConvertedAxis");
-      m_s12ConvertedGraphs =         (TList*) m_rootFile->Get("S1Recalibration/ConvertedBiasS1");
+      m_s12ElectronEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("S1Recalibration/ElectronAxis")));
+      m_s12ElectronGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("S1Recalibration/ElectronBiasS1")));m_s12ElectronGraphs->SetOwner();
+      m_s12UnconvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("S1Recalibration/UnconvertedAxis")));
+      m_s12UnconvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("S1Recalibration/UnconvertedBiasS1")));m_s12UnconvertedGraphs->SetOwner();
+      m_s12ConvertedEtaBins.reset( dynamic_cast< TAxis* >( m_rootFile->Get("S1Recalibration/ConvertedAxis")));
+      m_s12ConvertedGraphs.reset( dynamic_cast< TList* >( m_rootFile->Get("S1Recalibration/ConvertedBiasS1")));m_s12ConvertedGraphs->SetOwner();
     }
 
     // further inputs do not depend on year
 
     // ... material distortions
 
-    m_matUnconvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigA") );
-    m_matUnconvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigCpDp") );
-    m_matUnconvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigEpLp") );
-    m_matUnconvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigFpMX") );
-    m_matUnconvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigGp") );
-
-    m_matConvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigA") );
-    m_matConvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigCpDp") );
-    m_matConvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigEpLp") );
-    m_matConvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigFpMX") );
-    m_matConvertedScale.push_back( (TH1D*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigGp") );
-
-    m_matElectronCstTerm.push_back( (TH1F*) m_rootFile->Get("Material/electronCstTerm_ConfigA") );
-    m_matElectronCstTerm.push_back( (TH1F*) m_rootFile->Get("Material/electronCstTerm_ConfigCpDp") );
-    m_matElectronCstTerm.push_back( (TH1F*) m_rootFile->Get("Material/electronCstTerm_ConfigEpLp") );
-    m_matElectronCstTerm.push_back( (TH1F*) m_rootFile->Get("Material/electronCstTerm_ConfigFpMX") );
-    m_matElectronCstTerm.push_back( (TH1F*) m_rootFile->Get("Material/electronCstTerm_ConfigGp") );
-
-    m_matX0Additions.push_back( (TH1D*) m_rootFile->Get("Material/DX0_ConfigA") );
-    m_matX0Additions.push_back( (TH1D*) m_rootFile->Get("Material/DX0_ConfigCpDp") );
-    m_matX0Additions.push_back( (TH1D*) m_rootFile->Get("Material/DX0_ConfigEpLp") );
-    m_matX0Additions.push_back( (TH1D*) m_rootFile->Get("Material/DX0_ConfigFpMX") );
-    m_matX0Additions.push_back( (TH1D*) m_rootFile->Get("Material/DX0_ConfigGp") );
-
-    m_matElectronEtaBins =         (TAxis*) m_rootFile->Get("Material/LinearityEtaBins");
-    m_matElectronGraphs.push_back( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigA") );
-    m_matElectronGraphs.push_back( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigCpDp") );
-    m_matElectronGraphs.push_back( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigEpLp") );
-    m_matElectronGraphs.push_back( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigFpMX") );
-    m_matElectronGraphs.push_back( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigGp") );
+    m_matUnconvertedScale.emplace_back(std::unique_ptr<TH1>( (TH1*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigA") ));
+    m_matUnconvertedScale.back()->SetDirectory(nullptr);
+    m_matUnconvertedScale.emplace_back(std::unique_ptr<TH1>( (TH1*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigCpDp") ));
+    m_matUnconvertedScale.back()->SetDirectory(nullptr);
+    m_matUnconvertedScale.emplace_back(std::unique_ptr<TH1>( (TH1*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigEpLp") ));
+    m_matUnconvertedScale.back()->SetDirectory(nullptr);
+    m_matUnconvertedScale.emplace_back(std::unique_ptr<TH1>( (TH1*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigFpMX") ));
+    m_matUnconvertedScale.back()->SetDirectory(nullptr);
+    m_matUnconvertedScale.emplace_back(std::unique_ptr<TH1>( (TH1*) m_rootFile->Get("Material/unconvertedBiasSubtracted_ConfigGp") ));
+    m_matUnconvertedScale.back()->SetDirectory(nullptr);
+
+    m_matConvertedScale.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigA") ));
+    m_matConvertedScale.back()->SetDirectory(nullptr);
+    m_matConvertedScale.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigCpDp") ));
+    m_matConvertedScale.back()->SetDirectory(nullptr);
+    m_matConvertedScale.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigEpLp") ));
+    m_matConvertedScale.back()->SetDirectory(nullptr);
+    m_matConvertedScale.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigFpMX") ));
+    m_matConvertedScale.back()->SetDirectory(nullptr);
+    m_matConvertedScale.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/convertedBiasSubtracted_ConfigGp") ));
+    m_matConvertedScale.back()->SetDirectory(nullptr);
+
+    m_matElectronCstTerm.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/electronCstTerm_ConfigA") ));
+    m_matElectronCstTerm.back()->SetDirectory(nullptr);
+    m_matElectronCstTerm.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/electronCstTerm_ConfigCpDp") ));
+    m_matElectronCstTerm.back()->SetDirectory(nullptr);
+    m_matElectronCstTerm.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/electronCstTerm_ConfigEpLp") ));
+    m_matElectronCstTerm.back()->SetDirectory(nullptr);
+    m_matElectronCstTerm.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/electronCstTerm_ConfigFpMX") ));
+    m_matElectronCstTerm.back()->SetDirectory(nullptr);
+    m_matElectronCstTerm.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/electronCstTerm_ConfigGp") ));
+    m_matElectronCstTerm.back()->SetDirectory(nullptr);
+
+    if (m_esmodel==egEnergyCorr::es2017_R21_v1 || m_esmodel==egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) {
+     // update dX0 plots for distorted geometry for case A, EL, FMX and N
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material_rel21/DX0_ConfigA") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/DX0_ConfigCpDp") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material_rel21/DX0_ConfigEpLp") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material_rel21/DX0_ConfigFpMX") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/DX0_ConfigGp") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material_rel21/DX0_ConfigN") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+    }
+    else {
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/DX0_ConfigA") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/DX0_ConfigCpDp") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/DX0_ConfigEpLp") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/DX0_ConfigFpMX") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+      m_matX0Additions.emplace_back(std::unique_ptr<TH1>(  (TH1*) m_rootFile->Get("Material/DX0_ConfigGp") ));
+      m_matX0Additions.back()->SetDirectory(nullptr);
+    }
+
+
+    m_matElectronEtaBins.reset( dynamic_cast<TAxis*>(m_rootFile->Get("Material/LinearityEtaBins")));
+    m_matElectronGraphs.emplace_back( std::unique_ptr<TList>( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigA")) );
+    m_matElectronGraphs.emplace_back( std::unique_ptr<TList>( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigCpDp")) );
+    m_matElectronGraphs.emplace_back( std::unique_ptr<TList>( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigEpLp")) );
+    m_matElectronGraphs.emplace_back( std::unique_ptr<TList>( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigFpMX")) );
+    m_matElectronGraphs.emplace_back( std::unique_ptr<TList>( (TList*) m_rootFile->Get("Material/Linearity_Cluster_ConfigGp")) );
+
+
+    for (auto &mat: m_matElectronGraphs) {
+      mat->SetOwner();
+    }
+
+
+    // ... new material distortions from release 21 parameterizations
+
+    if (m_esmodel==egEnergyCorr::es2017_R21_v1 || m_esmodel==egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) {
+      m_electronBias_ConfigA.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/electronBias_ConfigA")));            m_electronBias_ConfigA->SetDirectory(nullptr);
+      m_electronBias_ConfigEpLp.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/electronBias_ConfigEpLp")));      m_electronBias_ConfigEpLp->SetDirectory(nullptr);
+      m_electronBias_ConfigFpMX.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/electronBias_ConfigFpMX")));      m_electronBias_ConfigFpMX->SetDirectory(nullptr);
+      m_electronBias_ConfigN.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/electronBias_ConfigN")));            m_electronBias_ConfigN->SetDirectory(nullptr);
+      m_electronBias_ConfigIBL.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/electronBias_ConfigIBL")));        m_electronBias_ConfigIBL->SetDirectory(nullptr);
+      m_electronBias_ConfigPP0.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/electronBias_ConfigPP0")));        m_electronBias_ConfigPP0->SetDirectory(nullptr);
+      m_unconvertedBias_ConfigA.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/unconvertedBias_ConfigA")));      m_unconvertedBias_ConfigA->SetDirectory(nullptr);
+      m_unconvertedBias_ConfigEpLp.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/unconvertedBias_ConfigEpLp"))); m_unconvertedBias_ConfigEpLp->SetDirectory(nullptr);
+      m_unconvertedBias_ConfigFpMX.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/unconvertedBias_ConfigFpMX")));m_unconvertedBias_ConfigFpMX->SetDirectory(nullptr);
+      m_unconvertedBias_ConfigN.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/unconvertedBias_ConfigN")));      m_unconvertedBias_ConfigN->SetDirectory(nullptr);
+      m_unconvertedBias_ConfigIBL.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/unconvertedBias_ConfigIBL")));  m_unconvertedBias_ConfigIBL->SetDirectory(nullptr);
+      m_unconvertedBias_ConfigPP0.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/unconvertedBias_ConfigPP0")));  m_unconvertedBias_ConfigPP0->SetDirectory(nullptr);
+      m_convertedBias_ConfigA.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/convertedBias_ConfigA")));          m_convertedBias_ConfigA->SetDirectory(nullptr);
+      m_convertedBias_ConfigEpLp.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/convertedBias_ConfigEpLp")));    m_convertedBias_ConfigEpLp->SetDirectory(nullptr);
+      m_convertedBias_ConfigFpMX.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/convertedBias_ConfigFpMX")));    m_convertedBias_ConfigFpMX->SetDirectory(nullptr);
+      m_convertedBias_ConfigN.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/convertedBias_ConfigN")));          m_convertedBias_ConfigN->SetDirectory(nullptr);
+      m_convertedBias_ConfigIBL.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/convertedBias_ConfigIBL")));      m_convertedBias_ConfigIBL->SetDirectory(nullptr);
+      m_convertedBias_ConfigPP0.reset( dynamic_cast< TH2* >( m_rootFile->Get("Material_rel21/convertedBias_ConfigPP0")));      m_convertedBias_ConfigPP0->SetDirectory(nullptr);
+    }
+
+
 
     // ... Fastsim to Fullsim corrections
 
@@ -1082,34 +1153,46 @@ namespace AtlasRoot {
         m_esmodel == egEnergyCorr::es2015cPRE or m_esmodel == egEnergyCorr::es2015cPRE_res_improved or
         m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE) {
 
-      m_G4OverAFII_electron = (TH1D*) m_rootFile->Get("FastSim/es2015/el_scale_full_fast_peak_gaussian"); m_G4OverAFII_electron->SetDirectory(0);
-      m_G4OverAFII_unconverted = (TH1D*) m_rootFile->Get("FastSim/es2015/ph_unconv_scale_full_fast_peak_gaussian"); m_G4OverAFII_unconverted->SetDirectory(0);
-      m_G4OverAFII_converted = (TH1D*) m_rootFile->Get("FastSim/es2015/ph_conv_scale_full_fast_peak_gaussian"); m_G4OverAFII_converted->SetDirectory(0);
+      m_G4OverAFII_electron.reset( dynamic_cast< TH1* >( m_rootFile->Get("FastSim/es2015/el_scale_full_fast_peak_gaussian"))); m_G4OverAFII_electron->SetDirectory(nullptr);
+      m_G4OverAFII_unconverted.reset( dynamic_cast< TH1* >( m_rootFile->Get("FastSim/es2015/ph_unconv_scale_full_fast_peak_gaussian"))); m_G4OverAFII_unconverted->SetDirectory(nullptr);
+      m_G4OverAFII_converted.reset( dynamic_cast< TH1* >( m_rootFile->Get("FastSim/es2015/ph_conv_scale_full_fast_peak_gaussian"))); m_G4OverAFII_converted->SetDirectory(nullptr);
+    }
+    else if (m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer
+             or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final
+             or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV
+             or m_esmodel == egEnergyCorr::es2017_R21_v0) {
+      m_G4OverAFII_electron.reset( dynamic_cast< TH1* >( m_rootFile->Get("FastSim/es2017/el_scale_full_fast_peak_gaussian"))); m_G4OverAFII_electron->SetDirectory(nullptr);
+      m_G4OverAFII_unconverted.reset( dynamic_cast< TH1* >( m_rootFile->Get("FastSim/es2017/ph_unconv_scale_full_fast_peak_gaussian"))); m_G4OverAFII_unconverted->SetDirectory(nullptr);
+      m_G4OverAFII_converted.reset( dynamic_cast< TH1* >( m_rootFile->Get("FastSim/es2017/ph_conv_scale_full_fast_peak_gaussian"))); m_G4OverAFII_converted->SetDirectory(nullptr);
     }
-    else if (m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE) {
-      m_G4OverAFII_electron = (TH1D*) m_rootFile->Get("FastSim/es2017/el_scale_full_fast_peak_gaussian"); m_G4OverAFII_electron->SetDirectory(0);
-      m_G4OverAFII_unconverted = (TH1D*) m_rootFile->Get("FastSim/es2017/ph_unconv_scale_full_fast_peak_gaussian"); m_G4OverAFII_unconverted->SetDirectory(0);
-      m_G4OverAFII_converted = (TH1D*) m_rootFile->Get("FastSim/es2017/ph_conv_scale_full_fast_peak_gaussian"); m_G4OverAFII_converted->SetDirectory(0);
+    else if (m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) {
+      m_G4OverAFII_electron_2D.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2017_v1/scale_Af2ToG4_elec_rel21"))); m_G4OverAFII_electron_2D->SetDirectory(nullptr);
+      m_G4OverAFII_unconverted_2D.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2017_v1/scale_Af2ToG4_unco_rel21"))); m_G4OverAFII_unconverted_2D->SetDirectory(nullptr);
+      m_G4OverAFII_converted_2D.reset( dynamic_cast< TH2* >( m_rootFile->Get("FastSim/es2017_v1/scale_Af2ToG4_conv_rel21"))); m_G4OverAFII_converted_2D->SetDirectory(nullptr);
     }
     else { // run 1
-      m_G4OverAFII_electron = (TH1D*) m_rootFile->Get("FastSim/hG4OverAF");                 m_G4OverAFII_electron->SetDirectory(0);
+      m_G4OverAFII_electron.reset( dynamic_cast< TH1* >( m_rootFile->Get("FastSim/hG4OverAF")));                 m_G4OverAFII_electron->SetDirectory(nullptr);
     }
-    m_G4OverFrSh            = (TH1D*) m_rootFile->Get("FastSim/hG4OverFS");                 m_G4OverFrSh->SetDirectory(0);
+
+    m_G4OverFrSh.reset( dynamic_cast< TH1* >( m_rootFile->Get("FastSim/hG4OverFS")));                 m_G4OverFrSh->SetDirectory(nullptr);
 
     // ... Leakage systematics
-    
-    if(m_esmodel != egEnergyCorr::es2017_summer and m_esmodel != egEnergyCorr::es2017_summer_improved and m_esmodel != egEnergyCorr::es2017_R21_PRE){
-      m_leakageConverted      = (TH1D*) m_rootFile->Get("Leakage/LeakageDiffConverted");      m_leakageConverted->SetDirectory(0);
-      m_leakageUnconverted    = (TH1D*) m_rootFile->Get("Leakage/LeakageDiffUnconverted");    m_leakageUnconverted->SetDirectory(0);
+
+    if(m_esmodel != egEnergyCorr::es2017_summer and m_esmodel != egEnergyCorr::es2017_summer_improved
+       and m_esmodel != egEnergyCorr::es2017_summer_final and m_esmodel != egEnergyCorr::es2017_R21_PRE
+       and m_esmodel != egEnergyCorr::es2015_5TeV and m_esmodel != egEnergyCorr::es2017_R21_v0
+       and m_esmodel != egEnergyCorr::es2017_R21_v1 and m_esmodel != egEnergyCorr::es2017_R21_ofc0_v1 and m_esmodel != egEnergyCorr::es2018_R21_v0 and m_esmodel != egEnergyCorr::es2018_R21_v1){
+      m_leakageConverted.reset( dynamic_cast< TH1* >( m_rootFile->Get("Leakage/LeakageDiffConverted")));      m_leakageConverted->SetDirectory(nullptr);
+      m_leakageUnconverted.reset( dynamic_cast< TH1* >( m_rootFile->Get("Leakage/LeakageDiffUnconverted")));    m_leakageUnconverted->SetDirectory(nullptr);
     }
     else{
-      m_leakageConverted      = (TH1D*) m_rootFile->Get("Leakage/es2017_summer/LeakageDiffConverted");      m_leakageConverted->SetDirectory(0);
-      m_leakageUnconverted    = (TH1D*) m_rootFile->Get("Leakage/es2017_summer/LeakageDiffUnconverted");    m_leakageUnconverted->SetDirectory(0);
+      m_leakageConverted.reset( dynamic_cast< TH1* >( m_rootFile->Get("Leakage/es2017_summer/LeakageDiffConverted")));      m_leakageConverted->SetDirectory(nullptr);
+      m_leakageUnconverted.reset( dynamic_cast< TH1* >( m_rootFile->Get("Leakage/es2017_summer/LeakageDiffUnconverted")));    m_leakageUnconverted->SetDirectory(nullptr);
     }
-      
+
     // ... Zee S2 profile (needed for gain switch syst).
 
-    m_zeeES2Profile         = (TH1D*) m_rootFile->Get("ZeeEnergyProfiles/p2MC");    m_zeeES2Profile->SetDirectory(0);
+    m_zeeES2Profile.reset( dynamic_cast< TH1* >( m_rootFile->Get("ZeeEnergyProfiles/p2MC")));    m_zeeES2Profile->SetDirectory(nullptr);
 
     // OK, now we are all initialized and everything went fine
 
@@ -1167,7 +1250,7 @@ namespace AtlasRoot {
       fullyCorrectedEnergy = energy * this->applyFStoG4(cl_eta);
     else if ( dataType == PATCore::ParticleDataType::Fast ) // AtlFast2 sim
     {
-      fullyCorrectedEnergy = energy * this->applyAFtoG4(cl_eta, ptype);
+      fullyCorrectedEnergy = energy * this->applyAFtoG4(cl_eta, 0.001*energy/cosh(cl_eta),ptype);
     }
 
     // If nothing is to be done
@@ -1183,7 +1266,15 @@ namespace AtlasRoot {
 
       if( scaleVar == egEnergyCorr::Scale::Nominal ) {
         double alpha = getAlphaValue(runnumber, cl_eta, cl_etaCalo, fullyCorrectedEnergy, energyS2, eraw, ptype, scaleVar, varSF);
-        fullyCorrectedEnergy /= (1 + alpha);
+	fullyCorrectedEnergy /= (1 + alpha);
+        // apply additional k.E+b corrections if histograms exist (like in es2017_R21_v1)
+	if (m_zeeFwdk &&  m_zeeFwdb && fabs(cl_eta)>2.5){ //  calo eta?
+	  int ieta_k = m_zeeFwdk->GetXaxis()->FindBin(cl_eta);
+	  double value_k = m_zeeFwdk->GetBinContent(ieta_k);
+	  int ieta_b = m_zeeFwdb->GetXaxis()->FindBin(cl_eta);
+          double value_b = m_zeeFwdb->GetBinContent(ieta_b);
+	  fullyCorrectedEnergy = value_k*fullyCorrectedEnergy + value_b*GeV;   // value is stored in GeV in the histogram file
+	}
         ATH_MSG_DEBUG("after alpha = " << boost::format("%.2f") % fullyCorrectedEnergy);
       }
 
@@ -1198,6 +1289,23 @@ namespace AtlasRoot {
         ATH_MSG_DEBUG("after mc alpha = " << boost::format("%.2f") % fullyCorrectedEnergy);
       }
 
+       // AF2 systematics  (this will not be in the sum of all other NP in the 1 NP model)
+      if (dataType == PATCore::ParticleDataType::Fast && (m_esmodel== egEnergyCorr::es2017_R21_v0 || m_esmodel== egEnergyCorr::es2017_R21_v1 || m_esmodel== egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) ) {
+        if (scaleVar==egEnergyCorr::Scale::af2Up or scaleVar==egEnergyCorr::Scale::af2Down) {
+           double daAF2=0.;
+           if (m_esmodel== egEnergyCorr::es2017_R21_v0) {
+              if (scaleVar==egEnergyCorr::Scale::af2Up) daAF2 = 0.005;
+              if (scaleVar==egEnergyCorr::Scale::af2Down) daAF2 = -0.005;
+           }
+           if (m_esmodel== egEnergyCorr::es2017_R21_v1 || m_esmodel== egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) {
+              if (scaleVar==egEnergyCorr::Scale::af2Up) daAF2 = 0.001;
+              if (scaleVar==egEnergyCorr::Scale::af2Down) daAF2 = -0.001;
+           }
+           fullyCorrectedEnergy *= ( 1 + daAF2);
+        }
+      }
+
+
       // Do the resolution correction
       if ( resVar != egEnergyCorr::Resolution::None )
       fullyCorrectedEnergy *= getSmearingCorrection(cl_eta, cl_etaCalo, fullyCorrectedEnergy, ptype, dataType, resVar, resType);
@@ -1241,7 +1349,7 @@ namespace AtlasRoot {
 
     double daE4 = 0., linE4 = 0.;
     // E4 contribution
-    if ((m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE or m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE) and
+    if ((m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE or m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or m_esmodel == egEnergyCorr::es2018_R21_v1) and
         (var == egEnergyCorr::Scale::E4ScintillatorUp or var == egEnergyCorr::Scale::E4ScintillatorDown))
     {
       daE4 = getE4Uncertainty(cl_eta);
@@ -1251,7 +1359,7 @@ namespace AtlasRoot {
 
     //wtots1 contribution
     double daWtots1 = 0.;
-    if ((m_esmodel==egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE) and (var == egEnergyCorr::Scale::Wtots1Up or var == egEnergyCorr::Scale::Wtots1Down)){
+    if ((m_esmodel==egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or  m_esmodel == egEnergyCorr::es2018_R21_v1) and (var == egEnergyCorr::Scale::Wtots1Up or var == egEnergyCorr::Scale::Wtots1Down)){
       daWtots1 = getWtots1Uncertainty(cl_eta, energy, ptype);
       if(var == egEnergyCorr::Scale::Wtots1Down)
 	daWtots1 = -daWtots1;
@@ -1260,6 +1368,7 @@ namespace AtlasRoot {
     // ... Presampler contribution
 
     if( var==egEnergyCorr::Scale::PSUp || var==egEnergyCorr::Scale::PSDown ||
+	var==egEnergyCorr::Scale::PSb12Up || var==egEnergyCorr::Scale::PSb12Down ||
 	var==egEnergyCorr::Scale::LArElecUnconvUp || var==egEnergyCorr::Scale::LArElecUnconvDown ) {
 
       daPS  = getLayerUncertainty(  0, cl_eta, var, varSF );
@@ -1284,7 +1393,10 @@ namespace AtlasRoot {
     double daMatID, daMatCryo, daMatCalo;
     daMatID = daMatCryo = daMatCalo = 0;
 
-    if( ptype!=PATCore::ParticleType::Electron ) {
+    // for release 21 sensitivity use the same getMaterialNonLinearity for all particles
+    // while in sensitivities derived from run 1 this is only used for electrons
+
+    if( ptype!=PATCore::ParticleType::Electron  && (m_esmodel != egEnergyCorr::es2017_R21_v1 && m_esmodel != egEnergyCorr::es2017_R21_ofc0_v1 &&  m_esmodel != egEnergyCorr::es2018_R21_v0 && m_esmodel != egEnergyCorr::es2018_R21_v1) ) {
 
       daMatID   = getAlphaMaterial( cl_eta, egEnergyCorr::MatID,   ptype, var, varSF );
       daMatCryo = getAlphaMaterial( cl_eta, egEnergyCorr::MatCryo, ptype, var, varSF );
@@ -1293,11 +1405,11 @@ namespace AtlasRoot {
     } else {
 
       daMatID   = getMaterialNonLinearity( cl_eta, energy, egEnergyCorr::MatID,   ptype, var, varSF )
-	- getMaterialNonLinearity( cl_eta, meanE,  egEnergyCorr::MatID,   ptype, var, varSF );
+	- getMaterialNonLinearity( cl_eta, meanE,  egEnergyCorr::MatID,   PATCore::ParticleType::Electron, var, varSF );
       daMatCryo = getMaterialNonLinearity( cl_eta, energy, egEnergyCorr::MatCryo, ptype, var, varSF )
-	- getMaterialNonLinearity( cl_eta, meanE,  egEnergyCorr::MatCryo, ptype, var, varSF );
+	- getMaterialNonLinearity( cl_eta, meanE,  egEnergyCorr::MatCryo, PATCore::ParticleType::Electron, var, varSF );
       daMatCalo = getMaterialNonLinearity( cl_eta, energy, egEnergyCorr::MatCalo, ptype, var, varSF )
-	- getMaterialNonLinearity( cl_eta, meanE,  egEnergyCorr::MatCalo, ptype, var, varSF );
+	- getMaterialNonLinearity( cl_eta, meanE,  egEnergyCorr::MatCalo, PATCore::ParticleType::Electron, var, varSF );
 
     }
 
@@ -1368,26 +1480,54 @@ namespace AtlasRoot {
     double dapp0 = 0.;
     // values from the histogram already are 0 for the Z->ee electrons
     if (var == egEnergyCorr::Scale::MatPP0Up or var == egEnergyCorr::Scale::MatPP0Down) {
-      decltype(m_pp0_conv) histo = nullptr;
-      if (ptype == PATCore::ParticleType::Electron) histo = m_pp0_elec;
-      else if (ptype == PATCore::ParticleType::ConvertedPhoton) histo = m_pp0_conv;
-      else if (ptype == PATCore::ParticleType::UnconvertedPhoton) histo = m_pp0_unconv;
 
-      if (histo) {
-        const double aeta = std::abs(cl_eta);
-        dapp0 = getValueHistAt(*histo, aeta, energy / GeV / cosh(cl_eta), false, true, false, true);
-        if (var == egEnergyCorr::Scale::MatPP0Down) { dapp0 = -dapp0; }
+// new parameterization for release 21 reconstruction with mc16 geometries + distortions
+      if (m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 ||  m_esmodel == egEnergyCorr::es2018_R21_v1) {
+
+          if (fabs(cl_eta)<1.5)
+           dapp0 = getMaterialEffect(egEnergyCorr::ConfigIBL,ptype ,cl_eta,energy / GeV / cosh(cl_eta))
+                  -getMaterialEffect(egEnergyCorr::ConfigIBL,PATCore::ParticleType::Electron, cl_eta,getZeeMeanET(cl_eta)/GeV);
+          else
+           dapp0 = getMaterialEffect(egEnergyCorr::ConfigPP0,ptype ,cl_eta,energy / GeV / cosh(cl_eta))
+                  -getMaterialEffect(egEnergyCorr::ConfigPP0,PATCore::ParticleType::Electron, cl_eta,getZeeMeanET(cl_eta)/GeV);
 
-        // normalize to pp0 systematics
-        if (aeta > 1.5 and aeta < 2.0) { dapp0 *= 2.6; }
-        else if (aeta >= 2.0 and aeta <= 2.5) { dapp0 *= 2.3; }
+          if (var == egEnergyCorr::Scale::MatPP0Down) { dapp0 = -dapp0; }
       }
+
+      // release 20 run 2 systematics for mc15 like geometries
+      else {
+        //Just pick the owned one from a unique_ptr per case
+        TH2* histo = nullptr;
+        if (ptype == PATCore::ParticleType::Electron && m_pp0_elec) histo = dynamic_cast<TH2*>(m_pp0_elec.get());
+        else if (ptype == PATCore::ParticleType::ConvertedPhoton && m_pp0_conv ) histo = dynamic_cast<TH2*>(m_pp0_conv.get());
+        else if (ptype == PATCore::ParticleType::UnconvertedPhoton && m_pp0_unconv) histo = dynamic_cast<TH2*>(m_pp0_unconv.get());
+
+        if (histo) {
+          const double aeta = std::abs(cl_eta);
+          dapp0 = getValueHistAt(*histo, aeta, energy / GeV / cosh(cl_eta), false, true, false, true);
+          if (var == egEnergyCorr::Scale::MatPP0Down) { dapp0 = -dapp0; }
+
+          // normalize to pp0 systematics
+          if (aeta > 1.5 and aeta < 2.0) { dapp0 *= 2.6; }
+          else if (aeta >= 2.0 and aeta <= 2.5) { dapp0 *= 2.3; }
+        }
+     }
     }
 
     // Conversion systematics
 
     double daConvSyst = getAlphaConvSyst(cl_eta, energy, ptype, var, varSF);
 
+    // topo cluster threshold systematics for release 21
+    double daTopoCluster=0;
+    if ((var==egEnergyCorr::Scale::topoClusterThresUp || var==egEnergyCorr::Scale::topoClusterThresDown) && (m_esmodel== egEnergyCorr::es2017_R21_v0 || m_esmodel== egEnergyCorr::es2017_R21_v1 || m_esmodel== egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1)) {
+       double Et = energy/cosh(cl_eta);
+       double Et0=10000.;
+       //  Effect taken as 10**-3/(Et/10GeV) - order of magniture from https://indico.cern.ch/event/669895/contributions/2745266/attachments/1535612/2405452/slides.pdf
+       if (var==egEnergyCorr::Scale::topoClusterThresUp)      daTopoCluster = 1e-3*(1./(Et/Et0)-1./(getZeeMeanET(cl_eta)/Et0));
+       if (var==egEnergyCorr::Scale::topoClusterThresUp)      daTopoCluster = -1e-3*(1./(Et/Et0)-1./(getZeeMeanET(cl_eta)/Et0));
+    }
+
     // Total
 
     double alphaTot = alphaZee;
@@ -1402,6 +1542,7 @@ namespace AtlasRoot {
     alphaTot += daPedestal;
     alphaTot += daWtots1;
     alphaTot += dapp0;
+    alphaTot += daTopoCluster;
 
     ATH_MSG_DEBUG("alpha value for " << variationName(var) << " = " << alphaTot);
 
@@ -1637,8 +1778,9 @@ namespace AtlasRoot {
 
   // get fractional uncertainty on resolution
 
-  double egammaEnergyCorrectionTool::getResolutionError(double energy, double eta, double etaCalo, PATCore::ParticleType::Type ptype,egEnergyCorr::Resolution::Variation value,
-                                                        egEnergyCorr::Resolution::resolutionType resType ) const
+  double egammaEnergyCorrectionTool::getResolutionError(PATCore::ParticleDataType::DataType dataType,double energy, double eta, double etaCalo,
+                                                        PATCore::ParticleType::Type ptype,egEnergyCorr::Resolution::Variation value,
+                                                       egEnergyCorr::Resolution::resolutionType resType) const
 
   {
 
@@ -1654,24 +1796,8 @@ namespace AtlasRoot {
 
     int isys=0;
     if (value==egEnergyCorr::Resolution::AllUp || value==egEnergyCorr::Resolution::AllDown) {
-      // old code, seems to do a linear sum, Guillaume email 1 Jul 2016
       isys=0xFFFF;
-      /*const std::vector<egEnergyCorr::Resolution::Variation> list_up = { egEnergyCorr::Resolution::ZSmearingUp, egEnergyCorr::Resolution::SamplingTermUp,
-                                                                    egEnergyCorr::Resolution::MaterialIDUp, egEnergyCorr::Resolution::MaterialCaloUp,
-                                                                    egEnergyCorr::Resolution::MaterialGapUp, egEnergyCorr::Resolution::MaterialCryoUp,
-                                                                    egEnergyCorr::Resolution::PileUpUp };
-      const std::vector<egEnergyCorr::Resolution::Variation> list_down = { egEnergyCorr::Resolution::ZSmearingDown, egEnergyCorr::Resolution::SamplingTermDown,
-                                                                    egEnergyCorr::Resolution::MaterialIDDown, egEnergyCorr::Resolution::MaterialCaloDown,
-                                                                    egEnergyCorr::Resolution::MaterialGapDown, egEnergyCorr::Resolution::MaterialCryoDown,
-                                                                    egEnergyCorr::Resolution::PileUpDown };
-      const std::vector<egEnergyCorr::Resolution::Variation> list_sys_loop = value == egEnergyCorr::Resolution::AllUp ? list_up : list_down;
-      double acc_sys = 0.;
-      for (const auto var : list_sys_loop) {
-        acc_sys += std::pow(getResolutionError(energy, eta, etaCalo, ptype, var, resType), 2);
-      }
-      acc_sys = std::sqrt(acc_sys);
-      if (value == egEnergyCorr::Resolution::AllDown) return -acc_sys;
-      else return acc_sys;*/
+
     }
     if (value==egEnergyCorr::Resolution::ZSmearingUp || value==egEnergyCorr::Resolution::ZSmearingDown) {
       isys=0x1;
@@ -1701,20 +1827,26 @@ namespace AtlasRoot {
     if (value==egEnergyCorr::Resolution::MaterialPP0Up || value==egEnergyCorr::Resolution::MaterialPP0Down) {
       isys=0x100;
     }
+    if (value==egEnergyCorr::Resolution::af2Up || value==egEnergyCorr::Resolution::af2Down) {
+      isys=0x200;
+    }
 
     double sign = 1.;
     if (value==egEnergyCorr::Resolution::AllDown ||  value==egEnergyCorr::Resolution::ZSmearingDown ||
         value==egEnergyCorr::Resolution::SamplingTermDown ||  value==egEnergyCorr::Resolution::MaterialIDDown ||
         value==egEnergyCorr::Resolution::MaterialGapDown || value==egEnergyCorr::Resolution::MaterialCaloDown ||
         value==egEnergyCorr::Resolution::MaterialCryoDown || value==egEnergyCorr::Resolution::PileUpDown ||
-	value==egEnergyCorr::Resolution::MaterialIBLDown || value==egEnergyCorr::Resolution::MaterialPP0Down) sign=-1.;
+	value==egEnergyCorr::Resolution::MaterialIBLDown || value==egEnergyCorr::Resolution::MaterialPP0Down ||
+        value==egEnergyCorr::Resolution::af2Down) sign=-1.;
 
     double resolution;
     double resolution_error;
     double resolution_error_up;
     double resolution_error_down;
 
-    getResolution_systematics(eg_resolution_ptype, energy,  eta, etaCalo, isys,  resolution, resolution_error, resolution_error_up, resolution_error_down, resType);
+
+    getResolution_systematics(eg_resolution_ptype, energy,  eta, etaCalo, isys,  resolution, resolution_error, resolution_error_up, resolution_error_down, resType,
+          dataType == PATCore::ParticleDataType::Fast);
 
     // total resolution uncertainty
     if (value==egEnergyCorr::Resolution::AllUp || value==egEnergyCorr::Resolution::AllDown) {
@@ -1784,7 +1916,7 @@ namespace AtlasRoot {
     if (m_use_new_resolution_model) {
       sig2 = pow(m_resolution_tool->getResolution(eg_resolution_ptype, energy, cl_eta, resType), 2);
       const double et = energy / cosh(cl_eta);
-      sig2 += pow(pileUpTerm(cl_eta, eg_resolution_ptype) / et, 2);  // TODO: why et and not E?
+      sig2 += pow(pileUpTerm(energy, cl_eta, eg_resolution_ptype) / et, 2);  // TODO: why et and not E?
     } else { // OLD model
 
       double energyGeV = energy/GeV;
@@ -1801,16 +1933,27 @@ namespace AtlasRoot {
     }
 
     if (fast and std::abs(cl_eta) < 2.5) {
-      if (m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015PRE or m_esmodel == egEnergyCorr::es2015PRE_res_improved or m_esmodel == egEnergyCorr::es2015cPRE or m_esmodel == egEnergyCorr::es2015cPRE_res_improved or m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE) {
+      if (m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2015PRE or m_esmodel == egEnergyCorr::es2015PRE_res_improved or m_esmodel == egEnergyCorr::es2015cPRE or m_esmodel == egEnergyCorr::es2015cPRE_res_improved or m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or m_esmodel == egEnergyCorr::es2018_R21_v1) {
 
         double ratio_IQR_full_fast = 1.;
         const double ptGeV = energy / cosh(cl_eta) / 1E3;
 
-        if (ptype == PATCore::ParticleType::Electron) { ratio_IQR_full_fast = getValueHistAt(*m_G4OverAFII_resolution_electron, ptGeV, cl_eta, true, false); }
-        else if (ptype == PATCore::ParticleType::UnconvertedPhoton) { ratio_IQR_full_fast = getValueHistAt(*m_G4OverAFII_resolution_unconverted, ptGeV, cl_eta, true, false); }
-        else if (ptype == PATCore::ParticleType::ConvertedPhoton) {  ratio_IQR_full_fast = getValueHistAt(*m_G4OverAFII_resolution_converted, ptGeV, cl_eta, true, false); }
+        if  ( m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) {
+//
+// for es2017_R21_v1, histograms contain directly values of deltaSigma**2 of relative energy resolution (FastSIm-FulSim) so need to subtract this value to get the sigma**2 of FastSim
 
-        sig2 /= ratio_IQR_full_fast * ratio_IQR_full_fast;
+           if(ptype == PATCore::ParticleType::Electron) sig2 -=   getValueHistAt(*m_G4OverAFII_resolution_electron,cl_eta,ptGeV,true,true,true,true);
+           if (ptype == PATCore::ParticleType::UnconvertedPhoton) sig2 -=   getValueHistAt(*m_G4OverAFII_resolution_unconverted,cl_eta,ptGeV,true,true,true,true);
+           if (ptype == PATCore::ParticleType::ConvertedPhoton) sig2 -=   getValueHistAt(*m_G4OverAFII_resolution_converted,cl_eta,ptGeV,true,true,true,true);
+           if (sig2<0.) sig2=0.;
+        }
+        else {
+          if (ptype == PATCore::ParticleType::Electron) { ratio_IQR_full_fast = getValueHistAt(*m_G4OverAFII_resolution_electron, ptGeV, cl_eta, true, false); }
+          else if (ptype == PATCore::ParticleType::UnconvertedPhoton) { ratio_IQR_full_fast = getValueHistAt(*m_G4OverAFII_resolution_unconverted, ptGeV, cl_eta, true, false); }
+          else if (ptype == PATCore::ParticleType::ConvertedPhoton) {  ratio_IQR_full_fast = getValueHistAt(*m_G4OverAFII_resolution_converted, ptGeV, cl_eta, true, false); }
+
+          sig2 /= ratio_IQR_full_fast * ratio_IQR_full_fast;
+        }
       }
     }
 
@@ -1859,7 +2002,7 @@ namespace AtlasRoot {
     ATH_MSG_DEBUG("resolution in data: " << resData << " in MC: " << resMC);
 
     if (m_use_new_resolution_model) {
-      resData *= 1 + getResolutionError(energy, cl_eta, cl_etaCalo, ptype, value, resType);
+      resData *= 1 + getResolutionError(dataType,energy, cl_eta, cl_etaCalo, ptype, value, resType);
     } else { // OLD model
       double errUp, errDown;
       resolutionError( energyGeV, cl_eta, errUp, errDown );
@@ -1874,6 +2017,7 @@ namespace AtlasRoot {
     ATH_MSG_DEBUG("resolution in data after systematics: " << resData);
 
     const double sigma2 = std::pow(resData * energyGeV, 2 ) - std::pow(resMC * energyGeV, 2);
+
     // TODO: for nominal case it can be simplified to:
     // const double sigma = dataConstantTerm(m_use_etaCalo_scales ? cl_etaCalo : cl_eta) * energyGeV;
     // which is just the additional constant term
@@ -1930,7 +2074,7 @@ namespace AtlasRoot {
 
   // AF -> G4 correction
 
-  double egammaEnergyCorrectionTool::applyAFtoG4(double eta,
+  double egammaEnergyCorrectionTool::applyAFtoG4(double eta, double ptGeV,
 						 PATCore::ParticleType::Type ptype) const {
     const double aeta = fabs(eta);
     if (aeta > 2.47) return 1.;
@@ -1938,11 +2082,24 @@ namespace AtlasRoot {
     if (m_esmodel == egEnergyCorr::es2015PRE or m_esmodel == egEnergyCorr::es2015PRE_res_improved or
         m_esmodel == egEnergyCorr::es2015cPRE or m_esmodel == egEnergyCorr::es2015cPRE_res_improved or
         m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE or m_esmodel == egEnergyCorr::es2017
-	or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE) {
-      if (ptype == PATCore::ParticleType::Electron) { return getValueHistoAt(*m_G4OverAFII_electron, eta); }
-      else if (ptype == PATCore::ParticleType::ConvertedPhoton) { return getValueHistoAt(*m_G4OverAFII_converted, eta); }
-      else if (ptype == PATCore::ParticleType::UnconvertedPhoton) { return getValueHistoAt(*m_G4OverAFII_unconverted, eta); }
-      else { throw std::runtime_error("particle not valid"); }
+	or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final
+	or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or m_esmodel == egEnergyCorr::es2018_R21_v1) {
+
+      if (m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 ||  m_esmodel == egEnergyCorr::es2018_R21_v1) {
+//
+// in es02017_R21_v1 : AF2 to FullSim correction is in a 2D eta-Pt histogram
+
+        if (ptype == PATCore::ParticleType::Electron) { return (1.+getValueHistAt(*m_G4OverAFII_electron_2D, aeta,ptGeV,true,true,true,true)); }
+        else if (ptype == PATCore::ParticleType::ConvertedPhoton) { return (1.+getValueHistAt(*m_G4OverAFII_converted_2D, aeta,ptGeV,true,true,true,true)); }
+        else if (ptype == PATCore::ParticleType::UnconvertedPhoton) { return (1.+getValueHistAt(*m_G4OverAFII_unconverted_2D, aeta,ptGeV,true,true,true,true)); }
+        else { throw std::runtime_error("particle not valid"); }
+      }
+      else {
+        if (ptype == PATCore::ParticleType::Electron) { return getValueHistoAt(*m_G4OverAFII_electron, aeta); }
+        else if (ptype == PATCore::ParticleType::ConvertedPhoton) { return getValueHistoAt(*m_G4OverAFII_converted, aeta); }
+        else if (ptype == PATCore::ParticleType::UnconvertedPhoton) { return getValueHistoAt(*m_G4OverAFII_unconverted, aeta); }
+        else { throw std::runtime_error("particle not valid"); }
+      }
     }
     else {
       // run 1
@@ -1975,7 +2132,39 @@ namespace AtlasRoot {
     int ieta = m_zeeNom->GetXaxis()->FindBin(eta);
     double value = m_zeeNom->GetBinContent(ieta);
 
-    if ((m_esmodel==egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved) && runnumber < 297000) {
+    // for es2018_R21_v0 and v1 different set of scales for 2018, 2017, 2016 and 2015 data
+    if ((m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1)  && runnumber<=341649 && runnumber>=324320){
+      int ieta = m_zeeNom_data2017->GetXaxis()->FindBin(eta);
+      value = m_zeeNom_data2017->GetBinContent(ieta);
+    }
+
+     // for es2017_R21_v0 different set of scales for 2017, 2016 and 2015 data
+    if ( m_esmodel == egEnergyCorr::es2017_R21_v0 && runnumber<322817 && runnumber>=297000) {
+       int ieta = m_zeeNom_data2016->GetXaxis()->FindBin(eta);
+       value = m_zeeNom_data2016->GetBinContent(ieta);
+    }
+
+    if ( (m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) && runnumber<322817 && runnumber>=297000) {
+      int ieta = m_zeeNom_data2016->GetXaxis()->FindBin(eta);
+      value = m_zeeNom_data2016->GetBinContent(ieta);
+    }
+
+    if (m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 && runnumber<322817 && runnumber>=297000) {
+      int ieta = m_zeeNom_data2016->GetXaxis()->FindBin(eta);
+      value = m_zeeNom_data2016->GetBinContent(ieta);
+    }
+
+    if (m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 && runnumber<297000) {
+       int ieta = m_zeeNom_data2015->GetXaxis()->FindBin(eta);
+       value = m_zeeNom_data2015->GetBinContent(ieta);
+    }
+
+    if (m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 && runnumber>347847) {
+        int ieta = m_zeeNom_data2018->GetXaxis()->FindBin(eta);
+        value = m_zeeNom_data2018->GetBinContent(ieta);
+    }
+
+    if ((m_esmodel==egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or m_esmodel == egEnergyCorr::es2018_R21_v1) && runnumber < 297000) {
       // 2 sets of scales for this configuration
       // change histogram if 2015 data
       int ieta = m_zeeNom_data2015->GetXaxis()->FindBin(eta);
@@ -2035,20 +2224,37 @@ namespace AtlasRoot {
       }
     }
 
+
     if (var == egEnergyCorr::Scale::ZeeStatUp or var == egEnergyCorr::Scale::ZeeStatDown) {
       const double sign = (var == egEnergyCorr::Scale::ZeeStatUp) ? 1 : -1;
 
-      const TH1* h = m_zeeNom;
-      if ((m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved) && runnumber < 297000) h = m_zeeNom_data2015; // special for 2015 with es2017
+      TH1* h= ((TH1*)m_zeeNom.get());
+
+      if ((m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or
+           m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final or
+           m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2017_R21_v0 or
+           m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or m_esmodel == egEnergyCorr::es2018_R21_v1) && runnumber < 297000){
+        h=((TH1*) m_zeeNom_data2015.get()); // special for 2015 with es2017
+      }
+      if ( (m_esmodel== egEnergyCorr::es2017_R21_v0 || m_esmodel== egEnergyCorr::es2017_R21_v1 ||
+            m_esmodel== egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) && runnumber>=297000 && runnumber<322817){
+        h = m_zeeNom_data2016.get(); // 2016 data
+      }
+      if (  m_esmodel== egEnergyCorr::es2017_R21_ofc0_v1 && runnumber>347847) {
+        h = m_zeeNom_data2018.get();
+      }
+      if ( (m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) && runnumber>=324320 && runnumber<=341649 ){
+        h=((TH1*)m_zeeNom_data2017.get()); // 2017 data
+      }
       double stat_error = h->GetBinError(h->FindFixBin(eta));
 	    if (m_use_stat_error_scaling) {
         stat_error = stat_error / sqrt(h->GetNbinsX());
 	    }
 	    value += sign * stat_error * varSF;
-
     }
     else if( var==egEnergyCorr::Scale::ZeeSystUp && m_zeeSyst ) {
       value += get_ZeeSyst(eta) * varSF;
+
     } else if( var==egEnergyCorr::Scale::ZeeSystDown && m_zeeSyst ) {
       value -= get_ZeeSyst(eta) * varSF;
     } else if( var==egEnergyCorr::Scale::ZeePhysUp && m_zeePhys ) {
@@ -2105,7 +2311,7 @@ namespace AtlasRoot {
       double diff = pow(m_zeeNom->GetBinError(ieta) * varSF, 2);
 
       if( m_zeeSyst ) {
-        diff += pow(get_ZeeSyst(eta) * varSF, 2);
+	diff += pow(get_ZeeSyst(eta) * varSF, 2);
       }
 
       if( m_zeePhys ) {
@@ -2156,8 +2362,6 @@ namespace AtlasRoot {
     int bin = m_wstot_slope_A_data->FindFixBin(cl_eta);
     double A = m_wstot_slope_A_data->GetBinContent(bin);
     double B = m_wstot_slope_B_MC->GetBinContent(bin);
-    double wstot_40_data = m_wstot_40GeV_data->GetBinContent(bin);
-    double wstot_40_MC = m_wstot_40GeV_MC->GetBinContent(bin);
 
     //the wstot=f(pT) depends on the particle type
     double ETGeV = energy / cosh(cl_eta) / 1E3;
@@ -2166,6 +2370,9 @@ namespace AtlasRoot {
     double wstot_pT_MC_p0 = 0.;
     double wstot_pT_MC_p1 = 0.;
 
+    double wstot_40_data = m_wstot_pT_data_p0_electrons->GetBinContent(bin) + (m_wstot_pT_data_p1_electrons->GetBinContent(bin))/sqrt(40.);
+    double wstot_40_MC   = m_wstot_pT_MC_p0_electrons->GetBinContent(bin) + (m_wstot_pT_MC_p1_electrons->GetBinContent(bin))/sqrt(40.);
+
     if (ptype == PATCore::ParticleType::Electron ) {
       wstot_pT_data_p0 = m_wstot_pT_data_p0_electrons->GetBinContent(bin);
       wstot_pT_data_p1 = m_wstot_pT_data_p1_electrons->GetBinContent(bin);
@@ -2230,6 +2437,12 @@ namespace AtlasRoot {
       else if( var==egEnergyCorr::Scale::PSDown && m_aPSNom )
 	value = -m_aPSNom->GetBinError( m_aPSNom->FindBin(nearestEta) );
 
+      else if( var==egEnergyCorr::Scale::PSb12Up && m_daPSb12 )
+	value =  m_daPSb12->GetBinContent( m_daPSb12->FindBin(nearestEta) );
+
+      else if( var==egEnergyCorr::Scale::PSb12Down && m_daPSb12 )
+	value = -m_daPSb12->GetBinContent( m_daPSb12->FindBin(nearestEta) );
+
       else if( var==egEnergyCorr::Scale::LArElecUnconvUp && m_daPSCor )
 	value =  m_daPSCor->GetBinContent( m_daPSCor->FindBin(nearestEta) );
 
@@ -2244,20 +2457,21 @@ namespace AtlasRoot {
       else if (var == egEnergyCorr::Scale::S12Down && m_aS12Nom) { value = -m_aS12Nom->GetBinError(m_aS12Nom->FindBin(cl_eta)); }
       else if (var == egEnergyCorr::Scale::LArCalibUp && m_daS12Cor) { value = m_daS12Cor->GetBinContent(m_daS12Cor->FindBin(cl_eta)); }
       else if (var == egEnergyCorr::Scale::LArCalibDown && m_daS12Cor) { value = -m_daS12Cor->GetBinContent( m_daS12Cor->FindBin(cl_eta)); }
-      else if (var == egEnergyCorr::Scale::LArCalibExtra2015PreUp and 
+      else if (var == egEnergyCorr::Scale::LArCalibExtra2015PreUp and
 	       (m_esmodel == egEnergyCorr::es2015PRE or m_esmodel == egEnergyCorr::es2015PRE_res_improved or
 		m_esmodel == egEnergyCorr::es2015cPRE or m_esmodel == egEnergyCorr::es2015cPRE_res_improved or
 		m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE or m_esmodel == egEnergyCorr::es2017
-		or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE)) { 
+		or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE
+		or m_esmodel == egEnergyCorr::es2015_5TeV)) {
 	// special case for es2015PRE and also for es2015c_summer and also for es2017
 	// numbers from Lydia and Christophe,
 	// https://indico.cern.ch/event/395345/contribution/2/material/slides/0.pdf
 	// assuming constant uncertainty
 	// es2017_summer: increased to 5% in the endcap
-	const double aeta = std::abs(cl_eta); 
+	const double aeta = std::abs(cl_eta);
 	//endcap
 	if ( aeta >= 1.37 and aeta < 2.5){
-	  if ( m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE) value = 5.0E-2;
+	  if ( m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV) value = 5.0E-2;
 	  else value = 1.5E-2;
 	}
 	else{//barrel
@@ -2269,22 +2483,23 @@ namespace AtlasRoot {
                (m_esmodel == egEnergyCorr::es2015PRE or m_esmodel == egEnergyCorr::es2015PRE_res_improved or
                 m_esmodel == egEnergyCorr::es2015cPRE or m_esmodel == egEnergyCorr::es2015cPRE_res_improved or
                 m_esmodel == egEnergyCorr::es2015c_summer or m_esmodel == egEnergyCorr::es2016PRE or m_esmodel == egEnergyCorr::es2017
-		or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE)) {
-	const double aeta = std::abs(cl_eta);  
-        //endcap 
-        if ( aeta >= 1.37 and aeta < 2.5){ 
-          if ( m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE) value = -5.0E-2; 
-          else value = -1.5E-2; 
-        } 
-        else{//barrel 
-          if (m_esmodel == egEnergyCorr::es2017_summer_improved) value = -2.5E-2; 
-          else value = -1.5E-2; 
-        } 
-      }
-      
+		or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE
+		or m_esmodel == egEnergyCorr::es2015_5TeV)) {
+	const double aeta = std::abs(cl_eta);
+        //endcap
+        if ( aeta >= 1.37 and aeta < 2.5){
+          if ( m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV) value = -5.0E-2;
+          else value = -1.5E-2;
+        }
+        else{//barrel
+          if (m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2015_5TeV) value = -2.5E-2;
+          else value = -1.5E-2;
+        }
+      }
+
       else if (var == egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Up or var == egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Down) {
         // special large sys for run2 in the last eta-bin in es2017, see ATLASEG-42
-        if (m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE) {
+        if (m_esmodel == egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV) {
 	  const double aeta = std::abs(cl_eta);
 	  if (aeta >= 2.4 and aeta < 2.5) {
 	    if (var == egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Up) value = 25E-2;
@@ -2307,11 +2522,24 @@ namespace AtlasRoot {
     const double aeta = std::abs(cl_eta);
     const double ETGeV = energy / cosh(cl_eta) / 1E3;
 
-    TAxis* axis = nullptr;
-    TList* graphs = nullptr;
-    if (ptype == PATCore::ParticleType::Electron ) { axis = m_E4ElectronEtaBins; graphs = m_E4ElectronGraphs; }
-    else if (ptype == PATCore::ParticleType::UnconvertedPhoton) { axis = m_E4UnconvertedEtaBins; graphs = m_E4UnconvertedGraphs; }
-    else if (ptype == PATCore::ParticleType::ConvertedPhoton) { axis = m_E4ConvertedEtaBins; graphs = m_E4ConvertedGraphs; }
+    //This will point to the return of get() of a unique_ptr
+    TAxis* axis;
+    TList* graphs;
+
+    if (ptype == PATCore::ParticleType::Electron ) {
+      axis=(dynamic_cast<TAxis*>(m_E4ElectronEtaBins.get()));
+      graphs=(dynamic_cast<TList*>(m_E4ElectronGraphs.get()));
+      graphs->SetOwner();
+    } else if (ptype == PATCore::ParticleType::UnconvertedPhoton) {
+      axis=dynamic_cast<TAxis*>(m_E4UnconvertedEtaBins.get());
+      graphs=dynamic_cast<TList*>(m_E4UnconvertedGraphs.get());
+      graphs->SetOwner();
+    }
+    else if (ptype == PATCore::ParticleType::ConvertedPhoton) {
+      axis=dynamic_cast<TAxis*>(m_E4ConvertedEtaBins.get());
+      graphs=dynamic_cast<TList*>(m_E4ConvertedGraphs.get());
+      graphs->SetOwner();
+    }
     else { ATH_MSG_FATAL("invalid particle type"); return -1; }
 
 
@@ -2532,6 +2760,7 @@ namespace AtlasRoot {
 
     double DeltaX = getDeltaX(cl_eta, imat, var) - getDeltaX(cl_eta, imat, egEnergyCorr::Scale::Nominal);
 
+
     // calculate scale change per unit added material
 
     double DAlphaDXID, DAlphaDXCryo, DAlphaDXCalo, DAlphaDXGp;
@@ -2548,6 +2777,7 @@ namespace AtlasRoot {
       DAlphaDXCalo = m_matConvertedScale[geoCalo]->GetBinContent( m_matConvertedScale[geoCalo]->FindBin(cl_eta) );
     }
 
+
     // when in crack, use G', exit
 
     if( isInCrack(cl_eta) ) {
@@ -2580,6 +2810,7 @@ namespace AtlasRoot {
 
     // final value
 
+
     if( imat==egEnergyCorr::MatID )
       value = DeltaX * (DAlphaDXID - DAlphaDXCryo);
     else if( imat==egEnergyCorr::MatCryo )
@@ -2587,10 +2818,85 @@ namespace AtlasRoot {
     else if( imat==egEnergyCorr::MatCalo )
       value = DeltaX * DAlphaDXCalo;
 
+
     return value * varSF;
 
   }
 
+double egammaEnergyCorrectionTool::getMaterialEffect(egEnergyCorr::Geometry geo,PATCore::ParticleType::Type ptype,double cl_eta,double ET) const {
+
+  //Again this does no need to be ptr just get the one owned
+   TH2D* hmat;
+
+   if (ptype==PATCore::ParticleType::Electron) {
+      if (geo==egEnergyCorr::ConfigA) hmat=((TH2D*) m_electronBias_ConfigA.get());
+      else if (geo==egEnergyCorr::ConfigEL) hmat=((TH2D*)m_electronBias_ConfigEpLp.get());
+      else if (geo==egEnergyCorr::ConfigFMX) hmat=((TH2D*)m_electronBias_ConfigFpMX.get());
+      else if (geo==egEnergyCorr::ConfigN) hmat=((TH2D*)m_electronBias_ConfigN.get());
+      else if (geo==egEnergyCorr::ConfigIBL) hmat=((TH2D*)m_electronBias_ConfigIBL.get());
+      else if (geo==egEnergyCorr::ConfigPP0) hmat=((TH2D*)m_electronBias_ConfigPP0.get());
+      else return 0;
+   } else if (ptype==PATCore::ParticleType::UnconvertedPhoton) {
+      if (geo==egEnergyCorr::ConfigA) hmat=((TH2D*)m_unconvertedBias_ConfigA.get());
+      else if (geo==egEnergyCorr::ConfigEL) hmat=((TH2D*)m_unconvertedBias_ConfigEpLp.get());
+      else if (geo==egEnergyCorr::ConfigFMX) hmat=((TH2D*)m_unconvertedBias_ConfigFpMX.get());
+      else if (geo==egEnergyCorr::ConfigN) hmat=((TH2D*)m_unconvertedBias_ConfigN.get());
+      else if (geo==egEnergyCorr::ConfigIBL) hmat=((TH2D*)m_unconvertedBias_ConfigIBL.get());
+      else if (geo==egEnergyCorr::ConfigPP0) hmat=((TH2D*)m_unconvertedBias_ConfigIBL.get());
+      else return 0;
+   } else if (ptype==PATCore::ParticleType::ConvertedPhoton) {
+      if (geo==egEnergyCorr::ConfigA) hmat=((TH2D*)m_convertedBias_ConfigA.get());
+      else if (geo==egEnergyCorr::ConfigEL) hmat=((TH2D*)m_convertedBias_ConfigEpLp.get());
+      else if (geo==egEnergyCorr::ConfigFMX) hmat=((TH2D*)m_convertedBias_ConfigFpMX.get());
+      else if (geo==egEnergyCorr::ConfigN) hmat=((TH2D*)m_convertedBias_ConfigN.get());
+      else if (geo==egEnergyCorr::ConfigIBL) hmat=((TH2D*)m_convertedBias_ConfigIBL.get());
+      else if (geo==egEnergyCorr::ConfigPP0) hmat=((TH2D*)m_convertedBias_ConfigPP0.get());
+      else return 0;
+   } else return 0;
+
+
+
+
+
+   // use one bin in eta and linear interpolation in Et between 2 bins
+
+  double aeta=fabs(cl_eta);
+  int ieta = hmat->GetXaxis()->FindBin(aeta);
+
+  int ipt = hmat->GetYaxis()->FindBin(ET);
+  double ptBin = hmat->GetYaxis()->GetBinCenter(ipt);
+
+  int i1,i2;
+  double pt1,pt2;
+   if (ET>ptBin) {
+      i1=ipt;
+      i2=ipt+1;
+      pt1=ptBin;
+      pt2= hmat->GetYaxis()->GetBinCenter(i2);
+  }
+  else {
+     i1=ipt-1;
+     i2=ipt;
+     pt1=hmat->GetYaxis()->GetBinCenter(i1);
+     pt2=ptBin;
+  }
+
+  int nbins=hmat->GetYaxis()->GetNbins();
+  double value=0;
+  if (i1>=1 && i1 < nbins) {
+    double v1 = hmat->GetBinContent(ieta,i1);
+    double v2 = hmat->GetBinContent(ieta,i2);
+    value =  (v1*(pt2-ET) + v2*(ET-pt1)) / (pt2-pt1);
+  }
+  else{
+    if (ipt<1) ipt=1;
+    if (ipt>nbins) ipt=nbins;
+    value=hmat->GetBinContent(ieta,ipt);
+  }
+  return value;
+
+}
+
 
   // returns the energy dependence of the above (non-zero for electrons only).
 
@@ -2602,7 +2908,7 @@ namespace AtlasRoot {
     double value = 0;
     double ET = energy/cosh(cl_eta)/GeV;
 
-    if( ptype!=PATCore::ParticleType::Electron || var==egEnergyCorr::Scale::Nominal )
+    if( (ptype!=PATCore::ParticleType::Electron && (m_esmodel != egEnergyCorr::es2017_R21_v1 && m_esmodel != egEnergyCorr::es2017_R21_ofc0_v1 && m_esmodel != egEnergyCorr::es2018_R21_v0 &&  m_esmodel !=egEnergyCorr::es2018_R21_v1) )  || var==egEnergyCorr::Scale::Nominal )
       return value;
 
     egEnergyCorr::Geometry geoID, geoCryo, geoCalo, geoGp;
@@ -2611,23 +2917,43 @@ namespace AtlasRoot {
       geoCryo = egEnergyCorr::ConfigEL;
     else
       geoCryo = egEnergyCorr::ConfigFMX;
-    geoCalo = egEnergyCorr::ConfigFMX;
+
+    //   G.Unal 21.08.2018
+    // for Calo material use correctly ConfigN material for endcap (PS to Calo) in release 21 (not done for run 1, which used FMX in this case)
+    if (fabs(cl_eta)>1.52 && (m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 ||  m_esmodel == egEnergyCorr::es2018_R21_v1))
+      geoCalo = egEnergyCorr::ConfigN;
+    else
+      geoCalo = egEnergyCorr::ConfigFMX;
     geoGp = egEnergyCorr::ConfigGp;
 
     // look up material bias
 
     double DeltaX = getDeltaX(cl_eta, imat, var) - getDeltaX(cl_eta, imat, egEnergyCorr::Scale::Nominal);
 
+
     // calculate scale change per unit added material
 
-    int ialpha = m_matElectronEtaBins->FindBin( fabs(cl_eta) ) - 1;
-    if (ialpha<0 || ialpha>=m_matElectronGraphs[geoGp]->GetSize())
-      return 0.;
+    // G.Unal 21.08.2019 new code called for release 21 sensivitities
+
+    double DAlphaDXGp,DAlphaDXID,DAlphaDXCryo,DAlphaDXCalo;
+
+    if (m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 ||  m_esmodel == egEnergyCorr::es2018_R21_v1) {
+       DAlphaDXGp = getMaterialEffect(egEnergyCorr::ConfigFMX,ptype,cl_eta,ET);   // no G' in release 21, use FMX for the crack
+       DAlphaDXID = getMaterialEffect(geoID,ptype,cl_eta,ET);
+       DAlphaDXCryo = getMaterialEffect(geoCryo,ptype,cl_eta,ET);
+       DAlphaDXCalo = getMaterialEffect(geoCalo,ptype,cl_eta,ET);
+
+    } else {
+      int ialpha = m_matElectronEtaBins->FindBin( fabs(cl_eta) ) - 1;
+      if (ialpha<0 || ialpha>=m_matElectronGraphs[geoGp]->GetSize())
+        return 0.;
+
+      DAlphaDXGp   = ((TGraphErrors*)m_matElectronGraphs[geoGp]->At(ialpha))->GetFunction("fNonLin")->Eval( ET );
+      DAlphaDXID   = ((TGraphErrors*)m_matElectronGraphs[geoID]->At(ialpha))->GetFunction("fNonLin")->Eval( ET );
+      DAlphaDXCryo = ((TGraphErrors*)m_matElectronGraphs[geoCryo]->At(ialpha))->GetFunction("fNonLin")->Eval( ET );
+      DAlphaDXCalo = ((TGraphErrors*)m_matElectronGraphs[geoCalo]->At(ialpha))->GetFunction("fNonLin")->Eval( ET );
+    }
 
-    double DAlphaDXGp   = ((TGraphErrors*)m_matElectronGraphs[geoGp]->At(ialpha))->GetFunction("fNonLin")->Eval( ET );
-    double DAlphaDXID   = ((TGraphErrors*)m_matElectronGraphs[geoID]->At(ialpha))->GetFunction("fNonLin")->Eval( ET );
-    double DAlphaDXCryo = ((TGraphErrors*)m_matElectronGraphs[geoCryo]->At(ialpha))->GetFunction("fNonLin")->Eval( ET );
-    double DAlphaDXCalo = ((TGraphErrors*)m_matElectronGraphs[geoCalo]->At(ialpha))->GetFunction("fNonLin")->Eval( ET );
 
     // when in crack, use G', exit
 
@@ -2643,19 +2969,28 @@ namespace AtlasRoot {
     if(idx<1 || idx>m_matX0Additions[geoID]->GetNbinsX())
       DAlphaDXID = 0;
     else
-      DAlphaDXID /= m_matX0Additions[geoID]->GetBinContent(idx);
+    {
+      if (m_matX0Additions[geoID]->GetBinContent(idx) >0.) DAlphaDXID /= m_matX0Additions[geoID]->GetBinContent(idx);
+      else DAlphaDXID=0.;
+    }
 
     idx = m_matX0Additions[geoCryo]->FindBin( fabs(cl_eta) );
     if(idx<1 || idx>m_matX0Additions[geoCryo]->GetNbinsX())
       DAlphaDXCryo = 0;
     else
-      DAlphaDXCryo /= m_matX0Additions[geoCryo]->GetBinContent(idx);
+    {
+      if (m_matX0Additions[geoCryo]->GetBinContent(idx)>0.) DAlphaDXCryo /= m_matX0Additions[geoCryo]->GetBinContent(idx);
+      else DAlphaDXCryo=0.;
+    }
 
     idx = m_matX0Additions[geoCalo]->FindBin( fabs(cl_eta) );
     if(idx<1 || idx>m_matX0Additions[geoCalo]->GetNbinsX())
       DAlphaDXCalo = 0;
     else
-      DAlphaDXCalo /= m_matX0Additions[geoCalo]->GetBinContent(idx);
+    {
+      if (m_matX0Additions[geoCalo]->GetBinContent(idx)>0.) DAlphaDXCalo /= m_matX0Additions[geoCalo]->GetBinContent(idx);
+      else DAlphaDXCalo=0.;
+    }
 
     // final value
 
@@ -2666,6 +3001,7 @@ namespace AtlasRoot {
     else if( imat==egEnergyCorr::MatCalo )
       value = DeltaX * DAlphaDXCalo;
 
+
     return value * varSF;
 
   }
@@ -2746,7 +3082,7 @@ namespace AtlasRoot {
 	alpha = delta / (energy / cosh(cl_eta));
 	if (var == egEnergyCorr::Scale::PedestalDown) alpha *= -1;
       }
-      else if(m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_R21_PRE){
+      else if(m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final or m_esmodel == egEnergyCorr::es2017_R21_PRE or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2017_R21_v0 or  m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or m_esmodel == egEnergyCorr::es2018_R21_v1){
 	//Et uncertainty band: 10 MeV for the corrected cluster
 	alpha = 10. / (energy / cosh(cl_eta));
 	if (var == egEnergyCorr::Scale::PedestalDown) alpha *= -1;
@@ -2836,14 +3172,25 @@ namespace AtlasRoot {
   }
 
 
-  double egammaEnergyCorrectionTool::pileUpTerm(double eta, int particle_type) const {
+  double egammaEnergyCorrectionTool::pileUpTerm(double energy, double eta, int particle_type) const {
+
+    double pileupNoise;
 
-    // approximate pileup noise addition to the total noise in MeV   for <mu_data> (2012) = 20
-    // converted photons and electrons
-    double pileupNoise=240.;
-    // unconverted photons, different values in barrel and end-cap
-    if (particle_type==1) {
+    // release 21 for <mu> =32 (combined 2015-2016-2017 dataset), pileup noise = f(Et) for superclusters
+    if (m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or m_esmodel == egEnergyCorr::es2018_R21_v1) {
+       double et = energy/cosh(eta);
+       if (et<5000.) et=5000.;
+       if (et>50000.) et=50000.;
+       pileupNoise=sqrt(32.)*(60.+40.*log(et/10000.)/log(5.));
+    }
+    else {
+      // approximate pileup noise addition to the total noise in MeV   for <mu_data> (2012) = 20
+      // converted photons and electrons
+      pileupNoise=240.;
+      // unconverted photons, different values in barrel and end-cap
+      if (particle_type==1) {
       if (fabs(eta)<1.4) pileupNoise=200.;
+      }
     }
     return pileupNoise;
 
@@ -2859,9 +3206,10 @@ namespace AtlasRoot {
 							     double& resolution_error,
                                                              double& resolution_error_up,
                                                              double& resolution_error_down,
-							     int resol_type) const {
+							     int resol_type,
+                                                             bool fast) const {
 
-    double pileupNoise =  pileUpTerm(eta, particle_type);
+    double pileupNoise =  pileUpTerm(energy,eta, particle_type);
     double et = energy/cosh(eta);
 
     resolution = m_resolution_tool->getResolution(particle_type,energy,eta,resol_type);
@@ -2876,8 +3224,7 @@ namespace AtlasRoot {
     double sum_deltaDown=0.;
     double sum_deltaUp=0.;
 
-
-    for (int isys=0;isys<9;isys++) {
+    for (int isys=0;isys<10;isys++) {
 
       if (syst_mask & (1<<isys) ) {
 
@@ -2950,13 +3297,30 @@ namespace AtlasRoot {
 
 	// systematics from pileup noise  on total noise (200 MeV in quadrature, somewhat conservative)
 	if (isys==6) {
-	  double et = energy/cosh(eta);
-	  double deltaPileupNoise=100.; // MeV
-	  if (std::abs(eta)>=1.4 && std::abs(eta)<1.8) deltaPileupNoise=200.; // larger systematic in this eta bin
-	  double scaleNcells=1;
-	  if (particle_type==1 && std::abs(eta)<1.4) scaleNcells = sqrt(3./5.);   // cluster=3X5 instead of 3x7, rms scales with cluster area
-	  double sigmaPileUp = deltaPileupNoise*scaleNcells/et;
-	  double sigmaZ = deltaPileupNoise/(40000.); // effect for Z->ee at Et=40 GeV
+
+          double et = energy/cosh(eta);
+          double sigmaPileUp=0.;
+          double sigmaZ=0.;
+          // release 21 - 10% uncertainty on pileup noise
+          if (m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or  m_esmodel == egEnergyCorr::es2018_R21_v1) {
+              double deltaNoise = sqrt(1.1*1.1-1.0)*pileupNoise;  // uncertainty in quadrature 1.1*noise - noise
+              sigmaPileUp = deltaNoise/et;   // sigmaE/E impact
+              sigmaZ = deltaNoise/40000.;    // sigmaE/E for Z->ee electrons (absorbed in smearing correction)
+          }
+          // no pileup noise uncertainty for es2017_R21_ofc0_v1
+          else if (m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1) {
+            sigmaPileUp=0.;
+            sigmaZ=0.;
+          }
+          else {
+           // older models
+	    double deltaPileupNoise=100.; // MeV
+	    if (std::abs(eta)>=1.4 && std::abs(eta)<1.8) deltaPileupNoise=200.; // larger systematic in this eta bin
+	    double scaleNcells=1;
+	    if (particle_type==1 && std::abs(eta)<1.4) scaleNcells = sqrt(3./5.);   // cluster=3X5 instead of 3x7, rms scales with cluster area
+	    sigmaPileUp = deltaPileupNoise*scaleNcells/et;
+	    sigmaZ = deltaPileupNoise/(40000.); // effect for Z->ee at Et=40 GeV
+          }
 	  sigma2=sigmaPileUp*sigmaPileUp-sigmaZ*sigmaZ;
 	  sigma2up = sigma2;
 	  sigma2down = -1.*sigma2;
@@ -2964,7 +3328,7 @@ namespace AtlasRoot {
 	}
 
 	// systematics from material in IBL+PP0 for barrel
-	if (isys==7 && fabs(eta)<1.5  && (m_esmodel==egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved)) {
+	if (isys==7 && fabs(eta)<1.5  && (m_esmodel==egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or  m_esmodel == egEnergyCorr::es2018_R21_v1)) {
 	  double  sigmaE = m_getMaterialDelta->getDelta(particle_type,energy,eta,1,5);
 	  sigma2 = sigmaE*sigmaE;
 	  sigma2up = sigma2;
@@ -2973,7 +3337,7 @@ namespace AtlasRoot {
 	}
 
 	// systematics from material in IBL+PP0 for end-cap
-	if (isys==8 && fabs(eta)>1.5 && (m_esmodel==egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved)) {
+	if (isys==8 && fabs(eta)>1.5 && (m_esmodel==egEnergyCorr::es2017 or m_esmodel == egEnergyCorr::es2017_summer or m_esmodel == egEnergyCorr::es2017_summer_improved or m_esmodel == egEnergyCorr::es2017_summer_final or m_esmodel == egEnergyCorr::es2015_5TeV or m_esmodel == egEnergyCorr::es2017_R21_v0 or m_esmodel == egEnergyCorr::es2017_R21_v1 or m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 or m_esmodel == egEnergyCorr::es2018_R21_v0 or  m_esmodel == egEnergyCorr::es2018_R21_v1)) {
 	  double sigmaE =  m_getMaterialDelta->getDelta(particle_type,energy,eta,1,5);
 	  // scale factor 2.3 in X0 => sqrt(2) in resolution or 2 in resolution**2
 	  sigma2 = 2.3*sigmaE*sigmaE;
@@ -2983,6 +3347,17 @@ namespace AtlasRoot {
 
 	}
 
+        // AF2 resolution systematics for es2017_R21_v1 model (neglected before that...)
+
+        if (isys==9 && (m_esmodel == egEnergyCorr::es2017_R21_v1 || m_esmodel == egEnergyCorr::es2017_R21_ofc0_v1 || m_esmodel == egEnergyCorr::es2018_R21_v0 || m_esmodel == egEnergyCorr::es2018_R21_v1) && fast) {
+           const double ptGeV = et/1e3;
+           if(particle_type == 0) sigma2 = getValueHistAt(*m_G4OverAFII_resolution_electron,eta,ptGeV,true,true,true,true);
+           if(particle_type == 1) sigma2 = getValueHistAt(*m_G4OverAFII_resolution_unconverted,eta,ptGeV,true,true,true,true);
+           if(particle_type == 2) sigma2 = getValueHistAt(*m_G4OverAFII_resolution_converted,eta,ptGeV,true,true,true,true);
+           sigma2up = -1.*sigma2;  // AF2 resolution worse than full Sim, sigma2up gives back AF2 resolution
+           sigma2down = sigma2;
+        }
+
 
 //  old method to use max of up and down for All
 /*
@@ -3016,7 +3391,7 @@ namespace AtlasRoot {
 	else rr2=0.;
 	double deltaSigmaDown = (rr2-resolution)/resolution;
 	//std::cout << " relative resolution change Down " << deltaSigmaDown << std::endl;
-	
+
 	sum_deltaUp += deltaSigmaUp;
 	sum_deltaDown += deltaSigmaDown;
 
@@ -3030,7 +3405,7 @@ namespace AtlasRoot {
     resolution_error_up = sum_deltaUp*resolution;
     resolution_error_down = sum_deltaDown*resolution;
 
-    
+
     //std::cout << " Resolution (MeV): " << resolution << "   Resolution Error (MeV): " << resolution_error
     //	      << " Z smearing " << smearingZ << " +- " << esmearingZ << std::endl;
 
@@ -3064,6 +3439,8 @@ namespace AtlasRoot {
     case egEnergyCorr::Scale::G4Down: return "G4Down";
     case egEnergyCorr::Scale::PSUp: return "PSUp";
     case egEnergyCorr::Scale::PSDown: return "PSDown";
+    case egEnergyCorr::Scale::PSb12Up: return "PSb12Up";
+    case egEnergyCorr::Scale::PSb12Down: return "PSb12Down";
     case egEnergyCorr::Scale::S12Up: return "S12Up";
     case egEnergyCorr::Scale::S12Down: return "S12Down";
     case egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Up: return "S12ExtraLastEtaBinRun2Up";
@@ -3133,116 +3510,27 @@ namespace AtlasRoot {
       case egEnergyCorr::Resolution::MaterialPP0Down: return "Resolution::MaterialPP0Down";
       case egEnergyCorr::Resolution::MaterialIBLUp: return "Resolution::MaterialIBLUp";
       case egEnergyCorr::Resolution::MaterialIBLDown: return "Resolution::MaterialIBLDown";
+      case egEnergyCorr::Resolution::af2Up: return "Resolution::af2Up";
+      case egEnergyCorr::Resolution::af2Down: return "Resolution::af2Down";
       case egEnergyCorr::Resolution::LastResolutionVariation: return "LastResolutionVariation";
       default: return "Resolution::Unknown";
     }
   }
 
 
-  egEnergyCorr::Scale::Variation egammaEnergyCorrectionTool::ScaleVariationFromString(string& var) {
-
-    egEnergyCorr::Scale::Variation TheVar = egEnergyCorr::Scale::None;
-
-    if( var == "None" )                        TheVar = egEnergyCorr::Scale::None;
-    else if( var == "Nominal" )                TheVar = egEnergyCorr::Scale::Nominal;
-    else if( var == "MomentumUp" )             TheVar = egEnergyCorr::Scale::MomentumUp;
-    else if( var == "MomentumDown" )           TheVar = egEnergyCorr::Scale::MomentumDown;
-    else if( var == "ZeeStatUp" )              TheVar = egEnergyCorr::Scale::ZeeStatUp;
-    else if( var == "ZeeStatDown" )            TheVar = egEnergyCorr::Scale::ZeeStatDown;
-    else if( var == "ZeeSystUp" )              TheVar = egEnergyCorr::Scale::ZeeSystUp;
-    else if( var == "ZeeSystDown" )            TheVar = egEnergyCorr::Scale::ZeeSystDown;
-    else if( var == "ZeePhysUp" )              TheVar = egEnergyCorr::Scale::ZeePhysUp;
-    else if( var == "ZeePhysDown" )            TheVar = egEnergyCorr::Scale::ZeePhysDown;
-    else if( var == "ZeeAllUp" )               TheVar = egEnergyCorr::Scale::ZeeAllUp;
-    else if( var == "ZeeAllDown" )             TheVar = egEnergyCorr::Scale::ZeeAllDown;
-    else if( var == "LArCalibUp" )             TheVar = egEnergyCorr::Scale::LArCalibUp;
-    else if( var == "LArCalibDown" )           TheVar = egEnergyCorr::Scale::LArCalibDown;
-    else if( var == "LArUnconvCalibUp" )       TheVar = egEnergyCorr::Scale::LArUnconvCalibUp;
-    else if( var == "LArUnconvCalibDown" )     TheVar = egEnergyCorr::Scale::LArUnconvCalibDown;
-    else if( var == "LArElecCalibUp" )         TheVar = egEnergyCorr::Scale::LArElecCalibUp;
-    else if( var == "LArElecCalibDown" )       TheVar = egEnergyCorr::Scale::LArElecCalibDown;
-    else if( var == "LArElecUnconvUp" )        TheVar = egEnergyCorr::Scale::LArElecUnconvUp;
-    else if( var == "LArElecUnconvDown" )      TheVar = egEnergyCorr::Scale::LArElecUnconvDown;
-    else if( var == "G4Up" )                   TheVar = egEnergyCorr::Scale::G4Up;
-    else if( var == "G4Down" )                 TheVar = egEnergyCorr::Scale::G4Down;
-    else if( var == "PSUp" )                   TheVar = egEnergyCorr::Scale::PSUp;
-    else if( var == "PSDown" )                 TheVar = egEnergyCorr::Scale::PSDown;
-    else if( var == "S12Up" )                  TheVar = egEnergyCorr::Scale::S12Up;
-    else if( var == "S12Down" )                TheVar = egEnergyCorr::Scale::S12Down;
-    else if( var == "S12ExtraLastEtaBinRun2Up") TheVar = egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Up;
-    else if( var == "S12ExtraLastEtaBinRun2Down") TheVar = egEnergyCorr::Scale::S12ExtraLastEtaBinRun2Down;
-    else if( var == "MatPP0Up")                TheVar = egEnergyCorr::Scale::MatPP0Up;
-    else if( var == "MatPP0Down")                TheVar = egEnergyCorr::Scale::MatPP0Down;
-    else if( var == "MatIDUp" )                TheVar = egEnergyCorr::Scale::MatIDUp;
-    else if( var == "MatIDDown" )              TheVar = egEnergyCorr::Scale::MatIDDown;
-    else if( var == "MatCryoUp" )              TheVar = egEnergyCorr::Scale::MatCryoUp;
-    else if( var == "MatCryoDown" )            TheVar = egEnergyCorr::Scale::MatCryoDown;
-    else if( var == "MatCaloUp" )              TheVar = egEnergyCorr::Scale::MatCaloUp;
-    else if( var == "MatCaloDown" )            TheVar = egEnergyCorr::Scale::MatCaloDown;
-    else if( var == "L1GainUp" )               TheVar = egEnergyCorr::Scale::L1GainUp;
-    else if( var == "L1GainDown" )             TheVar = egEnergyCorr::Scale::L1GainDown;
-    else if( var == "L2GainUp" )               TheVar = egEnergyCorr::Scale::L2GainUp;
-    else if( var == "L2GainDown" )             TheVar = egEnergyCorr::Scale::L2GainDown;
-    else if( var == "LeakageConvUp" )          TheVar = egEnergyCorr::Scale::LeakageConvUp;
-    else if( var == "LeakageConvDown" )        TheVar = egEnergyCorr::Scale::LeakageConvDown;
-    else if( var == "LeakageUnconvUp" )        TheVar = egEnergyCorr::Scale::LeakageUnconvUp;
-    else if( var == "LeakageUnconvDown" )      TheVar = egEnergyCorr::Scale::LeakageUnconvDown;
-    else if( var == "ConvEfficiencyUp" )       TheVar = egEnergyCorr::Scale::ConvEfficiencyUp;
-    else if( var == "ConvEfficiencyDown" )     TheVar = egEnergyCorr::Scale::ConvEfficiencyDown;
-    else if( var == "ConvFakeRateUp" )         TheVar = egEnergyCorr::Scale::ConvFakeRateUp;
-    else if( var == "ConvFakeRateDown" )       TheVar = egEnergyCorr::Scale::ConvFakeRateDown;
-    else if( var == "ConvRadiusUp" )           TheVar = egEnergyCorr::Scale::ConvRadiusUp;
-    else if( var == "ConvRadiusDown" )         TheVar = egEnergyCorr::Scale::ConvRadiusDown;
-    else if( var == "PedestalUp" )             TheVar = egEnergyCorr::Scale::PedestalUp;
-    else if( var == "PedestalDown" )           TheVar = egEnergyCorr::Scale::PedestalDown;
-    else if( var == "AllUp" )                  TheVar = egEnergyCorr::Scale::AllUp;
-    else if( var == "AllDown" )                TheVar = egEnergyCorr::Scale::AllDown;
-    else if( var == "LastScaleVariation" )     TheVar = egEnergyCorr::Scale::LastScaleVariation;
-
-    return TheVar;
-
-  }
-
-
-  egEnergyCorr::Resolution::Variation egammaEnergyCorrectionTool::ResolutionVariationFromString(string& var) {
-
-    egEnergyCorr::Resolution::Variation TheVar  = egEnergyCorr::Resolution::None;
-
-    if ( var == "None") TheVar = egEnergyCorr::Resolution::None;
-    else if ( var == "Nominal")                   TheVar = egEnergyCorr::Resolution::Nominal;
-    else if ( var == "AllDown")                   TheVar = egEnergyCorr::Resolution::AllDown;
-    else if ( var == "AllUp")                     TheVar = egEnergyCorr::Resolution::AllUp;
-    else if ( var == "ZSmearingUp")               TheVar = egEnergyCorr::Resolution::ZSmearingUp;
-    else if ( var == "ZSmearingDown")             TheVar = egEnergyCorr::Resolution::ZSmearingDown;
-    else if ( var == "SamplingTermUp")            TheVar = egEnergyCorr::Resolution::SamplingTermUp;
-    else if ( var == "SamplingTermDown")          TheVar = egEnergyCorr::Resolution::SamplingTermDown;
-    else if ( var == "MaterialIDUp")              TheVar = egEnergyCorr::Resolution::MaterialIDUp;
-    else if ( var == "MaterialIDDown")            TheVar = egEnergyCorr::Resolution::MaterialIDDown;
-    else if ( var == "MaterialCaloUp")            TheVar = egEnergyCorr::Resolution::MaterialCaloUp;
-    else if ( var == "MaterialCaloDown")          TheVar = egEnergyCorr::Resolution::MaterialCaloDown;
-    else if ( var == "MaterialCryoUp")            TheVar = egEnergyCorr::Resolution::MaterialCryoUp;
-    else if ( var == "MaterialCryoDown")          TheVar = egEnergyCorr::Resolution::MaterialCryoDown;
-    else if ( var == "MaterialGapUp")             TheVar = egEnergyCorr::Resolution::MaterialGapUp;
-    else if ( var == "MaterialGapDown")           TheVar = egEnergyCorr::Resolution::MaterialGapDown;
-    else if ( var == "MaterialIBLUp")             TheVar = egEnergyCorr::Resolution::MaterialIBLUp;
-    else if ( var == "MaterialIBLDown")           TheVar = egEnergyCorr::Resolution::MaterialIBLDown;
-    else if ( var == "MaterialPP0Up")             TheVar = egEnergyCorr::Resolution::MaterialPP0Up;
-    else if ( var == "MaterialPP0Down")           TheVar = egEnergyCorr::Resolution::MaterialPP0Down;
-    else if ( var == "PileUpUp")                  TheVar = egEnergyCorr::Resolution::PileUpUp;
-    else if ( var == "PileUpDown")                TheVar = egEnergyCorr::Resolution::PileUpDown;
-    else if ( var == "LastResolutionVariation")   TheVar = egEnergyCorr::Resolution::LastResolutionVariation;
-
-    return TheVar;
-
-  }
-
   double egammaEnergyCorrectionTool::get_ZeeSyst(double eta) const
   {
     const auto ieta = m_zeeSyst->GetXaxis()->FindFixBin(eta);
     auto value_histo = m_zeeSyst->GetBinContent(ieta);
+
     return value_histo;
   }
 
+  const TAxis& egammaEnergyCorrectionTool::get_ZeeStat_eta_axis() const
+  {
+    return *m_zeeNom->GetXaxis();
+  }
+
 
 
 } // egRescaler
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/get_MaterialResolutionEffect.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/get_MaterialResolutionEffect.cxx
index 21cbd955decddd0849108144f795ebfd6fc9ccf4..bd90b147b6fd74f4c01d53c5f76d0fb475f79657 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/get_MaterialResolutionEffect.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/Root/get_MaterialResolutionEffect.cxx
@@ -1,24 +1,26 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "ElectronPhotonFourMomentumCorrection/get_MaterialResolutionEffect.h"
 
 #include "PathResolver/PathResolver.h"
 
-#include <stdlib.h>
-#include "TAxis.h"
 #include "Riostream.h"
 
+#include "TH1.h"
+#include "TH2.h"
+#include "TFile.h"
+#include "TArrayD.h"
+
 get_MaterialResolutionEffect::get_MaterialResolutionEffect()
   : asg::AsgMessaging("get_MaterialResolutionEffect")
 {
   //std::cout << " Initialize get_MaterialResolutionEffect " << std::endl;
 
   const std::string filename = PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v8/histos-systematics-material.root");
-  
-  
-  m_file0 = std::make_unique<TFile>(filename.c_str());
+
+  m_file0.reset(TFile::Open( filename.c_str(), "READ" ));
 
   for (Int_t isys=0;isys<4;isys++) {
     for (Int_t ieta=0;ieta<8;ieta++) {
@@ -37,9 +39,11 @@ get_MaterialResolutionEffect::get_MaterialResolutionEffect()
          if (isys==1 && iconv==2) sprintf(name,"systConv_CD_etaBin_%d",ieta);
          if (isys==2 && iconv==2) sprintf(name,"systConv_EL_etaBin_%d",ieta);
          if (isys==3 && iconv==2) sprintf(name,"systConv_FMX_etaBin_%d",ieta);
-         
-         if (!(m_hSystPeak[isys][ieta][iconv]=(TH1D*) m_file0->Get(name))) ATH_MSG_FATAL("cannot find histogram " << name << " in file '" << filename << "'");
-	 
+
+         m_hSystPeak.at(isys).at(ieta).at(iconv).reset( dynamic_cast<TH1*>(m_file0->Get(name)));
+         m_hSystPeak.at(isys).at(ieta).at(iconv)->SetDirectory( nullptr );
+         if (!m_hSystPeak.at(isys).at(ieta).at(iconv).get()) ATH_MSG_FATAL("cannot find histogram " << name << " in file '" << filename << "'");
+
 
          if (isys==0 && iconv==0) sprintf(name,"systElec_sigmaG_A_etaBin_%d",ieta);
          if (isys==1 && iconv==0) sprintf(name,"systElec_sigmaG_CD_etaBin_%d",ieta);
@@ -55,24 +59,32 @@ get_MaterialResolutionEffect::get_MaterialResolutionEffect()
          if (isys==2 && iconv==2) sprintf(name,"systConv_sigmaG_EL_etaBin_%d",ieta);
          if (isys==3 && iconv==2) sprintf(name,"systConv_sigmaG_FMX_etaBin_%d",ieta);
 
-         if (!(m_hSystResol[isys][ieta][iconv]=(TH1D*) m_file0->Get(name))) ATH_MSG_FATAL("cannot find histogram " << name << " in file '" << filename << "'");
-      }      
+         m_hSystResol.at(isys).at(ieta).at(iconv).reset( dynamic_cast<TH1*>(m_file0->Get(name)));
+         m_hSystResol.at(isys).at(ieta).at(iconv)->SetDirectory( nullptr );
+         if (!(m_hSystResol.at(isys).at(ieta).at(iconv).get())) ATH_MSG_FATAL("cannot find histogram " << name << " in file '" << filename << "'");
+      }
     }
   }
 
    // IBL+PP0 material systematics stored in 2D file
-  if (!(m_hsyst_IBL_PP0[0]=(TH2D*) m_file0->Get("systElec_IBLPP0"))) ATH_MSG_FATAL("cannot find histogram systElec_IBLPP0 in file '" << filename << "'");
-  if (!(m_hsyst_IBL_PP0[1]=(TH2D*) m_file0->Get("systUnconv_IBLPP0"))) ATH_MSG_FATAL("cannot find histogram systUnconv_IBLPP0 in file '" << filename << "'");
-  if (!(m_hsyst_IBL_PP0[2]=(TH2D*) m_file0->Get("systConv_IBLPP0"))) ATH_MSG_FATAL("cannot find histogram systConv_IBLPP0 in file '" << filename << "'");
-   
+  m_hsyst_IBL_PP0.at(0).reset(dynamic_cast<TH2*>(m_file0->Get("systElec_IBLPP0")));
+  m_hsyst_IBL_PP0.at(0)->SetDirectory( nullptr );
+  if (!(m_hsyst_IBL_PP0.at(0).get())) ATH_MSG_FATAL("cannot find histogram systElec_IBLPP0 in file '" << filename << "'");
+  m_hsyst_IBL_PP0.at(1).reset(dynamic_cast<TH2*>(m_file0->Get("systUnconv_IBLPP0")));
+  m_hsyst_IBL_PP0.at(1)->SetDirectory( nullptr );
+
+  if (!(m_hsyst_IBL_PP0.at(1).get())) ATH_MSG_FATAL("cannot find histogram systUnconv_IBLPP0 in file '" << filename << "'");
+  m_hsyst_IBL_PP0.at(2).reset(dynamic_cast<TH2*>(m_file0->Get("systConv_IBLPP0")));
+  m_hsyst_IBL_PP0.at(2)->SetDirectory( nullptr );
+  if (!(m_hsyst_IBL_PP0.at(2).get())) ATH_MSG_FATAL("cannot find histogram systConv_IBLPP0 in file '" << filename << "'");
+
 
-  TAxis* aa=m_hSystResol[0][0][1]->GetXaxis();
-  m_etBins = aa->GetXbins();
+  m_etBins=m_hSystResol.at(0).at(0).at(1)->GetXaxis()->GetXbins();
 }
 
 //=========================================================================
 get_MaterialResolutionEffect::~get_MaterialResolutionEffect(){
-  m_file0->Close();
+  ///m_file0->Close();
 }
 
 //============================================================================
@@ -99,7 +111,8 @@ double get_MaterialResolutionEffect::getDelta(int particle_type, double energy,
       double et2=et;
       if (et<5.) et2=5.1;
       if (et>2000) et2=1999.;
-      return 0.01*m_hsyst_IBL_PP0[particle_type]->GetBinContent(m_hsyst_IBL_PP0[particle_type]->GetXaxis()->FindBin(aeta),m_hsyst_IBL_PP0[particle_type]->GetYaxis()->FindBin(et2));
+      if (particle_type==3) particle_type=2;
+      return 0.01*m_hsyst_IBL_PP0.at(particle_type)->GetBinContent(m_hsyst_IBL_PP0.at(particle_type)->GetXaxis()->FindBin(aeta),m_hsyst_IBL_PP0.at(particle_type)->GetYaxis()->FindBin(et2));
    }
 
 
@@ -126,10 +139,10 @@ double get_MaterialResolutionEffect::getDelta(int particle_type, double energy,
    //cout << " m_hSystResol " << m_hSystResol[isyst][ieta][particle_type] << endl;
 
    if (response_type==0) {
-      return 0.01*m_hSystPeak[isyst][ieta][particle_type]->GetBinContent(ibinEt+1);
+      return 0.01*m_hSystPeak.at(isyst).at(ieta).at(particle_type)->GetBinContent(ibinEt+1);
    }
    else {
-      return 0.01*m_hSystResol[isyst][ieta][particle_type]->GetBinContent(ibinEt+1);
+      return 0.01*m_hSystResol.at(isyst).at(ieta).at(particle_type)->GetBinContent(ibinEt+1);
    }
 
 }
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/create_input.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/create_input.py
index 2ca30ec2f423869a92bbc7e005c0ede0dad357a0..f1b161dacf85c9de9a8ee08ee542c60e02e86e3a 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/create_input.py
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/create_input.py
@@ -2,8 +2,6 @@
 
 # this file do not work out of the box
 
-from __future__ import print_function
-
 import ROOT
 from array import array
 import numpy as np
@@ -41,7 +39,7 @@ assert ct_sys_christophe
 def qsum_histograms(histo1, histo2):
     new_histo = histo1.Clone()
     new_histo.Reset()
-    for ibin in range(histo1.GetNbinsX() + 2):
+    for ibin in xrange(histo1.GetNbinsX() + 2):
         value1 = histo1.GetBinContent(ibin)
         central_value = histo1.GetBinCenter(ibin)
         ibin2 = histo2.FindBin(central_value)
@@ -129,7 +127,7 @@ def merge_histograms(old, new, merge_error=True):
     UNDERFLOW = 0
     OVERFLOW = new.GetNbinsX() + 1
 
-    for iold in range(1, old.GetNbinsX()):
+    for iold in xrange(1, old.GetNbinsX()):
         l = old.GetBinLowEdge(iold)
         r = l + old.GetBinWidth(iold)
 
@@ -153,7 +151,7 @@ def merge_histograms(old, new, merge_error=True):
             break
     last_old = iold
 
-    for inew in range(1, new.GetNbinsX() + 1):
+    for inew in xrange(1, new.GetNbinsX() + 1):
         l = new.GetBinLowEdge(inew)
         r = l + new.GetBinWidth(inew)
         new_binning.append((l, r))
@@ -165,7 +163,7 @@ def merge_histograms(old, new, merge_error=True):
         new_values.append(old.GetBinContent(remainer))
         new_errors.append(old.GetBinError(remainer))
 
-    for iold in range(last_old, old.GetNbinsX() + 1):
+    for iold in xrange(last_old, old.GetNbinsX() + 1):
         l = old.GetBinLowEdge(iold)
         r = l + old.GetBinWidth(iold)
 
@@ -227,7 +225,7 @@ histo_ct.SetName("ctZee_errStat")
 # this created a file structured as the official one, with empty directories
 #output_file = create_structured_file("calibration_constants_run2.root")
 import shutil
-print (old_filename)
+print(old_filename)
 shutil.copy2(old_filename, "xxx.root")
 output_file = ROOT.TFile("xxx.root", "update")
 create_new_directories(output_file)
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/dump_layer.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/dump_layer.py
index 7b8f7d46ab6dc2e1be7d63aae40547854e8b2c0c..42f5aa849b457a45faf34b41d7af5b542d8a581c 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/dump_layer.py
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/dump_layer.py
@@ -11,8 +11,6 @@ The output of this tool is needed to generate single particle from scratch and
 then to compute the decomposition of the covariance matrix.
 """
 
-from __future__ import print_function
-
 import ROOT
 from glob import glob
 from array import array
@@ -23,7 +21,7 @@ def main(path, particle):
     chain = ROOT.TChain("egamma")
     for f in files:
         chain.Add(f)
-    print ("entries:", chain.GetEntries())
+    print("entries:", chain.GetEntries())
 
     selection = {"unconv": "(ph_Rconv >= 800 || ph_Rconv <= 0)",
                  "conv": "(ph_Rconv < 800 && ph_Rconv > 0)",
@@ -62,14 +60,14 @@ def main(path, particle):
         vars_to_plot.append("ph_zconv")
         title.append("ph_zconv")
 
-    print ("plotting counting")
+    print("plotting counting")
     histo_name = "histo_count_%s" % particle
     histo_count = ROOT.TH2F(histo_name, "count %s" % particle, len(pt_binning) - 1, pt_binning, len(aeta_binning) - 1, aeta_binning)
     chain.Draw(aetaCalo + ":" + truth_pt + ">>" + histo_name, selection)
 
     result = []
     for t, v in zip(title, vars_to_plot):
-        print ("plotting", v)
+        print("plotting", v)
         histo_name = "histo_%s_%s" % (particle, t)
         if "zconv" in v:
             sel = selection + " && abs(ph_zconv) < 5000"
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/merge_scale_histograms.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/merge_scale_histograms.py
index b1e6f84a0748dec3cc40f7ca8756920765c89433..12548deec608a8b987000f970a951dd89968082d 100755
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/merge_scale_histograms.py
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/merge_scale_histograms.py
@@ -2,8 +2,6 @@
 
 # Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-from __future__ import print_function
-
 
 doc = """
 This is an utility to merge histograms. The common case is when you have
@@ -18,16 +16,16 @@ logging.basicConfig(level=logging.INFO)
 from array import array
 
 def merge_histograms(old, new, merge_error=True):
-    print ("old binning: " + ", ".join(("%.3f" % old.GetBinLowEdge(ibin)) for ibin in range(1, old.GetNbinsX() + 2)))
-    print ("new binning: " + ", ".join(("%.3f" % new.GetBinLowEdge(ibin)) for ibin in range(1, new.GetNbinsX() + 2)))
-    
+    print("old binning: " + ", ".join(("%.3f" % old.GetBinLowEdge(ibin)) for ibin in xrange(1, old.GetNbinsX() + 2)))
+    print("new binning: " + ", ".join(("%.3f" % new.GetBinLowEdge(ibin)) for ibin in xrange(1, new.GetNbinsX() + 2)))
+
     new_binning = []
     new_values = []
     new_errors = []
     UNDERFLOW = 0
     OVERFLOW = new.GetNbinsX() + 1
 
-    for iold in range(1, old.GetNbinsX()):
+    for iold in xrange(1, old.GetNbinsX()):
         l = old.GetBinLowEdge(iold)
         r = l + old.GetBinWidth(iold)
 
@@ -36,7 +34,7 @@ def merge_histograms(old, new, merge_error=True):
         remainer = None
 
         if il_new == UNDERFLOW and ir_new == UNDERFLOW:
-            print ("1. adding %.3f - %.3f from old" % (l, r))
+            print("1. adding %.3f - %.3f from old" % (l, r))
             new_binning.append((l, r))
             new_values.append(old.GetBinContent(iold))
             new_errors.append(old.GetBinError(iold))
@@ -49,25 +47,25 @@ def merge_histograms(old, new, merge_error=True):
             new_errors.append(old.GetBinError(iold))
             if ir_new == OVERFLOW:
                 remainer = iold
-            print ("breaking")
+            print("breaking")
             break
     last_old = iold
 
-    for inew in range(1, new.GetNbinsX() + 1):
+    for inew in xrange(1, new.GetNbinsX() + 1):
         l = new.GetBinLowEdge(inew)
         r = l + new.GetBinWidth(inew)
-        print ("2. adding %.3f - %.3f from new" % (l, r))
+        print("2. adding %.3f - %.3f from new" % (l, r))
         new_binning.append((l, r))
         new_values.append(new.GetBinContent(inew))
         new_errors.append(new.GetBinError(inew))
     """
     if remainer is not None:
-        print ("3. adding %.3f - %.3f from old" % (new.GetBinLowEdge(new.GetNbinsX()), old.GetBinLowEdge(remainer) + old.GetBinWidth(remainer)))
+        print("3. adding %.3f - %.3f from old" % (new.GetBinLowEdge(new.GetNbinsX()), old.GetBinLowEdge(remainer) + old.GetBinWidth(remainer)))
         new_binning.append((new.GetBinLowEdge(new.GetNbinsX()), old.GetBinLowEdge(remainer) + old.GetBinWidth(remainer)))
         new_values.append(old.GetBinContent(remainer))
         new_errors.append(old.GetBinError(remainer))
     """
-    for iold in range(last_old, old.GetNbinsX() + 1):
+    for iold in xrange(last_old, old.GetNbinsX() + 1):
         l = old.GetBinLowEdge(iold)
         r = l + old.GetBinWidth(iold)
 
@@ -75,7 +73,7 @@ def merge_histograms(old, new, merge_error=True):
         ir_new = new.FindFixBin(r)
 
         if il_new == OVERFLOW and ir_new == OVERFLOW:
-            print ("4. adding %.3f - %.3f from old" % (l, r))
+            print("4. adding %.3f - %.3f from old" % (l, r))
             new_binning.append((l, r))
             new_values.append(old.GetBinContent(iold))
             new_errors.append(old.GetBinError(iold))
@@ -86,7 +84,7 @@ def merge_histograms(old, new, merge_error=True):
             new_values.append(old.GetBinContent(iold))
             new_errors.append(old.GetBinError(iold))
 
-    print (new_binning)
+    print(new_binning)
     new_edges = array('f', [x[0] for x in new_binning] + [new_binning[-1][1]])
     histo_type = type(new)
     result = histo_type(new.GetName(), new.GetTitle(), len(new_edges) - 1, new_edges)
@@ -95,9 +93,9 @@ def merge_histograms(old, new, merge_error=True):
         if merge_error:
             result.SetBinError(i, e)
 
-    print ("merged binning: " + ", ".join(("%.3f" % result.GetBinLowEdge(ibin)) for ibin in range(1, result.GetNbinsX() + 1)))
+    print("merged binning: " + ", ".join(("%.3f" % result.GetBinLowEdge(ibin)) for ibin in xrange(1, result.GetNbinsX() + 1)))
+
 
-            
     return result
 
 
@@ -160,7 +158,7 @@ example (merge ct sys 2015PRE + 2015 summer): ./merge_scale_histograms.py ../../
     legend.AddEntry(histo_new, "new")
     legend.SetBorderSize(0)
     legend.Draw()
-    
+
     fout = ROOT.TFile.Open(args.output_filename, "recreate" if args.recreate else "update")
     if args.title is not None:
         histo_merged.SetTitle(args.title)
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot.py
index c160785459cce37f4da820337792d94551a3ab69..ad16fedfaff2bde5b5a6bbf843fb96462f156898 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot.py
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot.py
@@ -1,19 +1,25 @@
 #!/usr/bin/env python
-# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-from __future__ import print_function
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 import numpy as np
 import logging
 import os
-from itertools import tee, izip, cycle, chain
+from itertools import tee, izip, cycle, chain, product
 import matplotlib as mpl
+mpl.use('Agg')
 import matplotlib.pyplot as plt
 import matplotlib.patches as patches
-
+from matplotlib.ticker import MaxNLocator
+import matplotlib.lines as mlines
+import tqdm
+import colorlog
+import seaborn as sns
+from functools import wraps
+import time
+from fnmatch import fnmatch
 import ROOT
 ROOT.PyConfig.IgnoreCommandLineOptions = True
-logging.basicConfig(level=logging.INFO)
 
 plt.rcParams['image.cmap'] = 'coolwarm'  # RdBu_r
 
@@ -22,17 +28,13 @@ rcParams['font.family'] = 'sans-serif'
 rcParams['mathtext.fontset'] = 'stixsans'
 rcParams['mathtext.default'] = 'rm'
 rcParams['font.sans-serif'] = 'helvetica, Helvetica, Nimbus Sans L, Mukti Narrow, FreeSans'
-rcParams['figure.figsize'] = 8.75, 5.92
-#rcParams['figure.facecolor'] = 'white'
-rcParams['figure.subplot.bottom'] = 0.16
-rcParams['figure.subplot.top'] = 0.95
-rcParams['figure.subplot.left'] = 0.16
-rcParams['figure.subplot.right'] = 0.95
 
 # axes
 rcParams['axes.labelsize'] = 20
 rcParams['xtick.minor.visible'] = True
 rcParams['ytick.minor.visible'] = True
+rcParams['xtick.direction'] = 'in'
+rcParams['ytick.direction'] = 'in'
 rcParams['xtick.labelsize'] = 19
 rcParams['xtick.major.size'] = 12
 rcParams['xtick.minor.size'] = 6
@@ -40,6 +42,8 @@ rcParams['ytick.labelsize'] = 19
 rcParams['ytick.major.size'] = 14
 rcParams['ytick.minor.size'] = 7
 rcParams['lines.markersize'] = 8
+rcParams['ytick.right'] = True
+rcParams['xtick.top'] = True
 # rcParams['lines.markeredgewidth'] = 0. # not working, it changes other stuff
 
 # legend
@@ -50,6 +54,29 @@ rcParams['legend.labelspacing'] = 0.3
 
 extensions = 'pdf', 'png'
 
+
+def check_status_code(func):
+    def wrapper(self, *args):
+        status = func(self, *args)
+        if not status.isSuccess():
+            raise ValueError('status is not success')
+        return status
+    return wrapper
+
+ROOT.CP.EgammaCalibrationAndSmearingTool.initialize = check_status_code(ROOT.CP.EgammaCalibrationAndSmearingTool.initialize)
+
+
+def timed(method):
+    @wraps(method)
+    def timed(*args, **kw):
+        ts = time.time()
+        result = method(*args, **kw)
+        te = time.time()
+
+        log.info("function %s run in  %d second", method.__name__, te-ts)
+        return result
+    return timed
+
 def plot_ATLAS(fig, x, y, label='Internal', fontsize=20):
     l = fig.text(x, y, 'ATLAS', fontsize=fontsize, fontstyle='italic', fontweight='bold')
     def on_draw(event):
@@ -68,12 +95,27 @@ def pairwise(iterable):
     next(b, None)
     return izip(a, b)
 
+def divide_square(n, horizontal=True):
+    if horizontal:
+        x = np.ceil(np.sqrt(n))
+        y = np.floor(np.sqrt(n))
+        if (x * y) < n:
+            x += 1
+    else:
+        x = np.floor(np.sqrt(n))
+        y = np.ceil(np.sqrt(n))
+        if (x * y) < n:
+            y += 1
+    return int(x), int(y)
+
+
+
 def histo2data(histo):
     xs = []
     ys = []
     exs = []
     eys = []
-    for ibin in range(1, histo.GetNbinsX() + 1):
+    for ibin in xrange(1, histo.GetNbinsX() + 1):
         xs.append(histo.GetBinCenter(ibin))
         ys.append(histo.GetBinContent(ibin))
         eys.append(histo.GetBinError(ibin))
@@ -81,6 +123,19 @@ def histo2data(histo):
     return np.array(xs), np.array(exs), np.array(ys), np.array(eys)
 
 
+def systematics_from_tool(tool, only_scale=True, only_resolution=False, only_up=True):
+    _ = tool.recommendedSystematics()
+    for sys in _:
+        sys_name = sys.name()
+        if only_scale and 'RESOLUTION' in sys_name:
+            continue
+        if only_resolution and 'SCALE' in sys_name:
+            continue
+        if only_up and '1down' in sys_name:
+            continue
+        yield sys
+
+
 def partition(x, n):
     r = []
     for xx in x:
@@ -104,12 +159,14 @@ def generator_photon(self):
     store.clear()
 
 
-def eval_sys_eta_pt(tool, etas, pts, simulation=True, particle='unconverted'):
+def calibrate_eta_pt(tool, etas, pts, simulation=True, particle='unconverted'):
+    log.debug("creating TEvent and EgammaFactory")
     event = ROOT.xAOD.TEvent()
     factory = ROOT.EgammaFactory()
     result = np.ones((len(pts), len(etas)))
     ei = factory.create_eventinfo(simulation, 266904)
     assert ei.eventType(ROOT.xAOD.EventInfo.IS_SIMULATION) == simulation
+    log.debug("looping")
     for ieta, eta in enumerate(etas):
         for ipt, pt in enumerate(pts):
             if particle == 'unconverted':
@@ -121,7 +178,9 @@ def eval_sys_eta_pt(tool, etas, pts, simulation=True, particle='unconverted'):
             else:
                 raise ValueError()
             result[ipt, ieta] = tool.getEnergy(p, ei)
+    log.debug("deleting event")
     del event
+    log.debug("returning result %s" % result)
     return result
 
 
@@ -148,7 +207,7 @@ def eval_sys_eta_phi(tool, etas, phis, pt, simulation, particle='unconverted'):
 def eval_eta_slice(tool, etas, pts, ptype, only_material=False, only_up=True):
     sys_set = ROOT.CP.SystematicSet()
     tool.applySystematicVariation(sys_set)
-    nominal = eval_sys_eta_pt(tool, etas, pts, particle=ptype)
+    nominal = calibrate_eta_pt(tool, etas, pts, particle=ptype)
     all_syst = tool.recommendedSystematics()
 
     results = {}
@@ -161,16 +220,16 @@ def eval_eta_slice(tool, etas, pts, ptype, only_material=False, only_up=True):
         if only_material:
             if 'MAT' not in sys_name:
                 continue
-        logging.info("plotting sys %s", sys_name)
+        log.info("computing sys %s, %d eta samplings", sys_name, len(etas))
         sys_set = ROOT.CP.SystematicSet()
         sys_set.insert(sys)
         tool.applySystematicVariation(sys_set)
 
-        sys = eval_sys_eta_pt(tool, etas, pts, particle=ptype)
+        sys = calibrate_eta_pt(tool, etas, pts, particle=ptype)
 
         ratio = sys / nominal
 
-        ratio = np.average(ratio - 1, axis=1)
+        ratio = np.average(ratio - 1, axis=1)  # average the supersampling
         results[sys_name] = ratio
     return results
 
@@ -181,17 +240,22 @@ def beautify_sysname(sysname):
          "EG_SCALE_L1GAIN": "L1 gain",
          "EG_SCALE_PS": r"$\alpha_{PS}$",
          "EG_SCALE_S12": r"$\alpha_{1/2}$",
-         "EG_SCALE_ZEESYST": r"$Z\to ee$ calibration (sys)",
+         "EG_SCALE_S12EXTRALASTETABINRUN2": r"$\alpha_{1/2}$ [2.4-2.5]",
+         "EG_SCALE_ZEESYST": r"$Z\to ee$ cal. (sys)",
+         "EG_SCALE_ZEESTAT": r"$Z\to ee$ cal. (stat)",
          "PH_SCALE_LEAKAGEUNCONV": "Leakage unconverted",
          "EG_SCALE_MATID": "ID material",
          "EG_SCALE_MATCRYO": "Cryo material",
+         "EG_SCALE_MATPP0": "PP0 material",
+         "EG_SCALE_WTOTS1": "$w_{tots1}$ non-lin.",
          "EG_SCALE_CONVEFFICIENCY": "Conversion efficiency",
          "EG_SCALE_MATCALO": "Calo material",
          "EG_SCALE_ZEE_STAT": r"$Z\to ee$ (stat)",
          "EG_SCALE_G4": "Geant4",
-         "EG_SCALE_LEAKAGECONV": "Leakage converted",
-         "PH_SCALE_CONV_RATIUS": "Conversion radius",
-         "PH_SCALE_CONVFAKERATE": "Conversion fake rate",
+         "PH_SCALE_LEAKAGECONV": "Leakage converted",
+         "PH_SCALE_CONVRADIUS": "Conv. radius",
+         "PH_SCALE_CONVFAKERATE": "Conv. fake rate",
+         "PH_SCALE_CONVEFFICIENCY": "Conv. efficiency",
          "EG_SCALE_LARCALIB": r"$\alpha_{1/2}$ $\mu\to e$ extrap.",
          "EG_SCALE_E4SCINTILLATOR": "Scintillators",
          "EG_SCALE_LARTEMPERATURE_EXTRA2016PRE": r"Temp. 2015 $\to$ 2016",
@@ -205,14 +269,17 @@ def beautify_particle(particle):
          'unconverted': 'Unconverted photons'}
     return d.get(particle, particle).capitalize()
 
-def plot_all_syst_eta_slice(etabins, netas=3, esmodel='es2012c',
-                            decorrelation='FULL_v1', ptype='unconverted',
+def plot_all_syst_eta_slice(etabins, supersampling_eta=3, esmodel='es2012c', decorrelation='FULL_v1', ptype='unconverted', pts=np.logspace(np.log10(5E3), 6, 100),
                             basedir='plot', only_material=False, beautify_sysnames=False,
-                            sys_paper_order=False, superimpose_all=False, skip_null_sys=False, yrange=None, only_up=True, debug=False, legend_outside=False, symmetrize_labels=False):
+                            sys_order=None, superimpose_all=False, skip_null_sys=False, min_sys=-0.02, max_sys=0.02,
+                            only_up=True, debug=False, legend_outside=False, symmetrize_labels=False, log_x=False,
+                            plot_qsum=False, abs_sys=False, atlas_label='Internal'):
     tool = ROOT.CP.EgammaCalibrationAndSmearingTool("tool")
     tool.setProperty("ESModel", esmodel)
     tool.setProperty("decorrelationModel", decorrelation)
     tool.setProperty("int")("doSmearing", 0)
+    log.warning('setting randomRunNumber to 297730')
+    tool.setProperty("int")("randomRunNumber", 297730)
     if debug:
         tool.msg().setLevel(0)
 
@@ -223,38 +290,50 @@ def plot_all_syst_eta_slice(etabins, netas=3, esmodel='es2012c',
         tool_all.setProperty("ESModel", esmodel)
         tool_all.setProperty("decorrelationModel", "1NP_v1")
         tool_all.setProperty("int")("doSmearing", 0)
+        log.warning('setting randomRunNumber to 297730')
+        tool_all.setProperty("int")("randomRunNumber", 297730)
         tool_all.initialize()
 
 
-    pts = np.logspace(np.log10(5E3), 6, 100)
 
     # compute the eta-inclusive one, just to sort
+    log.info('compute sys inclusively, just to sort sys by importance')
     results = eval_eta_slice(tool, np.linspace(-2.5, 2.5, 20),
                              np.linspace(10E3, 200E3, 10),       # use this range to mimic the range in the paper
                              ptype, only_material)
     sorted_sys_name = sorted(list(results), key=lambda k: -np.max(np.abs(results[k])))
     if skip_null_sys:
         sorted_sys_name = [sys_name for sys_name in sorted_sys_name if np.sum(results[sys_name]) != 0]
-    if sys_paper_order:
-        partitions = [["EG_SCALE_PS__1up", "EG_SCALE_S12__1up", "EG_SCALE_LARCALIB__1up", "EG_SCALE_L2GAIN__1up"],
-                      ["EG_SCALE_MATID__1up", "EG_SCALE_MATCRYO__1up", "EG_SCALE_MATCALO__1up", "EG_SCALE_ZEESYST__1up"]]
-        if esmodel == "es2016PRE":
-            partitions += [["EG_SCALE_PEDESTAL__1up", "EG_SCALE_LARCALIB_EXTRA2015PRE__1up", "EG_SCALE_LARTEMPERATURE_EXTRA2016PRE__1up", "EG_SCALE_E4SCINTILLATOR__1up"]]
-
-        remainers = [item for item in sorted_sys_name if item not in list(np.array(partitions).flatten())]
+    if sys_order:
+        if sys_order == 'paper_run1':
+            partitions = [["EG_SCALE_PS__1up", "EG_SCALE_S12__1up", "EG_SCALE_LARCALIB__1up", "EG_SCALE_L2GAIN__1up"],
+                          ["EG_SCALE_MATID__1up", "EG_SCALE_MATCRYO__1up", "EG_SCALE_MATCALO__1up", "EG_SCALE_ZEESYST__1up"]]
+            if esmodel == "es2016PRE":
+                partitions += [["EG_SCALE_PEDESTAL__1up", "EG_SCALE_LARCALIB_EXTRA2015PRE__1up", "EG_SCALE_LARTEMPERATURE_EXTRA2016PRE__1up", "EG_SCALE_E4SCINTILLATOR__1up"]]
+        elif sys_order == 'paper_run2':
+            partitions = [["EG_SCALE_PS__1up", "EG_SCALE_S12__1up", "EG_SCALE_LARCALIB__1up", "EG_SCALE_LARCALIB_EXTRA2015PRE__1up", "EG_SCALE_S12EXTRALASTETABINRUN2"],
+                          ["EG_SCALE_MATID__1up", "EG_SCALE_MATCRYO__1up", "EG_SCALE_MATCALO__1up", "EG_SCALE_MATPP0__1up", "EG_SCALE_ZEESYST__1up"],
+                          ["EG_SCALE_L2GAIN__1up", "EG_SCALE_WTOTS1__1up", "EG_SCALE_PEDESTAL__1up", "EG_SCALE_E4SCINTILLATOR__1up"],
+                          ["PH_SCALE_CONVEFFICIENCY__1up", "PH_SCALE_CONVFAKERATE__1up", "PH_SCALE_CONVRADIUS__1up", "PH_SCALE_LEAKAGECONV__1up", "PH_SCALE_LEAKAGEUNCONV__1up"]]
+        flat_list = [item for sublist in partitions for item in sublist]
+        remainers = [item for item in sorted_sys_name if item not in flat_list]
         partitions = chain(partitions, partition(remainers, 4))
     else:
         partitions = partition(sorted_sys_name, 4)
     partitions = list(partitions)
 
-    for etamin, etamax in etabins:
-        etas = np.linspace(etamin, etamax, netas)
+    for etamin, etamax in tqdm.tqdm(etabins):
+        log.info('plotting eta range %.2f %.2f', etamin, etamax)
+        etas = np.linspace(etamin, etamax, supersampling_eta + 2)[1:-1]
         results = eval_eta_slice(tool, etas, pts, ptype, only_material, only_up=only_up)
+        qsum = np.sqrt((np.array(results.values()) ** 2).sum(axis=0))
 
         if superimpose_all:
             results_all = eval_eta_slice(tool_all, etas, pts, ptype, only_up=False)
 
         for ip, p in enumerate(partitions):
+            log.info('plotting %d/%d', ip + 1, len(partitions))
+
             f, ax = plt.subplots()
             if superimpose_all:
                 #max_up_down = np.max(np.abs([results_all["EG_SCALE_ALL__1down"],
@@ -263,12 +342,17 @@ def plot_all_syst_eta_slice(etabins, netas=3, esmodel='es2012c',
                                 #color='0.8', label='total')
                 #ax.plot(pts/1E3, np.sqrt(np.sum([r ** 2 for r in results.values()], axis=0)) * 100., 'r:')
                 if only_up:
-                    ax.fill_between(pts / 1E3, -results_all["EG_SCALE_ALL__1up"] * 100., results_all["EG_SCALE_ALL__1up"] * 100,
+                    if abs_sys:
+                        ax.fill_between(pts / 1E3, 0, results_all["EG_SCALE_ALL__1up"] * 100,
+                                    color='0.8', label='Total')
+                    else:
+                        ax.fill_between(pts / 1E3, -results_all["EG_SCALE_ALL__1up"] * 100., results_all["EG_SCALE_ALL__1up"] * 100,
                                     color='0.8', label='Total')
                 else:
                     ax.fill_between(pts / 1E3, results_all["EG_SCALE_ALL__1down"] * 100., results_all["EG_SCALE_ALL__1up"] * 100,
                                     color='0.8', label='Total')
-            for sys_name in p:
+            for isys, sys_name in enumerate(p):
+                color = 'C%d' % isys  # TODO: fix, use cycle
                 if sys_name not in results:
                     continue  ## TODO: FIXME
                 r = results[sys_name]
@@ -276,7 +360,13 @@ def plot_all_syst_eta_slice(etabins, netas=3, esmodel='es2012c',
                 sys_label = beautify_sysname(sys_name.replace('__1up', '')) if beautify_sysnames else sys_name
                 if not only_up:
                     sys_label += " UP"
-                ax.semilogx(pts / 1E3, r * 100., label=sys_label)
+                if abs_sys:
+                    mask_positive = r >= 0
+                    r = np.abs(r)
+                    ax.plot(pts[mask_positive] / 1E3, r[mask_positive] * 100., label=sys_label, color=color)
+                    ax.plot(pts[~mask_positive] / 1E3, r[~mask_positive] * 100., "--", color=color)
+                else:
+                    ax.plot(pts / 1E3, r * 100., label=sys_label, color=color)
 
             if not only_up:
                 ax.set_prop_cycle(None)
@@ -288,38 +378,46 @@ def plot_all_syst_eta_slice(etabins, netas=3, esmodel='es2012c',
                     r[np.isnan(r)] = 0
                     sys_label = beautify_sysname(sys_name.replace('__1down', '')) if beautify_sysnames else sys_name
                     sys_label += ' DOWN'
-                    ax.semilogx(pts / 1E3, r * 100., label=sys_label, linestyle='--')
+                    ax.plot(pts / 1E3, r * 100., label=sys_label, linestyle='--')
 
-            ax.set_xlabel('$E_T$ [GeV]', ha='right', x=1., fontsize=22)
-            ax.set_ylabel('Signed uncertainty [%]', ha='right', y=1., fontsize=22)
-            ax.tick_params(axis='both', which='major', labelsize=20)
+            if plot_qsum:
+                ax.plot(pts / 1E3, qsum * 100, label='quadrature sum', linestyle=':')
 
-            ax.axis('tight')
-            if yrange is None:
-                if only_material:
-                    vmax = 1.
-                else:
-                    vmax = max(2, np.max(np.abs(ax.get_ylim())))
-                ax.set_ylim(-vmax, vmax)
+            ax.set_xlabel('$E_T$ [GeV]', ha='right', x=1., fontsize=19)
+            if abs_sys:
+                ax.set_ylabel('Uncertainty [%]', ha='right', y=1., fontsize=19)
             else:
-                ax.set_ylim(*yrange)
+                ax.set_ylabel('Signed uncertainty [%]', ha='right', y=1., fontsize=19)
+
+            ax.tick_params(axis='both', which='major', labelsize=17)
+
+            ax.axis('tight')
+
+            if max_sys is None and min_sys is None:
+                max_sys = max(2, np.max(np.abs(ax.get_ylim())))
+                min_sys = -max_sys
+
+            ax.set_ylim(min_sys * 100, max_sys * 100)
 
             if legend_outside:
                 ax.legend(bbox_to_anchor=(0., 1., 1, 0.2), mode='expand', borderaxespad=0.,
                           loc=3, frameon=True, fontsize=17 if only_up else 14, borderpad=1, ncol=1 if only_up else 2)
                 f.subplots_adjust(top=0.65)
-                plot_ATLAS(f, 0.2, 0.58, label='Internal')
+                plot_ATLAS(f, 0.2, 0.58, label=atlas_label)
                 f.text(0.2, 0.2, beautify_particle(ptype), transform=ax.transAxes, fontsize=16)
                 f.text(0.2, 0.25, r'$%.2f < \eta < %.2f$' % (etamin, etamax), transform=ax.transAxes, fontsize=16)
             else:
-                ax.legend(loc=1, frameon=False, fontsize=17 if only_up else 14, borderpad=1, ncol=1 if only_up else 2)
+                ax.legend(loc=1, frameon=False, fontsize=13 if only_up else 9, borderpad=1, ncol=1 if only_up else 2)
+
+                plot_ATLAS(f, 0.16, 0.80, label=atlas_label, fontsize=19)
+                f.text(0.16, 0.74, beautify_particle(ptype), transform=ax.transAxes, fontsize=16)
+                f.text(0.16, 0.68, r'$%.2f < \eta < %.2f$' % (etamin, etamax), transform=ax.transAxes, fontsize=16)
 
-                plot_ATLAS(f, 0.2, 0.85, label='Internal', fontsize=21)
-                f.text(0.2, 0.80, beautify_particle(ptype), transform=ax.transAxes, fontsize=16)
-                f.text(0.2, 0.75, r'$%.2f < \eta < %.2f$' % (etamin, etamax), transform=ax.transAxes, fontsize=16)
+            if log_x:
+                ax.set_xscale('log')
 
             for extension in extensions:
-                f.savefig(os.path.join(basedir, "%s_%s_%.2f_%.2f_%d.%s" % (ptype, decorrelation, etamin, etamax, ip, extension)))
+                f.savefig(os.path.join(basedir, "%s_%s_%s_%.2f_%.2f_%d.%s" % (ptype, esmodel, decorrelation, etamin, etamax, ip, extension)), bbox_inches='tight')
             plt.close(f)
 
 
@@ -353,9 +451,9 @@ def plot_all_Zee_syst(etas, pt=100E3, basedir='plots'):
 
     tools = [tool_es2012c, tool_es2015PRE_notemp, tool_es2015PRE]
 
-    nominal_es2012c = eval_sys_eta_pt(tool_es2012c, etas, [pt], particle='electron')[0]
-    nominal_es2015PRE = eval_sys_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
-    nominal_es2015PRE_notemp = eval_sys_eta_pt(tool_es2015PRE_notemp, etas, [pt], particle='electron')[0]
+    nominal_es2012c = calibrate_eta_pt(tool_es2012c, etas, [pt], particle='electron')[0]
+    nominal_es2015PRE = calibrate_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
+    nominal_es2015PRE_notemp = calibrate_eta_pt(tool_es2015PRE_notemp, etas, [pt], particle='electron')[0]
 
     # up variations
     sys = ROOT.CP.SystematicVariation('EG_SCALE_ZEESYST', 1)
@@ -365,9 +463,9 @@ def plot_all_Zee_syst(etas, pt=100E3, basedir='plots'):
     for tool in tools:
         tool.applySystematicVariation(sys_set)
 
-    sys_up_es2012c = eval_sys_eta_pt(tool_es2012c, etas, [pt], particle='electron')[0]
-    sys_up_es2015PRE = eval_sys_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
-    sys_up_es2015PRE_notemp = eval_sys_eta_pt(tool_es2015PRE_notemp, etas, [pt], particle='electron')[0]
+    sys_up_es2012c = calibrate_eta_pt(tool_es2012c, etas, [pt], particle='electron')[0]
+    sys_up_es2015PRE = calibrate_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
+    sys_up_es2015PRE_notemp = calibrate_eta_pt(tool_es2015PRE_notemp, etas, [pt], particle='electron')[0]
 
     ratio_sys_up_es2012c = sys_up_es2012c / nominal_es2012c - 1
     ratio_sys_up_es2015PRE = sys_up_es2015PRE / nominal_es2015PRE - 1
@@ -381,9 +479,9 @@ def plot_all_Zee_syst(etas, pt=100E3, basedir='plots'):
     for tool in tools:
         tool.applySystematicVariation(sys_set)
 
-    sys_down_es2012c = eval_sys_eta_pt(tool_es2012c, etas, [pt], particle='electron')[0]
-    sys_down_es2015PRE = eval_sys_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
-    sys_down_es2015PRE_notemp = eval_sys_eta_pt(tool_es2015PRE_notemp, etas, [pt], particle='electron')[0]
+    sys_down_es2012c = calibrate_eta_pt(tool_es2012c, etas, [pt], particle='electron')[0]
+    sys_down_es2015PRE = calibrate_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
+    sys_down_es2015PRE_notemp = calibrate_eta_pt(tool_es2015PRE_notemp, etas, [pt], particle='electron')[0]
 
     ratio_sys_down_es2012c = sys_down_es2012c / nominal_es2012c - 1
     ratio_sys_down_es2015PRE = sys_down_es2015PRE / nominal_es2015PRE - 1
@@ -394,7 +492,7 @@ def plot_all_Zee_syst(etas, pt=100E3, basedir='plots'):
     sys_set = ROOT.CP.SystematicSet()
     sys_set.insert(sys)
     tool_es2015PRE.applySystematicVariation(sys_set)
-    stat_up_es2015PRE = eval_sys_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
+    stat_up_es2015PRE = calibrate_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
     ratio_stat_up = stat_up_es2015PRE / nominal_es2015PRE - 1
 
 
@@ -403,7 +501,7 @@ def plot_all_Zee_syst(etas, pt=100E3, basedir='plots'):
     sys_set = ROOT.CP.SystematicSet()
     sys_set.insert(sys)
     tool_es2015PRE.applySystematicVariation(sys_set)
-    stat_down_es2015PRE = eval_sys_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
+    stat_down_es2015PRE = calibrate_eta_pt(tool_es2015PRE, etas, [pt], particle='electron')[0]
     ratio_stat_down = stat_down_es2015PRE / nominal_es2015PRE - 1
 
     ratio_full_down = -np.sqrt(ratio_stat_down ** 2 + ratio_sys_down_es2015PRE ** 2)
@@ -459,19 +557,19 @@ def plot_all_syst_fixed_pt(tools, names, labels, pt=100E3, ptype='unconverted',
         tool.applySystematicVariation(empty_set)
     etas_histo = np.linspace(-5, 5, 101, True)
     etas = 0.5 * (etas_histo[1:] + etas_histo[:-1])
-    nominals = [eval_sys_eta_pt(tool, etas, [pt], particle=ptype)[0] for tool in tools]
+    nominals = [calibrate_eta_pt(tool, etas, [pt], particle=ptype)[0] for tool in tools]
     all_syst = tools[0].recommendedSystematics()
     for sys in all_syst:
         sys_name = sys.name()
         sys_set = ROOT.CP.SystematicSet()
         sys_set.insert(sys)
-        logging.info("plotting sys %s %s", sys_name, ptype)
+        log.info("plotting sys %s %s", sys_name, ptype)
 
         f, ax = plt.subplots()
 
         for tool, nominal, name, label in zip(tools, nominals, names, labels):
             tool.applySystematicVariation(sys_set)
-            sys = eval_sys_eta_pt(tool, etas, [pt], particle=ptype)[0]
+            sys = calibrate_eta_pt(tool, etas, [pt], particle=ptype)[0]
             ratio = sys / nominal - 1
             ax.plot(etas, ratio * 100, label=label)
             histo = values2histo(name + "_" + sys_name, label, etas_histo, ratio * 100)
@@ -486,53 +584,251 @@ def plot_all_syst_fixed_pt(tools, names, labels, pt=100E3, ptype='unconverted',
             f.savefig(os.path.join(basedir, "%s_%s_pt_%.2f.%s" % (ptype, sys_name, pt / 1E3, extension)))
         plt.close(f)
 
+def get_property_from_tool(tool, property_name):
+    # really?
+    result = ROOT.std.string()
+    status = tool.getPropertyMgr().getProperty(property_name).getString(result)
+    if not status.isSuccess():
+        raise ValueError("cannot find property %s in tool %s" % (property_name, tool))
+    return str(ss)[1:-1]
+
+
+def compute_or_read_sys(tool, ptypes, eta_edges, pt_edges):
+    empty_set = ROOT.CP.SystematicSet()
+
+    eta_edges = np.asarray(eta_edges)
+    pt_edges = np.asarray(pt_edges)
+
+    # TODO: replace midpoints with supersampling
+    eta_midpoints = 0.5 * (eta_edges[1:] + eta_edges[:-1])
+    pt_midpoints = 0.5 * (pt_edges[1:] + pt_edges[:-1])
+
+    log.debug("getting list of systematics")
+    all_syst = tool.recommendedSystematics()
+    log.debug("%d systematics found", len(all_syst))
+
+    results = {ptype: {} for ptype in ptypes}
+
+    with tqdm.tqdm(total=len(ptypes) * (len(all_syst) + 1), leave=False) as pbar:
+        for iptype, ptype in enumerate(ptypes):
+            log.debug("computing for particle=%s", ptype)
+            tool.applySystematicVariation(empty_set)
+            log.debug("computing nominal energies for eta=%s, pt=%s, particle=%s", eta_midpoints, pt_midpoints, ptype)
+
+            values_nominal = calibrate_eta_pt(tool, eta_midpoints, pt_midpoints, particle=ptype)
+            pbar.update(1)
+
+            for isys, sys in enumerate(all_syst):
+                sys_name = sys.name()
+                sys_set = ROOT.CP.SystematicSet()
+                sys_set.insert(sys)
+                tool.applySystematicVariation(sys_set)
+                values_sys = calibrate_eta_pt(tool, eta_midpoints, pt_midpoints, particle=ptype)
+                ratio = values_sys / values_nominal - 1
+
+                results[ptype][sys_name] = ratio
+                pbar.update(1)
+
+    return results
+
+@timed
+def compare_sys(esmodels=None, ptypes=None, decorrelation='FULL_ETACORRELATED_v1', eta_edges=None, pt_edges=None, basedir='plots', smearing=False, only_up=True, abs_sys=False, log_x=False):
+    esmodels = esmodels or ['es2012c']
+    ptypes = ptypes or ['electron']
+    if pt_edges is None:
+        pt_edges = np.linspace(0, 100, 5)
+    if eta_edges is None:
+        eta_edges = np.array([0, 0.6, 1.0, 1.37, 1.55, 1.82, 2.47])
+    pt_edges = np.asarray(pt_edges)
+    eta_edges = np.asarray(eta_edges)
+
+    pt_midpoints = 0.5 * (pt_edges[1:] + pt_edges[:-1])
+    eta_midpoints = 0.5 * (eta_edges[1:] + eta_edges[:-1])
+    log.info('comparing systematics for esmodels=%s, ptypes=%s, #pt-bins=%d, #eta-bins=%d' % (esmodels, ptypes, len(pt_edges) - 1, len(eta_edges) - 1))
+
+    effects = {}
+    for esmodel in esmodels:
+        log.info("creating tool for %s" % esmodel)
+        tool = ROOT.CP.EgammaCalibrationAndSmearingTool("tool")
+        tool.setProperty("ESModel", esmodel)
+        tool.setProperty("decorrelationModel", decorrelation)
+        tool.setProperty("int")("randomRunNumber", 297730)
+        if not smearing:
+            tool.setProperty("int")("doSmearing", 0)
+        tool.initialize()
+
+        log.info('computing systematics for %s' % esmodel)
+
+        sys_values = compute_or_read_sys(tool, ptypes, eta_edges, pt_edges)
+        effects[esmodel] = sys_values
+
+        log.debug("delete tool")
+        del tool
+
+    def sorting_function(sys):
+        return max(np.abs(effects[esmodel][ptype].get(sys, np.zeros(1))).max() for esmodel in esmodels for ptype in ptypes)
+
+
+    all_sys = set()
+    for effects_esmodel in effects.values():
+        for effects_particle in effects_esmodel.values():
+            all_sys |= set(effects_particle.keys())
+
+    if only_up:
+        all_sys = set(s for s in all_sys if '__1up' in s)
+    all_sys = set(s for s in all_sys if 'RESOLUTION' not in s)
+    sorted_sys = sorted(all_sys, key=sorting_function, reverse=True)
+
+    log.info("plot")
+    log.info("sorted sys: %s" % sorted_sys)
+    colors = sns.color_palette("Set2", len(esmodels))
+    line_styles = '--', ':', '-'
+
+    for ptype, (ieta, (eta1, eta2)) in tqdm.tqdm(product(ptypes, enumerate(pairwise(eta_edges))), total=len(ptypes) * (len(eta_edges) - 1), desc='plotting', leave=False):
+        nsub_x, nsub_y = divide_square(len(sorted_sys))
+        fig, axs = plt.subplots(nsub_x, nsub_y, figsize=(14, 8), sharex=True)
+        if hasattr(axs, "flat"):
+            axs = axs.flat
+        else:
+            axs = [axs]
+        for ax, sys in zip(axs, sorted_sys):
+            for iesmodel, esmodel in enumerate(esmodels):
+                if sys in effects[esmodel][ptype]:
+                    values = effects[esmodel][ptype][sys][:, ieta]
+                    if abs_sys:
+                        values = np.abs(values)
+                else:
+                    values = np.zeros_like(pt_midpoints)
+                ax.plot(pt_midpoints / 1E3, values * 100, label=esmodel,
+                        ls=line_styles[iesmodel],
+                        color=colors[iesmodel])
+
+            ylimits = [0.01, 0.3, 0.7, 2.1, 5]  # possible y-axis maxima
+            for ylimit in ylimits:
+                if max(np.abs(values)) * 100 < ylimit:
+                    if abs_sys:
+                        ax.set_ylim(0, ylimit)
+                    else:
+                        ax.set_ylim(-ylimit, ylimit)
+                    break
+
+            title = sys.replace('EG_SCALE_', '').replace('PH_SCALE_', '').replace('__1up', '')
+            if len(title) > 17:
+                title = title[:17] + "..."
+            ax.set_title(title, fontsize=9)
+            ax.yaxis.set_major_locator(MaxNLocator(6, prune='both'))
+            ax.xaxis.set_major_locator(MaxNLocator(4))
+            ax.tick_params(axis='both', which='major', labelsize=8)
+            ax.tick_params(axis='y', which='minor', left='off', right='off')
+
+            if log_x:
+                ax.set_xscale('log')
+            ax.set_ylabel('')
+
+        for ax in axs:
+            if ax.is_last_row():
+                ax.set_xlabel('$p_{T}$ [GeV]', fontsize=11)
+            if ax.is_first_col():
+                ax.set_ylabel("effect [%]", fontsize=11)
+        fig.subplots_adjust(wspace=0.4, hspace=0.27, bottom=0.15)
+
+        handles = [mlines.Line2D([], [], color=colors[i], ls=line_styles[i]) for i in range(len(esmodels))]
+        labels = esmodels
+        fig.legend(handles,
+                   labels,
+                   ncol=len(esmodels), loc='upper center',
+                   bbox_to_anchor=(0.1, -0.14, 0.7, 0.2),
+                   mode='expand',
+                   borderaxespad=0.
+        )
+
+        fig.suptitle(r'%s $|\eta|\in [%.2f, %.2f]$' % (ptype, eta1, eta2), fontsize=14)
+
+        figname = 'compare_sys_%s_eta_%.2f_%.2f_vs_pT' % (ptype, eta1, eta2)
+        log.info("saving %s" % figname)
+        for extension in extensions:
+            fig.savefig(os.path.join(basedir, "%s.%s" % (figname, extension)))
+        plt.close(fig)
+
 
-def plot_all_syst(esmodel='es2012c', decorrelation='FULL_v1', ptype='unconverted', basedir='plots'):
+@timed
+def plot_all_syst_eta_pt(esmodel='es2012c', decorrelation='FULL_v1', ptype='unconverted',
+                         basedir='plots', eta_range=None, pt_range=None, log_pt=False, abs_sys=False, only_up=False, sys_filters=None, min_value=None, max_value=None):
+    """
+    Plot a 2D map (eta, pT) of the value of the systematic in %
+    """
+    log.debug("creating tool")
     tool = ROOT.CP.EgammaCalibrationAndSmearingTool("tool")
     tool.setProperty("ESModel", esmodel)
     tool.setProperty("decorrelationModel", decorrelation)
     tool.setProperty("int")("doSmearing", 0)
+    log.warning('setting randomRunNumber to 297730')
+    tool.setProperty("int")("randomRunNumber", 297730)
     tool.initialize()
 
-    etas = np.arange(-3, 3, 0.1)
-    pts = np.logspace(4, 7, 100)
-    X, Y = np.meshgrid(etas, pts)
-    nominal = eval_sys_eta_pt(tool, etas, pts, particle=ptype)
+    etas = eta_range if eta_range is not None else np.arange(-3, 3, 0.1)
+    pts = pt_range if pt_range is not None else np.logspace(4, 7, 100)
+
+    nominal = calibrate_eta_pt(tool, etas, pts, particle=ptype)
 
     all_syst = tool.recommendedSystematics()
-    for sys in all_syst:
+
+    nplotted = 0
+
+    for sys in tqdm.tqdm(all_syst):
         sys_name = sys.name()
         if "RESOLUTION" in sys_name:
+            log.debug('skipping %s', sys_name)
+            continue
+        if only_up and "1up" not in sys_name:
+            log.debug('skipping %s', sys_name)
             continue
-        logging.info("plotting sys %s", sys_name)
+        if sys_filters is not None:
+            if not any(fnmatch(sys_name, sys_filter) for sys_filter in sys_filters):
+                log.debug('skipping %s', sys_name)
+                continue
+        nplotted += 1
+        log.info("computing sys %s", sys_name)
 
         sys_set = ROOT.CP.SystematicSet()
         sys_set.insert(sys)
         tool.applySystematicVariation(sys_set)
 
-        sys = eval_sys_eta_pt(tool, etas, pts, particle=ptype)
+        sys = calibrate_eta_pt(tool, etas, pts, particle=ptype)
 
         ratio = sys / nominal
-        f, ax = plt.subplots()
         ratio[nominal == 0] = 1
         # TODO: check why nan
         ratio[np.isnan(ratio)] = 1
-        vmax = np.percentile(np.abs(ratio - 1), 90)
+        ratio = ratio - 1
+        vmax = max_value or np.percentile(np.abs(ratio), 95)
+        vmin = min_value or -vmax
+        if abs_sys:
+            ratio = np.abs(ratio)
 
-        p = ax.pcolormesh(etas, pts / 1E3, (ratio - 1) * 100., vmin=-vmax * 100, vmax=vmax * 100)
-        # ax.contour(X, Y / 10E3, ratio - 1, levels=[0], colors='k', linercParamss='dashed')
-        ax.set_title(sys_name)
-        ax.set_xlabel('$\eta$')
-        ax.set_ylabel('$p_T$ [GeV]')
-        ax.set_yscale('log')
+        f, ax = plt.subplots()
+        p = ax.pcolormesh(etas, pts / 1E3, ratio * 100., vmin=-vmax * 100, vmax=vmax * 100)
+        ax.set_title("%s\n%s\n%s" % (ptype, esmodel, sys_name), loc='left')
+        ax.set_xlabel('$\eta$', x=1., ha='right')
+        ax.set_ylabel('$p_T$ [GeV]', y=1., ha='right')
+        if log_pt:
+            ax.set_yscale('log')
         cb = f.colorbar(p)
-        cb.ax.set_ylabel('ratio to nominal [%]')
+        cb.ax.set_ylabel('systematic effect [%]')
         for extension in extensions:
-            f.savefig(os.path.join(basedir, "%s_%s_%s.%s" % (ptype, decorrelation, sys_name, extension)))
+            f.savefig(os.path.join(basedir, "%s_%s_%s_%s.%s" % (ptype, esmodel, decorrelation, sys_name, extension)))
         plt.close(f)
 
+    if nplotted == 0:
+        log.warning('no systematic plotted')
+    else:
+        log.info('%d systematic plotted' % nplotted)
+
 
-def plot_all_scales(esmodels, basedir, labels=None, etas=np.arange(-4.5, 4.5, 0.01), add_patch=False):
+@timed
+def plot_all_scales(esmodels, basedir, labels=None, etas=np.arange(-4.5, 4.5, 0.01), add_patch=False, debug=False):
+    log.info("comparing scale factors %s" % esmodels)
+    log.warning("<mu> fixed")
     labels = labels or esmodels
     scales = {}
     to_legend = []
@@ -549,11 +845,13 @@ def plot_all_scales(esmodels, basedir, labels=None, etas=np.arange(-4.5, 4.5, 0.
             value_properties = esmodel[2]
             type_properties = esmodel[3]
             esmodel = esmodel[0]
-        print (esmodel, key_properties)
 
         tool_with = ROOT.CP.EgammaCalibrationAndSmearingTool("tool_with")
         tool_without = ROOT.CP.EgammaCalibrationAndSmearingTool("tool_without")
+
         for tool in tool_with, tool_without:
+            if debug:
+                tool.msg().setLevel(0)
             tool.setProperty("ESModel", esmodel)
             tool.setProperty("int")("doSmearing", 0)
             for k, v, t in zip(key_properties, value_properties, type_properties):
@@ -565,10 +863,9 @@ def plot_all_scales(esmodels, basedir, labels=None, etas=np.arange(-4.5, 4.5, 0.
         tool_with.initialize()
         tool_without.initialize()
 
-
-
         event = ROOT.xAOD.TEvent()
         factory = ROOT.EgammaFactory()
+        log.warning("using eveninfo 266904")
         ei = factory.create_eventinfo(False, 266904)
 
         for eta in etas:
@@ -580,10 +877,10 @@ def plot_all_scales(esmodels, basedir, labels=None, etas=np.arange(-4.5, 4.5, 0.
         scales[label] = np.array(energy_without) / np.array(energy_with) - 1
 
     f, ax = plt.subplots()
-    for k, v in scales.items():
+    for k, v in scales.iteritems():
         ax.plot(etas, v * 100, label=k)
-    ax.set_xlabel("$\eta$")
-    ax.set_ylabel("energy without scale factors / energy with scale factors - 1 [%]")
+    ax.set_xlabel("$\eta$", fontsize=15, x=1, ha='right')
+    ax.set_ylabel("energy without scale factors / energy with scale factors - 1 [%]", fontsize=10)
     ax.grid()
 
     if add_patch:
@@ -600,6 +897,23 @@ def plot_all_scales(esmodels, basedir, labels=None, etas=np.arange(-4.5, 4.5, 0.
         f.savefig(os.path.join(basedir, "scales.%s" % extension))
     plt.close(f)
 
+    # ratio plot
+    reference = labels[0]
+    ratio = {label: scales[label] - scales[reference] for label in labels}
+    f, ax = plt.subplots()
+    for k, v in ratio.iteritems():
+        ax.plot(etas, v, label=k)
+    ax.set_xlabel("$\eta$", fontsize=15, x=1, ha='right')
+    ax.set_ylabel("scales - scales (%s)" % reference, fontsize=10)
+    ax.grid()
+    ax.legend()
+    f.tight_layout()
+
+    for extension in extensions:
+        f.savefig(os.path.join(basedir, "scales_difference_%s.%s" % (reference, extension)))
+    plt.close(f)
+
+
 
 def plot_all_cterms(esmodels, basedir, labels=None, etas=np.arange(-4.5, 4.5, 0.01)):
     labels = labels or esmodels
@@ -625,14 +939,14 @@ def plot_all_cterms(esmodels, basedir, labels=None, etas=np.arange(-4.5, 4.5, 0.
             el = factory.create_electron(eta, 0.1, 40E3)
             en_without = tool_without.getEnergy(el, ei)
             ratios = np.zeros(1000)
-            for repetition in range(1000):
+            for repetition in xrange(1000):
                 en_with = tool_with.getEnergy(el, ei)
                 ratios[repetition] = en_with / en_without
             cterms.append(np.std(ratios))
         cterms_all_models[label] = cterms
 
     f, ax = plt.subplots()
-    for k, v in cterms_all_models.items():
+    for k, v in cterms_all_models.iteritems():
         ax.plot(etas, v, label=k)
     ax.set_xlabel("$\eta$")
     ax.set_ylabel("std (energy with additional cterm / energy without)")
@@ -652,11 +966,11 @@ def plot_all_cterms(esmodels, basedir, labels=None, etas=np.arange(-4.5, 4.5, 0.
 
 def compare_two_tools_eta(tool1, tool2, pt, simulation, name, basedir, title, particle='unconverted'):
     etas = np.arange(-4.5, 4.5, 0.01)
-    r1 = eval_sys_eta_pt(tool1, etas, [pt], simulation, particle)
-    r2 = eval_sys_eta_pt(tool2, etas, [pt], simulation, particle)
+    r1 = calibrate_eta_pt(tool1, etas, [pt], simulation, particle)
+    r2 = calibrate_eta_pt(tool2, etas, [pt], simulation, particle)
     r = r1 / r2 - 1
     r = r[0]
-    print (r)
+    print(r)
     f, ax = plt.subplots()
     r = np.nan_to_num(r)
     ax.plot(etas, r * 100)
@@ -693,8 +1007,8 @@ def compare_two_tools_eta_phi(tool1, tool2, pt, simulation, name, basedir, title
 def compare_two_tools_eta_pt(tool1, tool2, simulation, name, basedir, title, particle='unconverted'):
     etas = np.arange(-4.5, 4.5, 0.05)
     pts = np.logspace(3.2, 6, 50)
-    r1 = eval_sys_eta_pt(tool1, etas, pts, simulation, particle)
-    r2 = eval_sys_eta_pt(tool2, etas, pts, simulation, particle)
+    r1 = calibrate_eta_pt(tool1, etas, pts, simulation, particle)
+    r2 = calibrate_eta_pt(tool2, etas, pts, simulation, particle)
     r = r1 / r2 - 1
     f, ax = plt.subplots()
     r = np.nan_to_num(r)
@@ -838,20 +1152,21 @@ def plot_resolution_eta_pt(basedir, tool, pts, etas, ptype, title):
 
 
 def plot_resolution_error(basedir, **kwargs):
-    esmodels = kwargs["esmodels"] or ('es2012c', 'es2015PRE', 'es2015PRE_res_improved', 'es2016PRE')
+    esmodels = kwargs["esmodels"] or ('es2012c', 'es2015PRE', 'es2015PRE_res_improved', 'es2016PRE', 'es2017')
     if kwargs["eta_bins"] is not None:
         eta_bins = pairwise(kwargs["eta_bins"])
     else:
         eta_bins = (0, 0.4), (0.4, 0.6), (0.6, 1.37), (1.52, 1.8), (1.8, 2.37)
     for esmodel in esmodels:
-        logging.debug("plotting resolution error for %s" % esmodel)
+        log.debug("plotting resolution error for %s" % esmodel)
         tool = ROOT.AtlasRoot.egammaEnergyCorrectionTool()
         if kwargs['debug']:
             tool.msg().setLevel(0)
         tool.setESModel(getattr(ROOT.egEnergyCorr, esmodel))
         tool.initialize()
         for particle in ('electron', 'converted', 'unconverted'):
-            for eta_min, eta_max in eta_bins:
+            log.info('plotting resolution %s', particle)
+            for eta_min, eta_max in tqdm.tqdm(eta_bins):
                 plot_resolution_error_bin(eta_min, eta_max, particle, esmodel, basedir, tool=tool, **kwargs)
 
 
@@ -891,26 +1206,39 @@ def plot_resolution_error_bin(eta_min, eta_max, particle, esmodel, basedir, tool
     all_errors = [{}, {}]  # up and down
 #                  ,--,
 
-    pt_range = np.linspace(10E3, 800E3, 100)
+    pt_range = kwargs.get('pt_bins')
+    if pt_range is None:
+        pr_range = np.linspace(10E3, 2000E3, 100)
+
     nsamples_eta = kwargs['super_sampling_eta'] or 5
     eta_range = np.linspace(eta_min, eta_max, nsamples_eta + 2)[1:-1]
 
+
+    only_up = True
+
     for side, errors, variations_name in zip(("up", "down"), all_errors, (variations_name_up, variations_name_down)):
+        if only_up and side == 'down':
+            continue
         quadrature_sum = np.zeros((len(pt_range), len(eta_range)))
-        for variation_name, variation_id in variations_name.items():
+        for variation_name, variation_id in variations_name.iteritems():
             errors_var_pt_eta = np.zeros((len(pt_range), len(eta_range)))
             for ipt, pt in enumerate(pt_range):
                 for ieta, eta in enumerate(eta_range):
                     energy = pt * np.cosh(eta)
-                    logging.debug("evaluating systematics %s in eta=%.2f pt=%.2f on resolution" % (variation_name, eta, pt))
+                    log.debug("evaluating systematics %s in eta=%.2f pt=%.2f on resolution" % (variation_name, eta, pt))
                     errors_var_pt_eta[ipt, ieta] = tool.getResolutionError(energy, eta, eta, ptype, variation_id)
             errors[variation_name] = errors_var_pt_eta.mean(axis=1)  # average over different eta points inside the eta-bin
+            if kwargs['abs_sys']:
+                errors[variation_name] = np.abs(errors[variation_name])
 
     sorted_keys_up = sorted(variations_name_up.keys(), key=lambda x: np.abs(all_errors[0][x].mean()))
-    totals = [np.sqrt(np.sum(e ** 2 for k, e in errors.items() if "all " not in k)) for errors in all_errors]
+    totals = [np.sqrt(np.sum(e ** 2 for k, e in errors.iteritems() if "all " not in k)) for errors in all_errors]
 
     fig, ax = plt.subplots()
-    ax.fill_between(pt_range / 1E3, all_errors[0]['all up'], all_errors[1]['all down'], color='0.8')
+    if only_up:
+        ax.fill_between(pt_range / 1E3, 0, all_errors[0]['all up'], color='0.8')
+    else:
+        ax.fill_between(pt_range / 1E3, all_errors[0]['all up'], all_errors[1]['all down'], color='0.8')
 #    ax.fill_between(pt_range / 1E3, totals[0], -totals[-1], color='0.8')
 #    totals[1] *= -1
 
@@ -918,6 +1246,8 @@ def plot_resolution_error_bin(eta_min, eta_max, particle, esmodel, basedir, tool
     props = mpl.rcParams["axes.prop_cycle"]
 
     for side, errors, total in zip(('up', 'down'), all_errors, totals):
+        if only_up and side == 'down':
+            continue
         #ax.plot(pt_range / 1E3, total, label='sum %s' % side, color='k')
         ax.plot(pt_range / 1E3, errors['all %s' % side], 'k', label='all %s' % side)
         colors_iter = cycle(colors)
@@ -932,38 +1262,106 @@ def plot_resolution_error_bin(eta_min, eta_max, particle, esmodel, basedir, tool
                 linestyle = ":"
             ax.plot(pt_range / 1E3, v, linestyle, label=k, color=next(colors_iter))
 
+    fig.text(0.16, 0.73, beautify_particle(particle), transform=ax.transAxes, fontsize=15)
+    fig.text(0.16, 0.67, r'$%.2f < \eta < %.2f$' % (eta_min, eta_max), transform=ax.transAxes, fontsize=15)
+
+    ax.set_title("%s" % esmodel)
+    ax.set_ylabel('relative resolution error [%]', ha='right', y=1., fontsize=19)
+    ax.set_xlabel('$E_T$ [GeV]', ha='right', x=1., fontsize=19)
+    if kwargs['abs_sys']:
+        ax.set_ylim(0, 0.6)
+    else:
+        ax_set_ylim(-1.7, 1.7)
+    ax.set_xlim(np.min(pt_range) / 1E3, np.max(pt_range) / 1E3)
 
-    ax.set_title("%s $\eta\in$ [%.2f-%.2f] - %s" % (particle, eta_min, eta_max, esmodel))
-    ax.set_ylabel('relative resolution error', ha='right', y=1.)
-    ax.set_xlabel('$p_T$ [GeV]', ha='right', x=1.)
-    ax.set_ylim(-0.7, 0.7)
     fig.subplots_adjust(bottom=0.35)
 
     ax.legend(loc=3, bbox_to_anchor=(0., -0.5, 1, 0.2), mode="expand",
               ncol=4, borderaxespad=0., fontsize=10)
 
-    #plot_ATLAS(fig, 0.6, 0.75, 'Internal')
+    plot_ATLAS(fig, 0.16, 0.8, 'Internal', fontsize=19)
 
-    ax.grid()
+    if kwargs['grid']:
+        ax.grid()
     filename = os.path.join(basedir, 'error_relresolution_%s_%s_eta%.2f-%.2f' % (esmodel, particle, eta_min, eta_max))
     for ext in 'png', 'pdf':
-        fig.savefig(filename + "." + ext)
+        fig.savefig(filename + "." + ext, bbox_inches='tight')
     plt.close(fig)
 
+def list_systematics(esmodels, decorrelation='FULL_ETACORRELATED_v1'):
+    if type(esmodels) is str:
+        esmodels = [esmodels]
+    elif esmodels is None:
+        log.warning('no esmodel specified, using es2012c')
+        esmodels = ['es2012c']
+    syslist_esmodel = {}
+    for esmodel in esmodels:
+        log.debug("creating tool for %s" % esmodel)
+        tool = ROOT.CP.EgammaCalibrationAndSmearingTool("tool")
+        tool.setProperty("ESModel", esmodel)
+        tool.setProperty("decorrelationModel", decorrelation)
+        tool.initialize()
+        syslist_esmodel[esmodel] = [s.name() for s in systematics_from_tool(tool, only_scale=False)]
+
+    for esmodel, sys_list in syslist_esmodel.iteritems():
+        print("esmodel: %s %s UP variations" % (esmodel, len(sys_list)))
+        for sysname in sys_list:
+            print("   {:10s}".format(sysname))
 
+    if len(esmodels) > 1:
+        log.info('comparing the %s esmodels' % len(esmodels))
+        all_sys = set([item for sublist in syslist_esmodel.values() for item in sublist])
+        print(' ' * 40 + ''.join(' [%d] ' % i for i in range(len(esmodels))))
+        for sysname in sorted(all_sys):
+            cross = ''.join(['  x  ' if sysname in syslist_esmodel[esmodel] else '     ' for esmodel in esmodels])
+            print(('{:40s}'.format(sysname) + cross))
+        for iesmodel, esmodel in enumerate(esmodels):
+            print("[%d] = %s" % (iesmodel, esmodel))
+
+
+@timed
 def main():
     from argparse import ArgumentParser, RawDescriptionHelpFormatter
     parser = ArgumentParser(formatter_class=RawDescriptionHelpFormatter,
-                            epilog="to produce paper plots for systematics: python plot.py sys_eta_slices --beautify-sysnames --sys-paper-order --superimpose-all --skip-null-sys --esmodels es2016PRE --yrange -1 2.0 --symmetrize-labels")
-    parser.add_argument('action', choices=['uA2MeV', 'zee', 'material', 'scale', 'cterm', 'all', 'gain', 'uniformity',
-                                           'sys_fixed_pt', 'sys_eta_slices', 'all_sys', 'resolution', 'fast', 'resolution-err'],
+                            epilog="""
+to produce paper plots for systematics:
+    python plot.py sys_eta_slices --beautify-sysnames --sys-order paper_run1 --superimpose-all --skip-null-sys --esmodels es2016PRE --min-sys-value -0.01 --max-sys-value 0.02 --symmetrize-labels  --pt-bins-logspace 5E3 1E6 100
+
+    # python plot.py sys_eta_slices --beautify-sysnames --sys-order paper_run1 --superimpose-all --skip-null-sys --esmodels es2016data_mc15c_summer_improved --min-sys-value -0.01 --max-sys-value 0.02 --symmetrize-labels  --pt-bins-logspace 5E3 1E6 100
+
+to produce paper plot for resolution (the name of the esmodels here are the ones used by the internal class)
+   python plot.py resolution-err --esmodels es2017 --abs-sys --pt-bins-linspace 5E3 200E3 200
+
+
+to compare systematics between tools vs pT:
+    python plot.py compare_sys --particles electron converted unconverted --esmodels es2016data_mc15c_summer_improved es2016data_mc15c_summer --eta-bins 0 0.6 1.0 1.37 1.55 1.82 2.47 --pt-bins-logspace 5E3 1500E3 50 --abs-sys --log-x
+
+to plot all systematics in a 2d plot (eta, pt):
+    python plot.py all_sys --esmodel es2016data_mc15c_summer es2012c --decorrelation=FULL_ETACORRELATED_v1 --eta-bins-linspace -2.5 2.5 50 --pt-bins-linspace 15E3 100E3 50 --particles converted unconverted --sys-filters *LARCALIB* *LARELECUNCONV*
+
+to produce scale factor correction (doScaleCorrection on/off):
+    python plot.py scale --esmodels es2015PRE es2016data_mc15c_summer
+
+to list the systematics:
+    python plot.py list-systematics --esmodels es2012c es2016data_mc15c_summer es2016data_mc15c_summer_improved es2017_R21_PRE
+""")
+    parser.add_argument('action', choices=['compare_sys', 'compute_sys', 'uA2MeV',
+                                           'zee', 'material', 'scale', 'cterm',
+                                           'all', 'gain', 'uniformity',
+                                           'sys_fixed_pt', 'sys_eta_slices',
+                                           'all_sys', 'resolution', 'fast', 'resolution-err', 'list-systematics'],
                         default='all', help='what to do')
     parser.add_argument('--esmodels', nargs='*', help='esmodel to consider')
+    parser.add_argument('--decorrelation', default='FULL_ETACORRELATED_v1')
+    parser.add_argument('--particles', nargs='*', help='the particle (electron/converted/unconverted)', default=['electron'])
     parser.add_argument('--beautify-sysnames', action='store_true')
     parser.add_argument('--eta-bins', nargs='*', type=float, help='edges of the eta-bins')
+    parser.add_argument('--eta-bins-linspace', nargs=3, type=float, help='edge of the eta-bins as min max nbins')
     parser.add_argument('--pt-bins', nargs='*', type=float, help='edges of the pt-bins')
+    parser.add_argument('--pt-bins-linspace', nargs=3, type=float, help='edge of the eta-bins as min max nbins')
+    parser.add_argument('--pt-bins-logspace', nargs=3, type=float, help='edge of the eta-bins as min max nbins')
     parser.add_argument('--super-sampling-eta', type=int, default=5, help='how many point to average inside a bin')
-    parser.add_argument('--sys-paper-order', action='store_true', default='use the same order of systeamatics as in run1 paper')
+    parser.add_argument('--sys-order', choices=['paper_run1', 'paper_run2'], default='how to order systematics, options: paper_run1, paper_run2')
     parser.add_argument('--debug', action='store_true')
     parser.add_argument('--superimpose-all', action='store_true', help='superimpose sum of systematics')
     parser.add_argument('--skip-null-sys', action='store_true', help='do not plot null systematics')
@@ -971,25 +1369,61 @@ def main():
     parser.add_argument('--add-down', action='store_true', help='plot also the down systematics')
     parser.add_argument('--legend-outside', action='store_true', help='draw the legend outside the plot')
     parser.add_argument('--symmetrize-labels', action='store_true')
+    parser.add_argument('--abs-sys', action='store_true', help='consider the abs value of the systeamatics')
+    parser.add_argument('--log-x', action='store_true', help='use log scale')
+    parser.add_argument('--log-pt', action='store_true', help='use log scale for pT')
+    parser.add_argument('--sys-filters', nargs='*', help='list of wildcard to filter systematic names')
+    parser.add_argument('--min-sys-value', type=float, help='min value for the systematic axis')
+    parser.add_argument('--max-sys-value', type=float, help='max value for the systematic axis')
+    parser.add_argument('--grid', action='store_true', help='show grid')
+    parser.add_argument('--plot-qsum', action='store_true', help='plot the quadrature sum of the systematics for debug (should be equal to 1NP up)')
+    parser.add_argument('--atlas-label', help='Internal, Preliminary, ..., use "" for papers')
     args = parser.parse_args()
 
     if args.debug:
-        logging.basicConfig(level=logging.DEBUG)
+        log.setLevel(logging.DEBUG)
+        log.debug("DEBUG activated")
+
+    if args.eta_bins_linspace:
+        args.eta_bins = np.linspace(args.eta_bins_linspace[0], args.eta_bins_linspace[1], args.eta_bins_linspace[2] + 1)
+    if args.pt_bins_linspace:
+        args.pt_bins = np.linspace(args.pt_bins_linspace[0], args.pt_bins_linspace[1], args.pt_bins_linspace[2] + 1)
+    if args.pt_bins_logspace:
+        args.pt_bins = np.logspace(np.log10(args.pt_bins_logspace[0]), np.log10(args.pt_bins_logspace[1]), args.pt_bins_logspace[2] + 1)
 
     basedir = 'plots'
     if not os.path.exists(basedir):
         os.makedirs(basedir)
 
+    if args.action == 'list-systematics':
+        list_systematics(args.esmodels, args.decorrelation)
+
+    if args.action == 'compute_sys':
+        log.info('computing systematics')
+        for esmodel in args.esmodels or ['es2012c']:
+            tool = ROOT.CP.EgammaCalibrationAndSmearingTool("tool")
+            tool.setProperty("ESModel", esmodel)
+            tool.setProperty("decorrelationModel", 'FULL_ETACORRELATED_v1')
+            tool.setProperty("int")("doSmearing", 0)
+            tool.initialize()
+            result = compute_or_read_sys(tool, ['electron'], args.eta_bins, args.pt_bins)
+            print(result)
+
+    if args.action == 'compare_sys':
+        log.info("comparing systematics")
+        compare_sys(args.esmodels, ptypes=args.particles, decorrelation=args.decorrelation,
+                    eta_edges=args.eta_bins, pt_edges=args.pt_bins, abs_sys=args.abs_sys, log_x=args.log_x)
+
     if args.action == 'resolution-err':
-        logging.info("plotting resolution error")
+        log.info("plotting resolution error")
         plot_resolution_error(basedir='plots', **vars(args))
 
     if args.action == 'zee' or args.action == 'all':
-        logging.info("plotting scale systematics")
+        log.info("plotting scale systematics")
         plot_all_Zee_syst(etas=np.arange(-2.5, 2.5, 0.01), pt=100E3, basedir='plots')
 
     if args.action == 'all' or args.action == 'uA2MeV':
-        logging.info("plotting uA2MeV")
+        log.info("plotting uA2MeV")
         tool_es2015PRE_nouA2MeV = ROOT.CP.EgammaCalibrationAndSmearingTool("tool_es2015PRE_nouA2MeV")
         tool_es2015PRE_nouA2MeV.setProperty("ESModel", "es2015PRE")
         tool_es2015PRE_nouA2MeV.setProperty("decorrelationModel", 'FULL_ETACORRELATED_v1')
@@ -1013,19 +1447,19 @@ def main():
         del tool_es2015PRE
 
     if args.action == 'all' or args.action == 'scale':
-        logging.info("plotting scales")
-        plot_all_scales(esmodels=("es2012c", "es2015PRE"),
-                        labels=("2012", "new + temp"),
+        log.info("plotting scales")
+        plot_all_scales(esmodels=args.esmodels,
+                        labels=args.esmodels,
                         basedir=basedir, etas=np.arange(-2.5, 2.5, 0.01),
-                        add_patch=True)
+                        add_patch=False, debug=args.debug)
     if args.action == 'all' or args.action == 'fast':
-        logging.info("plotting full / fast scale")
+        log.info("plotting full / fast scale")
         check_fast(basedir, "es2015PRE")
         plot_all_scales(esmodels=("es2015PRE", ("es2015PRE", ("useAFII",), (True,), (bool,))),
                         labels=("2015PRE", "2015PRE FAST"),
                         basedir=basedir, etas=np.arange(-2.5, 2.5, 0.01))
     if args.action == 'all' or args.action == 'cterm':
-        logging.info("plotting smearings")
+        log.info("plotting smearings")
         plot_all_cterms(esmodels=("es2012c", "es2012XX", "es2015PRE"), labels=("2012", "new", "new + temp"), basedir=basedir, etas=np.arange(-2.5, 2.5, 0.01))
 
     if args.action == 'gain' or args.action == "all":
@@ -1048,39 +1482,47 @@ def main():
                                   labels=('es2012c', '$\oplus$ 7/8 diff $\oplus$ 34/68 diff', '$\oplus$ LAr temperature'))
 
     if args.action == 'sys_eta_slices' or args.action == 'all':
-        etabins = ((0., 0.6), (0.6, 1.45), (1.52, 1.7), (1.7, 1.9), (1.9, 2.5), (1.4, 1.6))
+        if not args.eta_bins:
+            eta_bins = ((0., 0.6), (0.6, 1.45), (1.52, 1.7), (1.7, 1.9), (1.9, 2.5), (1.4, 1.6))
+            log.warning('no eta-binning specified using %s', eta_bins)
+        else:
+            eta_bins = list(pairwise(args.eta_bins))
+            log.info('eta-bin: %s', eta_bins)
         for ptype in 'electron', 'unconverted', 'converted':
-            logging.debug("plot all sys FULL_ETACORRELATED_v1 eta slice %s" % ptype)
-            plot_all_syst_eta_slice(etabins, netas=args.super_sampling_eta, esmodel=args.esmodels[0],
+            log.debug("plot all sys FULL_ETACORRELATED_v1 eta slice %s" % ptype)
+            plot_all_syst_eta_slice(eta_bins, supersampling_eta=args.super_sampling_eta, esmodel=args.esmodels[0],
                                     decorrelation='FULL_ETACORRELATED_v1', ptype=ptype, basedir=basedir,
-                                    beautify_sysnames=args.beautify_sysnames, sys_paper_order=args.sys_paper_order,
-                                    superimpose_all=args.superimpose_all, skip_null_sys=args.skip_null_sys, yrange=args.yrange, debug=args.debug,
+                                    beautify_sysnames=args.beautify_sysnames, sys_order=args.sys_order,
+                                    superimpose_all=args.superimpose_all, skip_null_sys=args.skip_null_sys,
+                                    max_sys=args.max_sys_value, min_sys=args.min_sys_value,
+                                    debug=args.debug,
                                     only_up=not args.add_down, symmetrize_labels=args.symmetrize_labels,
-                                    legend_outside=args.legend_outside)
-        for ptype in 'electron', 'unconverted', 'converted':
-            logging.debug("plot all sys 1NP_v1 eta slice %s" % ptype)
-            plot_all_syst_eta_slice(etabins, netas=args.super_sampling_eta, esmodel=args.esmodels[0],
-                                    decorrelation='1NP_v1', ptype=ptype, basedir=basedir,
-                                    beautify_sysnames=args.beautify_sysnames, sys_paper_order=args.sys_paper_order, yrange=args.yrange, debug=args.debug, only_up=not args.add_down,
-                                    legend_outside=args.legend_outside, symmetrize_labels=args.symmetrize_labels)
-
+                                    legend_outside=args.legend_outside, pts=args.pt_bins, log_x=args.log_x, plot_qsum=args.plot_qsum, abs_sys=args.abs_sys, atlas_label=args.atlas_label)
 
     if args.action == 'material' or args.action == 'all':
         if not os.path.exists('material'):
             os.makedirs('material')
         etabins = ((0., 0.6), (0.6, 1.45), (1.52, 1.7), (1.7, 1.9), (1.9, 2.5))
         for ptype in 'electron', 'unconverted', 'converted':
-            plot_all_syst_eta_slice(etabins, netas=args.super_sampling_eta, esmodel=args.esmodels[0],
+            plot_all_syst_eta_slice(etabins, supersampling_eta=args.super_sampling_eta, esmodel=args.esmodels[0],
                                     decorrelation='FULL_ETACORRELATED_v1', ptype=ptype, basedir="material",
                                     only_material=True, beautify_sysnames=args.beautify_sysnames,
-                                    sys_paper_order=args.sys_paper_order, skip_null_sys=args.skip_null_sys, yrange=args.yrange, debug=args.debug, only_up=not args.add_down,
-                                    legend_outside=args.legend_outside, symmetrize_labels=args.symmetrize_labels)
+                                    sys_order=args.sys_order,
+                                    skip_null_sys=args.skip_null_sys,
+                                    max_sys=args.max_sys_value, min_sys=args.min_sys_value,
+                                    debug=args.debug, only_up=not args.add_down,
+                                    legend_outside=args.legend_outside, symmetrize_labels=args.symmetrize_labels, log_x=args.log_x, plot_qsum=args.plot_qsum, abs_sys=args.abs_sys, atlas_label=args.atlas_label)
 
     if args.action == 'all_sys' or args.action == 'all':
-        for ptype in 'electron', 'unconverted', 'converted':
-            plot_all_syst(decorrelation="1NP_v1", ptype=ptype, basedir=basedir)
-            plot_all_syst(decorrelation="FULL_ETACORRELATED_v1", ptype=ptype, basedir=basedir)
-            plot_all_syst(decorrelation="FULL_v1", ptype=ptype, basedir=basedir)
+        for esmodel in args.esmodels:
+            for ptype in args.particles:
+                log.info("plotting sys for %s %s" % (ptype, esmodel))
+                plot_all_syst_eta_pt(esmodel=esmodel, decorrelation=args.decorrelation,
+                                     ptype=ptype, basedir=basedir,
+                                     eta_range=args.eta_bins, pt_range=args.pt_bins, log_pt=args.log_pt,
+                                     abs_sys=args.abs_sys, sys_filters=args.sys_filters,
+                                     min_value=args.min_sys_value, max_value=args.max_sys_value)
+
 
     if args.action == "resolution" or args.action == 'all':
         tool = ROOT.CP.EgammaCalibrationAndSmearingTool("tool")
@@ -1093,5 +1535,34 @@ def main():
         plot_resolution_eta_pt(basedir, tool, pts, etas, 'unconverted', title="resolution unconverted es2015PRE")
 
 if __name__ == '__main__':
+    class TqdmLoggingHandler(logging.Handler):
+        def __init__ (self, level = logging.NOTSET):
+            super (self.__class__, self).__init__ (level)
+
+        def emit (self, record):
+            try:
+                msg = self.format (record)
+                tqdm.tqdm.write (msg)
+                self.flush ()
+            except (KeyboardInterrupt, SystemExit):
+                raise
+            except:
+                self.handleError(record)
+
+
+    log = logging.getLogger(__name__)
+    log.setLevel(logging.INFO)
+    handler = TqdmLoggingHandler()
+    handler.setFormatter(colorlog.ColoredFormatter('%(log_color)s %(name)-23s %(levelname)-7s %(message)s',
+                                                   log_colors={
+                                                       'DEBUG': 'cyan',
+                                                       'INFO': 'blue',
+                                                       'SUCCESS:': 'green',
+                                                       'WARNING': 'yellow',
+                                                       'ERROR': 'red',
+                                                       'CRITICAL': 'red,bg_white'},))
+    log.addHandler(handler)
+
+    log.info("importing framework packages")
     ROOT.gROOT.ProcessLine(".x $ROOTCOREDIR/scripts/load_packages.C")
     main()
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot_paper_2017.sh b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot_paper_2017.sh
new file mode 100644
index 0000000000000000000000000000000000000000..a5f51421a8aa3894969308ead826e232d8cc0dba
--- /dev/null
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot_paper_2017.sh
@@ -0,0 +1,8 @@
+#!/bin/sh
+
+## This script produces the plots used in the internal notes and in
+## the calibration paper in 2017
+
+# PES vs ET in eta-bins per particles
+
+python plot.py sys_eta_slices --beautify-sysnames --sys-order paper_run2 --superimpose-all --skip-null-sys --esmodels es2016data_mc15c_summer_improved --min-sys-value 0 --max-sys-value 0.032 --symmetrize-labels  --pt-bins-linspace 7E3 200E3 200  --eta-bins 0.0 0.8 1.37 1.52 1.8 2.47 --super-sampling-eta 20 --abs-sys
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot_requirements.txt b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot_requirements.txt
new file mode 100644
index 0000000000000000000000000000000000000000..abc34297f9a44d23536ef97afe8f80f745fbbaaa
--- /dev/null
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/plot_requirements.txt
@@ -0,0 +1,5 @@
+numpy
+matplotlib
+tqdm
+colorlog
+seaborn
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/run_xAOD_ElectronPhotonFourMomentumCorrection.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/run_xAOD_ElectronPhotonFourMomentumCorrection.py
index 6282d947eb9f52c397afb8717fc986b5ca68ded4..6a847f6627a54e0811054a888830f98375cc0664 100755
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/run_xAOD_ElectronPhotonFourMomentumCorrection.py
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/run_xAOD_ElectronPhotonFourMomentumCorrection.py
@@ -1,7 +1,6 @@
 #!/bin/env python
-# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-from __future__ import print_function
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 import ROOT
 import math
@@ -38,7 +37,7 @@ def xAOD_particle_generator(tree, collection_getter, newevent_function=None, end
     elif type(event_numbers) is int:
         event_numbers = [event_numbers]
 
-    for ievent in range(tree.GetEntries()):
+    for ievent in xrange(tree.GetEntries()):
         tree.GetEntry(ievent)
         ei = tree.EventInfo
         event_number = ei.eventNumber()
@@ -51,7 +50,7 @@ def xAOD_particle_generator(tree, collection_getter, newevent_function=None, end
 
         collection = collection_getter(tree)
 
-        for i in range(collection.size()):
+        for i in xrange(collection.size()):
             p = collection.at(i)
             if min_pt is not None and p.pt() < min_pt:
                 continue
@@ -99,6 +98,7 @@ def main(filename, **args):
     logging.debug("initializing tool")
     tool = ROOT.CP.EgammaCalibrationAndSmearingTool("tool")
     tool.setProperty("ESModel", args["esmodel"]).ignore()
+    tool.setProperty("decorrelationModel", args["decorrelation"]).ignore()
     if args["no_smearing"]:
         tool.setProperty("int")("doSmearing", 0).ignore()
     if args['debug']:
@@ -108,6 +108,11 @@ def main(filename, **args):
 
     tool.initialize()
 
+    if args['variation'] is not None:
+        logging.info("applying systematic variation %s", args['variation'])
+        sys_set = ROOT.CP.SystematicSet()
+        sys_set.insert(ROOT.CP.SystematicVariation(args['variation'], args['variation_sigma']))
+        tool.applySystematicVariation(sys_set)
 
     logging.debug("creating output tree")
     fout = ROOT.TFile("output.root", "recreate")
@@ -154,7 +159,8 @@ def main(filename, **args):
         tree_out.Fill(ei.eventNumber(), cluster.eta(), cluster.phi(),
                       true_e, pdgId, calibrated_energy, xAOD_energy, raw_e, raw_ps)
         if math.isnan(calibrated_energy) or math.isnan(calibrated_energy) or calibrated_energy < 1:
-            print ("==>", particle.author(), particle.eta(), particle.phi(), xAOD_energy, calibrated_energy)
+            print("==>", particle.author(), particle.eta(), particle.phi(), xAOD_energy, calibrated_energy)
+
 
     logging.info("%d events written", tree_out.GetEntries())
 
@@ -179,6 +185,9 @@ if __name__ == '__main__':
     parser.add_argument('--no-layer-correction', action='store_true', default=False)
     parser.add_argument('--no-smearing', action='store_true')
     parser.add_argument('--esmodel', default="es2015c_summer")
+    parser.add_argument('--decorrelation', default='1NP_v1')
+    parser.add_argument('--variation', type=str, help='variation to apply (optional)')
+    parser.add_argument('--variation-sigma', type=int, default=1, help='number of sigma for the variation (+1 or -1)')
     parser.add_argument('--use-afii', type=int)
 
     args = parser.parse_args()
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/test.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/test.py
deleted file mode 100755
index 2f7a1ecce7cbbd12f8432cd28d4666ac9a7f1dee..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/python/test.py
+++ /dev/null
@@ -1,873 +0,0 @@
-#!/usr/bin/env python
-
-# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-
-import unittest
-import math
-import ROOT
-ROOT.PyConfig.IgnoreCommandLineOptions = True
-
-
-def arange(xmin, xmax, delta):
-    # just to don't inject dep from numpy
-    x = xmin
-    while True:
-        yield x
-        x += delta
-        if x >= xmax:
-            break
-
-
-def linspace(start, stop, n):
-    step = (stop - start) / float(n - 1)
-    for i in range(n):
-        yield start + step * i
-
-
-from PATCore.ParticleType import Electron, Photon, ConvertedPhoton, UnconvertedPhoton
-from PATCore.ParticleDataType import Data, Full
-
-
-class Test(unittest.TestCase):
-    def setUp(self):
-        self.all_systematics = [getattr (ROOT.egEnergyCorr.Scale, 'None'),
-                                ROOT.egEnergyCorr.Scale.Nominal,
-                                ROOT.egEnergyCorr.Scale.PSUp, ROOT.egEnergyCorr.Scale.PSDown,
-                                ROOT.egEnergyCorr.Scale.ZeeStatUp, ROOT.egEnergyCorr.Scale.ZeeStatDown,
-                                ROOT.egEnergyCorr.Scale.ZeeSystUp, ROOT.egEnergyCorr.Scale.ZeeSystDown,
-                                ROOT.egEnergyCorr.Scale.ZeeAllUp, ROOT.egEnergyCorr.Scale.ZeeAllDown,
-                                ROOT.egEnergyCorr.Scale.S12Up, ROOT.egEnergyCorr.Scale.S12Down,
-                                ROOT.egEnergyCorr.Scale.L1GainDown, ROOT.egEnergyCorr.Scale.L1GainUp,
-                                ROOT.egEnergyCorr.Scale.L2GainDown, ROOT.egEnergyCorr.Scale.L2GainUp,
-                                ROOT.egEnergyCorr.Scale.LeakageUnconvUp, ROOT.egEnergyCorr.Scale.LeakageUnconvDown,
-                                ROOT.egEnergyCorr.Scale.LeakageConvUp, ROOT.egEnergyCorr.Scale.LeakageConvDown,
-                                ROOT.egEnergyCorr.Scale.MatIDUp, ROOT.egEnergyCorr.Scale.MatIDDown,
-                                ROOT.egEnergyCorr.Scale.MatCryoUp, ROOT.egEnergyCorr.Scale.MatCryoDown,
-                                ROOT.egEnergyCorr.Scale.MatCaloUp, ROOT.egEnergyCorr.Scale.MatCaloDown,
-                                ROOT.egEnergyCorr.Scale.LArCalibUp, ROOT.egEnergyCorr.Scale.LArCalibDown,
-                                ROOT.egEnergyCorr.Scale.LArUnconvCalibUp, ROOT.egEnergyCorr.Scale.LArUnconvCalibDown,
-                                ROOT.egEnergyCorr.Scale.LArElecUnconvUp, ROOT.egEnergyCorr.Scale.LArElecUnconvDown,
-                                ROOT.egEnergyCorr.Scale.AllUp, ROOT.egEnergyCorr.Scale.AllDown]
-
-        # just a shortcut
-        self.EnergyCorrectionTool = ROOT.AtlasRoot.egammaEnergyCorrectionTool
-        self.es = [ROOT.egEnergyCorr.es2010,
-                   ROOT.egEnergyCorr.es2011c,
-                   #              ROOT.egEnergyCorr.es2011d,
-                   ROOT.egEnergyCorr.es2012a,
-                   ROOT.egEnergyCorr.es2012c]
-        self.labels = ["es2010", "es2011c",
-                       #  "es2011d",
-                       "es2012a", "es2012c"]
-        self.tools = {}
-        for es, label in zip(self.es, self.labels):
-            self.tools[label] = self.EnergyCorrectionTool()
-            self.tools[label].setESModel(es)
-            self.tools[label].initialize()
-
-        input_file = ROOT.TFile("$ROOTCOREBIN/data/ElectronPhotonFourMomentumCorrection/example.root")
-        self.electron_tree = input_file.Get("electron")
-        self.photon_tree = input_file.Get("photon")
-#        self.electron_tree = self.electron_tree.CloneTree()
-#        self.electron_tree.SetDirectory(0)
-#        self.photon_tree = self.photon_tree.CloneTree()
-#        self.photon_tree.SetDirectory(0)
-        self.E0MC = input_file.Get("ElectronProfiles/p0MC")
-        self.E1MC = input_file.Get("ElectronProfiles/p1MC")
-        self.E2MC = input_file.Get("ElectronProfiles/p2MC")
-        self.E3MC = input_file.Get("ElectronProfiles/p3MC")
-        self.E0MC.SetDirectory(0)
-        self.E1MC.SetDirectory(0)
-        self.E2MC.SetDirectory(0)
-        self.E3MC.SetDirectory(0)
-
-        self.output_file = ROOT.TFile("output_test.root", "recreate")
-
-    def example_input(self, particle=Electron, eta=0.0,
-                      std_energy=35E3, pdata=Full, phi=0.):
-        return (195848,                         # 0
-                pdata,
-                particle,
-                std_energy * 0.05,  # Es0
-                std_energy * 0.1,   # Es1
-                std_energy * 0.7,   # Es2       # 5
-                std_energy * 0.15,  # Es3
-                eta,                # cl_eta
-                phi,                # cl_phi
-                eta,                # trk_eta
-                std_energy,         # cl_E      # 10
-                eta,                # cl_etaCalo
-                phi,                # cl_phiCalo
-                std_energy * 1.1 if particle == Photon else -999,               # ptconv
-                std_energy * 0.4 if particle == Photon else -999,               # pt1conv   # 15
-                std_energy * 0.7 if particle == Photon else -999,               # pt2conv
-                3 if particle == Photon else -999,       # convtrk1nPixHits
-                5 if particle == Photon else -999,       # convtrk1nSCTHits
-                2 if particle == Photon else -999,       # convtrk2nPixHits
-                4 if particle == Photon else -999,                                          # 20
-                300 if particle == Photon else -999)     # RConv
-
-    def example_electron(self, eta=0.0, std_energy=35E3, pdata=Full, phi=0.):
-        inp = self.example_input(particle=Electron, eta=eta, std_energy=std_energy, pdata=pdata, phi=phi)
-        return inp[3:13]
-
-    def example_photon(self, eta=0.0, std_energy=35E3, pdata=Full, phi=0.):
-        inp = self.example_input(particle=Photon, eta=eta, std_energy=std_energy, pdata=pdata, phi=phi)
-        return inp[3:9] + inp[10:]
-
-    def iscrack(self, eta):
-        # ranges used by MVA calibration
-        return 1.37 <= abs(eta) <= 1.52
-
-    def test_init(self):
-        for es in [ROOT.egEnergyCorr.es2010, ROOT.egEnergyCorr.es2011c,
-                   ROOT.egEnergyCorr.es2011d, ROOT.egEnergyCorr.es2012a, ROOT.egEnergyCorr.es2012c]:
-            tool = self.EnergyCorrectionTool()
-            tool.setESModel(es)
-            self.assertTrue(tool)
-            try:
-                tool.initialize()
-            except Exception as exception:
-                self.fail("EnergyCorrectionTool.initialize raises exception %s" % str(exception))
-
-    def test_mva_working(self):
-        tool_mva = self.EnergyCorrectionTool()
-        tool_mva.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_std = self.EnergyCorrectionTool()
-        tool_std.setESModel(ROOT.egEnergyCorr.es2010)
-
-        tool_mva.initialize()
-        tool_std.initialize()
-
-        for eta in linspace(-2.5, 2.5, 200):
-            inputs = self.example_input(eta=eta)
-            std_energy_input = inputs[10]
-
-            energy_mva = tool_mva.getCorrectedEnergy(*inputs)
-            energy_std = tool_std.getCorrectedEnergy(*inputs)
-            self.assertAlmostEqual(std_energy_input, energy_std)
-            if (not self.iscrack(eta) and not abs(eta) >= 2.47):
-                self.assertNotAlmostEqual(energy_mva, energy_std)
-            else:
-                self.assertAlmostEqual(energy_mva, energy_std)
-
-    def test_intermodule_correction_working(self):
-        tool = self.EnergyCorrectionTool()
-        tool.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_no_correction = self.EnergyCorrectionTool()
-        tool_no_correction.setESModel(ROOT.egEnergyCorr.es2012c)
-
-        tool.initialize()
-        tool_no_correction.initialize()
-
-        tool_no_correction.useIntermoduleCorrection(False)
-
-        energy, energy_no_correction = [], []
-
-        for phi in linspace(-math.pi, math.pi, 400):
-            input_phi = self.example_input(phi=phi, eta=0.1, pdata=Data)
-            energy.append(tool.getCorrectedEnergy(*input_phi))
-            energy_no_correction.append(tool_no_correction.getCorrectedEnergy(*input_phi))
-
-        self.assertFalse(all([x == y for x, y in zip(energy, energy_no_correction)]))
-
-    def test_phicorrection_working(self):
-        tool = self.EnergyCorrectionTool()
-        tool.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_no_correction = self.EnergyCorrectionTool()
-        tool_no_correction.setESModel(ROOT.egEnergyCorr.es2012c)
-
-        tool.initialize()
-        tool_no_correction.initialize()
-
-        tool_no_correction.usePhiUniformCorrection(False)
-
-        h = ROOT.TH2F("phi_correction", "phi_correction", 200, -2.5, 2.5, 200, -math.pi, math.pi)
-
-        energy, energy_no_correction = [], []
-        for eta in linspace(-3, 3, 200):
-            for phi in linspace(-math.pi, math.pi, 200):
-                input_phi = self.example_input(phi=phi, pdata=Data, eta=eta)
-
-                e = tool.getCorrectedEnergy(*input_phi)
-                e_no_correction = tool_no_correction.getCorrectedEnergy(*input_phi)
-
-                energy.append(e)
-                energy_no_correction.append(e_no_correction)
-                h.Fill(eta, phi, e / e_no_correction)
-
-        self.assertFalse(all([x == y for x, y in zip(energy, energy_no_correction)]))
-        self.assertTrue(all([abs(x / y - 1) < 0.3 for x, y in zip(energy, energy_no_correction)]))
-
-        m = min([x / y for x, y in zip(energy, energy_no_correction)])
-        M = max([x / y for x, y in zip(energy, energy_no_correction)])
-
-        canvas_phicorrection = ROOT.TCanvas()
-        h.SetMaximum(m)
-        h.SetMinimum(M)
-        h.Draw("colz")
-        h.SetMaximum(m)
-        h.SetMinimum(M)
-        canvas_phicorrection.Update()
-        canvas_phicorrection.Modified()
-        canvas_phicorrection.SaveAs("canvas_phicorrection.png")
-
-    def test_interface_equivalence(self):
-        tool = self.EnergyCorrectionTool()
-        tool.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool.initialize()
-
-        for eta in linspace(-2.5, 2.5, 200):
-            input_electron = self.example_input(pdata=Data, eta=eta, particle=Electron)
-            input_photon = self.example_input(pdata=Data, eta=eta, particle=Photon)
-
-            input_electron2 = self.example_electron(pdata=Data, eta=eta)
-            input_photon2 = self.example_photon(pdata=Data, eta=eta)
-
-            electron = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(*input_electron2)
-            photon = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(*input_photon2)
-
-            energy_electron2 = tool.getCorrectedEnergyElectron(input_electron[0],
-                                                               input_electron[1],
-                                                               *input_electron2)
-            energy_photon2 = tool.getCorrectedEnergyPhoton(input_electron[0],
-                                                           input_electron[1],
-                                                           *input_photon2)
-
-            energy_electron1 = tool.getCorrectedEnergy(*input_electron)
-            energy_photon1 = tool.getCorrectedEnergy(*input_photon)
-
-            energy_electron3 = tool.getCorrectedEnergy(input_electron[0],
-                                                       input_electron[1],
-                                                       electron)
-
-            energy_photon3 = tool.getCorrectedEnergy(input_electron[0],
-                                                     input_electron[1],
-                                                     photon)
-
-            self.assertAlmostEqual(energy_electron1, energy_electron2)
-            self.assertAlmostEqual(energy_electron2, energy_electron3)
-            self.assertAlmostEqual(energy_photon1, energy_photon2)
-            self.assertAlmostEqual(energy_photon2, energy_photon3)
-
-    def test_scale_factors(self):
-        graph_MC_nominal_ratio = {}
-        graph_data_nominal_ratio = {}
-        for label in self.labels:
-            graph_MC_nominal_ratio[label] = ROOT.TGraph()
-            graph_MC_nominal_ratio[label].SetTitle("MC " + label)
-            graph_data_nominal_ratio[label] = ROOT.TGraph()
-            graph_data_nominal_ratio[label].SetTitle("data " + label)
-
-            ipoint = 0
-
-            for eta in linspace(-2.5, 2.5, 250):
-                input_electron = self.example_input(eta=eta, particle=Electron)
-                particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(*(input_electron[3:13]))
-                nominal = ROOT.egEnergyCorr.Scale.Nominal
-                none = getattr(ROOT.egEnergyCorr.Scale, 'None')
-
-                energy_MC_none = self.tools[label].getCorrectedEnergy(0, Full, particle_information, none)
-                energy_data_none = self.tools[label].getCorrectedEnergy(0, Data, particle_information, none)
-
-                energy_MC_nominal = self.tools[label].getCorrectedEnergy(0, Full, particle_information, ROOT.egEnergyCorr.Scale.Nominal)
-                energy_data_nominal = self.tools[label].getCorrectedEnergy(0, Data, particle_information, ROOT.egEnergyCorr.Scale.Nominal)
-
-                # TODO: check also forward scales
-                if (-2.47 < eta < 2.47):
-                    self.assertAlmostEqual(energy_MC_nominal/energy_MC_none, 1.)
-                    self.assertNotAlmostEqual(energy_data_nominal/energy_data_none, 1.)
-                    graph_MC_nominal_ratio[label].SetPoint(ipoint, eta, energy_MC_nominal/energy_MC_none)
-                    graph_data_nominal_ratio[label].SetPoint(ipoint, eta, energy_data_nominal/energy_data_none)
-                    ipoint += 1
-
-        canvas_MC = ROOT.TCanvas("canvas_MC_ratio")
-        legend = ROOT.TLegend(0.6, 0.6, 0.9, 0.9)
-        for i, graph in enumerate(graph_MC_nominal_ratio.values()):
-            graph.SetLineColor(i + 1)
-            graph.GetYaxis().SetTitle("Nominal-corrected energy / None-corrected energy")
-            graph.GetXaxis().SetTitle("#eta")
-            graph.SetFillColor(0)
-            graph.SetMarkerColor(i + 1)
-            graph.SetMarkerStyle(24 + i)
-            graph.Draw("APL" if i==0 else "PL")
-            legend.AddEntry(graph)
-        legend.Draw()
-        canvas_MC.SaveAs(canvas_MC.GetTitle() + ".png")
-
-        canvas_data = ROOT.TCanvas("canvas_data_ratio")
-        legend2 = ROOT.TLegend(0.6, 0.6, 0.9, 0.9)
-        for i, graph in enumerate(graph_data_nominal_ratio.values()):
-            graph.SetLineColor(i + 1)
-            graph.GetYaxis().SetTitle("Nominal-corrected energy / None-corrected energy")
-            graph.GetXaxis().SetTitle("#eta")
-            graph.SetFillColor(0)
-            graph.SetMarkerColor(i + 1)
-            graph.SetMarkerStyle(24 + i)
-            graph.Draw("APL" if i==0 else "PL")
-            legend2.AddEntry(graph)
-        legend2.Draw()
-        canvas_data.SaveAs(canvas_data.GetTitle() + ".png")
-
-
-    def test_data_over_MC(self):
-        graph_none_ratio = {}
-        for label in self.labels:
-            graph_none_ratio[label] = ROOT.TGraph()
-            graph_none_ratio[label].SetTitle("data_over_MC_ " + label)
-
-            ipoint = 0
-
-            for eta in linspace(-2.5, 2.5, 250):
-                input_electron = self.example_input(eta=eta, particle=Electron)
-                particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(*(input_electron[3:13]))
-
-                energy_MC_none = self.tools[label].getCorrectedEnergy(0, Full, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-                energy_data_none = self.tools[label].getCorrectedEnergy(0, Data, particle_information, getattr (ROOT.egEnergyCorr.Scale, 'None'))
-
-                # TODO: check also forward scales
-                if (-2.47 < eta < 2.47):
-#                    self.assertNotAlmostEqual(energy_MC_none, energy_data_none)
-                    graph_none_ratio[label].SetPoint(ipoint, eta, energy_data_none / energy_MC_none)
-                    ipoint += 1
-
-        canvas_MC = ROOT.TCanvas("canvas_dataOverMC_ratio")
-        legend = ROOT.TLegend(0.6, 0.6, 0.9, 0.9)
-        multigraph = ROOT.TMultiGraph()
-        multigraph.SetTitle("Data / MC no scale;#eta; data/MC None corrected");
-        for i, graph in enumerate(graph_none_ratio.values()):
-            graph.SetLineColor(i + 1)
-            graph.SetMarkerStyle(24 + i)
-            graph.SetFillColor(0)
-            graph.GetYaxis().SetTitle("Data None corrected / MC None corrected")
-            graph.GetXaxis().SetTitle("#eta")
-            multigraph.Add(graph)
-            legend.AddEntry(graph)
-        multigraph.Draw("APL")
-        legend.Draw()
-        canvas_MC.SaveAs(canvas_MC.GetTitle() + ".png")
-
-    def test_compare_layer2_recalib(self):
-        tool_E2 = self.EnergyCorrectionTool()
-        tool_E2.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_E1 = self.EnergyCorrectionTool()
-        tool_E1.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_E1.useLayer2Recalibration(False)
-        tool_E1.initialize()
-        tool_E2.initialize()
-
-        tool_E1.useIntermoduleCorrection(False)
-        tool_E1.usePhiUniformCorrection(False)
-        tool_E2.useIntermoduleCorrection(False)
-        tool_E2.usePhiUniformCorrection(False)
-
-        graph_E1 = ROOT.TGraph()
-        graph_E1.SetName("graph_es2012c_data_E1recalib")
-        graph_E1.SetTitle("layer 1 recalib")
-        graph_E2 = ROOT.TGraph()
-        graph_E2.SetName("graph_es2012c_data_E2recalib")
-        graph_E2.SetTitle("layer 2 recalib")
-        ipoint = 0
-        for eta in linspace(-2.5, 2.5, 250):
-            E0 = self.E0MC.GetBinContent(self.E0MC.FindBin(eta)) * 1E3
-            E1 = self.E1MC.GetBinContent(self.E1MC.FindBin(eta)) * 1E3
-            E2 = self.E2MC.GetBinContent(self.E2MC.FindBin(eta)) * 1E3
-            E3 = self.E3MC.GetBinContent(self.E3MC.FindBin(eta)) * 1E3
-
-            phi = 0
-            particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(E0, E1, E2, E3,
-                                                                                                 eta,
-                                                                                                 phi,
-                                                                                                 eta,
-                                                                                                 40E3,
-                                                                                                 eta,
-                                                                                                 phi)
-            energy_E1_MC = tool_E1.getCorrectedEnergy(0, Full, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-            energy_E1_data = tool_E1.getCorrectedEnergy(0, Data, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-            energy_E2_MC = tool_E2.getCorrectedEnergy(0, Full, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-            energy_E2_data = tool_E2.getCorrectedEnergy(0, Data, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-            graph_E1.SetPoint(ipoint, eta, energy_E1_data / energy_E1_MC)
-            graph_E2.SetPoint(ipoint, eta, energy_E2_data / energy_E2_MC)
-            ipoint += 1
-            self.assertAlmostEqual(energy_E1_MC, energy_E2_MC)
-        graph_E1.SetLineColor(ROOT.kRed)
-        graph_E2.SetLineColor(ROOT.kBlue)
-        graph_E1.SetMarkerColor(ROOT.kRed)
-        graph_E2.SetMarkerColor(ROOT.kBlue)
-        legend = ROOT.TLegend(0.6, 0.6, 0.9, 0.9)
-        for g in (graph_E1, graph_E2):
-            g.GetXaxis().SetTitle("#eta")
-            g.GetYaxis().SetTitle("data None / MC None")
-            g.SetFillColor(0)
-            legend.AddEntry(g)
-        self.output_file.cd()
-        canvas = ROOT.TCanvas()
-        canvas.SetName("layer1_vs_layer2")
-        graph_E1.Draw("APL")
-        graph_E2.Draw("PLsame")
-        legend.Draw()
-        canvas.SaveAs("layer1_vs_layer2.png")
-        canvas.Write()
-
-    def do_test_layer(self, tool, canvas_name, function=None):
-        if function is not None:
-            function(tool)
-
-        tool.useIntermoduleCorrection(False)
-        tool.usePhiUniformCorrection(False)
-
-        canvas = ROOT.TCanvas()
-        canvas.SetName("canvas_" + canvas_name)
-        canvas.Divide(2, 2)
-        gr = []
-        for i in range(4):
-            gr.append(ROOT.TGraph())
-            gr[i].SetTitle(canvas_name + " layer %d" % i)
-            gr[i].GetXaxis().SetTitle("#eta")
-        ipoint = 0
-
-        for eta in linspace(-3.5, 3.5, 300):
-            E0 = self.E0MC.GetBinContent(self.E0MC.FindBin(eta)) * 1E3
-            E1 = self.E1MC.GetBinContent(self.E1MC.FindBin(eta)) * 1E3
-            E2 = self.E2MC.GetBinContent(self.E2MC.FindBin(eta)) * 1E3
-            E3 = self.E3MC.GetBinContent(self.E3MC.FindBin(eta)) * 1E3
-            input_electron = self.example_input(eta=eta, particle=Electron)
-            phi = 0
-            particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(E0, E1, E2, E3,
-                                                                                                 eta,
-                                                                                                 phi,
-                                                                                                 eta,
-                                                                                                 40E3,
-                                                                                                 eta,
-                                                                                                 phi)
-            energy = tool.getCorrectedEnergy(0, Data, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-            r = [1, 1, 1, 1]
-            r[0] = 1 if particle_information.rawcl_Es0==0 else tool.getCalibInputs(0) / particle_information.rawcl_Es0
-            r[1] = 1 if particle_information.rawcl_Es1==0 else tool.getCalibInputs(1) / particle_information.rawcl_Es1
-            r[2] = 1 if particle_information.rawcl_Es2==0 else tool.getCalibInputs(2) / particle_information.rawcl_Es2
-            r[3] = 1 if particle_information.rawcl_Es3==0 else tool.getCalibInputs(3) / particle_information.rawcl_Es3
-            for i in range(4):
-                gr[i].SetPoint(ipoint, eta, r[i])
-            ipoint += 1
-        for i in range(4):
-            canvas.cd(i + 1)
-            gr[i].Draw("APL")
-        canvas.SaveAs("canvas_" + canvas_name + ".png")
-        self.output_file.cd()
-        canvas.Write()
-
-
-    def test_layer(self):
-        tool_es2012c = self.EnergyCorrectionTool()
-        tool_es2012c.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_es2012c.initialize()
-
-        tool_es2011d = self.EnergyCorrectionTool()
-        tool_es2011d.setESModel(ROOT.egEnergyCorr.es2011d)
-        tool_es2011d.initialize()
-
-        self.do_test_layer(tool_es2012c, "es2012c")
-        self.do_test_layer(tool_es2011d, "es2011d")
-
-        tool_es2012c_layer1 = self.EnergyCorrectionTool()
-        tool_es2012c_layer1.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_es2012c_layer1.useLayer2Recalibration(False)
-        tool_es2012c_layer1.initialize()
-
-        tool_es2011d_layer1 = self.EnergyCorrectionTool()
-        tool_es2011d_layer1.setESModel(ROOT.egEnergyCorr.es2011d)
-        tool_es2011d_layer1.useLayer2Recalibration(False)
-        tool_es2011d_layer1.initialize()
-
-        self.do_test_layer(tool_es2012c_layer1, "es2012c_with_layer1")
-        self.do_test_layer(tool_es2011d_layer1, "es2011d_with_layer1")
-
-    def test_gain(self):
-        tool_es2012c = self.EnergyCorrectionTool()
-        tool_es2012c.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_es2012c.initialize()
-        tool_es2012c.useIntermoduleCorrection(False)
-        tool_es2012c.usePhiUniformCorrection(False)
-
-        tool_es2012c_nogain = self.EnergyCorrectionTool()
-        tool_es2012c_nogain.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_es2012c_nogain.initialize()
-        tool_es2012c_nogain.useGainCorrection(False)
-        tool_es2012c_nogain.useIntermoduleCorrection(False)
-        tool_es2012c_nogain.usePhiUniformCorrection(False)
-
-        graph = ROOT.TGraph()
-        ipoint = 0
-        for eta in linspace(-3, 3, 300):
-            input_electron = self.example_input(eta=eta, particle=Electron)
-            particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(*(input_electron[3:13]))
-            energy = tool_es2012c.getCorrectedEnergy(0, Data, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-            energy_nogain = tool_es2012c_nogain.getCorrectedEnergy(0, Data, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-
-            graph.SetPoint(ipoint, eta, energy/energy_nogain)
-            ipoint += 1
-
-        self.output_file.cd()
-        canvas = ROOT.TCanvas()
-        canvas.SetName("canvas_gain")
-        graph.GetXaxis().SetTitle("#eta")
-        graph.GetYaxis().SetTitle("E_{gain} / E_{no gain} data")
-        graph.Draw("APL")
-        canvas.SaveAs("canvas_gain.png")
-        canvas.Write()
-
-
-    def test_gain2(self):
-        tool_es2012c = self.EnergyCorrectionTool()
-        tool_es2012c.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_es2012c.initialize()
-        tool_es2012c.useIntermoduleCorrection(False)
-        tool_es2012c.usePhiUniformCorrection(False)
-
-        tool_es2012c_nogain = self.EnergyCorrectionTool()
-        tool_es2012c_nogain.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_es2012c_nogain.initialize()
-        tool_es2012c_nogain.useGainCorrection(False)
-        tool_es2012c_nogain.useIntermoduleCorrection(False)
-        tool_es2012c_nogain.usePhiUniformCorrection(False)
-
-        graph = ROOT.TGraph()
-        ipoint = 0
-        for eta in linspace(-3.5, 3.5, 300):
-            E0 = self.E0MC.GetBinContent(self.E0MC.FindBin(eta)) * 1E3
-            E1 = self.E1MC.GetBinContent(self.E1MC.FindBin(eta)) * 1E3
-            E2 = self.E2MC.GetBinContent(self.E2MC.FindBin(eta)) * 1E3
-            E3 = self.E3MC.GetBinContent(self.E3MC.FindBin(eta)) * 1E3
-
-            phi = 0
-
-            particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(E0, E1, E2, E3,
-                                                                                                 eta,
-                                                                                                 phi,
-                                                                                                 eta,
-                                                                                                 40E3,
-                                                                                                 eta,
-                                                                                                 phi)
-            energy = tool_es2012c.getCorrectedEnergy(0, Data, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-            energy_nogain = tool_es2012c_nogain.getCorrectedEnergy(0, Data, particle_information, getattr(ROOT.egEnergyCorr.Scale, 'None'))
-
-            if energy_nogain != 0:
-                graph.SetPoint(ipoint, eta, energy/energy_nogain)
-                ipoint += 1
-            elif energy_nogain == 0 and energy == 0:
-                graph.SetPoint(ipoint, eta, 1)
-                ipoint += 1
-
-        self.output_file.cd()
-        canvas = ROOT.TCanvas()
-        canvas.SetName("canvas_gain")
-        graph.GetXaxis().SetTitle("#eta")
-        graph.GetYaxis().SetTitle("E_{gain} / E_{no gain} data")
-        graph.Draw("APL")
-        canvas.SaveAs("canvas_gain2.png")
-        canvas.Write()
-
-    def energy_scan(self, tool, datatype, scale, smearing, etas):
-        energies = []
-        for eta in etas:
-            E0 = self.E0MC.GetBinContent(self.E0MC.FindBin(eta)) * 1E3
-            E1 = self.E1MC.GetBinContent(self.E1MC.FindBin(eta)) * 1E3
-            E2 = self.E2MC.GetBinContent(self.E2MC.FindBin(eta)) * 1E3
-            E3 = self.E3MC.GetBinContent(self.E3MC.FindBin(eta)) * 1E3
-
-            phi = 0
-
-            particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(E0, E1, E2, E3,
-                                                                                                 eta,
-                                                                                                 phi,
-                                                                                                 eta,
-                                                                                                 40E3,
-                                                                                                 eta,
-                                                                                                 phi)
-            energy = tool.getCorrectedEnergy(0, datatype, particle_information,
-                                             scale, smearing)
-            energies.append(energy)
-        return energies
-
-    def test_nan(self):
-        tool = self.EnergyCorrectionTool()
-        tool.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool.initialize()
-
-        for particle in ("electron", "converted", "unconverted"):
-            for scale_energy in [0.05, 0.1, 0.5, 1., 2.0, 10., 100.]:
-                for sys in self.all_systematics:
-                    for eta in linspace(-5, 5, 500):
-                        E0 = self.E0MC.GetBinContent(self.E0MC.FindBin(eta)) * 1E3 * scale_energy
-                        E1 = self.E1MC.GetBinContent(self.E1MC.FindBin(eta)) * 1E3 * scale_energy
-                        E2 = self.E2MC.GetBinContent(self.E2MC.FindBin(eta)) * 1E3 * scale_energy
-                        E3 = self.E3MC.GetBinContent(self.E3MC.FindBin(eta)) * 1E3 * scale_energy
-                        if E0 == 0 and E1 == 0 and E2 == 0 and E3 == 0:
-                            E0 = self.E0MC.GetBinContent(self.E0MC.FindBin(2)) * 1E3 * scale_energy
-                            E1 = self.E1MC.GetBinContent(self.E1MC.FindBin(2)) * 1E3 * scale_energy
-                            E2 = self.E2MC.GetBinContent(self.E2MC.FindBin(2)) * 1E3 * scale_energy
-                            E3 = self.E3MC.GetBinContent(self.E3MC.FindBin(2)) * 1E3 * scale_energy
-                        cl_E = 40E3 * scale_energy
-
-                        phi = 0
-
-                        if particle == "converted":
-                            particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(E0, E1, E2, E3,
-                                                                                                                 eta,
-                                                                                                                 phi,
-                                                                                                                 cl_E,
-                                                                                                                 eta,
-                                                                                                                 phi,
-                                                                                                                 35E3 * scale_energy,
-                                                                                                                 20E3 * scale_energy,
-                                                                                                                 18E3 * scale_energy,
-                                                                                                                 1,
-                                                                                                                 1,
-                                                                                                                 1,
-                                                                                                                 1, 100)
-                            particle_str = "converted eta:%f, phi:%f, E0:%f, E1:%f, E2:%f, E3:%f, cl_E:%f, ptconv: %f, p1: %f, p2: %f, R: %f" % (eta, phi, E0, E1, E2, E3, cl_E, 35E3*scale_energy, 20E3*scale_energy, 18E3 * scale_energy, 100)
-
-                        elif particle == "unconverted":
-                            particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(E0, E1, E2, E3,
-                                                                                                                 eta,
-                                                                                                                 phi,
-                                                                                                                 cl_E,
-                                                                                                                 eta,
-                                                                                                                 phi,
-                                                                                                                 0,
-                                                                                                                 0,
-                                                                                                                 0,
-                                                                                                                 0,
-                                                                                                                 0,
-                                                                                                                 0,
-                                                                                                                 0, 0)
-                            particle_str = "unconverted eta:%f, phi:%f, E0:%f, E1:%f, E2:%f, E3:%f, cl_E:%f" % (eta, phi, E0, E1, E2, E3, cl_E)
-
-                        elif particle == "electron":
-                            particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(E0, E1, E2, E3,
-                                                                                                                 eta,
-                                                                                                                 phi,
-                                                                                                                 eta,
-                                                                                                                 cl_E,
-                                                                                                                 eta, phi)
-
-                            particle_str = "electron eta:%f, phi:%f, E0:%f, E1:%f, E2:%f, E3:%f, cl_E:%f" % (eta, phi, E0, E1, E2, E3, cl_E)
-
-                        energy = tool.getCorrectedEnergy(0, Full, particle_information, sys, getattr(ROOT.egEnergyCorr.Resolution, 'None'))
-                        self.assertFalse(math.isnan(energy), msg="got nan for sys=%f, %s" % (sys, particle_str))
-
-                        if sys in (getattr(ROOT.egEnergyCorr.Scale, 'None'), ROOT.egEnergyCorr.Scale.Nominal):
-                            energy = tool.getCorrectedEnergy(0, Full, particle_information, sys, ROOT.egEnergyCorr.Resolution.Nominal)
-                            self.assertFalse(math.isnan(energy), msg="got nan for Nominal res, %s" % particle_str)
-                            energy = tool.getCorrectedEnergy(0, Full, particle_information, sys, ROOT.egEnergyCorr.Resolution.AllUp)
-                            self.assertFalse(math.isnan(energy), msg="got nan for ErrorUp res, %s" % particle_str)
-                            energy = tool.getCorrectedEnergy(0, Full, particle_information, sys, ROOT.egEnergyCorr.Resolution.AllDown)
-                            self.assertFalse(math.isnan(energy), msg="got nan for ErrorDown res, %s" % particle_str)
-                            energy = tool.getCorrectedEnergy(0, Data, particle_information, sys, ROOT.getattr(egEnergyCorr.Resolution, 'None'))
-                            self.assertFalse(math.isnan(energy), msg="got nan for Data, sys=%s, %s" % (sys, particle_str))
-
-    def test_systematics(self):
-        tool = self.EnergyCorrectionTool()
-        tool.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool.initialize()
-
-        etas = list(linspace(0, 2.4, 300))
-
-        datatype = Full
-
-        systematics = self.all_systematics
-
-        def create_graph(etas, nominal, distorted):
-            gr = ROOT.TGraph()
-            for i, (eta, n, d) in enumerate(zip(etas, nominal, distorted)):
-                gr.SetPoint(i, eta, d / n)
-            return gr
-
-        all_energies_smearing = {}
-        all_energies_nosmearing = {}
-
-        for sys in systematics + [ROOT.egEnergyCorr.Scale.Nominal]:
-            tool.setRandomSeed(1)
-            energies_sys_smearing = self.energy_scan(tool, datatype, sys, ROOT.egEnergyCorr.Resolution.Nominal, etas)
-            energies_sys_nosmearing = self.energy_scan(tool, datatype, sys, getattr(ROOT.egEnergyCorr.Resolution, 'None'), etas)
-            all_energies_smearing[sys] = energies_sys_smearing
-            all_energies_nosmearing[sys] = energies_sys_nosmearing
-
-        ratios_smearing = {}
-        ratios_nosmearing = {}
-        for sys in systematics:
-            ratios_smearing[sys] = create_graph(etas, all_energies_smearing[sys], all_energies_smearing[ROOT.egEnergyCorr.Scale.Nominal])
-            ratios_nosmearing[sys] = create_graph(etas, all_energies_nosmearing[sys], all_energies_nosmearing[ROOT.egEnergyCorr.Scale.Nominal])
-            ratios_smearing[sys].SetLineColor(ROOT.kRed)
-            ratios_smearing[sys].SetMarkerStyle(24)
-            ratios_smearing[sys].SetMarkerColor(ROOT.kRed)
-
-        canvas = ROOT.TCanvas()
-        multigraph = ROOT.TMultiGraph()
-        multigraph.SetTitle("All;#eta; E_{sys} / E_{nom}")
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.AllUp])
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.AllDown])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.AllUp])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.AllDown])
-        multigraph.Draw("APL")
-        canvas.SaveAs("sys_All_es2012c.png")
-
-        canvas = ROOT.TCanvas()
-        multigraph = ROOT.TMultiGraph()
-        multigraph.SetTitle("LeakageUnconv;#eta; E_{sys} / E_{nom}")
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.LeakageUnconvUp])
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.LeakageUnconvDown])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.LeakageUnconvUp])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.LeakageUnconvDown])
-        multigraph.Draw("APL")
-        canvas.SaveAs("sys_LeakageUnconv_es2012c.png")
-
-        canvas = ROOT.TCanvas()
-        multigraph = ROOT.TMultiGraph()
-        multigraph.SetTitle("LeakageConv;#eta; E_{sys} / E_{nom}")
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.LeakageConvUp])
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.LeakageConvDown])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.LeakageConvUp])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.LeakageConvDown])
-        multigraph.Draw("APL")
-        canvas.SaveAs("sys_LeakageConv_es2012c.png")
-
-        canvas = ROOT.TCanvas()
-        multigraph = ROOT.TMultiGraph()
-        multigraph.SetTitle("S12;#eta; E_{sys} / E_{nom}")
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.S12Up])
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.S12Down])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.S12Up])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.S12Down])
-        multigraph.Draw("APL")
-        canvas.SaveAs("sys_S12_es2012c.png")
-
-        canvas = ROOT.TCanvas()
-        multigraph = ROOT.TMultiGraph()
-        multigraph.SetTitle("PS;#eta; E_{sys} / E_{nom}")
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.PSUp])
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.PSDown])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.PSUp])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.PSDown])
-        multigraph.Draw("APL")
-        canvas.SaveAs("sys_PS_es2012c.png")
-
-        canvas = ROOT.TCanvas()
-        multigraph = ROOT.TMultiGraph()
-        multigraph.SetTitle("ZeeStat;#eta; E_{sys} / E_{nom}")
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.ZeeStatUp])
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.ZeeStatDown])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.ZeeStatUp])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.ZeeStatDown])
-        multigraph.Draw("APL")
-        canvas.SaveAs("sys_ZeeStat_es2012c.png")
-
-        canvas = ROOT.TCanvas()
-        multigraph = ROOT.TMultiGraph()
-        multigraph.SetTitle("ZeeSyst;#eta; E_{sys} / E_{nom}")
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.ZeeSystUp])
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.ZeeSystDown])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.ZeeSystUp])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.ZeeSystDown])
-        multigraph.Draw("APL")
-        canvas.SaveAs("sys_ZeeSyst_es2012c.png")
-
-        canvas = ROOT.TCanvas()
-        multigraph = ROOT.TMultiGraph()
-        multigraph.SetTitle("mg_Zeeall;#eta; E_{sys} / E_{nom}")
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.ZeeAllUp])
-        multigraph.Add(ratios_smearing[ROOT.egEnergyCorr.Scale.ZeeAllDown])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.ZeeAllUp])
-        multigraph.Add(ratios_nosmearing[ROOT.egEnergyCorr.Scale.ZeeAllDown])
-        multigraph.Draw("APL")
-        canvas.SaveAs("sys_ZeeAll_es2012c.png")
-
-    def test_layer_invariance(self):
-        tool_es2012c_layer1 = self.EnergyCorrectionTool()
-        tool_es2012c_layer1.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_es2012c_layer1.useLayer2Recalibration(False)
-        tool_es2012c_layer1.initialize()
-
-        tool_es2012c_layer2 = self.EnergyCorrectionTool()
-        tool_es2012c_layer2.setESModel(ROOT.egEnergyCorr.es2012c)
-        tool_es2012c_layer2.initialize()
-
-        for eta in linspace(-3.5, 3.5, 300):
-            E0 = self.E0MC.GetBinContent(self.E0MC.FindBin(eta)) * 1E3
-            E1 = self.E1MC.GetBinContent(self.E1MC.FindBin(eta)) * 1E3
-            E2 = self.E2MC.GetBinContent(self.E2MC.FindBin(eta)) * 1E3
-            E3 = self.E3MC.GetBinContent(self.E3MC.FindBin(eta)) * 1E3
-
-            phi = 0
-
-            particle_information = ROOT.AtlasRoot.egammaEnergyCorrectionTool.ParticleInformation(E0, E1, E2, E3,
-                                                                                                 eta,
-                                                                                                 phi,
-                                                                                                 40E3,
-                                                                                                 eta,
-                                                                                                 phi,
-                                                                                                 35E3,
-                                                                                                 20E3,
-                                                                                                 18E3,
-                                                                                                 1,
-                                                                                                 1,
-                                                                                                 1,
-                                                                                                 1, 100)
-            energy1 = tool_es2012c_layer1.getCorrectedEnergy(0, Full, particle_information,
-                                                             getattr(ROOT.egEnergyCorr.Scale, 'None'),
-                                                             getattr(ROOT.egEnergyCorr.Resolution, 'None'))
-            energy2 = tool_es2012c_layer2.getCorrectedEnergy(0, Full, particle_information,
-                                                             getattr(ROOT.egEnergyCorr.Scale, 'None'),
-                                                             getattr(ROOT.egEnergyCorr.Resolution, 'None'))
-
-            self.assertEqual(energy1, energy2)
-
-
-class TestConsistencyEgammaMVACalib(unittest.TestCase):
-    def test_electron(self):
-        weight_version = "egammaMVACalib/v1"
-        tool_egammaMVACalib = ROOT.egammaMVACalib(ROOT.egammaMVACalib.egELECTRON,
-                                                  True, weight_version)
-        tool_egammaMVACalib.InitTree(0)
-        # egammaEnergyCorrectionTool uses as default v1
-        tool_EP4MC = ROOT.AtlasRoot.egammaEnergyCorrectionTool()
-        tool_EP4MC.setESModel(6)   # es2012c
-        tool_EP4MC.initialize()
-        from itertools import product
-        for eta, phi, phi_shift, eta_shift, el_cl_E in product(arange(-2.5, 2.5, 0.02),
-                                                               arange(-3, 3, 0.2),
-                                                               (-0.01, 0, 0.01),
-                                                               (-0.01, 0, 0.01),
-                                                               arange(1E3, 200E3, 20E3)):
-            Es0 = el_cl_E * 0.8 * 0.05
-            Es1 = el_cl_E * 0.8 * 0.10
-            Es2 = el_cl_E * 0.8 * 0.65
-            Es3 = el_cl_E * 0.8 * 0.20
-            phiCalo = phi + phi_shift
-            trk_eta = eta + eta_shift
-            etaCalo = eta - eta_shift
-            args = (0, 1,   # run number, Full simulation
-                    Es0, Es1, Es2, Es3,
-                    eta, phi, trk_eta,
-                    el_cl_E,
-                    etaCalo, phiCalo,
-                    0, 0)  # no scale factor, no smearing
-            energy_EP4MC = tool_EP4MC.getCorrectedEnergyElectron(*args)
-            args = (Es0, Es1, Es2, Es3, eta, el_cl_E, etaCalo, phiCalo)
-            energy_egammaMVACalib = tool_egammaMVACalib.getMVAEnergyElectron(*args)
-            self.assertAlmostEqual(energy_EP4MC, energy_egammaMVACalib,
-                                   msg="different energy eta=%f" % eta)
-
-if __name__ == '__main__':
-    ROOT.gROOT.ProcessLine(".x $ROOTCOREBIN/scripts/load_packages.C")
-#    ROOT.gROOT.LoadMacro("AtlasStyle.C")
-#    ROOT.SetAtlasStyle()
-    ROOT.gStyle.SetCanvasDefH(800)
-    ROOT.gStyle.SetCanvasDefW(800)
-    ROOT.gStyle.SetPadTickX(1)
-    ROOT.gStyle.SetPadTickY(1)
-    ROOT.gStyle.SetLabelSize(0.03, "X")
-    ROOT.gStyle.SetLabelSize(0.03, "Y")
-    ROOT.gStyle.SetTitleSize(0.03, "X")
-    ROOT.gStyle.SetTitleSize(0.03, "Y")
-    unittest.main()
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/share/CalibrationExample_jobOptions.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/share/CalibrationExample_jobOptions.py
index 1984849f94c56148aba5966f63d0847c17c5d83f..515ba965f3adab40a9fb2c2f5ff1634ba6d36b3a 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/share/CalibrationExample_jobOptions.py
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/share/CalibrationExample_jobOptions.py
@@ -15,6 +15,7 @@ alg = testAthenaEgammaCalibTool()
 alg.EgammaCalibrationAndSmearingTool.ESModel = "es2015cPRE"
 alg.EgammaCalibrationAndSmearingTool.OutputLevel = DEBUG
 theJob += alg
+print alg
 
 # Do some additional tweaking:
 from AthenaCommon.AppMgr import theApp
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/CalibratedEgammaProvider.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/CalibratedEgammaProvider.h
index 8876bad77329f13f27c3d375d1e2272f457b2058..47a27c33389223d1c5880be7d799a32fdf481186 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/CalibratedEgammaProvider.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/CalibratedEgammaProvider.h
@@ -1,12 +1,12 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 
 //athena friendly provider of egamma calibrations - applies the egammaCalibTool to collections 
 //author: will buttinger
 
-// Dear emacs, this is -*- c++ -*-
+
 #ifndef CALIBRATEDEGAMMAPROVIDER_H
 #define CALIBRATEDEGAMMAPROVIDER_H
 
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/components/ElectronPhotonFourMomentumCorrection_load.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/components/ElectronPhotonFourMomentumCorrection_load.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..c5db2c71b2a1530a11e9efeec83a00c5ea89242b
--- /dev/null
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/components/ElectronPhotonFourMomentumCorrection_load.cxx
@@ -0,0 +1,3 @@
+#include "GaudiKernel/LoadFactoryEntries.h"
+
+LOAD_FACTORY_ENTRIES( ElectronPhotonFourMomentumCorrection )
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/dumpAllSystematics.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/dumpAllSystematics.cxx
index a7cb4415e346ff2f0da585f671d9304cf6ea8b96..3625bf1e7173ffa8f2c70376566faf33e24fdc99 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/dumpAllSystematics.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/dumpAllSystematics.cxx
@@ -34,33 +34,7 @@
 #include "dumpAllSystematics.h"
 
 DumpAllSystematics::DumpAllSystematics(const std::string& name, ISvcLocator* svcLoc)
-  : AthAlgorithm(name, svcLoc),
-  m_EventNumber(0),
-  m_RunNumber(0),
-  m_instance_index(0),
-  m_actualIntPerXing(0.),
-  m_averageIntPerXing(0.),
-  m_truth_pt(0.),
-  m_truth_phi(0.),
-  m_truth_eta(0.),
-  m_truth_E(0.),
-  m_truth_pdgId(0),
-  m_truth_parent_pdgId(0),
-  m_truth_matched(false),
-  m_truth_isConv(false),
-  m_truth_Rconv(0.),
-  m_npv(0),
-  m_cl_phi(0.),
-  m_cl_eta(0.),
-  m_cl_etaCalo(0.),
-  m_cl_rawcl_Es0(0.),
-  m_cl_rawcl_Es1(0.),
-  m_cl_rawcl_Es2(0.),
-  m_cl_rawcl_Es3(0.),
-  m_cl_E(0.),
-  m_ph_Rconv(0.),
-  m_ph_convFlag(0),
-  m_wstot(0.)
+  : AthAlgorithm(name, svcLoc)
 {
   declareProperty("EgammaCalibrationAndSmearingTools", m_EgammaCalibrationAndSmearingTools);
   declareProperty("particle", m_particle_name="", "electron/photon");
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/dumpAllSystematics.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/dumpAllSystematics.h
index c99ef08367ad8b6f22dea9213a03443250d24455..268810729de2f1708141a0ad5ae9e3cecab649e8 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/dumpAllSystematics.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/dumpAllSystematics.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-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef DUMPALLSYSTEMATICS_H
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/testAthenaEgammaCalibTool.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/testAthenaEgammaCalibTool.cxx
index 538b63bdaf60fd3464b4938afb57d56b6f3a0fa4..6d500b74c3eadfb4d5ebf46e88995d69daf246d6 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/testAthenaEgammaCalibTool.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/testAthenaEgammaCalibTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 // EDM include(s):
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/testAthenaEgammaCalibTool.h b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/testAthenaEgammaCalibTool.h
index a4b217e79fb17098a50066d6e1d0d6a3982b897f..014fe4745b7eeef68fcfc4ed6f4ed872d5ba9d95 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/testAthenaEgammaCalibTool.h
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/src/testAthenaEgammaCalibTool.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-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TESTATHENAEGAMMACALIBTOOL_H
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test.py
index ff7f8a591d6a26f3913eb64d51434d115a8ef0af..ce598840a5fd4716323e1ba1d07406cbe4694a51 100755
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test.py
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test.py
@@ -522,7 +522,7 @@ class TestEgammaCalibrationAndSmearingTool(unittest.TestCase):
         tool_1NP.setProperty("int")("randomRunNumber", RUN2015).ignore()
         #tool_1NP.setProperty("int")("doSmearing", 0).ignore()   # remove
         #tool_1NP.msg().setLevel(ROOT.MSG.DEBUG)
-        
+
         tool_1NP.initialize().ignore()
 
         tool_FULL = ROOT.CP.EgammaCalibrationAndSmearingTool("tool_es2016data_mc15c_FULL")
@@ -536,7 +536,7 @@ class TestEgammaCalibrationAndSmearingTool(unittest.TestCase):
         tool_FULL.initialize().ignore()
 
         ei = self.factory.create_eventinfo(True, 100000)  # MC
-        for ptype, generator in self.generators().items():
+        for ptype, generator in self.generators().iteritems():
             for particle in generator:
                 sys_set = ROOT.CP.SystematicSet()
                 tool_FULL.applySystematicVariation(sys_set).ignore()
@@ -728,5 +728,5 @@ if __name__ == '__main__':
     ROOT.gROOT.ProcessLine(".x $ROOTCOREDIR/scripts/load_packages.C")
 #    from ROOT import EgammaCalibPeriodRunNumbersExample
 
-    #ROOT.StatusCode.enableChecking()
+    #ROOT.xAOD.TReturnCode.enableFailure()
     unittest.main()
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test_factory.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test_factory.py
index e3177ee80c5c784995ab9f18a46f575de420328a..ff2ae3998b8014c9efb8f7405a883bd8e030e215 100755
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test_factory.py
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test_factory.py
@@ -36,7 +36,7 @@ class TestEgammaFactory(unittest.TestCase):
         self.assertAlmostEqual(ph.caloCluster().auxdata("float")("phiCalo"), phi)
         self.assertAlmostEqual(ph.e(), e, delta=0.01)
         self.assertEqual(ph.caloCluster().e(), e)
-        for i in range(3):
+        for i in xrange(3):
             self.assertGreater(ph.caloCluster().energyBE(i), 0)
 
     def test_converted(self):
@@ -60,7 +60,7 @@ class TestEgammaFactory(unittest.TestCase):
         self.assertAlmostEqual(ph.caloCluster().auxdata("float")("phiCalo"), phi)
         self.assertAlmostEqual(ph.e(), e, delta=0.01)
         self.assertEqual(ph.caloCluster().e(), e)
-        for i in range(3):
+        for i in xrange(3):
             self.assertGreater(ph.caloCluster().energyBE(i), 0)
 
     def test_photon(self):
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test_resolution.py b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test_resolution.py
index da0420ee3617cf32506713a13fa48cd6fd31a630..b4a330f56aceeb8ef213a825043a182c0c7a807f 100755
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test_resolution.py
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/test/ut_test_resolution.py
@@ -97,7 +97,7 @@ class TestEgammaResolution(unittest.TestCase):
         f = ROOT.TFile(rootfile)
         tree = f.Get("test_resolution_nonregression_data_run1")
 
-        for ievent in range(tree.GetEntries()):
+        for ievent in xrange(tree.GetEntries()):
 
             tree.GetEntry(ievent)
             resolution = self.tool_run1.getResolution(tree.ptype,
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/ElectronPhotonFourMomentumCorrection_test_memory.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/ElectronPhotonFourMomentumCorrection_test_memory.cxx
index 28ac4b93e25ed79a1ad7e86d8aa8943f27d819b9..014e8ccf3785c8682e854789d1003d04d6592f8a 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/ElectronPhotonFourMomentumCorrection_test_memory.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/ElectronPhotonFourMomentumCorrection_test_memory.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include <ElectronPhotonFourMomentumCorrection/EgammaCalibrationAndSmearingTool.h>
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testEgammaCalibTool.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testEgammaCalibTool.cxx
index da495d0505f76a1aa860c21883fa5c065b2ee9aa..2ee5a17e0044792e67a4adf9dfe0dbd21335cc87 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testEgammaCalibTool.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testEgammaCalibTool.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 //simple macro to test the xAOD-based calibration tool
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testMomentumSystematics.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testMomentumSystematics.cxx
index 13a792906026de34afc75cfc6db3d4de437f3b5f..a2fa32076800ee81cc32e2d7c71e6a3d5c0b4e52 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testMomentumSystematics.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testMomentumSystematics.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include <ElectronPhotonFourMomentumCorrection/egammaEnergyCorrectionTool.h>
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testResolutionParam.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testResolutionParam.cxx
index 584c73b999f0ab21f306a809381c6fc0295a8f77..20f38592500c1f98c8e1dbd454de227e7588c939 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testResolutionParam.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testResolutionParam.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include <ElectronPhotonFourMomentumCorrection/egammaEnergyCorrectionTool.h>
@@ -10,6 +10,7 @@
 #include "TLegend.h"
 #include "TStyle.h"
 #include "TPad.h"
+#include "TFile.h"
 
 int main() {
 
diff --git a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testUniformityCorrections.cxx b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testUniformityCorrections.cxx
index 3b322cb82bc7b5952f4589815e6d527fec40742e..886545fee65dbe976577c466f5d78abe6b5ccf39 100644
--- a/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testUniformityCorrections.cxx
+++ b/PhysicsAnalysis/ElectronPhotonID/ElectronPhotonFourMomentumCorrection/util/testUniformityCorrections.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include <ElectronPhotonFourMomentumCorrection/egammaEnergyCorrectionTool.h>
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/CMakeLists.txt b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/CMakeLists.txt
deleted file mode 100644
index d26b43e199b95ed53ca9f1ac05702881f45e7e07..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/CMakeLists.txt
+++ /dev/null
@@ -1,11 +0,0 @@
-################################################################################
-# Package: HIInDetValidation
-################################################################################
-
-# Declare the package name:
-atlas_subdir( HIInDetValidation )
-
-# Install files from the package:
-atlas_install_joboptions( share/*.py )
-atlas_install_runtime( test/HIInDetValidation_TestConfiguration.xml share/HIInDetValidation*.py macros/HIInDetValidation_Eff*.C macros/HIInDetValidation_Fakes*.C macros/HIInDetValidation_CoolDozer.py share/ARTT_Plots.html macros/png_file.png macros/HIInDetValidation_Loose_Vs_Tight.C macros/HIInDetValidation_Vertexing.C share/HIInDetTrkD3PD_jobOptions.py )
-
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_CoolDozer.py b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_CoolDozer.py
deleted file mode 100644
index 8884001f9e6f94089a90b917e8e464aad7e9e500..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_CoolDozer.py
+++ /dev/null
@@ -1,115 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# Based on RTTRandomDozerApp by K. Ciba
-
-import sys
-sys.argv.append("-b")
-sys.rtt = True
-
-from CoolDozer import *
-import logging
-
-class HIInDetValidation_CoolDozer( RTTDozerApp ):
-
-    def __init__( self, argDict = {}):        
-        ## call base class constructor
-        RTTDozerApp.__init__(self, argDict)
-        #super( RTTDozerApp, self ).__init__( argDict )
-        self.algoNames = ("Track_Loose", "Track_Tight");
-
-    def schema( self ):
-        self.info("will construct generic DozerSchema")
-
-        schema = DozerSchema()
-
-        effChannel = DozerChannel( "efficiency", "efficiency of tracks reconstruction")
-        for algo in self.algoNames:
-            effChannel += DozerData(algo, "Double", "%" )
-            effChannel += DozerData(algo+";error", "Double", "%" )
-        schema += effChannel
-
-        fakeChannel = DozerChannel( "fakerate", "fake rate of tracks reconstruction")
-        for algo in self.algoNames:
-            fakeChannel += DozerData(algo, "Double", "%" )
-            fakeChannel += DozerData(algo+";error", "Double", "%" )
-        schema += fakeChannel
-
-        #resChannel = DozerChannel( "resolution", "resolutions of algorithms")
-        #for algo in self.algoNames:
-        #    resChannel += DozerData(algo, "Double", "%" )
-        #schema += resChannel
-
-        return schema
-
-    def writer( self ):
-        import glob
-
-        #get truth efficiency
-        filelista = glob.glob("efficiency_HIInDetValidation.txt")
-        if ( len(filelista) == 0 ):
-            return
-        infile = file(filelista[0])
-
-        while infile:
-            line = infile.readline()
-            if (line == ''):
-                break
-            if (line.find('eff') > -1):
-                words = line.split()
-                for algo in self.algoNames:
-                    if (words[0] == algo):
-                        self.dozerSchema["efficiency"][algo].setValue( float(words[3]) )
-                        self.dozerSchema["efficiency"][algo+";error"].setValue( float(words[6]) )
-
-        #fake ratios
-        filelistb = glob.glob("fakes_HIInDetValidation.txt")
-        if ( len(filelistb) == 0 ):
-            return
-        infileb = file(filelistb[0])
-
-        while infileb:
-            lineb = infileb.readline()
-            if (lineb == ''):
-                break                        
-            if (lineb.find('fake') > -1):
-                wordsb = lineb.split()
-                for algo in self.algoNames:
-                    if (wordsb[0] == algo):
-                        self.dozerSchema["fakerate"][algo].setValue( float(wordsb[4]) )
-                        self.dozerSchema["fakerate"][algo+";error"].setValue( float(wordsb[7]) )
-
-## dummy standalone run outside RTT
-if __name__ == "__main__":
-    print "Dummy test running..."
-
-    ##
-    # @class Paths
-    # @brief fake RTT Paths
-    class Paths:
-        def __init__(self):
-            self.release    = "rel_0"
-            self.branch     = "devval"
-            self.runType    = "build"
-            self.cmtConfig  = "i686-slc4-gcc34-opt"
-            self.topProject = "AtlasAnalysis"
-            self.packageTag = "HIInDetValidation-00-00-05"
-    ##
-    # @class Desc
-    # @brief fake RTT JobDescriptor for testing
-    class Desc:
-        def __init__(self):
-            self.package    = "HIInDetValidation"
-            self.trendId    = "testJob"
-            self.runPath    = "."
-            self.paths      = Paths()
-            self.log        = "dummy.log"
-
-    testCfg = { "JobDescriptor"    : Desc(),
-                "LastNDays"        : 30,
-                "Fit"              : True, 
-                "Histos"           : False, 
-                "DryRun"           : False,
-                "Style"            : "Dozer" }
-
-    testDozerApp = HIInDetValidation_CoolDozer( testCfg )
-    testDozerApp.run()
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Eff_Loose.C b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Eff_Loose.C
deleted file mode 100644
index 6af38159874367be9639ce60106915c6a15a2f2c..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Eff_Loose.C
+++ /dev/null
@@ -1,814 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "vector"
-#include "stdio.h"
-#include "TFile.h"
-#include "TChain.h"
-#include "TH2F"
-#include "TH1F.h"
-#include "TCanvas.h"
-#include "TMath.h"
-#include "TLatex.h"
-
-
-#include "TTree.h"
-#include "TBrowser.h"
-#include "TH2.h"
-#include "TRandom.h"
-
-#ifdef __MAKECINT__
-#pragma link C++ class vector<float>+;
-#endif
-
-const Float_t MIN_MC_PROB = 0.5;
-
-const Float_t PT_CUT = 500.;
-
-// event selection
-const Int_t APPLY_PV_CUT = 1;
-const Int_t APPLY_TRIGGER_CUT  = 0;
-const Int_t APPLY_ONEGOODTRACK = 1;
-//const TRIGL1NAME = 'L1_MBTS_1';
-
-const Int_t APPLY_PV_CORR  = 0;
-const Int_t MAX_EVTS = -1;
-
-   std::vector<float> *reco=0;
-   std::vector<int> *recoh=0;
-   TBranch *br;
-   TBranch *brh;   
-   Float_t aa;
-   Float_t aaa;
-   
-   
-bool trkCutsEvtSelection(TTree *L, Int_t evt, Int_t r, Float_t pt, Float_t eta){
-
-
-    // pT > PT_CUT MeV
-    if (pt < PT_CUT) return 0;
-
-    // |eta| < 2.5
-    if (fabs(eta) > 2.5 ) return 0;
-//////////////////////////////////////////////
-    brh = L->GetBranch("trk_nPixHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-
-    // Pixel hits
-    if ( recoh->at(r) < 1 ) return 0;
-    // Pixel holes
-    //if evt.trk_nPixHoles[r] > 0 : return False
-
-    brh = L->GetBranch("trk_nSCTHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-
-    // SCT hits
-    if (recoh->at(r) < 6 ) return 0;
-
-
-
-    br = L->GetBranch("trk_d0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-
-    if (fabs( reco->at(r) ) > 1.5 ) return 0;
-
-    br = L->GetBranch("trk_z0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aa = reco->at(r);
-
-    br = L->GetBranch("trk_theta");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aaa = reco->at(r);
-
-    // z0 sin(theta) cut
-   if ( fabs( aa * TMath::Sin( aaa) ) > 1.5 ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-   std::vector<float> *recot=0;
-   std::vector<int> *recoht=0;
-   TBranch *brt;
-   TBranch *brht;
-   
-   Float_t aat;
-   Float_t aaat;
-   
-bool trkCuts(TTree *L, Int_t evt, Int_t r, Float_t pt, Float_t eta){
-
-
-    // pT > PT_CUT MeV
-    if (pt < PT_CUT) return 0;
-
-    // |eta| < 2.5
-    if (fabs(eta) > 2.5 ) return 0;
-//////////////////////////////////////////////
-    brht = L->GetBranch("trk_nPixHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-
-    // Pixel hits
-    if ( recoht->at(r) < 1 ) return 0;
-    // Pixel holes
-    //if evt.trk_nPixHoles[r] > 0 : return False
-
-    brht = L->GetBranch("trk_nSCTHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-
-    // SCT hits
-    if (recoht->at(r) < 6 ) return 0;
-
-    brt = L->GetBranch("trk_d0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-
-    if (fabs( recot->at(r) ) > 1.5 ) return 0;
-
-    brt = L->GetBranch("trk_z0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-	aat = recot->at(r);
-
-    brt = L->GetBranch("trk_theta");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-    aaat = recot->at(r);
-
-    // z0 sin(theta) cut
-    if ( fabs( aat * TMath::Sin( aaat) ) > 1.5 ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-void HIInDetValidation_Eff_Loose(){
-
-/////////////////ATLAS STYLE//////////////////////////////////////////
-TStyle *atlasStyle = new TStyle("ATLAS","Atlas style");
-
-  // use plain black on white colors
-  Int_t icol=0; // WHITE
-  atlasStyle->SetFrameBorderMode(icol);
-  atlasStyle->SetFrameFillColor(icol);
-  atlasStyle->SetCanvasBorderMode(icol);
-  atlasStyle->SetCanvasColor(icol);
-  atlasStyle->SetPadBorderMode(icol);
-  atlasStyle->SetPadColor(icol);
-  atlasStyle->SetStatColor(icol);
-  //atlasStyle->SetFillColor(icol); // don't use: white fill color for *all* objects
-
-  // set the paper & margin sizes
-  atlasStyle->SetPaperSize(20,26);
-
-  // set margin sizes
-  atlasStyle->SetPadTopMargin(0.10);
-  atlasStyle->SetPadRightMargin(0.05);
-  atlasStyle->SetPadBottomMargin(0.10);
-  atlasStyle->SetPadLeftMargin(0.10);
-
-  // set title offsets (for axis label)
-  atlasStyle->SetTitleXOffset(1.2);
-  atlasStyle->SetTitleYOffset(1.1);
-
-  // use large fonts
-  //Int_t font=72; // Helvetica italics
-  Int_t font=42; // Helvetica
-  Double_t tsize=0.04;
-  atlasStyle->SetTextFont(font);
-
-  atlasStyle->SetTextSize(tsize);
-  atlasStyle->SetLabelFont(font,"x");
-  atlasStyle->SetTitleFont(font,"x");
-  atlasStyle->SetLabelFont(font,"y");
-  atlasStyle->SetTitleFont(font,"y");
-  atlasStyle->SetLabelFont(font,"z");
-  atlasStyle->SetTitleFont(font,"z");
-  
-  atlasStyle->SetLabelSize(tsize,"x");
-  atlasStyle->SetTitleSize(tsize,"x");
-  atlasStyle->SetLabelSize(tsize,"y");
-  atlasStyle->SetTitleSize(tsize,"y");
-  atlasStyle->SetLabelSize(tsize,"z");
-  atlasStyle->SetTitleSize(tsize,"z");
-
-  // use bold lines and markers
-  atlasStyle->SetMarkerStyle(20);
-  atlasStyle->SetMarkerSize(0.9);
-  atlasStyle->SetMarkerColor(4);
-  atlasStyle->SetHistLineWidth(1.);
-  atlasStyle->SetLineStyleString(2,"[12 12]"); // postscript dashes
-
-  // get rid of X error bars 
-  //atlasStyle->SetErrorX(0.001);
-  // get rid of error bar caps
-  atlasStyle->SetEndErrorSize(0.);
-
-  // do not display any of the standard histogram decorations
-  atlasStyle->SetOptTitle();
-  atlasStyle->SetOptStat();
-  //atlasStyle->SetOptStat(0);
-  //atlasStyle->SetOptFit(1111);
-  atlasStyle->SetOptFit(0);
-
- // put tick marks on top and RHS of plots
-  //atlasStyle->SetPadTickX(1);
- // atlasStyle->SetPadTickY(1);
- 
-atlasStyle->SetStatY(0.99);                
-// Set y-position (fraction of pad size)
-atlasStyle->SetStatX(0.99);                
-// Set x-position (fraction of pad size)
-atlasStyle->SetStatW(0.2);                
-// Set width of stat-box (fraction of pad size)
-atlasStyle->SetStatH(0.1);                
-// Set height of stat-box (fraction of pad size)
-atlasStyle->SetLabelOffset(0.008,"X");
-atlasStyle->SetLabelOffset(0.008,"Y");
-  
-  gROOT->SetStyle("ATLAS");
-  gROOT->ForceStyle();
-///////////////////////////////////////////////////////////////////////////////////////
-
-
-   TFile *file = TFile::Open("InDetTrackD3PD.root","READ");
-   
-   TTree *T = (TTree*)file->Get("InDetTrackTree");
-
-   histofile = TFile("Histos-Tracking-MCprob-Loose.root","recreate");
-
-
-//////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t binsEta = 30;
-Float_t minEta  = -2.5;
-Float_t maxEta  =  2.5;
-Int_t binsPt  = 30;
-Float_t minPt   = 0.;
-Float_t maxPt   = 10.0;
-
-
-TH1F *numbertrk             = new TH1F("number_of_trk_per_evt", "", 50, 0, 1200);
-TH1F *h_eta                     = new TH1F("h_eta",                 "", binsEta, minEta, maxEta);
-TH1F *h_eta_truth           = new TH1F("h_eta_truth",           "", binsEta, minEta, maxEta);
-TH1F *h_eta_reco            = new TH1F("h_eta_reco",            "", binsEta, minEta, maxEta);
-TH1F *h_eta_eff              = new TH1F("h_eta_eff",             "Efficiency(#eta)", binsEta, minEta, maxEta);
-
-TH1F *h_pt                      = new TH1F("h_pt",                  "", binsPt, minPt, maxPt);
-TH1F *h_pt_truth            = new TH1F("h_pt_truth",            "", binsPt, minPt, maxPt);
-TH1F *h_pt_reco             = new TH1F("h_pt_reco",             "", binsPt, minPt, maxPt);
-TH1F *h_pt_eff               = new TH1F("h_pt_eff",             "Efficiency(p_{T})", binsPt, minPt, maxPt);
-
-TH1F *h_phi_truth            = new TH1F("h_phi_truth",          "", 30, -4, 4);
-TH1F *h_phi_reco             = new TH1F("h_phi_reco",           "", 30, -4, 4);
-TH1F *h_phi_eff              = new TH1F("h_phi_eff",            "Efficiency(#phi)", 30, -4, 4);
-
-TH1F *h_D0_truth            = new TH1F("h_D0_truth",            "", 30, -1.5, 1.5);
-TH1F *h_D0_reco             = new TH1F("h_D0_reco",             "", 30, -1.5, 1.5);
-TH1F *h_D0_eff              = new TH1F("h_D0_eff",              "Efficiency(d_{0})", 30, -1.5, 1.5);
-
-
-TH1F *h_Z0_truth            = new TH1F("h_Z0_truth",            "", 30, -10, 10);
-TH1F *h_Z0_reco             = new TH1F("h_Z0_reco",             "", 30, -10, 10);
-TH1F *h_Z0_eff              = new TH1F("h_Z0_eff",              "Efficiency(z_{0})", 30, -10, 10);
-
-
-TH2F *hMC_etapt             = new TH2F("hMC_etaphi",            "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-//hReco_incl_etapt      = ROOT.TH2F("hReco_incl_etaphi",    "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-TH2F *hReco_matchCone_etapt = new TH2F("hReco_matchCone_etapt", "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-//hReco_matchHits_etapt = ROOT.TH2F("hReco_matchHits_etapt","", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-
-TH1F *h_ResEta              = new TH1F("h_ResEta",              "", 50, -0.02, 0.02);
-TH1F *h_ResPhi              = new TH1F("h_ResPhi",              "", 50, -0.02, 0.02);
-TH1F *h_ResPt              = new TH1F("h_ResPt",                "", 50, -0.2, 0.2);
-TH1F *h_ResD0              = new TH1F("h_ResD0",                "", 50, -2, 2);
-TH1F *h_ResZ0              = new TH1F("h_ResZ0",                "", 50, -2, 2);
-
-
-TH1F *h_Pull_phi            = new TH1F("h_Pull_phi",              "", 50, -6, 6);
-TH1F *h_Pull_d0            = new TH1F("h_Pull_d0",              "", 50, -6, 6);
-TH1F *h_Pull_z0            = new TH1F("h_Pull_z0",              "", 50, -6, 6);
-TH1F *h_Pull_qoverp            = new TH1F("h_Pull_qoverp",              "", 50, -6, 6);
-TH1F *h_Pull_eta            = new TH1F("h_Pull_eta",              "", 50, -6, 6);
-
-TH1F *hVal_PVz  	   = new TH1F("hVal_PVz",               "", 100, -100, 100);
-
-///////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t counter = 0;
-Int_t evtAfterTrigger = 0;
-Int_t evtAfterPV      = 0;
-Int_t evtAfterGoodTrk = 0;
-
-            	
-            	   std::vector<int> *m_mc_gen_barcode=0;
-            	  T->SetBranchAddress("mc_gen_barcode",&m_mc_gen_barcode);
-            	
-            //		   std::vector<float> *reco_main1=0;
-		//TBranch *br_main1 = T->GetBranch("mc_gen_pt");
-		std::vector<float> *m_mc_gen_pt=0;
-		 T->SetBranchAddress("mc_gen_pt",&m_mc_gen_pt);
-		
-        	
-        	//	std::vector<float> *reco_main2=0;
-		//TBranch *br_main2 = T->GetBranch("mc_gen_eta");
-        	std::vector<float> *m_mc_gen_eta=0;
-        	 T->SetBranchAddress("mc_gen_eta",&m_mc_gen_eta);
-        	
-        	
-        	////////////////
-        	   //    std::vector<float> *new1=0;
-		//TBranch *br_new1 = T->GetBranch("mc_gen_phi");
-        	std::vector<float> *m_mc_gen_phi=0;
-        	 T->SetBranchAddress("mc_gen_phi",&m_mc_gen_phi);
-        	
-        	
-        	    //   std::vector<float> *new2=0;
-		//TBranch *br_new2 = T->GetBranch("mc_perigee_d0");
-        	std::vector<float> *m_mc_perigee_d0=0;
-        	 T->SetBranchAddress("mc_perigee_d0",&m_mc_perigee_d0);
-        	
-        
-        	 //      std::vector<float> *new3=0;
-		//TBranch *br_new3 = T->GetBranch("mc_perigee_z0");
-        	std::vector<float> *m_mc_perigee_z0=0;
-        	 T->SetBranchAddress("mc_perigee_z0",&m_mc_perigee_z0);
-        	
-        	//	   std::vector<int> *s2=0;		
-		//TBranch *b_destep2 = T->GetBranch("mc_gen_status");
-            	std::vector<int> *m_mc_gen_status=0;
-            	T->SetBranchAddress("mc_gen_status",&m_mc_gen_status);
-            	
-            	
-            	//	std::vector<float> *reco_main3=0;	
-		//TBranch *br_main3 = T->GetBranch("mc_charge");
-        	std::vector<float> *m_mc_charge=0;
-        	T->SetBranchAddress("mc_charge",&m_mc_charge);
-        	
-        	
-        	//		std::vector<int> *s3=0;
-		//TBranch *b_destep3 = T->GetBranch("trk_mc_index");
-            	std::vector<int> *m_trk_mc_index=0;
-            	T->SetBranchAddress("trk_mc_index",&m_trk_mc_index);
-            	
-            	
-            	   //         	std::vector<float> *reco_main4=0;	
-		//TBranch *br_main4 = T->GetBranch("trk_mc_probability");
-        	std::vector<float> *m_trk_mc_probability=0;
-        	T->SetBranchAddress("trk_mc_probability",&m_trk_mc_probability);
-        	
-        	
-        	 //       	std::vector<float> *reco_main5=0;	
-		//TBranch *br_main5 = T->GetBranch("trk_eta");
-		std::vector<float> *m_trk_eta=0;
-		T->SetBranchAddress("trk_eta",&m_trk_eta);
-		
-        	
-        	//        	std::vector<float> *reco_main6=0;	
-		//TBranch *br_main6 = T->GetBranch("trk_phi");
-		std::vector<float> *m_trk_phi=0;
-        	T->SetBranchAddress("trk_phi",&m_trk_phi);
-        	
-        	
-        	//		std::vector<float> *reco_main7=0;	
-		//TBranch *br_main7 = T->GetBranch("mc_gen_phi");
-		std::vector<float> *m_mc_gen_phi=0;
-        	T->SetBranchAddress("mc_gen_phi",&m_mc_gen_phi);
-        	
-        	
-        	//        	std::vector<float> *reco_main8=0;	
-		//TBranch *br_main8 = T->GetBranch("trk_pt");
-		std::vector<float> *m_trk_pt=0;
-		T->SetBranchAddress("trk_pt",&m_trk_pt);
-		
-        	
-        	 //               std::vector<float> *reco_main9=0;	
-		//TBranch *br_main9 = T->GetBranch("mc_gen_pt");
-		std::vector<float> *m_mc_gen_pt=0;
-		T->SetBranchAddress("mc_gen_pt",&m_mc_gen_pt);
-		
-        	
-        	    //    	std::vector<float> *reco_main10=0;	
-		//TBranch *br_main10 = T->GetBranch("trk_d0");
-        	std::vector<float> *m_trk_d0=0;
-        	T->SetBranchAddress("trk_d0",&m_trk_d0);
-        	
-        	
-        	        //	std::vector<float> *reco_main11=0;	
-		//TBranch *br_main11 = T->GetBranch("mc_perigee_d0");
-        	std::vector<float> *m_mc_perigee_d0=0;
-        	T->SetBranchAddress("mc_perigee_d0",&m_mc_perigee_d0);
-        	
-        	
-        	
-        	     //   	std::vector<float> *reco_main12=0;	
-		//TBranch *br_main12 = T->GetBranch("trk_z0");
-		std::vector<float> *m_trk_z0=0;
-        	T->SetBranchAddress("trk_z0",&m_trk_z0);
-        	
-        	
-        	     //           std::vector<float> *reco_main13=0;	
-		//TBranch *br_main13 = T->GetBranch("mc_perigee_z0");
-		std::vector<float> *m_mc_perigee_z0=0;
-		T->SetBranchAddress("mc_perigee_z0",&m_mc_perigee_z0);
-		
-		Int_t m_trk_n;
-		T->SetBranchAddress("trk_n",&m_trk_n);
-		
-		
-		std::vector<int> *m_vx_type=0;
-		T->SetBranchAddress("vx_type",&m_vx_type);
-		
-		std::vector<int> *m_vx_nTracks=0;
-		T->SetBranchAddress("vx_nTracks",&m_vx_nTracks);
-		
-		std::vector<float> *m_vx_z=0;
-		T->SetBranchAddress("vx_z",&m_vx_z);
-		
-		Int_t m_mc_n;
-		T->SetBranchAddress("mc_n",&m_mc_n);
-		
-		std::vector<float> *m_trk_err_phi=0;
-		T->SetBranchAddress("trk_err_phi",&m_trk_err_phi);
-		
-		std::vector<float> *m_trk_err_d0=0;
-		T->SetBranchAddress("trk_err_d0",&m_trk_err_d0);
-		
-		std::vector<float> *m_trk_err_z0=0;
-		T->SetBranchAddress("trk_err_z0",&m_trk_err_z0);
-		
-		std::vector<float> *m_trk_err_qoverp=0;
-		T->SetBranchAddress("trk_err_qoverp",&m_trk_err_qoverp);
-		
-		std::vector<float> *m_trk_err_theta=0;
-		T->SetBranchAddress("trk_err_theta",&m_trk_err_theta);
-		
-		
-		std::vector<float> *m_trk_qoverp=0;
-		T->SetBranchAddress("trk_qoverp",&m_trk_qoverp);
-		
-		std::vector<float> *m_mc_perigee_qoverp=0;
-		T->SetBranchAddress("mc_perigee_qoverp",&m_mc_perigee_qoverp);
-		
-///////////////////////////////   
-   
-                Int_t nentries = (Int_t)(T->GetEntries());
-
-	        bool ok = 0;
-	        
-	        Int_t x1 = 600;
-	        Int_t x2 = 2000;
-	        
-	       Float_t e1=0, e2=0, e3=0, e4=0, e5=0, e6=0;
-	       Int_t n1=0, n2=0, n3=0;	
-       
-	
-/////////////////  MAIN LOOP  ///////////////////////////////////////////
-   for (Int_t i=0;i<nentries;i++) {
-   
-   	T->GetEntry(i);
-   
-	printf("Processing event: %i\n",counter);
-	counter += 1;
-	
-	  	//b = T->GetBranch("trk_n");
-   		//b->SetAddress(&d);
-		//b->GetEntry(i); 
-		numbertrk->Fill(m_trk_n);
-		printf("Tracks: %i\n",m_trk_n);
-	
-	// maximum events
-	if (counter > MAX_EVTS && MAX_EVTS != -1) break;
-	////////// EVENT SLECTION :
-	/////////////////////////
-	// 1) L1 Trigger Fired
-	if (APPLY_TRIGGER_CUT){
-        	ok = 0;
-        	//  for (name in ch.ctp_decisionItems){
-        	if (name == TRIGL1NAME){
-                ok = 1;
-                break;
-                }
-        	//if not ok continue;
-       		// }     		
-       	}	
-    	evtAfterTrigger += 1;
-					
-	if ( APPLY_PV_CUT && ( (*m_vx_type)[0] == 0 || (*m_vx_nTracks)[0] < 3)) continue;
-		
-    	evtAfterPV += 1;
-    	
-	// 3) At least one good track in event
-	if (APPLY_ONEGOODTRACK){
-		ok = 0;
-		
-		for ( Int_t r=0; r< m_trk_n; r++ ){
-			if ( trkCutsEvtSelection( T, i, r, (*m_trk_pt)[r], (*m_trk_eta)[r]) ){
-			ok = 1;
-			break;
-			}
-		////////////////////////////////////////////////////////////////
-		if (!ok) continue;
-		///////////////////////////////////////////////////////
-		}
-		evtAfterGoodTrk += 1;
-	}
-	//DONE with Event Selection
-	
-	//Reweight MC
-    	Float_t ev_weight = 1.0;
-    	 
-    	if (APPLY_PV_CORR){
-    	ev_weight = hCorrectPV.GetBinContent( hCorrectPV.FindBin( (*m_vx_z)[0]) );
-    	}
-
-    	hVal_PVz->Fill( (*m_vx_z)[0],ev_weight);
-    	
-	if ( m_trk_n<x1 ) n1++;
-	if (  m_trk_n>x1 && m_trk_n<x2 ) n2++;
-	if ( m_trk_n>x2 )n3++;
-		
-	for (Int_t k=0; k<m_mc_n; k++){
-	
-	// select barcode < 200000 (already done)   	
-	if ((*m_mc_gen_barcode)[k] > 200000 | (*m_mc_gen_barcode)[k] == 0 ) continue;
-	
-	// pT > PT_CUT MeV
-        if ((*m_mc_gen_pt)[k] < PT_CUT) continue;
-        
-	// |eta| < 0.8
-        if (fabs( (*m_mc_gen_eta)[k]) >2.5) continue;	
-
-	// require particle to be stable
-	if ((*m_mc_gen_status)[k] !=1) continue;
-	
-	// charge != 0	
-        if ((*m_mc_charge)[k] ==0) continue;
-
-        // cut truth particles with an undefined PDG ID
-        //truth_pdg = evt.mc_pdg[t]
-        
-	        if ( m_trk_n<x1 ) e4++; 
-                if (  m_trk_n>=x1 && m_trk_n<x2 )e5++; 
-		if ( m_trk_n>=x2 ) e6++; 
-
-        // fill hists
-       hMC_etapt->Fill(  (*m_mc_gen_eta)[k], (*m_mc_gen_pt)[k]/1000., ev_weight  );
-       h_eta_truth->Fill(  (*m_mc_gen_eta)[k], ev_weight);
-       h_pt_truth->Fill( (*m_mc_gen_pt)[k]/1000., ev_weight);
-
-       h_phi_truth->Fill( (*m_mc_gen_phi)[k], ev_weight);
-       h_D0_truth->Fill( (*m_mc_perigee_d0)[k], ev_weight);
-       h_Z0_truth->Fill( (*m_mc_perigee_z0)[k], ev_weight);
-
-	for (Int_t l=0; l<m_trk_n; l++){
-	//printf("MyLog: %f\n",s3->at(l));
-	if (k == (*m_trk_mc_index)[l] && ((*m_trk_mc_probability)[l] >= MIN_MC_PROB) && trkCuts(T, i, l,  (*m_trk_pt)[l], (*m_trk_eta)[l]) ) ){
-	
-        	if ( m_trk_n<x1 ) e1++;
-                if (  m_trk_n>=x1 && m_trk_n<x2 ) e2++;
-		if ( m_trk_n>=x2 ) e3++;
-		
-	 	hReco_matchCone_etapt->Fill(  (*m_mc_gen_eta)[k], (*m_mc_gen_pt)[k]/1000., ev_weight );
-                h_eta_reco->Fill(  (*m_mc_gen_eta)[k], ev_weight);
-                h_pt_reco->Fill( (*m_mc_gen_pt)[k]/1000., ev_weight);
-                
-                h_phi_reco->Fill( (*m_mc_gen_phi)[k], ev_weight);
-                h_D0_reco->Fill( (*m_mc_perigee_d0)[k], ev_weight);
-                h_Z0_reco->Fill( (*m_mc_perigee_z0)[k], ev_weight);
-                
-                                
-                h_ResEta->Fill( (*m_trk_eta)[l]- (*m_mc_gen_eta)[k], ev_weight);
-                h_ResPhi->Fill( (*m_trk_phi)[l]-(*m_mc_gen_phi)[k], ev_weight);
-                h_ResPt->Fill( (*m_trk_pt)[l]/1000.-(*m_mc_gen_pt)[k]/1000., ev_weight);
-                h_ResD0->Fill( (*m_trk_d0)[l]-(*m_mc_perigee_d0)[k], ev_weight);
-                h_ResZ0->Fill( (*m_trk_z0)[l]-(*m_mc_perigee_z0)[k], ev_weight);
-                
-                h_Pull_phi->Fill( ( (*m_trk_phi)[l]-(*m_mc_gen_phi)[k] ) / (*m_trk_err_phi)[l], ev_weight );
-                h_Pull_d0->Fill( ( (*m_trk_d0)[l]-(*m_mc_perigee_d0)[k] ) / (*m_trk_err_d0)[l], ev_weight );
-                h_Pull_z0->Fill( ( (*m_trk_z0)[l]-(*m_mc_perigee_z0)[k] ) / (*m_trk_err_z0)[l], ev_weight );
-                h_Pull_qoverp->Fill( ( (*m_trk_qoverp)[l]-(*m_mc_perigee_qoverp)[k] ) / (*m_trk_err_qoverp)[l], ev_weight );
-                h_Pull_eta->Fill( ( (*m_trk_eta)[l]-(*m_mc_gen_eta)[k] ) / ( fabs( - 1./TMath::Sin(      -TMath::Log( TMath::Tan( (*m_trk_eta)[l]/2.) )      ) * (*m_trk_err_theta)[l] ) ), ev_weight );                
-	 break;}
-
-		}
-	}
-   
-   }
-   
-const Float_t bins[] = {10., (Float_t)x1, (Float_t)x2, 10000.};
-
-TH1F *h_number                    = new TH1F("h_number",                 "Efficiency vs # of tracks per evt", 3, bins); 
-
-	if (n3 !=0){
-	h_number->Fill(e6/n3, e3/e6);
-	h_number->SetBinError(3, (sqrt(e3/e6*(1-e3/e6)/e6))); }
-	
-	if (n2 !=0){
-	h_number->Fill( e5/n2, e2/e5);
-	h_number->SetBinError(2, (sqrt(e2/e5*(1-e2/e5)/e5))); }
-	
-	if (n1 !=0){
-	h_number->Fill(e4/n1, e1/e4);
-	h_number->SetBinError(1, (sqrt(e1/e4*(1-e1/e4)/e4))); }
-
-	printf ("%f %f  %f  %f\n" ,e4/n1, e5/n2, e6/n3, 10.*e6/n3);
-
-printf ("events : %i (processed) %i (after trigger) %i (after PV cut) %i (after good trk)\n" ,counter-1, evtAfterTrigger, evtAfterPV, evtAfterGoodTrk);
-
-
-h_eta_truth->Sumw2();
-h_eta_reco->Sumw2();
-h_eta_eff->Divide(h_eta_reco,h_eta_truth,1.0,1.0,"b");
-h_eta_eff->GetXaxis()->SetTitle("#eta");
-//h_eta_eff->GetYaxis()->SetTitle("Eff");
-//h_eta_eff->SetTitle("#eta");
-
-h_pt_truth->Sumw2();
-h_pt_reco->Sumw2();
-h_pt_eff->Divide(h_pt_reco,h_pt_truth,1.0,1.0,"b");
-h_pt_eff->GetXaxis()->SetTitle("p_{T} [GeV]");
-//h_pt_eff->GetYaxis()->SetTitle("Eff");
-//h_pt_eff->SetTitle("p_{T}");
-
-h_phi_truth->Sumw2();
-h_phi_reco->Sumw2();
-h_phi_eff->Divide(h_phi_reco,h_phi_truth,1.0,1.0,"b");
-h_phi_eff->GetXaxis()->SetTitle("#phi");
-//h_phi_eff->GetYaxis()->SetTitle("Eff");
-//h_phi_eff->SetTitle("phi");
-
-h_D0_truth->Sumw2();
-h_D0_reco->Sumw2();
-h_D0_eff->Divide(h_D0_reco,h_D0_truth,1.0,1.0,"b");
-h_D0_eff->GetXaxis()->SetTitle("d_{0}");
-//h_D0_eff->GetYaxis()->SetTitle("Eff");
-//h_D0_eff->SetTitle("d0");
-
-h_Z0_truth->Sumw2();
-h_Z0_reco->Sumw2();
-h_Z0_eff->Divide(h_Z0_reco,h_Z0_truth,1.0,1.0,"b");
-h_Z0_eff->GetXaxis()->SetTitle("z_{0}");
-//h_Z0_eff->GetYaxis()->SetTitle("Eff");
-//h_Z0_eff->SetTitle("z0");
-
-
-TCanvas* c1=new TCanvas();
-c1->SetWindowSize(800,600);
-c1->Resize();
-
-h_eta_eff->Scale(100);
-
-h_eta_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_eta_loose.png");
-
-c1->Update();
-h_pt_eff->Scale(100);
-h_pt_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_pt_loose.png");
-
-c1->Update();
-h_phi_eff->Scale(100);
-h_phi_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_phi_loose.png");
-
-c1->Update();
-h_D0_eff->Scale(100);
-h_D0_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_d0_loose.png");
-c1->Update();
-h_Z0_eff->Scale(100);
-h_Z0_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_z0_loose.png");
-
-////////////////////////////////////////////////////////////////////////////////////////////////////////
-c1->Update();
-h_ResPhi->GetXaxis()->SetTitle("#phi");
-h_ResPhi->Draw("h");
-c1->cd();
-c1->SaveAs("Res_phi_loose.png");
-
-c1->Update();
-h_ResEta->GetXaxis()->SetTitle("#eta");
-h_ResEta->Draw("h");
-c1->cd();
-c1->SaveAs("Res_eta_loose.png");
-
-c1->Update();
-h_ResPt->GetXaxis()->SetTitle("p_{T}");
-h_ResPt->Draw("h");
-c1->cd();
-c1->SaveAs("Res_pt_loose.png");
-
-c1->Update();
-h_ResD0->GetXaxis()->SetTitle("d_{0}");
-h_ResD0->Draw("h");
-c1->cd();
-c1->SaveAs("Res_d0_loose.png");
-
-c1->Update();
-h_ResZ0->GetXaxis()->SetTitle("z_{0}");
-h_ResZ0->Draw("h");
-c1->cd();
-c1->SaveAs("Res_z0_loose.png");
-//////////////////////////////////////////////////////////////////////////////////////////////////
-
-c1->Update();
-h_Pull_phi->GetXaxis()->SetTitle("#phi");
-h_Pull_phi->Draw("h");
-c1->cd();
-c1->SaveAs("Pull_phi_loose.png");
-
-c1->Update();
-h_Pull_eta->GetXaxis()->SetTitle("#eta");
-h_Pull_eta->Draw("h");
-c1->cd();
-c1->SaveAs("Pull_eta_loose.png");
-
-c1->Update();
-h_Pull_qoverp->GetXaxis()->SetTitle("q/p");
-h_Pull_qoverp->Draw("h");
-c1->cd();
-c1->SaveAs("Pull_qoverp_loose.png");
-
-c1->Update();
-h_Pull_d0->GetXaxis()->SetTitle("d_{0}");
-h_Pull_d0->Draw("h");
-c1->cd();
-c1->SaveAs("Pull_d0_loose.png");
-
-c1->Update();
-h_Pull_z0->GetXaxis()->SetTitle("z_{0}");
-h_Pull_z0->Draw("h");
-c1->cd();
-c1->SaveAs("Pull_z0_loose.png");
-
-
-
-c1->SetLogx();
-
-c1->Update();
-
-gr = new TGraphErrors(h_number);
-gr->Draw("ALP");
-
-h_number->Scale(100);
-h_number->GetXaxis()->SetTitle("number of tracks per evt");
-h_number->GetYaxis()->SetTitle("Efficiency [%]");
-
-h_number ->Draw("E1");
-   
-  /*  TLatex Tl;
-   Tl.SetTextSize(0.04);
-   Tl.SetTextAlign(11);
-Tl.DrawLatex(10., 0.8, "<100");
-Tl.DrawLatex(85., 1., "100 #leq trk<500");
-Tl.DrawLatex(2000., 0.75, "#geq 500");*/
-
-
-c1->cd();
-c1->SaveAs("Eff_number.png");
- 
- 
-Float_t effi = h_phi_reco->GetEntries()/h_phi_truth->GetEntries();
-TString out=""; out+=(effi*100.); out+=" % +- ";
-out+=100.*(sqrt(effi*(1-effi)/h_phi_truth->GetEntries()));
-out+=" %";
-
-
-string line;
-Int_t ww=0;
-
-ifstream Myfile("efficiency_HIInDetValidation.txt");
-if(Myfile.is_open())
-{
-while(!Myfile.eof())
-{
-getline(Myfile,line);
-if (line =="--------------- Efficiency summary (loose cuts) ------------") ww=1;
-}
-Myfile.close();
-}
-if (ww==0)
-{
-ofstream myfile("efficiency_HIInDetValidation.txt", ios::out | ios::app);
-myfile <<"--------------- Efficiency summary (loose cuts) ------------\n";
-myfile <<"Track_Loose efficiency : " << out << endl;
-}
- 
-
-histofile.Write();
-histofile.Close();
-}
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Eff_Tight.C b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Eff_Tight.C
deleted file mode 100644
index 43b8d9c076d816d5a9176c554c2154e8d85fcb22..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Eff_Tight.C
+++ /dev/null
@@ -1,704 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "vector"
-#include "stdio.h"
-#include "TFile.h"
-#include "TChain.h"
-#include "TH2F"
-#include "TH1F.h"
-#include "TCanvas.h"
-#include "TMath.h"
-
-
-#include "TTree.h"
-#include "TBrowser.h"
-#include "TH2.h"
-#include "TRandom.h"
-
-#ifdef __MAKECINT__
-#pragma link C++ class vector<float>+;
-#endif
-
-const Float_t MIN_MC_PROB = 0.5;
-
-const Float_t PT_CUT = 500.;
-
-// event selection
-const Int_t APPLY_PV_CUT = 1;
-const Int_t APPLY_TRIGGER_CUT  = 0;
-const Int_t APPLY_ONEGOODTRACK = 1;
-//const TRIGL1NAME = 'L1_MBTS_1';
-
-const Int_t APPLY_PV_CORR  = 0;
-const Int_t MAX_EVTS = -1;
-
-   std::vector<float> *reco=0;
-   std::vector<int> *recoh=0;
-   TBranch *br;
-   TBranch *brh;   
-   Float_t aa;
-   Float_t aaa;
-   
-   
-bool trkCutsEvtSelection(TTree *L,Int_t evt, Int_t r){
-
-
-   
- 	    br = L->GetBranch("trk_pt");
-            br->SetAddress(&reco);
-            br->GetEntry(evt); 
-
-    // pT > PT_CUT MeV
-    if (reco->at(r) < PT_CUT) return 0;
-
-    br = L->GetBranch("trk_eta");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-
-    // |eta| < 2.5
-    if (fabs(reco->at(r)) > 2.5 ) return 0;
-//////////////////////////////////////////////
-    brh = L->GetBranch("trk_nPixHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // Pixel hits
-    if ( recoh->at(r) <= 1 ) return 0;
-    
-    brh = L->GetBranch("trk_nPixHoles");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // Pixel holes   
-    if (recoh->at(r) > 0)  return 0;
-
-    brh = L->GetBranch("trk_nSCTHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // SCT hits
-    if (recoh->at(r) <=7 ) return 0;
-
-    br = L->GetBranch("trk_d0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-
-    if (fabs( reco->at(r) ) >= 1. ) return 0;
-
-    br = L->GetBranch("trk_z0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aa = reco->at(r);
-
-    br = L->GetBranch("trk_theta");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aaa = reco->at(r);
-
-    // z0 sin(theta) cut
-   if ( fabs( aa * TMath::Sin( aaa) ) >= 1. ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-   std::vector<float> *recot=0;
-   std::vector<int> *recoht=0;
-   TBranch *brt;
-   TBranch *brht;
-   
-   Float_t aat;
-   Float_t aaat;
-bool trkCuts(TTree *L,Int_t evt, Int_t r){
-
-
-   
-   	    brt = L->GetBranch("trk_pt");
-            brt->SetAddress(&recot);
-            brt->GetEntry(evt); 
-
-    // pT > PT_CUT MeV
-    if (recot->at(r) < PT_CUT) return 0;
-
-    brt = L->GetBranch("trk_eta");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-
-    // |eta| < 2.5
-    if (fabs(recot->at(r)) > 2.5 ) return 0;
-//////////////////////////////////////////////
-    brht = L->GetBranch("trk_nPixHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // Pixel hits
-    if ( recoht->at(r) <= 1 ) return 0;
-
-    brht = L->GetBranch("trk_nPixHoles");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // Pixel holes   
-    if (recoht->at(r) > 0)  return 0;
-
-    brht = L->GetBranch("trk_nSCTHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // SCT hits
-    if (recoht->at(r) <= 7 ) return 0;
-    
-    brht = L->GetBranch("trk_nSCTHoles");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // SCT holes
-    if (recoht->at(r) >= 2 ) return 0;
-
-    brt = L->GetBranch("trk_d0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-    if (fabs( recot->at(r) ) >= 1. ) return 0;
-
-    brt = L->GetBranch("trk_z0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-	aat = recot->at(r);
-
-    brt = L->GetBranch("trk_theta");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-    aaat = recot->at(r);
-
-    // z0 sin(theta) cut
-    if ( fabs( aat * TMath::Sin( aaat) ) >= 1. ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-void HIInDetValidation_Eff_Tight(){
-
-/////////////////ATLAS STYLE//////////////////////////////////////////
-TStyle *atlasStyle = new TStyle("ATLAS","Atlas style");
-
-  // use plain black on white colors
-  Int_t icol=0; // WHITE
-  atlasStyle->SetFrameBorderMode(icol);
-  atlasStyle->SetFrameFillColor(icol);
-  atlasStyle->SetCanvasBorderMode(icol);
-  atlasStyle->SetCanvasColor(icol);
-  atlasStyle->SetPadBorderMode(icol);
-  atlasStyle->SetPadColor(icol);
-  atlasStyle->SetStatColor(icol);
-  //atlasStyle->SetFillColor(icol); // don't use: white fill color for *all* objects
-
-  // set the paper & margin sizes
-  atlasStyle->SetPaperSize(20,26);
-
-  // set margin sizes
-  atlasStyle->SetPadTopMargin(0.10);
-  atlasStyle->SetPadRightMargin(0.05);
-  atlasStyle->SetPadBottomMargin(0.10);
-  atlasStyle->SetPadLeftMargin(0.10);
-
-  // set title offsets (for axis label)
-  atlasStyle->SetTitleXOffset(1.1);
-  atlasStyle->SetTitleYOffset(1.4);
-
-  // use large fonts
-  //Int_t font=72; // Helvetica italics
-  Int_t font=42; // Helvetica
-  Double_t tsize=0.04;
-  atlasStyle->SetTextFont(font);
-
-  atlasStyle->SetTextSize(tsize);
-  atlasStyle->SetLabelFont(font,"x");
-  atlasStyle->SetTitleFont(font,"x");
-  atlasStyle->SetLabelFont(font,"y");
-  atlasStyle->SetTitleFont(font,"y");
-  atlasStyle->SetLabelFont(font,"z");
-  atlasStyle->SetTitleFont(font,"z");
-  
-  atlasStyle->SetLabelSize(tsize,"x");
-  atlasStyle->SetTitleSize(tsize,"x");
-  atlasStyle->SetLabelSize(tsize,"y");
-  atlasStyle->SetTitleSize(tsize,"y");
-  atlasStyle->SetLabelSize(tsize,"z");
-  atlasStyle->SetTitleSize(tsize,"z");
-
-  // use bold lines and markers
-  atlasStyle->SetMarkerStyle(20);
-  atlasStyle->SetMarkerSize(0.9);
-  atlasStyle->SetMarkerColor(2);
-  atlasStyle->SetHistLineWidth(1.);
-  atlasStyle->SetLineStyleString(2,"[12 12]"); // postscript dashes
-
-  // get rid of X error bars 
-  //atlasStyle->SetErrorX(0.001);
-  // get rid of error bar caps
-  atlasStyle->SetEndErrorSize(0.);
-
-  // do not display any of the standard histogram decorations
-  atlasStyle->SetOptTitle();
-  atlasStyle->SetOptStat();
-  //atlasStyle->SetOptStat(0);
-  //atlasStyle->SetOptFit(1111);
-  atlasStyle->SetOptFit(0);
-
- // put tick marks on top and RHS of plots
-  //atlasStyle->SetPadTickX(1);
- // atlasStyle->SetPadTickY(1);
- 
-atlasStyle->SetStatY(0.99);                
-// Set y-position (fraction of pad size)
-atlasStyle->SetStatX(0.99);                
-// Set x-position (fraction of pad size)
-atlasStyle->SetStatW(0.2);                
-// Set width of stat-box (fraction of pad size)
-atlasStyle->SetStatH(0.1);                
-// Set height of stat-box (fraction of pad size)
-atlasStyle->SetLabelOffset(0.008,"X");
-atlasStyle->SetLabelOffset(0.008,"Y");
-  
-  gROOT->SetStyle("ATLAS");
-  gROOT->ForceStyle();
-///////////////////////////////////////////////////////////////////////////////////////
-
-
-   TFile *file = TFile::Open("InDetTrackD3PD.root","READ");
-   
-   TTree *T = (TTree*)file->Get("InDetTrackTree");
-
-   histofile = TFile("Histos-Tracking-MCprob-Tight.root","recreate");
-
-
-//////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t binsEta = 30;
-Float_t minEta  = -2.5;
-Float_t maxEta  =  2.5;
-Int_t binsPt  = 30;
-Float_t minPt   = 0.;
-Float_t maxPt   = 10.0;
-
-TH1F *numbertrk             = new TH1F("number_of_trk_per_evt", "", 50, 0, 1200);
-TH1F *h_eta                     = new TH1F("h_eta",                 "", binsEta, minEta, maxEta);
-TH1F *h_eta_truth           = new TH1F("h_eta_truth",           "", binsEta, minEta, maxEta);
-TH1F *h_eta_reco            = new TH1F("h_eta_reco",            "", binsEta, minEta, maxEta);
-TH1F *h_eta_eff              = new TH1F("h_eta_eff",             "Efficiency(#eta)", binsEta, minEta, maxEta);
-
-TH1F *h_pt                      = new TH1F("h_pt",                  "", binsPt, minPt, maxPt);
-TH1F *h_pt_truth            = new TH1F("h_pt_truth",            "", binsPt, minPt, maxPt);
-TH1F *h_pt_reco             = new TH1F("h_pt_reco",             "", binsPt, minPt, maxPt);
-TH1F *h_pt_eff               = new TH1F("h_pt_eff",             "Efficiency(p_{T})", binsPt, minPt, maxPt);
-
-TH1F *h_phi_truth            = new TH1F("h_phi_truth",          "", 30, -4, 4);
-TH1F *h_phi_reco             = new TH1F("h_phi_reco",           "", 30, -4, 4);
-TH1F *h_phi_eff              = new TH1F("h_phi_eff",            "Efficiency(#phi)", 30, -4, 4);
-
-TH1F *h_D0_truth            = new TH1F("h_D0_truth",            "", 30, -1.5, 1.5);
-TH1F *h_D0_reco             = new TH1F("h_D0_reco",             "", 30, -1.5, 1.5);
-TH1F *h_D0_eff              = new TH1F("h_D0_eff",              "Efficiency(d_{0})", 30, -1.5, 1.5);
-
-
-TH1F *h_Z0_truth            = new TH1F("h_Z0_truth",            "", 30, -10, 10);
-TH1F *h_Z0_reco             = new TH1F("h_Z0_reco",             "", 30, -10, 10);
-TH1F *h_Z0_eff              = new TH1F("h_Z0_eff",              "Efficiency(z_{0})", 30, -10, 10);
-
-
-TH2F *hMC_etapt             = new TH2F("hMC_etaphi",            "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-//hReco_incl_etapt      = ROOT.TH2F("hReco_incl_etaphi",    "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-TH2F *hReco_matchCone_etapt = new TH2F("hReco_matchCone_etapt", "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-//hReco_matchHits_etapt = ROOT.TH2F("hReco_matchHits_etapt","", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-
-TH1F *h_ResEta              = new TH1F("h_ResEta",              "", 50, -0.1, 0.1);
-TH1F *h_ResPhi              = new TH1F("h_ResPhi",              "", 50, -0.1, 0.1);
-TH1F *h_ResPt              = new TH1F("h_ResPt",                "", 50, -1, 1);
-TH1F *h_ResD0              = new TH1F("h_ResD0",                "", 50, -0.5, 0.5);
-TH1F *h_ResZ0              = new TH1F("h_ResZ0",                "", 50, -1, 1);
-
-TH1F *hVal_PVz  	   = new TH1F("hVal_PVz",               "", 100, -100, 100);
-
-///////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t counter = 0;
-Int_t evtAfterTrigger = 0;
-Int_t evtAfterPV      = 0;
-Int_t evtAfterGoodTrk = 0;
-
-
-            	
-            	   std::vector<int> *m_mc_gen_barcode=0;
-            	  T->SetBranchAddress("mc_gen_barcode",&m_mc_gen_barcode);
-            	
-            	
-            //		   std::vector<float> *reco_main1=0;
-		//TBranch *br_main1 = T->GetBranch("mc_gen_pt");
-		std::vector<float> *m_mc_gen_pt=0;
-		 T->SetBranchAddress("mc_gen_pt",&m_mc_gen_pt);
-		
-        	
-        	//	std::vector<float> *reco_main2=0;
-		//TBranch *br_main2 = T->GetBranch("mc_gen_eta");
-        	std::vector<float> *m_mc_gen_eta=0;
-        	 T->SetBranchAddress("mc_gen_eta",&m_mc_gen_eta);
-        	
-        	
-        	////////////////
-        	   //    std::vector<float> *new1=0;
-		//TBranch *br_new1 = T->GetBranch("mc_gen_phi");
-        	std::vector<float> *m_mc_gen_phi=0;
-        	 T->SetBranchAddress("mc_gen_phi",&m_mc_gen_phi);
-        	
-        	
-        	    //   std::vector<float> *new2=0;
-		//TBranch *br_new2 = T->GetBranch("mc_perigee_d0");
-        	std::vector<float> *m_mc_perigee_d0=0;
-        	 T->SetBranchAddress("mc_perigee_d0",&m_mc_perigee_d0);
-        	
-        
-        	 //      std::vector<float> *new3=0;
-		//TBranch *br_new3 = T->GetBranch("mc_perigee_z0");
-        	std::vector<float> *m_mc_perigee_z0=0;
-        	 T->SetBranchAddress("mc_perigee_z0",&m_mc_perigee_z0);
-        	 
-        	///////////////
-        	
-        	//	   std::vector<int> *s2=0;		
-		//TBranch *b_destep2 = T->GetBranch("mc_gen_status");
-            	std::vector<int> *m_mc_gen_status=0;
-            	T->SetBranchAddress("mc_gen_status",&m_mc_gen_status);
-            	
-            	
-            	//	std::vector<float> *reco_main3=0;	
-		//TBranch *br_main3 = T->GetBranch("mc_charge");
-        	std::vector<float> *m_mc_charge=0;
-        	T->SetBranchAddress("mc_charge",&m_mc_charge);
-        	
-        	
-        	//		std::vector<int> *s3=0;
-		//TBranch *b_destep3 = T->GetBranch("trk_mc_index");
-            	std::vector<int> *m_trk_mc_index=0;
-            	T->SetBranchAddress("trk_mc_index",&m_trk_mc_index);
-            	
-            	
-            	   //         	std::vector<float> *reco_main4=0;	
-		//TBranch *br_main4 = T->GetBranch("trk_mc_probability");
-        	std::vector<float> *m_trk_mc_probability=0;
-        	T->SetBranchAddress("trk_mc_probability",&m_trk_mc_probability);
-        	
-        	
-        	 //       	std::vector<float> *reco_main5=0;	
-		//TBranch *br_main5 = T->GetBranch("trk_eta");
-		std::vector<float> *m_trk_eta=0;
-		T->SetBranchAddress("trk_eta",&m_trk_eta);
-		
-        	
-        	//        	std::vector<float> *reco_main6=0;	
-		//TBranch *br_main6 = T->GetBranch("trk_phi");
-		std::vector<float> *m_trk_phi=0;
-        	T->SetBranchAddress("trk_phi",&m_trk_phi);
-        	
-        	
-        	//		std::vector<float> *reco_main7=0;	
-		//TBranch *br_main7 = T->GetBranch("mc_gen_phi");
-		std::vector<float> *m_mc_gen_phi=0;
-        	T->SetBranchAddress("mc_gen_phi",&m_mc_gen_phi);
-        	
-        	
-        	//        	std::vector<float> *reco_main8=0;	
-		//TBranch *br_main8 = T->GetBranch("trk_pt");
-		std::vector<float> *m_trk_pt=0;
-		T->SetBranchAddress("trk_pt",&m_trk_pt);
-		
-		/////////////////////////////////////////////////////////////////////////////tu sie zaczelo    /////////////////
-        	
-        	 //               std::vector<float> *reco_main9=0;	
-		//TBranch *br_main9 = T->GetBranch("mc_gen_pt");
-		std::vector<float> *m_mc_gen_pt=0;
-		T->SetBranchAddress("mc_gen_pt",&m_mc_gen_pt);
-		
-        	
-        	    //    	std::vector<float> *reco_main10=0;	
-		//TBranch *br_main10 = T->GetBranch("trk_d0");
-        	std::vector<float> *m_trk_d0=0;
-        	T->SetBranchAddress("trk_d0",&m_trk_d0);
-        	
-        	
-        	        //	std::vector<float> *reco_main11=0;	
-		//TBranch *br_main11 = T->GetBranch("mc_perigee_d0");
-        	std::vector<float> *m_mc_perigee_d0=0;
-        	T->SetBranchAddress("mc_perigee_d0",&m_mc_perigee_d0);
-        	
-        	
-        	
-        	     //   	std::vector<float> *reco_main12=0;	
-		//TBranch *br_main12 = T->GetBranch("trk_z0");
-		std::vector<float> *m_trk_z0=0;
-        	T->SetBranchAddress("trk_z0",&m_trk_z0);
-        	
-        	
-        	     //           std::vector<float> *reco_main13=0;	
-		//TBranch *br_main13 = T->GetBranch("mc_perigee_z0");
-		std::vector<float> *m_mc_perigee_z0=0;
-		T->SetBranchAddress("mc_perigee_z0",&m_mc_perigee_z0);
-		
-
-		Int_t m_trk_n;
-		T->SetBranchAddress("trk_n",&m_trk_n);
-		
-		
-		std::vector<int> *m_vx_type=0;
-		T->SetBranchAddress("vx_type",&m_vx_type);
-		
-		std::vector<int> *m_vx_nTracks=0;
-		T->SetBranchAddress("vx_nTracks",&m_vx_nTracks);
-		
-		std::vector<float> *m_vx_z=0;
-		T->SetBranchAddress("vx_z",&m_vx_z);
-		
-		Int_t m_mc_n;
-		T->SetBranchAddress("mc_n",&m_mc_n);
-		
-///////////////////////////////   
-   
-                Int_t nentries = (Int_t)(T->GetEntries());
-
-	        bool ok = 0;
-	
-/////////////////  MAIN LOOP  ///////////////////////////////////////////
-   for (Int_t i=0;i<nentries;i++) {
-   
-   	T->GetEntry(i);
-   
-	printf("Processing event: %i\n",counter);
-	counter += 1;
-	
-	  	//b = T->GetBranch("trk_n");
-   		//b->SetAddress(&d);
-		//b->GetEntry(i); 
-		numbertrk->Fill(m_trk_n);
-		printf("Tracks: %i\n",m_trk_n);
-	
-	// maximum events
-	if (counter > MAX_EVTS && MAX_EVTS != -1) break;
-	////////// EVENT SLECTION :
-	/////////////////////////
-	// 1) L1 Trigger Fired
-	if (APPLY_TRIGGER_CUT){
-        	ok = 0;
-        	//  for (name in ch.ctp_decisionItems){
-        	if (name == TRIGL1NAME){
-                ok = 1;
-                break;
-                }
-        	//if not ok continue;
-       		// }
-       		
-       	}	
-    	evtAfterTrigger += 1;
-   	
-	// 2) Require a good Primary Vertex
-	//b_destep = T->GetBranch("vx_type");
-       //     b_destep->SetAddress(&s);
-        //    b_destep->GetEntry(i); 
-        //Int_t vxtype =  (*m_vx_type)[0];
-        
-
-       	//b_destep = T->GetBranch("vx_nTracks");
-        //    b_destep->SetAddress(&s);
-       //     b_destep->GetEntry(i); 
-	//Int_t vxntracks = s->at(0);
-					
-	if ( APPLY_PV_CUT && ( (*m_vx_type)[0] == 0 || (*m_vx_nTracks)[0] < 3)) continue;
-		
-    	evtAfterPV += 1;
-    	
-	// 3) At least one good track in event
-	if (APPLY_ONEGOODTRACK){
-		ok = 0;
-		
-		for ( Int_t r=0; r< m_trk_n; r++ ){
-			if ( trkCutsEvtSelection( T, i, r) ){
-			ok = 1;
-			break;
-			}
-		////////////////////////////////////////////////////////////////
-		if (!ok) continue;
-		///////////////////////////////////////////////////////
-		}
-		evtAfterGoodTrk += 1;
-	}
-	
-	//DONE with Event Selection
-	//Reweight MC
-    	Float_t ev_weight = 1.0;
-    	
-    	//br_main = T->GetBranch("vx_z");
-       // br_main->SetAddress(&reco_main);
-      //  br_main->GetEntry(i);
-    	 
-    	if (APPLY_PV_CORR){
-    	ev_weight = hCorrectPV.GetBinContent( hCorrectPV.FindBin( (*m_vx_z)[0]) );
-    	}
-
-    	hVal_PVz->Fill( (*m_vx_z)[0],ev_weight);
-
-    		
-		
-	for (Int_t k=0; k<m_mc_n; k++){
-		// select barcode < 200000 (already done)
- 
-            	
-	if ((*m_mc_gen_barcode)[k] > 200000 | (*m_mc_gen_barcode)[k] == 0 ) continue;
-	// pT > PT_CUT MeV
-
-        if ((*m_mc_gen_pt)[k] < PT_CUT) continue;
-        
-	// |eta| < 0.8
-
-        if (fabs( (*m_mc_gen_eta)[k]) >2.5) continue;	
-
-	// require particle to be stable
-	
-	if ((*m_mc_gen_status)[k] !=1) continue;
-	
-	// charge != 0
-	
-        if ((*m_mc_charge)[k] ==0) continue;	
-	        	//printf("ppppppppp %f\n",reco_main->at(k));
-
-        // cut truth particles with an undefined PDG ID
-        //truth_pdg = evt.mc_pdg[t]
-        // fill hists
-        
-       hMC_etapt->Fill(  (*m_mc_gen_eta)[k], (*m_mc_gen_pt)[k]/1000., ev_weight  );
-       h_eta_truth->Fill(  (*m_mc_gen_eta)[k], ev_weight);
-       h_pt_truth->Fill( (*m_mc_gen_pt)[k]/1000., ev_weight);
-
-       h_phi_truth->Fill( (*m_mc_gen_phi)[k], ev_weight);
-       h_D0_truth->Fill( (*m_mc_perigee_d0)[k], ev_weight);
-       h_Z0_truth->Fill( (*m_mc_perigee_z0)[k], ev_weight);
-
-	for (Int_t l=0; l<m_trk_n; l++){
-	//printf("MyLog: %f\n",s3->at(l));
-	if (k == (*m_trk_mc_index)[l] && ((*m_trk_mc_probability)[l] >= MIN_MC_PROB) && trkCuts(T, i,l)){
-	 hReco_matchCone_etapt->Fill(  (*m_mc_gen_eta)[k], (*m_mc_gen_pt)[k]/1000., ev_weight );
-                h_eta_reco->Fill(  (*m_mc_gen_eta)[k], ev_weight);
-                h_pt_reco->Fill( (*m_mc_gen_pt)[k]/1000., ev_weight);
-                
-                h_phi_reco->Fill( (*m_mc_gen_phi)[k], ev_weight);
-                h_D0_reco->Fill( (*m_mc_perigee_d0)[k], ev_weight);
-                h_Z0_reco->Fill( (*m_mc_perigee_z0)[k], ev_weight);
-                
-                                
-                h_ResEta->Fill( (*m_trk_eta)[l]- (*m_mc_gen_eta)[k], ev_weight);
-                h_ResPhi->Fill( (*m_trk_phi)[l]-(*m_mc_gen_phi)[k], ev_weight);
-                h_ResPt->Fill( (*m_trk_pt)[l]/1000.-(*m_mc_gen_pt)[k]/1000., ev_weight);
-                h_ResD0->Fill( (*m_trk_d0)[l]-(*m_mc_perigee_d0)[k], ev_weight);
-                h_ResZ0->Fill( (*m_trk_z0)[l]-(*m_mc_perigee_z0)[k], ev_weight);
-	 break;}
-
-		}
-	}
-   
-   }
-
-printf ("events : %i (processed) %i (after trigger) %i (after PV cut) %i (after good trk)" ,counter-1, evtAfterTrigger, evtAfterPV, evtAfterGoodTrk);
-
-
-h_eta_truth->Sumw2();
-h_eta_reco->Sumw2();
-h_eta_eff->Divide(h_eta_reco,h_eta_truth,1.0,1.0,"b");
-h_eta_eff->GetXaxis()->SetTitle("#eta");
-//h_eta_eff->GetYaxis()->SetTitle("Eff");
-//h_eta_eff->SetTitle("#eta");
-
-h_pt_truth->Sumw2();
-h_pt_reco->Sumw2();
-h_pt_eff->Divide(h_pt_reco,h_pt_truth,1.0,1.0,"b");
-h_pt_eff->GetXaxis()->SetTitle("p_{T} [GeV]");
-//h_pt_eff->GetYaxis()->SetTitle("Eff");
-//h_pt_eff->SetTitle("p_{T}");
-
-h_phi_truth->Sumw2();
-h_phi_reco->Sumw2();
-h_phi_eff->Divide(h_phi_reco,h_phi_truth,1.0,1.0,"b");
-h_phi_eff->GetXaxis()->SetTitle("#phi");
-//h_phi_eff->GetYaxis()->SetTitle("Eff");
-//h_phi_eff->SetTitle("phi");
-
-h_D0_truth->Sumw2();
-h_D0_reco->Sumw2();
-h_D0_eff->Divide(h_D0_reco,h_D0_truth,1.0,1.0,"b");
-h_D0_eff->GetXaxis()->SetTitle("d_{0}");
-//h_D0_eff->GetYaxis()->SetTitle("Eff");
-//h_D0_eff->SetTitle("d0");
-
-h_Z0_truth->Sumw2();
-h_Z0_reco->Sumw2();
-h_Z0_eff->Divide(h_Z0_reco,h_Z0_truth,1.0,1.0,"b");
-h_Z0_eff->GetXaxis()->SetTitle("z_{0}");
-//h_Z0_eff->GetYaxis()->SetTitle("Eff");
-//h_Z0_eff->SetTitle("z0");
-
-TCanvas* c1=new TCanvas();
-c1->SetWindowSize(800,600);
-c1->Resize();
-h_eta_eff->Scale(100);
-h_eta_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_eta_tight.png");
-
-c1->Update();
-h_pt_eff->Scale(100);
-h_pt_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_pt_tight.png");
-
-c1->Update();
-h_phi_eff->Scale(100);
-h_phi_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_phi_tight.png");
-
-c1->Update();
-h_D0_eff->Scale(100);
-h_D0_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_d0_tight.png");
-c1->Update();
-h_Z0_eff->Scale(100);
-h_Z0_eff->Draw("E");
-c1->cd();
-c1->SaveAs("Eff_z0_tight.png");
- 
-Float_t effi = h_phi_reco->GetEntries()/h_phi_truth->GetEntries();
-TString out=""; out+=(effi*100.); out+=" % +- ";
-out+=100.*(sqrt(effi*(1-effi)/h_phi_truth->GetEntries()));
-out+=" %";
-
-
-string line;
-Int_t ww=0;
-
-ifstream Myfile("efficiency_HIInDetValidation.txt");
-if(Myfile.is_open())
-{
-while(!Myfile.eof())
-{
-getline(Myfile,line);
-if (line =="--------------- Efficiency summary (tight cuts) ------------") ww=1;
-}
-Myfile.close();
-}
-if (ww==0)
-{
-ofstream myfile("efficiency_HIInDetValidation.txt", ios::out | ios::app);
-myfile <<"--------------- Efficiency summary (tight cuts) ------------\n";
-myfile <<"Track_Tight efficiency : " << out << endl;
-}
-
-
-
- 
-
-histofile.Write();
-histofile.Close();
-}
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Fakes_Loose.C b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Fakes_Loose.C
deleted file mode 100644
index bfbf7e9def35fbbb0947a053d8da320f5473b0e7..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Fakes_Loose.C
+++ /dev/null
@@ -1,588 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "vector"
-#include "stdio.h"
-#include "TFile.h"
-#include "TChain.h"
-#include "TH2F"
-#include "TH1F.h"
-#include "TCanvas.h"
-#include "TMath.h"
-
-
-#include "TTree.h"
-#include "TBrowser.h"
-#include "TH2.h"
-#include "TRandom.h"
-
-#ifdef __MAKECINT__
-#pragma link C++ class vector<float>+;
-#endif
-
-const Float_t MIN_MC_PROB = 0.499;
-
-const Float_t PT_CUT = 500.;
-
-// event selection
-const Int_t APPLY_PV_CUT = 1;
-const Int_t APPLY_TRIGGER_CUT  = 0;
-const Int_t APPLY_ONEGOODTRACK = 1;
-//const TRIGL1NAME = 'L1_MBTS_1';
-
-const Int_t APPLY_PV_CORR  = 0;
-const Int_t MAX_EVTS = -1;
-const Int_t APPLY_TRK_SEL     = 1;
-
-   std::vector<float> *reco=0;
-   std::vector<int> *recoh=0;
-   TBranch *br;
-   TBranch *brh;   
-   Float_t aa;
-   Float_t aaa;
-   
-   
-bool trkCutsEvtSelection(TTree *L,Int_t evt, Int_t r, Float_t eta){
-
-
-    //br = L->GetBranch("trk_eta");
-    //br->SetAddress(&reco);
-    //br->GetEntry(evt);
-
-    // |eta| > 2.5
-    if (fabs(eta) > 2.5 ) return 0;
-//////////////////////////////////////////////
-    brh = L->GetBranch("trk_nPixHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // Pixel hits
-    if ( recoh->at(r) < 1 ) return 0;
-    
-
-    /*brh = L->GetBranch("trk_nPixHoles");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // Pixel holes
-    if ( recoh->at(r) > 0 ) return 0;*/
-
-    brh = L->GetBranch("trk_nSCTHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // SCT hits
-    if ( recoh->at(r) <6 ) return 0;
-
-    /*brh = L->GetBranch("trk_nSCTHoles");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // SCT holes
-    if (recoh->at(r) > 2 ) return 0;*/
-
-    br = L->GetBranch("trk_d0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-    if (fabs( reco->at(r) ) >= 1.5 ) return 0;
-
-    br = L->GetBranch("trk_z0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aa = reco->at(r);
-
-    br = L->GetBranch("trk_theta");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aaa = reco->at(r);
-
-    // z0 sin(theta) cut
-    if ( fabs( aa * TMath::Sin( aaa) ) >= 1.5 ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-
-   std::vector<float> *recot=0;
-   std::vector<int> *recoht=0;
-   TBranch *brt;
-   TBranch *brht;
-   
-   Float_t aat;
-   Float_t aaat;
-   
-bool trkSelCuts(TTree *L,Int_t evt, Int_t r, Float_t pt){
-
-    //brt = L->GetBranch("trk_pt");
-   // brt->SetAddress(&recot);
-   // brt->GetEntry(evt); 
-    // pT cut
-    if (pt < PT_CUT) return 0;
-
-//////////////////////////////////////////////
-    /*brht = L->GetBranch("trk_nPixHoles");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // Pixel holes
-    if ( recoht->at(r) > 0 ) return 0;*/
-
-    brht = L->GetBranch("trk_nPixHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // Pixel hits
-    if ( recoht->at(r) < 1 ) return 0;
-
-    brht = L->GetBranch("trk_nSCTHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // SCT hits
-    if (recoht->at(r) < 6 ) return 0;
-
-    /*brht = L->GetBranch("trk_nSCTHoles");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // SCT holes
-    if (recoht->at(r) > 2 ) return 0;*/
-
-    brt = L->GetBranch("trk_d0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-    if (fabs( recot->at(r) ) >= 1.5 ) return 0;
-
-    brt = L->GetBranch("trk_z0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-	aat = recot->at(r);
-
-    brt = L->GetBranch("trk_theta");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-    aaat = recot->at(r);
-    // z0 sin(theta) cut
-    if ( fabs( aat * TMath::Sin( aaat) ) >= 1.5 ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-void HIInDetValidation_Fakes_Loose(){
-
-/////////////////ATLAS STYLE//////////////////////////////////////////
-TStyle *atlasStyle = new TStyle("ATLAS","Atlas style");
-
-  // use plain black on white colors
-  Int_t icol=0; // WHITE
-  atlasStyle->SetFrameBorderMode(icol);
-  atlasStyle->SetFrameFillColor(icol);
-  atlasStyle->SetCanvasBorderMode(icol);
-  atlasStyle->SetCanvasColor(icol);
-  atlasStyle->SetPadBorderMode(icol);
-  atlasStyle->SetPadColor(icol);
-  atlasStyle->SetStatColor(icol);
-  //atlasStyle->SetFillColor(icol); // don't use: white fill color for *all* objects
-
-  // set the paper & margin sizes
-  atlasStyle->SetPaperSize(20,26);
-
-  // set margin sizes
-  atlasStyle->SetPadTopMargin(0.10);
-  atlasStyle->SetPadRightMargin(0.05);
-  atlasStyle->SetPadBottomMargin(0.10);
-  atlasStyle->SetPadLeftMargin(0.10);
-
-  // set title offsets (for axis label)
-  atlasStyle->SetTitleXOffset(1.2);
-  atlasStyle->SetTitleYOffset(1.1);
-
-  // use large fonts
-  //Int_t font=72; // Helvetica italics
-  Int_t font=42; // Helvetica
-  Double_t tsize=0.04;
-  atlasStyle->SetTextFont(font);
-
-  atlasStyle->SetTextSize(tsize);
-  atlasStyle->SetLabelFont(font,"x");
-  atlasStyle->SetTitleFont(font,"x");
-  atlasStyle->SetLabelFont(font,"y");
-  atlasStyle->SetTitleFont(font,"y");
-  atlasStyle->SetLabelFont(font,"z");
-  atlasStyle->SetTitleFont(font,"z");
-  
-  atlasStyle->SetLabelSize(tsize,"x");
-  atlasStyle->SetTitleSize(tsize,"x");
-  atlasStyle->SetLabelSize(tsize,"y");
-  atlasStyle->SetTitleSize(tsize,"y");
-  atlasStyle->SetLabelSize(tsize,"z");
-  atlasStyle->SetTitleSize(tsize,"z");
-
-  // use bold lines and markers
-  atlasStyle->SetMarkerStyle(20);
-  atlasStyle->SetMarkerSize(0.9);
-  atlasStyle->SetMarkerColor(4);
-  atlasStyle->SetHistLineWidth(1.);
-  atlasStyle->SetLineStyleString(2,"[12 12]"); // postscript dashes
-
-  // get rid of X error bars 
-  //atlasStyle->SetErrorX(0.001);
-  // get rid of error bar caps
-  atlasStyle->SetEndErrorSize(0.);
-
-  // do not display any of the standard histogram decorations
-  atlasStyle->SetOptTitle();
-  atlasStyle->SetOptStat();
-  //atlasStyle->SetOptStat(0);
-  //atlasStyle->SetOptFit(1111);
-  atlasStyle->SetOptFit(0);
-
- // put tick marks on top and RHS of plots
-  //atlasStyle->SetPadTickX(1);
- // atlasStyle->SetPadTickY(1);
- 
-atlasStyle->SetStatY(0.99);                
-// Set y-position (fraction of pad size)
-atlasStyle->SetStatX(0.99);                
-// Set x-position (fraction of pad size)
-atlasStyle->SetStatW(0.2);                
-// Set width of stat-box (fraction of pad size)
-atlasStyle->SetStatH(0.1);                
-// Set height of stat-box (fraction of pad size)
-atlasStyle->SetLabelOffset(0.008,"X");
-atlasStyle->SetLabelOffset(0.008,"Y");
-  
-  gROOT->SetStyle("ATLAS");
-  gROOT->ForceStyle();
-///////////////////////////////////////////////////////////////////////////////////////
-
-   TFile *file = TFile::Open("InDetTrackD3PD.root","READ");
-   
-   TTree *T = (TTree*)file->Get("InDetTrackTree");
-
-   histofile = TFile("Fakes-C-Loose.root","recreate");
-
-//////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t binsEta = 30;
-Float_t minEta  = -2.5;
-Float_t maxEta  =  2.5;
-Int_t binsPt  = 30;
-Float_t minPt   = 0.;
-Float_t maxPt   = 10.0;
-
-
-TH1F *h_eta_allReco           = new TH1F("h_eta_allReco",       "", binsEta, minEta, maxEta);
-TH1F *h_eta_noMatch           = new TH1F("h_eta_noMatch",       "", binsEta, minEta, maxEta);
-TH1F *h_eta_fake              = new TH1F("h_eta_fake",          "FakeRatio(#eta)", binsEta, minEta, maxEta);
-
-TH1F *h_pt_allReco            = new TH1F("h_pt_allReco",        "", binsPt, minPt, maxPt);
-TH1F *h_pt_noMatch            = new TH1F("h_pt_noMatch",        "", binsPt, minPt, maxPt);
-TH1F *h_pt_fake               = new TH1F("h_pt_fake",           "FakeRatio(p_{T})", binsPt, minPt, maxPt);
-
-TH1F *h_phi_allReco           = new TH1F("h_phi_allReco",       "", 30, -4, 4);
-TH1F *h_phi_noMatch           = new TH1F("h_phi_noMatch",       "", 30, -4, 4);
-TH1F *h_phi_fake              = new TH1F("h_phi_fake",          "FakeRatio(#phi)", 30, -4, 4);
-
-TH1F *h_D0_allReco            = new TH1F("h_D0_allReco",        "", 30, -2, 2);
-TH1F *h_D0_noMatch            = new TH1F("h_D0_noMatch",        "", 30, -2, 2);
-TH1F *h_D0_fake               = new TH1F("h_D0_fake",           "FakeRatio(d_{0})", 30, -2, 2);
-
-TH1F *h_Z0_allReco            = new TH1F("h_Z0_allReco",        "", 30, -100, 100);
-TH1F *h_Z0_noMatch            = new TH1F("h_Z0_noMatch",        "", 30, -100, 100);
-TH1F *h_Z0_fake               = new TH1F("h_Z0_fake",           "FakeRatio(z_{0})", 30, -100, 100);
-
-
-TH2F *hAllReco_etapt          = new TH2F("hAllReco_etapt",      "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-
-TH2F *hReco_fakes_etapt       = new TH2F("hReco_fakes_etapt",   "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-
-TH1F *hVal_PVz  	      = new TH1F("hVal_PVz",            "", 100, -100, 100);
-
-///////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t counter = 0;
-Int_t evtAfterTrigger = 0;
-Int_t evtAfterPV      = 0;
-Int_t evtAfterGoodTrk = 0;
-    	
-            	std::vector<int> *m_trk_mc_index=0;
-            	T->SetBranchAddress("trk_mc_index",&m_trk_mc_index);
-            	
-        	std::vector<float> *m_trk_mc_probability=0;
-        	T->SetBranchAddress("trk_mc_probability",&m_trk_mc_probability);
-        	
-		std::vector<float> *m_trk_eta=0;
-		T->SetBranchAddress("trk_eta",&m_trk_eta);
-		
-		std::vector<float> *m_trk_phi=0;
-        	T->SetBranchAddress("trk_phi",&m_trk_phi);
-        	
-		std::vector<float> *m_trk_pt=0;
-		T->SetBranchAddress("trk_pt",&m_trk_pt);
-
-        	std::vector<float> *m_trk_d0=0;
-        	T->SetBranchAddress("trk_d0",&m_trk_d0);
-        	
-		std::vector<float> *m_trk_z0=0;
-        	T->SetBranchAddress("trk_z0",&m_trk_z0);
-
-		Int_t m_trk_n;
-		T->SetBranchAddress("trk_n",&m_trk_n);
-		
-		
-		std::vector<int> *m_vx_type=0;
-		T->SetBranchAddress("vx_type",&m_vx_type);
-		
-		std::vector<int> *m_vx_nTracks=0;
-		T->SetBranchAddress("vx_nTracks",&m_vx_nTracks);
-		
-		std::vector<float> *m_vx_z=0;
-		T->SetBranchAddress("vx_z",&m_vx_z);
-		
-		Int_t m_mc_n;
-		T->SetBranchAddress("mc_n",&m_mc_n);  
-   
-                Int_t nentries = (Int_t)(T->GetEntries());
-
-	        bool ok = 0;
-	        
-	       	Int_t x1 = 600;
-	        Int_t x2 = 2000;
-	        
-	        Float_t e1=0, e2=0, e3=0, e4=0, e5=0, e6=0;
-	        Int_t n1=0, n2=0, n3=0;	
-	
-/////////////////  MAIN LOOP  ///////////////////////////////////////////
-   for (Int_t i=0;i<nentries;i++) {
-   
-   	T->GetEntry(i);
-   
-	printf("Processing event: %i\n",counter);
-	counter += 1;
-	
-	// maximum events
-	if (counter >= MAX_EVTS && MAX_EVTS != -1) break;
-	////////// EVENT SLECTION :
-	/////////////////////////
-	// 1) L1 Trigger Fired
-	/*if (APPLY_TRIGGER_CUT){
-        	ok = 0;
-        	//  for (name in ch.ctp_decisionItems){
-        	if (name == TRIGL1NAME){
-                ok = 1;
-                break;
-                }
-        	//if not ok continue;
-       		// }
-       		
-       	}	*/
-    	evtAfterTrigger += 1;
-   	
-	// 2) Require a good Primary Vertex					
-	if ( APPLY_PV_CUT && ( (*m_vx_type)[0] == 0 || (*m_vx_nTracks)[0] < 3)) continue;
-		
-    	evtAfterPV += 1;
-    	
-	// 3) At least one good track in event
-	if (APPLY_ONEGOODTRACK){
-		ok = 0;
-		
-		for ( Int_t r=0; r< m_trk_n; r++ ){
-			if ( trkCutsEvtSelection( T, i, r, (*m_trk_eta)[r]) ){
-			ok = 1;
-			break;
-			}
-		////////////////////////////////////////////////////////////////
-		if (!ok) continue;
-		///////////////////////////////////////////////////////
-		}
-		evtAfterGoodTrk += 1;
-	}	
-	//DONE with Event Selection
-	
-	//Reweight MC
-    	Float_t ev_weight = 1.0;
-    	 
-    	/*if (APPLY_PV_CORR){
-    	ev_weight = hCorrectPV.GetBinContent( hCorrectPV.FindBin( (*m_vx_z)[0]) );
-    	}*/
-
-    	hVal_PVz->Fill( (*m_vx_z)[0],ev_weight);
-	
-	if ( m_trk_n<x1 ) n1++;
-	if (  m_trk_n>x1 && m_trk_n<x2 ) n2++;
-	if ( m_trk_n>x2 )n3++;
-	
-		
-	for (Int_t k=0; k<m_trk_n; k++){
-    	
-	if (APPLY_TRK_SEL && !(trkSelCuts( T, i, k, (*m_trk_pt)[k]))) continue;
-
-		if ( m_trk_n<x1 ) e4++; 
-                if (  m_trk_n>=x1 && m_trk_n<x2 )e5++; 
-		if ( m_trk_n>=x2 ) e6++; 
-	
-        h_phi_allReco->Fill( (*m_trk_phi)[k], ev_weight);
-        h_D0_allReco->Fill( (*m_trk_d0)[k], ev_weight);
-        h_Z0_allReco->Fill( (*m_trk_z0)[k], ev_weight);
-       
-        hAllReco_etapt->Fill(  (*m_trk_eta)[k], (*m_trk_pt)[k]/1000., ev_weight  );
-        h_pt_allReco->Fill( (*m_trk_pt)[k]/1000., ev_weight);
-        h_eta_allReco->Fill(  (*m_trk_eta)[k], ev_weight);
-
-
-	if ( ( (*m_trk_mc_probability)[k] <= MIN_MC_PROB) ){
-	
-	        if ( m_trk_n<x1 ) e1++;
-                if (  m_trk_n>=x1 && m_trk_n<x2 ) e2++;
-		if ( m_trk_n>=x2 ) e3++;
-	
-       		hReco_fakes_etapt->Fill(  (*m_trk_eta)[k], (*m_trk_pt)[k]/1000., ev_weight  );
-       		h_eta_noMatch->Fill(  (*m_trk_eta)[k], ev_weight);
-      		h_pt_noMatch->Fill( (*m_trk_pt)[k]/1000., ev_weight);
-
-       		h_phi_noMatch->Fill( (*m_trk_phi)[k], ev_weight);
-       		h_D0_noMatch->Fill( (*m_trk_d0)[k], ev_weight);
-       		h_Z0_noMatch->Fill( (*m_trk_z0)[k], ev_weight);
-	 	
-	 		}
-	
-		}
-
-   }
-   
-const Float_t bins[] = {10., (Float_t)x1, (Float_t)x2, 10000.};
-
-TH1F *h_number                    = new TH1F("h_number",                 "Fakes vs # of tracks per evt", 3, bins); 
-
-	if (n3 !=0){
-	h_number->Fill(e6/n3, e3/e6);
-	h_number->SetBinError(3, (sqrt(e3/e6*(1-e3/e6)/e6))); }
-	
-	if (n2 !=0){
-	h_number->Fill( e5/n2, e2/e5);
-	h_number->SetBinError(2, (sqrt(e2/e5*(1-e2/e5)/e5))); }
-	
-	if (n1 !=0){
-	h_number->Fill(e4/n1, e1/e4);
-	h_number->SetBinError(1, (sqrt(e1/e4*(1-e1/e4)/e4))); }
-
-	printf ("%f %f  %f  %f\n" ,e4/n1, e5/n2, e6/n3, 10.*e6/n3);
-   
-
-printf ("events : %i (processed) %i (after trigger) %i (after PV cut) %i (after good trk)\n" ,counter, evtAfterTrigger, evtAfterPV, evtAfterGoodTrk);
-
-
-h_pt_allReco->Sumw2();
-h_pt_noMatch->Sumw2();
-h_pt_fake->Divide(h_pt_noMatch,h_pt_allReco,1.0,1.0,"b");
-h_pt_fake->GetXaxis()->SetTitle("p_{T} [GeV]");
-//h_pt_eff->GetYaxis()->SetTitle("Eff");
-//h_pt_eff->SetTitle("p_{T}");
-
-h_phi_allReco->Sumw2();
-h_phi_noMatch->Sumw2();
-h_phi_fake->Divide(h_phi_noMatch,h_phi_allReco,1.0,1.0,"b");
-h_phi_fake->GetXaxis()->SetTitle("#phi");
-//h_phi_eff->GetYaxis()->SetTitle("Eff");
-//h_phi_eff->SetTitle("phi");
-
-h_D0_allReco->Sumw2();
-h_D0_noMatch->Sumw2();
-h_D0_fake->Divide(h_D0_noMatch,h_D0_allReco,1.0,1.0,"b");
-h_D0_fake->GetXaxis()->SetTitle("d_{0}");
-//h_D0_eff->GetYaxis()->SetTitle("Eff");
-//h_D0_eff->SetTitle("d0");
-
-h_eta_allReco->Sumw2();
-h_eta_noMatch->Sumw2();
-h_eta_fake->Divide(h_eta_noMatch,h_eta_allReco,1.0,1.0,"b");
-h_eta_fake->GetXaxis()->SetTitle("#eta");
-//h_eta_eff->GetYaxis()->SetTitle("Eff");
-//h_eta_eff->SetTitle("#eta");
-
-h_Z0_allReco->Sumw2();
-h_Z0_noMatch->Sumw2();
-h_Z0_fake->Divide(h_Z0_noMatch,h_Z0_allReco,1.0,1.0,"b");
-h_Z0_fake->GetXaxis()->SetTitle("z_{0}");
-//h_Z0_eff->GetYaxis()->SetTitle("Eff");
-//h_Z0_eff->SetTitle("z0");
-
-TCanvas* c1=new TCanvas();
-c1->SetWindowSize(800,600);
-c1->Resize();
-
-h_eta_fake->Scale(100);
-h_eta_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_eta_loose.png");
-
-c1->Update();
-h_pt_fake->Scale(100);
-h_pt_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_pt_loose.png");
-
-c1->Update();
-h_phi_fake->Scale(100);
-h_phi_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_phi_loose.png");
-
-c1->Update();
-h_D0_fake->Scale(100);
-h_D0_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_d0_loose.png");
-c1->Update();
-h_Z0_fake->Scale(100);
-h_Z0_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_z0_loose.png");
-
-c1->SetLogx();
-
-c1->Update();
-
-gr = new TGraphErrors(h_number);
-gr->Draw("ALP");
-
-h_number->Scale(100);
-h_number->GetXaxis()->SetTitle("number of tracks per evt");
-h_number->GetYaxis()->SetTitle("Fake Ratio [%]");
-
-h_number ->Draw("E1");
-
-c1->cd();
-c1->SaveAs("Fake_number.png");
-
-
-
-Float_t fakr = h_phi_noMatch->GetEntries()/h_phi_allReco->GetEntries();
-TString out=""; out+=(fakr*100.); out+=" % +- ";
-out+=100.*(sqrt(fakr*(1-fakr)/h_phi_allReco->GetEntries()));
-out+=" %";
-
-
-string line;
-Int_t ww=0;
-
-ifstream Myfile("fakes_HIInDetValidation.txt");
-if(Myfile.is_open())
-{
-while(!Myfile.eof())
-{
-getline(Myfile,line);
-if (line =="----------------Fake ratio summary (loose cuts)---------------------") ww=1;
-}
-Myfile.close();
-}
-if (ww==0)
-{
-ofstream myfile("fakes_HIInDetValidation.txt", ios::out | ios::app);
-myfile <<"----------------Fake ratio summary (loose cuts)---------------------\n";
-myfile <<"Track_Loose fake ratio : " << out << endl;
-}
-
-
-
-
-histofile.Write();
-histofile.Close();
-}
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Fakes_Tight.C b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Fakes_Tight.C
deleted file mode 100644
index 8f05a9d20a81ffe1c1bf36f33d10539ad83aaf97..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Fakes_Tight.C
+++ /dev/null
@@ -1,539 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "vector"
-#include "stdio.h"
-#include "TFile.h"
-#include "TChain.h"
-#include "TH2F"
-#include "TH1F.h"
-#include "TCanvas.h"
-#include "TMath.h"
-
-
-#include "TTree.h"
-#include "TBrowser.h"
-#include "TH2.h"
-#include "TRandom.h"
-
-#ifdef __MAKECINT__
-#pragma link C++ class vector<float>+;
-#endif
-
-const Float_t MIN_MC_PROB = 0.499;
-
-const Float_t PT_CUT = 500.;
-
-// event selection
-const Int_t APPLY_PV_CUT = 1;
-const Int_t APPLY_TRIGGER_CUT  = 0;
-const Int_t APPLY_ONEGOODTRACK = 1;
-//const TRIGL1NAME = 'L1_MBTS_1';
-
-const Int_t APPLY_PV_CORR  = 0;
-const Int_t MAX_EVTS = -1;
-const Int_t APPLY_TRK_SEL     = 1;
-
-   std::vector<float> *reco=0;
-   std::vector<int> *recoh=0;
-   TBranch *br;
-   TBranch *brh;   
-   Float_t aa;
-   Float_t aaa;
-   
-   
-bool trkCutsEvtSelection(TTree *L,Int_t evt, Int_t r, Float_t eta){
-
-
-    //br = L->GetBranch("trk_eta");
-    //br->SetAddress(&reco);
-    //br->GetEntry(evt);
-
-    // |eta| > 2.5
-    if (fabs(eta) > 2.5 ) return 0;
-//////////////////////////////////////////////
-    brh = L->GetBranch("trk_nPixHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // Pixel hits
-    if ( recoh->at(r) <= 1 ) return 0;
-    
-
-    brh = L->GetBranch("trk_nPixHoles");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // Pixel holes
-    if ( recoh->at(r) > 0 ) return 0;
-
-    brh = L->GetBranch("trk_nSCTHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // SCT hits
-    if ( recoh->at(r) <=7) return 0;
-
-    brh = L->GetBranch("trk_nSCTHoles");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-    // SCT holes
-    if (recoh->at(r) >= 2 ) return 0;
-
-    br = L->GetBranch("trk_d0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-    if (fabs( reco->at(r) ) >= 1. ) return 0;
-
-    br = L->GetBranch("trk_z0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aa = reco->at(r);
-
-    br = L->GetBranch("trk_theta");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aaa = reco->at(r);
-
-    // z0 sin(theta) cut
-    if ( fabs( aa * TMath::Sin( aaa) ) >= 1. ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-
-   std::vector<float> *recot=0;
-   std::vector<int> *recoht=0;
-   TBranch *brt;
-   TBranch *brht;
-   
-   Float_t aat;
-   Float_t aaat;
-   
-bool trkSelCuts(TTree *L,Int_t evt, Int_t r, Float_t pt){
-
-    //brt = L->GetBranch("trk_pt");
-   // brt->SetAddress(&recot);
-   // brt->GetEntry(evt); 
-    // pT cut
-    if (pt < PT_CUT) return 0;
-
-//////////////////////////////////////////////
-    brht = L->GetBranch("trk_nPixHoles");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // Pixel holes
-    if ( recoht->at(r) > 0 ) return 0;
-
-    brht = L->GetBranch("trk_nPixHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // Pixel hits
-    if ( recoht->at(r) <= 1 ) return 0;
-
-    brht = L->GetBranch("trk_nSCTHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // SCT hits
-    if (recoht->at(r) <=7 ) return 0;
-
-    brht = L->GetBranch("trk_nSCTHoles");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-    // SCT holes
-    if (recoht->at(r) >= 2 ) return 0;
-
-    brt = L->GetBranch("trk_d0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-    if (fabs( recot->at(r) ) >= 1. ) return 0;
-
-    brt = L->GetBranch("trk_z0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-	aat = recot->at(r);
-
-    brt = L->GetBranch("trk_theta");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-    aaat = recot->at(r);
-    // z0 sin(theta) cut
-    if ( fabs( aat * TMath::Sin( aaat) ) >= 1. ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-
-void HIInDetValidation_Fakes_Tight(){
-
-
-/////////////////ATLAS STYLE//////////////////////////////////////////
-TStyle *atlasStyle = new TStyle("ATLAS","Atlas style");
-
-  // use plain black on white colors
-  Int_t icol=0; // WHITE
-  atlasStyle->SetFrameBorderMode(icol);
-  atlasStyle->SetFrameFillColor(icol);
-  atlasStyle->SetCanvasBorderMode(icol);
-  atlasStyle->SetCanvasColor(icol);
-  atlasStyle->SetPadBorderMode(icol);
-  atlasStyle->SetPadColor(icol);
-  atlasStyle->SetStatColor(icol);
-  //atlasStyle->SetFillColor(icol); // don't use: white fill color for *all* objects
-
-  // set the paper & margin sizes
-  atlasStyle->SetPaperSize(20,26);
-
-  // set margin sizes
-  atlasStyle->SetPadTopMargin(0.10);
-  atlasStyle->SetPadRightMargin(0.05);
-  atlasStyle->SetPadBottomMargin(0.10);
-  atlasStyle->SetPadLeftMargin(0.10);
-
-  // set title offsets (for axis label)
-  atlasStyle->SetTitleXOffset(1.1);
-  atlasStyle->SetTitleYOffset(1.4);
-
-  // use large fonts
-  //Int_t font=72; // Helvetica italics
-  Int_t font=42; // Helvetica
-  Double_t tsize=0.04;
-  atlasStyle->SetTextFont(font);
-
-  atlasStyle->SetTextSize(tsize);
-  atlasStyle->SetLabelFont(font,"x");
-  atlasStyle->SetTitleFont(font,"x");
-  atlasStyle->SetLabelFont(font,"y");
-  atlasStyle->SetTitleFont(font,"y");
-  atlasStyle->SetLabelFont(font,"z");
-  atlasStyle->SetTitleFont(font,"z");
-  
-  atlasStyle->SetLabelSize(tsize,"x");
-  atlasStyle->SetTitleSize(tsize,"x");
-  atlasStyle->SetLabelSize(tsize,"y");
-  atlasStyle->SetTitleSize(tsize,"y");
-  atlasStyle->SetLabelSize(tsize,"z");
-  atlasStyle->SetTitleSize(tsize,"z");
-
-  // use bold lines and markers
-  atlasStyle->SetMarkerStyle(20);
-  atlasStyle->SetMarkerSize(0.9);
-  atlasStyle->SetMarkerColor(2);
-  atlasStyle->SetHistLineWidth(1.);
-  atlasStyle->SetLineStyleString(2,"[12 12]"); // postscript dashes
-
-  // get rid of X error bars 
-  //atlasStyle->SetErrorX(0.001);
-  // get rid of error bar caps
-  atlasStyle->SetEndErrorSize(0.);
-
-  // do not display any of the standard histogram decorations
-  atlasStyle->SetOptTitle();
-  atlasStyle->SetOptStat();
-  //atlasStyle->SetOptStat(0);
-  //atlasStyle->SetOptFit(1111);
-  atlasStyle->SetOptFit(0);
-
- // put tick marks on top and RHS of plots
-  //atlasStyle->SetPadTickX(1);
- // atlasStyle->SetPadTickY(1);
- 
-atlasStyle->SetStatY(0.99);                
-// Set y-position (fraction of pad size)
-atlasStyle->SetStatX(0.99);                
-// Set x-position (fraction of pad size)
-atlasStyle->SetStatW(0.2);                
-// Set width of stat-box (fraction of pad size)
-atlasStyle->SetStatH(0.1);                
-// Set height of stat-box (fraction of pad size)
-atlasStyle->SetLabelOffset(0.008,"X");
-atlasStyle->SetLabelOffset(0.008,"Y");
-  
-  gROOT->SetStyle("ATLAS");
-  gROOT->ForceStyle();
-///////////////////////////////////////////////////////////////////////////////////////
-
-
-  // TFile file("/home/mateusz/Pulpit/user.mdyndal.test_500MeV_noTRT/user.mdyndal.test_500MeV_noTRT.D3PD._00001.root");
-   TFile *file = TFile::Open("InDetTrackD3PD.root","READ");
-   
-   TTree *T = (TTree*)file->Get("InDetTrackTree");
-
-   histofile = TFile("Fakes-C-Tight.root","recreate");
-
-
-//////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t binsEta = 30;
-Float_t minEta  = -2.5;
-Float_t maxEta  =  2.5;
-Int_t binsPt  = 30;
-Float_t minPt   = 0.;
-Float_t maxPt   = 10.0;
-
-
-TH1F *h_eta_allReco           = new TH1F("h_eta_allReco",       "", binsEta, minEta, maxEta);
-TH1F *h_eta_noMatch           = new TH1F("h_eta_noMatch",       "", binsEta, minEta, maxEta);
-TH1F *h_eta_fake              = new TH1F("h_eta_fake",          "FakeRatio(#eta)", binsEta, minEta, maxEta);
-
-TH1F *h_pt_allReco            = new TH1F("h_pt_allReco",        "", binsPt, minPt, maxPt);
-TH1F *h_pt_noMatch            = new TH1F("h_pt_noMatch",        "", binsPt, minPt, maxPt);
-TH1F *h_pt_fake               = new TH1F("h_pt_fake",           "FakeRatio(p_{T})", binsPt, minPt, maxPt);
-
-TH1F *h_phi_allReco           = new TH1F("h_phi_allReco",       "", 30, -4, 4);
-TH1F *h_phi_noMatch           = new TH1F("h_phi_noMatch",       "", 30, -4, 4);
-TH1F *h_phi_fake              = new TH1F("h_phi_fake",          "FakeRatio(#phi)", 30, -4, 4);
-
-TH1F *h_D0_allReco            = new TH1F("h_D0_allReco",        "", 30, -2, 2);
-TH1F *h_D0_noMatch            = new TH1F("h_D0_noMatch",        "", 30, -2, 2);
-TH1F *h_D0_fake               = new TH1F("h_D0_fake",           "FakeRatio(d_{0})", 30, -2, 2);
-
-TH1F *h_Z0_allReco            = new TH1F("h_Z0_allReco",        "", 30, -100, 100);
-TH1F *h_Z0_noMatch            = new TH1F("h_Z0_noMatch",        "", 30, -100, 100);
-TH1F *h_Z0_fake               = new TH1F("h_Z0_fake",           "FakeRatio(z_{0})", 30, -100, 100);
-
-
-TH2F *hAllReco_etapt          = new TH2F("hAllReco_etapt",      "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-
-TH2F *hReco_fakes_etapt       = new TH2F("hReco_fakes_etapt",   "", binsEta, minEta, maxEta, binsPt, minPt, maxPt);
-
-TH1F *hVal_PVz  	      = new TH1F("hVal_PVz",            "", 100, -100, 100);
-
-///////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t counter = 0;
-Int_t evtAfterTrigger = 0;
-Int_t evtAfterPV      = 0;
-Int_t evtAfterGoodTrk = 0;
-    	
-
-            	std::vector<int> *m_trk_mc_index=0;
-            	T->SetBranchAddress("trk_mc_index",&m_trk_mc_index);
-            	
-        	std::vector<float> *m_trk_mc_probability=0;
-        	T->SetBranchAddress("trk_mc_probability",&m_trk_mc_probability);
-        	
-		std::vector<float> *m_trk_eta=0;
-		T->SetBranchAddress("trk_eta",&m_trk_eta);
-		
-		std::vector<float> *m_trk_phi=0;
-        	T->SetBranchAddress("trk_phi",&m_trk_phi);
-        	
-		std::vector<float> *m_trk_pt=0;
-		T->SetBranchAddress("trk_pt",&m_trk_pt);
-
-        	std::vector<float> *m_trk_d0=0;
-        	T->SetBranchAddress("trk_d0",&m_trk_d0);
-        	
-		std::vector<float> *m_trk_z0=0;
-        	T->SetBranchAddress("trk_z0",&m_trk_z0);
-
-		Int_t m_trk_n;
-		T->SetBranchAddress("trk_n",&m_trk_n);
-		
-		
-		std::vector<int> *m_vx_type=0;
-		T->SetBranchAddress("vx_type",&m_vx_type);
-		
-		std::vector<int> *m_vx_nTracks=0;
-		T->SetBranchAddress("vx_nTracks",&m_vx_nTracks);
-		
-		std::vector<float> *m_vx_z=0;
-		T->SetBranchAddress("vx_z",&m_vx_z);
-		
-		Int_t m_mc_n;
-		T->SetBranchAddress("mc_n",&m_mc_n);  
-   
-                Int_t nentries = (Int_t)(T->GetEntries());
-
-	        bool ok = 0;
-	
-/////////////////  MAIN LOOP  ///////////////////////////////////////////
-   for (Int_t i=0;i<nentries;i++) {
-   
-   	T->GetEntry(i);
-   
-	printf("Processing event: %i\n",counter);
-	counter += 1;
-	
-	// maximum events
-	if (counter >= MAX_EVTS && MAX_EVTS != -1) break;
-	////////// EVENT SLECTION :
-	/////////////////////////
-	// 1) L1 Trigger Fired
-	/*if (APPLY_TRIGGER_CUT){
-        	ok = 0;
-        	//  for (name in ch.ctp_decisionItems){
-        	if (name == TRIGL1NAME){
-                ok = 1;
-                break;
-                }
-        	//if not ok continue;
-       		// }
-       		
-       	}	*/
-    	evtAfterTrigger += 1;
-   	
-	// 2) Require a good Primary Vertex					
-	if ( APPLY_PV_CUT && ( (*m_vx_type)[0] == 0 || (*m_vx_nTracks)[0] < 3)) continue;
-		
-    	evtAfterPV += 1;
-    	
-	// 3) At least one good track in event
-	if (APPLY_ONEGOODTRACK){
-		ok = 0;
-		
-		for ( Int_t r=0; r< m_trk_n; r++ ){
-			if ( trkCutsEvtSelection( T, i, r, (*m_trk_eta)[r]) ){
-			ok = 1;
-			break;
-			}
-		////////////////////////////////////////////////////////////////
-		if (!ok) continue;
-		///////////////////////////////////////////////////////
-		}
-		evtAfterGoodTrk += 1;
-	}	
-	//DONE with Event Selection
-	
-	//Reweight MC
-    	Float_t ev_weight = 1.0;
-    	 
-    	/*if (APPLY_PV_CORR){
-    	ev_weight = hCorrectPV.GetBinContent( hCorrectPV.FindBin( (*m_vx_z)[0]) );
-    	}*/
-
-    	hVal_PVz->Fill( (*m_vx_z)[0],ev_weight);
-		
-		
-	for (Int_t k=0; k<m_trk_n; k++){
-    	
-	if (APPLY_TRK_SEL && !(trkSelCuts( T, i, k, (*m_trk_pt)[k]))) continue;
-
-        h_phi_allReco->Fill( (*m_trk_phi)[k], ev_weight);
-        h_D0_allReco->Fill( (*m_trk_d0)[k], ev_weight);
-        h_Z0_allReco->Fill( (*m_trk_z0)[k], ev_weight);
-       
-        hAllReco_etapt->Fill(  (*m_trk_eta)[k], (*m_trk_pt)[k]/1000., ev_weight  );
-        h_pt_allReco->Fill( (*m_trk_pt)[k]/1000., ev_weight);
-        h_eta_allReco->Fill(  (*m_trk_eta)[k], ev_weight);
-
-
-	if ( ( (*m_trk_mc_probability)[k] <= MIN_MC_PROB) ){
-       		hReco_fakes_etapt->Fill(  (*m_trk_eta)[k], (*m_trk_pt)[k]/1000., ev_weight  );
-       		h_eta_noMatch->Fill(  (*m_trk_eta)[k], ev_weight);
-      		h_pt_noMatch->Fill( (*m_trk_pt)[k]/1000., ev_weight);
-
-       		h_phi_noMatch->Fill( (*m_trk_phi)[k], ev_weight);
-       		h_D0_noMatch->Fill( (*m_trk_d0)[k], ev_weight);
-       		h_Z0_noMatch->Fill( (*m_trk_z0)[k], ev_weight);
-	 	
-	 		}
-	
-		}
-
-   }
-
-printf ("events : %i (processed) %i (after trigger) %i (after PV cut) %i (after good trk)\n" ,counter, evtAfterTrigger, evtAfterPV, evtAfterGoodTrk);
-
-
-h_pt_allReco->Sumw2();
-h_pt_noMatch->Sumw2();
-h_pt_fake->Divide(h_pt_noMatch,h_pt_allReco,1.0,1.0,"b");
-h_pt_fake->GetXaxis()->SetTitle("p_{T} [GeV]");
-//h_pt_eff->GetYaxis()->SetTitle("Eff");
-//h_pt_eff->SetTitle("p_{T}");
-
-h_phi_allReco->Sumw2();
-h_phi_noMatch->Sumw2();
-h_phi_fake->Divide(h_phi_noMatch,h_phi_allReco,1.0,1.0,"b");
-h_phi_fake->GetXaxis()->SetTitle("#phi");
-//h_phi_eff->GetYaxis()->SetTitle("Eff");
-//h_phi_eff->SetTitle("phi");
-
-h_D0_allReco->Sumw2();
-h_D0_noMatch->Sumw2();
-h_D0_fake->Divide(h_D0_noMatch,h_D0_allReco,1.0,1.0,"b");
-h_D0_fake->GetXaxis()->SetTitle("d_{0}");
-//h_D0_eff->GetYaxis()->SetTitle("Eff");
-//h_D0_eff->SetTitle("d0");
-
-h_eta_allReco->Sumw2();
-h_eta_noMatch->Sumw2();
-h_eta_fake->Divide(h_eta_noMatch,h_eta_allReco,1.0,1.0,"b");
-h_eta_fake->GetXaxis()->SetTitle("#eta");
-//h_eta_eff->GetYaxis()->SetTitle("Eff");
-//h_eta_eff->SetTitle("#eta");
-
-h_Z0_allReco->Sumw2();
-h_Z0_noMatch->Sumw2();
-h_Z0_fake->Divide(h_Z0_noMatch,h_Z0_allReco,1.0,1.0,"b");
-h_Z0_fake->GetXaxis()->SetTitle("z_{0}");
-//h_Z0_eff->GetYaxis()->SetTitle("Eff");
-//h_Z0_eff->SetTitle("z0");
-
-TCanvas* c1=new TCanvas();
-c1->SetWindowSize(800,600);
-c1->Resize();
-
-h_eta_fake->Scale(100);
-h_eta_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_eta_tight.png");
-
-c1->Update();
-h_pt_fake->Scale(100);
-h_pt_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_pt_tight.png");
-
-c1->Update();
-h_phi_fake->Scale(100);
-h_phi_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_phi_tight.png");
-
-c1->Update();
-h_D0_fake->Scale(100);
-h_D0_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_d0_tight.png");
-c1->Update();
-
-h_Z0_fake->Scale(100);
-h_Z0_fake->Draw("E");
-c1->cd();
-c1->SaveAs("Fake_z0_tight.png");
-
-
-
-Float_t fakr = h_phi_noMatch->GetEntries()/h_phi_allReco->GetEntries();
-TString out=""; out+=(fakr*100.); out+=" % +- ";
-out+=100.*(sqrt(fakr*(1-fakr)/h_phi_allReco->GetEntries()));
-out+=" %";
-
-
-string line;
-Int_t ww=0;
-
-ifstream Myfile("fakes_HIInDetValidation.txt");
-if(Myfile.is_open())
-{
-while(!Myfile.eof())
-{
-getline(Myfile,line);
-if (line =="--------------- Fake ratio summary (tight cuts) ------------") ww=1;
-}
-Myfile.close();
-}
-if (ww==0)
-{
-ofstream myfile("fakes_HIInDetValidation.txt", ios::out | ios::app);
-myfile <<"--------------- Fake ratio summary (tight cuts) ------------\n";
-myfile <<"Track_Tight fake ratio : " << out << endl;
-}
-
-
-histofile.Write();
-histofile.Close();
-}
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Loose_Vs_Tight.C b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Loose_Vs_Tight.C
deleted file mode 100644
index 1a9fb555c4d5d710b6454602a03bc320bd1ad69f..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Loose_Vs_Tight.C
+++ /dev/null
@@ -1,226 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-{
-/////////////////ATLAS STYLE//////////////////////////////////////////
-TStyle *atlasStyle = new TStyle("ATLAS","Atlas style");
-
-  // use plain black on white colors
-  Int_t icol=0; // WHITE
-  atlasStyle->SetFrameBorderMode(icol);
-  atlasStyle->SetFrameFillColor(icol);
-  atlasStyle->SetCanvasBorderMode(icol);
-  atlasStyle->SetCanvasColor(icol);
-  atlasStyle->SetPadBorderMode(icol);
-  atlasStyle->SetPadColor(icol);
-  atlasStyle->SetStatColor(icol);
-  //atlasStyle->SetFillColor(icol); // don't use: white fill color for *all* objects
-
-  // set the paper & margin sizes
-  atlasStyle->SetPaperSize(20,26);
-
-  // set margin sizes
-  atlasStyle->SetPadTopMargin(0.10);
-  atlasStyle->SetPadRightMargin(0.05);
-  atlasStyle->SetPadBottomMargin(0.10);
-  atlasStyle->SetPadLeftMargin(0.10);
-
-  // set title offsets (for axis label)
-  atlasStyle->SetTitleXOffset(1.1);
-  atlasStyle->SetTitleYOffset(1.4);
-
-  // use large fonts
-  //Int_t font=72; // Helvetica italics
-  Int_t font=42; // Helvetica
-  Double_t tsize=0.04;
-  atlasStyle->SetTextFont(font);
-
-  atlasStyle->SetTextSize(tsize);
-  atlasStyle->SetLabelFont(font,"x");
-  atlasStyle->SetTitleFont(font,"x");
-  atlasStyle->SetLabelFont(font,"y");
-  atlasStyle->SetTitleFont(font,"y");
-  atlasStyle->SetLabelFont(font,"z");
-  atlasStyle->SetTitleFont(font,"z");
-  
-  atlasStyle->SetLabelSize(tsize,"x");
-  atlasStyle->SetTitleSize(tsize,"x");
-  atlasStyle->SetLabelSize(tsize,"y");
-  atlasStyle->SetTitleSize(tsize,"y");
-  atlasStyle->SetLabelSize(tsize,"z");
-  atlasStyle->SetTitleSize(tsize,"z");
-
-  // use bold lines and markers
-  atlasStyle->SetMarkerStyle(20);
-  atlasStyle->SetMarkerSize(0.9);
-  atlasStyle->SetMarkerColor(4);
-  atlasStyle->SetHistLineWidth(1.);
-  atlasStyle->SetLineStyleString(2,"[12 12]"); // postscript dashes
-
-  // get rid of X error bars 
-  //atlasStyle->SetErrorX(0.001);
-  // get rid of error bar caps
-  atlasStyle->SetEndErrorSize(0.);
-
-  // do not display any of the standard histogram decorations
-  atlasStyle->SetOptTitle();
-  atlasStyle->SetOptStat();
-  //atlasStyle->SetOptStat(0);
-  //atlasStyle->SetOptFit(1111);
-  atlasStyle->SetOptFit(0);
-
- // put tick marks on top and RHS of plots
-  //atlasStyle->SetPadTickX(1);
- // atlasStyle->SetPadTickY(1);
- 
-atlasStyle->SetStatY(0.99);                
-// Set y-position (fraction of pad size)
-atlasStyle->SetStatX(0.99);                
-// Set x-position (fraction of pad size)
-atlasStyle->SetStatW(0.2);                
-// Set width of stat-box (fraction of pad size)
-atlasStyle->SetStatH(0.1);                
-// Set height of stat-box (fraction of pad size)
-atlasStyle->SetLabelOffset(0.008,"X");
-atlasStyle->SetLabelOffset(0.008,"Y");
-  
-  gROOT->SetStyle("ATLAS");
-  gROOT->ForceStyle();
-///////////////////////////////////////////////////////////////////////////////////////
-
-
-
-TCanvas *c1 = new TCanvas("c1","title",800,600); 
-//c1->Divide(3,2);
-
-  TFile f1("Histos-Tracking-MCprob-Loose.root");
- TFile f2("Histos-Tracking-MCprob-Tight.root");
-
-  f1.cd();
-     leg_hist = new TLegend(0.92,0.13,0.72,0.23);
-  //leg_hist->SetHeader("Some histograms");
-  leg_hist->AddEntry(h_pt_eff,"loose cuts","lep");
-
-     //h_pt_eff->Scale(100);
-  h_pt_eff->Draw();
-   f2.cd();
-   h_pt_eff->SetMarkerColor(2);
-
-   h_pt_eff->Draw("same");
-  leg_hist->AddEntry(h_pt_eff,"tight cuts","lep");
-
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Eff_pt_loose_vs_tight.png");
-   
-  f1.cd(); 
- // h_eta_eff->Scale(100);
-  h_eta_eff->Draw();
-   f2.cd();
-
-   h_eta_eff->SetMarkerColor(2);
-   h_eta_eff->Draw("same");
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Eff_eta_loose_vs_tight.png");
-   
-   f1.cd(); 
-   //h_phi_eff->Scale(100);
-  h_phi_eff->Draw();
-   f2.cd();
-  
-   h_phi_eff->SetMarkerColor(2);
-   h_phi_eff->Draw("same");
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Eff_phi_loose_vs_tight.png");  
-  
-    f1.cd(); 
-    // h_D0_eff->Scale(100);
-  h_D0_eff->Draw();
-   f2.cd();
-
-   h_D0_eff->SetMarkerColor(2);
-   h_D0_eff->Draw("same");
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Eff_d0_loose_vs_tight.png");
-  
-    f1.cd(); 
-    // h_Z0_eff->Scale(100);
-  h_Z0_eff->SetMinimum(50.);
-  h_Z0_eff->Draw();
-   f2.cd();
- 
-
-   h_Z0_eff->SetMarkerColor(2);
-   h_Z0_eff->Draw("same");
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Eff_z0_loose_vs_tight.png");
-  
-////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
-  
-  TFile f3("Fakes-C-Loose.root");
- TFile f4("Fakes-C-Tight.root");
-
-   f3.cd(); 
-   //h_pt_fake->Scale(100);
-  h_pt_fake->Draw();
-   f4.cd();
- 
-   h_pt_fake->SetMarkerColor(2);
-   h_pt_fake->Draw("same");
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Fake_pt_loose_vs_tight.png");
-
-   f3.cd(); 
-  // h_eta_fake->Scale(100);
-  h_eta_fake->SetMinimum(0.);
-  h_eta_fake->Draw();
-   f4.cd();
-
-
-   h_eta_fake->SetMarkerColor(2);
-   h_eta_fake->Draw("same");
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Fake_eta_loose_vs_tight.png");
-
-   f3.cd(); 
-   //h_phi_fake->Scale(100);
-  h_phi_fake->Draw();
-   f4.cd();
-
-   h_phi_fake->SetMarkerColor(2);
-   h_phi_fake->Draw("same");
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Fake_phi_loose_vs_tight.png");
-  
-     f3.cd(); 
-    // h_D0_fake->Scale(100);
-  h_D0_fake->Draw();
-   f4.cd();
- 
-   h_D0_fake->SetMarkerColor(2);
-   h_D0_fake->Draw("same");
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Fake_d0_loose_vs_tight.png");
-  
-     f3.cd(); 
-  //    h_Z0_fake->Scale(100);
-  h_Z0_fake->Draw();
-   f4.cd();
-
-   h_Z0_fake->SetMarkerColor(2);
-   h_Z0_fake->Draw("same");
-  leg_hist->Draw();
-  c1->cd();
-  c1->SaveAs("Fake_z0_loose_vs_tight.png");
-
-
-}
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Vertexing.C b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Vertexing.C
deleted file mode 100644
index ca784592e8d8346b60a5bb2b5dcb5c22273d7c3a..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Vertexing.C
+++ /dev/null
@@ -1,470 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "vector"
-#include "stdio.h"
-#include "TFile.h"
-#include "TChain.h"
-#include "TH2F"
-#include "TH1F.h"
-#include "TCanvas.h"
-#include "TMath.h"
-#include "TLatex.h"
-
-
-#include "TTree.h"
-#include "TBrowser.h"
-#include "TH2.h"
-#include "TRandom.h"
-
-#ifdef __MAKECINT__
-#pragma link C++ class vector<float>+;
-#endif
-
-const Float_t MIN_MC_PROB = 0.5;
-
-const Float_t PT_CUT = 500.;
-
-// event selection
-const Int_t APPLY_PV_CUT = 1;
-const Int_t APPLY_TRIGGER_CUT  = 0;
-const Int_t APPLY_ONEGOODTRACK = 1;
-//const TRIGL1NAME = 'L1_MBTS_1';
-
-const Int_t APPLY_PV_CORR  = 0;
-const Int_t MAX_EVTS = -1;
-
-   std::vector<float> *reco=0;
-   std::vector<int> *recoh=0;
-   TBranch *br;
-   TBranch *brh;   
-   Float_t aa;
-   Float_t aaa;
-   
-   
-bool trkCutsEvtSelection(TTree *L, Int_t evt, Int_t r, Float_t pt, Float_t eta){
-
-
-    // pT > PT_CUT MeV
-    if (pt < PT_CUT) return 0;
-
-    // |eta| < 2.5
-    if (fabs(eta) > 2.5 ) return 0;
-//////////////////////////////////////////////
-    brh = L->GetBranch("trk_nPixHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-
-    // Pixel hits
-    if ( recoh->at(r) < 1 ) return 0;
-    // Pixel holes
-    //if evt.trk_nPixHoles[r] > 0 : return False
-
-    brh = L->GetBranch("trk_nSCTHits");
-    brh->SetAddress(&recoh);
-    brh->GetEntry(evt);
-
-    // SCT hits
-    if (recoh->at(r) < 6 ) return 0;
-
-
-
-    br = L->GetBranch("trk_d0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-
-    if (fabs( reco->at(r) ) > 1.5 ) return 0;
-
-    br = L->GetBranch("trk_z0_wrtPV");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aa = reco->at(r);
-
-    br = L->GetBranch("trk_theta");
-    br->SetAddress(&reco);
-    br->GetEntry(evt);
-	aaa = reco->at(r);
-
-    // z0 sin(theta) cut
-   if ( fabs( aa * TMath::Sin( aaa) ) > 1.5 ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-   std::vector<float> *recot=0;
-   std::vector<int> *recoht=0;
-   TBranch *brt;
-   TBranch *brht;
-   
-   Float_t aat;
-   Float_t aaat;
-   
-bool trkCuts(TTree *L, Int_t evt, Int_t r, Float_t pt, Float_t eta){
-
-
-    // pT > PT_CUT MeV
-    if (pt < PT_CUT) return 0;
-
-    // |eta| < 2.5
-    if (fabs(eta) > 2.5 ) return 0;
-//////////////////////////////////////////////
-    brht = L->GetBranch("trk_nPixHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-
-    // Pixel hits
-    if ( recoht->at(r) < 1 ) return 0;
-    // Pixel holes
-    //if evt.trk_nPixHoles[r] > 0 : return False
-
-    brht = L->GetBranch("trk_nSCTHits");
-    brht->SetAddress(&recoht);
-    brht->GetEntry(evt);
-
-    // SCT hits
-    if (recoht->at(r) < 6 ) return 0;
-
-    brt = L->GetBranch("trk_d0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-
-    if (fabs( recot->at(r) ) > 1.5 ) return 0;
-
-    brt = L->GetBranch("trk_z0_wrtPV");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-	aat = recot->at(r);
-
-    brt = L->GetBranch("trk_theta");
-    brt->SetAddress(&recot);
-    brt->GetEntry(evt);
-    aaat = recot->at(r);
-
-    // z0 sin(theta) cut
-    if ( fabs( aat * TMath::Sin( aaat) ) > 1.5 ) return 0;
-
-    // all cuts good ==> good track    
-    return 1;
-}
-
-void HIInDetValidation_Vertexing(){
-
-/////////////////ATLAS STYLE//////////////////////////////////////////
-TStyle *atlasStyle = new TStyle("ATLAS","Atlas style");
-
-  // use plain black on white colors
-  Int_t icol=0; // WHITE
-  atlasStyle->SetFrameBorderMode(icol);
-  atlasStyle->SetFrameFillColor(icol);
-  atlasStyle->SetCanvasBorderMode(icol);
-  atlasStyle->SetCanvasColor(icol);
-  atlasStyle->SetPadBorderMode(icol);
-  atlasStyle->SetPadColor(icol);
-  atlasStyle->SetStatColor(icol);
-  //atlasStyle->SetFillColor(icol); // don't use: white fill color for *all* objects
-
-  // set the paper & margin sizes
-  atlasStyle->SetPaperSize(20,26);
-
-  // set margin sizes
-  atlasStyle->SetPadTopMargin(0.10);
-  atlasStyle->SetPadRightMargin(0.05);
-  atlasStyle->SetPadBottomMargin(0.10);
-  atlasStyle->SetPadLeftMargin(0.10);
-
-  // set title offsets (for axis label)
-  atlasStyle->SetTitleXOffset(1.2);
-  atlasStyle->SetTitleYOffset(1.1);
-
-  // use large fonts
-  //Int_t font=72; // Helvetica italics
-  Int_t font=42; // Helvetica
-  Double_t tsize=0.04;
-  atlasStyle->SetTextFont(font);
-
-  atlasStyle->SetTextSize(tsize);
-  atlasStyle->SetLabelFont(font,"x");
-  atlasStyle->SetTitleFont(font,"x");
-  atlasStyle->SetLabelFont(font,"y");
-  atlasStyle->SetTitleFont(font,"y");
-  atlasStyle->SetLabelFont(font,"z");
-  atlasStyle->SetTitleFont(font,"z");
-  
-  atlasStyle->SetLabelSize(tsize,"x");
-  atlasStyle->SetTitleSize(tsize,"x");
-  atlasStyle->SetLabelSize(tsize,"y");
-  atlasStyle->SetTitleSize(tsize,"y");
-  atlasStyle->SetLabelSize(tsize,"z");
-  atlasStyle->SetTitleSize(tsize,"z");
-
-  // use bold lines and markers
-  atlasStyle->SetMarkerStyle(20);
-  atlasStyle->SetMarkerSize(0.9);
-  atlasStyle->SetMarkerColor(4);
-  atlasStyle->SetHistLineWidth(1.);
-  atlasStyle->SetLineStyleString(2,"[12 12]"); // postscript dashes
-
-  // get rid of X error bars 
-  //atlasStyle->SetErrorX(0.001);
-  // get rid of error bar caps
-  atlasStyle->SetEndErrorSize(0.);
-
-  // do not display any of the standard histogram decorations
-  atlasStyle->SetOptTitle();
-  atlasStyle->SetOptStat(111111);
-  //atlasStyle->SetOptStat(0);
-  //atlasStyle->SetOptFit(1111);
-  atlasStyle->SetOptFit(0);
-
- // put tick marks on top and RHS of plots
-  //atlasStyle->SetPadTickX(1);
- // atlasStyle->SetPadTickY(1);
- 
-atlasStyle->SetStatY(0.99);                
-// Set y-position (fraction of pad size)
-atlasStyle->SetStatX(0.99);                
-// Set x-position (fraction of pad size)
-atlasStyle->SetStatW(0.2);                
-// Set width of stat-box (fraction of pad size)
-atlasStyle->SetStatH(0.1);                
-// Set height of stat-box (fraction of pad size)
-atlasStyle->SetLabelOffset(0.008,"X");
-atlasStyle->SetLabelOffset(0.008,"Y");
-  
-  gROOT->SetStyle("ATLAS");
-  gROOT->ForceStyle();
-///////////////////////////////////////////////////////////////////////////////////////
-
-
-   TFile *file = TFile::Open("InDetTrackD3PD.root","READ");
-   
-   TTree *T = (TTree*)file->Get("InDetTrackTree");
-
-   histofile = TFile("Vertexing-Loose.root","recreate");
-
-
-//////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t binsEta = 30;
-Float_t minEta  = -2.5;
-Float_t maxEta  =  2.5;
-Int_t binsPt  = 30;
-Float_t minPt   = 0.;
-Float_t maxPt   = 10.0;
-
-
-TH1F *numbertrk             = new TH1F("number_of_trk_per_evt", "", 50, 0, 1200);
-
-
-TH1F *h_vx_n             = new TH1F("h_vx_n",              "", 10, 0, 10);
-
-TH1F *h_vx_x  	   = new TH1F("h_vx_x",               "", 50, -0.4, 0.4);
-TH1F *h_vx_y  	   = new TH1F("h_vx_y",               "", 50, -0.4, 0.4);
-TH1F *h_vx_z  	   = new TH1F("h_vx_z",               "", 50, -100, 100);
-
-TH1F *h_res_vx_x  	   = new TH1F("h_res_vx_x",               "", 50, -0.4, 0.4);
-TH1F *h_res_vx_y  	   = new TH1F("h_res_vx_y",               "", 50, -0.4, 0.4);
-TH1F *h_res_vx_z  	   = new TH1F("h_res_vx_z",               "", 50, -0.4, 0.4);
-
-TH1F *h_vx_dummy             = new TH1F("h_vx_dummy",              "", 10, 0, 10);
-
- TH1F *h_trk_n_all      = new TH1F("h_trk_n_all",              "", 20, 0, 20);
- TH1F *h_trk_n_vx      = new TH1F("h_trk_n_vx",              "", 20, 0, 20);
- TH1F *h_trk_n_eff      = new TH1F("h_trk_n_eff",              "", 20, 0, 20);
-
-///////////////////////////////////////////////////////////////////////////////////////////
-
-Int_t counter = 0;
-Int_t evtAfterTrigger = 0;
-Int_t evtAfterPV      = 0;
-Int_t evtAfterGoodTrk = 0;
-
-		Int_t m_trk_n;
-		T->SetBranchAddress("trk_n",&m_trk_n);
-		
-		std::vector<float> *m_trk_eta=0;
-		T->SetBranchAddress("trk_eta",&m_trk_eta);
-
-		std::vector<float> *m_trk_pt=0;
-		T->SetBranchAddress("trk_pt",&m_trk_pt);
-
-		std::vector<int> *m_vx_type=0;
-		T->SetBranchAddress("vx_type",&m_vx_type);
-		
-		std::vector<int> *m_vx_nTracks=0;
-		T->SetBranchAddress("vx_nTracks",&m_vx_nTracks);
-		
-		std::vector<float> *m_vx_x=0;
-		T->SetBranchAddress("vx_x",&m_vx_x);		
-		
-		std::vector<float> *m_vx_y=0;
-		T->SetBranchAddress("vx_y",&m_vx_y);
-		
-		std::vector<float> *m_vx_z=0;
-		T->SetBranchAddress("vx_z",&m_vx_z);
-		
-		Int_t m_vx_n;
-		T->SetBranchAddress("vx_n",&m_vx_n);		
-		
-		
-		
-		Int_t m_mc_n;
-		T->SetBranchAddress("mc_n",&m_mc_n);
-
-		std::vector<float> *m_mcVx_x=0;
-		T->SetBranchAddress( "mcVx_x", &m_mcVx_x );	
-		
-		std::vector<float> *m_mcVx_y=0;
-		T->SetBranchAddress( "mcVx_y", &m_mcVx_y );	
-		
-		std::vector<float> *m_mcVx_z=0;
-		T->SetBranchAddress( "mcVx_z", &m_mcVx_z );	
-			
-
-                Int_t nentries = (Int_t)(T->GetEntries());
-
-	        bool ok = 0;
-		
-/////////////////  MAIN LOOP  ///////////////////////////////////////////
-   for (Int_t i=0;i<nentries;i++) {
-   
-   	T->GetEntry(i);
-   
-	//printf("Processing event: %i\n",counter);
-	counter += 1;
-	
-		numbertrk->Fill(m_trk_n);
-		h_trk_n_all->Fill(m_trk_n);
-
-	if ( m_vx_n == 1){
-	  printf("Tracks: %i\n",m_trk_n);
-	  h_vx_dummy->Fill( m_trk_n, 1.);
-	}
-	else{
-	  h_trk_n_vx->Fill( m_trk_n, 1.);
-	}
-		
-    	h_vx_n->Fill( m_vx_n, 1.);
-	
-	// maximum events
-	if (counter > MAX_EVTS && MAX_EVTS != -1) break;
-	////////// EVENT SLECTION :
-	/////////////////////////
-	// 1) L1 Trigger Fired
-	if (APPLY_TRIGGER_CUT){
-        	ok = 0;
-        	//  for (name in ch.ctp_decisionItems){
-        	if (name == TRIGL1NAME){
-                ok = 1;
-                break;
-                }
-        	//if not ok continue;
-       		// }     		
-       	}	
-    	evtAfterTrigger += 1;
-					
-	if ( APPLY_PV_CUT && ( (*m_vx_type)[0] == 0 || (*m_vx_nTracks)[0] < 3)) continue;
-		
-    	evtAfterPV += 1;
-    	
-	// 3) At least one good track in event
-	if (APPLY_ONEGOODTRACK){
-		ok = 0;
-		
-		for ( Int_t r=0; r< m_trk_n; r++ ){
-			if ( trkCutsEvtSelection( T, i, r, (*m_trk_pt)[r], (*m_trk_eta)[r]) ){
-			ok = 1;
-			break;
-			}
-		////////////////////////////////////////////////////////////////
-		if (!ok) continue;
-		///////////////////////////////////////////////////////
-		}
-		evtAfterGoodTrk += 1;
-	}
-	//DONE with Event Selection
-	
-	//Reweight MC
-    	Float_t ev_weight = 1.0;
-    	 
-    	if (APPLY_PV_CORR){
-    	ev_weight = hCorrectPV.GetBinContent( hCorrectPV.FindBin( (*m_vx_z)[0]) );
-    	}
-
-	if (m_vx_n != 1){
-	  h_vx_x->Fill( (*m_vx_x)[0],ev_weight);
-	  h_vx_y->Fill( (*m_vx_y)[0],ev_weight);
-	  h_vx_z->Fill( (*m_vx_z)[0],ev_weight);
-	  
-	  h_res_vx_x->Fill( (*m_mcVx_x)[0] - (*m_vx_x)[0],ev_weight);
-	  h_res_vx_y->Fill( (*m_mcVx_y)[0] - (*m_vx_y)[0],ev_weight);
-	  h_res_vx_z->Fill( (*m_mcVx_z)[0] - (*m_vx_z)[0],ev_weight);
-	}
-   
- }
-
-printf ("events : %i (processed) %i (after trigger) %i (after PV cut) %i (after good trk)\n" ,counter, evtAfterTrigger, evtAfterPV, evtAfterGoodTrk);
-
-
-TCanvas* c1=new TCanvas();
-c1->SetWindowSize(800,600);
-c1->Resize();
-
-h_trk_n_all->Sumw2();
-h_trk_n_vx->Sumw2();
-h_trk_n_eff->Divide(h_trk_n_vx,h_trk_n_all,1.0,1.0,"b");
-h_trk_n_eff->Scale(100);
-h_trk_n_eff->SetMinimum(90);
- h_trk_n_eff->SetMaximum(105);
- h_trk_n_eff->GetXaxis()->SetTitle("n^{sel}_{trk}");
- h_trk_n_eff->GetYaxis()->SetTitle("Vertex efficiency (%)");
-
-
-h_trk_n_eff->Draw("");
-c1->cd();
-c1->SaveAs("Vertex_eff.png");
-
-h_vx_x->Draw("h");
-c1->cd();
-c1->SaveAs("Vertex_vx_x.png");
-
-c1->Update();
-h_vx_y->Draw("h");
-c1->cd();
-c1->SaveAs("Vertex_vx_y.png");
-
-c1->Update();
-h_vx_z->Draw("h");
-c1->cd();
-c1->SaveAs("Vertex_vx_z.png");
-
-c1->Update();
-h_vx_n->Draw("h");
-c1->cd();
-c1->SaveAs("Vertex_vx_n.png");
-
-c1->Update();
-h_res_vx_x->Draw("h");
-c1->cd();
-c1->SaveAs("Vertex_res_vx_x.png");
-
-c1->Update();
-h_res_vx_y->Draw("h");
-c1->cd();
-c1->SaveAs("Vertex_res_vx_y.png");
-
-c1->Update();
-h_res_vx_z->Draw("h");
-c1->cd();
-c1->SaveAs("Vertex_res_vx_z.png");
-
-c1->Update();
-h_vx_dummy->Draw("h");
-c1->cd();
-c1->SaveAs("Vertex_trk_dummy.png");
-
-histofile.Write();
-histofile.Close();
-}
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Vertexing_plot.C b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Vertexing_plot.C
deleted file mode 100644
index 373e4801d8fcad5882cab38ce422f329bd833361..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/HIInDetValidation_Vertexing_plot.C
+++ /dev/null
@@ -1,284 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "vector"
-#include "stdio.h"
-#include "TFile.h"
-#include "TChain.h"
-#include "TH2F"
-#include "TH1F.h"
-#include "TCanvas.h"
-#include "TMath.h"
-#include "TLatex.h"
-
-
-#include "TTree.h"
-#include "TBrowser.h"
-#include "TH2.h"
-#include "TRandom.h"
-
-#ifdef __MAKECINT__
-#pragma link C++ class vector<float>+;
-#endif
-
-
-   
-   
-void HIInDetValidation_Vertexing_plot(){
-
-/////////////////ATLAS STYLE//////////////////////////////////////////
-TStyle *atlasStyle = new TStyle("ATLAS","Atlas style");
-
-  // use plain black on white colors
-  Int_t icol=0; // WHITE
-  atlasStyle->SetFrameBorderMode(icol);
-  atlasStyle->SetFrameFillColor(icol);
-  atlasStyle->SetCanvasBorderMode(icol);
-  atlasStyle->SetCanvasColor(icol);
-  atlasStyle->SetPadBorderMode(icol);
-  atlasStyle->SetPadColor(icol);
-  atlasStyle->SetStatColor(icol);
-  //atlasStyle->SetFillColor(icol); // don't use: white fill color for *all* objects
-
-  // set the paper & margin sizes
-  atlasStyle->SetPaperSize(20,26);
-
-  // set margin sizes
-  atlasStyle->SetPadTopMargin(0.);
-  atlasStyle->SetPadRightMargin(0.0005);
-  atlasStyle->SetPadBottomMargin(0.12);
-  atlasStyle->SetPadLeftMargin(0.13);
-  
-
-
-  // set title offsets (for axis label)
-  atlasStyle->SetTitleXOffset(0.75);
- // atlasStyle->SetTitleYOffset(1.1);
-
-  // use large fonts
-  //Int_t font=72; // Helvetica italics
-  Int_t font=42; // Helvetica
-  Double_t tsize=0.04;
-  atlasStyle->SetTextFont(font);
-  atlasStyle->SetStatFontSize(0.033);
-
-
-  atlasStyle->SetTextSize(tsize);
-  atlasStyle->SetLabelFont(font,"x");
-  atlasStyle->SetTitleFont(font,"x");
-  atlasStyle->SetLabelFont(font,"y");
-  atlasStyle->SetTitleFont(font,"y");
-  atlasStyle->SetLabelFont(font,"z");
-  atlasStyle->SetTitleFont(font,"z");
-  
-  atlasStyle->SetLabelSize(tsize,"x");
-  atlasStyle->SetTitleSize(tsize,"x");
-  atlasStyle->SetLabelSize(tsize,"y");
-  atlasStyle->SetTitleSize(tsize,"y");
-  atlasStyle->SetLabelSize(tsize,"z");
-  atlasStyle->SetTitleSize(tsize,"z");
-
-  // use bold lines and markers
-  atlasStyle->SetMarkerStyle(21);
- // atlasStyle->SetMarkerSize(0.9);
- // atlasStyle->SetMarkerColor(4);
-  atlasStyle->SetHistLineWidth(1.);
-  atlasStyle->SetLineStyleString(2,"[12 12]"); // postscript dashes
-
-  // get rid of X error bars 
-  //atlasStyle->SetErrorX(0.001);
-  // get rid of error bar caps
-  atlasStyle->SetEndErrorSize(0.);
-
-  // do not display any of the standard histogram decorations
-  atlasStyle->SetOptTitle();
-  atlasStyle->SetOptStat(0);
-  //atlasStyle->SetOptStat(0);
-  //atlasStyle->SetOptFit(1111);
-  atlasStyle->SetOptFit(011);
-
- // put tick marks on top and RHS of plots
-  //atlasStyle->SetPadTickX(1);
- // atlasStyle->SetPadTickY(1);
- 
- atlasStyle->SetStatY(0.99);                
-// Set y-position (fraction of pad size)
- atlasStyle->SetStatX(0.99);                
-// Set x-position (fraction of pad size)
- atlasStyle->SetStatW(0.25);                
-// Set width of stat-box (fraction of pad size)
- atlasStyle->SetStatH(0.15);                
- // Set height of stat-box (fraction of pad size)
- atlasStyle->SetLabelOffset(0.008,"X");
- atlasStyle->SetLabelOffset(0.008,"Y");
-  
-  
- atlasStyle->SetOptStat(0);
- atlasStyle->SetOptFit(0011);
-
-  
-   atlasStyle->SetFrameBorderMode(0);
- gROOT->SetStyle("ATLAS");
- gROOT->ForceStyle();
-///////////////////////////////////////////////////////////////////////////////////////
-
-
-
-
-
-/*TCanvas* c1=new TCanvas();
-c1->SetWindowSize(700,1000);
-c1->Resize();*/
-
-   TCanvas *c1 = new TCanvas("c1", "Tracking Performance",10,32,500,667);
-   gStyle->SetOptStat(0);
-   c1->Range(0,0,1,1);
-   c1->SetFillColor(10);
-   c1->SetBorderMode(0);
-   c1->SetBorderSize(2);
-   c1->SetFrameFillColor(0);
-   c1->SetFrameBorderMode(0);
-
-
-  TFile f1("Vertexing-SetupA.root");
-
- 
- c1->cd();
- c1->Clear();c1->Divide(2,3);
-
-
- c1->cd(1);
-
-
- h_res_vx_x->Fit("gaus", "", "", -0.04, 0.04);
-  h_res_vx_x->Draw("h");
- h_res_vx_x->GetXaxis()->CenterTitle(true);
- h_res_vx_x->GetYaxis()->CenterTitle(true);
- h_res_vx_x->GetYaxis()->SetTitleFont(62); 
- h_res_vx_x->GetXaxis()->SetTitleFont(62); 
- h_res_vx_x->GetYaxis()->SetTitleSize(0.065); 
- h_res_vx_x->GetXaxis()->SetTitleSize(0.065); 
- h_res_vx_x->GetYaxis()->SetTitleOffset(0.7); 
- h_res_vx_x->GetXaxis()->SetTitle("v_{x}^{reco}-v_{x}^{gen} [mm]");
- h_res_vx_x->GetYaxis()->SetTitle("Events");
- 
-    tex = new TLatex(0.8,0.73,"   (c)");
-tex->SetNDC();
-   tex->SetTextSize(0.05401814);
-   tex->SetLineWidth(2);
-   tex->Draw();
- c1_1->Modified();
-
- c1->cd(2);
- h_res_vx_y->Fit("gaus", "", "", -0.04, 0.04);
-  h_res_vx_y->Draw("h");
- h_res_vx_y->GetXaxis()->CenterTitle(true);
- h_res_vx_y->GetYaxis()->CenterTitle(true);
- h_res_vx_y->GetYaxis()->SetTitleFont(62); 
- h_res_vx_y->GetXaxis()->SetTitleFont(62); 
- h_res_vx_y->GetYaxis()->SetTitleSize(0.065); 
- h_res_vx_y->GetXaxis()->SetTitleSize(0.065); 
- h_res_vx_y->GetYaxis()->SetTitleOffset(0.7); 
- h_res_vx_y->GetXaxis()->SetTitle("v_{y}^{reco}-v_{y}^{gen} [mm]");
- h_res_vx_y->GetYaxis()->SetTitle("Events");
-   tex = new TLatex(0.8,0.73,"   (d)");
-tex->SetNDC();
-   tex->SetTextSize(0.05401814);
-   tex->SetLineWidth(2);
-   tex->Draw();
- c1_2->Modified();
-
-    c1->cd(3);
-
- h_vx_z->Draw("h");
- h_vx_z->GetXaxis()->CenterTitle(true);
- h_vx_z->GetYaxis()->CenterTitle(true);
- h_vx_z->GetYaxis()->SetTitleFont(62); 
- h_vx_z->GetXaxis()->SetTitleFont(62); 
- h_vx_z->GetYaxis()->SetTitleSize(0.065); 
- h_vx_z->GetXaxis()->SetTitleSize(0.065); 
- h_vx_z->GetYaxis()->SetTitleOffset(0.7); 
- h_vx_z->GetXaxis()->SetTitle("v_{z}^{reco} [mm]");
- h_vx_z->GetYaxis()->SetTitle("Events");
-    tex = new TLatex(0.8,0.73,"   (b)");
-tex->SetNDC();
-   tex->SetTextSize(0.05401814);
-   tex->SetLineWidth(2);
-   tex->Draw();
- c1_3->Modified();
-
-  
- c1->cd(4);
- //c1->SetLiny();
- h_res_vx_z->Draw("h");
- h_res_vx_z->Fit("gaus", "", "", -0.1, 0.1);
- h_res_vx_z->GetXaxis()->CenterTitle(true);
- h_res_vx_z->GetYaxis()->CenterTitle(true);
- h_res_vx_z->GetYaxis()->SetTitleFont(62); 
- h_res_vx_z->GetXaxis()->SetTitleFont(62); 
- h_res_vx_z->GetYaxis()->SetTitleSize(0.065); 
- h_res_vx_z->GetXaxis()->SetTitleSize(0.065); 
- h_res_vx_z->GetYaxis()->SetTitleOffset(0.7); 
- h_res_vx_z->GetXaxis()->SetTitle("v_{z}^{reco}-v_{z}^{gen} [mm]");
- h_res_vx_z->GetYaxis()->SetTitle("Events");
- 
-    tex = new TLatex(0.8,0.73,"   (e)");
-tex->SetNDC();
-   tex->SetTextSize(0.05401814);
-   tex->SetLineWidth(2);
-   tex->Draw();
- c1_4->Modified();
- 
- c1->cd(5);
-
- h_vx_corr->SetMarkerSize(0.15);
- h_vx_corr->Draw("h");
- h_vx_corr->GetXaxis()->CenterTitle(true);
- h_vx_corr->GetYaxis()->CenterTitle(true);
- h_vx_corr->GetYaxis()->SetTitleFont(62); 
- h_vx_corr->GetXaxis()->SetTitleFont(62); 
- h_vx_corr->GetYaxis()->SetTitleSize(0.065); 
- h_vx_corr->GetXaxis()->SetTitleSize(0.065); 
- h_vx_corr->GetYaxis()->SetTitleOffset(1.); 
- h_vx_corr->GetXaxis()->SetTitle("Tracks in event");
- h_vx_corr->GetYaxis()->SetTitle("Tracks in vertex");
- 
-   tex = new TLatex(0.8,0.73,"   (a)");
-tex->SetNDC();
-   tex->SetTextSize(0.05401814);
-   tex->SetLineWidth(2);
-   tex->Draw();
- c1_5->Modified();
- 
- c1->cd(6);
-
- h_vx_res_nTracks->SetMarkerSize(0.15);
- h_vx_res_nTracks->Draw("h");
- h_vx_res_nTracks->GetYaxis()->SetTitleFont(62); 
- h_vx_res_nTracks->GetXaxis()->SetTitleFont(62); 
- h_vx_res_nTracks->GetYaxis()->SetTitleSize(0.065); 
- h_vx_res_nTracks->GetXaxis()->SetTitleSize(0.065); 
- h_vx_res_nTracks->GetYaxis()->SetTitleOffset(1.); 
- h_vx_res_nTracks->GetXaxis()->CenterTitle(true);
- h_vx_res_nTracks->GetYaxis()->CenterTitle(true);
- h_vx_res_nTracks->GetXaxis()->SetTitle("Tracks in vertex");
- h_vx_res_nTracks->GetYaxis()->SetTitle("v_{x}^{reco}-v_{x}^{gen} [mm]");
-
- 
-   tex = new TLatex(0.8,0.73,"   (f)");
-tex->SetNDC();
-   tex->SetTextSize(0.05401814);
-   tex->SetLineWidth(2);
-   tex->Draw();
- c1_6->Modified();
-
-
-c1_4->SetLogy();
-c1_2->SetLogy();
-c1_1->SetLogy();
-
-c1->SaveAs("Vertex_plot_C.pdf");
-
-
-}
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/png_file.png b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/png_file.png
deleted file mode 100644
index 794a10faa67ac828c3970f8f039845b02ee6e49f..0000000000000000000000000000000000000000
Binary files a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/macros/png_file.png and /dev/null differ
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/share/ARTT_Plots.html b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/share/ARTT_Plots.html
deleted file mode 100644
index 36d08af8f3f7c72675aa3ddef686aeef56a56235..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/share/ARTT_Plots.html
+++ /dev/null
@@ -1,258 +0,0 @@
-<html><head>
-<Title>Plots</Title></head>
-<body>
-
-<center><a name="top"><p><h1 style="font-family:verdana">HIInDetValidation Plots</h1></p></a>
-<br />
-
-
-<a name="eff-loose-vs-eta"><p style="font-family:arial;color:red;font-size:20px;">EFFICIENCY: LOOSE VS TIGHT</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center>eta</center></TD>
-    <TD><center>pt<center></TD>
-    <TD><center>phi<center></TD>
-    <TD><center>d0<center></TD>
-    <TD><center>z0<center></TD>
-  </TR>
-  <TR>
-    <TD><center>Eff</center></TD>
-    	<TD><center><a href="Eff_eta_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-    	<TD><center><a href="Eff_pt_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-    <TD><center><a href="Eff_phi_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Eff_d0_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Eff_z0_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-  </TR>
-</TABLE>
-
<!-- 
-
-<a name="eff-loose"><p style="font-family:arial;color:red;font-size:20px;">Track efficiencies (loose cuts) vs. param</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center>eta</center></TD>
-    <TD><center>pt<center></TD>
-    <TD><center>phi<center></TD>
-    <TD><center>d0<center></TD>
-    <TD><center>z0<center></TD>
-  </TR>
-  <TR>
-    <TD><center>Eff</center></TD>
-    	<TD><center><a href="Eff_eta_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-    	<TD><center><a href="Eff_pt_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-    <TD><center><a href="Eff_phi_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Eff_d0_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Eff_z0_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-  </TR>
-</TABLE>
-
<br />
-<a href="#top">top</a>
-<br/>
-
-<a name="eff-tight"><p style="font-family:arial;color:red;font-size:20px;">Track efficiencies (tight cuts) vs. param</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center>eta</center></TD>
-    <TD><center>pt<center></TD>
-    <TD><center>phi<center></TD>
-    <TD><center>d0<center></TD>
-    <TD><center>z0<center></TD>
-  </TR>
-  <TR>
-    <TD><center>Eff</center></TD>
-    	<TD><center><a href="Eff_eta_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-    	<TD><center><a href="Eff_pt_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-    <TD><center><a href="Eff_phi_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Eff_d0_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Eff_z0_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-  </TR>
-</TABLE>
--->
-<br />
-<a href="#top">top</a>
-<br />
-
-
-<a name="fake-loose-vs-eta"><p style="font-family:arial;color:red;font-size:20px;">FAKES: LOOSE VS TIGHT</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center>eta</center></TD>
-    <TD><center>pt<center></TD>
-    <TD><center>phi<center></TD>
-    <TD><center>d0<center></TD>
-    <TD><center>z0<center></TD>
-  </TR>
-  <TR>
-    <TD><center>Eff</center></TD>
-    	<TD><center><a href="Fake_eta_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-    	<TD><center><a href="Fake_pt_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-    <TD><center><a href="Fake_phi_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Fake_d0_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Fake_z0_loose_vs_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-  </TR>
-</TABLE>
-
-<br />
-<a href="#top">top</a>
-<br />
-<!-- 
-<a name="fakes-loose"><p style="font-family:arial;color:red;font-size:20px;">Fake rates (loose cuts) vs. param</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center>eta</center></TD>
-    <TD><center>pt<center></TD>
-    <TD><center>phi<center></TD>
-    <TD><center>d0<center></TD>
-    <TD><center>z0<center></TD>
-  </TR>
-  <TR>
-    <TD><center>Fake Ratio</center></TD>
-    	<TD><center><a href="Fake_eta_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-    	<TD><center><a href="Fake_pt_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-    <TD><center><a href="Fake_phi_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Fake_d0_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Fake_z0_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-  </TR>
-</TABLE>
-
-
-
-<br />
-<a href="#top">top</a>
-<br />
-
-<a name="fakes-tight"><p style="font-family:arial;color:red;font-size:20px;">Fake rates (tight cuts) vs. param</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center>eta</center></TD>
-    <TD><center>pt<center></TD>
-    <TD><center>phi<center></TD>
-    <TD><center>d0<center></TD>
-    <TD><center>z0<center></TD>
-  </TR>
-  <TR>
-    <TD><center>Fake Ratio</center></TD>
-    	<TD><center><a href="Fake_eta_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-    	<TD><center><a href="Fake_pt_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-    <TD><center><a href="Fake_phi_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Fake_d0_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Fake_z0_tight.png"><img src="png_file.png" width=100></a><br></center></TD>
-  </TR>
-</TABLE>
-
-<br />
-<a href="#top">top</a>
-<br />
--->
-
-<a name="eff-tracks"><p style="font-family:arial;color:red;font-size:20px;">Efficiency (loose cuts) vs. # of tracks</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center># of tracks</center></TD>
-
-  </TR>
-  <TR>
-    <TD><center>Eff</center></TD>
-    	<TD><center><a href="Eff_number.png"><img src="png_file.png" width=100></a><br></center></TD>
-
-  </TR>
-  <TR>
-    <TD><center>Fake</center></TD>
-    	<TD><center><a href="Fake_number.png"><img src="png_file.png" width=100></a><br></center></TD>
-  </TR>
-</TABLE>
-
-<br />
-<a href="#top">top</a>
-<br />
-
-<a name="res-loose"><p style="font-family:arial;color:red;font-size:20px;">Track Resolution vs. param (Loose)</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center>eta</center></TD>
-    <TD><center>pt<center></TD>
-    <TD><center>phi<center></TD>
-    <TD><center>d0<center></TD>
-    <TD><center>z0<center></TD>
-  </TR>
-  <TR>
-    <TD><center>Res</center></TD>
-    	<TD><center><a href="Res_eta_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-    	<TD><center><a href="Res_pt_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-    <TD><center><a href="Res_phi_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Res_d0_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Res_z0_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-  </TR>
-</TABLE>
-
-<br />
-<a href="#top">top</a>
-<br />
-
-<a name="pull-loose"><p style="font-family:arial;color:red;font-size:20px;">Track Resolution (Pulls) vs. param (Loose)</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center>eta</center></TD>
-    <TD><center>q/p<center></TD>
-    <TD><center>phi<center></TD>
-    <TD><center>d0<center></TD>
-    <TD><center>z0<center></TD>
-  </TR>
-  <TR>
-    <TD><center>Res (Pull)</center></TD>
-    	<TD><center><a href="Pull_eta_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-    	<TD><center><a href="Pull_qoverp_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-    <TD><center><a href="Pull_phi_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Pull_d0_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-   <TD><center><a href="Pull_z0_loose.png"><img src="png_file.png" width=100></a><br></center></TD>
-  </TR>
-</TABLE>
-
-<br />
-<a href="#top">top</a>
-<br />
-
-<a name="vert"><p style="font-family:arial;color:red;font-size:20px;">Vertex Resolution</p></a>
-
-<TABLE BORDER=4 CELLSPACING=2 CELLPADDING=2>
-  <TR>
-    <TD><center>param -></center></TD>
-    <TD><center>x</center></TD>
-    <TD><center>y<center></TD>
-    <TD><center>z<center></TD>
-
-
-  </TR>
-  <TR>
-    <TD><center>Entries</center></TD>
-    	<TD><center><a href="Vertex_res_vx_x.png"><img src="png_file.png" width=100></a><br></center></TD>
-    	<TD><center><a href="Vertex_res_vx_y.png"><img src="png_file.png" width=100></a><br></center></TD>
-    <TD><center><a href="Vertex_res_vx_z.png"><img src="png_file.png" width=100></a><br></center></TD>

-  </TR>
-</TABLE>
-
-<br />
-<br />
-<a name="vt"><p style="font-family:arial;color:red;font-size:20px;"># of tracks in case of vx_n = 1</p></a>
-<center><a href="Vertex_trk_dummy.png"><img src="png_file.png" width=100></a><br></center>
-
-
-</center>
-</body></html>
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/share/HIInDetTrkD3PD_jobOptions.py b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/share/HIInDetTrkD3PD_jobOptions.py
deleted file mode 100644
index 60300f79f4e478209c29f9a8ba411697ef43f4e1..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/share/HIInDetTrkD3PD_jobOptions.py
+++ /dev/null
@@ -1,12 +0,0 @@
-#---------------------
-from InDetRecExample.InDetJobProperties import InDetFlags
-
-from TrackD3PDMaker.TrackD3PDMakerFlags import TrackD3PDFlags
-TrackD3PDFlags.trackParametersAtGlobalPerigeeLevelOfDetails.set_Value_and_Lock(2)
-TrackD3PDFlags.trackParametersAtBeamSpotLevelOfDetails.set_Value_and_Lock(2)
-
-TrackD3PDFlags.storeDiagonalCovarianceAsErrors.set_Value_and_Lock(True)
-
-InDetFlags.doTrkD3PD = True
-InDetFlags.doVtxD3PD = True
-#---------------------
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/share/HIInDetValidation_JobOptions.py b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/share/HIInDetValidation_JobOptions.py
deleted file mode 100755
index e63693bb876d78529fd0d21e0df142713c6826f9..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/share/HIInDetValidation_JobOptions.py
+++ /dev/null
@@ -1,240 +0,0 @@
-#--------------------------------------------------------------
-# Control
-#--------------------------------------------------------------
-
-# --- Set output level threshold (2=DEBUG, 3=INFO, 4=WARNING, 5=ERROR, 6=FATAL )
-OutputLevel     = INFO
-# --- produce an atlantis data file
-doJiveXML       = False
-# --- run the Virtual Point 1 event visualisation
-doVP1           = False
-# --- controls what is written out. ESD includes AOD, so it's normally enough
-doWriteESD      = True
-doWriteAOD      = False
-#
-#readESD = True
-# --- do auditors ?
-doAuditors      = True
-
-import os
-if os.environ['CMTCONFIG'].endswith('-dbg'):
-  # --- do EDM monitor (debug mode only)
-  doEdmMonitor    = True 
-  # --- write out a short message upon entering or leaving each algorithm
-  doNameAuditor   = True
-else:
-  doEdmMonitor    = False
-  doNameAuditor   = False
-
-# --- enable rec.doHeavyIon
-from RecExConfig.RecFlags import rec
-rec.doHeavyIon=True
-#rec.Commissioning=False
-
-#--------------------------------------------------------------
-# load Global Flags and set defaults (import the new jobProperty globalflags)
-#--------------------------------------------------------------
-import AthenaCommon.SystemOfUnits as Units
-from AthenaCommon.GlobalFlags import globalflags
-# --- default is atlas geometry
-globalflags.DetGeo = 'atlas'
-# --- set defaults
-globalflags.DataSource = 'geant4'
-# --- BS default input uses this
-if 'doReadBS' in dir() and doReadBS:
-  globalflags.InputFormat   = 'bytestream'
-  globalflags.ConditionsTag = 'OFLCOND-FDR-02-01-00'
-else:
-  globalflags.InputFormat = 'pool'
-
-#--------------------------------------------------------------
-# detector description version: both RDO and BS default use this
-#--------------------------------------------------------------
-# --- set geometry version
-if not ('DetDescrVersion' in dir()):
-  DetDescrVersion = "ATLAS-GEO-10-00-00"
-
-globalflags.DetDescrVersion = DetDescrVersion
-  
-# --- printout
-globalflags.print_JobProperties()
-
-if len(globalflags.ConditionsTag())!=0:
-   from IOVDbSvc.CondDB import conddb
-   conddb.setGlobalTag(globalflags.ConditionsTag()) 
-    
-from AthenaCommon.BeamFlags import jobproperties
-# --- in Tier0 reco these flags are set from outside
-jobproperties.Beam.numberOfCollisions = 10.0 # arbitrary higher number for 7+ TeV, for 900 GeV it is 2.
-jobproperties.Beam.energy             = 7.*Units.TeV
-jobproperties.Beam.beamType           = 'collisions'
-if 'doReadBS' in dir() and doReadBS:
-  jobproperties.Beam.numberOfCollisions = 6.9
-  jobproperties.Beam.bunchSpacing       = 75
-
-ServiceMgr += Service('BeamCondSvc')
-beamCondSvc = ServiceMgr.BeamCondSvc
-beamCondSvc.useDB = False
-beamCondSvc.posX = 0.0 #0.0
-beamCondSvc.posY = 0.0025 #0.004
-beamCondSvc.posZ = 0.0
-beamCondSvc.sigmaX = 0.013 #0.012
-beamCondSvc.sigmaY = 0.013 #0.012
-beamCondSvc.sigmaZ = 55.0 #55.0
-
-#--------------------------------------------------------------
-# Set Detector setup
-#--------------------------------------------------------------
-
-from RecExConfig.RecFlags import rec
-rec.Commissioning=False
-
-from AthenaCommon.DetFlags import DetFlags 
-# --- switch on InnerDetector
-DetFlags.ID_setOn()
-#DetFlags.makeRIO.pixel_setOff()
-#DetFlags.makeRIO.SCT_setOff()
-#DetFlags.makeRIO.TRT_setOff()
-
-# --- and switch off all the rest
-DetFlags.Calo_setOff()
-DetFlags.Muon_setOff()
-# ---- switch parts of ID off/on as follows (always use both lines)
-#DetFlags.pixel_setOff()
-#DetFlags.detdescr.pixel_setOn()
-#DetFlags.SCT_setOff()
-#DetFlags.detdescr.SCT_setOn()
-DetFlags.TRT_setOff()
-DetFlags.detdescr.TRT_setOn()
-# --- printout
-DetFlags.Print()
-
-#--------------------------------------------------------------
-# Load InDet configuration
-#--------------------------------------------------------------
-
-# --- setup InDetJobProperties
-from InDetRecExample.InDetJobProperties import InDetFlags
-InDetFlags.doTruth       = (globalflags.DataSource == 'geant4' and globalflags.InputFormat() == 'pool')
-
-# --- uncomment to change the default of one of the following options:
-#InDetFlags.doHeavyIon = True
-#InDetFlags.doNewTracking  = False#####################################
-#InDetFlags.doLowPt        = True
-#InDetFlags.doBeamGas      = True
-#InDetFlags.doBeamHalo     = True
-#InDetFlags.doxKalman      = True
-#InDetFlags.doiPatRec      = False
-#InDetFlags.doBackTracking = False
-#InDetFlags.doTRTStandalone = False
-#InDetFlags.doSingleSpBackTracking = True
-#InDetFlags.doV0Finder         = False
-#InDetFlags.doConversions      = False
-#InDetFlags.doStatistics       = False
-#InDetFlags.preProcessing      = False
-#InDetFlags.doPRDFormation        = False
-#InDetFlags.doSpacePointFormation = False
-#InDetFlags.doVertexFinding    = True
-#InDetFlags.doParticleCreation = True
-#InDetFlags.primaryVertexSetup = 'DefaultFastFinding'
-#InDetFlags.primaryVertexCutSetup = "StartUp"
-#InDetFlags.useBeamConstraint = True ###
-#InDetFlags.doSingleCollisionVertexReco=True
-#InDetFlags.useZvertexTool     = True # with False I don't reconstruct tracks at all, but ME suggested turning off
-
-
-# --- Turn off track slimming
-InDetFlags.doSlimming = False
-
-# --- possibility to run tracking on subdetectors separately (and independent from each other)
-InDetFlags.doTrackSegmentsPixel = False
-#InDetFlags.doTrackSegmentsSCT   = False
-#InDetFlags.doTrackSegmentsTRT   = True
-
-# --- possibility to change the trackfitter
-#InDetFlags.trackFitterType = 'KalmanFitter'
-
-# --- activate monitorings
-InDetFlags.doMonitoringGlobal    = False
-InDetFlags.doMonitoringPixel     = False
-InDetFlags.doMonitoringSCT       = False
-InDetFlags.doMonitoringTRT       = False
-InDetFlags.doMonitoringAlignment = False
-
-# --- activate (memory/cpu) monitoring
-InDetFlags.doPerfMon = True
-
-# --- activate creation of standard plots
-#InDetFlags.doPhysValMon  = True
-
-# --- produce various ntuples (all in one root file)
-#InDetFlags.doTrkNtuple      = True
-#InDetFlags.doPixelTrkNtuple = True
-#InDetFlags.doSctTrkNtuple   = True
-#InDetFlags.doTrtTrkNtuple   = True
-#InDetFlags.doSctClusterNtuple   = True
-#InDetFlags.doVtxNtuple      = True
-#InDetFlags.doConvVtxNtuple  = True
-#InDetFlags.doV0VtxNtuple    = True
-
-# --- produce various ntuples (all in one root file)
-#InDetFlags.doTrkD3PD = True
-#InDetFlags.doPixelTrkD3PD = False
-#InDetFlags.doSctTrkD3PD = False
-#InDetFlags.doTrtTrkD3PD = False
-#InDetFlags.doVtxD3PD = True
-#InDetFlags.doConvVtxD3PD = True  # NOT implemented yet
-#InDetFlags.doV0VtxD3PD = True    # NOT implemented yet
-
-# activate the print InDetXYZAlgorithm statements
-InDetFlags.doPrintConfigurables = True
-
-# IMPORTANT NOTE: initialization of the flags and locking them is done in InDetRec_jobOptions.py!
-# This way RecExCommon just needs to import the properties without doing anything else!
-# DO NOT SET JOBPROPERTIES AFTER THIS LINE! The change will be ignored!
-
-#-------------------------------------------------
-# change Configured parameters
-#------------------------------------------------
-
-#from InDetRecExample.ConfiguredNewTrackingCuts import ConfiguredNewTrackingCuts
-#InDetNewTrackingCuts = ConfiguredNewTrackingCuts("HeavyIon")
-#InDetNewTrackingCuts._ConfiguredNewTrackingCuts__minPT           = 500    #1000.0
-#InDetNewTrackingCuts._ConfiguredNewTrackingCuts__Xi2max          = 15.
-
-#--------------------------------------------------------------
-# load master joboptions file
-#--------------------------------------------------------------
-#from InDetPriVxFinderTool.InDetPriVxFinderToolConf import InDet__InDetPriVxFinderTool
-#InDetPriVxFinderTool = InDet__InDetPriVxFinderTool(name              = "InDetPriVxFinderTool")
-# import TrackD3PD stuff 
-include('HIInDetValidation/HIInDetTrkD3PD_jobOptions.py')
-
-include("InDetRecExample/InDetRec_all.py")
-
-#ToolSvc.InDetPriVxFinderTool.chi2CutMethod = 1  #2#
-#ToolSvc.InDetPriVxFinderTool.maxChi2PerTrack = 15.0 ###were commented
-#ToolSvc.InDetPriVxFinderTool.enableMultipleVertices = 0	###were commented
-
-#print 'igb 1 - InDetPriVxFinderTool setup changed'
-#if 'InDetPriVxFinderTool' in dir():
-#  print InDetPriVxFinderTool
-  
-#--------------------------------------------------------------
-# Event related parameters and input files
-#--------------------------------------------------------------
-
-# Number of events to be processed
-if not ('EMax' in dir()):
-	EMax=20
-	
-theApp.EvtMax = EMax
-
-
-#ServiceMgr.EventSelector.SkipEvents = 2
-#ServiceMgr.StoreGateSvc.Dump = True
-
-ServiceMgr.PoolSvc.AttemptCatalogPatch=True
-
-#ServiceMgr.EventSelector.InputCollections = ["root://castoratlas//castor/cern.ch/atlas/atlascerngroupdisk/proj-sit/rtt/rtt/archive/devval/2/nightly/devval/build/i686-slc5-gcc43-opt/offline/HIInDetValidation/HIInDetValidation_Min_Bias/InDetRecESD.root/InDetRecESD.root"]
-#ServiceMgr.EventSelector.InputCollections = ["root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000001.pool.root.1","root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000002.pool.root.1", "root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000003.pool.root.1", "root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000004.pool.root.1", "root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000005.pool.root.1", "root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000006.pool.root.1", "root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000007.pool.root.1", "root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000008.pool.root.1", "root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000009.pool.root.1", "root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000010.pool.root.1", "root://castoratlas//castor/cern.ch/grid/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000011.pool.root.1"]
diff --git a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/test/HIInDetValidation_TestConfiguration.xml b/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/test/HIInDetValidation_TestConfiguration.xml
deleted file mode 100644
index 71159b937fac2f8cafa71bc6722dc8b260990aa6..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/HeavyIonPhys/HIInDetValidation/test/HIInDetValidation_TestConfiguration.xml
+++ /dev/null
@@ -1,1205 +0,0 @@
-<?xml version="1.0"?>
-<!DOCTYPE unifiedTestConfiguration SYSTEM 
-"http://www.hep.ucl.ac.uk/atlas/AtlasTesting/DTD/unifiedTestConfiguration.dtd">
-<unifiedTestConfiguration>
-
-  <atn/>
-  <kv/>
-
-   <rtt xmlns="http://www.hep.ucl.ac.uk/atlas/AtlasTesting/rtt">
-	<rttContactPerson>Mateusz Dyndal (Mateusz.Dyndal@cern.ch)</rttContactPerson>
-		<mailto>Mateusz.Dyndal@cern.ch,Iwona.Grabowska@cern.ch</mailto>
-		
-        	<jobList>
-			<classification>
-          			<displayClass>OfflineValidation</displayClass>
-	          		<displayProcess>Reco</displayProcess>
-	          		<displayComponent>Det-InDet</displayComponent>
-	       		</classification>
-	 
-	          <athena userJobId="HIInDetValidation_Min_Bias">
-	          	<doc>testing</doc>
-	          	<commandLineFlags>EMax=2000;DetDescrVersion="ATLAS-GEO-10-00-00"</commandLineFlags>
-	          	<options>HIInDetValidation/HIInDetValidation_JobOptions</options>
-	          	<package>PhysicsAnalysis/HeavyIonPhys/HIInDetValidation</package>
-	          	<group>HIInDetValidation</group>
-	          	<queue>long</queue>
-	          	
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000001.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000002.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000003.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000004.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000005.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000006.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000007.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000008.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000009.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000010.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000011.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000012.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000013.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000014.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000015.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000016.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000017.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000018.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000019.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000020.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000021.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000022.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000023.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000024.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000025.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000026.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000027.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000028.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000029.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000030.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000031.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000032.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000033.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000034.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000035.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000036.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000037.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000038.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000039.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000040.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000041.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000042.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000043.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000044.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000045.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000046.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000047.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000048.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000049.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000050.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000051.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000052.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000053.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000054.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000055.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000056.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000057.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000058.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000059.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000060.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000061.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000062.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000063.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000064.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000065.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000066.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000067.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000068.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000069.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000070.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000071.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000072.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000073.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000074.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000075.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000076.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000077.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000078.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000079.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000080.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000081.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000082.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000083.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000084.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000085.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000086.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000087.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000088.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000089.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000090.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000091.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000092.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000093.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000094.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000095.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000096.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000097.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000098.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000099.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000100.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000101.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000102.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000103.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000104.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000105.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000106.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000107.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000108.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000109.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000110.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000111.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000112.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000113.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000114.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000115.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000116.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000117.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000118.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000119.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000120.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000121.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000122.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000123.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000124.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000125.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000126.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000127.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000128.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000129.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000130.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000131.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000132.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000133.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000134.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000135.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000136.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000137.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000138.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000139.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000140.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000141.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000142.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000143.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000144.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000145.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000146.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000147.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000148.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000149.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000150.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000151.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000152.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000153.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000154.pool.root.1__DQ2-1276533034</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000155.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000156.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000157.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000158.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000159.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000160.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000161.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000162.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000163.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000164.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000165.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000166.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000167.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000168.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000169.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000170.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000171.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000172.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000173.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000174.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000175.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000176.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000177.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000178.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000179.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000180.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000181.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000182.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000183.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000184.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000185.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000186.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000187.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000188.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000189.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000190.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000191.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000192.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000193.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000194.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000195.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000196.pool.root.1__DQ2-1276533757</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000197.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000198.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000199.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000200.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000201.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000202.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000203.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000204.pool.root.1__DQ2-1276533757</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000205.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000206.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000207.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000208.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000209.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000210.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000211.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000212.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000213.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000214.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000215.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000216.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000217.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000218.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000219.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000220.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000221.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000222.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000223.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000224.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000225.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000226.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000227.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000228.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000229.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000230.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000231.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000232.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000233.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000234.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000235.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000236.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000237.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000238.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000239.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000240.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000241.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000242.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000243.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000244.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000245.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000246.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000247.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000248.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000249.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000250.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000251.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000252.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000253.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000254.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000255.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000256.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000257.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000258.pool.root.1__DQ2-1276533757</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000259.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000260.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000261.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000262.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000263.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000264.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000265.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000266.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000267.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000268.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000269.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000270.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000271.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000272.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000273.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000274.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000275.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000276.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000277.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000278.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000279.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000280.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000281.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000282.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000283.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000284.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000285.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000286.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000287.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000288.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000289.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000290.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000291.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000292.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000293.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000294.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000295.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000296.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000297.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000298.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000299.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000300.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000301.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000302.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000303.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000304.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000305.pool.root.1__DQ2-1276533034</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000306.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000307.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000308.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000309.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000310.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000311.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000312.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000313.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000314.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000315.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000316.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000317.pool.root.1__DQ2-1276533757</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000318.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000319.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000320.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000321.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000322.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000323.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000324.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000325.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000326.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000327.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000328.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000329.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000330.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000331.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000332.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000333.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000334.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000335.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000336.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000337.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000338.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000339.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000340.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000341.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000342.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000343.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000344.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000345.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000346.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000347.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000348.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000349.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000350.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000351.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000352.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000353.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000354.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000355.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000356.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000357.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000358.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000359.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000360.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000361.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000362.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000363.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000364.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000365.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000366.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000367.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000368.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000369.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000370.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000371.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000372.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000373.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000374.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000375.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000376.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000377.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000378.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000379.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000380.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000381.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000382.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000383.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000384.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000385.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000386.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000387.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000388.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000389.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000390.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000391.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000392.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000393.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000394.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000395.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000396.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000397.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000398.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000399.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000400.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000401.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000402.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000403.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000404.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000405.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000406.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000407.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000408.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000409.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000410.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000411.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000412.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000413.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000414.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000415.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000416.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000417.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000418.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000419.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000420.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000421.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000422.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000423.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000424.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000425.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000426.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000427.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000428.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000429.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000430.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000431.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000432.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000433.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000434.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000435.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000436.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000437.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000438.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000439.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000440.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000441.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000442.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000443.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000444.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000445.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000446.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000447.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000448.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000449.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000450.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000451.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000452.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000453.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000454.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000455.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000456.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000457.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000458.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000459.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000460.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000461.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000462.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000463.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000464.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000465.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000466.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000467.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000468.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000469.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000470.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000471.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000472.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000473.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000474.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000475.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000476.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000477.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000478.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000479.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000480.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000481.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000482.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000483.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000484.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000485.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000486.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000487.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000488.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000489.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000490.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000491.pool.root.1__DQ2-1276534258</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000492.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000493.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000494.pool.root.2</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000495.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000496.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000497.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000498.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000499.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208801.Hijing_PbPb_2p75TeV_MinBias.digit.RDO.e511_s780_s767_d313_tid144736_00/RDO.144736._000500.pool.root.1</dataset>
-
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Eff_Loose.C</argvalue>
-                      		</arg>
-	                   </test>
-
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Eff_Tight.C</argvalue>
-                      		</arg>
-	                   </test>
-	          
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Fakes_Loose.C</argvalue>
-                      		</arg>
-	                   </test>	                   
-
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Fakes_Tight.C</argvalue>
-                      		</arg>
-	                   </test>
-
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Loose_Vs_Tight.C</argvalue>
-                      		</arg>
-	                   </test>
-	                   
-	                   
-	                  <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Vertexing.C</argvalue>
-                      		</arg>
-	                   </test>
-
-	                   <test>
-	                    	<modulename>HIInDetValidation_CoolDozer</modulename>
-              			<testname>HIInDetValidation_CoolDozer</testname>
-	             		 <arg>
-	                		<argname>DryRun</argname>
-	                		<argvalue>False</argvalue>
-              			</arg>
-	                   </test>	                    
-	                    
-	                 <athenaCommonFlags /> 
-		  </athena>  
-		  
-		  
-		  
-		  <athena userJobId="HIInDetValidation_Central">
-	          	<doc>testing</doc>
-	          	<commandLineFlags>EMax=100;DetDescrVersion="ATLAS-GEO-10-00-00"</commandLineFlags>
-	          	<options>HIInDetValidation/HIInDetValidation_JobOptions</options>
-	          	<package>PhysicsAnalysis/HeavyIonPhys/HIInDetValidation</package>
-	          	<group>HIInDetValidation</group>
-	          	<queue>long</queue>
-	          	
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000001.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000002.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000003.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000004.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000005.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000006.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000007.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000008.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000009.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000010.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000011.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000012.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000013.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000014.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000015.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000016.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000017.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000018.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000019.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000020.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000021.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000022.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000023.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000024.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000025.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000026.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000027.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000028.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000029.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000030.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000031.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000032.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000033.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000034.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000035.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000036.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000037.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000038.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000039.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000040.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000041.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000042.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000043.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000044.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000045.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000046.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000047.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000048.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000049.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000050.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000051.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000052.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000053.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000054.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000055.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000056.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000057.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000058.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000059.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000060.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000061.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000062.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000063.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000064.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000065.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000066.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000067.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000068.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000069.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000070.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000071.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000072.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000073.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000074.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000075.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000076.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000077.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000078.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000079.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000080.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000081.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000082.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000083.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000084.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000085.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000086.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000087.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000088.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000089.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000090.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000091.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000092.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000093.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000094.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000095.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000096.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000097.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000098.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000099.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000100.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000101.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000102.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000103.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000104.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000105.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000106.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000107.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000108.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000109.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000110.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000111.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000112.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000113.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000114.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000115.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000116.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000117.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000118.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000119.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000120.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000121.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000122.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000123.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000124.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000125.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000126.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000127.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000128.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000129.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000130.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000131.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000132.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000133.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000134.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000135.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000136.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000137.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000138.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000139.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000140.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000141.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000142.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000143.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000144.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000145.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000146.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000147.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000148.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000149.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000150.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000151.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000152.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000153.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000154.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000155.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000156.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000157.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000158.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000159.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000160.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000161.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000162.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000163.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000164.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000165.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000166.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000167.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000168.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000169.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000170.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000171.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000172.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000173.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000174.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000175.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000176.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000177.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000178.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000179.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000180.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000181.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000182.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000183.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000184.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000185.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000186.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000187.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000188.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000189.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000190.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000191.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000192.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000193.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000194.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000195.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000196.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000197.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000198.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000199.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000200.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000201.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000202.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000203.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000204.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000205.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000206.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000207.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000208.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000209.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000210.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000211.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000212.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000213.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000214.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000215.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000216.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000217.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000218.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000219.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000220.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000221.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000222.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000223.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000224.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000225.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000226.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000227.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000228.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000229.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000230.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000231.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000232.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000233.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000234.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000235.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000236.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000237.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000238.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000239.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000240.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000241.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000242.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000243.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000244.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000245.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000246.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000247.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000248.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000249.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000250.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000251.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000252.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000253.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000254.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000255.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000256.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000257.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000258.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000259.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000260.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000261.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000262.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000263.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000264.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000265.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000266.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000267.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000268.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000269.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000270.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000271.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000272.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000273.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000274.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000275.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000276.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000277.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000278.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000279.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000280.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000281.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000282.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000283.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000284.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000285.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000286.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000287.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000288.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000289.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000290.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000291.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000292.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000293.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000294.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000295.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000296.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000297.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000298.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000299.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000300.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000301.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000302.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000303.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000304.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000305.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000306.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000307.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000308.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000309.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000310.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000311.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000312.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000313.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000314.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000315.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000316.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000317.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000318.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000319.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000320.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000321.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000322.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000323.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000324.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000325.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000326.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000327.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000328.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000329.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000330.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000331.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000332.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000333.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000334.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000335.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000336.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000337.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000338.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000339.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000340.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000341.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000342.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000343.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000344.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000345.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000346.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000347.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000348.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000349.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000350.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000351.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000352.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000353.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000354.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000355.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000356.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000357.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000358.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000359.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000360.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000361.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000362.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000363.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000364.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000365.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000366.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000367.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000368.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000369.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000370.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000371.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000372.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000373.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000374.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000375.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000376.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000377.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000378.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000379.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000380.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000381.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000382.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000383.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000384.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000385.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000386.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000387.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000388.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000389.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000390.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000391.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000392.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000393.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000394.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000395.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000396.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000397.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000398.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000399.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000400.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000401.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000402.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000403.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000404.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000405.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000406.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000407.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000408.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000409.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000410.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000411.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000412.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000413.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000414.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000415.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000416.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000417.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000418.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000419.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000420.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000421.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000422.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000423.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000424.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000425.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000426.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000427.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000428.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000429.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000430.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000431.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000432.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000433.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000434.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000435.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000436.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000437.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000438.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000439.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000440.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000441.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000442.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000443.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000444.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000445.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000446.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000447.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000448.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000449.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000450.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000451.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000452.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000453.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000454.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000455.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000456.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000457.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000458.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000459.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000460.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000461.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000462.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000463.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000464.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000465.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000466.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000467.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000468.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000469.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000470.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000471.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000472.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000473.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000474.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000475.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000476.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000477.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000478.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000479.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000480.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000481.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000482.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000483.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000484.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000485.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000486.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000487.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000488.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000489.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000490.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000491.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000492.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000493.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000494.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000495.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000496.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000497.pool.root.1</dataset>
-<dataset>/eos/atlas/atlasgroupdisk/phys-hi/dq2/mc09_7TeV/RDO/e511_s780_s767_d313/mc09_7TeV.208807.Hijing_PbPb_2p75TeV_Central.digit.RDO.e511_s780_s767_d313_tid144733_00/RDO.144733._000498.pool.root.1</dataset>
-
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Eff_Loose.C</argvalue>
-                      		</arg>
-	                   </test>
-
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Eff_Tight.C</argvalue>
-                      		</arg>
-	                   </test>
-	          
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Fakes_Loose.C</argvalue>
-                      		</arg>
-	                   </test>	                   
-
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Fakes_Tight.C</argvalue>
-                      		</arg>
-	                   </test>
-
-	                   <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Loose_Vs_Tight.C</argvalue>
-                      		</arg>
-	                   </test>
-	                   
-	                   
-	                  <test>
-	                       <modulename>RttLibraryTools</modulename>
-	                       <testname>ROOTMacroRunner</testname>
-	                       <arg>
-	                          	<argname>macro</argname>
-	                          	<argvalue>HIInDetValidation_Vertexing.C</argvalue>
-                      		</arg>
-	                   </test>
-
-	                   <test>
-	                    	<modulename>HIInDetValidation_CoolDozer</modulename>
-              			<testname>HIInDetValidation_CoolDozer</testname>
-	             		 <arg>
-	                		<argname>DryRun</argname>
-	                		<argvalue>False</argvalue>
-              			</arg>
-	                   </test>	                    
-	                    
-	                 <athenaCommonFlags /> 
-		  </athena> 
-		   		   
-        	</jobList>
-	
-		<jobGroups>
-	         	<jobGroup name="AthenaHIInDetValidation" parent="Athena">
-	         		<keepFilePattern displayColor="blue">*D3PD*.root</keepFilePattern>
-	         		<keepFilePattern displayColor="blue">*ESD*.root</keepFilePattern>
-	         		<keepFilePattern displayColor="red">Histos-Tracking-MCprob*.root</keepFilePattern>
-	         		<keepFilePattern displayColor="red">Fakes-C*.root</keepFilePattern>
-	         		<keepFilePattern displayColor="red">Vertexing-Loose.root</keepFilePattern>
-	         		<keepFilePattern>*.png</keepFilePattern>
-	         		<keepFilePattern>*.log</keepFilePattern>
-	         		<keepFilePattern displayColor="#FFD500">efficiency_HIInDetValidation.txt</keepFilePattern>
-	         		<keepFilePattern displayColor="#FFD500">fakes_HIInDetValidation.txt</keepFilePattern>
-	         		<keepFilePattern displayColor="red">*.html</keepFilePattern>
-	         		<keepFilePattern displayColor="#0DFF00">ARTT_Plots.html</keepFilePattern>
-	         		<keepFilePattern displayColor="#0DFF00">*CoolDozer.html</keepFilePattern>
-	         		
-	         		<auxFilePattern>HIInDetValidation_Eff*.C</auxFilePattern>
-	         		<auxFilePattern>HIInDetValidation_Fakes*.C</auxFilePattern>
-	         		<auxFilePattern>HIInDetValidation_CoolDozer.py</auxFilePattern>
-	         		<auxFilePattern>ARTT_Plots.html</auxFilePattern>
-	         		<auxFilePattern>Histos-Tracking-MCprob*.root</auxFilePattern>
-	         		<auxFilePattern>Fakes-C*.root</auxFilePattern>
-	         		<auxFilePattern>Vertexing-Loose.root</auxFilePattern>
-	         		<auxFilePattern>efficiency_HIInDetValidation.txt</auxFilePattern>
-	         		<auxFilePattern>fakes_HIInDetValidation.txt</auxFilePattern>
-	         		<auxFilePattern>HIInDetValidation_Loose_Vs_Tight.C</auxFilePattern>
-	         		<auxFilePattern>HIInDetValidation_Vertexing.C</auxFilePattern>
-	         		<auxFilePattern>png_file.png</auxFilePattern>
-	      		</jobGroup>
-	      	</jobGroups>
-	      	
-   	</rtt>
-</unifiedTestConfiguration>
diff --git a/PhysicsAnalysis/JetTagging/JetTagValidation/JetTagDQA/src/BTaggingValidationPlots.cxx b/PhysicsAnalysis/JetTagging/JetTagValidation/JetTagDQA/src/BTaggingValidationPlots.cxx
index 4c38270bde1c21cb7551a239badad5d8104918cf..d16705fde6da008ca3736f7a0463d620dddcc220 100644
--- a/PhysicsAnalysis/JetTagging/JetTagValidation/JetTagDQA/src/BTaggingValidationPlots.cxx
+++ b/PhysicsAnalysis/JetTagging/JetTagValidation/JetTagDQA/src/BTaggingValidationPlots.cxx
@@ -345,13 +345,13 @@ namespace JetTagDQA{
 								if((hist_iter->first).find("_trackCuts") < (hist_iter->first).length()){
 									if(nGTinSvx > 0 && nIP3DTracks > 0){ 
 										double weight=-999;
-										btag->variable<double>(*tag_iter,"discriminant",weight);		
+										btag->MVx_discriminant( *tag_iter,weight );
 										(hist_iter->second)->Fill(weight);
 									}
 								}
 								else{
 									double weight=-999;
-									btag->variable<double>(*tag_iter,"discriminant",weight);
+									btag->MVx_discriminant( *tag_iter,weight );
 									(hist_iter->second)->Fill(weight);
 								}
 							}	
diff --git a/PhysicsAnalysis/MCTruthClassifier/MCTruthClassifier/IMCTruthClassifier.h b/PhysicsAnalysis/MCTruthClassifier/MCTruthClassifier/IMCTruthClassifier.h
index 4d3032486cdf3e71dbc769be53c7f52b387b076e..e9f6e0413a0ec8940a517966d5d3c29089055239 100644
--- a/PhysicsAnalysis/MCTruthClassifier/MCTruthClassifier/IMCTruthClassifier.h
+++ b/PhysicsAnalysis/MCTruthClassifier/MCTruthClassifier/IMCTruthClassifier.h
@@ -110,10 +110,18 @@ public:
 
   virtual const xAOD::TruthParticle* isHadronFromB(const xAOD::TruthParticle*) const = 0;
 
+  /// \brief main function used in \ref MCTruthClassifier returning the value from defOrigofParticle to \ref TruthClassificationDecorator
+  virtual unsigned int classify(const xAOD::TruthParticle *) const = 0;
+
+  /// \brief function used in \ref MCTruthClassifier classifying truth particles with HepMC status 1 & 2
+  virtual unsigned int defOrigOfParticle(const xAOD::TruthParticle*) const = 0;    
+
+
 #ifndef XAOD_ANALYSIS /*This can not run in Analysis Base*/
   virtual std::pair<MCTruthPartClassifier::ParticleType, MCTruthPartClassifier::ParticleOrigin> particleTruthClassifier(
     HepMC::ConstGenParticlePtr,
     Info* info = nullptr) const = 0;
+
 #endif
   //
 #ifndef GENERATIONBASE /*These can not run in Generation only release*/
@@ -136,6 +144,7 @@ public:
   particleTruthClassifier(const xAOD::Jet*, bool DR, Info* info = nullptr) const = 0;
 
   virtual const xAOD::TruthParticle* getGenPart(const xAOD::TrackParticle*, Info* info = nullptr) const = 0;
+
 #endif
 };
 
diff --git a/PhysicsAnalysis/MCTruthClassifier/MCTruthClassifier/MCTruthClassifier.h b/PhysicsAnalysis/MCTruthClassifier/MCTruthClassifier/MCTruthClassifier.h
index e62e9a8c7dcf943bff11fd55a9b10ba25703b1fa..81d0f257f64c16eaea0129c3becde2857578a5e3 100644
--- a/PhysicsAnalysis/MCTruthClassifier/MCTruthClassifier/MCTruthClassifier.h
+++ b/PhysicsAnalysis/MCTruthClassifier/MCTruthClassifier/MCTruthClassifier.h
@@ -83,6 +83,29 @@ public:
   virtual const xAOD::TruthParticle* isHadronFromB(const xAOD::TruthParticle*) const override;
   const xAOD::TruthParticle* getMother(const xAOD::TruthParticle*) const;
 
+  virtual unsigned int classify(const xAOD::TruthParticle  *) const override;
+
+  enum MCTC_bits { HadTau=0, Tau, hadron, frombsm, uncat, isbsm, isgeant, stable, totalBits };
+
+  /// \brief These helper functions return the value that the respective bit is set to in \ref MCTruthClassifier
+  static unsigned int isGeant(const unsigned int classify) { return std::bitset<MCTC_bits::totalBits> (classify).test(MCTC_bits::isgeant); }
+  static unsigned int isBSM(const unsigned int classify) { return std::bitset<MCTC_bits::totalBits> (classify).test(MCTC_bits::isbsm); }
+  static unsigned int fromBSM(const unsigned int classify) { return std::bitset<MCTC_bits::totalBits> (classify).test(MCTC_bits::frombsm); }
+
+  /*! \brief This helper function returns the value -1 by checking the bit set in \ref MCTruthClassifier.                                                  
+   * It returns the value -1 if uncategorised, 0 if non-prompt, 1 if prompt                                                                                
+   * It also checks for prompt taus                                                                                                                        
+   */
+
+  static int isPrompt(const unsigned int classify, bool allow_prompt_tau_decays = true) {
+    std::bitset<MCTC_bits::totalBits> res(classify);
+    if (res.test(MCTC_bits::uncat)) return -1;
+    bool fromPromptTau = res.test(MCTC_bits::Tau) && !res.test(MCTC_bits::HadTau);
+    if (fromPromptTau) return int(allow_prompt_tau_decays);
+    return !res.test(MCTC_bits::hadron);
+  }
+
+
 #ifndef XAOD_ANALYSIS /*This can not run in Analysis Base*/
   virtual std::pair<MCTruthPartClassifier::ParticleType, MCTruthPartClassifier::ParticleOrigin> particleTruthClassifier(
     HepMC::ConstGenParticlePtr,
@@ -110,6 +133,7 @@ public:
   particleTruthClassifier(const xAOD::Jet*, bool DR, Info* info = nullptr) const override;
 
   virtual const xAOD::TruthParticle* getGenPart(const xAOD::TrackParticle*, Info* info = nullptr) const override;
+  
 #endif
 
 private:
@@ -150,6 +174,9 @@ private:
                                                           const xAOD::TruthParticle*,
                                                           bool& isPrompt,
                                                           Info* info) const;
+  //MCTruthPartClassifier::ParticleOrigin                                                                                                                   
+  virtual unsigned int defOrigOfParticle(const xAOD::TruthParticle*) const override;
+
   //
   MCTruthPartClassifier::ParticleOrigin defHadronType(long);
   static bool isHadron(const xAOD::TruthParticle*);
@@ -232,6 +259,7 @@ this,
     "xAODTruthLinks",
     "ReadHandleKey for xAODTruthParticleLinkVector"
   };
+
 #endif
 #ifndef GENERATIONBASE /*Disable when no recostruction packages are expected*/
   float m_deltaRMatchCut;
diff --git a/PhysicsAnalysis/MCTruthClassifier/Root/MCTruthClassifierGen.cxx b/PhysicsAnalysis/MCTruthClassifier/Root/MCTruthClassifierGen.cxx
index eaf341374baf40c4f22137d2dd6b7f4f19085ebf..aef379a04271e9cee96d3e175243d9bd444381ce 100644
--- a/PhysicsAnalysis/MCTruthClassifier/Root/MCTruthClassifierGen.cxx
+++ b/PhysicsAnalysis/MCTruthClassifier/Root/MCTruthClassifierGen.cxx
@@ -312,6 +312,102 @@ MCTruthClassifier::findAllJetMothers(const xAOD::TruthParticle* thePart,
     }
   }
 }
+
+//--------------------------------------------------------------------------------------
+unsigned int MCTruthClassifier::classify(const xAOD::TruthParticle  *thePart) const {
+//--------------------------------------------------------------------------------------
+
+  ATH_MSG_DEBUG( "Executing classify" );
+  
+  if(!thePart){ATH_MSG_WARNING( "Passed a nullptr" ); return 0;}
+
+  return defOrigOfParticle(thePart);
+}
+
+//-------------------------------------------------------------------------------
+unsigned int MCTruthClassifier::defOrigOfParticle(const xAOD::TruthParticle  *thePart) const {
+//-------------------------------------------------------------------------------  
+
+  ATH_MSG_DEBUG( "Executing DefOrigOfParticle " );
+
+  int iParticlePDG = std::abs(thePart->pdgId());
+  int iParticleStat = std::abs(thePart->status());
+
+  unsigned int outputvalue;
+
+  bool isStable=0; bool fromhad = 0; bool uncat = 0; bool isHadTau=0; bool mybeam=0; bool fromTau=0; bool fromBSM=0; bool isGeant=0;  bool isBSM=0;
+
+  if(iParticleStat == 1 || iParticleStat == 2){
+    isStable = 1;
+  }
+  if(isStable == 1){
+    const xAOD::TruthVertex* partOriVert=thePart->hasProdVtx() ? thePart->prodVtx():0;
+    if( partOriVert!=0 ) {
+      for (unsigned int ipIn=0; ipIn<partOriVert->nIncomingParticles(); ++ipIn) {
+        const xAOD::TruthParticle* theMother=partOriVert->incomingParticle(ipIn);
+        if(!theMother) continue;
+
+        if(std::abs(thePart->barcode()) >= m_barcodeG4Shift){
+          isGeant = 1; break;
+        }
+        if(MC::PID::isBSM(iParticlePDG) && abs(iParticleStat) == 1){
+          isBSM=1;
+        }
+
+        while (mybeam==0){
+          const xAOD::TruthVertex* partOriVert=thePart->hasProdVtx() ? thePart->prodVtx():0;
+          if( partOriVert!=0 ) {
+            const xAOD::TruthParticle* theMother=partOriVert->incomingParticle(0);
+            if(!theMother) continue;
+
+            if(std::abs(theMother->pdgId()) == 2212){
+              mybeam = 1; break;
+            }
+            if(MC::PID::isTau(theMother->pdgId()) && theMother->status() == 2 ){
+              fromTau = 1; isHadTau =0;
+            }
+            if(isHadron(theMother) == true && theMother->status() == 2 ) {
+              fromhad = 1;
+              if(fromTau == 1){
+                isHadTau = 1;
+              }
+            }
+
+            if(MC::PID::isBSM(theMother->pdgId())){
+              fromBSM = 1;
+            }
+            thePart = theMother;
+          }
+          else{break;}
+        }
+      }
+    }
+    else{
+      uncat=1;
+    }
+    std::bitset<MCTC_bits::totalBits> status;
+
+    status[MCTC_bits::stable] = isStable;
+    status[MCTC_bits::isgeant] = isGeant;
+    status[MCTC_bits::isbsm] = isBSM;
+    status[MCTC_bits::uncat] = uncat;
+    status[MCTC_bits::frombsm] = fromBSM;
+    status[MCTC_bits::hadron] = fromhad;
+    status[MCTC_bits::Tau] = fromTau;
+    status[MCTC_bits::HadTau] = isHadTau;
+
+    outputvalue = static_cast<unsigned int>(status.to_ulong());
+  }
+  else {
+    std::bitset<MCTC_bits::totalBits> unclass;
+    unclass[MCTC_bits::stable] = isStable;
+
+    outputvalue = static_cast<unsigned int>(unclass.to_ulong());
+  }
+
+  return outputvalue;
+}
+      
 //-------------------------------------------------------------------------------
 ParticleType
 MCTruthClassifier::defTypeOfElectron(ParticleOrigin EleOrig, bool isPrompt) const
diff --git a/PhysicsAnalysis/PrimaryDPDMaker/share/bstodpd_data.py b/PhysicsAnalysis/PrimaryDPDMaker/share/bstodpd_data.py
deleted file mode 100644
index af3a04e7fb8ec7aeb7e991987631cef750978fab..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/PrimaryDPDMaker/share/bstodpd_data.py
+++ /dev/null
@@ -1,53 +0,0 @@
-##=============================================================================
-## Name:        bstodpd_data.py
-##
-## Author:      David Cote (DESY)
-## Created:     November 2008
-##
-## Description: This is the starting script to produce a DPD from RAW.
-##=============================================================================
-
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.BeamFlags import jobproperties
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from AthenaCommon.GlobalFlags import globalflags
-from PrimaryDPDMaker.PrimaryDPDFlags import primDPD
-
-#Input
-globalflags.InputFormat.set_Value_and_Lock('bytestream')
-athenaCommonFlags.BSRDOInput.set_Value_and_Lock(['/castor/cern.ch/grid/atlas/DAQ/2008/87863/physics_BPTX/daq.NoTag.0087863.physics.BPTX.LB0000.SFO-1._0001.data'])
-athenaCommonFlags.EvtMax=5
-
-#Default configuration
-rec.doAOD=False
-rec.doWriteAOD=False
-rec.doWriteTAG=False	
-rec.doWriteTAGCOM=False
-rec.doMonitoring=False
-rec.doCBNT=False
-rec.doESD=True
-
-#auto-configuration
-rec.triggerStream="BPTX"
-rec.AutoConfiguration.append('FieldAndGeo')
-rec.AutoConfiguration.append('BeamType')
-rec.AutoConfiguration.append('ConditionsTag')
-
-#data configuration
-include( "RecExCommission/RecExCommissionFlags_jobOptions.py" )
-#ATLASCosmicFlags.doFilteredESD=False 
-include("RecExCommission/MinimalCommissioningSetup.py")
-
-#DPD (skimmed bytestream)
-rec.doDPD.set_Value_and_Lock( True )
-rec.DPDMakerScripts.append("PrimaryDPDMaker/PrimaryDPDMaker.py")
-from PrimaryDPDMaker.PrimaryDPDFlags import primDPD
-#skimmed bytestream
-primDPD.WriteRAW_IDPROJCOMM=True
-primDPD.RAW_IDPROJCOMMName="mySkimmedBS"
-
-#ESD (optional)
-rec.doWriteESD=True
-athenaCommonFlags.PoolESDOutput="myESD.pool.root"
-
-include("RecExCommon/RecExCommon_topOptions.py")
diff --git a/PhysicsAnalysis/RingerSelectorTools/CMakeLists.txt b/PhysicsAnalysis/RingerSelectorTools/CMakeLists.txt
index 7800944552b150b75cd24c420a99cd6e04e7cbf4..1601d5765465a06d64b858cd972bbf4553303f1e 100644
--- a/PhysicsAnalysis/RingerSelectorTools/CMakeLists.txt
+++ b/PhysicsAnalysis/RingerSelectorTools/CMakeLists.txt
@@ -1,25 +1,13 @@
-################################################################################
-# Package: RingerSelectorTools
-################################################################################
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 # Declare package version:
 set( RingerSelectorTools_version "\"RingerSelectorTools-00-00-18\"" )
 
 # Declare the package name:
 atlas_subdir( RingerSelectorTools )
-# Extra dependencies based on the environment:
-set( extra_pub_dep )
-set( extra_dep )
-if( XAOD_STANDALONE )
-   set( extra_dep Control/xAODRootAccess )
-else()
-  set( extra_pub_dep Control/AthenaKernel )
-  set( extra_dep Control/AthContainers Tracking/TrkEvent/TrkTrackSummary GaudiKernel )
-endif()
 
 # External dependencies:
-find_package( Boost COMPONENTS filesystem thread system )
-find_package( ROOT COMPONENTS Core Gpad Tree MathCore Hist RIO pthread )
+find_package( ROOT COMPONENTS Core RIO )
 
 atlas_add_library( RingerSelectorToolsEnumsLib
                    Root/enums/*.cxx
@@ -32,22 +20,22 @@ atlas_add_library( RingerSelectorToolsLib
                    Root/procedures/*.cxx
                    Root/tools/*.cxx
                    PUBLIC_HEADERS RingerSelectorTools
-                   INCLUDE_DIRS ${Boost_INCLUDE_DIRS} ${ROOT_INCLUDE_DIRS}
-                   LINK_LIBRARIES ${Boost_LIBRARIES} ${ROOT_LIBRARIES} AsgTools CxxUtils xAODCaloRings xAODEgamma xAODTracking PATCoreLib EgammaAnalysisInterfacesLib RingerSelectorToolsEnumsLib 
-                   PRIVATE_LINK_LIBRARIES xAODBase PathResolver TrkTrackSummary )
+                   INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
+                   LINK_LIBRARIES ${ROOT_LIBRARIES} AsgMessagingLib AsgTools AthenaKernel GaudiKernel xAODCaloRings xAODEgamma xAODTracking EgammaAnalysisInterfacesLib RingerSelectorToolsEnumsLib
+                   PRIVATE_LINK_LIBRARIES xAODBase AthContainers PathResolver TrkTrackSummary )
+
 if( NOT XAOD_STANDALONE )
   atlas_add_component( RingerSelectorTools
                        src/components/*.cxx
-                       INCLUDE_DIRS ${Boost_INCLUDE_DIRS} ${ROOT_INCLUDE_DIRS}
-                       LINK_LIBRARIES ${Boost_LIBRARIES} ${ROOT_LIBRARIES} AthenaKernel AthContainers GaudiKernel TrkTrackSummary RingerSelectorToolsLib )
+                       LINK_LIBRARIES RingerSelectorToolsLib )
 endif()
 
 
 atlas_add_dictionary( RingerSelectorToolsDict
                       RingerSelectorTools/RingerSelectorToolsDict.h
                       RingerSelectorTools/selection.xml
-                      INCLUDE_DIRS ${Boost_INCLUDE_DIRS} ${ROOT_INCLUDE_DIRS}
-                      LINK_LIBRARIES ${Boost_LIBRARIES} ${ROOT_LIBRARIES} RingerSelectorToolsLib )
+                      INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
+                      LINK_LIBRARIES ${ROOT_LIBRARIES} RingerSelectorToolsLib )
 
 atlas_add_dictionary( RingerSelectorToolsEnumsDict
                       RingerSelectorTools/RingerSelectorToolsEnumsDict.h
@@ -63,10 +51,10 @@ atlas_add_executable( dumpRings
 
 atlas_add_executable( ringsHist
    util/ringsHist.cxx
-   LINK_LIBRARIES RingerSelectorToolsLib  ${ROOT_LIBRARIES} )
+   LINK_LIBRARIES RingerSelectorToolsLib ${ROOT_LIBRARIES} )
 endif()
 
-atlas_install_python_modules( python/*.py )
+atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 
 if( XAOD_STANDALONE )
 message( STATUS "Using tag ${RingerSelectorTools_version} for all written RingerSelectorTools data." )
diff --git a/PhysicsAnalysis/RingerSelectorTools/python/ElectronRingerSelectorDefs.py b/PhysicsAnalysis/RingerSelectorTools/python/ElectronRingerSelectorDefs.py
index f30d1d827df7ed62fb2338bf7bb910a01a0cc088..600c890fb9f21ead2ba57229119f89286ff70c64 100644
--- a/PhysicsAnalysis/RingerSelectorTools/python/ElectronRingerSelectorDefs.py
+++ b/PhysicsAnalysis/RingerSelectorTools/python/ElectronRingerSelectorDefs.py
@@ -3,12 +3,10 @@
 from AthenaCommon.Logging import logging
 mlog = logging.getLogger( 'ElectronRingerSelectorDefs.py' )
 
-from AthenaCommon.Configurable import Configurable
-
 # Import from Ringer utilities:
 import ROOT
 ROOT.gSystem.Load('libRingerSelectorToolsEnumsDict.so')
-from ROOT.Ringer import ElectronTAccept_v1
+from ROOT import Ringer
 
 from RingerSelectorTools.RingerSelectorToolsConf import Ringer__AsgElectronRingerSelector
 from CaloRingerAlgs.CaloRingerKeys import outputElectronRingSetsConfKey
@@ -28,7 +26,7 @@ def removeClusterCutsFromIsEMMask(CutIDIsEMMask):
 class BaseElectronSelectorConf ( Ringer__AsgElectronRingerSelector ):
   def _setDefault(self,attrName, default, **kwargs):
     "Overwrites AsgElectronRingerSelector default to new default value."
-    if not kwargs.has_key(attrName):
+    if attrName not in kwargs:
       setattr(self, attrName, default)
 
   def _setCutIDSelector(self,defaultName,quality,menu,**kwargs):
@@ -37,12 +35,12 @@ class BaseElectronSelectorConf ( Ringer__AsgElectronRingerSelector ):
     available in the kwargs
     """
     removeMask = False
-    if not kwargs.has_key("cutIDConfDict") and not kwargs.has_key("CutIDSelector"):
+    if "cutIDConfDict" not in kwargs and "CutIDSelector" not in kwargs:
       removeMask = True
-    if not kwargs.has_key("CutIDSelector"):
-      CutIDSelectorTool = ConfiguredAsgElectronIsEMSelector(defaultName, \
-        quality, \
-        menu, \
+    if "CutIDSelector" not in kwargs:
+      CutIDSelectorTool = ConfiguredAsgElectronIsEMSelector(defaultName,
+        quality,
+        menu,
         **kwargs.pop("cutIDConfDict",{}))
       from AthenaCommon.AppMgr import ToolSvc
       ToolSvc += CutIDSelectorTool
@@ -71,8 +69,8 @@ class ElectronRingerSelectorTestLoose( BaseElectronSelectorConf ):
                      "RingerSelectorTools/TestMenu_20150605_v1/ElectronRingerOfflineThresLoose.root",
                      **kwargs)
     self._setDefault("CutsMask",
-                     ElectronTAccept_v1.getAppliedCutMsk(Ringer.Loose,
-                                                         kwargs.get("useCutIDTrack",False)),
+                     Ringer.ElectronTAccept_v1.getAppliedCutMsk(Ringer.Loose,
+                                                                kwargs.get("useCutIDTrack",False)),
                      **kwargs)
     self._setCutIDSelector("LooseRingerIsEMSelector",\
         egammaPID.ElectronIDLoosePP, \
@@ -88,8 +86,8 @@ class ElectronRingerSelectorTestMedium( BaseElectronSelectorConf ):
                      "RingerSelectorTools/TestMenu_20150605_v1/ElectronRingerOfflineThresMedium.root",
                      **kwargs)
     self._setDefault("CutsMask",
-                     ElectronTAccept_v1.getAppliedCutMsk(Ringer.Medium,
-                                                         kwargs.get("useCutIDTrack",False)),
+                     Ringer.ElectronTAccept_v1.getAppliedCutMsk(Ringer.Medium,
+                                                                kwargs.get("useCutIDTrack",False)),
                      **kwargs)
     self._setCutIDSelector("MediumRingerIsEMSelector", \
         egammaPID.ElectronIDMediumPP, \
@@ -106,8 +104,8 @@ class ElectronRingerSelectorTestTight( BaseElectronSelectorConf ):
                      "RingerSelectorTools/TestMenu_20150605_v1/ElectronRingerOfflineThresTight.root",
                      **kwargs)
     self._setDefault("CutsMask",
-                     ElectronTAccept_v1.getAppliedCutMsk(Ringer.Tight,
-                                                         kwargs.get("useCutIDTrack",False)),
+                     Ringer.ElectronTAccept_v1.getAppliedCutMsk(Ringer.Tight,
+                                                                kwargs.get("useCutIDTrack",False)),
                      **kwargs)
     self._setCutIDSelector("TightRingerIsEMSelector", \
         egammaPID.ElectronIDTightPP, \
@@ -124,8 +122,8 @@ class ElectronRingerSelectorTestNoCut( BaseElectronSelectorConf ):
                      "RingerSelectorTools/TestMenu_20150605_v1/ElectronRingerOfflineThresMedium.root",
                      **kwargs)
     self._setDefault("CutsMask",
-                     ElectronTAccept_v1.getAppliedCutMsk(Ringer.NoCut,
-                                                         kwargs.get("useCutIDTrack",False)),
+                     Ringer.ElectronTAccept_v1.getAppliedCutMsk(Ringer.NoCut,
+                                                                kwargs.get("useCutIDTrack",False)),
                      **kwargs)
     self._setCutIDSelector("NoCutRingerIsEMSelector", \
         egammaPID.ElectronIDNoCut, \
diff --git a/PhysicsAnalysis/RingerSelectorTools/python/ElectronRingerSelectorMapping.py b/PhysicsAnalysis/RingerSelectorTools/python/ElectronRingerSelectorMapping.py
index f0b5a14595b5357aab664e868cb41963cd17d32c..86e07eca125f962efc075a28dea52ded7eeec40c 100644
--- a/PhysicsAnalysis/RingerSelectorTools/python/ElectronRingerSelectorMapping.py
+++ b/PhysicsAnalysis/RingerSelectorTools/python/ElectronRingerSelectorMapping.py
@@ -17,7 +17,7 @@ import ROOT
 ROOT.gSystem.Load('libRingerSelectorToolsEnumsDict.so')
 from ROOT import Ringer
 
-from RingerSelectorTools.ElectronRingerSelectorDefs import *
+import RingerSelectorTools.ElectronRingerSelectorDefs as Defs
 
 class electronRingerPIDmenu (electronPIDmenu):
   testMenu = 999
@@ -47,8 +47,8 @@ class electronRingerPIDmenu (electronPIDmenu):
 #####################################################################################################
 
 ElectronRingerMap = {
-  (Ringer.Requirement.Loose, electronRingerPIDmenu.testMenu): ElectronRingerSelectorTestLoose,
-  (Ringer.Requirement.Medium, electronRingerPIDmenu.testMenu): ElectronRingerSelectorTestMedium,
-  (Ringer.Requirement.Tight, electronRingerPIDmenu.testMenu):  ElectronRingerSelectorTestTight,
-  (Ringer.Requirement.NoCut, electronRingerPIDmenu.testMenu):  ElectronRingerSelectorTestNoCut,
+  (Ringer.Requirement.Loose, electronRingerPIDmenu.testMenu): Defs.ElectronRingerSelectorTestLoose,
+  (Ringer.Requirement.Medium, electronRingerPIDmenu.testMenu): Defs.ElectronRingerSelectorTestMedium,
+  (Ringer.Requirement.Tight, electronRingerPIDmenu.testMenu):  Defs.ElectronRingerSelectorTestTight,
+  (Ringer.Requirement.NoCut, electronRingerPIDmenu.testMenu):  Defs.ElectronRingerSelectorTestNoCut,
   }
diff --git a/PhysicsAnalysis/TauID/TauAnalysisTools/CMakeLists.txt b/PhysicsAnalysis/TauID/TauAnalysisTools/CMakeLists.txt
index 311ef8ac5b348694cac7c93f9a5550a4b0c067aa..2c79cd33e9205a87a9001275c9db5403309061f5 100644
--- a/PhysicsAnalysis/TauID/TauAnalysisTools/CMakeLists.txt
+++ b/PhysicsAnalysis/TauID/TauAnalysisTools/CMakeLists.txt
@@ -17,7 +17,7 @@ if( XAOD_STANDALONE )
       INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
       LINK_LIBRARIES ${ROOT_LIBRARIES} AsgTools xAODEgamma xAODMuon xAODJet
       xAODTau xAODTracking xAODTruth TruthUtils PATCoreLib PATInterfaces
-      tauRecToolsLib MCTruthClassifierLib
+      tauRecToolsLib MCTruthClassifierLib AsgAnalysisInterfaces
       PRIVATE_LINK_LIBRARIES AthLinks xAODEventInfo xAODMetaData PathResolver )
 else()
    atlas_add_library( TauAnalysisToolsLib
@@ -27,12 +27,13 @@ else()
       LINK_LIBRARIES ${ROOT_LIBRARIES} AsgTools xAODEgamma xAODMuon xAODJet
       xAODTau xAODTracking xAODTruth TruthUtils PATCoreLib PATInterfaces
       ElectronPhotonSelectorToolsLib tauRecToolsLib MCTruthClassifierLib
+      AsgAnalysisInterfaces
       PRIVATE_LINK_LIBRARIES AthLinks xAODEventInfo xAODMetaData PathResolver )
 endif()
 
 if( NOT XAOD_STANDALONE )
    atlas_add_component( TauAnalysisTools
-      src/*.cxx src/components/*.cxx		     
+      src/*.cxx src/components/*.cxx
       LINK_LIBRARIES AthenaBaseComps AsgTools xAODTau GaudiKernel
       TauAnalysisToolsLib )
 endif()
diff --git a/PhysicsAnalysis/TauID/TauAnalysisTools/TauAnalysisTools/TauEfficiencyCorrectionsTool.h b/PhysicsAnalysis/TauID/TauAnalysisTools/TauAnalysisTools/TauEfficiencyCorrectionsTool.h
index 2bdc46addaf5abc0c3fed4c7a29dcc67cc9c3671..3f9c8bb6e0377531487aebf2c7b9459cf8f7cacd 100644
--- a/PhysicsAnalysis/TauID/TauAnalysisTools/TauAnalysisTools/TauEfficiencyCorrectionsTool.h
+++ b/PhysicsAnalysis/TauID/TauAnalysisTools/TauAnalysisTools/TauEfficiencyCorrectionsTool.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-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TAUANALYSISTOOLS_TAUEFFICIENCYTOOL_H
@@ -29,11 +29,9 @@
 #include "TauAnalysisTools/TauEfficiencyEleIDTool.h"
 #include "TauAnalysisTools/TauEfficiencyTriggerTool.h"
 
-#if __has_include("PileupReweighting/IPileupReweightingTool.h")
 // Tool include(s)
 #include "AsgAnalysisInterfaces/IPileupReweightingTool.h"
 #define TAUANALYSISTOOLS_PRWTOOL_AVAILABLE
-#endif
 
 namespace TauAnalysisTools
 {
diff --git a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/CMakeLists.txt b/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/CMakeLists.txt
index 1a8fd7212e75859d7909ebd4377d99b0a6891be1..17f13a3ebc6156512113e84bdb7b51301cbe6c0f 100644
--- a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/CMakeLists.txt
+++ b/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/CMakeLists.txt
@@ -10,15 +10,11 @@ atlas_add_root_dictionary( TopDataPreparation _cintDictSource
                            EXTERNAL_PACKAGES ROOT )
 
 # Build a library that other components can link against:
-atlas_add_library( TopDataPreparation Root/*.cxx Root/*.h Root/*.icc
-                   TopDataPreparation/*.h TopDataPreparation/*.icc TopDataPreparation/*/*.h
-                   TopDataPreparation/*/*.icc ${_cintDictSource} 
+atlas_add_library( TopDataPreparation Root/*.cxx Root/*.h
+                   TopDataPreparation/*.h ${_cintDictSource}
                    PUBLIC_HEADERS TopDataPreparation
                    LINK_LIBRARIES ${ROOT_LIBRARIES}
                    INCLUDE_DIRS ${ROOT_INCLUDE_DIRS} )
 
-# Install the Python modules of the package:
-atlas_install_python_modules( python/*.py )
-
 # Install data files from the package:
 atlas_install_data( data/* )
diff --git a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/LinkDef.h b/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/LinkDef.h
index a28d094e3236ac5164b5dfb388e12279addd5d50..3baf126a81d6e9b88181209b69498dbd56268519 100644
--- a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/LinkDef.h
+++ b/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/LinkDef.h
@@ -4,11 +4,9 @@
 
 #ifdef __CINT__
 #pragma extra_include "TopDataPreparation/SampleXsection.h";
-#pragma extra_include "TopDataPreparation/SampleXsectionSvc.h";
 #pragma link off all globals;
 #pragma link off all classes;
 #pragma link off all functions;
 #pragma link C++ nestedclass;
 #pragma link C++ class SampleXsection+;
-#pragma link C++ class SampleXsectionSvc+;
 #endif
diff --git a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/SamplePDF.cxx b/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/SamplePDF.cxx
deleted file mode 100644
index 551b7f53d517bb5072b1a0636e0e13d246e7b563..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/SamplePDF.cxx
+++ /dev/null
@@ -1,63 +0,0 @@
-/*
-   Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
- */
-
-#include <fstream>
-#include <sstream>
-#include <string>
-
-#include "TopDataPreparation/SamplePDF.h"
-#include <iostream>
-#include <stdlib.h>
-
-using namespace std;
-
-SamplePDF& SamplePDF::operator = (const SamplePDF& xs) {
-  if (this != &xs) {
-    m_PDFs = xs.m_PDFs;
-  }
-  return *this;
-}
-
-bool SamplePDF::readFromFile(const char* fName) {
-  ifstream in(fName);
-
-  if (!in) {
-    cerr << "SamplePDF::readFromFile : issue with " << fName << endl;
-    return false;
-  }
-
-  for (; !in.eof(); ) {
-    string line;
-    if (!getline(in, line)) break;
-    if (!line.empty() && line[0] != '#') {
-      istringstream istr(line);
-      int dsid, PDFid = -1;
-      istr >> dsid >> PDFid;
-      //cout << dsid << "\t" << PDFid << endl;
-      setSample(dsid, PDFid);
-    }
-  }
-
-  in.close();
-  return true;
-}
-
-void SamplePDF::setSample(const int dsid, const int PDFid) {
-  if (dsid < 0) return;
-
-  map<int, int >::const_iterator it = m_PDFs.find(dsid);
-  if (it != m_PDFs.end()) {
-    cerr << "ERROR!! SamplePDF::setSample: duplicate entry ! DSID= " << dsid << endl;
-    //cerr << "ERROR!! SamplePDF::setSample:                   xSect=" << xSect << "\told xSect=" << it->second.first
-    // <<endl;
-  }
-  m_PDFs[dsid] = PDFid;
-}
-
-int SamplePDF::getPDFid(const int dsid) const {
-  map<int, int >::const_iterator it = m_PDFs.find(dsid);
-  if (it != m_PDFs.end()) return it->second;
-
-  return unknown;
-}
diff --git a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/SampleXsectionSvc.cxx b/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/SampleXsectionSvc.cxx
deleted file mode 100644
index 49009041bb8c5e36a708c7fec559ea69f1d63180..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/Root/SampleXsectionSvc.cxx
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
-   Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
- */
-
-#include "TopDataPreparation/SampleXsectionSvc.h"
-#include <iostream>
-#include <cstdlib>
-
-SampleXsectionSvc* SampleXsectionSvc::s_instance = 0;
-
-SampleXsectionSvc::SampleXsectionSvc(std::string inputFile) :
-  m_inputFile(inputFile),
-  m_sampleXsection(0) {
-}
-
-//-------------------------------------------------------------------------------
-
-SampleXsectionSvc::~SampleXsectionSvc() {
-  if (m_sampleXsection) delete m_sampleXsection;
-}
-
-//-------------------------------------------------------------------------------
-
-int SampleXsectionSvc::initialize() {
-  m_sampleXsection = new SampleXsection();
-
-  char* rootcoreDir = getenv("ROOTCOREBIN");
-
-  if (!m_sampleXsection->readFromFile(m_inputFile.c_str())) {
-    if (rootcoreDir) {// if file can't be read, maybe it's in the common directory
-      std::string fullpath = std::string(rootcoreDir) + "/data/TopDataPreparation/";
-      fullpath += m_inputFile;
-      if (!m_sampleXsection->readFromFile(fullpath.c_str())) {
-        std::cerr << "SampleXsection::unable to read input file " << fullpath << std::endl;
-        return 1;
-      } else return 0; //all OK
-    } else {// if common directory can't be found, then surrender
-      std::cerr << "SampleXsection::unable to read input file " << m_inputFile << std::endl;
-      return 1;
-    }
-  }
-
-  return 0;
-}
-
-//----------------------------------------------------------------
-
-SampleXsectionSvc* SampleXsectionSvc::svc(std::string inputFile) {
-  if (s_instance == 0) {
-    s_instance = new SampleXsectionSvc(inputFile);
-
-    if (s_instance->initialize() != 0) {
-      std::cerr << "Error: initialize failed.  Could not create SampleXsectionSvc." << std::endl;
-      delete s_instance;
-      s_instance = 0;
-    }
-  }
-
-  return s_instance;
-}
diff --git a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/TopDataPreparation/SamplePDF.h b/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/TopDataPreparation/SamplePDF.h
deleted file mode 100644
index 015fd40121ca36c06eb46ee7800ca048f7f0001c..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/TopDataPreparation/SamplePDF.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
-   Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
- */
-
-#ifndef SAMPLEPDF_H
-#define SAMPLEPDF_H
-
-#include <map>
-
-/** @class SamplePDFSvc
-**
-** @author David Calvet <calvet@in2p3.fr>
-**
-** @brief A class to provide access to Monte Carlo sample luminosity information.
-**
-*/
-class SamplePDF {
-public:
-  enum showering {
-    pythia=0, herwig=1, sherpa=2, pythia8=4, herwigpp=5, sherpa21=6, unknown=10
-  };
-
-  inline SamplePDF() : m_PDFs() {}
-  inline SamplePDF(const SamplePDF& xs) : m_PDFs(xs.m_PDFs) {}
-  inline ~SamplePDF() {}
-
-  SamplePDF& operator = (const SamplePDF& xs);
-
-  bool readFromFile(const char* fName);
-  void setSample(const int dsid, const int PDFid);
-
-  int getPDFid(const int dsid) const;
-private:
-  std::map<int, int > m_PDFs;
-};
-
-#endif // SAMPLEPDF_H
diff --git a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/TopDataPreparation/SampleXsectionSvc.h b/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/TopDataPreparation/SampleXsectionSvc.h
deleted file mode 100644
index 2d8ed248862ff4d6f5bd272e3a6d307be831106f..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/TopDataPreparation/SampleXsectionSvc.h
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
-   Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
- */
-
-#ifndef SAMPLEXSECTIONSVC_H
-#define SAMPLEXSECTIONSVC_H
-
-#include <string>
-
-#include "TopDataPreparation/SampleXsection.h"
-
-/** @class SampleXsectionSvc
-**
-** @author W. H. Bell <W.Bell@cern.ch>
-**
-** @brief Singleton class providing access to SampleXsection
-**
-** The files associated with SampleXsection are read once when the unique instance is created.
-** This happens on the first call to
-** SampleXsection::svc(std::string inputFile),
-** which also return a pointer to the instance. Subsequently it is sufficient
-** to call SampleXsectionSvc::svc() without any arguments.
-*/
-class SampleXsectionSvc {
-public:
-  /** Return a pointer to the unique instance, initialize if necessary.
-   *  @param inputFile name of the input file.
-   *  @return pointer to SampleXsectionSvc instance, NULL on failure.
-   */
-  static SampleXsectionSvc* svc(std::string inputFile);
-
-  /** Return a pointer to the unique instance, or NULL if not initialized.
-   *  @return pointer to SampleXsectionSvc instance. */
-  static SampleXsectionSvc* svc() {return s_instance;}
-
-  /** Provide access to the WhichPeriod object held by the instance.
-   *  @return pointer to the initialized WhichPeriod object. */
-  const SampleXsection* sampleXsection() const {return m_sampleXsection;}
-private:
-  /** Singleton pattern: Private constructor. */
-  SampleXsectionSvc(std::string inputFile = "");
-
-  /** Singleton pattern: Private destructor. */
-  ~SampleXsectionSvc();
-
-  /** Singleton pattern: Copy constructor is private and undefined. */
-  SampleXsectionSvc(const SampleXsectionSvc&);
-
-  /** Singleton pattern: Assignment operator is private and undefined. */
-  SampleXsectionSvc& operator = (const SampleXsectionSvc&);
-
-  /** A pointer to carry the address of the unique instance. */
-  static SampleXsectionSvc* s_instance;
-
-  /** A member function to setup the WhichPeriod object. */
-  int initialize(void);
-
-  /** Input file. */
-  std::string m_inputFile;
-
-  /** The SampleXsection instance. */
-  SampleXsection* m_sampleXsection;
-};
-
-#endif
diff --git a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/python/getPDF.py b/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/python/getPDF.py
deleted file mode 100755
index 9dbb32c120a98827b6260aeccf8e51b7e4fa5c9e..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/TopPhys/TopPhysUtils/TopDataPreparation/python/getPDF.py
+++ /dev/null
@@ -1,70 +0,0 @@
-#!/usr/bin/env python
-
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-import os
-
-def getWikiFile():
-	WikiFile = "svn+ssh://svn.cern.ch/reps/atlasphys/Physics/Top/Software/Production/TopMC12twiki/status/"
-	com = "svn co "+WikiFile
-	print(com)
-	os.system(com)
-
-
-def producePDFfile(fileout_name='PDF-MC12-8TeV.data'):
-	filein = open('status/output/PDFInfo/generators_and_PDFs_info.csv', 'r')
-	fileout = open(fileout_name, 'w')
-	
-	dico = {}
-	
-	for line in filein.readlines():
-		l = line.split(' ')
-		DSID = l[0][:-1]
-		PDF= l[-1][:-1].replace(' ', '') # temparory variable
-		
-		#print DSID, PDF
-		
-		# format: (PDFid;PDFname)
-		if PDF[0]!="(" or PDF[-1]!=")" or PDF.find(";")==-1:
-			
-			# for the Z', do it by hand
-			if DSID>="110899" and DSID<="110910":
-				PDF = "21000"
-			else:
-				print("wrong format for",line[:-1])
-				print("-->",PDF,"====")
-				print("\n")
-				continue
-				
-		else : # good format
-			PDF = PDF.replace('(', '').replace(')', '')
-			PDF = PDF.split(";")[0]
-		#print DSID, PDF
-		
-		if dico.has_key(DSID):
-			if dico[DSID] != PDF:
-				print(DSID,"already exists")
-				print("\told:",dico[DSID])
-				print("\tnew:",PDF)
-		else :
-			dico[DSID]=PDF
-			out = DSID+"\t"+PDF
-			fileout.write(out+"\n")
-	
-	for sample in ["110906", "110909"]:
-		if not dico.has_key(sample):
-			print("adding missing sample",sample,"by hand")
-			out = sample+"\t21000"
-			fileout.write(out+"\n")
-		
-	for sample in ["203307", "203308", "203309", "203310", "203311", "203312", "203313", "203314", "203315", "203316", "203317", "203318"]:
-		if not dico.has_key(sample):
-			print("adding missing sample",sample,"by hand")
-			out = sample+"\t10042"
-			fileout.write(out+"\n")
-		
-	filein.close()
-	fileout.close()
-	
-getWikiFile()
-producePDFfile()
diff --git a/PhysicsAnalysis/TopPhys/xAOD/TopAnalysis/scripts/at-pkg b/PhysicsAnalysis/TopPhys/xAOD/TopAnalysis/scripts/at-pkg
deleted file mode 100755
index 3042fa0686c6a36aa718957516ddad4f89bc46dd..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/TopPhys/xAOD/TopAnalysis/scripts/at-pkg
+++ /dev/null
@@ -1,85 +0,0 @@
-#!/bin/bash
-echo "Creating a new cmake folder for use with AnalysisTop"
-pkgname=$1
-classname=$2
-echo "Creating $pkgname with $classname"
-
-mkdir -p $pkgname/Root $pkgname/$pkgname $pkgname/util $pkgname/scripts $pkgname/share
-touch $pkgname/Root/LinkDef.h
-
-echo "
-# Declare the name of this package:
-atlas_subdir( $pkgname None )
-
-# This package depends on other packages:
-atlas_depends_on_subdirs( PUBLIC
-			  TopAnalysis                          
-                          TopCPTools
-                          TopEventSelectionTools
-                          TopConfiguration
-                          TopCorrections
-                          TopEvent
-                          TopParticleLevel
-                          TopPartons
-                          TopObjectSelectionTools
-                          TopSystematicObjectMaker
-			  TopDataPreparation
-			  TopHLUpgrade )
-
-# This package uses ROOT:
-find_package( ROOT REQUIRED COMPONENTS Core Gpad Tree Hist RIO MathCore Graf )
-
-# Custom definitions needed for this package:
-add_definitions( -g )
-
-# Generate a CINT dictionary source file:
-atlas_add_root_dictionary( $pkgname _cintDictSource
-                           ROOT_HEADERS Root/LinkDef.h
-                           EXTERNAL_PACKAGES ROOT )
-
-# Build a library that other components can link against:
-atlas_add_library( $pkgname Root/*.cxx Root/*.h Root/*.icc
-                   $pkgname/*.h $pkgname/*.icc $pkgname/*/*.h
-                   $pkgname/*/*.icc \${_cintDictSource} 
-                   PUBLIC_HEADERS $pkgname
-                   LINK_LIBRARIES TopAnalysis
-				  TopCPTools
-                                  TopEventSelectionTools
-                                  TopConfiguration
-                                  TopCorrections
-                                  TopEvent
-                                  TopParticleLevel
-                                  TopPartons
-                                  TopObjectSelectionTools
-                                  TopSystematicObjectMaker
-				  TopDataPreparation
-				  TopHLUpgrade
-                                  \${ROOT_LIBRARIES}
-                   INCLUDE_DIRS \${ROOT_INCLUDE_DIRS} )
-
-# Install data files from the package:
-atlas_install_data( share/* )
-
-# Install user scripts
-atlas_install_scripts( scripts/*.py )
-
-# Build the executables of the package:
-#atlas_add_executable( myexec_$pkgname
-#                      util/myexec_$pkgname.cxx
-#                      LINK_LIBRARIES TopCPTools
-#                                     TopEventSelectionTools
-#                                     TopConfiguration
-#                                     TopCorrections
-#                                     TopEvent
-#                                     TopParticleLevel
-#                                     TopPartons
-#                                     TopObjectSelectionTools
-#                                     TopSystematicObjectMaker
-#				     TopDataPreparation
-#                                     TopHLUpgrade
-#                                     ${ROOT_LIBRARIES}
-#                                     TopAnalysis )
-" > $pkgname/CMakeLists.txt
-
-touch $pkgname/$pkgname/$classname.h
-touch $pkgname/Root/$classname.cxx
diff --git a/PhysicsAnalysis/TopPhys/xAOD/TopAnalysis/scripts/validation-data.py b/PhysicsAnalysis/TopPhys/xAOD/TopAnalysis/scripts/validation-data.py
deleted file mode 100755
index 9f81a2bbacf69930c82dd843fc557cd65a664091..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/TopPhys/xAOD/TopAnalysis/scripts/validation-data.py
+++ /dev/null
@@ -1,398 +0,0 @@
-#!/usr/bin/env python
-
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-import ROOT
-import random,string
-
-import TopExamples.AtlasStyle
-
-import sys
-import os
-import re
-
-def thumbnail(plot, width, height):
-    img = ROOT.TASImage(plot)
-    img.Scale(width, height)
-    name = plot.replace('.png', '_tn.png')
-    img.WriteImage(name)
-
-def br():
-    out.write('<br>\n')
-
-def h1(txt):
-    out.write('<h1>%s</h1>\n' % txt)
-
-def h3(txt):
-    out.write('<h3>%s</h3>\n' % txt)
-
-
-# rebin histogram to add underflow and overflow bins
-def addUnderOverflowBin(h):
-    # see https://root.cern.ch/phpBB3/viewtopic.php?t=6764
-    # function to paint the histogram h with extra bins for underflows/overflows
-    nx = h.GetNbinsX()+1
-    xbins = []
-    for r in range(nx+1):
-        xbins.append(h.GetBinLowEdge(r))
-
-    xbins.append(xbins[nx-1]+h.GetBinWidth(nx))
-    # book a temporary histogram having extra bins, change name to avoid memory leak warnings
-    xName="".join(random.SystemRandom().choice(string.ascii_uppercase + string.digits) for _ in range(5))
-    htmp = ROOT.TH1D(h.GetName()+xName, h.GetTitle(), nx+1, h.GetBinLowEdge(1)-h.GetBinWidth(1), xbins[nx])
-    # Set up plot for markers and errors
-    htmp.Sumw2()
-    # fill the new histogram including the underflows/overflows
-    for r in range(nx+1):
-        htmp.SetBinContent(htmp.FindBin(htmp.GetBinCenter(r+1)),h.GetBinContent(r))
-        htmp.SetBinError(htmp.FindBin(htmp.GetBinCenter(r+1)),h.GetBinError(r))
-    
-    htmp.SetEntries(h.GetEffectiveEntries())
-    htmp.SetXTitle(h.GetXaxis().GetTitle())
-    htmp.SetYTitle(h.GetYaxis().GetTitle())
-    return htmp
-
-
-# create ratio plot
-def createRatio(h1, h2):
-    hRatio = h1.Clone("hRatio")
-    hRatio.SetLineColor(ROOT.kBlack)
-    hRatio.SetMarkerStyle(20)
-    hRatio.SetTitle("")
-    hRatio.SetMinimum(0.8)
-    hRatio.SetMaximum(1.20)
-    #hRatio.Sumw2() # this should have already been done in addUnderOverflowBin (warnings if uncommented)
-    hRatio.SetStats(0)
-    hRatio.Divide(h2)
-    
-    # Adjust y-axis settings
-    y = hRatio.GetYaxis()
-    y.SetTitle("Ratio")
-    y.SetNdivisions(505)
-    y.SetTitleSize(20)
-    y.SetTitleFont(43)
-    y.SetTitleOffset(1.2)
-    y.SetLabelFont(43)
-    y.SetLabelSize(15)
-    
-    # Adjust x-axis settings
-    x = hRatio.GetXaxis()
-    x.SetTitleSize(20)
-    x.SetTitleFont(43)
-    x.SetTitleOffset(3.5)
-    x.SetLabelFont(43)
-    x.SetLabelSize(10)
-    return hRatio
-
-
-def createCanvasPads():
-    c1.cd()
-    # Upper histogram plot is pad1
-    pad1.SetBottomMargin(0)
-    pad1.Draw()
-    # Lower ratio plot is pad2
-    pad2.SetTopMargin(0)
-    pad2.SetBottomMargin(0.2)
-    pad2.SetGridx()
-    pad2.SetGridy()
-    pad2.Draw()
-
-
-def plot(name):
-    legend = ROOT.TLegend(0.70, 0.80, 0.90, 0.90)
-    legend.SetFillColor(0)
-    legend.SetFillStyle(0)
-    legend.SetBorderSize(0)
-    legend.SetTextFont(72)
-    legend.SetTextSize(0.04)
-
-    stack = ROOT.THStack()
-    h = [] # list of rebinned histograms for the stack
-
-    for i, f in enumerate(files):
-        h_orig = f.Get(name)
-        if h_orig == None:
-            print "Cannot find :",name,"in",f.GetName()
-            return None
-        h.append(addUnderOverflowBin(h_orig))
-
-        h[i].SetLineColor(histogramStyles[i].m_linecolour)
-        h[i].SetLineStyle(histogramStyles[i].m_linestyle)
-        h[i].SetLineWidth(histogramStyles[i].m_linewidth)
-        h[i].SetFillColor(histogramStyles[i].m_fillcolour)
-
-        version = re.findall("\d+[\.]?", names[i])
-        if (version):
-            versionName = 'AT-%s'% ''.join(str(e) for e in version)
-        else:
-            versionName = names[i].replace('.root','')
-        legend.AddEntry(h[i], versionName, 'f')
-
-        stack.Add(h[i])
-
-    #for the cutflow histograms print the number of entries on the bin
-    txt = 'hist nostack'
-    if name.find('cutflow') > -1:
-        txt += ' text'
-
-    # Create different pads
-    createCanvasPads()
-    pad1.cd()
-
-    stack.Draw(txt)
-    stack.GetHistogram().GetXaxis().SetTitle(h[0].GetXaxis().GetTitle())
-    stack.GetHistogram().GetYaxis().SetTitle(h[0].GetYaxis().GetTitle())
-    # Change the size of the numbers in the Y axis and the range
-    stack.GetHistogram().GetYaxis().SetLabelSize(0.04)
-    Ymax = stack.GetHistogram().GetMaximum()
-    stack.SetMaximum(Ymax+0.1*Ymax)    
-
-    legend.Draw('same')
-
-    if len(files) == 2:
-        # Create ratio plot
-        hRatio = createRatio(h[0],h[1])
-        pad2.cd()
-        hRatio.Draw()
-
-        thesame = True
-        for i in range(1, h[0].GetNbinsX()): #h.Chi2Test better?
-            if h[0].GetBinContent(i) != h[1].GetBinContent(i):
-                thesame = False
-
-        if not thesame:
-            x1 = stack.GetHistogram().GetXaxis().GetXmin()
-            x2 = stack.GetHistogram().GetXaxis().GetXmax()
-
-            y1 = stack.GetHistogram().GetMinimum()
-            y2 = stack.GetHistogram().GetMaximum()
-
-            pad1.cd()
-            box = ROOT.TBox(x1, y1, x2, y2)
-            box.SetFillStyle(0)
-            box.SetLineColor(ROOT.kRed)
-            box.SetLineWidth(3)
-            box.Draw('same')
-
-
-    #write the channel in the top right
-    caption = name.split('/')[0]
-    lmode = ROOT.TLatex()
-    lmode.SetTextAlign(31); #right, obviously
-    lmode.SetNDC()
-    lmode.SetTextColor(1)
-    lmode.SetTextFont(72)
-    lmode.SetTextSize(0.04) 
-    lmode.DrawLatex(0.95, 0.96, caption)
-
-    filename = name.replace('/','_') + '.png'
-    c1.Print(outputdir + '/' + filename)
-    thumbnail(outputdir + '/' + filename, 250, 250)
-    out.write('<a href="%s"><img src="%s"></a>\n' % (filename, filename.replace('.png', '_tn.png')))
-
-
-# electron plots
-def plotElectrons(channel):
-    h3('Electrons')
-    plot(channel + '/el_true_type')
-    plot(channel + '/el_n')
-    br()
-    plot(channel + '/el_pt')
-    plot(channel + '/el_eta')
-    plot(channel + '/el_phi')
-    plot(channel + '/el_charge')
-    plot(channel + '/el_trkpart_charge')
-    br()
-
-    plot(channel + '/el_topoetcone20')
-    plot(channel + '/el_topoetcone30')
-    plot(channel + '/el_topoetcone40')
-    br()
-
-    plot(channel + '/el_ptcone20')
-    plot(channel + '/el_ptcone30')
-    plot(channel + '/el_ptcone40')
-    br()
-
-    plot(channel + '/el_ptvarcone20')
-    plot(channel + '/el_ptvarcone30')
-    plot(channel + '/el_ptvarcone40')
-    br()
-
-
-# muon plots
-def plotMuons(channel):
-    h3('Muons')
-    plot(channel + '/mu_true_type')
-    plot(channel + '/mu_n')
-    br()
-    plot(channel + '/mu_pt')
-    plot(channel + '/mu_eta')
-    plot(channel + '/mu_phi')
-    plot(channel + '/mu_charge')
-    br()
-
-    plot(channel + '/mu_topoetcone20')
-    plot(channel + '/mu_topoetcone30')
-    plot(channel + '/mu_topoetcone40')
-    br()
-
-    plot(channel + '/mu_ptcone20')
-    plot(channel + '/mu_ptcone30')
-    plot(channel + '/mu_ptcone40')
-    br()
-
-    plot(channel + '/mu_ptvarcone20')
-    plot(channel + '/mu_ptvarcone30')
-    plot(channel + '/mu_ptvarcone40')
-    br()
-
-
-# photon plots
-def plotPhotons(channel):
-    h3('Photons')
-    plot(channel + '/ph_n')
-    plot(channel + '/ph_pt')
-    plot(channel + '/ph_eta')
-    plot(channel + '/ph_phi')
-    plot(channel + '/ph_e')
-    plot(channel + '/ph_ptvarcone20')
-    br()
-
-
-# jet and large-R jet plots
-def plotJets(channel):
-    h3('All Jets')
-    plot(channel + '/jet_n')
-    br()
-    plot(channel + '/jet_pt')
-    plot(channel + '/jet_eta')
-    plot(channel + '/jet_phi')
-    plot(channel + '/jet_e')
-    br()
-    plot(channel + '/jet_mv2c10')
-    plot(channel + '/jet_truthflav')
-    plot(channel + '/jet_isbtagged_MV2c10_77')
-    plot(channel + '/jet_btagSF_MV2c10_77')
-
-    for i in range(4):
-        h3('Jet%d' % i)
-        plot(channel + '/jet%d_pt' % i)
-        plot(channel + '/jet%d_eta' % i)
-        plot(channel + '/jet%d_phi' % i)
-        plot(channel + '/jet%d_e' % i)
-        br()
-        plot(channel + '/jet%d_mv2c10' % i)
-        plot(channel + '/jet%d_truthflav' % i)
-        plot(channel + '/jet%d_isbtagged_MV2c10_77' % i)
-        plot(channel + '/jet%d_btagSF_MV2c10_77' % i)
-
-    h3('Large-R jet')
-    plot(channel + '/ljet_n')
-    plot(channel + '/ljet_pt')
-    plot(channel + '/ljet_eta')
-    plot(channel + '/ljet_phi')
-    plot(channel + '/ljet_m')
-    plot(channel + '/ljet_sd12')
-
-
-
-# tau plots
-def plotTau(channel):
-    h3('Tau')
-    plot(channel + '/taujet_n')
-    plot(channel + '/taujet_pt')
-    plot(channel + '/taujet_eta')
-    plot(channel + '/taujet_phi')
-    plot(channel + '/taujet_charge')
-
-
-
-ROOT.gROOT.SetBatch(True)
-
-channels = ['ejets_2015', 'ejets_2016', 'mujets_2015', 'mujets_2016', 'ee_2015', 'ee_2016', 'mumu_2015', 'mumu_2016', 'emu_2015', 'emu_2016']
-particles = ['Electrons', 'Muons', 'Photons', 'Jets', 'Tau', 'MET']
-
-
-if len(sys.argv) < 2:
-    print 'Try:'
-    print 'python %s outputdir/ primary.root rel_1.root' % sys.argv[0]
-    sys.exit()
-
-outputdir = sys.argv[1]
-
-names = sys.argv[2:]
-print 'Expecting these files', names
-
-#try to make it, but don't worry too much if it already exists
-try:
-    os.mkdir(outputdir)
-except:
-    pass
-
-class HistStyle:
-    def __init__(self, linecolour, linestyle, linewidth, fillcolour):
-        self.m_linecolour = linecolour
-        self.m_linestyle = linestyle
-        self.m_linewidth = linewidth
-        self.m_fillcolour = fillcolour
-
-histogramStyles = [
-    HistStyle(ROOT.kYellow, 1, 3, ROOT.kYellow),
-    HistStyle(ROOT.kBlack, 2, 3, 0),
-    HistStyle(ROOT.kRed, 3, 3, 0),
-    HistStyle(ROOT.kGreen, 4, 3, 0),
-    HistStyle(ROOT.kBlue, 5, 3, 0),
-    HistStyle(ROOT.kGray, 6, 3, ROOT.kGray),
-]
-
-files = []
-for name in names:
-    files.append(ROOT.TFile.Open(name))
-
-if len(files) > len(histogramStyles):
-    print 'You are trying to open more files than we have styles'
-    print 'edit the histogramStyles list and add some more'
-    sys.exit(1)
-
-out = open(outputdir + '/index.html', 'w')
-c1 = ROOT.TCanvas('c1', '', 600, 600)
-pad1 = ROOT.TPad("pad1", "pad1", 0, 0.3, 1, 1.0)
-pad2 = ROOT.TPad("pad2", "pad2", 0, 0.05, 1, 0.3)
-
-h3('Cutflows')
-for channel in channels:
-    plot(channel + '/cutflow')
-
-for channel in channels:
-    h1(channel)
-
-    h3('Event stuff')
-    plot(channel + '/mc_weight')
-    plot(channel + '/pileup_weight')
-    plot(channel + '/event_mu')
-    plot(channel + '/jvt_SF')
-
-    print channel
-
-    if 'Electrons' in particles:
-        plotElectrons(channel)
-
-    if 'Muons' in particles:
-        plotMuons(channel)
-
-    if 'Photons' in particles:
-        plotPhotons(channel)
-
-    if 'Jets' in particles:
-        plotJets(channel)
-
-    if 'Taus' in particles:
-        plotTaus(channel)
-
-
-    h3('MET')
-    plot(channel + '/event_met_et')
-    plot(channel + '/event_met_phi')
-
-out.close()
diff --git a/PhysicsAnalysis/TopPhys/xAOD/TopAnalysis/scripts/validation.py b/PhysicsAnalysis/TopPhys/xAOD/TopAnalysis/scripts/validation.py
deleted file mode 100755
index 9c0b17d53b91e569e65afbb34a8545060e0f5f77..0000000000000000000000000000000000000000
--- a/PhysicsAnalysis/TopPhys/xAOD/TopAnalysis/scripts/validation.py
+++ /dev/null
@@ -1,395 +0,0 @@
-#!/usr/bin/env python
-
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-import ROOT
-import random,string
-
-import TopExamples.AtlasStyle
-
-import sys
-import os
-import re
-
-def thumbnail(plot, width, height):
-    img = ROOT.TASImage(plot)
-    img.Scale(width, height)
-    name = plot.replace('.png', '_tn.png')
-    img.WriteImage(name)
-
-def br():
-    out.write('<br>\n')
-
-def h1(txt):
-    out.write('<h1>%s</h1>\n' % txt)
-
-def h3(txt):
-    out.write('<h3>%s</h3>\n' % txt)
-
-
-# rebin histogram to add underflow and overflow bins
-def addUnderOverflowBin(h):
-    # see https://root.cern.ch/phpBB3/viewtopic.php?t=6764
-    # function to paint the histogram h with extra bins for underflows/overflows
-    nx = h.GetNbinsX()+1
-    xbins = []
-    for r in range(nx+1):
-        xbins.append(h.GetBinLowEdge(r))
-
-    xbins.append(xbins[nx-1]+h.GetBinWidth(nx))
-    # book a temporary histogram having extra bins, change name to avoid memory leak warnings
-    xName="".join(random.SystemRandom().choice(string.ascii_uppercase + string.digits) for _ in range(5))
-    htmp = ROOT.TH1D(h.GetName()+xName, h.GetTitle(), nx+1, h.GetBinLowEdge(1)-h.GetBinWidth(1), xbins[nx])
-    # Set up plot for markers and errors
-    htmp.Sumw2()
-    # fill the new histogram including the underflows/overflows
-    for r in range(nx+1):
-        htmp.SetBinContent(htmp.FindBin(htmp.GetBinCenter(r+1)),h.GetBinContent(r))
-        htmp.SetBinError(htmp.FindBin(htmp.GetBinCenter(r+1)),h.GetBinError(r))
-    
-    htmp.SetEntries(h.GetEffectiveEntries())
-    htmp.SetXTitle(h.GetXaxis().GetTitle())
-    htmp.SetYTitle(h.GetYaxis().GetTitle())
-    return htmp
-
-
-# create ratio plot
-def createRatio(h1, h2):
-    hRatio = h1.Clone("hRatio")
-    hRatio.SetLineColor(ROOT.kBlack)
-    hRatio.SetMarkerStyle(20)
-    hRatio.SetTitle("")
-    hRatio.SetMinimum(0.8)
-    hRatio.SetMaximum(1.20)
-    #hRatio.Sumw2() # this should have already been done in addUnderOverflowBin (warnings if uncommented)
-    hRatio.SetStats(0)
-    hRatio.Divide(h2)
-    
-    # Adjust y-axis settings
-    y = hRatio.GetYaxis()
-    y.SetTitle("Ratio")
-    y.SetNdivisions(505)
-    y.SetTitleSize(20)
-    y.SetTitleFont(43)
-    y.SetTitleOffset(1.2)
-    y.SetLabelFont(43)
-    y.SetLabelSize(15)
-    
-    # Adjust x-axis settings
-    x = hRatio.GetXaxis()
-    x.SetTitleSize(20)
-    x.SetTitleFont(43)
-    x.SetTitleOffset(3.5)
-    x.SetLabelFont(43)
-    x.SetLabelSize(10)
-    return hRatio
-
-
-def createCanvasPads():
-    c1.cd()
-    # Upper histogram plot is pad1
-    pad1.SetBottomMargin(0)
-    pad1.Draw()
-    # Lower ratio plot is pad2
-    pad2.SetTopMargin(0)
-    pad2.SetBottomMargin(0.2)
-    pad2.SetGridx()
-    pad2.SetGridy()
-    pad2.Draw()
-
-
-def plot(name):
-    legend = ROOT.TLegend(0.70, 0.80, 0.90, 0.90)
-    legend.SetFillColor(0)
-    legend.SetFillStyle(0)
-    legend.SetBorderSize(0)
-    legend.SetTextFont(72)
-    legend.SetTextSize(0.04)
-
-    stack = ROOT.THStack()
-    h = [] # list of rebinned histograms for the stack
-
-    for i, f in enumerate(files):
-        h_orig = f.Get(name)
-        h.append(addUnderOverflowBin(h_orig))
-
-        h[i].SetLineColor(histogramStyles[i].m_linecolour)
-        h[i].SetLineStyle(histogramStyles[i].m_linestyle)
-        h[i].SetLineWidth(histogramStyles[i].m_linewidth)
-        h[i].SetFillColor(histogramStyles[i].m_fillcolour)
-
-        version = re.findall("\d+[\.]?", names[i])
-        if (version):
-            versionName = 'AT-%s'% ''.join(str(e) for e in version)
-        else:
-            versionName = names[i].replace('.root','')
-        legend.AddEntry(h[i], versionName, 'f')
-
-        stack.Add(h[i])
-
-    #for the cutflow histograms print the number of entries on the bin
-    txt = 'hist nostack'
-    if name.find('cutflow') > -1:
-        txt += ' text'
-
-    # Create different pads
-    createCanvasPads()
-    pad1.cd()
-
-    stack.Draw(txt)
-    stack.GetHistogram().GetXaxis().SetTitle(h[0].GetXaxis().GetTitle())
-    stack.GetHistogram().GetYaxis().SetTitle(h[0].GetYaxis().GetTitle())
-    # Change the size of the numbers in the Y axis and the range
-    stack.GetHistogram().GetYaxis().SetLabelSize(0.04)
-    Ymax = stack.GetHistogram().GetMaximum()
-    stack.SetMaximum(Ymax+0.1*Ymax)    
-
-    legend.Draw('same')
-
-    if len(files) == 2:
-        # Create ratio plot
-        hRatio = createRatio(h[0],h[1])
-        pad2.cd()
-        hRatio.Draw()
-
-        thesame = True
-        for i in range(1, h[0].GetNbinsX()): #h.Chi2Test better?
-            if h[0].GetBinContent(i) != h[1].GetBinContent(i):
-                thesame = False
-
-        if not thesame:
-            x1 = stack.GetHistogram().GetXaxis().GetXmin()
-            x2 = stack.GetHistogram().GetXaxis().GetXmax()
-
-            y1 = stack.GetHistogram().GetMinimum()
-            y2 = stack.GetHistogram().GetMaximum()
-
-            pad1.cd()
-            box = ROOT.TBox(x1, y1, x2, y2)
-            box.SetFillStyle(0)
-            box.SetLineColor(ROOT.kRed)
-            box.SetLineWidth(3)
-            box.Draw('same')
-
-
-    #write the channel in the top right
-    caption = name.split('/')[0]
-    lmode = ROOT.TLatex()
-    lmode.SetTextAlign(31); #right, obviously
-    lmode.SetNDC()
-    lmode.SetTextColor(1)
-    lmode.SetTextFont(72)
-    lmode.SetTextSize(0.04) 
-    lmode.DrawLatex(0.95, 0.96, caption)
-
-    filename = name.replace('/','_') + '.png'
-    c1.Print(outputdir + '/' + filename)
-    thumbnail(outputdir + '/' + filename, 250, 250)
-    out.write('<a href="%s"><img src="%s"></a>\n' % (filename, filename.replace('.png', '_tn.png')))
-
-
-# electron plots
-def plotElectrons(channel):
-    h3('Electrons')
-    plot(channel + '/el_true_type')
-    plot(channel + '/el_n')
-    br()
-    plot(channel + '/el_pt')
-    plot(channel + '/el_eta')
-    plot(channel + '/el_phi')
-    plot(channel + '/el_charge')
-    plot(channel + '/el_trkpart_charge')
-    br()
-
-    plot(channel + '/el_topoetcone20')
-    plot(channel + '/el_topoetcone30')
-    plot(channel + '/el_topoetcone40')
-    br()
-
-    plot(channel + '/el_ptcone20')
-    plot(channel + '/el_ptcone30')
-    plot(channel + '/el_ptcone40')
-    br()
-
-    plot(channel + '/el_ptvarcone20')
-    plot(channel + '/el_ptvarcone30')
-    plot(channel + '/el_ptvarcone40')
-    br()
-
-
-# muon plots
-def plotMuons(channel):
-    h3('Muons')
-    plot(channel + '/mu_true_type')
-    plot(channel + '/mu_n')
-    br()
-    plot(channel + '/mu_pt')
-    plot(channel + '/mu_eta')
-    plot(channel + '/mu_phi')
-    plot(channel + '/mu_charge')
-    br()
-
-    plot(channel + '/mu_topoetcone20')
-    plot(channel + '/mu_topoetcone30')
-    plot(channel + '/mu_topoetcone40')
-    br()
-
-    plot(channel + '/mu_ptcone20')
-    plot(channel + '/mu_ptcone30')
-    plot(channel + '/mu_ptcone40')
-    br()
-
-    plot(channel + '/mu_ptvarcone20')
-    plot(channel + '/mu_ptvarcone30')
-    plot(channel + '/mu_ptvarcone40')
-    br()
-
-
-# photon plots
-def plotPhotons(channel):
-    h3('Photons')
-    plot(channel + '/ph_n')
-    plot(channel + '/ph_pt')
-    plot(channel + '/ph_eta')
-    plot(channel + '/ph_phi')
-    plot(channel + '/ph_e')
-    plot(channel + '/ph_ptvarcone20')
-    br()
-
-
-# jet and large-R jet plots
-def plotJets(channel):
-    h3('All Jets')
-    plot(channel + '/jet_n')
-    br()
-    plot(channel + '/jet_pt')
-    plot(channel + '/jet_eta')
-    plot(channel + '/jet_phi')
-    plot(channel + '/jet_e')
-    br()
-    plot(channel + '/jet_mv2c10')
-    plot(channel + '/jet_truthflav')
-    plot(channel + '/jet_isbtagged_MV2c10_77')
-    plot(channel + '/jet_btagSF_MV2c10_77')
-
-    for i in range(4):
-        h3('Jet%d' % i)
-        plot(channel + '/jet%d_pt' % i)
-        plot(channel + '/jet%d_eta' % i)
-        plot(channel + '/jet%d_phi' % i)
-        plot(channel + '/jet%d_e' % i)
-        br()
-        plot(channel + '/jet%d_mv2c10' % i)
-        plot(channel + '/jet%d_truthflav' % i)
-        plot(channel + '/jet%d_isbtagged_MV2c10_77' % i)
-        plot(channel + '/jet%d_btagSF_MV2c10_77' % i)
-
-    h3('Large-R jet')
-    plot(channel + '/ljet_n')
-    plot(channel + '/ljet_pt')
-    plot(channel + '/ljet_eta')
-    plot(channel + '/ljet_phi')
-    plot(channel + '/ljet_m')
-    plot(channel + '/ljet_sd12')
-
-
-
-# tau plots
-def plotTau(channel):
-    h3('Tau')
-    plot(channel + '/taujet_n')
-    plot(channel + '/taujet_pt')
-    plot(channel + '/taujet_eta')
-    plot(channel + '/taujet_phi')
-    plot(channel + '/taujet_charge')
-
-
-
-ROOT.gROOT.SetBatch(True)
-
-channels = ['ejets_2015', 'ejets_2016', 'mujets_2015', 'mujets_2016', 'ee_2015', 'ee_2016', 'mumu_2015', 'mumu_2016', 'emu_2015', 'emu_2016']
-particles = ['Electrons', 'Muons', 'Photons', 'Jets', 'Tau', 'MET']
-
-
-if len(sys.argv) < 2:
-    print 'Try:'
-    print 'python %s outputdir/ primary.root rel_1.root' % sys.argv[0]
-    sys.exit()
-
-outputdir = sys.argv[1]
-
-names = sys.argv[2:]
-print 'Expecting these files', names
-
-#try to make it, but don't worry too much if it already exists
-try:
-    os.mkdir(outputdir)
-except:
-    pass
-
-class HistStyle:
-    def __init__(self, linecolour, linestyle, linewidth, fillcolour):
-        self.m_linecolour = linecolour
-        self.m_linestyle = linestyle
-        self.m_linewidth = linewidth
-        self.m_fillcolour = fillcolour
-
-histogramStyles = [
-    HistStyle(ROOT.kYellow, 1, 3, ROOT.kYellow),
-    HistStyle(ROOT.kBlack, 2, 3, 0),
-    HistStyle(ROOT.kRed, 3, 3, 0),
-    HistStyle(ROOT.kGreen, 4, 3, 0),
-    HistStyle(ROOT.kBlue, 5, 3, 0),
-    HistStyle(ROOT.kGray, 6, 3, ROOT.kGray),
-]
-
-files = []
-for name in names:
-    files.append(ROOT.TFile.Open(name))
-
-if len(files) > len(histogramStyles):
-    print 'You are trying to open more files than we have styles'
-    print 'edit the histogramStyles list and add some more'
-    sys.exit(1)
-
-out = open(outputdir + '/index.html', 'w')
-c1 = ROOT.TCanvas('c1', '', 600, 600)
-pad1 = ROOT.TPad("pad1", "pad1", 0, 0.3, 1, 1.0)
-pad2 = ROOT.TPad("pad2", "pad2", 0, 0.05, 1, 0.3)
-
-h3('Cutflows')
-for channel in channels:
-    plot(channel + '/cutflow')
-
-for channel in channels:
-    h1(channel)
-
-    h3('Event stuff')
-    plot(channel + '/mc_weight')
-    plot(channel + '/pileup_weight')
-    plot(channel + '/event_mu')
-    plot(channel + '/jvt_SF')
-
-    print channel
-
-    if 'Electrons' in particles:
-        plotElectrons(channel)
-
-    if 'Muons' in particles:
-        plotMuons(channel)
-
-    if 'Photons' in particles:
-        plotPhotons(channel)
-
-    if 'Jets' in particles:
-        plotJets(channel)
-
-    if 'Taus' in particles:
-        plotTaus(channel)
-
-
-    h3('MET')
-    plot(channel + '/event_met_et')
-    plot(channel + '/event_met_phi')
-
-out.close()
diff --git a/PhysicsAnalysis/TopPhys/xAOD/TopCPTools/CMakeLists.txt b/PhysicsAnalysis/TopPhys/xAOD/TopCPTools/CMakeLists.txt
index 2a7dfa40be522903fb9e80cf7c6b90fa5cc76597..89ba00a007bf96038c1e9f8bceec253c4448c58f 100644
--- a/PhysicsAnalysis/TopPhys/xAOD/TopCPTools/CMakeLists.txt
+++ b/PhysicsAnalysis/TopPhys/xAOD/TopCPTools/CMakeLists.txt
@@ -35,6 +35,7 @@ atlas_add_library( TopCPTools Root/*.cxx Root/*.h Root/*.icc
                                   TrigConfInterfaces
                                   TrigDecisionToolLib
                                   TriggerAnalysisInterfaces
+                                  TrigGlobalEfficiencyCorrectionLib
                                   TrigTauMatchingLib
                                   TriggerMatchingToolLib
                                   xAODBTaggingEfficiencyLib
diff --git a/PhysicsAnalysis/TopPhys/xAOD/TopCPTools/Root/TopTriggerCPTools.cxx b/PhysicsAnalysis/TopPhys/xAOD/TopCPTools/Root/TopTriggerCPTools.cxx
index 190f0f6cc559656b5517e085a33fe6c108c77251..acf7072d6997333175d45e8e3d16bc87c5ee091d 100644
--- a/PhysicsAnalysis/TopPhys/xAOD/TopCPTools/Root/TopTriggerCPTools.cxx
+++ b/PhysicsAnalysis/TopPhys/xAOD/TopCPTools/Root/TopTriggerCPTools.cxx
@@ -1,5 +1,5 @@
 /*
-   Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
+   Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
  */
 
 #include "TopCPTools/TopTriggerCPTools.h"
@@ -22,8 +22,8 @@
 #include "TriggerMatchingTool/MatchingTool.h"
 #include "TriggerMatchingTool/MatchFromCompositeTool.h"
 #include "TrigTauMatching/TrigTauMatching.h"
-//#include "TrigGlobalEfficiencyCorrection/TrigGlobalEfficiencyCorrectionTool.h"
-//#include "TrigGlobalEfficiencyCorrection/ImportData.h"
+#include "TrigGlobalEfficiencyCorrection/TrigGlobalEfficiencyCorrectionTool.h"
+#include "TrigGlobalEfficiencyCorrection/ImportData.h"
 #include "EgammaAnalysisInterfaces/IAsgElectronEfficiencyCorrectionTool.h"
 #include "MuonAnalysisInterfaces/IMuonTriggerScaleFactors.h"
 #include "MuonEfficiencyCorrections/MuonTriggerScaleFactors.h"
@@ -79,20 +79,10 @@ namespace top {
         if (asg::ToolStore::contains<Trig::IMatchingTool>(trig_match_name)) {
           m_trigMatchTool = asg::ToolStore::get<Trig::IMatchingTool>(trig_match_name);
         } else {
-          if (m_config->getDerivationStream() == "PHYS") {
-            Trig::MatchFromCompositeTool* trigMatchTool = new Trig::MatchFromCompositeTool(trig_match_name);
-            top::check(trigMatchTool->initialize(),
-                       "Failed to initialize trig. matching tool");
-            m_trigMatchTool = trigMatchTool;
-
-          } else {
-            Trig::MatchingTool* trigMatchTool = new Trig::MatchingTool(trig_match_name);
-            top::check(trigMatchTool->setProperty("TrigDecisionTool", m_trigDecisionTool),
-                       "Failed to set trigger decision tool to trigger matching tool");
-            top::check(trigMatchTool->initialize(),
-                       "Failed to initialize trig. matching tool");
-            m_trigMatchTool = trigMatchTool;
-          }
+          Trig::MatchFromCompositeTool* trigMatchTool = new Trig::MatchFromCompositeTool(trig_match_name);
+          top::check(trigMatchTool->initialize(),
+                     "Failed to initialize trig. matching tool");
+          m_trigMatchTool = trigMatchTool;
         }
 
         ///-- Tau matching --///
@@ -128,267 +118,267 @@ namespace top {
     StatusCode statusCode = StatusCode::SUCCESS;
 
     // utilities for TrigGlobEffCorr::ImportData
-    //TrigGlobEffCorr::ImportData triggerData;
-    //top::check(triggerData.importTriggers(), "failed to import trigger data");
-    //auto const& triggerDict = triggerData.getDictionary();
-    //std::unordered_map<std::string, TrigGlobEffCorr::ImportData::TrigDef> triggerDefs;
-    //for (auto&& kv : triggerData.getTriggerDefs()) {
-    //  auto it = triggerDict.find(kv.first);
-    //  if (it != triggerDict.end()) {
-    //    triggerDefs[it->second] = kv.second;
-    //  }
-    //}
-    //auto getTriggerLegs =
-    //  [&](std::unordered_map<std::string, std::vector<std::string> > const& triggerCombination,
-    //      std::unordered_map<std::string, std::set<std::string> >& electronLegsByPeriod) {
-    //    for (auto&& kv : triggerCombination) {
-    //      std::string const& period = kv.first;
-    //      for (auto const& trigKey : kv.second) {
-    //        auto triggerDefsIt = triggerDefs.find(trigKey);
-    //        if (triggerDefsIt == triggerDefs.end()) {
-    //          statusCode = StatusCode::FAILURE;
-    //          ATH_MSG_ERROR("unrecognized trigger `" << trigKey << "'");
-    //          continue;
-    //        }
-    //        auto const& trigDef = triggerDefsIt->second;
-    //        for (auto const& leg : trigDef.leg) {
-    //          if (!leg) continue;
-    //          std::string const& legname = triggerDict.at(leg);
-    //          bool ok = true;
-    //          xAOD::Type::ObjectType legtype = triggerData.associatedLeptonFlavour(legname, ok);
-    //          if (!ok) {
-    //            statusCode = StatusCode::FAILURE;
-    //            ATH_MSG_ERROR("could not determine object type for trigger leg `" << legname <<
-    //              "'");
-    //            continue;
-    //          }
-    //          switch (legtype) {
-    //          case xAOD::Type::Electron:
-    //            electronLegsByPeriod[period].insert(legname);
-    //            break;
-
-    //          case xAOD::Type::Muon:
-    //            break;
-
-    //          default:
-    //            statusCode = StatusCode::FAILURE;
-    //            ATH_MSG_ERROR(
-    //              "trigger leg `" << legname << "' has unsupported object type `" << legtype << "'");
-    //            continue;
-    //          }
-    //        }
-    //      }
-    //    }
-    //  };
-
-    //// Get trigger strings from configuration
-    //std::map<std::string, std::string> triggerCombination, triggerCombinationLoose;
-    //std::vector<std::string> electronSystematics, muonSystematics, electronToolNames, muonToolNames;
-    //std::unordered_map<std::string, std::vector<std::string> > const emptymap;
-    //std::unordered_map<std::string, std::vector<std::string> > const&
-    //triggersByPeriod = (m_config->doTightEvents() ? m_config->getGlobalTriggers() : emptymap),
-    //  triggersByPeriodLoose = (m_config->doLooseEvents() ? m_config->getGlobalTriggersLoose() : emptymap);
-
-    //std::unordered_map<std::string, std::set<std::string> > electronLegsByPeriod, electronLegsByPeriodLoose;
-    //getTriggerLegs(triggersByPeriod, electronLegsByPeriod);
-    //getTriggerLegs(triggersByPeriodLoose, electronLegsByPeriodLoose);
-
-    //// Get quality
-    //std::string electronID, electronIDLoose, electronIsolation, electronIsolationLoose, muonQuality, muonQualityLoose;
-    //if (m_config->doTightEvents()) {
-    //  electronID = m_config->electronID();
-    //  electronIsolation = m_config->electronIsolationSF();
-    //  muonQuality = m_config->muonQuality();
-    //}
-    //if (m_config->doLooseEvents()) {
-    //  electronIDLoose = m_config->electronIDLoose();
-    //  electronIsolationLoose = m_config->electronIsolationSFLoose();
-    //  muonQualityLoose = m_config->muonQualityLoose();
-    //}
-
-    //// Tidy name for e/gamma
-    //electronID = mapWorkingPoints(electronID);
-    //electronIDLoose = mapWorkingPoints(electronIDLoose);
-    //// This is hopefully only temporary
-    //electronIsolation = mapWorkingPoints(electronIsolation);
-    //electronIsolationLoose = mapWorkingPoints(electronIsolationLoose);
-
-    //// Create electron trigger SF and Eff tools
-    //ToolHandleArray<IAsgElectronEfficiencyCorrectionTool> electronEffTools, electronSFTools, electronEffToolsLoose,
-    //                                                      electronSFToolsLoose;
-    //std::map<std::string, std::string> legsPerTool, legsPerToolLoose;
-    //int nTools = 0;
-
-    //// Loop over the triggers found (electrons - tight)
-    //for (auto& y_t : electronLegsByPeriod) {
-    //  std::string year = y_t.first;
-    //  for (auto& trigKey : y_t.second) {
-    //    nTools++;
-    //    for (int j = 0; j < 2; ++j) { // one tool instance for efficiencies, another for scale factors
-    //      ATH_MSG_INFO("TIGHT " << year << " " << trigKey << " " << electronID << " " << electronIsolation);
-    //      auto t = m_electronToolsFactory.emplace(
-    //        m_electronToolsFactory.end(), "AsgElectronEfficiencyCorrectionTool/ElTrigEff_" + std::to_string(
-    //          j) + "_" + std::to_string(nTools));
-    //      top::check(t->setProperty("MapFilePath",
-    //                                "ElectronEfficiencyCorrection/2015_2017/rel21.2/Consolidation_September2018_v1/map3.txt"),
-    //                 "Fail");
-    //      top::check(t->setProperty("TriggerKey",
-    //                                (j ? year + "_" + trigKey : "Eff_" + year + "_" + trigKey)),
-    //                 "Failed to set TriggerKey");
-    //      if (electronID != "None") top::check(t->setProperty("IdKey", electronID), "Failed to set IdKey");
-    //      if (electronIsolation != "None") top::check(t->setProperty("IsoKey",
-    //                                                                 electronIsolation), "Failed to set IsoKey");
-    //      top::check(t->setProperty("CorrelationModel", "TOTAL"), "Failed to set CorrelationModel");
-    //      top::check(t->setProperty("ForceDataType",
-    //                                (int) PATCore::ParticleDataType::Full), "Failed to set ForceDataType");
-    //      top::check(t->setProperty("OutputLevel", MSG::INFO), "Failed to set OutputLevel");
-    //      top::check(t->initialize(), "Failed to initalise");
-    //      // Using syntax from examples
-    //      auto& handles = j ? electronSFTools : electronEffTools;
-    //      handles.push_back(t->getHandle());
-    //      std::string name = handles[handles.size() - 1].name();
-    //      legsPerTool[name] = trigKey + " [" + year + "]";
-    //      ATH_MSG_INFO("TIGHT " << name << " -> " << trigKey);
-    //      electronToolNames.push_back(name);
-    //      // Special - Record the systematic names from the efficiency tool (not SF tool)
-    //      if (electronSystematics.size() == 0 && j == 1) {
-    //        for (auto& s :
-    //             handles[handles.size() - 1]->recommendedSystematics().getBaseNames()) electronSystematics.push_back(s);
-
-    //      }
-    //    }
-    //  }
-    //}
-
-    //// Loop over the triggers found (electrons - loose)
-    //nTools = 0;
-    //for (auto& y_t : electronLegsByPeriodLoose) {
-    //  std::string year = y_t.first;
-    //  for (auto& trigKey : y_t.second) {
-    //    nTools++;
-    //    for (int j = 0; j < 2; ++j) { // one tool instance for efficiencies, another for scale factors
-    //      ATH_MSG_INFO("LOOSE " << year << " " << trigKey << " " << electronIDLoose << " " << electronIsolationLoose);
-    //      auto tLoose = m_electronToolsFactoryLoose.emplace(
-    //        m_electronToolsFactoryLoose.end(), "AsgElectronEfficiencyCorrectionTool/ElTrigEffLoose_" + std::to_string(
-    //          j) + "_" + std::to_string(nTools));
-    //      top::check(tLoose->setProperty("MapFilePath",
-    //                                     "ElectronEfficiencyCorrection/2015_2017/rel21.2/Consolidation_September2018_v1/map3.txt"),
-    //                 "Fail");
-    //      top::check(tLoose->setProperty("TriggerKey",
-    //                                     (j ? year + "_" + trigKey : "Eff_" + year + "_" + trigKey)),
-    //                 "Failed to set TriggerKey");
-    //      if (electronIDLoose !=
-    //          "None") top::check(tLoose->setProperty("IdKey", electronIDLoose), "Failed to set IdKey");
-    //      if (electronIsolationLoose != "None") top::check(tLoose->setProperty("IsoKey",
-    //                                                                           electronIsolationLoose),
-    //                                                       "Failed to set IsoKey");
-    //      top::check(tLoose->setProperty("CorrelationModel", "TOTAL"), "Failed to set CorrelationModel");
-    //      top::check(tLoose->setProperty("ForceDataType",
-    //                                     (int) PATCore::ParticleDataType::Full), "Failed to set ForceDataType");
-    //      top::check(tLoose->setProperty("OutputLevel", MSG::INFO), "Failed to set OutputLevel");
-    //      top::check(tLoose->initialize(), "Failed to initalise");
-    //      // Using syntax from examples
-    //      auto& handlesLoose = j ? electronSFToolsLoose : electronEffToolsLoose;
-    //      handlesLoose.push_back(tLoose->getHandle());
-    //      std::string name = handlesLoose[handlesLoose.size() - 1].name();
-    //      legsPerToolLoose[name] = trigKey + " [" + year + "]";
-    //      ATH_MSG_INFO("LOOSE " << name << " -> " << trigKey);
-    //      electronToolNames.push_back(name);
-    //      // Special - Record the systematic names from the efficiency tool (not SF tool)
-    //      if (electronSystematics.size() == 0 && j == 1) {
-    //        for (auto& s :
-    //             handlesLoose[handlesLoose.size() -
-    //                          1]->recommendedSystematics().getBaseNames()) electronSystematics.push_back(s);
-    //      }
-    //    }
-    //  }
-    //}
-
-    //// Create muon trigger SF tool
-    //ToolHandleArray<CP::IMuonTriggerScaleFactors> muonTools;
-    //ToolHandleArray<CP::IMuonTriggerScaleFactors> muonToolsLoose;
-
-    //if (m_config->doTightEvents()) {
-    //  if (muonQuality != "None") top::check(m_muonTool.setProperty("MuonQuality",
-    //                                                               muonQuality), "Failed to set MuonQuality");
-    //  top::check(m_muonTool.setProperty("AllowZeroSF", true), "Failed to set AllowZeroSF");
-    //  top::check(m_muonTool.initialize(), "Failed to initialise");
-    //  muonTools.push_back(m_muonTool.getHandle());
-    //  ATH_MSG_INFO("Muon tool name (tight) " << muonTools[muonTools.size() - 1].name());
-    //  muonToolNames.push_back(muonTools[muonTools.size() - 1].name());
-    //  // Special - Get muon systematics
-    //  if (muonSystematics.size() == 0) {
-    //    for (auto& s:
-    //    muonTools[muonTools.size() - 1]->recommendedSystematics().getBaseNames()) muonSystematics.push_back(s);
-    //  }
-    //}
-
-    //if (m_config->doLooseEvents()) {
-    //  if (muonQualityLoose != "None") top::check(m_muonToolLoose.setProperty("MuonQuality",
-    //                                                                         muonQualityLoose),
-    //    "Failed to set MuonQuality");
-    //  top::check(m_muonToolLoose.setProperty("AllowZeroSF", true), "Failed to set AllowZeroSF");
-    //  top::check(m_muonToolLoose.initialize(), "Failed to initialise");
-    //  muonToolsLoose.push_back(m_muonToolLoose.getHandle());
-    //  ATH_MSG_INFO("Muon tool name (loose) " << muonToolsLoose[muonToolsLoose.size() - 1].name());
-    //  muonToolNames.push_back(muonToolsLoose[muonToolsLoose.size() - 1].name());
-    //  // Special - Get muon systematics
-    //  if (muonSystematics.size() == 0) {
-    //    for (auto& s: muonToolsLoose[muonToolsLoose.size() - 1]->recommendedSystematics().getBaseNames()) muonSystematics.push_back(s);
-    //  }
-    //}
-
-    //for (auto& key : triggersByPeriod) {
-    //  if (triggerCombination.find(key.first) == triggerCombination.end()) {
-    //    triggerCombination[key.first] = "";
-    //  } else {
-    //    triggerCombination[key.first] += " || ";
-    //  }
-    //  triggerCombination[key.first] += boost::algorithm::join(key.second, " || ");
-    //}
-    //for (auto& key : triggersByPeriodLoose) {
-    //  if (triggerCombinationLoose.find(key.first) == triggerCombinationLoose.end()) {
-    //    triggerCombinationLoose[key.first] = "";
-    //  } else {
-    //    triggerCombinationLoose[key.first] += " || ";
-    //  }
-    //  triggerCombinationLoose[key.first] += boost::algorithm::join(key.second, " || ");
-    //}
-
-    //// Print out what we configured
-    //for (auto kv: triggerCombination) ATH_MSG_DEBUG("TRIG (TIGHT): " << kv.first << " -> " << kv.second);
-    //for (auto kv: triggerCombinationLoose) ATH_MSG_DEBUG("TRIG (LOOSE): " << kv.first << " -> " << kv.second);
+    TrigGlobEffCorr::ImportData triggerData;
+    top::check(triggerData.importTriggers(), "failed to import trigger data");
+    auto const& triggerDict = triggerData.getDictionary();
+    std::unordered_map<std::string, TrigGlobEffCorr::ImportData::TrigDef> triggerDefs;
+    for (auto&& kv : triggerData.getTriggerDefs()) {
+      auto it = triggerDict.find(kv.first);
+      if (it != triggerDict.end()) {
+        triggerDefs[it->second] = kv.second;
+      }
+    }
+    auto getTriggerLegs =
+      [&](std::unordered_map<std::string, std::vector<std::string> > const& triggerCombination,
+          std::unordered_map<std::string, std::set<std::string> >& electronLegsByPeriod) {
+        for (auto&& kv : triggerCombination) {
+          std::string const& period = kv.first;
+          for (auto const& trigKey : kv.second) {
+            auto triggerDefsIt = triggerDefs.find(trigKey);
+            if (triggerDefsIt == triggerDefs.end()) {
+              statusCode = StatusCode::FAILURE;
+              ATH_MSG_ERROR("unrecognized trigger `" << trigKey << "'");
+              continue;
+            }
+            auto const& trigDef = triggerDefsIt->second;
+            for (auto const& leg : trigDef.leg) {
+              if (!leg) continue;
+              std::string const& legname = triggerDict.at(leg);
+              bool ok = true;
+              xAOD::Type::ObjectType legtype = triggerData.associatedLeptonFlavour(legname, ok);
+              if (!ok) {
+                statusCode = StatusCode::FAILURE;
+                ATH_MSG_ERROR("could not determine object type for trigger leg `" << legname <<
+                  "'");
+                continue;
+              }
+              switch (legtype) {
+              case xAOD::Type::Electron:
+                electronLegsByPeriod[period].insert(legname);
+                break;
+
+              case xAOD::Type::Muon:
+                break;
+
+              default:
+                statusCode = StatusCode::FAILURE;
+                ATH_MSG_ERROR(
+                  "trigger leg `" << legname << "' has unsupported object type `" << legtype << "'");
+                continue;
+              }
+            }
+          }
+        }
+      };
+
+    // Get trigger strings from configuration
+    std::map<std::string, std::string> triggerCombination, triggerCombinationLoose;
+    std::vector<std::string> electronSystematics, muonSystematics, electronToolNames, muonToolNames;
+    std::unordered_map<std::string, std::vector<std::string> > const emptymap;
+    std::unordered_map<std::string, std::vector<std::string> > const&
+    triggersByPeriod = (m_config->doTightEvents() ? m_config->getGlobalTriggers() : emptymap),
+      triggersByPeriodLoose = (m_config->doLooseEvents() ? m_config->getGlobalTriggersLoose() : emptymap);
+
+    std::unordered_map<std::string, std::set<std::string> > electronLegsByPeriod, electronLegsByPeriodLoose;
+    getTriggerLegs(triggersByPeriod, electronLegsByPeriod);
+    getTriggerLegs(triggersByPeriodLoose, electronLegsByPeriodLoose);
+
+    // Get quality
+    std::string electronID, electronIDLoose, electronIsolation, electronIsolationLoose, muonQuality, muonQualityLoose;
+    if (m_config->doTightEvents()) {
+      electronID = m_config->electronID();
+      electronIsolation = m_config->electronIsolationSF();
+      muonQuality = m_config->muonQuality();
+    }
+    if (m_config->doLooseEvents()) {
+      electronIDLoose = m_config->electronIDLoose();
+      electronIsolationLoose = m_config->electronIsolationSFLoose();
+      muonQualityLoose = m_config->muonQualityLoose();
+    }
+
+    // Tidy name for e/gamma
+    electronID = mapWorkingPoints(electronID);
+    electronIDLoose = mapWorkingPoints(electronIDLoose);
+    // This is hopefully only temporary
+    electronIsolation = mapWorkingPoints(electronIsolation);
+    electronIsolationLoose = mapWorkingPoints(electronIsolationLoose);
+
+    // Create electron trigger SF and Eff tools
+    ToolHandleArray<IAsgElectronEfficiencyCorrectionTool> electronEffTools, electronSFTools, electronEffToolsLoose,
+                                                          electronSFToolsLoose;
+    std::map<std::string, std::string> legsPerTool, legsPerToolLoose;
+    int nTools = 0;
+
+    // Loop over the triggers found (electrons - tight)
+    for (auto& y_t : electronLegsByPeriod) {
+      std::string year = y_t.first;
+      for (auto& trigKey : y_t.second) {
+        nTools++;
+        for (int j = 0; j < 2; ++j) { // one tool instance for efficiencies, another for scale factors
+          ATH_MSG_INFO("TIGHT " << year << " " << trigKey << " " << electronID << " " << electronIsolation);
+          auto t = m_electronToolsFactory.emplace(
+            m_electronToolsFactory.end(), "AsgElectronEfficiencyCorrectionTool/ElTrigEff_" + std::to_string(
+              j) + "_" + std::to_string(nTools));
+          top::check(t->setProperty("MapFilePath",
+                                    "ElectronEfficiencyCorrection/2015_2017/rel21.2/Consolidation_September2018_v1/map3.txt"),
+                     "Fail");
+          top::check(t->setProperty("TriggerKey",
+                                    (j ? year + "_" + trigKey : "Eff_" + year + "_" + trigKey)),
+                     "Failed to set TriggerKey");
+          if (electronID != "None") top::check(t->setProperty("IdKey", electronID), "Failed to set IdKey");
+          if (electronIsolation != "None") top::check(t->setProperty("IsoKey",
+                                                                     electronIsolation), "Failed to set IsoKey");
+          top::check(t->setProperty("CorrelationModel", "TOTAL"), "Failed to set CorrelationModel");
+          top::check(t->setProperty("ForceDataType",
+                                    (int) PATCore::ParticleDataType::Full), "Failed to set ForceDataType");
+          top::check(t->setProperty("OutputLevel", MSG::INFO), "Failed to set OutputLevel");
+          top::check(t->initialize(), "Failed to initalise");
+          // Using syntax from examples
+          auto& handles = j ? electronSFTools : electronEffTools;
+          handles.push_back(t->getHandle());
+          std::string name = handles[handles.size() - 1].name();
+          legsPerTool[name] = trigKey + " [" + year + "]";
+          ATH_MSG_INFO("TIGHT " << name << " -> " << trigKey);
+          electronToolNames.push_back(name);
+          // Special - Record the systematic names from the efficiency tool (not SF tool)
+          if (electronSystematics.size() == 0 && j == 1) {
+            for (auto& s :
+                 handles[handles.size() - 1]->recommendedSystematics().getBaseNames()) electronSystematics.push_back(s);
+
+          }
+        }
+      }
+    }
+
+    // Loop over the triggers found (electrons - loose)
+    nTools = 0;
+    for (auto& y_t : electronLegsByPeriodLoose) {
+      std::string year = y_t.first;
+      for (auto& trigKey : y_t.second) {
+        nTools++;
+        for (int j = 0; j < 2; ++j) { // one tool instance for efficiencies, another for scale factors
+          ATH_MSG_INFO("LOOSE " << year << " " << trigKey << " " << electronIDLoose << " " << electronIsolationLoose);
+          auto tLoose = m_electronToolsFactoryLoose.emplace(
+            m_electronToolsFactoryLoose.end(), "AsgElectronEfficiencyCorrectionTool/ElTrigEffLoose_" + std::to_string(
+              j) + "_" + std::to_string(nTools));
+          top::check(tLoose->setProperty("MapFilePath",
+                                         "ElectronEfficiencyCorrection/2015_2017/rel21.2/Consolidation_September2018_v1/map3.txt"),
+                     "Fail");
+          top::check(tLoose->setProperty("TriggerKey",
+                                         (j ? year + "_" + trigKey : "Eff_" + year + "_" + trigKey)),
+                     "Failed to set TriggerKey");
+          if (electronIDLoose !=
+              "None") top::check(tLoose->setProperty("IdKey", electronIDLoose), "Failed to set IdKey");
+          if (electronIsolationLoose != "None") top::check(tLoose->setProperty("IsoKey",
+                                                                               electronIsolationLoose),
+                                                           "Failed to set IsoKey");
+          top::check(tLoose->setProperty("CorrelationModel", "TOTAL"), "Failed to set CorrelationModel");
+          top::check(tLoose->setProperty("ForceDataType",
+                                         (int) PATCore::ParticleDataType::Full), "Failed to set ForceDataType");
+          top::check(tLoose->setProperty("OutputLevel", MSG::INFO), "Failed to set OutputLevel");
+          top::check(tLoose->initialize(), "Failed to initalise");
+          // Using syntax from examples
+          auto& handlesLoose = j ? electronSFToolsLoose : electronEffToolsLoose;
+          handlesLoose.push_back(tLoose->getHandle());
+          std::string name = handlesLoose[handlesLoose.size() - 1].name();
+          legsPerToolLoose[name] = trigKey + " [" + year + "]";
+          ATH_MSG_INFO("LOOSE " << name << " -> " << trigKey);
+          electronToolNames.push_back(name);
+          // Special - Record the systematic names from the efficiency tool (not SF tool)
+          if (electronSystematics.size() == 0 && j == 1) {
+            for (auto& s :
+                 handlesLoose[handlesLoose.size() -
+                              1]->recommendedSystematics().getBaseNames()) electronSystematics.push_back(s);
+          }
+        }
+      }
+    }
+
+    // Create muon trigger SF tool
+    ToolHandleArray<CP::IMuonTriggerScaleFactors> muonTools;
+    ToolHandleArray<CP::IMuonTriggerScaleFactors> muonToolsLoose;
+
+    if (m_config->doTightEvents()) {
+      if (muonQuality != "None") top::check(m_muonTool.setProperty("MuonQuality",
+                                                                   muonQuality), "Failed to set MuonQuality");
+      top::check(m_muonTool.setProperty("AllowZeroSF", true), "Failed to set AllowZeroSF");
+      top::check(m_muonTool.initialize(), "Failed to initialise");
+      muonTools.push_back(m_muonTool.getHandle());
+      ATH_MSG_INFO("Muon tool name (tight) " << muonTools[muonTools.size() - 1].name());
+      muonToolNames.push_back(muonTools[muonTools.size() - 1].name());
+      // Special - Get muon systematics
+      if (muonSystematics.size() == 0) {
+        for (auto& s:
+        muonTools[muonTools.size() - 1]->recommendedSystematics().getBaseNames()) muonSystematics.push_back(s);
+      }
+    }
+
+    if (m_config->doLooseEvents()) {
+      if (muonQualityLoose != "None") top::check(m_muonToolLoose.setProperty("MuonQuality",
+                                                                             muonQualityLoose),
+        "Failed to set MuonQuality");
+      top::check(m_muonToolLoose.setProperty("AllowZeroSF", true), "Failed to set AllowZeroSF");
+      top::check(m_muonToolLoose.initialize(), "Failed to initialise");
+      muonToolsLoose.push_back(m_muonToolLoose.getHandle());
+      ATH_MSG_INFO("Muon tool name (loose) " << muonToolsLoose[muonToolsLoose.size() - 1].name());
+      muonToolNames.push_back(muonToolsLoose[muonToolsLoose.size() - 1].name());
+      // Special - Get muon systematics
+      if (muonSystematics.size() == 0) {
+        for (auto& s: muonToolsLoose[muonToolsLoose.size() - 1]->recommendedSystematics().getBaseNames()) muonSystematics.push_back(s);
+      }
+    }
+
+    for (auto& key : triggersByPeriod) {
+      if (triggerCombination.find(key.first) == triggerCombination.end()) {
+        triggerCombination[key.first] = "";
+      } else {
+        triggerCombination[key.first] += " || ";
+      }
+      triggerCombination[key.first] += boost::algorithm::join(key.second, " || ");
+    }
+    for (auto& key : triggersByPeriodLoose) {
+      if (triggerCombinationLoose.find(key.first) == triggerCombinationLoose.end()) {
+        triggerCombinationLoose[key.first] = "";
+      } else {
+        triggerCombinationLoose[key.first] += " || ";
+      }
+      triggerCombinationLoose[key.first] += boost::algorithm::join(key.second, " || ");
+    }
+
+    // Print out what we configured
+    for (auto kv: triggerCombination) ATH_MSG_DEBUG("TRIG (TIGHT): " << kv.first << " -> " << kv.second);
+    for (auto kv: triggerCombinationLoose) ATH_MSG_DEBUG("TRIG (LOOSE): " << kv.first << " -> " << kv.second);
 
     // Make the global trigger tool
-//    if (m_config->doTightEvents()) {
-//      TrigGlobalEfficiencyCorrectionTool* globalTriggerEffTool = new TrigGlobalEfficiencyCorrectionTool("TrigGlobalEfficiencyCorrectionTool::TrigGlobal");
-//      top::check(globalTriggerEffTool->setProperty("ElectronEfficiencyTools", electronEffTools), "Failed to attach electron efficiency tools");
-//      top::check(globalTriggerEffTool->setProperty("ElectronScaleFactorTools", electronSFTools), "Failed to attach electron scale factor tools");
-//      top::check(globalTriggerEffTool->setProperty("MuonTools", muonTools), "Failed to attach muon tools");
-//      top::check(globalTriggerEffTool->setProperty("ListOfLegsPerTool", legsPerTool), "Failed to define list of legs per tool");
-//      top::check(globalTriggerEffTool->setProperty("TriggerCombination", triggerCombination), "Failed to define trigger combination");
-//      top::check(globalTriggerEffTool->setProperty("TriggerMatchingTool", m_trigMatchTool), "Failed to set TriggerMatchingTool");
-//      // Setting MSG::ERROR to avoid flooding output with invalid efficiency warnings before event selection is complete
-//      top::check(globalTriggerEffTool->setProperty("OutputLevel", MSG::ERROR), "Failed to set message level");
-//      top::check(globalTriggerEffTool->initialize(), "Failed to initalise");
-//      m_globalTriggerEffTool = globalTriggerEffTool;
-//    }
-//    if (m_config->doLooseEvents()) {
-//      TrigGlobalEfficiencyCorrectionTool* globalTriggerEffToolLoose = new TrigGlobalEfficiencyCorrectionTool("TrigGlobalEfficiencyCorrectionTool::TrigGlobalLoose");
-//      top::check(globalTriggerEffToolLoose->setProperty("ElectronEfficiencyTools", electronEffToolsLoose), "Failed to attach electron efficiency tools");
-//      top::check(globalTriggerEffToolLoose->setProperty("ElectronScaleFactorTools", electronSFToolsLoose), "Failed to attach electron scale factor tools");
-//      top::check(globalTriggerEffToolLoose->setProperty("MuonTools", muonToolsLoose), "Failed to attach muon tools");
-//      top::check(globalTriggerEffToolLoose->setProperty("ListOfLegsPerTool", legsPerToolLoose), "Failed to define list of legs per tool");
-//      top::check(globalTriggerEffToolLoose->setProperty("TriggerCombination", triggerCombinationLoose), "Failed to define trigger combination");
-//      top::check(globalTriggerEffToolLoose->setProperty("TriggerMatchingTool", m_trigMatchTool), "Failed to set TriggerMatchingTool");
-//      // Setting MSG::ERROR to avoid flooding output with invalid efficiency warnings before event selection is complete
-//      top::check(globalTriggerEffToolLoose->setProperty("OutputLevel", MSG::ERROR), "Failed to set message level");
-//      top::check(globalTriggerEffToolLoose->initialize(), "Failed to initalise");
-//      m_globalTriggerEffToolLoose = globalTriggerEffToolLoose;
-//    }
+    if (m_config->doTightEvents()) {
+      TrigGlobalEfficiencyCorrectionTool* globalTriggerEffTool = new TrigGlobalEfficiencyCorrectionTool("TrigGlobalEfficiencyCorrectionTool::TrigGlobal");
+      top::check(globalTriggerEffTool->setProperty("ElectronEfficiencyTools", electronEffTools), "Failed to attach electron efficiency tools");
+      top::check(globalTriggerEffTool->setProperty("ElectronScaleFactorTools", electronSFTools), "Failed to attach electron scale factor tools");
+      top::check(globalTriggerEffTool->setProperty("MuonTools", muonTools), "Failed to attach muon tools");
+      top::check(globalTriggerEffTool->setProperty("ListOfLegsPerTool", legsPerTool), "Failed to define list of legs per tool");
+      top::check(globalTriggerEffTool->setProperty("TriggerCombination", triggerCombination), "Failed to define trigger combination");
+      top::check(globalTriggerEffTool->setProperty("TriggerMatchingTool", m_trigMatchTool), "Failed to set TriggerMatchingTool");
+      // Setting MSG::ERROR to avoid flooding output with invalid efficiency warnings before event selection is complete
+      top::check(globalTriggerEffTool->setProperty("OutputLevel", MSG::ERROR), "Failed to set message level");
+      top::check(globalTriggerEffTool->initialize(), "Failed to initalise");
+      m_globalTriggerEffTool = globalTriggerEffTool;
+    }
+    if (m_config->doLooseEvents()) {
+      TrigGlobalEfficiencyCorrectionTool* globalTriggerEffToolLoose = new TrigGlobalEfficiencyCorrectionTool("TrigGlobalEfficiencyCorrectionTool::TrigGlobalLoose");
+      top::check(globalTriggerEffToolLoose->setProperty("ElectronEfficiencyTools", electronEffToolsLoose), "Failed to attach electron efficiency tools");
+      top::check(globalTriggerEffToolLoose->setProperty("ElectronScaleFactorTools", electronSFToolsLoose), "Failed to attach electron scale factor tools");
+      top::check(globalTriggerEffToolLoose->setProperty("MuonTools", muonToolsLoose), "Failed to attach muon tools");
+      top::check(globalTriggerEffToolLoose->setProperty("ListOfLegsPerTool", legsPerToolLoose), "Failed to define list of legs per tool");
+      top::check(globalTriggerEffToolLoose->setProperty("TriggerCombination", triggerCombinationLoose), "Failed to define trigger combination");
+      top::check(globalTriggerEffToolLoose->setProperty("TriggerMatchingTool", m_trigMatchTool), "Failed to set TriggerMatchingTool");
+      // Setting MSG::ERROR to avoid flooding output with invalid efficiency warnings before event selection is complete
+      top::check(globalTriggerEffToolLoose->setProperty("OutputLevel", MSG::ERROR), "Failed to set message level");
+      top::check(globalTriggerEffToolLoose->initialize(), "Failed to initalise");
+      m_globalTriggerEffToolLoose = globalTriggerEffToolLoose;
+    }
 
     // Set information about systematics inside TopConfig
-//    m_config->setGlobalTriggerConfiguration(electronSystematics, muonSystematics, electronToolNames, muonToolNames);
+    m_config->setGlobalTriggerConfiguration(electronSystematics, muonSystematics, electronToolNames, muonToolNames);
 
     return statusCode;
   }
diff --git a/PhysicsAnalysis/TruthParticleID/McParticleEventTPCnv/src/RootTruthParticleCnvTool.cxx b/PhysicsAnalysis/TruthParticleID/McParticleEventTPCnv/src/RootTruthParticleCnvTool.cxx
index c9e8e9812c65f480758e21b156bd2d48ab3444b5..98fc6fb64fcbe761f6c1dd1d8ac2d250fc404e1b 100644
--- a/PhysicsAnalysis/TruthParticleID/McParticleEventTPCnv/src/RootTruthParticleCnvTool.cxx
+++ b/PhysicsAnalysis/TruthParticleID/McParticleEventTPCnv/src/RootTruthParticleCnvTool.cxx
@@ -71,16 +71,16 @@ RootTruthParticleCnvTool::convert(const McEventCollection *mcCollection,
   container->setGenEvent( mcCollection, genEventIndex );
 
   // reserve enough space for the container so we don't have to relocate it
+#ifdef HEPMC3
+  container->reserve( evt->particles().size() );
+#else
   container->reserve( evt->particles_size() );
+#endif
 
   /// Create a map to enhance access between GenParticles and TruthParticles
   TruthParticleContainer::Map_t bcToMcPart;
 
-  const HepMC::GenEvent::particle_const_iterator itrEnd = evt->particles_end();
-  for ( HepMC::GenEvent::particle_const_iterator itrPart=evt->particles_begin();
-	itrPart != itrEnd;
-	++itrPart ) {
-    const HepMC::GenParticle * hepMcPart = (*itrPart);
+  for ( auto hepMcPart:  *evt) {
 
     TruthParticle * mcPart = new TruthParticle( hepMcPart, container );
     container->push_back( mcPart );
diff --git a/PhysicsAnalysis/TruthParticleID/McParticleTests/src/McAodMcTopAna_solution.cxx b/PhysicsAnalysis/TruthParticleID/McParticleTests/src/McAodMcTopAna_solution.cxx
index b2c94b6e12c4311dac4b81029d4864e3875fad57..11402e4f83f6ddbb4287a4315eb98b2ed1079de9 100644
--- a/PhysicsAnalysis/TruthParticleID/McParticleTests/src/McAodMcTopAna_solution.cxx
+++ b/PhysicsAnalysis/TruthParticleID/McParticleTests/src/McAodMcTopAna_solution.cxx
@@ -210,20 +210,22 @@ StatusCode McTopAnaSolution::doMcTopWb()
   m_vtxFilter->filterMcEventCollection(mcevt, filteredMcEvt);
 
   const HepMC::GenEvent * evtAod = filteredMcEvt->front();
-  for ( HepMC::GenEvent::particle_const_iterator itr = evtAod->particles_begin();
-        itr != evtAod->particles_end();
-        ++itr ) {
-    ATH_MSG_DEBUG("Part. id: " << (*itr)->pdg_id() << endmsg
-                  << "E= "        << (*itr)->momentum().e()
-                  << "\tpx= "     << (*itr)->momentum().px());
+  for ( auto particle:  *evtAod) {
+    ATH_MSG_DEBUG("Part. id: " << particle->pdg_id() << endmsg
+                  << "E= "        << particle->momentum().e()
+                  << "\tpx= "     << particle->momentum().px());
 
     // retrieve the decay vertex of the current particle
-    const HepMC::GenVertex * decayVtx = (*itr)->end_vertex();
+   auto decayVtx = particle->end_vertex();
 
-    if (PDG::t == (*itr)->pdg_id() && //> select top
+    if (PDG::t == particle->pdg_id() && //> select top
         0      !=  decayVtx        && //> check that we have a valid vtx pointer
+#ifdef HEPMC3
+        2      <=  decayVtx->particles_out().size() ) { //> isn't necessary, just to exercize the GenVertex interface
+#else
         2      <=  decayVtx->particles_out_size() ) { //> isn't necessary, just to exercize the GenVertex interface
-      m_h_mctop_mass->Fill( (*itr)->momentum().m() );
+#endif
+      m_h_mctop_mass->Fill( particle->momentum().m() );
     }//> top
   }//> end loop over particles
 
@@ -266,8 +268,8 @@ StatusCode McTopAnaSolution::doMcTopWb()
       // not interested in... Skip it
       continue;
     }
-    const HepMC::GenParticle* hepPart = mc->genParticle();
-    const HepMC::GenVertex* vtx = hepPart->end_vertex();
+    auto hepPart = mc->genParticle();
+    auto vtx = hepPart->end_vertex();
     // Get the W boson
     if ( 0 != vtx &&
          wqqFilter.isAccepted( vtx ) ) {
diff --git a/Projects/AnalysisBase/externals.txt b/Projects/AnalysisBase/externals.txt
index 7f4d60ef9b2c287ef59222023405efa7d4ac1507..9bef68dd7b8d9ce7a1e7dde91de056cc15c86988 100644
--- a/Projects/AnalysisBase/externals.txt
+++ b/Projects/AnalysisBase/externals.txt
@@ -6,4 +6,4 @@
 # forbidden.
 
 # The version of atlas/atlasexternals to use:
-AnalysisBaseExternalsVersion = 2.0.89
+AnalysisBaseExternalsVersion = 2.0.91
diff --git a/Projects/AnalysisBase/version.txt b/Projects/AnalysisBase/version.txt
index 5c95d72232a3900fe95a39c600c6251fc0caba17..d4b369b4e5d8570b7a4ffd09e3e1336fcc9bc5e1 100644
--- a/Projects/AnalysisBase/version.txt
+++ b/Projects/AnalysisBase/version.txt
@@ -1 +1 @@
-22.2.3
+22.2.4
diff --git a/Projects/AthDataQuality/externals.txt b/Projects/AthDataQuality/externals.txt
index 0c594889a0ad3ca6443b115437e1ddd2acef5ca8..bbd29140dc219168b6cc21f800d389236c206ed1 100644
--- a/Projects/AthDataQuality/externals.txt
+++ b/Projects/AthDataQuality/externals.txt
@@ -5,4 +5,4 @@
 # an "origin/" prefix before it. For tags however this is explicitly
 # forbidden.
 
-AtlasExternalsVersion = 2.0.89
+AtlasExternalsVersion = 2.0.91
diff --git a/Projects/AthDataQuality/version.txt b/Projects/AthDataQuality/version.txt
index beb148da6ac7fd229df2a0f84137f6a0de206ba7..138a69a123afacdc587361ce2a55b709ac755878 100644
--- a/Projects/AthDataQuality/version.txt
+++ b/Projects/AthDataQuality/version.txt
@@ -1 +1 @@
-22.0.22
+22.0.23
diff --git a/Projects/AthGeneration/externals.txt b/Projects/AthGeneration/externals.txt
index b8583a418633424eddd94355d0fad69183f35c8c..01fafdea60a6a55cdaf5c771ce053a5e68b60a8a 100644
--- a/Projects/AthGeneration/externals.txt
+++ b/Projects/AthGeneration/externals.txt
@@ -6,4 +6,4 @@
 # forbidden.
 
 # The version of atlas/atlasexternals to use:
-AthGenerationExternalsVersion = 2.0.89
+AthGenerationExternalsVersion = 2.0.91
diff --git a/Projects/AthGeneration/version.txt b/Projects/AthGeneration/version.txt
index beb148da6ac7fd229df2a0f84137f6a0de206ba7..138a69a123afacdc587361ce2a55b709ac755878 100644
--- a/Projects/AthGeneration/version.txt
+++ b/Projects/AthGeneration/version.txt
@@ -1 +1 @@
-22.0.22
+22.0.23
diff --git a/Projects/AthSimulation/externals.txt b/Projects/AthSimulation/externals.txt
index 8a54fbde1930857bfcb8d6d459c0c289d3d62323..69948802cf33ebba34d044f96147edbce5e9767f 100644
--- a/Projects/AthSimulation/externals.txt
+++ b/Projects/AthSimulation/externals.txt
@@ -6,4 +6,4 @@
 # forbidden.
 
 # The version of atlas/atlasexternals to use:
-AthSimulationExternalsVersion = 2.0.89
+AthSimulationExternalsVersion = 2.0.91
diff --git a/Projects/AthSimulation/version.txt b/Projects/AthSimulation/version.txt
index beb148da6ac7fd229df2a0f84137f6a0de206ba7..138a69a123afacdc587361ce2a55b709ac755878 100644
--- a/Projects/AthSimulation/version.txt
+++ b/Projects/AthSimulation/version.txt
@@ -1 +1 @@
-22.0.22
+22.0.23
diff --git a/Projects/Athena/externals.txt b/Projects/Athena/externals.txt
index ca4d89ec730f9e5c7a02c855e28ce398cd94b022..1064a77cbab600769747fc352a714797fa96d3b3 100644
--- a/Projects/Athena/externals.txt
+++ b/Projects/Athena/externals.txt
@@ -6,4 +6,4 @@
 # forbidden.
 
 # The version of atlas/atlasexternals to use:
-AthenaExternalsVersion = 2.0.89
+AthenaExternalsVersion = 2.0.91
diff --git a/Projects/Athena/version.txt b/Projects/Athena/version.txt
index beb148da6ac7fd229df2a0f84137f6a0de206ba7..138a69a123afacdc587361ce2a55b709ac755878 100644
--- a/Projects/Athena/version.txt
+++ b/Projects/Athena/version.txt
@@ -1 +1 @@
-22.0.22
+22.0.23
diff --git a/Projects/VP1Light/externals.txt b/Projects/VP1Light/externals.txt
index 35f49b4e473919a25cda0238348a4e7247b8ea3b..954c138d8e4972e49a53d0931c67af028fffb024 100644
--- a/Projects/VP1Light/externals.txt
+++ b/Projects/VP1Light/externals.txt
@@ -6,4 +6,4 @@
 # forbidden.
 
 # The version of atlas/atlasexternals to use:
-VP1LightExternalsVersion = 2.0.89
+VP1LightExternalsVersion = 2.0.91
diff --git a/Projects/VP1Light/version.txt b/Projects/VP1Light/version.txt
index beb148da6ac7fd229df2a0f84137f6a0de206ba7..138a69a123afacdc587361ce2a55b709ac755878 100644
--- a/Projects/VP1Light/version.txt
+++ b/Projects/VP1Light/version.txt
@@ -1 +1 @@
-22.0.22
+22.0.23
diff --git a/Reconstruction/HeavyIonRec/HIJetRec/src/HIClusterSubtraction.h b/Reconstruction/HeavyIonRec/HIJetRec/src/HIClusterSubtraction.h
index d73a7dff18601fc93737fef358abd42864992cbe..e962a63ccd082ee892494421653205c5dec57292 100644
--- a/Reconstruction/HeavyIonRec/HIJetRec/src/HIClusterSubtraction.h
+++ b/Reconstruction/HeavyIonRec/HIJetRec/src/HIClusterSubtraction.h
@@ -33,7 +33,6 @@
 #include "StoreGate/ReadHandleKey.h"
 #include "StoreGate/WriteHandleKey.h"
 
-#include "xAODCaloEvent/CaloClusterContainer.h"
 #include "xAODHIEvent/HIEventShapeContainer.h"
 
 class HIClusterSubtraction : virtual public asg::AsgTool,
diff --git a/Reconstruction/Jet/JetAnalysisTools/JetAnalysisEDM/Root/LinkDef.h b/Reconstruction/Jet/JetAnalysisTools/JetAnalysisEDM/Root/LinkDef.h
index 6e0b7cf3e818d0b5fc592533d8b2d475a88d5706..3777858997f537b25b9f04e6b4b1fc966079e7ca 100644
--- a/Reconstruction/Jet/JetAnalysisTools/JetAnalysisEDM/Root/LinkDef.h
+++ b/Reconstruction/Jet/JetAnalysisTools/JetAnalysisEDM/Root/LinkDef.h
@@ -16,9 +16,6 @@
 #include "../JetAnalysisEDM/ParticleContainer.h"
 #include "../JetAnalysisEDM/EventObject.h"
 #include "../JetAnalysisEDM/EventManager.h"
-//#include "Math/Vector4D.h"
-
-#include "../JetAnalysisEDM/Utils.h"
 
 #pragma link off all globals;
 #pragma link off all classes;
diff --git a/Reconstruction/Jet/JetEvent/src/Jet.cxx b/Reconstruction/Jet/JetEvent/src/Jet.cxx
index 28b3bbeb2684db1bc9d971bcebcf64fcf4c3aaff..391f54757fb5a400dd64143472e26c6b7c976740 100755
--- a/Reconstruction/Jet/JetEvent/src/Jet.cxx
+++ b/Reconstruction/Jet/JetEvent/src/Jet.cxx
@@ -22,8 +22,6 @@
 //
 ///////////////////////////////////////////////////////////////////////////////
 
-#include <cmath>
-
 // externals
 #include "CLHEP/Units/SystemOfUnits.h"
 #include "CLHEP/Vector/LorentzVector.h"
diff --git a/Reconstruction/Jet/JetEvent/src/JetECS.cxx b/Reconstruction/Jet/JetEvent/src/JetECS.cxx
index 1b94eb575f319cfd11b8f2cb8e7a9054f5d506f1..50e59f12d234766cbfc5193c03c2591f53b52874 100755
--- a/Reconstruction/Jet/JetEvent/src/JetECS.cxx
+++ b/Reconstruction/Jet/JetEvent/src/JetECS.cxx
@@ -14,7 +14,6 @@ June 2004: Modified from CombinedJetSums to use Jet and new Navigation.
 
 #include "JetEvent/JetECS.h"
 #include "JetEvent/Jet.h"
-#include "JetEvent/Jet.h"
 
 
 JetECS::JetECS(double e, double eta, double phi, double m)
diff --git a/Reconstruction/Jet/JetEvent/src/JetINav4MomAssociation.cxx b/Reconstruction/Jet/JetEvent/src/JetINav4MomAssociation.cxx
index d0c0e72852ee8be53afe5734d7af4c623e95705a..639b111165cb62c614abafecaa748129f5b13de0 100644
--- a/Reconstruction/Jet/JetEvent/src/JetINav4MomAssociation.cxx
+++ b/Reconstruction/Jet/JetEvent/src/JetINav4MomAssociation.cxx
@@ -4,8 +4,6 @@
 
 #include "JetEvent/JetINav4MomAssociation.h"
 
-#include "JetEvent/JetINav4MomAssociation.h"
-
 JetINav4MomAssociation::JetINav4MomAssociation()
 {  } 
   
diff --git a/Reconstruction/Jet/JetEvent/src/JetSums.cxx b/Reconstruction/Jet/JetEvent/src/JetSums.cxx
index 051c38f890c4e91101d9c4a9627cf1cc867c200e..1c77af3731707730c2c6df49084a39234bdb81d5 100755
--- a/Reconstruction/Jet/JetEvent/src/JetSums.cxx
+++ b/Reconstruction/Jet/JetEvent/src/JetSums.cxx
@@ -14,7 +14,6 @@ June 2004: Modified from CombinedJetSums to use Jet and new Navigation.
 
 #include "JetEvent/JetSums.h"
 #include "JetEvent/Jet.h"
-#include "JetEvent/Jet.h"
 
 
 JetSums::JetSums(double e, double et, double eta, double phi, double m)
diff --git a/Reconstruction/Jet/JetEventTPCnv/src/JetCnv_p5.cxx b/Reconstruction/Jet/JetEventTPCnv/src/JetCnv_p5.cxx
index 8e3a47580998c9bd0c17f0239164ccba26a24e0e..06f3ad4324b85cbfb23d13df3161cef75e7cda1f 100644
--- a/Reconstruction/Jet/JetEventTPCnv/src/JetCnv_p5.cxx
+++ b/Reconstruction/Jet/JetEventTPCnv/src/JetCnv_p5.cxx
@@ -13,11 +13,6 @@
 // DataModelAthenaPool includes
 #include "DataModelAthenaPool/NavigableCnv_p1.h"
 
-// EventCommonTPCnv includes
-// #include "EventCommonTPCnv/P4ImplPxPyPzECnv_p1.h"
-
-// #include "JetEventTPCnv/JetSignalStateCnv.h"
-
 #include "ParticleEventTPCnv/ParticleBaseCnv_p1.h"
 
 // JetEvent includes
diff --git a/Reconstruction/Jet/JetMomentTools/JetMomentTools/JetForwardJvtTool.h b/Reconstruction/Jet/JetMomentTools/JetMomentTools/JetForwardJvtTool.h
index cf9407b73835d7e8daccd47590afaf71b20317cf..363cd7c4b724759c77a92b43581e37b2733dad97 100644
--- a/Reconstruction/Jet/JetMomentTools/JetMomentTools/JetForwardJvtTool.h
+++ b/Reconstruction/Jet/JetMomentTools/JetMomentTools/JetForwardJvtTool.h
@@ -27,7 +27,6 @@
 #include "xAODTracking/VertexContainer.h"
 #include "xAODMissingET/MissingETContainer.h"
 #include "xAODCaloEvent/CaloCluster.h"
-#include "xAODTracking/VertexContainer.h"
 #include "JetInterface/IJetDecorator.h"
 #include "AsgTools/IAsgTool.h"
 
diff --git a/Reconstruction/Jet/JetMomentTools/JetMomentTools/JetForwardJvtToolBDT.h b/Reconstruction/Jet/JetMomentTools/JetMomentTools/JetForwardJvtToolBDT.h
index 87ba3dd0fc0539556d2bcf305c4a86d9f2b7bad0..300f7db52b4f5ec0d197cd94b7ca622a9be858da 100644
--- a/Reconstruction/Jet/JetMomentTools/JetMomentTools/JetForwardJvtToolBDT.h
+++ b/Reconstruction/Jet/JetMomentTools/JetMomentTools/JetForwardJvtToolBDT.h
@@ -38,7 +38,6 @@
 #include "AsgDataHandles/ReadDecorHandle.h"
 #include "AsgDataHandles/WriteDecorHandleKey.h"
 #include "AsgDataHandles/WriteDecorHandle.h"
-#include "xAODTracking/VertexContainer.h"
 
 
 namespace TMVA{ class Reader; }
diff --git a/Reconstruction/Jet/JetRec/Root/JetClusterer.cxx b/Reconstruction/Jet/JetRec/Root/JetClusterer.cxx
index acad6882e30dce3bb48e9a140bcc405b3336af84..7a4349bd386310fbd6ea732186ac113cf5178f11 100644
--- a/Reconstruction/Jet/JetRec/Root/JetClusterer.cxx
+++ b/Reconstruction/Jet/JetRec/Root/JetClusterer.cxx
@@ -95,18 +95,18 @@ std::pair<std::unique_ptr<xAOD::JetContainer>, std::unique_ptr<SG::IAuxStore> >
   // -----------------------
   // Build the cluster sequence
   fastjet::JetDefinition jetdef(m_fjalg, m_jetrad);
-  fastjet::ClusterSequence *clSequence = nullptr;
+  std::unique_ptr<fastjet::ClusterSequence> clSequence(nullptr);
   bool useArea = m_ghostarea > 0 ;
   if ( useArea ) {
     // Prepare ghost area specifications -------------
     ATH_MSG_DEBUG("Creating input area cluster sequence");
     bool seedsok=true;
     fastjet::AreaDefinition adef = buildAreaDefinition(seedsok);
-    if(seedsok) {clSequence = new fastjet::ClusterSequenceArea(*pseudoJetVector, jetdef, adef);}
+    if(seedsok) {clSequence = std::make_unique<fastjet::ClusterSequenceArea>(*pseudoJetVector, jetdef, adef);}
     else {return nullreturn;}
   } else {
     ATH_MSG_DEBUG("Creating input cluster sequence");
-    clSequence = new fastjet::ClusterSequence(*pseudoJetVector, jetdef);
+    clSequence = std::make_unique<fastjet::ClusterSequence>(*pseudoJetVector, jetdef);
   } 
 
 
@@ -122,41 +122,47 @@ std::pair<std::unique_ptr<xAOD::JetContainer>, std::unique_ptr<SG::IAuxStore> >
     }
   }
 
-  // Let fastjet deal with deletion of ClusterSequence, so we don't need to also put it in the EventStore.
-  clSequence->delete_self_when_unused();
-
-
-  // -------------------------------------
-  // translate to xAOD::Jet
-  ATH_MSG_DEBUG("Converting pseudojets to xAOD::Jet");
-  static SG::AuxElement::Accessor<const fastjet::PseudoJet*> pjAccessor("PseudoJet");
-  PseudoJetTranslator pjTranslator(useArea, useArea);
-  for (const fastjet::PseudoJet &  pj: *pjVector ) {
-    // create the xAOD::Jet from the PseudoJet, doing the signal & ghost constituents extraction
-    xAOD::Jet& jet = pjTranslator.translate(pj, *pjContHandle, *jets);
-
-    // Add the PseudoJet onto the xAOD jet. Maybe we should do it in the above JetFromPseudojet call ??
-    pjAccessor(jet) = &pj;
-
-    jet.setInputType(  xAOD::JetInput::Type( (int) m_inputType) ) ;
-    xAOD::JetAlgorithmType::ID ialg = xAOD::JetAlgorithmType::algId(m_fjalg);
-    jet.setAlgorithmType(ialg);
-    jet.setSizeParameter((float)m_jetrad);
-    if(useArea) jet.setAttribute(xAOD::JetAttribute::JetGhostArea, (float)m_ghostarea);
-
-    ATH_MSG_VERBOSE( "  xAOD::Jet with pt " << std::setprecision(4) << jet.pt()*1e-3 << " has " << jet.getConstituents().size() << " constituents" );
-    ATH_MSG_VERBOSE( "  Leading constituent is of type " << jet.getConstituents()[0].rawConstituent()->type());
-  }
+  // No PseudoJets, so there's nothing else to do
+  // Delete the cluster sequence before we go
+  if(!pjVector->empty()) {
+
+    // Let fastjet deal with deletion of ClusterSequence, so we don't need to also put it in the EventStore.
+    // Release the memory from the unique_ptr
+    clSequence->delete_self_when_unused();
+    clSequence.release();
+
+    // -------------------------------------
+    // translate to xAOD::Jet
+    ATH_MSG_DEBUG("Converting pseudojets to xAOD::Jet");
+    static SG::AuxElement::Accessor<const fastjet::PseudoJet*> pjAccessor("PseudoJet");
+    PseudoJetTranslator pjTranslator(useArea, useArea);
+    for (const fastjet::PseudoJet &  pj: *pjVector ) {
+      // create the xAOD::Jet from the PseudoJet, doing the signal & ghost constituents extraction
+      xAOD::Jet& jet = pjTranslator.translate(pj, *pjContHandle, *jets);
+
+      // Add the PseudoJet onto the xAOD jet. Maybe we should do it in the above JetFromPseudojet call ??
+      pjAccessor(jet) = &pj;
+
+      jet.setInputType(  xAOD::JetInput::Type( (int) m_inputType) ) ;
+      xAOD::JetAlgorithmType::ID ialg = xAOD::JetAlgorithmType::algId(m_fjalg);
+      jet.setAlgorithmType(ialg);
+      jet.setSizeParameter((float)m_jetrad);
+      if(useArea) jet.setAttribute(xAOD::JetAttribute::JetGhostArea, (float)m_ghostarea);
+
+      ATH_MSG_VERBOSE( "  xAOD::Jet with pt " << std::setprecision(4) << jet.pt()*1e-3 << " has " << jet.getConstituents().size() << " constituents" );
+      ATH_MSG_VERBOSE( "  Leading constituent is of type " << jet.getConstituents()[0].rawConstituent()->type());
+    }
 
-  // -------------------------------------
-  // record final PseudoJetVector
-  SG::WriteHandle<PseudoJetVector> pjVectorHandle(m_finalPseudoJets);
-  if(!pjVectorHandle.record(std::move(pjVector))){
-    ATH_MSG_ERROR("Can't record PseudoJetVector under key "<< m_finalPseudoJets);
-    return nullreturn;
+    // -------------------------------------
+    // record final PseudoJetVector
+    SG::WriteHandle<PseudoJetVector> pjVectorHandle(m_finalPseudoJets);
+    if(!pjVectorHandle.record(std::move(pjVector))){
+      ATH_MSG_ERROR("Can't record PseudoJetVector under key "<< m_finalPseudoJets);
+      return nullreturn;
+    }
   }
 
-  ATH_MSG_DEBUG("Reconstructed jet count: " << jets->size() <<  "  clusterseq="<<clSequence);
+  ATH_MSG_DEBUG("Reconstructed jet count: " << jets->size() <<  "  clusterseq="<<clSequence.get());
   // Return the jet container and aux, use move to transfer
   // ownership of pointers to caller
   return std::make_pair(std::move(jets), std::move(auxCont));
diff --git a/Reconstruction/Jet/JetRec/Root/PseudoJetContainer.cxx b/Reconstruction/Jet/JetRec/Root/PseudoJetContainer.cxx
index fe25e4f0d77f0f664ee11dec87acc6b266bdc7bc..449796aacf5631518017cf5a495ab26a179645bb 100644
--- a/Reconstruction/Jet/JetRec/Root/PseudoJetContainer.cxx
+++ b/Reconstruction/Jet/JetRec/Root/PseudoJetContainer.cxx
@@ -14,7 +14,6 @@
 #include <ios>
 #include <iostream>
 #include <exception>
-#include <map>
 
 using fastjet::PseudoJet;
 
diff --git a/Reconstruction/Jet/JetRecTools/Root/LinkDef.h b/Reconstruction/Jet/JetRecTools/Root/LinkDef.h
index 3370efd98964d460d182361e0f9668066537cbfb..3b802d125d2cd747794c065fdde3b1c20191018f 100644
--- a/Reconstruction/Jet/JetRecTools/Root/LinkDef.h
+++ b/Reconstruction/Jet/JetRecTools/Root/LinkDef.h
@@ -11,8 +11,6 @@
 #include <JetRecTools/JetConstituentModifierBase.h>
 #include <JetRecTools/CaloClusterConstituentsOrigin.h>
 #include <JetRecTools/ConstituentSubtractorTool.h>
-#include <JetRecTools/JetConstituentModifierBase.h>
-#include <JetRecTools/JetConstituentModSequence.h>
 #include <JetRecTools/SoftKillerWeightTool.h>
 #include <JetRecTools/VoronoiWeightTool.h>
 #include <JetRecTools/PFlowPseudoJetGetter.h>
diff --git a/Reconstruction/Jet/JetSubStructureUtils/Root/BosonTag.cxx b/Reconstruction/Jet/JetSubStructureUtils/Root/BosonTag.cxx
index 33a3d85d2f34f25a4cc330b5fdfedce590342bcc..dc4fce1fb0fc91a492162d339a9abf14ea44c208 100644
--- a/Reconstruction/Jet/JetSubStructureUtils/Root/BosonTag.cxx
+++ b/Reconstruction/Jet/JetSubStructureUtils/Root/BosonTag.cxx
@@ -3,7 +3,6 @@
 */
 
 #include "JetSubStructureUtils/BosonTag.h"
-#include <iostream>
 
 #ifndef ROOTCORE
 #include "PathResolver/PathResolver.h"
diff --git a/Reconstruction/Jet/JetUncertainties/Root/ELogMassEtaUncertaintyComponent.cxx b/Reconstruction/Jet/JetUncertainties/Root/ELogMassEtaUncertaintyComponent.cxx
index c2464acb0637cfd0cf6dd1002f10ec7c4a77f1e0..35b63b73d789b5ef6f5085488483bde65149e84f 100644
--- a/Reconstruction/Jet/JetUncertainties/Root/ELogMassEtaUncertaintyComponent.cxx
+++ b/Reconstruction/Jet/JetUncertainties/Root/ELogMassEtaUncertaintyComponent.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "JetUncertainties/ELogMassEtaUncertaintyComponent.h"
@@ -57,7 +57,7 @@ bool ELogMassEtaUncertaintyComponent::getValidityImpl(const xAOD::Jet& jet, cons
 
 double ELogMassEtaUncertaintyComponent::getUncertaintyImpl(const xAOD::Jet& jet, const xAOD::EventInfo&) const
 {
-    return m_uncHist->getValue(jet.pt()*m_energyScale,log(getMassOverE(jet,m_massDef)),m_absEta ? fabs(jet.eta()) : jet.eta());
+    return m_uncHist->getValue(jet.e()*m_energyScale,log(getMassOverE(jet,m_massDef)),m_absEta ? fabs(jet.eta()) : jet.eta());
 }
 
 } // end jet namespace
diff --git a/Reconstruction/Jet/JetUncertainties/Root/ELogMassUncertaintyComponent.cxx b/Reconstruction/Jet/JetUncertainties/Root/ELogMassUncertaintyComponent.cxx
index 8908f04b824d83a502d060cc4b54f26ba80d569b..162aa23eeaefe745c178d24999876ce9cdcbf17c 100644
--- a/Reconstruction/Jet/JetUncertainties/Root/ELogMassUncertaintyComponent.cxx
+++ b/Reconstruction/Jet/JetUncertainties/Root/ELogMassUncertaintyComponent.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "JetUncertainties/ELogMassUncertaintyComponent.h"
@@ -49,12 +49,12 @@ ELogMassUncertaintyComponent* ELogMassUncertaintyComponent::clone() const
 
 bool ELogMassUncertaintyComponent::getValidityImpl(const xAOD::Jet& jet, const xAOD::EventInfo&) const
 {
-    return !m_validHist ? true : getValidBool(m_validHist->getValue(jet.pt()*m_energyScale,log(getMassOverE(jet,m_massDef))));
+    return !m_validHist ? true : getValidBool(m_validHist->getValue(jet.e()*m_energyScale,log(getMassOverE(jet,m_massDef))));
 }
 
 double ELogMassUncertaintyComponent::getUncertaintyImpl(const xAOD::Jet& jet, const xAOD::EventInfo&) const
 {
-    return m_uncHist->getValue(jet.pt()*m_energyScale,log(getMassOverE(jet,m_massDef)));
+    return m_uncHist->getValue(jet.e()*m_energyScale,log(getMassOverE(jet,m_massDef)));
 }
 
 } // end jet namespace
diff --git a/Reconstruction/Jet/JetUncertainties/testingMacros/code/CompareCorrelations.C b/Reconstruction/Jet/JetUncertainties/testingMacros/code/CompareCorrelations.C
index d7a57568dc0d7107cbf60316f42605ec85f8cd83..fd0d4b6b4c4c0913230b80b670f07234ae12b7a3 100644
--- a/Reconstruction/Jet/JetUncertainties/testingMacros/code/CompareCorrelations.C
+++ b/Reconstruction/Jet/JetUncertainties/testingMacros/code/CompareCorrelations.C
@@ -15,7 +15,6 @@
 #include "TLatex.h"
 #include "TROOT.h"
 #include "TH2D.h"
-#include "TSystem.h"
 #include "TStyle.h"
 #include "TError.h"
 #include <iostream>
diff --git a/Reconstruction/Jet/JetUncertainties/testingMacros/code/PropagateJES.C b/Reconstruction/Jet/JetUncertainties/testingMacros/code/PropagateJES.C
index e37f01aa858a9823eab6209ab6e2550cfb8e54a5..b3be57fb342803fd6d3486685d4e639dbf1921e7 100644
--- a/Reconstruction/Jet/JetUncertainties/testingMacros/code/PropagateJES.C
+++ b/Reconstruction/Jet/JetUncertainties/testingMacros/code/PropagateJES.C
@@ -16,7 +16,6 @@
 #include "TLatex.h"
 #include "TROOT.h"
 #include "TH2D.h"
-#include "TSystem.h"
 #include "TStyle.h"
 #include "TError.h"
 #include "TRandom.h"
diff --git a/Reconstruction/Jet/JetUtils/Root/JetCaloQualityUtils.cxx b/Reconstruction/Jet/JetUtils/Root/JetCaloQualityUtils.cxx
index e8c0f23ac13f154b55c135d31d461a0c74dfb0ea..80ad32026a9ff0177cf536698785d03beabf2d75 100644
--- a/Reconstruction/Jet/JetUtils/Root/JetCaloQualityUtils.cxx
+++ b/Reconstruction/Jet/JetUtils/Root/JetCaloQualityUtils.cxx
@@ -12,9 +12,6 @@
 #include "CaloGeoHelpers/CaloSampling.h"
 
 
-#include "xAODCaloEvent/CaloCluster.h"
-
-
 using xAOD::Jet;
 using xAOD::CaloCluster;
 
diff --git a/Reconstruction/MET/METReconstruction/python/LegacyRunII/__init__.py b/Reconstruction/MET/METReconstruction/python/LegacyRunII/__init__.py
old mode 100755
new mode 100644
diff --git a/Reconstruction/MissingETGoodness/MissingETGoodness/JetGoodiesFiller.h b/Reconstruction/MissingETGoodness/MissingETGoodness/JetGoodiesFiller.h
index 7051d6a72bc17f0df597127588a5fc823a021433..6f08cc7c2364c9df11492ff9baf645a2a399a25d 100644
--- a/Reconstruction/MissingETGoodness/MissingETGoodness/JetGoodiesFiller.h
+++ b/Reconstruction/MissingETGoodness/MissingETGoodness/JetGoodiesFiller.h
@@ -12,7 +12,6 @@
 
 #include "MissingETGoodness/JetVarTool.h"
 #include "AthenaBaseComps/AthAlgorithm.h"
-#include "GaudiKernel/ToolHandle.h"
 #include "MissingETGoodness/Goodies.h"
 
 #include "TString.h"
diff --git a/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCombinedFitTagTool.cxx b/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCombinedFitTagTool.cxx
index 4e9cd12b48ec4769b9a1e92c284d3ff70d4b0e88..c9b468236d84bcce0a2c680536366f5f9d97f7c2 100644
--- a/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCombinedFitTagTool.cxx
+++ b/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCombinedFitTagTool.cxx
@@ -37,7 +37,6 @@ namespace MuonCombined {
     ATH_MSG_INFO( "Initializing MuonCombinedFitTagTool - package version " << PACKAGE_VERSION );
     
     ATH_CHECK(m_printer.retrieve());
-    ATH_CHECK(m_tagTool.retrieve());
     ATH_CHECK(m_trackBuilder.retrieve());
     if(! m_outwardsBuilder.empty() ) ATH_CHECK(m_outwardsBuilder.retrieve());
     ATH_CHECK(m_trackQuery.retrieve());
@@ -171,7 +170,6 @@ namespace MuonCombined {
     }
     
     if( bestCandidate ){
-      double outerMatchChi2 = 1e19;
       // take the best MS Track, first the update extrapolated, than the extrapolated, last the spectrometer track
       bool haveME=true;
       if( !bestMETrack ){
@@ -181,7 +179,6 @@ namespace MuonCombined {
       }
 
       if( bestCandidate->indetTrackParticle().trackLink().isValid() && bestMETrack ){
-        outerMatchChi2 = m_tagTool->chi2(*bestCandidate->indetTrackParticle().track(),*bestMETrack);
         
         if(msgLevel() >= MSG::DEBUG) {
           dumpCaloEloss(bestCombTrack.get(), " bestCandidate Combined Track ");
@@ -192,7 +189,7 @@ namespace MuonCombined {
       ATH_MSG_DEBUG("Final combined muon: "<<m_printer->print(*bestCombTrack));
       ATH_MSG_DEBUG(m_printer->printStations(*bestCombTrack));
       ATH_MSG_DEBUG("Combined Muon with ID " << m_printer->print(bestCandidate->indetTrackParticle().perigeeParameters())
-        << " match chi2 " << bestTag->matchChi2() << " outer match " << outerMatchChi2 );
+        << " match chi2 " << bestTag->matchChi2());
       combTracks->push_back(bestCombTrack.release());
       ElementLink<TrackCollection> comblink( *combTracks,combTracks->size()-1);
       bestTag->setCombinedTrackLink(comblink);
diff --git a/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCombinedFitTagTool.h b/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCombinedFitTagTool.h
index 0926a88c7cea9058f3686ac8c371da447a8c4b75..17cb7d85fd74bf5454564d01171e30b96316fdb6 100644
--- a/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCombinedFitTagTool.h
+++ b/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCombinedFitTagTool.h
@@ -10,7 +10,6 @@
 #include "GaudiKernel/ServiceHandle.h"
 #include "GaudiKernel/ToolHandle.h"
 
-#include "MuonCombinedToolInterfaces/IMuonTrackTagTool.h"
 #include "TrkTrack/TrackCollection.h"
 #include "TrkParameters/TrackParameters.h"
 #include "TrkSegment/SegmentCollection.h"
@@ -73,7 +72,6 @@ namespace MuonCombined {
     ServiceHandle<Muon::IMuonIdHelperSvc> m_idHelperSvc {this, "MuonIdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"};
 
     ToolHandle<Muon::MuonEDMPrinterTool> m_printer {this, "Printer", "Muon::MuonEDMPrinterTool/MuonEDMPrinterTool"};
-    ToolHandle<MuonCombined::IMuonTrackTagTool> m_tagTool {this, "MuonTrackTagTool", "MuonCombined::MuonTrackTagTestTool/MuonTrackTagTestTool"};
     ToolHandle<Rec::ICombinedMuonTrackBuilder> m_trackBuilder {this, "TrackBuilder", ""};
     ToolHandle<Rec::ICombinedMuonTrackBuilder> m_outwardsBuilder {this, "OutwardsTrackBuilder", ""};
     ToolHandle<Rec::IMuonTrackQuery> m_trackQuery {this, "TrackQuery", "Rec::MuonTrackQuery/MuonTrackQuery"};
diff --git a/Reconstruction/MuonIdentification/MuonCombinedConfig/python/MuonCombinedRecToolsConfig.py b/Reconstruction/MuonIdentification/MuonCombinedConfig/python/MuonCombinedRecToolsConfig.py
index cb2137050e04c9f0e14d3baf9d1e433600844c00..43ca55ae2ff361046f424151abba0266aba0de99 100644
--- a/Reconstruction/MuonIdentification/MuonCombinedConfig/python/MuonCombinedRecToolsConfig.py
+++ b/Reconstruction/MuonIdentification/MuonCombinedConfig/python/MuonCombinedRecToolsConfig.py
@@ -576,8 +576,11 @@ def MuidSegmentRegionRecoveryToolCfg(flags, name ='MuidSegmentRegionRecoveryTool
 
 
 def MuidErrorOptimisationToolCfg(flags, name='MuidErrorOptimisationToolFit', **kwargs ):
-    result = MuonCombinedTrackSummaryToolCfg(flags)
+    from MuonConfig.MuonRecToolsConfig import MuonTrackSummaryHelperToolCfg
+    result = MuonTrackSummaryHelperToolCfg(flags)
     kwargs.setdefault("TrackSummaryTool",  result.popPrivateTools() )
+    tool = CompFactory.Muon.MuonErrorOptimisationTool(name, **kwargs)
+    result.setPrivateTools(tool)
     return result
 
 def MuonAlignmentUncertToolThetaCfg(flags,name ="MuonAlignmentUncertToolTheta", **kwargs):
@@ -690,7 +693,9 @@ def CombinedMuonTrackBuilderCfg(flags, name='CombinedMuonTrackBuilder', **kwargs
     if flags.Muon.enableErrorTuning and 'MuonErrorOptimizer' not in kwargs:
         # use alignment effects on track for all algorithms
 
-        useAlignErrs = True
+        # FIXME - useAlignErrs set to false until MuonAlignmentErrorDBAlg config is available 
+        useAlignErrs = False
+
         # FIXME - handle this.
         #    if conddb.dbdata == 'COMP200' or conddb.dbmc == 'COMP200' or 'HLT' in globalflags.ConditionsTag() or conddb.isOnline or TriggerFlags.MuonSlice.doTrigMuonConfig:
         #         useAlignErrs = False
diff --git a/Reconstruction/Particle/Particle/TrackParticle.h b/Reconstruction/Particle/Particle/TrackParticle.h
index b386a116e5ac57e3463065ae12a3073abe20b0e2..a4a0ee47e1ebef70a9a5944db66706b2c5e038e5 100755
--- a/Reconstruction/Particle/Particle/TrackParticle.h
+++ b/Reconstruction/Particle/Particle/TrackParticle.h
@@ -29,7 +29,6 @@
 #include "TrkTrack/Track.h"
 #include "TrkParameters/TrackParameters.h"
 #include "TrkTrackSummary/TrackSummary.h"
-#include "TrkTrack/TrackCollection.h"
 #include "TrkEventPrimitives/FitQuality.h"
 
 #include "TrkParticleBase/TrackParticleBase.h"
diff --git a/Reconstruction/RecExample/RecExCommission/CMakeLists.txt b/Reconstruction/RecExample/RecExCommission/CMakeLists.txt
deleted file mode 100644
index a2b2d4f2ba5666f617cdc40861e4679bcdc72784..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/CMakeLists.txt
+++ /dev/null
@@ -1,12 +0,0 @@
-################################################################################
-# Package: RecExCommission
-################################################################################
-
-# Declare the package name:
-atlas_subdir( RecExCommission )
-
-# Install files from the package:
-atlas_install_python_modules( python/*.py )
-atlas_install_joboptions( share/*.py )
-atlas_install_scripts( share/RecExCommissionData_links.sh share/RecExCommission_links.sh share/RecExCommissionData_links.csh )
-
diff --git a/Reconstruction/RecExample/RecExCommission/python/__init__.py b/Reconstruction/RecExample/RecExCommission/python/__init__.py
deleted file mode 100644
index a299a56aac03200c5c2005034e19a941eff828b3..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/python/__init__.py
+++ /dev/null
@@ -1,7 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# File RecExCommission/python/__init__.py
-# Author: jamie.boyd@cern.ch
-
-__author__="Jamie Boyd"
-__all__= ["RecExCommission_MagneticFieldConfig"]
diff --git a/Reconstruction/RecExample/RecExCommission/scripts/ec_mon.sh b/Reconstruction/RecExample/RecExCommission/scripts/ec_mon.sh
deleted file mode 100755
index ecc42623225af78681587710b242b43d5f993193..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/scripts/ec_mon.sh
+++ /dev/null
@@ -1,191 +0,0 @@
-#!/bin/bash
-#
-# script to run monitoring on phase 1 commissioning files.
-#
-# 30. Jan. 06   R. Seuster adopt it for online farm
-# 10. Jan. 06   R. Seuster make it run on kit and at CERN
-# 06. Jan. 06   R. Seuster, K. Voss
-#
-# After setting variables depending on the installation of
-# the atlas software, the enviroment and variables steering
-# the job are set in the first part.
-#
-# Next, a short python file with all variables for this job is
-# created.
-#
-# The job is run in its own run directory in the third part.
-#
-
-if [ $# -gt 4 ] ; then
-   echo "Script does not accept more than three parameters!"
-   echo ""
-   echo "usage: ec_mon.sh [runnumber [evtno [ gain [jobOptions.py]]]]"
-   echo "       runnumber     of the file to process (default 18720)"
-   echo "       gain          of the file to process (default HIGH)"
-   echo "       jobOptions.py of the algorithms to run (default RecExCommission_LAr_EC_INSTALLATION_jobOptions.py)"
-   return
-   exit
-fi
-
-##############################################################
-#          first part, general installation setup            #
-#                variables like runnumber                    #
-##############################################################
-
-# this is where your athena release is installed
-#export BASEPATH="/atlas/slc3"
-# at CERN this would be
-export BASEPATH="/afs/cern.ch/atlas/software"
-# P1:
-# export BASEPATH="/space/sw/offline_test"
-
-# which release to run
-ATLAS_RELEASE="11.2.0"
-
-# this is the run directory of the job, please give the absolute path !
-# RUNPATH=${HOME}/Athena/11.2.0-MON
-RUNPATH=${PWD}
-
-# the runnumber to process
-RUNNUMBER="1020"
-
-# the location of the datafiles disc or castor
-DATPATH="/castor/cern.ch/atlas/LargFec/EC_Installation"
-
-#
-EVTNO="10000000"
-
-# the gain of the noisefile
-GAIN=HIGH
-
-# the main joboptions file
-JOBOPTIONFILE=RecExCommission_LAr_EC_INSTALLATION_jobOptions.py
-
-# overwrite, if given on command line
-if [ $# -ge 1 ]; then
- RUNNUMBER="$1"
- shift
-fi
-
-# overwrite, if given on command line
-if [ $# -ge 1 ]; then
- EVTNO="$1"
- shift
-fi
-
-# overwrite, if given on command line
-if [ $# -ge 1 ]; then
- GAIN="$1"
- shift
-fi
-
-# overwrite, if given on command line
-if [ $# -eq 1 ]; then
- JOBOPTIONFILE=$1
- shift
-fi
-
-# construct string containing runnumber including leading 0's
-RUNSTR="`expr substr 0000000 1 \( 7 - length $RUNNUMBER \)`$RUNNUMBER"
-
-# name of logfile
-LOGFILE=logfile.$RUNSTR
-
-# do some basic cross checks, existance of directories and files
-if [ ! -d $RUNPATH ]; then
- echo Your run directory does not exist !!
- echo Please create one with
- echo \"mkdir $RUNPATH \"
- return
- exit
-fi
-
-
-# FILEPATH="${DATPATH}daq_EB-C_${GAIN}_InstPed_${RUNSTR}_file01.data"
-
-# if [ ! -e $FILEPATH ]; then
-#  echo Your datafile does not exist !!
-#  echo Looking for $FILEPATH
-# # return
-# # exit
-# fi
-
-# print out the setup:
-echo "Setting up for"
-echo "Atlas Release : $ATLAS_RELEASE"
-echo " installed in : $BASEPATH"
-echo ""
-echo "The run directory is    : $RUNPATH"
-echo "The data directory is   : $DATPATH"
-echo "The run number is       : $RUNSTR"
-echo "The number of events    : $EVTNO"
-echo "The gain of this run is : $GAIN"
-echo "The main jobOptions are : $JOBOPTIONFILE"
-echo ""
-echo "The output will be in   : $LOGFILE"
-
-# setup the athena enviroment
-
-#if [ ! -e $BASEPATH/$ATLAS_RELEASE/setup.sh ]; then
-#    echo "This AtlasRelease does not exist in this configuration !"
-#    echo $BASEPATH/$ATLAS_RELEASE
-##    return
-##    exit
-#fi
-
-# running at CERN ?
-if [ $BASEPATH = "/afs/cern.ch/atlas/software" ]; then
- source ~/Athena/cmthome/setup.sh -tag=$ATLAS_RELEASE,groupArea
- source ${BASEPATH}/dist/${ATLAS_RELEASE}/Control/AthenaRunTime/*/cmt/setup.sh
-else
- # basic setup and distribution dependent variables
- # source ${BASEPATH}/${ATLAS_RELEASE}/setup.sh
- source ${BASEPATH}/${ATLAS_RELEASE}-MON/setup.sh
- export CMTPATH=${RUNPATH}:${CMTPATH}
- # multiple releases in installation directory ?
- # source ${BASEPATH}/${ATLAS_RELEASE}/dist/${ATLAS_RELEASE}/Control/AthenaRunTime/*/cmt/setup.sh
- source ${BASEPATH}/${ATLAS_RELEASE}-MON/dist/${ATLAS_RELEASE}/Control/AthenaRunTime/*/cmt/setup.sh
- # source ${BASEPATH}/kits/dist/${ATLAS_RELEASE}/Control/AthenaRunTime/*/cmt/setup.sh
-fi
-
-# variables to access the CVS repository at CERN (via ssh)
-# P1:
-# export CVSROOT=:ext:atlas-sw.cern.ch:/atlascvs
-# export CVS_RSH=ssh
-
-
-
-if [ `basename $0` = "ec_mon.sh" ]; then
-
- if [ ! -e $JOBOPTIONFILE ]; then
-  echo No $JOBOPTIONFILE yet !
-  echo Getting it for you
-  get_files $JOBOPTIONFILE
- else
-  echo Using $JOBOPTIONFILE in your run directory !
- fi
- 
- MONDIR=~/scratch0/monitor.run.$RUNSTR
- TOPOPT=myTopOptions.py
- HEREDIR=`pwd` 
-
-
- mkdir -p $MONDIR
- cd $MONDIR
-
-cat <<EOF > $TOPOPT
-
-RunNumber = $RUNNUMBER
-LArDigitKey = "$GAIN"
-EvtNo=$EVTNO
-InputDir = "$DATPATH"
-
-EOF
-
- # now run athena
- echo starting athena
- athena.py -bs $TOPOPT $HEREDIR/$JOBOPTIONFILE >& $LOGFILE
-else
- echo just setting up the enviroment
-fi
-
diff --git a/Reconstruction/RecExample/RecExCommission/scripts/runmon.sh b/Reconstruction/RecExample/RecExCommission/scripts/runmon.sh
deleted file mode 100755
index 36896fafc39a32c55f5ee8291da0ce2cda9ae0d7..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/scripts/runmon.sh
+++ /dev/null
@@ -1,196 +0,0 @@
-#!/bin/bash
-#
-# script to run monitoring on phase 1 commissioning files.
-#
-# 30. Jan. 06   R. Seuster adopt it for online farm
-# 10. Jan. 06   R. Seuster make it run on kit and at CERN
-# 06. Jan. 06   R. Seuster, K. Voss
-#
-# After setting variables depending on the installation of
-# the atlas software, the enviroment and variables steering
-# the job are set in the first part.
-#
-# Next, a short python file with all variables for this job is
-# created.
-#
-# The job is run in its own run directory in the third part.
-#
-
-if [ $# -gt 4 ] ; then
-   echo "Script does not accept more than three parameters!"
-   echo ""
-   echo "usage: runmon.sh [runnumber [evtno [ gain [jobOptions.py]]]]"
-   echo "       runnumber     of the file to process (default 18720)"
-   echo "       gain          of the file to process (default HIGH)"
-   echo "       jobOptions.py of the algorithms to run (default RecExCommission_LAr_EXPERT-WEEK_jobOptions.py)"
-   return
-   exit
-fi
-
-##############################################################
-#          first part, general installation setup            #
-#                variables like runnumber                    #
-##############################################################
-
-# this is where your athena release is installed
-#export BASEPATH="/atlas/slc3"
-# at CERN this would be
-export BASEPATH="/afs/cern.ch/atlas/software"
-# P1:
-# export BASEPATH="/space/sw/offline_test"
-
-# which release to run
-ATLAS_RELEASE="11.2.0"
-
-# this is the run directory of the job, please give the absolute path !
-RUNPATH=${HOME}/scratch0/LArMonRun
-
-# the runnumber to process
-RUNNUMBER="1020"
-
-# the location of the datafiles disc or castor
-# DATPATH="/atlas/LargFec/Installation/"
-DATPATH="/castor/cern.ch/atlas/LargFec/ExpertWeek01"
-# P1:
-# DATPATH="/atlas-home/larmon/hma/data/"
-
-#
-EVTNO="10000000"
-
-# the gain of the noisefile
-GAIN=HIGH
-
-# the main joboptions file
-# JOBOPTIONFILE=RecExCommission_LArPhase1_jobOptions.py
-JOBOPTIONFILE=RecExCommission_LAr_EXPERT-WEEK_jobOptions.py
-
-# overwrite, if given on command line
-if [ $# -ge 1 ]; then
- RUNNUMBER="$1"
- shift
-fi
-
-# overwrite, if given on command line
-if [ $# -ge 1 ]; then
- EVTNO="$1"
- shift
-fi
-
-# overwrite, if given on command line
-if [ $# -ge 1 ]; then
- GAIN="$1"
- shift
-fi
-
-# overwrite, if given on command line
-if [ $# -eq 1 ]; then
- JOBOPTIONFILE=$1
- shift
-fi
-
-# construct string containing runnumber including leading 0's
-RUNSTR="`expr substr 0000000 1 \( 7 - length $RUNNUMBER \)`$RUNNUMBER"
-
-# name of logfile
-LOGFILE=logfile.$RUNSTR
-
-# do some basic cross checks, existance of directories and files
-if [ ! -d $RUNPATH ]; then
- echo Your run directory does not exist !!
- echo Please create one with
- echo \"mkdir $RUNPATH \"
- return
- exit
-fi
-
-if [ ! -d $DATPATH ]; then
- echo Your data directory does not exist !!
- echo $DATPATH
-# return
-# exit
-fi
-
-# FILEPATH="${DATPATH}daq_ROS-1_${GAIN}_InstPed_${RUNSTR}_file01.data"
-
-# if [ ! -e $FILEPATH ]; then
-#  echo Your datafile does not exist !!
-#  echo Looking for $FILEPATH
-# # return
-# # exit
-# fi
-
-# print out the setup:
-echo "Setting up for"
-echo "Atlas Release : $ATLAS_RELEASE"
-echo " installed in : $BASEPATH"
-echo ""
-echo "The run directory is    : $RUNPATH"
-echo "The data directory is   : $DATPATH"
-echo "The run number is       : $RUNSTR"
-echo "The number of events    : $EVTNO"
-echo "The gain of this run is : $GAIN"
-echo "The main jobOptions are : $JOBOPTIONFILE"
-echo ""
-echo "The output will be in   : $LOGFILE"
-
-# setup the athena enviroment
-
-#if [ ! -e $BASEPATH/$ATLAS_RELEASE/setup.sh ]; then
-#    echo "This AtlasRelease does not exist in this configuration !"
-#    echo $BASEPATH/$ATLAS_RELEASE
-##    return
-##    exit
-#fi
-
-# running at CERN ?
-if [ $BASEPATH = "/afs/cern.ch/atlas/software" ]; then
- source ~/cmthome/setup.sh -tag=$ATLAS_RELEASE,groupArea
- source ${BASEPATH}/dist/${ATLAS_RELEASE}/Control/AthenaRunTime/*/cmt/setup.sh
-else
- # basic setup and distribution dependent variables
- # source ${BASEPATH}/${ATLAS_RELEASE}/setup.sh
- source ${BASEPATH}/${ATLAS_RELEASE}-MON/setup.sh
- export CMTPATH=${RUNPATH}:${CMTPATH}
- # multiple releases in installation directory ?
- # source ${BASEPATH}/${ATLAS_RELEASE}/dist/${ATLAS_RELEASE}/Control/AthenaRunTime/*/cmt/setup.sh
- source ${BASEPATH}/${ATLAS_RELEASE}-MON/dist/${ATLAS_RELEASE}/Control/AthenaRunTime/*/cmt/setup.sh
- # source ${BASEPATH}/kits/dist/${ATLAS_RELEASE}/Control/AthenaRunTime/*/cmt/setup.sh
-fi
-
-# variables to access the CVS repository at CERN (via ssh)
-# P1:
-# export CVSROOT=:ext:atlas-sw.cern.ch:/atlascvs
-# export CVS_RSH=ssh
-
-if [ `basename $0` = "runmon.sh" ]; then
-
- if [ ! -e $JOBOPTIONFILE ]; then
-  echo No $JOBOPTIONFILE yet !
-  echo Getting it for you
-  get_files $JOBOPTIONFILE
- else
-  echo Using $JOBOPTIONFILE in your run directory !
- fi
- 
- MONDIR=monitor.run.$RUNSTR
- TOPOPT=myTopOptions.py
- 
- mkdir -p $MONDIR
- cd $MONDIR
-
-cat <<EOF > $TOPOPT
-
-RunNumber = $RUNNUMBER
-LArDigitKey = "$GAIN"
-EvtNo=$EVTNO
-InputDir = "$DATPATH"
-
-EOF
-
- # now run athena
- echo starting athena
- athena.py -bs $TOPOPT ../$JOBOPTIONFILE >& $LOGFILE
-else
- echo just setting up the enviroment
-fi
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/Collisions_ATN.py b/Reconstruction/RecExample/RecExCommission/share/Collisions_ATN.py
deleted file mode 100644
index 8423966e91b09f75ee425f8ee39be7aa8a8a52d8..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/Collisions_ATN.py
+++ /dev/null
@@ -1,312 +0,0 @@
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.BeamFlags import jobproperties
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from AthenaCommon.GlobalFlags import globalflags
-
-if not 'RTTdata' in dir():
-    RTTdata=False
-
-if not 'RTTsim' in dir():
-    RTTsim=False
-
-if not 'ATNsim' in dir():
-        ATNsim=False
-
-if ATNsim:
-    RTTsim=True
-        
-rec.readRDO=False
-
-
-
-#uncomment if read BS
-rec.readRDO=True
-#uncomment if read AOD
-#rec.readAOD=True
-#uncomment if read ESD (note that cosmics DPD are best treated as ESD)
-#rec.readESD=True
-
-# uncomment if reading from TAG (for commissioning one of rec.readESD or rec.readRDO should be true)
-#rec.readTAG=True
-# note that a PoolFileCatalog with the files to navigate to should be available in the run directory
-# note that there is problem 
-
-
-#uncomment if want JiveXML file
-#rec.doJiveXML=True
-
-
-if RTTdata:
-    Input = 'data'
-    
-if RTTsim:    
-    Input = 'simrdo'
-
-if RTTdata or RTTsim:
-    Debug = False
-
-
-
-
-if not 'Input' in dir():
-    # uncomment if input is real data
-    Input='data'
-    # uncomment if input is simulation BS
-    # Input='simbs'
-    # uncomment if input is simulation RDO
-    # Input='simrdo'
-
-if not 'Debug' in dir():
-    Debug=True  # change to True to have printout information
-
-
-#specify beam type (default is "collisions", other values "cosmics" "singlebeam"
-# pick the correct one
-jobproperties.Beam.beamType = 'cosmics'
-# singlebeam not tested recently
-#jobproperties.Beam.beamType = 'singlebeam'
-
-
-
-
-
-
-# input configuration (lock to prevent override)
-# note that if reading from TAG, the input file spec is ignored,
-#   however the flag settings should still be consistent 
-if Input=='data':
-    if rec.readTAG():
-        # read TAG, navigate to ESD
-        athenaCommonFlags.PoolTAGInput=['../cosm/myTAGCOMM.root']
-        athenaCommonFlags.PoolInputQuery.set_Value_and_Lock("TRTTracks>0")
-    if rec.readRDO(): 
-       if jobproperties.Beam.beamType() == 'cosmics':
-           if RTTdata:
-               # this is ignored if TAG are read
-               athenaCommonFlags.BSRDOInput.set_Value_and_Lock(['/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-1._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-1._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-1._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-2._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-2._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-2._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-3._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-3._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-3._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-4._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-4._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-4._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-5._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-5._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-5._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-1._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-1._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-1._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-2._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-2._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-2._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-3._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-3._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-3._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-4._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-4._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-4._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-5._0001.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-5._0002.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0002.SFO-5._0003.data',
-                                                                '/castor/cern.ch/grid/atlas/DAQ/2008/91900/physics_IDCosmic/daq.ATLAS.0091900.physics.IDCosmic.LB0003.SFO-1._0001.data'])
-           else:
-               athenaCommonFlags.BSRDOInput.set_Value_and_Lock(['/afs/cern.ch/user/g/gencomm/w0/RTT_INPUT_DATA/CosmicATN/daq.ATLAS.0091900.physics.IDCosmic.LB0001.SFO-1._0001.10EVTS.data'])
-
-           globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-03-00-00')
-           globalflags.ConditionsTag.set_Value_and_Lock('COMCOND-REPC-001-00')
-           # for running over data with field on need this to be setto true
-           from AthenaCommon.BFieldFlags import jobproperties
-           jobproperties.BField.solenoidOn.set_Value_and_Lock(True)
-           jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-           jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-
-        
-       else:
-           # this is ignored if tag are read
-           athenaCommonFlags.BSRDOInput.set_Value_and_Lock([
-            '/castor/cern.ch/grid/atlas/DAQ/2008/87863/physics_BPTX/daq.NoTag.0087863.physics.BPTX.LB0000.SFO-1._0001.data'])
-           # Detector description #jamie, use version with field (even though solenoid is off)
-
-           globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-04-00-00')
-           globalflags.ConditionsTag.set_Value_and_Lock('COMCOND-REPC-001-00')
-           # for running over data with field on need this to be setto true
-           from AthenaCommon.BFieldFlags import jobproperties
-           jobproperties.BField.solenoidOn.set_Value_and_Lock(False)
-           jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-           jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-        
-       globalflags.InputFormat.set_Value_and_Lock('bytestream')
-
-
-
-    if rec.readAOD():    
-       if rec.readTAG():
-           raise "Cannot have both readAOD and readTAG true"
-       athenaCommonFlags.PoolAODInput.set_Value_and_Lock(["../cosm/myAOD.pool.root"])
-       rec.doWriteAOD=False
-       rec.doWriteESD=False 
-
-    if rec.readESD():    #lxplus225
-        ####L1CaloEM
-        # this is ignored if tags are read
-        athenaCommonFlags.PoolESDInput.set_Value_and_Lock(["../cosm/myESD.pool.root"])
-        rec.doWriteESD=False
-
-    if rec.readESD() or rec.readAOD():
-        globalflags.InputFormat.set_Value_and_Lock('pool')
-        globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-03-00-00')
-        globalflags.ConditionsTag.set_Value_and_Lock('COMCOND-REPC-001-00')
-        from AthenaCommon.BFieldFlags import jobproperties
-        jobproperties.BField.solenoidOn.set_Value_and_Lock(True)
-        jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-        jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-
-
-
-elif Input=='overlay':
-    # not tested recently
-    from LArConditionsCommon.LArCondFlags import larCondFlags
-    larCondFlags.useShape=True
-
-    athenaCommonFlags.PoolRDOInput.set_Value_and_Lock([
-            'singleMuon100plusCosmics.RDO.020162._00002.pool.root'])
-
-    globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-03-00-00')
-    globalflags.ConditionsTag.set_Value_and_Lock('COMCOND-REPC-001-00')
-
-    from AthenaCommon.BFieldFlags import jobproperties
-    jobproperties.BField.solenoidOn.set_Value_and_Lock(True)
-    jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-    jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-
-    globalflags.InputFormat.set_Value_and_Lock('pool')
-    
-else:
-    if Input=='simbs':
-        #beware there might be sthg wrong in these BS files wrt ID cabling
-        athenaCommonFlags.BSRDOInput.set_Value_and_Lock(
-            ["/afs/cern.ch/user/g/gencomm/w0/jboyd/900Gev/BS/daq.0951001._0001.data",
-             "/afs/cern.ch/user/g/gencomm/w0/jboyd/900Gev/BS/daq.0951001._0002.data"])
-        globalflags.InputFormat.set_Value_and_Lock('bytestream')
-        globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-02-01-00')
-        globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIM-00-00-00')
-        doTileCosmicsTrigger=False
-    elif Input=='simrdo':
-
-        if jobproperties.Beam.beamType() == 'cosmics':
-            globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-Comm-02-00-00')
-            athenaCommonFlags.PoolRDOInput.set_Value_and_Lock( ["/afs/cern.ch/atlas/maxidisk/d17/dig.trtbarrel_ma_B100.root"])
-            from AthenaCommon.BFieldFlags import jobproperties
-            jobproperties.BField.solenoidOn=True
-            jobproperties.BField.barrelToroidOn=True
-            jobproperties.BField.endcapToroidOn=True
-            SpecialTileConfigHack=True
-            globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-CSC-01-00-00')
-
-        if jobproperties.Beam.beamType() == 'singlebeam':
-            athenaCommonFlags.PoolRDOInput.set_Value_and_Lock( ["/afs/cern.ch/user/g/gencomm/w0/RTT_INPUT_DATA/BeamGas/hijing.O.digit._00430.pool.root"])
-            globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-CSC-01-02-00')
-            from AthenaCommon.BFieldFlags import jobproperties
-            jobproperties.BField.solenoidOn=True
-            jobproperties.BField.barrelToroidOn=True
-            jobproperties.BField.endcapToroidOn=True
-            
-        else:
-            athenaCommonFlags.PoolRDOInput.set_Value_and_Lock(
-                ["castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._00001.pool.root.1",
-                 "castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._00002.pool.root.1",
-                 "castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._00003.pool.root.1",    
-                 "castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._00004.pool.root.1",
-                 "castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._00005.pool.root.1",
-                 "castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._00006.pool.root.1",
-                 "castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._00007.pool.root.1",
-                 "castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._00008.pool.root.1",
-                 "castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._00009.pool.root.1",
-                 "castor:/castor/cern.ch/user/i/ivivarel/900GeVminbias/RDO.024944._000010.pool.root.1"])         
-
-            globalflags.InputFormat.set_Value_and_Lock('pool')
-#            globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-02-01-00')
-#            globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIM-00-00-00')
-        # crashing :  No valid proxy for object TileTTL1CosmicsCnt  of type TileTTL1Container(CLID 2933)
-            doTileCosmicsTrigger=False
-
-    else:
-      raise RuntimeError,"Wrong Input value"
-
-    globalflags.DataSource.set_Value_and_Lock('geant4')    
-    #doTileCosmicsTrigger=False
-
-#hardcoded output specification (corresponds to optional flags from runArgs in transform skeleton)
-rec.RootNtupleOutput.set_Value_and_Lock("commission.ntuple.root")
-athenaCommonFlags.PoolESDOutput.set_Value_and_Lock("commissionESD.pool.root")
-rec.RootHistoOutput.set_Value_and_Lock("monitoring.root")
-if RTTdata or RTTsim:
-    if not ATNsim:
-        athenaCommonFlags.EvtMax.set_Value_and_Lock(500)
-    else:
-        athenaCommonFlags.EvtMax.set_Value_and_Lock(10)
-        
-else:
-    athenaCommonFlags.EvtMax.set_Value_and_Lock(10)
-#athenaCommonFlags.SkipEvents = 0
-
-
-if RTTsim:
-    rec.doHist=False
-else:
-    rec.doHist = True
-
-rec.doWriteTAG.set_Value_and_Lock(False)	
-rec.doWriteAOD=False
-rec.doAOD=False
-if RTTsim or Input=='overlay' or rec.readAOD():
-    rec.doMonitoring.set_Value_and_Lock(False)
-else:
-    rec.doMonitoring.set_Value_and_Lock(True)    
-
-if Input=='overlay':
-   topSequence.LArRawChannelBuilder.DataLocation = "LArDigitContainer_MC_Thinned"
-   topSequence.CBNT_AthenaAware.CBNTAA_LArDigits.ContainerKey = "LArDigitContainer_MC_Thinned"
-   ServiceMgr.MboySvc.UseAllSegments=0 # standard way to run Muonboy on collisions
-   topSequence.LArDigitThinner.Enable = False
-   topSequence.TileDigitsFilter.Enable = False
-
-if Debug:
-    # DEBUG/VERBOSE options
-    rec.doNameAuditor=True
-    rec.doPerfMon=True
-    rec.doDetailedPerfMon=True
-    rec.doDumpProperties=True
-    rec.doDumpTES=True
-    # rec.OutputLevel = INFO
-
-
-include("RecExCommission/RecExCommissionRepro.py")                
-
-# filtered ESD calib and tracking ntuple if from RDO
-if rec.readRDO():
-    from AthenaMonitoring.DQMonFlags import DQMonFlags
-    DQMonFlags.histogramFile.set_Value_and_Lock( "myMonitoring.root" )
-
-    #crashing in 14.5.X VAL 2 3 Feb
-    include("TrigT1CTMonitoring/CTPFlags.py")
-    CTPFlags.doCTRDO=False
-
-if RTTsim:
-    rec.doTrigger=False
-
-#FIXME very temporary, crashing
-#if rec.doJiveXML():
-#    include.block("TrigJiveXML/TrigJiveXML_DataTypes.py")
-
-
-include("RecExCommon/RecExCommon_topOptions.py")                
-
-if Debug:
-    from IOVDbSvc.CondDB import conddb
-    conddb.dumpFolderTags('iovfolderlist.txt',True)
diff --git a/Reconstruction/RecExample/RecExCommission/share/CombinedMuonFit_jobOptions.py b/Reconstruction/RecExample/RecExCommission/share/CombinedMuonFit_jobOptions.py
deleted file mode 100644
index 0fbf5498db6d3776037ccbc8e93faef780e542c9..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/CombinedMuonFit_jobOptions.py
+++ /dev/null
@@ -1,49 +0,0 @@
-from TrkGlobalChi2Fitter.TrkGlobalChi2FitterConf import Trk__GlobalChi2Fitter
-GlobalChi2FitterComb=Trk__GlobalChi2Fitter(name='GlobalChi2FitterComb',
-                                       StraightLine=not jobproperties.BField.solenoidOn(),
-                                       ExtrapolationTool=InDetExtrapolator,
-                                       NavigatorTool = InDetNavigator,
-                                       PropagatorTool = InDetPropagator,
-                                       RotCreatorTool = InDetRotCreator,
-                                       OutlierCut = 5.,
-                                       ExternalMat = True,
-                                       sortingReferencePoint = [0,25000,0])
-
-ToolSvc += GlobalChi2FitterComb
-
-print(GlobalChi2FitterComb)
-
-from CombinedMuonRefit.CombinedMuonRefitConf import ReFitMuon
-MuonReFitTrack2 = ReFitMuon (name = "CombMuonRefit",
-                             FitterTool     = GlobalChi2FitterComb,
-                             Cosmics=True,
-                             IDTrackName="Tracks",
-                             MSTrackName="MooreTracks",
-                             matEffects=0,
-                             runOutlier=False,
-                             NewTrackName="Combined_Tracks",
-                             OutputLevel=3)
-
-topSequence += MuonReFitTrack2
-print(MuonReFitTrack2)
-
-#GlobalChi2FitterBarrel.OutputLevel=1
-#GlobalChi2FitterBarrel.NumericalDerivs=True
-#MdtDriftCircleOnTrackCreator = Service( "ToolSvc.Muon::MdtDriftCircleOnTrackCreator" )
-#MdtDriftCircleOnTrackCreator.CreateTubeHit = True
-#MdtDriftCircleOnTrackCreator.OutputLevel=1
-#MdtTubeHitOnTrackCreator = Service( "ToolSvc.Muon::MdtTubeHitOnTrackCreator" )
-#MdtTubeHitOnTrackCreator.CreateTubeHit = True
-#MdtTubeHitOnTrackCreator.OutputLevel=1
-
-
-#mooretotracktool=Service("ToolSvc.Muon::MooreToTrackTool")
-#mooretotracktool.OutputLevel=1
-
-#ToolSvc.TrackFitter.OutputLevel=1
-#ToolSvc.GlobalChi2FitterBarrel.LayerCreatorTool="Trk::MuidDynamicLayerCreator/MuidDynamicLayerCreator"
-#ToolSvc.GlobalChi2FitterBarrel.ExternalMat=True
-#ToolSvc.GlobalChi2FitterBarrel.Momentum=5000
-#ToolSvc.MuidDynamicLayerCreator.Cosmics=True
-#MuonReFitTrack2.OutputLevel=1
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/CosmicSimulationRecoSetup-HLT.py b/Reconstruction/RecExample/RecExCommission/share/CosmicSimulationRecoSetup-HLT.py
deleted file mode 100644
index 6a6c1e12d9b4f75f992979ea2246fb15a17c6243..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/CosmicSimulationRecoSetup-HLT.py
+++ /dev/null
@@ -1,56 +0,0 @@
-LArDigitKey='FREE'
-
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.DetGeo = 'commis'
-globalflags.DataSource.set_Value_and_Lock('geant4')
-
-from RecExConfig.RecFlags import rec
-rec.Commissioning.set_Value_and_Lock(True)
-rec.oldFlagTopSteering.set_Value_and_Lock(False)
-#rec.doTruth.set_Value_and_Lock(False)
-#rec.doJiveXML.set_Value_and_Lock(True)
-
-if rec.readRDO :
-    rec.doTrigger.set_Value_and_Lock(True)
-    from TriggerJobOpts.TriggerFlags import TriggerFlags as tf
-    #####for l1 simulation configuration
-    tf.doCosmicSim.set_Value_and_Lock(True)
-    #############
-    tf.readLVL1configFromXML.set_Value_and_Lock(True)
-    tf.readHLTconfigFromXML.set_Value_and_Lock(True)
-
-    tf.triggerMenuSetup.set_Value_and_Lock('cosmic_default')
-
-
-# for running over data with field on need this to be setto true
-from AthenaCommon.BFieldFlags import jobproperties
-
-# set the field properties based on DetDescrVersion
-if globalflags.DetDescrVersion.get_Value().find('ATLAS-GEONSF-') >= 0 :
-    jobproperties.BField.solenoidOn.set_Value_and_Lock(False)
-    jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-    jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-    globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIMCT-00-00-00')
-    print('configuring reco with solenoid off, toroid on from DetDescrVersion:',globalflags.DetDescrVersion.get_Value())
-    
-if globalflags.DetDescrVersion.get_Value().find('ATLAS-GEO-') >= 0 :
-    jobproperties.BField.solenoidOn.set_Value_and_Lock(True)
-    jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-    jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-    globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIMCST-00-00-00')
-    print('configuring reco with solenoid on, toroid on from DetDescrVersion:',globalflags.DetDescrVersion.get_Value())
-    
-if globalflags.DetDescrVersion.get_Value().find('ATLAS-GEONF-') >= 0 :
-    jobproperties.BField.solenoidOn.set_Value_and_Lock(False)
-    jobproperties.BField.barrelToroidOn.set_Value_and_Lock(False)
-    jobproperties.BField.endcapToroidOn.set_Value_and_Lock(False)
-    globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIMC-00-00-00')
-    print('configuring reco with solenoid off, toroid off from DetDescrVersion:',globalflags.DetDescrVersion.get_Value())
-        
-if globalflags.DetDescrVersion.get_Value().find('ATLAS-GEONTF-') >= 0 :
-    jobproperties.BField.solenoidOn.set_Value_and_Lock(True)
-    jobproperties.BField.barrelToroidOn.set_Value_and_Lock(False)
-    jobproperties.BField.endcapToroidOn.set_Value_and_Lock(False)
-    globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIMCS-00-00-00')
-    print('configuring reco with solenoid on, toroid off from DetDescrVersion:',globalflags.DetDescrVersion.get_Value())
- 
diff --git a/Reconstruction/RecExample/RecExCommission/share/CosmicSimulationRecoSetup.py b/Reconstruction/RecExample/RecExCommission/share/CosmicSimulationRecoSetup.py
deleted file mode 100644
index 0065ac4c43541643a9ecac53527ffbccb9512af1..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/CosmicSimulationRecoSetup.py
+++ /dev/null
@@ -1,63 +0,0 @@
-LArDigitKey='FREE'
-
-from AthenaCommon.GlobalFlags import globalflags
-globalflags.DetGeo = 'commis'
-globalflags.DataSource.set_Value_and_Lock('geant4')
-
-from RecExConfig.RecFlags import rec
-rec.Commissioning.set_Value_and_Lock(True)
-rec.oldFlagTopSteering.set_Value_and_Lock(False)
-#rec.doTruth.set_Value_and_Lock(False)
-#rec.doJiveXML.set_Value_and_Lock(True)
-
-if rec.readRDO :
-    rec.doTrigger.set_Value_and_Lock(True)
-    from TriggerJobOpts.TriggerFlags import TriggerFlags as tf
-    #####for l1 simulation configuration
-    tf.doCosmicSim.set_Value_and_Lock(True)
-    #############
-    tf.readLVL1configFromXML.set_Value_and_Lock(True)
-    tf.readHLTconfigFromXML.set_Value_and_Lock(True)
-
-    tf.triggerMenuSetup.set_Value_and_Lock('Cosmic2009_v1')
-
-    # This will need to be changed when things work better
-    tf.inputLVL1configFile.set_Value_and_Lock('TriggerMenuXML/LVL1config_Cosmic2009_v1_7-bit_trigger_types.xml')
-
-globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-07-00-00')
-#globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-CSC-01-00-00')
-
-# for running over data with field on need this to be setto true
-from AthenaCommon.BFieldFlags import jobproperties
-
-# set the field properties based on DetDescrVersion
-if globalflags.DetDescrVersion=='ATLAS-GEONSF-07-00-00':
-    jobproperties.BField.solenoidOn.set_Value_and_Lock(False)
-    jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-    jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-    globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIMCT-00-00-00')
-    print('configuring reco with solenoid off, toroid on from DetDescrVersion: ATLAS-GEONSF-07-00-00')
-    
-if globalflags.DetDescrVersion=='ATLAS-GEO-07-00-00':
-    jobproperties.BField.solenoidOn.set_Value_and_Lock(True)
-    jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-    jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-    globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIMCST-00-00-00')
-    print('configuring reco with solenoid on, toroid on from DetDescrVersion: ATLAS-GEO-07-00-00')
-    
-if globalflags.DetDescrVersion=='ATLAS-GEONF-07-00-00':
-    jobproperties.BField.solenoidOn.set_Value_and_Lock(False)
-    jobproperties.BField.barrelToroidOn.set_Value_and_Lock(False)
-    jobproperties.BField.endcapToroidOn.set_Value_and_Lock(False)
-    globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIMC-00-00-00')
-    print('configuring reco with solenoid off, toroid off from DetDescrVersion: ATLAS-GEONF-07-00-00')
-        
-if globalflags.DetDescrVersion=='ATLAS-GEONTF-07-00-00':
-    jobproperties.BField.solenoidOn.set_Value_and_Lock(True)
-    jobproperties.BField.barrelToroidOn.set_Value_and_Lock(False)
-    jobproperties.BField.endcapToroidOn.set_Value_and_Lock(False)
-    globalflags.ConditionsTag.set_Value_and_Lock('OFLCOND-SIMCS-00-00-00')
-    print('configuring reco with solenoid on, toroid off from DetDescrVersion: ATLAS-GEONTF-07-00-00')
-                            
-
-                                                
diff --git a/Reconstruction/RecExample/RecExCommission/share/Cosmics_ATN.py b/Reconstruction/RecExample/RecExCommission/share/Cosmics_ATN.py
deleted file mode 100644
index ef982d6c550caf4caa97c0e7a7cf01fac3e1f039..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/Cosmics_ATN.py
+++ /dev/null
@@ -1,5 +0,0 @@
-from AthenaCommon.BeamFlags import jobproperties
-jobproperties.Beam.beamType.set_Value_and_Lock("cosmics")
-# the main jobOpt
-include("RecExCommission/Collisions_ATN.py")                
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/GetInputFiles.py b/Reconstruction/RecExample/RecExCommission/share/GetInputFiles.py
deleted file mode 100644
index a1528d067bc3949e2daaa25fa69679cce279128f..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/GetInputFiles.py
+++ /dev/null
@@ -1,24 +0,0 @@
-from os import popen
-
-def GetInputFiles(inputPath,filePattern):
-    print("Searching for files with pattern '",filePattern,"' in ",inputPath)
-    fileList=[]
-    if (inputPath[0:8]=='/castor/'):
-        cmd='nsls'
-    else:
-        cmd='ls -1'
-
-    for f in popen("%(cmd)s %(path)s | grep '%(pattern)s'" \
-                   % {'cmd':cmd,'path':inputPath,'pattern':filePattern}):
-        if f[len(f)-1:]=='\n':
-            f=f[0:len(f)-1]
-        fileList+=[inputPath+'/'+f]
-    print("Found ",len(fileList), " files")
-    return fileList
-    
-
-def GetInputFilesFromTokens(inputPath,runnumber,prefix=".*",trigger=".*"):
-    #pattern=prefix+"\.00"+str(runnumber)+"\..*"
-    pattern="%(prefix)s.*%(rn)07d.%(trig)s.*" % {'prefix' : prefix ,'rn' : runnumber,'trig' : trigger}
-    
-    return GetInputFiles(inputPath,pattern)
diff --git a/Reconstruction/RecExample/RecExCommission/share/NoRandomTrig.py b/Reconstruction/RecExample/RecExCommission/share/NoRandomTrig.py
deleted file mode 100644
index 39ef526a7ce5ad14ac95a060c2a104b5693a14cc..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/NoRandomTrig.py
+++ /dev/null
@@ -1,5 +0,0 @@
-#Random trigger off for reproducibility
-from TrigSteering.TrigSteeringConfig import ScalerSvc
-ScalerSvc = ScalerSvc()
-ScalerSvc.DefaultType = "HLT::PeriodicScaler"
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommission.py b/Reconstruction/RecExample/RecExCommission/share/RecExCommission.py
deleted file mode 100644
index 9bdbdae43cdd53235ff7a6cd5a48aa33322aa30f..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommission.py
+++ /dev/null
@@ -1,21 +0,0 @@
-include("RecExCommission/MinimalCommissioningSetup.py")
-
-# not needed anymore (RS, Dec. 6th 2010)
-# needed to get TRT track extension working
-# from TrkDetDescrSvc.TrkDetDescrJobProperties import TrkDetFlags
-# TrkDetFlags.TRT_BuildStrawLayers.set_Value(True)
-
-# setup trigger reading from COOL (obo Clemencia)
-if rec.doTrigger():
-    from TriggerJobOpts.TriggerFlags import TriggerFlags as tf
-    tf.configForStartup="HLTonline"
-    tf.configForStartup.lock()
-
-from RecExConfig.RecFlags  import rec
-rec.ScopingLevel.set_Value_and_Lock(1)
-# done in the trf
-# rec.Production=True
-
-#from LArConditionsCommon.LArCondFlags import larCondFlags
-#larCondFlags.LArCoolChannelSelection.set_Value_and_Lock("3:238,306,313,319,325,331,338,344,350,1001:1012,1021,1022")
-#larCondFlags.OFCShapeFolder.set_Value_and_Lock('5samples3bins17phases') 
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionCommonFlags_jobOptions.py b/Reconstruction/RecExample/RecExCommission/share/RecExCommissionCommonFlags_jobOptions.py
deleted file mode 100644
index d08ce74f2f95f2befd5268406faa51e63801e316..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionCommonFlags_jobOptions.py
+++ /dev/null
@@ -1,200 +0,0 @@
-# ---------------------------------------------------------------------------
-# RecExCommon flags
-# ---------------------------------------------------------------------------
-
-include.block("RecExCommission/RecExCommissionCommonFlags_jobOptions.py")
-
-
-# ---------------------------------------------------------------------------
-# AthenaCommonFlags
-# ---------------------------------------------------------------------------
-
-# start using the new job properties
-from AthenaCommon.JobProperties import jobproperties
-
-# AthenaCommon flags
-from AthenaCommon.AthenaCommonFlags  import athenaCommonFlags
-
-# -----------------------------------------------------------------------
-# being general reconstruction flags
-# -----------------------------------------------------------------------
-from RecExConfig.RecFlags  import jobproperties, rec
-
-#Number of events to process or generate
-athenaCommonFlags.EvtMax=10
-# Number of events to skip when reading an input POOL file.
-athenaCommonFlags.SkipEvents = 0
-# The list of input POOL files containing collections of Raw data objects
-# ['myfile.pool.root'] : file in run directory
-# ['LFN:mylogicalfile.root']: logical file name as specified in PoolFileCatalog.cml
-# ['rfio:/castor/cern.ch/somepath/somefile.pool.root']:file on castor (at CERN)
-athenaCommonFlags.PoolRDOInput = ["/afs/cern.ch/atlas/maxidisk/d17/data/TileTest/dig.05AprProd-10000000.root"]
-# The list of input ByteStream files containing collections of Raw data objects
-#athenaCommonFlags.BSRDOInput = ["/castor/cern.ch/grid/atlas/t0/perm/DAQ/daq.m4_combined.0019783.Default.L1TT-b00000001.LB0001.SFO-1._0001.data"]
-athenaCommonFlags.BSRDOInput = ["/castor/cern.ch/grid/atlas/t0/perm/DAQ/daq.m4_combined.0020720.debug.L1TT-b00000001.LB0000.SFO-1._0001.data"]
-#athenaCommonFlags.BSRDOInput = ["/castor/cern.ch/grid/atlas/DAQ/M6/daq.NoTag.0043719.physics.HLT_Cosmic_AllTeIDSelected.LB0000.SFO-1._0001.data"]
-# The list of input POOL files containing collections of ESD objects
-athenaCommonFlags.PoolESDInput = ["castor:/castor/cern.ch/grid/atlas/t0/perm/M4reproc/0020720/FESD/M4.0020720.physics.L1TT-b00000010.FESD.v130026.part0001._lumi0002._0001.1"]
-# The name of the output POOL file containing collections of ESD objects
-athenaCommonFlags.PoolESDOutput = "ESD.root"
-# The list of input POOL files containing collections of TAGs
-#athenaCommonFlags.PoolTAGInput = "TAG.root"
-# The name of the output POOL file containing collections of TAGs
-athenaCommonFlags.PoolTAGOutput = "TAG.root" 
-rec.PoolTAGCOMOutput="TAGCOM.root"
-athenaCommonFlags.PoolInputQuery = "TRT_Cosmic_Tracks"
-#AllowIgnoreExistingDataObject
-#AllowIgnoreConfigError
-#athenaCommonFlags.AthenaCommonFlags
-
-# -----------------------------------------------------------------------
-# GlobalFlags
-# -----------------------------------------------------------------------
-
-# GlobalFlags 
-from AthenaCommon.GlobalFlags import globalflags
-
-# Which detector configuration : atlas, combined test beam or commisisoning
-# Commissioning: 'commis'
-globalflags.DetGeo = 'commis'
-# Detector geometry DB tag
-globalflags.DetDescrVersion="ATLAS-CommNF-04-00-00"
-# data source: Where does the data comes from : real data, geant3 or geant4
-# real data: data
-# simulation: 'geant4'
-globalflags.DataSource = 'data'
-# Input format:
-# to read from BS: 'bytestream'
-# to read from ESD, RDO Pool files = 'pool'
-globalflags.InputFormat = 'bytestream'
-
-# ---------------------------------------------------------------------------
-# Beam flags to define the 
-# ---------------------------------------------------------------------------
-# Type of data to reconstruct: 'singlebeam','cosmics'
-from AthenaCommon.BeamFlags import jobproperties
-#jobproperties.Beam.beamType.set_Value_and_Lock("cosmics")
-
-
-# ---------------------------------------------------------------------------
-# BField flags to define the
-# ---------------------------------------------------------------------------
-# Field configuration: solenoidOn()   barrelToroidOn() endcapToroidOn()
-from AthenaCommon.BFieldFlags import jobproperties
-jobproperties.BField.solenoidOn=False
-jobproperties.BField.barrelToroidOn=False
-jobproperties.BField.endcapToroidOn=False
-
-# -----------------------------------------------------------------------
-# flags to drive the general behaviour of Reconstruction configuration
-# -----------------------------------------------------------------------
-#from RecExConfig.RecConfFlags import recConfFlags
-
-
-#RecConfFlags.AllowDisable
-#RecConfFlags.AllowIgnoreConfigError	
-#RecConfFlags.AllowIgnoreExistingDataObject	
-#RecConfFlags.RecConfFlags
-
-rec.CBNTAthenaAware = True	
-rec.doAOD = False
-#rec.doAODall	
-#rec.doAODCaloCells	
-rec.doCBNT = True	
-#rec.doCheckDictionary	
-#rec.doCheckJOT	
-#rec.doDetailedAuditor	
-#rec.doDumpMC	
-#rec.doDumpPoolInputContent	
-#rec.doDumpProperties	
-#rec.doDumpTDS	
-#rec.doDumpTES	
-#rec.doEdmMonitor	
-#rec.doESD = True
-# rec.doFileMetaData TODO might replace doDetStatus???
-rec.doDetStatus = True
-#rec.doFloatingPointException	
-#rec.doHeavyIon	
-rec.doHist = True
-rec.doJiveXML = False	
-#rec.doLowPt	
-#rec.doMinimalRec	
-#rec.doNameAuditor	
-#rec.doPerfMon = False
-rec.doPersint = False	
-#rec.doRestrictedESD	
-#rec.doSGAuditor	
-#rec.doShowSizeStatistics	
-#rec.doTimeLimit	
-#rec.doTruth	
-rec.doWriteAOD = False
-#rec.doWriteBS
-# If True writes out ESD file
-rec.doWriteESD = True
-#rec.doWriteRDO
-# If True writes out TAG file
-rec.doWriteTAG = True	
-#rec.noESDTrigger	
-#rec.oldFlagCompatibility	
-#rec.oldFlagLandMine	
-#rec.oldFlagTopSteering
-# General msg output level ALL,VERBOSE,DEBUG,INFO,WARNING,ERROR,FATAL
-rec.OutputLevel	= INFO
-#rec.readAOD
-#If True runs on ESD file  
-rec.readESD = False	
-#rec.readRDO	
-#rec.readTAG	
-#rec.Rec	
-#rec.RecAlgs	
-rec.RootHistoOutput = "monitoring.root"	
-rec.RootNtupleOutput = "ntuple.root"	
-#rec.TAGFromRDO	
-#rec.UserAlgs
-
-rec.doTile = True
-rec.doLArg = True
-rec.doInDet = True
-rec.doMuon = True
-
-## Switch on/off Calibration Ntuple
-#from MuonRecExample.MuonRecFlags import muonRecFlags
-#from MuonCalibAlgs.MuonCalibFlags import muonCalibFlags
-#muonRecFlags.doCalib = True
-#muonCalibFlags.Mode = 'trackNtuple'
-#muonCalibFlags.EventTag = 'Moore'
-
-### Switch on/off Combined Algorithms
-from MuonCombinedRecExample.MuonCombinedRecFlags import muonCombinedRecFlags,muidFlags
-muonCombinedRecFlags.doMuGirl = False
-muonCombinedRecFlags.doCaloTrkMuId = True
-muonCombinedRecFlags.doStaco = False
-muonCombinedRecFlags.doMuTag = False
-muonCombinedRecFlags.doAODMuons = True  # switch off AOD making
-muonCombinedRecFlags.doMergeMuons = True # switch off merging for ESD
-muidFlags.SegmentTagger = 'MuTagIMO' # switch off  by ''
-#muidFlags.Extrapolated = 'MuidStandalone' # switch off  by ''
-muidFlags.Extrapolated = '' # switch off  by ''
-#muidFlags.Combined = 'MuidCombined' # NOW not run # switch off  by ''
-muidFlags.Combined = 'CombinedMuonFit' # switch off  by ''
-
-
-# ----------------------------------------------------------------------
-# being flags to switch algorithm on/off
-# ----------------------------------------------------------------------
-from RecExConfig.RecAlgsFlags  import recAlgs
-
-#recAlgs.doTrigger 
-
-#
-# hack...
-#
-from RecExConfig.RecFlags import rec
-if not 'InDetKeys' in dir():
-    #
-    # --- setup StoreGate keys (JobProperties!)
-    #
-    print("InDetRec_jobOptions: InDetKeys not set before - I import them now")
-    from InDetRecExample.InDetKeys import InDetKeys
-#    InDetKeys.lock_JobProperties()
-                                                                         
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionConDB_jobOptions.py b/Reconstruction/RecExample/RecExCommission/share/RecExCommissionConDB_jobOptions.py
deleted file mode 100644
index fcb88ffede38203045efd9d7fce9cbd76e4a631a..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionConDB_jobOptions.py
+++ /dev/null
@@ -1,24 +0,0 @@
-if rec.doLArg() or rec.doTile():
-    if globalflags.DataSource()=='geant4':
-        include("LArConditionsCommon/LArIdMap_MC_jobOptions.py")
-        include("LArConditionsCommon/LArConditionsCommon_MC_jobOptions.py")
-    else :
-        include("LArConditionsCommon/LArIdMap_comm_jobOptions.py")
-        include("LArConditionsCommon/LArConditionsCommon_comm_jobOptions.py")
-
-    include( "LArIdCnv/LArIdCnv_joboptions.py" )
-    include ("CaloDetMgrDetDescrCnv/CaloDetMgrDetDescrCnv_joboptions.py")
- 
-if rec.doTile():
-    include( "TileIdCnv/TileIdCnv_jobOptions.py" )
-    include( "TileConditions/TileConditions_jobOptions.py" )        
-
-if rec.doMuon():
-    #MW/RN
-   
-    import MuonRecExample.MuonReadCalib
-    #    GeoModelSvc.MuonVersionOverride = "MuonSpectrometer-R.01.01.Initial.Light"
-    #if not globalflags.DataSource()=='geant4':
-    #    MuDetCosmicFlags.doCalibCOOLprod=True        
-    #    include("MuonCommRecExample/MuDetCosmicConDB_jobOptions.py")
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionData_links.csh b/Reconstruction/RecExample/RecExCommission/share/RecExCommissionData_links.csh
deleted file mode 100644
index 92e3e82a3b2b9e58706355868a79dc3eb663be8e..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionData_links.csh
+++ /dev/null
@@ -1,12 +0,0 @@
-#!/bin/tcsh
-if ( -e sqlite200 )then
-    rm -r sqlite200
-endif
-
-ln -s /afs/cern.ch/atlas/project/database/DBREL/packaging/DBRelease/current/geomDB .
-ln -s /afs/cern.ch/atlas/conditions/poolcond/catalogue/poolcond .
-
-setenv STAGE_HOST castoratlas 
-setenv RFIO_USE_CASTOR_V2 YES 
-setenv STAGE_SVCCLASS atlcal
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionData_links.sh b/Reconstruction/RecExample/RecExCommission/share/RecExCommissionData_links.sh
deleted file mode 100644
index abab5dc3ec8b708fa9ab7f79338269dc30ce0459..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionData_links.sh
+++ /dev/null
@@ -1,12 +0,0 @@
-if [ -e sqlite200 ]
-then
-    rm -r sqlite200
-fi
-
-ln -s /afs/cern.ch/atlas/project/database/DBREL/packaging/DBRelease/current/geomDB .
-ln -s /afs/cern.ch/atlas/conditions/poolcond/catalogue/poolcond .
-
-export STAGE_HOST=castoratlas 
-export RFIO_USE_CASTOR_V2=YES 
-export STAGE_SVCCLASS=atlcal
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionRepro.py b/Reconstruction/RecExample/RecExCommission/share/RecExCommissionRepro.py
deleted file mode 100644
index 82a65d7c95922e2c2b59e835d7bfa1181fe23e8a..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommissionRepro.py
+++ /dev/null
@@ -1,73 +0,0 @@
-# general configuration for commissioning
-from RecExConfig.RecFlags  import rec
-from RecExConfig.RecAlgsFlags  import recAlgs
-from AthenaCommon.BeamFlags import jobproperties
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from AthenaCommon.GlobalFlags import globalflags
-
-#Minimally required flags for commissioning
-rec.ScopingLevel.set_Value_and_Lock(2)
-include("RecExCommission/MinimalCommissioningSetup.py")
-
-#default
-
-#Commissioning Flags
-# include( "RecExCommission/RecExCommissionCommonFlags_jobOptions.py" )
-#include( "RecExCommission/RecExCommissionFlags_jobOptions.py" )
-#should not be there
-#from MuonCombinedRecExample.MuonCombinedRecFlags import muonCombinedRecFlags,muidFlags
-#muonCombinedRecFlags.doMuGirl = False
-#muonCombinedRecFlags.doCaloTrkMuId = True
-#muonCombinedRecFlags.doStaco = False
-#muonCombinedRecFlags.doMuTag = False
-#muonCombinedRecFlags.doAODMuons = True  # switch off AOD making
-#muonCombinedRecFlags.doMergeMuons = True # switch off merging for ESD
-#muidFlags.SegmentTagger = 'MuTagIMO' # switch off  by ''
-#muidFlags.Extrapolated = 'MuidStandalone' # switch off  by ''
-#muidFlags.Extrapolated = '' # switch off  by ''
-#muidFlags.Combined = 'MuidCombined' # NOW not run # switch off  by ''
-#muidFlags.Combined = 'CombinedMuonFit' # switch off  by ''
-
-
-   
-#if read from TAG, cannot write TAG at the same time
-#these lines should be in RecExCommon_flags.py
-if rec.readTAG():
-    rec.doWriteTAGCOM=False
-
-#rec.doTrigger=True
-#jet problem right now
-#from JetRec.JetRecFlags import jetFlags
-#jetFlags.Enabled.set_Value_and_Lock(False)
-recAlgs.doObjMissingET.set_Value_and_Lock(False)
-recAlgs.doMissingETSig.set_Value_and_Lock(False)
-
-
-#rec.doJetMissingETTag.set_Value_and_Lock(False)
-#from RecExConfig.RecAlgsFlags  import recAlgs
-#recAlgs.doMissingET.set_Value_and_Lock(True)
-#rec.doEgamma.set_Value_and_Lock(False)
-#rec.doTau.set_Value_and_Lock(False)
-#recAlgs.doMuonSpShower.set_Value_and_Lock(False)
-
-
-# For Trigger configuration during the reprocessing 08.
-# Will allow to read LVL1 thresholds from COOL instead of from hard-coded XML file.
-# For info: Sylvie Brunet, Joerg Stelzer
-from TriggerJobOpts.TriggerFlags import TriggerFlags as tf
-tf.configForStartup= "HLTonline"
-tf.configForStartup.lock()
-
-
-from LArConditionsCommon.LArCondFlags import larCondFlags
-larCondFlags.LArCoolChannelSelection.set_Value_and_Lock("3:238,306,313,319,325,331,338,344,350,1001:1012,1021,1022")
-#Option: Remove Conditions for HECC Quadrant with broken LV Power supply
-#larCondFlags.LArCoolChannelSelection.set_Value_and_Lock("3:238,306,313,325,331,338,344,350,1001:1012,1021,1022")
-larCondFlags.OFCShapeFolder.set_Value_and_Lock('5samples3bins17phases')
-larCondFlags.SingleVersion.set_Value_and_Lock(False)
-larCondFlags.useShape.set_Value_and_Lock(True)
-
-
-#Switch off EM-Topo cluster corrections for 2nd round of 2008 reprocessing
-from CaloClusterCorrection.CaloClusterCorrectionFlags import caloClusterCorrectionFlags
-caloClusterCorrectionFlags.CaloTopoEMWhichCorrection.set_Value ("none")
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_RemoveHLT_TrigTauRecMerged.py b/Reconstruction/RecExample/RecExCommission/share/RecExCommission_RemoveHLT_TrigTauRecMerged.py
deleted file mode 100644
index b51d8e2580d10c65f5fa95937e93dc6c99a51d58..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_RemoveHLT_TrigTauRecMerged.py
+++ /dev/null
@@ -1,15 +0,0 @@
-# RecExCommission_RemoveHLT_TrigTauRecMerged
-# Emergency hack to remove HLT_TrigTauRecMerged containers from ESD
-# because of failure : ERROR CreateRep failed, key = HLT_TrigTauRecMerged
-# C. Mora, May 4th, 2009  based on W. Lampl
-
-from AthenaCommon.Logging import logging
-log_HLTTau = logging.getLogger( 'RemoveHLT_TrigTauRecMerged' )
-
-try:
-    from AthenaCommon.AppMgr import theApp
-    StreamESD = theApp.getOutputStream( "StreamESD" )
-    StreamESD.ItemList.remove("Analysis::TauJetContainer#HLT_TrigTauRecMerged")
-    log_HLTTau.info("Removing Analysis::TauJetContainer#HLT_TrigTauRecMerged from ESD ItemList")
-except:
-    pass
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_RemoveTRTBSErr.py b/Reconstruction/RecExample/RecExCommission/share/RecExCommission_RemoveTRTBSErr.py
deleted file mode 100644
index 5a0d1d1b85dcd6893ef00602449ff8d90b04dbfe..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_RemoveTRTBSErr.py
+++ /dev/null
@@ -1,22 +0,0 @@
-#RecExCommission_RemoveTRTBSERR
-# Emergency hack to remove TRT BS Error containers from ESD
-# because of unresonably large disk-space consumption
-# Walter Lampl, Dec 16th, 2008
-
-from AthenaCommon.Logging import logging
-log_TRT_BS_ERR = logging.getLogger( 'RemoveTRTBSErrFromESD' )
-
-# Setup the output sequence
-from AthenaCommon.AppMgr import theApp
-StreamESD = theApp.getOutputStream( "StreamESD" )
-
-try:
-    StreamESD.ItemList.remove("TRT_BSErrContainer#TRT_ByteStreamErrs")
-    log_TRT_BS_ERR.info("Removing TRT_BSErrContainer#TRT_ByteStreamErrs from ESD ItemList")
-except:
-    pass
-try:
-    StreamESD.ItemList.remove("TRT_BSIdErrContainer#TRT_ByteStreamIdErrs")
-    log_TRT_BS_ERR.info("Removing TRT_BSIdErrContainer#TRT_ByteStreamIdErrs from ESD ItemList")
-except:
-    pass
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_SingleBeamtopOptions.py b/Reconstruction/RecExample/RecExCommission/share/RecExCommission_SingleBeamtopOptions.py
deleted file mode 100755
index abb3de82dba86a0c370cb0ef5085e0b02652ff06..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_SingleBeamtopOptions.py
+++ /dev/null
@@ -1,5 +0,0 @@
-from AthenaCommon.BeamFlags import jobproperties
-jobproperties.Beam.beamType.set_Value_and_Lock("singlebeam")
-
-include("RecExCommon/RecExCommon_topOptions.py")
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_fastRepro.py b/Reconstruction/RecExample/RecExCommission/share/RecExCommission_fastRepro.py
deleted file mode 100644
index d079e1485366427961590f117db4886f76a21d29..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_fastRepro.py
+++ /dev/null
@@ -1,28 +0,0 @@
-include("RecExCommission/MinimalCommissioningSetup.py")
-
-
-## tempory fix to get TCT to run whil bug 51007 is being fixed
-#DQMonFlags.doMuonTrackMon.set_Value_and_Lock(False)
-#DQMonFlags.doMuonSegmentMon.set_Value_and_Lock(False)
-#DQMonFlags.doMuonAlignMon.set_Value_and_Lock(False)
-#DQMonFlags.doMuonPhysicsMon.set_Value_and_Lock(False)
-
-#Temprary workaround for bug 51068
-#DQMonFlags.doTauMon.set_Value_and_Lock(False) 
-
-# needed to get TRT track extension working
-from TrkDetDescrSvc.TrkDetDescrJobProperties import TrkDetFlags
-TrkDetFlags.TRT_BuildStrawLayers.set_Value(True)
-
-# setup trigger reading from COOL (obo Clemencia)
-from TriggerJobOpts.TriggerFlags import TriggerFlags as tf
-tf.configForStartup="HLTonline"
-tf.configForStartup.lock()
-
-from RecExConfig.RecFlags  import rec
-rec.ScopingLevel.set_Value_and_Lock(2)
-
-from LArConditionsCommon.LArCondFlags import larCondFlags
-larCondFlags.SingleVersion=False
-larCondFlags.LArCoolChannelSelection.set_Value_and_Lock("3:238,306,313,319,325,331,338,344,350,1001:1012,1021,1022")
-larCondFlags.OFCShapeFolder.set_Value_and_Lock('5samples3bins17phases') 
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_links.sh b/Reconstruction/RecExample/RecExCommission/share/RecExCommission_links.sh
deleted file mode 100755
index 5fca3dee361d88eff7e8535cd0d4ee2ce34c1471..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecExCommission_links.sh
+++ /dev/null
@@ -1,6 +0,0 @@
-#!/bin/sh
-ln -s /afs/cern.ch/user/c/chriss/public/EndcapSoftware/InDetLayerMaterial-ATLAS-DC3-07.pool.root
-rm -rf sqlite200
-ln -s /afs/cern.ch/user/a/atlcond/coolrep/sqlite200
-ln -s /afs/cern.ch/atlas/project/database/DBREL/packaging/DBRelease/current/geomDB .
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecoPixelStreamSetup.py b/Reconstruction/RecExample/RecExCommission/share/RecoPixelStreamSetup.py
deleted file mode 100644
index 3d3368596de2e232dd63d0a9e8fd24ad00f1a494..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecoPixelStreamSetup.py
+++ /dev/null
@@ -1,28 +0,0 @@
-from InDetRecExample.InDetJobProperties import InDetFlags
-InDetFlags.useBeamConstraint.set_Value_and_Lock(False)
-InDetFlags.selectSCTIntimeHits=False
-InDetFlags.doVtxLumi.set_Value_and_Lock(True)
-
-AODFlags.TrackParticleSlimmer=True
-
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.Calo_setOff()
-DetFlags.Muon_setOff()
-DetFlags.ID_setOn()
-DetFlags.TRT_setOff()
-DetFlags.detdescr.TRT_setOn()
-DetFlags.makeRIO.TRT_setOff()
-
-rec.doTrigger.set_Value_and_Lock(True)
-rec.doCalo.set_Value_and_Lock(False)
-rec.doMuon.set_Value_and_Lock(False)
-rec.doJetMissingETTag.set_Value_and_Lock(False)
-rec.doMuonCombined.set_Value_and_Lock(False)
-rec.doEgamma.set_Value_and_Lock(False)
-rec.doTau.set_Value_and_Lock(False)
-
-from TrackD3PDMaker.VertexD3PDAnalysisFlags import VertexD3PDAnalysisFlags
-VertexD3PDAnalysisFlags.useBeamspot.set_Value_and_Lock(True)
-VertexD3PDAnalysisFlags.useTrigger.set_Value_and_Lock(False)
-VertexD3PDAnalysisFlags.useTriggerRaw.set_Value_and_Lock(True)
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/RecoVtxSatellitesSetup.py b/Reconstruction/RecExample/RecExCommission/share/RecoVtxSatellitesSetup.py
deleted file mode 100644
index 9a1895dfef74f7466f0afad8ec4e21b6f0c0565f..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/RecoVtxSatellitesSetup.py
+++ /dev/null
@@ -1,70 +0,0 @@
-## preInlcude for Reco_trf.py for satellite bunches reconstruction
-## Runs extended |z| tracking with low-pT threshold
-## This is the porting to 17.2 of what was used in ATLAS-CONF-2011-049
-## Example usage (see also VtxSatellitesD3PD_trf_v1.txt):
-## Reco_trf.py maxEvents=-1 autoConfiguration=everything preInclude=PUStudies/VtxSatellitesD3PD_preInclude_v1.py inputBSFile=/eliza18/atlas/spagan/GBStudies/RAW/data12_8TeV.00201351.calibration_VdM.daq.RAW/data12_8TeV.00201351.calibration_VdM.daq.RAW._lb0000._SFO-3._2333.data outputESDFile=myESD.pool.root outputAODFile=myAOD.pool.root outputNTUP_IDVTXLUMIFile=myVTXD3PD.root
-
-#Set general reco settings
-from InDetRecExample.InDetJobProperties import InDetFlags
-InDetFlags.useBeamConstraint.set_Value_and_Lock(False)
-InDetFlags.doLowMuRunSetup.set_Value_and_Lock(True)
-InDetFlags.doTrackSegmentsPixel.set_Value_and_Lock(False)
-InDetFlags.doTrackSegmentsSCT.set_Value_and_Lock(False)
-InDetFlags.doTrackSegmentsTRT.set_Value_and_Lock(False)
-InDetFlags.selectSCTIntimeHits=False
-
-
-#Set algorithms to be run
-AODFlags.TrackParticleSlimmer=True
-
-from AthenaCommon.DetFlags import DetFlags
-DetFlags.Calo_setOff()
-DetFlags.Muon_setOff()
-DetFlags.ID_setOn()
-DetFlags.TRT_setOff()
-DetFlags.detdescr.TRT_setOn()
-DetFlags.makeRIO.TRT_setOff()
-
-rec.doTrigger.set_Value_and_Lock(False)
-rec.doCalo.set_Value_and_Lock(False)
-rec.doMuon.set_Value_and_Lock(False)
-rec.doJetMissingETTag.set_Value_and_Lock(False)
-rec.doMuonCombined.set_Value_and_Lock(False)
-rec.doEgamma.set_Value_and_Lock(False)
-rec.doTau.set_Value_and_Lock(False)
-
-from RecExConfig.RecAlgsFlags import recAlgs
-recAlgs.doEgammaBremReco.set_Value_and_Lock  (False)
-
-from TrackD3PDMaker.VertexD3PDAnalysisFlags import VertexD3PDAnalysisFlags
-VertexD3PDAnalysisFlags.useBeamspot.set_Value_and_Lock(True)
-
-#Change tracking reconstruction cuts (Increase maximum z of tracking accpetance)
-from InDetRecExample.ConfiguredNewTrackingCuts import ConfiguredNewTrackingCuts
-InDetNewTrackingCuts      = ConfiguredNewTrackingCuts("Offline")
-InDetNewTrackingCuts._ConfiguredNewTrackingCuts__maxZImpact = 1700.
-InDetNewTrackingCuts.printInfo()
-
-InDetNewTrackingCutsLowPt = ConfiguredNewTrackingCuts("LowPt")
-InDetNewTrackingCutsLowPt._ConfiguredNewTrackingCuts__maxZImpact = 1700.
-InDetNewTrackingCutsLowPt.printInfo()
-
-#Change vertex reconstruction cuts (Increase maximum z of tracking accpetance)
-from InDetRecExample.ConfiguredVertexingCuts import ConfiguredVertexingCuts
-InDetPrimaryVertexingCuts = ConfiguredVertexingCuts("LowPt")
-InDetPrimaryVertexingCuts._ConfiguredVertexingCuts__z0Max = 1700.
-InDetPrimaryVertexingCuts._ConfiguredVertexingCuts__IPz0Max = 1700.
-InDetPrimaryVertexingCuts._ConfiguredVertexingCuts__sigIPd0Max = 5.0
-InDetPrimaryVertexingCuts.printInfo()
-
-#Setup D3PD making options
-InDetFlags.doVertexFindingForMonitoring.set_Value_and_Lock(False)
-InDetFlags.doSplitVertexFindingForMonitoring.set_Value_and_Lock(False)
-
-from TrackD3PDMaker.VertexD3PDAnalysisFlags import VertexD3PDAnalysisFlags
-VertexD3PDAnalysisFlags.useAllVertexCollections.set_Value_and_Lock(False)
-VertexD3PDAnalysisFlags.useBeamspot.set_Value_and_Lock(True)
-# Disable tracking info to have small D3PDs
-#VertexD3PDAnalysisFlags.useTracks.set_Value_and_Lock(True)
-# The following is only available after TrackD3PDMaker-01-03-05
-#VertexD3PDAnalysisFlags.filterTightTruth.set_Value_and_Lock(True)
diff --git a/Reconstruction/RecExample/RecExCommission/share/SingleBeam_ATN.py b/Reconstruction/RecExample/RecExCommission/share/SingleBeam_ATN.py
deleted file mode 100644
index 1ba6f9157fa7a6c17c052c0ff3fee59dc880b18c..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/SingleBeam_ATN.py
+++ /dev/null
@@ -1,5 +0,0 @@
-from AthenaCommon.BeamFlags import jobproperties
-jobproperties.Beam.beamType.set_Value_and_Lock("singlebeam")
-# the main jobOpt
-include("RecExCommission/Collisions_ATN.py")                
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/minimalRecoSplashSetup.py b/Reconstruction/RecExample/RecExCommission/share/minimalRecoSplashSetup.py
deleted file mode 100644
index ee370f546e93419f9fc8bc2df2139f3455ba2dc6..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/minimalRecoSplashSetup.py
+++ /dev/null
@@ -1,26 +0,0 @@
-from AthenaCommon.BeamFlags import jobproperties
-jobproperties.Beam.beamType.set_Value_and_Lock("singlebeam")
-
-## calo settings from Guillaume
-from CaloRec.CaloRecFlags import jobproperties
-jobproperties.CaloRecFlags.doEmCluster.set_Value_and_Lock(False)
-jobproperties.CaloRecFlags.doCaloTopoCluster.set_Value_and_Lock(False)
-jobproperties.CaloRecFlags.doCaloEMTopoCluster.set_Value_and_Lock(False)
-rec.doJetMissingETTag.set_Value_and_Lock(False)
-rec.doEgamma.set_Value_and_Lock(False)
-rec.doTau.set_Value_and_Lock(False)
-BTaggingFlags.Active=False
-
-## muon settings from Rosy
-#muonRecFlags.doMoore=False
-#muonCombinedRecFlags.doMuidMuonCollection=False 
-#muonRecFlags.doMuonboy=False
-#muonCombinedRecFlags.doStacoMuonCollection=False
-mooreFlags.doSegmentsOnly=True
-muonboyFlags.doSegmentsOnly=True
-muonRecFlags.doSegmentT0Fit = False
-muonCombinedRecFlags.Enabled = False
-
-## from Markus, Tony...
-from InDetRecExample.InDetJobProperties import InDetFlags
-InDetFlags.doMinimalReco      = True
diff --git a/Reconstruction/RecExample/RecExCommission/share/postInclude_ESDtoESD_MuonBoy.py b/Reconstruction/RecExample/RecExCommission/share/postInclude_ESDtoESD_MuonBoy.py
deleted file mode 100644
index 68c5da845ce60530138b978b5471e7b70c877882..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/postInclude_ESDtoESD_MuonBoy.py
+++ /dev/null
@@ -1,4 +0,0 @@
-from MuonboyAth.MuonboyAthConf import MboyRec
-theMboyRec = MboyRec()
-theMboyRec.AthPosOff = 1
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/readbsusingtag.py b/Reconstruction/RecExample/RecExCommission/share/readbsusingtag.py
deleted file mode 100644
index e4dc99043ebe7fca7c59f9c8314b5230cc62acfe..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/readbsusingtag.py
+++ /dev/null
@@ -1,15 +0,0 @@
-# for reading BS events using TAG_COMM 
-# need to have the BS file in your file catalogue
-# either by using: catalogBytestreamFiles.sh
-# or by using dq2-ls -P
-
-from AthenaCommon.AthenaCommonFlags  import athenaCommonFlags
-athenaCommonFlags.FilesInput=['tagcomm.root']
-athenaCommonFlags.PoolInputQuery.set_Value_and_Lock("EventNumber==2317247")
-
-from RecExConfig.RecFlags import rec
-rec.readRDO.set_Value_and_Lock(True)
-rec.doAOD.set_Value_and_Lock(False)
-rec.doWriteAOD.set_Value_and_Lock(False)
-rec.doWriteTAG.set_Value_and_Lock(False)
-include ("RecExCommon/RecExCommon_topOptions.py")
diff --git a/Reconstruction/RecExample/RecExCommission/share/readesd.py b/Reconstruction/RecExample/RecExCommission/share/readesd.py
deleted file mode 100644
index d99a52482bb6a7d7b9e6b0edc52844df4efe57f2..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/readesd.py
+++ /dev/null
@@ -1,95 +0,0 @@
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.BeamFlags import jobproperties
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from AthenaCommon.GlobalFlags import globalflags
-
-
-# various configuration special to commissioning, needed for all jobs
-athenaCommonFlags.PoolESDInput.set_Value_and_Lock(['castor:/castor/cern.ch/grid/atlas/tzero/prod1/perm/data08_cosmag/physics_IDCosmic/0091900/data08_cosmag.00091900.physics_IDCosmic.recon.ESD.o4_f73/data08_cosmag.00091900.physics_IDCosmic.recon.ESD.o4_f73._lb0001._sfo01._0001.1'])
-
-rec.AutoConfiguration=['everything']
-
-
-# all of these should now be autoconfigured - but i leave here incase 
-#jobproperties.Beam.beamType.set_Value_and_Lock("cosmics")
-#globalflags.DetDescrVersion.set_Value_and_Lock('ATLAS-GEO-04-00-00')
-#globalflags.ConditionsTag.set_Value_and_Lock('COMCOND-ES1C-000-00')
-# for running over data with field on need this to be setto true
-#from AthenaCommon.BFieldFlags import jobproperties
-#jobproperties.BField.solenoidOn.set_Value_and_Lock(False)
-#jobproperties.BField.barrelToroidOn.set_Value_and_Lock(True)
-#jobproperties.BField.endcapToroidOn.set_Value_and_Lock(True)
-
-
-#hardcoded output specification (corresponds to optional flags from runArgs in transform skeleton)
-rec.RootNtupleOutput.set_Value_and_Lock("newcommission.ntuple.root")
-#rec.RootHistoOutput.set_Value_and_Lock("monitoring.root")
-athenaCommonFlags.EvtMax.set_Value_and_Lock(10)
-#athenaCommonFlags.SkipEvents = 0
-
-# run ID reconstruction
-#from InDetRecExample.InDetJobProperties import InDetFlags
-#jobproperties.InDetJobProperties.Enabled.set_Value_and_Lock(True)
-#For version < 14.4.0: it requires to set in RecExCond/RecExCommon_DetFlags.py
-# the following: DetFlags.makeRIO.ID_setOn()
-
-
-# run Muons reconstruction
-#from MuonRecExample.MuonRecFlags import muonRecFlags
-#jobproperties.MuonRec.Enabled.set_Value_and_Lock(True)
-
-# run combined muon reconstruction
-#from MuonCombinedRecExample.MuonCombinedRecFlags import muonCombinedRecFlags 
-#jobproperties.MuonCombinedRec.Enabled.set_Value_and_Lock(True)
-
-#uncomment to do egamma
-#rec.doEgamma.set_Value_and_Lock(True)
-#from egammaRec.egammaRecFlags import jobproperties
-#jobproperties.egammaRecFlags.Enabled.set_Value_and_Lock(True)
-
-#but not others
-rec.doJetMissingETTag.set_Value_and_Lock(False)
-from JetRec.JetRecFlags import jetFlags
-jetFlags.Enabled.set_Value_and_Lock(False)
-from RecExConfig.RecAlgsFlags  import recAlgs
-recAlgs.doMissingET.set_Value_and_Lock(False)
-rec.doTau.set_Value_and_Lock(False)
-recAlgs.doMuonSpShower.set_Value_and_Lock(False)
-
-
-
-rec.doHist.set_Value_and_Lock(True)
-rec.doCBNT.set_Value_and_Lock(True)
-rec.doWriteTAGCOM.set_Value_and_Lock(False)
-rec.doWriteTAG.set_Value_and_Lock(False)	
-rec.doWriteAOD.set_Value_and_Lock(False)
-rec.doAOD.set_Value_and_Lock(False)
-rec.doMonitoring.set_Value_and_Lock(True)
-
-rec.readESD.set_Value_and_Lock(True)
-rec.doESD.set_Value_and_Lock(False)
-rec.doWriteESD.set_Value_and_Lock(False)
-globalflags.InputFormat.set_Value_and_Lock('pool')
-
-if not 'Debug' in dir():
-    Debug=True  # change to True to have printout information
-
-if Debug:
-    # DEBUG/VERBOSE options
-    rec.doNameAuditor=True
-    rec.doPerfMon=True
-    rec.doDetailedPerfMon=True
-    rec.doDumpProperties=True
-    rec.doDumpTES=True
-    # rec.OutputLevel = INFO
-
-# the main jobOpt
-include("RecExCommission/RecExCommission.py")                
-
-
-from AthenaMonitoring.DQMonFlags import DQMonFlags
-DQMonFlags.monType='BS_ESD'
-DQMonFlags.histogramFile.set_Value_and_Lock( "myMonitoringESD.root" )
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-
diff --git a/Reconstruction/RecExample/RecExCommission/share/readesdusingtag.py b/Reconstruction/RecExample/RecExCommission/share/readesdusingtag.py
deleted file mode 100644
index ce1479528eb2d8b7b702f938601b8db68a849119..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/readesdusingtag.py
+++ /dev/null
@@ -1,54 +0,0 @@
-from RecExConfig.RecFlags  import rec
-from AthenaCommon.BeamFlags import jobproperties
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from AthenaCommon.GlobalFlags import globalflags
-
-#Minimally required flags for commissioning
-include("RecExCommission/MinimalCommissioningSetup.py")
-
-athenaCommonFlags.FilesInput=["TAG.root"]
-rec.Commissioning.set_Value_and_Lock(True)
-# choose what detector to turn on:
-rec.doInDet.set_Value_and_Lock(True)
-rec.doLArg.set_Value_and_Lock(True)
-rec.doTile.set_Value_and_Lock(True)
-rec.doMuon.set_Value_and_Lock(True)
-rec.doMuonCombined.set_Value_and_Lock(True)
-
-rec.doTrigger.set_Value_and_Lock(False)
-
-#hardcoded output specification (corresponds to optional flags from runArgs in transform skeleton)
-rec.RootNtupleOutput.set_Value_and_Lock("newcommission.ntuple.root")
-#rec.RootHistoOutput.set_Value_and_Lock("monitoring.root")
-athenaCommonFlags.EvtMax.set_Value_and_Lock(10)
-#athenaCommonFlags.SkipEvents = 0
-
-rec.doJiveXML.set_Value_and_Lock(True)
-athenaCommonFlags.PoolInputQuery.set_Value_and_Lock("PixelTracks==1&&SCTTracks==1&&TRTTracks==1&&TileMuonFitter>0&&MooreTracks>0&&ConvertedMBoyTracks>0&&NpixSPs>2")
-
-rec.doCBNT.set_Value_and_Lock(False)
-
-if not 'Debug' in dir():
-    Debug=False  # change to True to have printout information
-
-if Debug:
-    # DEBUG/VERBOSE options
-#    rec.doNameAuditor=True
-    rec.doPerfMon=True
-    rec.doDetailedPerfMon=True
-    rec.doDumpProperties=True
-#    rec.doDumpTES=True
-    rec.OutputLevel = DEBUG
-
-# the main jobOpt
-include("RecExCommission/RecExCommission.py")                
-
-
-from AthenaMonitoring.DQMonFlags import DQMonFlags
-DQMonFlags.monType='BS_ESD'
-DQMonFlags.histogramFile.set_Value_and_Lock( "myMonitoringESD.root" )
-include ("RecExCommon/RecExCommon_topOptions.py")
-
-
-svcMgr.EventSelector.CollectionType="ExplicitROOT"
-svcMgr.EventSelector.Query=athenaCommonFlags.PoolInputQuery()
diff --git a/Reconstruction/RecExample/RecExCommission/share/setuptrf_offline.sh b/Reconstruction/RecExample/RecExCommission/share/setuptrf_offline.sh
deleted file mode 100644
index 24c416a004224d591fb4264f15c0bb1cef07408b..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/setuptrf_offline.sh
+++ /dev/null
@@ -1,64 +0,0 @@
-#!/usr/bin/env zsh
-
-#########################################################################
-##
-##  Script for setting up ATLAS/Athena run-time environment via CMT
-##
-##  - input parameters:
-##     1) CMT version; e.g. 'v1r20p20080222'
-##     2) patch directory (CMT test area)
-##     3) transuses string, i.e. hyphen-separated 'project-release' string; 
-##        e.g. 'AtlasTier0-14.2.10.2'
-##     4) special setup to be sourced
-##
-## (C) Luc Goossens, Armin Nairz (July 2008)
-##
-#########################################################################
-
-if test $# -ne 4 ; then
-     echo "ERROR incorrect nr of args"
-     echo "USAGE:  setuptrf.sh CMTVERSION PATCHDIR TRANSUSES SPECIALSETUP"
-     echo
-     exit 1
-fi
-
-export CMTVERSION=$1
-export PATCHDIR=$2
-export TRANSUSES=$3
-export SPECIALSETUP=$4
-
-export PROJECT=`echo ${TRANSUSES} | awk -F '-' '{print $1}'`
-export RELEASE=`echo ${TRANSUSES} | awk -F '-' '{print $2}'`
-
-export WORKDIR=`pwd`
-
-# set AthenaPOOL output level
-#-------------------------------------------------------------------------------
-export POOL_OUTMSG_LEVEL=5
-
-
-# assemble CMT requirements file
-#-------------------------------------------------------------------------------
-cat > requirements << EOF
-set   CMTSITE  CERN
-set   SITEROOT /afs/cern.ch
-macro ATLAS_DIST_AREA \${SITEROOT}/atlas/software/dist                           
-macro ATLAS_TEST_AREA ${PATCHDIR}
-use AtlasLogin AtlasLogin-* \$(ATLAS_DIST_AREA)
-EOF
-
-# set up CMT version
-#-------------------------------------------------------------------------------
-source /afs/cern.ch/sw/contrib/CMT/${CMTVERSION}/mgr/setup.sh ""
-cmt config
-
-# set up run environment
-#-------------------------------------------------------------------------------
-source ${WORKDIR}/setup.sh -tag=${PROJECT},${RELEASE},32,oneTest,runtime
-
-# source special/custom setup
-#-------------------------------------------------------------------------------
-if test $SPECIALSETUP != 'none' ;
-then
-  source $SPECIALSETUP
-fi
diff --git a/Reconstruction/RecExample/RecExCommission/share/skipBadEvents.py b/Reconstruction/RecExample/RecExCommission/share/skipBadEvents.py
deleted file mode 100644
index 8a0760044019e2efd725b21dde8cfeb877cf4dad..0000000000000000000000000000000000000000
--- a/Reconstruction/RecExample/RecExCommission/share/skipBadEvents.py
+++ /dev/null
@@ -1,3 +0,0 @@
-from AthenaCommon.AppMgr import ServiceMgr
-if (rec.doWriteESD):
-    ServiceMgr.EventSelector.MaxBadEvents=1000
diff --git a/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py b/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py
index ac97aa0382bcea27f38fa9dcf62b43dc75441de7..032ada00886b84a84aa1ec9656ab4b81d48a8186 100644
--- a/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py
+++ b/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py
@@ -1496,6 +1496,8 @@ if rec.doWriteBS():
     #    StreamBSFileOutput.ItemList += topSequence.StreamBS.ItemList
 
     # LVL1
+    from TrigT1ResultByteStream.TrigT1ResultByteStreamConfig import L1ByteStreamEncodersRecExSetup
+    L1ByteStreamEncodersRecExSetup()  # Configure BS encoder for RoIBResult
     StreamBSFileOutput.ItemList += [ "ROIB::RoIBResult#*" ]
 
     StreamBSFileOutput.ItemList += [ "DataVector<LVL1::TriggerTower>#TriggerTowers" ]
@@ -1565,7 +1567,6 @@ if not rec.oldFlagCompatibility:
 # -------------------------------------------------------------
 pdr.flag_domain('tag')
 if rec.doWriteTAGCOM():
-    # include( "RecExCommission/RecExCommissionTAG_jobOptions.py" )
     logRecExCommon_topOptions.warning( "TAGCOM has been retired !! Please use doWriteTAG instead !!" )
 
 try:
diff --git a/Reconstruction/RecExample/RecExCommon/share/RecoUtils.py b/Reconstruction/RecExample/RecExCommon/share/RecoUtils.py
index de4bcb1340684990c305dfc6e3467c93b385712c..05a4f115db4c401c7de03fd61eda3475137b2cf2 100644
--- a/Reconstruction/RecExample/RecExCommon/share/RecoUtils.py
+++ b/Reconstruction/RecExample/RecExCommon/share/RecoUtils.py
@@ -199,7 +199,7 @@ if not rec.OutputLevel.isDefault():
 if jobproperties.ConcurrencyFlags.NumThreads() > 0:
     ServiceMgr.MessageSvc.Format = "% F%50W%C%4W%R%e%s%8W%R%T %0W%M"
 else:
-    ServiceMgr.MessageSvc.Format = "% F%50W%C%7W%R%T %0W%M" 
+    ServiceMgr.MessageSvc.Format = "% F%50W%C%8W%R%T %0W%M" 
 
 
 #ServiceMgr.MessageSvc.defaultLimit = 9999999  # all messages
diff --git a/Reconstruction/RecExample/RecExCommission/share/MinimalCommissioningSetup.py b/Reconstruction/RecExample/RecExCond/share/MinimalCommissioningSetup.py
similarity index 100%
rename from Reconstruction/RecExample/RecExCommission/share/MinimalCommissioningSetup.py
rename to Reconstruction/RecExample/RecExCond/share/MinimalCommissioningSetup.py
diff --git a/Reconstruction/RecExample/RecExCond/share/RecExCommon_flags.py b/Reconstruction/RecExample/RecExCond/share/RecExCommon_flags.py
index f92301fd72ad413dc6e411c7808bb20a2033a93c..6b1b99e7cc0552b622dbad59d045a6c78ec32de9 100755
--- a/Reconstruction/RecExample/RecExCond/share/RecExCommon_flags.py
+++ b/Reconstruction/RecExample/RecExCond/share/RecExCommon_flags.py
@@ -233,10 +233,16 @@ if len(rec.AutoConfiguration())>0:
     from AthenaCommon.AppMgr import ServiceMgr as svcMgr
     svcMgr += AutoConfigConsistencyCheckSvc("AutoConfigConsistencyCheckSvc")
 
-
 #special commisioning job options
 if rec.Commissioning():
-   include("RecExCommission/RecExCommission.py")
+   include("RecExCond/MinimalCommissioningSetup.py")
+   # setup trigger reading from COOL
+   if rec.doTrigger():
+      from TriggerJobOpts.TriggerFlags import TriggerFlags as tf
+      tf.configForStartup="HLTonline"
+      tf.configForStartup.lock()
+
+   rec.ScopingLevel.set_Value_and_Lock(1)
 
 if rec.triggerStream().startswith('express'):
    logRecExCommon_flags.info('Disabling track slimming for express stream.')
@@ -594,12 +600,6 @@ except Exception:
 
 #load commissioning flags here (major cleanup needed)
 if rec.Commissioning():
-   #--------------------------------------------------------------
-   # Common flags with RecExCommon
-   #--------------------------------------------------------------
-   #if rec.readRDO:
-   #   include( "RecExCommission/RecExCommissionCommonFlags_jobOptions.py" )
-
 
    # ---------------------------------------------------------------------------
    # AthenaCommonFlags
diff --git a/Reconstruction/RecExample/RecExTB/root/include/monitor.h b/Reconstruction/RecExample/RecExTB/root/include/monitor.h
index 7194a7083a69ba46f682990bdfd509a24a7ce146..f7323f6781a6c55ee505fdbf895d47d7bcf0eacf 100755
--- a/Reconstruction/RecExample/RecExTB/root/include/monitor.h
+++ b/Reconstruction/RecExample/RecExTB/root/include/monitor.h
@@ -18,7 +18,6 @@
 #include "TGraph.h"
 #include "TH1.h"
 #include "TH2.h"
-#include "TGraph.h"
 #include "TProfile.h"
 #include "TCanvas.h"
 #include "TStyle.h"
diff --git a/Reconstruction/RecExample/RecJobTransformTests/test/test_data17_13tev.sh b/Reconstruction/RecExample/RecJobTransformTests/test/test_data17_13tev.sh
index 54cf670c42e943b702ff6a4c59076b2fd2408798..f4aebeffe211c34df96592528601e646632e2aff 100755
--- a/Reconstruction/RecExample/RecJobTransformTests/test/test_data17_13tev.sh
+++ b/Reconstruction/RecExample/RecJobTransformTests/test/test_data17_13tev.sh
@@ -10,7 +10,7 @@
 # art-include: 21.9/Athena
 
 
-Reco_tf.py --inputBSFile /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/RecJobTransformTests/data17_13TeV.00324910.physics_Main.daq.RAW._lb0713._SFO-6._0001.data --maxEvents 300 --AMI=f908 --outputESDFile myESD.pool.root --outputAODFile myAOD.pool.root --outputHISTFile myHist.root
+Reco_tf.py --inputBSFile /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/RecJobTransformTests/data17_13TeV.00324910.physics_Main.daq.RAW._lb0713._SFO-6._0001.data --maxEvents 300 --AMI=f1088 --outputESDFile myESD.pool.root --outputAODFile myAOD.pool.root --outputHISTFile myHist.root
 
 #Remember retval of transform as art result
 RES=$?
diff --git a/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV.sh b/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV.sh
index 76baafd63105f7493c3b6e244d0c52750d755445..151a271fbe912d11ecba4352f4fbcd12f1a8325c 100755
--- a/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV.sh
+++ b/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV.sh
@@ -10,7 +10,7 @@
 # art-include: 21.9/Athena
 
 
-Reco_tf.py --inputBSFile /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/RecJobTransformTests/data18_13TeV/data18_13TeV.00348885.physics_Main.daq.RAW._lb0827._SFO-8._0002.data --maxEvents 300 --AMI=f926 --outputESDFile myESD.pool.root --outputAODFile myAOD.pool.root --outputHISTFile myHist.root
+Reco_tf.py --inputBSFile /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/RecJobTransformTests/data18_13TeV/data18_13TeV.00348885.physics_Main.daq.RAW._lb0827._SFO-8._0002.data --maxEvents 300 --AMI=f1089 --outputESDFile myESD.pool.root --outputAODFile myAOD.pool.root --outputHISTFile myHist.root
 
 #Remember retval of transform as art result
 RES=$?
diff --git a/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV_largeRadiusTrackingOn.sh b/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV_largeRadiusTrackingOn.sh
index d808a92bbf5451403b0c32e9f299ecb57288430a..6e42b579165a8f573a99b6f08ce5d3ea97ca9e56 100755
--- a/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV_largeRadiusTrackingOn.sh
+++ b/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV_largeRadiusTrackingOn.sh
@@ -10,7 +10,7 @@
 # art-include: 21.9/Athena
 
 
-Reco_tf.py --inputBSFile /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/RecJobTransformTests/data18_13TeV/data18_13TeV.00348885.physics_Main.daq.RAW._lb0827._SFO-8._0002.data --preExec r2a:'from InDetRecExample.InDetJobProperties import InDetFlags; InDetFlags.doR3LargeD0.set_Value_and_Lock(True);InDetFlags.storeSeparateLargeD0Container.set_Value_and_Lock(True);' --maxEvents 300 --AMI=f926 --outputESDFile myESD.pool.root --outputAODFile myAOD.pool.root --outputHISTFile myHist.root
+Reco_tf.py --inputBSFile /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/RecJobTransformTests/data18_13TeV/data18_13TeV.00348885.physics_Main.daq.RAW._lb0827._SFO-8._0002.data --preExec r2a:'from InDetRecExample.InDetJobProperties import InDetFlags; InDetFlags.doR3LargeD0.set_Value_and_Lock(True);InDetFlags.storeSeparateLargeD0Container.set_Value_and_Lock(True);' --maxEvents 300 --AMI=f1089 --outputESDFile myESD.pool.root --outputAODFile myAOD.pool.root --outputHISTFile myHist.root
 
 #Remember retval of transform as art result
 RES=$?
diff --git a/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV_notrigger_fpe.sh b/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV_notrigger_fpe.sh
index a666fe9fc79621c1a23f90fcfaebc9e37b1b8aa2..4bc7aee35ca3880625c919ccfc5234744bcc1828 100755
--- a/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV_notrigger_fpe.sh
+++ b/Reconstruction/RecExample/RecJobTransformTests/test/test_data18_13TeV_notrigger_fpe.sh
@@ -10,7 +10,7 @@
 # art-include: 21.9/Athena
 
 
-Reco_tf.py --inputBSFile /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/RecJobTransformTests/data18_13TeV/data18_13TeV.00348885.physics_Main.daq.RAW._lb0827._SFO-8._0002.data --maxEvents 300 --AMI=f926 --outputESDFile myESD.pool.root --outputAODFile myAOD.pool.root --outputHISTFile myHist.root --preExec 'rec.doFloatingPointException=True;rec.doTrigger=False;' --postExec 'FPEAuditor.NStacktracesOnFPE=5'
+Reco_tf.py --inputBSFile /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/RecJobTransformTests/data18_13TeV/data18_13TeV.00348885.physics_Main.daq.RAW._lb0827._SFO-8._0002.data --maxEvents 300 --AMI=f1089 --outputESDFile myESD.pool.root --outputAODFile myAOD.pool.root --outputHISTFile myHist.root --preExec 'rec.doFloatingPointException=True;rec.doTrigger=False;' --postExec 'FPEAuditor.NStacktracesOnFPE=5'
 
 #Remember retval of transform as art result
 RES=$?
diff --git a/Reconstruction/RecJobTransforms/CMakeLists.txt b/Reconstruction/RecJobTransforms/CMakeLists.txt
index 85424aa442489cd450c201684af59938a13c0f1a..ef2583c4b6f17feb8b6835ecc2bcfcf1db3d78f9 100644
--- a/Reconstruction/RecJobTransforms/CMakeLists.txt
+++ b/Reconstruction/RecJobTransforms/CMakeLists.txt
@@ -4,7 +4,7 @@
 atlas_subdir( RecJobTransforms )
 
 # Install python modules
-atlas_install_python_modules( python/*.py )
+atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 # Install RDOtoRDOtrigger job opts with flake8 check
 atlas_install_joboptions( share/skeleton.RDOtoRDOtrigger*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 # Install other job opts without flake8 check
diff --git a/Reconstruction/RecJobTransforms/python/BsConfig.py b/Reconstruction/RecJobTransforms/python/BsConfig.py
index 3010f746eedbdd47b873ab0bf0d347df8af8dbcf..56439aea92480a965378a7267da6bfebac21fa77 100644
--- a/Reconstruction/RecJobTransforms/python/BsConfig.py
+++ b/Reconstruction/RecJobTransforms/python/BsConfig.py
@@ -1,9 +1,8 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-import os
 __all__ = []
 
-from PyJobTransformsCore.TransformConfig import *
+from PyJobTransformsCore.TransformConfig import TransformConfig
 
 class BsConfig(TransformConfig):
     # prevent any mistypings by not allowing dynamic members
diff --git a/Reconstruction/RecJobTransforms/python/ConfigUtils.py b/Reconstruction/RecJobTransforms/python/ConfigUtils.py
deleted file mode 100644
index fe7189dfba9304bc41941b0bcf6cfa3d386a2e56..0000000000000000000000000000000000000000
--- a/Reconstruction/RecJobTransforms/python/ConfigUtils.py
+++ /dev/null
@@ -1,82 +0,0 @@
-#!/usr/bin/env python
-
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-# First define a list of functions
-# Then call them from PredefinedConfigFunctions(key,runArgs) at the end
-
-from __future__ import print_function
-def ConfigureFieldAndGeo(runArgs):
-    print("Method ConfigureFieldAndGeo...")
-    from PATJobTransforms.GeoConfig import GetRunNumber
-    RunNumber=GetRunNumber(runArgs)
-    print("Configuring geometry and field from RunNuber",RunNumber)
-    from RecExCommission.RecExCommission_MagneticFieldConfig import setFieldConfig
-    setFieldConfig(RunNumber)
-    return
-
-#------------------------
-def SetBeamType(runArgs):
-    print("Method SetBeamType...")
-    BeamType='NONE'
-    if hasattr(runArgs,"beamType"):
-        BeamType=runArgs.beamType
-    elif hasattr(runArgs,"outputESDFile") or hasattr(runArgs,"outputAODFile") or hasattr(runArgs,"inputESDFile") or hasattr(runArgs,"inputAODFile"):
-        print("Attempting to set beamType from outputESD or outputAOD file...")
-        print("known cosmics projects: data08_cos, data08_cosmag")
-        print("known single beam projects: data08_1beam, data08_1beammag")
-        print("know collisions projects: data08_coll900, data08 ")
-
-        if hasattr(runArgs,"outputESDFile"): fileName=runArgs.outputESDFile
-        elif hasattr(runArgs,"outputAODFile"): fileName=runArgs.outputAODFile
-        elif hasattr(runArgs,"inputESDFile"): fileName=runArgs.inputESDFile[0]
-        elif hasattr(runArgs,"inputAODFile"): fileName=runArgs.inputAODFile[0]
-        #base on a file named like this:
-        #run08_cos.00077585.physics_HLT_Cosmics_NIM4.recon.ESD.o4_r509_tid024433/ESD.024433._00001.pool.root.2
-        #or directly
-        #data08_cosmag.00090415.physics_CosmicMuons.recon.ESD.o4_f68._lb0001._sfo02._0001
-
-        #if several directories, take the first part
-        subNames=fileName.split('/')
-        firstName=subNames[0]
-        #from run08_cos.ESD.pool.root, split by dots and project is the first part
-        project = firstName.split('.')[0]
-        print('project = ',project)
-        if project=="data08_cos" or project=="data08_cosmag": BeamType='cosmics'
-        elif project=="data08_1beam" or project=="data08_1beammag": BeamType='singlebeam'
-        elif project=="data08" or project=="data08_coll900": BeamType='collisions'
-        else:
-            print("\n\nWARNING - unknown project name '%s'\n\n"%project)
-            print("Will try to guess project from 'data', '_cos', '_1beam', '_coll' keywords...")
-            if project.startswith('data'):
-                if project.rfind('_cos')>0: BeamType='cosmics'
-                elif project.rfind('_1beam')>0: BeamType='singlebeam'
-                elif project.rfind('_coll')>0: BeamType='collisions'                
-            if BeamType == 'NONE':
-                print("Unexpected project name. Maybe the project position is wrong?")
-                print("Trying to search the complete file name for known projects... [%s]"%fileName)
-                if fileName.rfind("data08_cos")>0 or fileName.rfind("data08_cosmag")>0: BeamType='cosmics'
-                elif fileName.rfind("data08_1beam")>0 or fileName.rfind("data08_1beammag")>0: BeamType='singlebeam'
-                elif fileName.rfind("data08.")>0 or fileName.rfind("data08_coll900")>0: BeamType='collisions'
-                else:
-                    raise RuntimeError("(2) Unable to determine beamType from file named '%s'"%fileName)
-            
-    if BeamType == 'NONE':
-        raise RuntimeError("(3) Unable to determine beamType from file name nor from direct argument")
-    else:
-        from AthenaCommon.BeamFlags import jobproperties
-        jobproperties.Beam.beamType.set_Value_and_Lock( BeamType )
-        print("The beamType is set to",BeamType)
-
-    return
-
-
-def PredefinedConfigFunctions(key,runArgs):
-    if key == "FieldAndGeo":
-        ConfigureFieldAndGeo(runArgs)
-    elif key == "BeamType":
-        SetBeamType(runArgs)
-    else:
-        raise RuntimeError("Unknown key '%s' in PredefinedConfigFunctions(key,runArgs)"%key)
-    return
-
diff --git a/Reconstruction/RecJobTransforms/python/MixStreamConfig.py b/Reconstruction/RecJobTransforms/python/MixStreamConfig.py
index ba6a0facc90e37b26bfac95cc03dee10725d40a0..7073427d77df4e6581995640e8fae805c721a1d4 100644
--- a/Reconstruction/RecJobTransforms/python/MixStreamConfig.py
+++ b/Reconstruction/RecJobTransforms/python/MixStreamConfig.py
@@ -1,10 +1,3 @@
-from __future__ import print_function
-from __future__ import division
-from builtins import object
-from future.utils import iteritems
-
-from builtins import int
-
 # Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 #######################################################################################################
@@ -17,106 +10,103 @@ from builtins import int
 #    which also has (that) MixStreamConfig.
 #######################################################################################################
 
-#__all__ = []
-
-from PyJobTransformsCore.TransformConfig import *
-from RecJobTransforms.MixingSelector import *
-from math import sqrt
-import re
+from PyJobTransformsCore.TransformConfig import Descriptor, UniqueList, JobConfigError, TransformConfig, Integer
+from RecJobTransforms.MixingSelector import MixingSelector
+import os
 
 class ListOfSelectors(UniqueList):
-	"""List of class MixingSelector, for configuration of job."""
-	def __init__(self,doc,default=None,allowedValues=None):
-		UniqueList.__init__(self,doc,default,allowedValues)				
-	def _checkType(self,variableName,value):
-		"""Add check that all entries are MixingSelectors"""
-		# check that <value> is a list or tuple
-		value = UniqueList._checkType(self,variableName,value)
-		# check that all entries are strings
-		for v in value:
-			valType = type(v).__name__
-			if not isinstance(v, MixingSelector):
-				raise JobConfigError("Entry %r in %s is not a MixingSelector (but an %s)" % \
-						     (v,variableName,valType) )					
-		return value
-	
+        """List of class MixingSelector, for configuration of job."""
+        def __init__(self,doc,default=None,allowedValues=None):
+                UniqueList.__init__(self,doc,default,allowedValues)
+        def _checkType(self,variableName,value):
+                """Add check that all entries are MixingSelectors"""
+                # check that <value> is a list or tuple
+                value = UniqueList._checkType(self,variableName,value)
+                # check that all entries are strings
+                for v in value:
+                        valType = type(v).__name__
+                        if not isinstance(v, MixingSelector):
+                                raise JobConfigError("Entry %r in %s is not a MixingSelector (but an %s)" %
+                                                     (v,variableName,valType) )
+                return value
+
 class FloatList(Descriptor):
-	"""List of floats, which can have repeated entries.
-	List of allowed value has unit length and is the minimum SIZE of the list."""
-	def __init__(self,doc,default=None,allowedValues=None):
-		if default is None: default = []
-		Descriptor.__init__(self,doc,default,allowedValues)
-	def _checkType(self,variableName,value):
-		"""Check that <value> is a list or tuple, and make the tuple a list."""
-		valType = type(value).__name__
-		if not isinstance(value, list) and not isinstance(value, tuple):
-			raise JobConfigError('%s should be a list or tuple. Got %s instead.' & (variableName, valType))
-		if isinstance(value, tuple):
-			value = list(value)
-		for v in value:
-			valType = type(v).__name__
-			if not isinstance(v, float):
-				raise JobConfigError("Entry %r in %s is not a float (but an %s)" %  (v,variableName,valType) )
-		return value
-
-	def _checkValue(self,variableName,value):
-		# check that size is allowed
-		if len(self.allowedValues()):
-			allowed = self.allowedValues()[0]
-			if len(value) < allowed: raise JobConfigError( 'The list %s has size %r, less than %s' % (variableName, len(value), allowed) )
-		return value	
-
-	def _checkAllowedValues(self,variableName,allowedValues):
-		# just get the first value and ensure it is a positive integer
-		newAllowed=[]
-		if not allowedValues:
-			return newAllowed
-		if isinstance(allowedValues[0], int) and allowedValues[0] >= 0:
-			newAllowed += [ allowedValues[0] ]
-		return newAllowed
-				 
+        """List of floats, which can have repeated entries.
+        List of allowed value has unit length and is the minimum SIZE of the list."""
+        def __init__(self,doc,default=None,allowedValues=None):
+                if default is None: default = []
+                Descriptor.__init__(self,doc,default,allowedValues)
+        def _checkType(self,variableName,value):
+                """Check that <value> is a list or tuple, and make the tuple a list."""
+                valType = type(value).__name__
+                if not isinstance(value, list) and not isinstance(value, tuple):
+                        raise JobConfigError('%s should be a list or tuple. Got %s instead.' & (variableName, valType))
+                if isinstance(value, tuple):
+                        value = list(value)
+                for v in value:
+                        valType = type(v).__name__
+                        if not isinstance(v, float):
+                                raise JobConfigError("Entry %r in %s is not a float (but an %s)" %  (v,variableName,valType) )
+                return value
+
+        def _checkValue(self,variableName,value):
+                # check that size is allowed
+                if len(self.allowedValues()):
+                        allowed = self.allowedValues()[0]
+                        if len(value) < allowed: raise JobConfigError( 'The list %s has size %r, less than %s' % (variableName, len(value), allowed) )
+                return value
+
+        def _checkAllowedValues(self,variableName,allowedValues):
+                # just get the first value and ensure it is a positive integer
+                newAllowed=[]
+                if not allowedValues:
+                        return newAllowed
+                if isinstance(allowedValues[0], int) and allowedValues[0] >= 0:
+                        newAllowed += [ allowedValues[0] ]
+                return newAllowed
+
 class MixStreamConfig(TransformConfig):
-	# not allow dynamic members
-	__slots__ = ()
-	NumberOfBatchJobs = Integer("Number of batch jobs in total, for dividing up input files",5)	
-	NumberOfSFO = Integer("Number of SFO simulated in test, for setting event numbers",5)
-	NumberOfLumiBlocksPerRun = Integer("Number of LB per run simulated in test, for setting run numbers",30)
-	RunNumberBase = Integer("Base for calculating run number", 1)
-	LuminosityPartition = FloatList("Division of the total task luminosity as a list of floats",[1.0,], [1])
-	JobSelectors = ListOfSelectors("List of unique MixingSelectors for input config.  See Reconstruction.MixingSelector for details.",[])
-
-	def WhichSFO(self, WhichPartition):
-		if WhichPartition >= self.NumberOfBatchJobs: return -1
-		return WhichPartition % self.NumberOfSFO
-	def WhichLumiBlock(self, WhichPartition):
-		if WhichPartition >=  self.NumberOfBatchJobs: return -1
-		return (WhichPartition/self.NumberOfSFO) % self.NumberOfLumiBlocksPerRun	
-	def WhichRunNumber(self, WhichPartition):
-		if WhichPartition >=  self.NumberOfBatchJobs: return -1
-		return self.RunNumberBase + (WhichPartition/self.NumberOfSFO)/self.NumberOfLumiBlocksPerRun
-	def FinishedLuminosityFraction(self, WhichPartition):
-		if WhichPartition >=  self.NumberOfBatchJobs: return -1
-		lp = self.LuminosityPartition
-		theLB = (WhichPartition/self.NumberOfSFO)
-		totLB = (self.NumberOfBatchJobs/self.NumberOfSFO)
-		return sum(lp[0:theLB])/sum(lp[0:totLB])
-	def ThisLuminosityFraction(self, WhichPartition):
-		if WhichPartition >=  self.NumberOfBatchJobs: return -1
-		lp = self.LuminosityPartition
-		theLB = (WhichPartition/self.NumberOfSFO)
-		totLB = (self.NumberOfBatchJobs/self.NumberOfSFO)		
-		return ((lp[theLB])/sum(lp[0:totLB]))
-	def __init__(self,name='mixStreamConfig',metaData=[]):
-		TransformConfig.__init__(self,name,metaData)
+        # not allow dynamic members
+        __slots__ = ()
+        NumberOfBatchJobs = Integer("Number of batch jobs in total, for dividing up input files",5)
+        NumberOfSFO = Integer("Number of SFO simulated in test, for setting event numbers",5)
+        NumberOfLumiBlocksPerRun = Integer("Number of LB per run simulated in test, for setting run numbers",30)
+        RunNumberBase = Integer("Base for calculating run number", 1)
+        LuminosityPartition = FloatList("Division of the total task luminosity as a list of floats",[1.0,], [1])
+        JobSelectors = ListOfSelectors("List of unique MixingSelectors for input config.  See Reconstruction.MixingSelector for details.",[])
+
+        def WhichSFO(self, WhichPartition):
+                if WhichPartition >= self.NumberOfBatchJobs: return -1
+                return WhichPartition % self.NumberOfSFO
+        def WhichLumiBlock(self, WhichPartition):
+                if WhichPartition >=  self.NumberOfBatchJobs: return -1
+                return (WhichPartition/self.NumberOfSFO) % self.NumberOfLumiBlocksPerRun
+        def WhichRunNumber(self, WhichPartition):
+                if WhichPartition >=  self.NumberOfBatchJobs: return -1
+                return self.RunNumberBase + (WhichPartition/self.NumberOfSFO)/self.NumberOfLumiBlocksPerRun
+        def FinishedLuminosityFraction(self, WhichPartition):
+                if WhichPartition >=  self.NumberOfBatchJobs: return -1
+                lp = self.LuminosityPartition
+                theLB = (WhichPartition/self.NumberOfSFO)
+                totLB = (self.NumberOfBatchJobs/self.NumberOfSFO)
+                return sum(lp[0:theLB])/sum(lp[0:totLB])
+        def ThisLuminosityFraction(self, WhichPartition):
+                if WhichPartition >=  self.NumberOfBatchJobs: return -1
+                lp = self.LuminosityPartition
+                theLB = (WhichPartition/self.NumberOfSFO)
+                totLB = (self.NumberOfBatchJobs/self.NumberOfSFO)
+                return ((lp[theLB])/sum(lp[0:totLB]))
+        def __init__(self,name='mixStreamConfig',metaData=[]):
+                TransformConfig.__init__(self,name,metaData)
             
 # make default configuration object -- once.
-if not 'mixStreamConfig' in dir():
-	mixStreamConfig = MixStreamConfig()
+if 'mixStreamConfig' not in dir():
+        mixStreamConfig = MixStreamConfig()
 
-	
+
+############################################
+# MixingPartitioner
 ############################################
-# MixingPartitioner		
-############################################		
 # Usage:
 # m = MixingPartitioner()                      #Selects files
 # m.SetPartition(thisJob)                      #for batch job number \<thisJob\>
@@ -127,112 +117,111 @@ if not 'mixStreamConfig' in dir():
 # ...StreamAlg.SamplesToWeight = m.ListOfSamplesToWeight()
 # ...StreamAlg.SampleWeights   = m.ListOfSampleWeights()
 ############################################
-				
+
 class MixingPartitioner(object):
-	""" This collects input files to add to the stager, and generates python to configure EventMixer and your optional MCRunNumber-based event weighting service. """	
-	def __init__(self):
-		self.__ThisPartition = -1     
-		self.__Selectors = {}           #dataset aliases (like 5009) : MixingSelector object
-		self.__DatasetsToWeight = {}    #hash of dataset weights (indexed by MC run number)
-		self.__ThisScaleFactor = -1
-		self.__ScaleFactorSum = -1
-		self.__NumPartitions = -1
-			
-	def SetPartition(self,thisPartition):
-		"""Must be done  when partitionArg and mixStreamConfig gets a value."""
-		if self.__ThisPartition < 0 :                                                              #first time
-			for s in mixStreamConfig.JobSelectors:                                                     
-				self.__Selectors[s.DSID()] = s
-			self.__NumPartitions =  mixStreamConfig.NumberOfBatchJobs
-			
-		self.__ThisPartition = thisPartition		
-		if self.__ThisPartition < 0 :
-			print("*** MixingPartitioner: WARNING you requested an invalid partition number: setting to 0. *** ")
-			self.__ThisPartition = 0;		
-		else:
-			if self.__ThisPartition >= (self.__NumPartitions - 1):
-				print("*** MixingPartitioner: WARNING you requested an invalid (big) partition number: setting to", self.__NumPartitions - 1, ". *** ")
-				self.__ThisPartition = self.__NumPartitions - 1;
-			else:
-				print("*** MixingPartitioner: INFO you requested partition number", self.__ThisPartition)
-		self.__ThisScaleFactor = mixStreamConfig.ThisLuminosityFraction(self.__ThisPartition)      #the job config knows partitioning
-		self.__ScaleFactorSum  = mixStreamConfig.FinishedLuminosityFraction(self.__ThisPartition)  #the job config knows partitioning
-		
-
-	def AddSample(self, fileList, ksample, nEvents, newAlias=-1, nEventsPerFile=50):
-		if not (ksample in self.__Selectors):
-			self.__Selectors[ksample] = MixingSelector(self.__NumPartitions,ksample,nEvents,nEventsPerFile)
-			self.__Selectors[ksample].addNewCatalog(fileList)
-		else:
-			self.__Selectors[ksample].addNewCatalog(fileList)
-			if newAlias > 0: self.__Selectors[ksample].addAlias(newAlias)						
-			
-	def ConfigureServices(self):
-		EventMixerList = []
-		serviceString = "#Input selectors "
-		soFar = self.SoFar()
-		perSFOnow = self.PerSFOnow()		
-		for ksample in self.__Selectors:		
-			EventMixerList += [ self.__Selectors[ksample].trigger(soFar,perSFOnow) ]
-			serviceString += "\n%s =  EventSelectorAthenaPool( '%s' )" % (self.__Selectors[ksample].name(), self.__Selectors[ksample].name())
-			serviceString += "\nsvcMgr += %s" % self.__Selectors[ksample].name()
-			serviceString += "\n%s.InputCollections= ['%s']" % \
-					 (self.__Selectors[ksample].name(), ("', '").join(self.__Selectors[ksample].FilesToStage(soFar,perSFOnow)))
-		return EventMixerList, serviceString	
-	def ScaleFactor(self):
-		totalLumi = 1
-		return self.__ThisScaleFactor * totalLumi
-	def PerSFOnow(self):
-		return self.__ThisScaleFactor/mixStreamConfig.NumberOfSFO 		
-	def SoFar(self):
-		return self.__ScaleFactorSum + self.PerSFOnow() * (self.__ThisPartition % mixStreamConfig.NumberOfSFO)
-	def ConfigureSelectors(self):		
-		print("*** MixingPartitioner: INFO Partition ", self.__ThisPartition, " has a LB beginning after ", self.__ScaleFactorSum, "% of the input has been processed.")
-		print("*** MixingPartitioner: INFO Partition ", self.__ThisPartition, " has a LB reading ", self.__ThisScaleFactor * 100, "% of the input. ")
-		totalLumi = 1
-		print(":::::::::: STREAMING JOB CONFIGURATION: LHC INSTANTANEOUS LUMINOSITY= %f x 10^%i cm^-2 s^-1" % (self.ScaleFactor(), 31))
-		soFar = self.SoFar()
-		perSFOnow = self.PerSFOnow()
-		for ksample in self.__Selectors:
-			sel = self.__Selectors[ksample]						
-			if not sel.isSufficient():                   # prescale weighting is a TASK-GLOBAL! Read more, don't scale more.
-				print("*** MixingPartitioner: WARNING not enough events for %s -- (%s) will be weighted." % \
-				      (sel.name(), ','.join([str(ali) for ali in sel.Equivalents()]) ))
-				for aliasedID in sel.Equivalents():
-					self.__DatasetsToWeight[ aliasedID ] = sel.weight()					
-			print("*** MixingPartitioner: INFO \t%s FirstFile=%s EvOffset=%i NeV=%f" % \
-			      (sel.name(), sel.firstFileIndex(soFar), sel.firstEventInFile(soFar), sel.totalEventsThisJob(perSFOnow)))
-
-	def preStageInputFiles(self,CastorOrDCache = 'Castor'):
-		from PyJobTransformsCore.FilePreStager import theFileStagerRobot		
-		if CastorOrDCache == 'Castor':
+        """ This collects input files to add to the stager, and generates python to configure EventMixer and your optional MCRunNumber-based event weighting service. """
+        def __init__(self):
+                self.__ThisPartition = -1
+                self.__Selectors = {}           #dataset aliases (like 5009) : MixingSelector object
+                self.__DatasetsToWeight = {}    #hash of dataset weights (indexed by MC run number)
+                self.__ThisScaleFactor = -1
+                self.__ScaleFactorSum = -1
+                self.__NumPartitions = -1
+
+        def SetPartition(self,thisPartition):
+                """Must be done  when partitionArg and mixStreamConfig gets a value."""
+                if self.__ThisPartition < 0 :                                                              #first time
+                        for s in mixStreamConfig.JobSelectors:
+                                self.__Selectors[s.DSID()] = s
+                        self.__NumPartitions =  mixStreamConfig.NumberOfBatchJobs
+
+                self.__ThisPartition = thisPartition
+                if self.__ThisPartition < 0 :
+                        print("*** MixingPartitioner: WARNING you requested an invalid partition number: setting to 0. *** ")
+                        self.__ThisPartition = 0
+                else:
+                        if self.__ThisPartition >= (self.__NumPartitions - 1):
+                                print("*** MixingPartitioner: WARNING you requested an invalid (big) partition number: setting to", self.__NumPartitions - 1, ". *** ")
+                                self.__ThisPartition = self.__NumPartitions - 1
+                        else:
+                                print("*** MixingPartitioner: INFO you requested partition number", self.__ThisPartition)
+                self.__ThisScaleFactor = mixStreamConfig.ThisLuminosityFraction(self.__ThisPartition)      #the job config knows partitioning
+                self.__ScaleFactorSum  = mixStreamConfig.FinishedLuminosityFraction(self.__ThisPartition)  #the job config knows partitioning
+
+
+        def AddSample(self, fileList, ksample, nEvents, newAlias=-1, nEventsPerFile=50):
+                if not (ksample in self.__Selectors):
+                        self.__Selectors[ksample] = MixingSelector(self.__NumPartitions,ksample,nEvents,nEventsPerFile)
+                        self.__Selectors[ksample].addNewCatalog(fileList)
+                else:
+                        self.__Selectors[ksample].addNewCatalog(fileList)
+                        if newAlias > 0: self.__Selectors[ksample].addAlias(newAlias)
+
+        def ConfigureServices(self):
+                EventMixerList = []
+                serviceString = "#Input selectors "
+                soFar = self.SoFar()
+                perSFOnow = self.PerSFOnow()
+                for ksample in self.__Selectors:
+                        EventMixerList += [ self.__Selectors[ksample].trigger(soFar,perSFOnow) ]
+                        serviceString += "\n%s =  EventSelectorAthenaPool( '%s' )" % (self.__Selectors[ksample].name(), self.__Selectors[ksample].name())
+                        serviceString += "\nsvcMgr += %s" % self.__Selectors[ksample].name()
+                        serviceString += "\n%s.InputCollections= ['%s']" % \
+                                         (self.__Selectors[ksample].name(), ("', '").join(self.__Selectors[ksample].FilesToStage(soFar,perSFOnow)))
+                return EventMixerList, serviceString
+        def ScaleFactor(self):
+                totalLumi = 1
+                return self.__ThisScaleFactor * totalLumi
+        def PerSFOnow(self):
+                return self.__ThisScaleFactor/mixStreamConfig.NumberOfSFO
+        def SoFar(self):
+                return self.__ScaleFactorSum + self.PerSFOnow() * (self.__ThisPartition % mixStreamConfig.NumberOfSFO)
+        def ConfigureSelectors(self):
+                print("*** MixingPartitioner: INFO Partition ", self.__ThisPartition, " has a LB beginning after ", self.__ScaleFactorSum, "% of the input has been processed.")
+                print("*** MixingPartitioner: INFO Partition ", self.__ThisPartition, " has a LB reading ", self.__ThisScaleFactor * 100, "% of the input. ")
+                print(":::::::::: STREAMING JOB CONFIGURATION: LHC INSTANTANEOUS LUMINOSITY= %f x 10^%i cm^-2 s^-1" % (self.ScaleFactor(), 31))
+                soFar = self.SoFar()
+                perSFOnow = self.PerSFOnow()
+                for ksample in self.__Selectors:
+                        sel = self.__Selectors[ksample]
+                        if not sel.isSufficient():                   # prescale weighting is a TASK-GLOBAL! Read more, don't scale more.
+                                print("*** MixingPartitioner: WARNING not enough events for %s -- (%s) will be weighted." % \
+                                      (sel.name(), ','.join([str(ali) for ali in sel.Equivalents()]) ))
+                                for aliasedID in sel.Equivalents():
+                                        self.__DatasetsToWeight[ aliasedID ] = sel.weight()
+                        print("*** MixingPartitioner: INFO \t%s FirstFile=%s EvOffset=%i NeV=%f" % \
+                              (sel.name(), sel.firstFileIndex(soFar), sel.firstEventInFile(soFar), sel.totalEventsThisJob(perSFOnow)))
+
+        def preStageInputFiles(self,CastorOrDCache = 'Castor'):
+                from PyJobTransformsCore.FilePreStager import theFileStagerRobot
+                if CastorOrDCache == 'Castor':
                         print("WARNING: Castor is not supported anymore")
-		else:
-			from StreamMix import DCachePreStager
-		fileList = self.ListOfFilesToStage()
-		# NOTE THAT FILES THAT DON'T START WITH PNFS OR DCACHE WILL NOT BE CHECKED.
-		filesNeedingAction = theFileStagerRobot.addFilesToStagerIfNeeded( fileList )
-		print("This job muust stage %i files" % len(filesNeedingAction))
-		for f in filesNeedingAction: print(f)
-		filesNotStaged = theFileStagerRobot.waitUntilAllFilesStaged()
-		if filesNotStaged:
-			problemFiles = ''
-			for filename,status in iteritems(filesNotStaged):
-				problemFiles += os.linesep + "%s:%s" % (filename,status)
-			raise IOError("Could not stage following files from tape:%s" % problemFiles )
-	
-	def ListOfSamplesToWeight(self):		
-		return [ k for k in self.__DatasetsToWeight ]
-	def ListOfSampleFractions(self):
-		return [ self.__DatasetsToWeight[k] for k in self.__DatasetsToWeight ]
-	def ListOfSampleColonWeights(self):
-
-		return [ str(k)+":"+("%f" % self.__DatasetsToWeight[k]) for k in self.__DatasetsToWeight ]
-	def ListOfFilesToStage(self):
-		tlst = []
-		soFar = self.SoFar()
-		perSFOnow = self.PerSFOnow()
-		for ksample in self.__Selectors:
-			sel = self.__Selectors[ksample]
-			tlst += sel.FilesToStage(soFar,perSFOnow)
-		return tlst
+                else:
+                        from StreamMix import DCachePreStager  # noqa: F401
+                fileList = self.ListOfFilesToStage()
+                # NOTE THAT FILES THAT DON'T START WITH PNFS OR DCACHE WILL NOT BE CHECKED.
+                filesNeedingAction = theFileStagerRobot.addFilesToStagerIfNeeded( fileList )
+                print("This job muust stage %i files" % len(filesNeedingAction))
+                for f in filesNeedingAction: print(f)
+                filesNotStaged = theFileStagerRobot.waitUntilAllFilesStaged()
+                if filesNotStaged:
+                        problemFiles = ''
+                        for filename,status in filesNotStaged.items():
+                                problemFiles += os.linesep + "%s:%s" % (filename,status)
+                        raise IOError("Could not stage following files from tape:%s" % problemFiles )
+
+        def ListOfSamplesToWeight(self):
+                return [ k for k in self.__DatasetsToWeight ]
+        def ListOfSampleFractions(self):
+                return [ self.__DatasetsToWeight[k] for k in self.__DatasetsToWeight ]
+        def ListOfSampleColonWeights(self):
+
+                return [ str(k)+":"+("%f" % self.__DatasetsToWeight[k]) for k in self.__DatasetsToWeight ]
+        def ListOfFilesToStage(self):
+                tlst = []
+                soFar = self.SoFar()
+                perSFOnow = self.PerSFOnow()
+                for ksample in self.__Selectors:
+                        sel = self.__Selectors[ksample]
+                        tlst += sel.FilesToStage(soFar,perSFOnow)
+                return tlst
diff --git a/Reconstruction/RecJobTransforms/python/MixingSelector.py b/Reconstruction/RecJobTransforms/python/MixingSelector.py
index fc45efc6628337f98acbe98d5e8ccd8179b747d3..87ab0160dbbb8dbb71b185fe49591e31d3fd46b4 100644
--- a/Reconstruction/RecJobTransforms/python/MixingSelector.py
+++ b/Reconstruction/RecJobTransforms/python/MixingSelector.py
@@ -1,8 +1,4 @@
-from __future__ import print_function
-from __future__ import division
-
-from builtins import object
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 #####################################
 # Utility class
@@ -11,86 +7,85 @@ from builtins import object
 from math import sqrt
 
 class MixingSelector(object):
-	"""This class configures one EventSelector with the MC dataset ID and the average events per job.
-	   Later, the user can add lists of physical file names, or equivalent DSIDs (e.g. 5010 == 5030).
-	   This class only works properly for fixed-sized input files. """	
-	def __init__(self, numJobs, datasetName, eventsRequired, eventsPerFile=50):
-		self.__np = numJobs
-		self.__dsid = datasetName
-		self.__evReq = eventsRequired
-		self.__evPerFile = eventsPerFile
-		self.__aliases = [ datasetName ]
-		self.__physical = []
-		print("*** MixingPartitioner: INFO Created new selector Selector%i requesting an average of %f events per job ***" % (datasetName, eventsRequired))
-	def name(self):
-		return "Selector"+str(self.__dsid)
-	def __str__(self):
-		""" These are for printing """
-		return self.name()+"[ev/job="+str(self.__evReq)+",nFiles="+str(len(self.__physical))+"]"
-	def __repr__(self):
-		return self.__str__()
-	def DSID(self):
-		return self.__dsid
-	def numFiles(self):
-		return len(self.__physical)
-	def numEvents(self):
-		return self.__evPerFile * len(self.__physical)
-	### functions to add new files to the selector ###				      
-	def addAlias(self,newAlias):
-		"""If some downstream module is weighting prescales based on MC run number, inform it that run number newAlias is equivalent to this __dsid."""
-		if not newAlias in self.__aliases:
-			print("*** MixingPartitioner: INFO \tEventInfo run number %i interpreted like %i. ***" % (newAlias, self.__dsid))
-			self.__aliases += [ newAlias ]			
-	def addNewCatalog(self, pfnlist):
-		if len(pfnlist) == 0:
-			print("*** MixingPartitioner: WARNING Adding empty list to %s?" % self.name())
-			return
-		if self.numFiles():
-			print("*** MixingPartitioner: INFO Files (%s ...) will be appended to %s. ***" % (pfnlist[0], self.name()))
-		else:
-			print("*** MixingPartitioner: INFO Using files (%s ...) to initialize %s. ***" % (pfnlist[0], self.name()))
-		self.__physical += pfnlist
-	### functions to calculate staging and mixer configuration ###				      )
-	def evAvailablePerJob(self):
-		#This allows a three-sigma "buffer" between jobs.
-		evraw = (1.0*self.numEvents())/self.__np
-		return (2 + evraw + 9 - 3 * sqrt(4 * evraw + 9))
-	def isSufficient(self):
-		if True: #For safety, you could redefine 'sufficient' to include in-file buffers.
-			return self.__evReq*self.__np <= (self.numEvents())
-		else:
-			return self.evAvailablePerJob() >= self.__evReq
-	def weight(self):
-		#This works regardless of how isSufficient() is defined.
-		if self.isSufficient():
-			return 1.0
-		else:
-			return self.evAvailablePerJob()/self.__evReq		
-	def firstFileIndex(self, fractionDone):
-		#Always use maximal job spacing.
-		return int ((self.numEvents()*fractionDone)/self.__evPerFile)
-	def firstEventInFile(self, fractionDone) :
-		return int (self.numEvents()*fractionDone) % self.__evPerFile	
-	def lastFileIndex(self, fractionDone, lumiFraction):
-		if not self.isSufficient():
-			# maximum of 1 file overlap!
-			return int( (self.numEvents()*(fractionDone + lumiFraction))/self.__evPerFile) + 1		
-		lastProbableFile = self.firstFileIndex(fractionDone) + 1
-		eventsRequired = self.__evReq * (lumiFraction * self.__np) 
-		lastProbableFile += int ((eventsRequired + 3 * sqrt(eventsRequired))/self.__evPerFile) #allow 3 sigma fluctuation.
-		if lastProbableFile > self.numFiles():
-			lastProbableFile = self.numFiles()
-		return lastProbableFile	
-	def totalEventsThisJob(self,lumiFraction):
-		if self.isSufficient():
-			return self.__evReq * (lumiFraction * self.__np)
-		else:
-			return self.evAvailablePerJob() * (lumiFraction * self.__np) #luminosities should not vary too much per job.		
-	def trigger(self,fractionDone,lumiFraction):
-		firstEvt = self.firstEventInFile(fractionDone)
-		return "EventSelectorAthenaPool/" + self.name() + ":" +	str(firstEvt) + ":"  + str(int(firstEvt + self.totalEventsThisJob(lumiFraction)))
-	def Equivalents(self):
-		return self.__aliases
-	def FilesToStage(self,fractionDone,lumiFraction):
-		return self.__physical[self.firstFileIndex(fractionDone):self.lastFileIndex(fractionDone,lumiFraction)]
-	
+        """This class configures one EventSelector with the MC dataset ID and the average events per job.
+           Later, the user can add lists of physical file names, or equivalent DSIDs (e.g. 5010 == 5030).
+           This class only works properly for fixed-sized input files. """
+        def __init__(self, numJobs, datasetName, eventsRequired, eventsPerFile=50):
+                self.__np = numJobs
+                self.__dsid = datasetName
+                self.__evReq = eventsRequired
+                self.__evPerFile = eventsPerFile
+                self.__aliases = [ datasetName ]
+                self.__physical = []
+                print("*** MixingPartitioner: INFO Created new selector Selector%i requesting an average of %f events per job ***" % (datasetName, eventsRequired))
+        def name(self):
+                return "Selector"+str(self.__dsid)
+        def __str__(self):
+                """ These are for printing """
+                return self.name()+"[ev/job="+str(self.__evReq)+",nFiles="+str(len(self.__physical))+"]"
+        def __repr__(self):
+                return self.__str__()
+        def DSID(self):
+                return self.__dsid
+        def numFiles(self):
+                return len(self.__physical)
+        def numEvents(self):
+                return self.__evPerFile * len(self.__physical)
+        ### functions to add new files to the selector ###
+        def addAlias(self,newAlias):
+                """If some downstream module is weighting prescales based on MC run number, inform it that run number newAlias is equivalent to this __dsid."""
+                if newAlias not in self.__aliases:
+                        print("*** MixingPartitioner: INFO \tEventInfo run number %i interpreted like %i. ***" % (newAlias, self.__dsid))
+                        self.__aliases += [ newAlias ]
+        def addNewCatalog(self, pfnlist):
+                if len(pfnlist) == 0:
+                        print("*** MixingPartitioner: WARNING Adding empty list to %s?" % self.name())
+                        return
+                if self.numFiles():
+                        print("*** MixingPartitioner: INFO Files (%s ...) will be appended to %s. ***" % (pfnlist[0], self.name()))
+                else:
+                        print("*** MixingPartitioner: INFO Using files (%s ...) to initialize %s. ***" % (pfnlist[0], self.name()))
+                self.__physical += pfnlist
+        ### functions to calculate staging and mixer configuration ###                                )
+        def evAvailablePerJob(self):
+                #This allows a three-sigma "buffer" between jobs.
+                evraw = (1.0*self.numEvents())/self.__np
+                return (2 + evraw + 9 - 3 * sqrt(4 * evraw + 9))
+        def isSufficient(self):
+                if True: #For safety, you could redefine 'sufficient' to include in-file buffers.
+                        return self.__evReq*self.__np <= (self.numEvents())
+                else:
+                        return self.evAvailablePerJob() >= self.__evReq
+        def weight(self):
+                #This works regardless of how isSufficient() is defined.
+                if self.isSufficient():
+                        return 1.0
+                else:
+                        return self.evAvailablePerJob()/self.__evReq
+        def firstFileIndex(self, fractionDone):
+                #Always use maximal job spacing.
+                return int ((self.numEvents()*fractionDone)/self.__evPerFile)
+        def firstEventInFile(self, fractionDone) :
+                return int (self.numEvents()*fractionDone) % self.__evPerFile
+        def lastFileIndex(self, fractionDone, lumiFraction):
+                if not self.isSufficient():
+                        # maximum of 1 file overlap!
+                        return int( (self.numEvents()*(fractionDone + lumiFraction))/self.__evPerFile) + 1
+                lastProbableFile = self.firstFileIndex(fractionDone) + 1
+                eventsRequired = self.__evReq * (lumiFraction * self.__np)
+                lastProbableFile += int ((eventsRequired + 3 * sqrt(eventsRequired))/self.__evPerFile) #allow 3 sigma fluctuation.
+                if lastProbableFile > self.numFiles():
+                        lastProbableFile = self.numFiles()
+                return lastProbableFile
+        def totalEventsThisJob(self,lumiFraction):
+                if self.isSufficient():
+                        return self.__evReq * (lumiFraction * self.__np)
+                else:
+                        return self.evAvailablePerJob() * (lumiFraction * self.__np) #luminosities should not vary too much per job.
+        def trigger(self,fractionDone,lumiFraction):
+                firstEvt = self.firstEventInFile(fractionDone)
+                return "EventSelectorAthenaPool/" + self.name() + ":" + str(firstEvt) + ":"  + str(int(firstEvt + self.totalEventsThisJob(lumiFraction)))
+        def Equivalents(self):
+                return self.__aliases
+        def FilesToStage(self,fractionDone,lumiFraction):
+                return self.__physical[self.firstFileIndex(fractionDone):self.lastFileIndex(fractionDone,lumiFraction)]
diff --git a/Reconstruction/RecJobTransforms/python/RDOFilePeeker.py b/Reconstruction/RecJobTransforms/python/RDOFilePeeker.py
index 9c0b2dab049633de86546f80891b47193f4cccdc..190f79423c13f051f7dc48bcac419f61705eedfd 100644
--- a/Reconstruction/RecJobTransforms/python/RDOFilePeeker.py
+++ b/Reconstruction/RecJobTransforms/python/RDOFilePeeker.py
@@ -1,6 +1,6 @@
 from past.builtins import basestring
 
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 def RDOFilePeeker(runArgs, skeletonLog):
     from PyUtils.MetaReader import read_metadata
@@ -30,14 +30,14 @@ def RDOFilePeeker(runArgs, skeletonLog):
     if '/Digitization/Parameters' in metadata:
         metadatadict = metadata['/Digitization/Parameters']
         if isinstance(metadatadict, list):
-            skeletonLog.warning("%s inputfile: %s contained %s sets of Dititization Metadata. Using the final set in the list.",inputtype,inputfile,len(metadatadict))
+            skeletonLog.warning("inputfile: %s contained %s sets of Dititization Metadata. Using the final set in the list.",input_file,len(metadatadict))
             metadatadict = metadatadict[-1]
     ##Get IOVDbGlobalTag
         if 'IOVDbGlobalTag' not in metadatadict:
             try:
                 if metadata['/TagInfo']['IOVDbGlobalTag'] is not None:
                     metadatadict['IOVDbGlobalTag'] = metadata['/TagInfo']['IOVDbGlobalTag']
-            except:
+            except Exception:
                 skeletonLog.warning("Failed to find IOVDbGlobalTag.")
     else:
         ##Patch for older hit files
@@ -89,7 +89,7 @@ def RDOFilePeeker(runArgs, skeletonLog):
             skeletonLog.debug(cmd)
             try:
                 exec(cmd)
-            except:
+            except Exception:
                 skeletonLog.warning('Failed to switch on subdetector %s',subdet)
         #hacks to reproduce the sub-set of DetFlags left on by RecExCond/AllDet_detDescr.py
         DetFlags.simulate.all_setOff()
diff --git a/Reconstruction/RecJobTransforms/python/RecConfig.py b/Reconstruction/RecJobTransforms/python/RecConfig.py
index 9586f252b15843f02cc6250e6f2b689db5a12c6b..f5421eeec6799e4c42119e575b2a48165f526d12 100644
--- a/Reconstruction/RecJobTransforms/python/RecConfig.py
+++ b/Reconstruction/RecJobTransforms/python/RecConfig.py
@@ -1,9 +1,8 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-import os
 __all__ = []
 
-from PyJobTransformsCore.TransformConfig import *
+from PyJobTransformsCore.TransformConfig import TransformConfig, Boolean, String, ListOfStrings
 
 class RecConfig(TransformConfig):
     # prevent any mistypings by not allowing dynamic members
diff --git a/Reconstruction/RecJobTransforms/python/recTransformUtils.py b/Reconstruction/RecJobTransforms/python/recTransformUtils.py
index 77a6bacc76b99a17a274b01d173c6043d3e006f5..28bee14f944b0afac1069c9e6e474fd0551400da 100644
--- a/Reconstruction/RecJobTransforms/python/recTransformUtils.py
+++ b/Reconstruction/RecJobTransforms/python/recTransformUtils.py
@@ -1,4 +1,4 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 ## @brief Module with standard reconstruction transform options and substeps
 
@@ -10,7 +10,7 @@ msg = logging.getLogger(__name__)
 import PyJobTransforms.trfArgClasses as trfArgClasses
 
 from PyJobTransforms.trfExe import athenaExecutor, dummyExecutor, DQMergeExecutor, reductionFrameworkExecutor, reductionFrameworkExecutorNTUP
-from PyJobTransforms.trfArgs import addD3PDArguments, addPrimaryDPDArguments, addExtraDPDTypes, addReductionArguments
+from PyJobTransforms.trfArgs import addPrimaryDPDArguments, addExtraDPDTypes, addReductionArguments
 
 
 def addCommonRecTrfArgs(parser):
diff --git a/Reconstruction/RecJobTransforms/python/recoTransforms.py b/Reconstruction/RecJobTransforms/python/recoTransforms.py
index ac7bddd6e1396924b9f75630cc86174a3bcee556..58e7282f5b7fc291fe4e2b806f512acedd23d049 100644
--- a/Reconstruction/RecJobTransforms/python/recoTransforms.py
+++ b/Reconstruction/RecJobTransforms/python/recoTransforms.py
@@ -1,11 +1,9 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 ## @brief Specialist reconstruction and bytestream transforms
 #  @author atlas-comp-jt-dev@cern.ch
-#  @version $Id: recoTransforms.py 611371 2014-08-12 09:21:15Z seuster $
 
 import os
-import re
 import subprocess
 
 import logging
@@ -39,21 +37,21 @@ class skimRawExecutor(scriptExecutor):
                         evtprefix, evtstr = splitStrings[2].split("=")
                         # Check sanity
                         if runprefix != "Run" or evtprefix != "Event":
-                            msg.warning("Failed to understand this line from AtlListBSEvents: {0}".format(line))
+                            msg.warning("Failed to understand this line from AtlListBSEvents: %s", line)
                         else:
-                            runnumber = int(runstr)
-                            evtnumber = int(evtstr)
+                            runnumber = int(runstr)  # noqa: F841
+                            evtnumber = int(evtstr)  # noqa: F841
                             # We build up a string key as "RUN-EVENT", so that we can take advantage of
                             # the fast hash search against a dictionary 
                             rawEventList[runstr + "-" + evtstr] = True
-                            msg.debug("Identified run {0}, event {1} in input RAW files".format(runstr, evtstr))
-                    except ValueError as e:
-                        msg.warning("Failed to understand this line from AtlListBSEvents: {0}".format(line))
+                            msg.debug("Identified run %s, event %s in input RAW files", runstr, evtstr)
+                    except ValueError:
+                        msg.warning("Failed to understand this line from AtlListBSEvents: %s", line)
         except subprocess.CalledProcessError as e:
             errMsg = "Call to AtlListBSEvents failed: {0}".format(e)
-            msg.error(erMsg)
+            msg.error(errMsg)
             raise trfExceptions.TransformExecutionException(trfExit.nameToCode("TRF_EXEC_SETUP_FAIL"), errMsg)
-        msg.info("Found {0} events as skim candidates in RAW inputs".format(len(rawEventList)))
+        msg.info("Found %d events as skim candidates in RAW inputs", len(rawEventList))
         
         # Now open the list of filter events, and check through them
         slimmedFilterFile = "slimmedFilterFile.{0}".format(os.getpid())
@@ -63,17 +61,17 @@ class skimRawExecutor(scriptExecutor):
                 try:
                     runstr, evtstr = line.split()
                     if runstr + "-" + evtstr in rawEventList:
-                        msg.debug("Found run {0}, event {1} in master filter list".format(runstr, evtstr))
+                        msg.debug("Found run %s, event %s in master filter list", runstr, evtstr)
                         os.write(slimFF.fileno(), line)
                         count += 1
                 except ValueError as e:
-                    msg.warning("Failed to understand this line from master filter file: {0} {1}".format(line, e))
+                    msg.warning("Failed to understand this line from master filter file: %s %s", line, e)
             if count == 0:
                 # If there are no matched events, create a bogus request for run and event 0 to keep
                 # AtlCopyBSEvent.exe CLI
                 msg.info("No events matched in this input file - empty RAW file output will be made")
                 os.write(slimFF.fileno(), "0 0\n")
-        msg.info("Matched {0} lines from the master filter file against input events; wrote these to {1}".format(count, slimmedFilterFile))
+        msg.info("Matched %d lines from the master filter file against input events; wrote these to %s", count, slimmedFilterFile)
         
         # Build up the right command line for acmd.py
         self._cmd = ['acmd.py', 'filter-files']
diff --git a/Reconstruction/RecJobTransforms/python/streaming_arg.py b/Reconstruction/RecJobTransforms/python/streaming_arg.py
deleted file mode 100644
index c19e18271a227e9c06112a2743ee8252fbc101cb..0000000000000000000000000000000000000000
--- a/Reconstruction/RecJobTransforms/python/streaming_arg.py
+++ /dev/null
@@ -1,72 +0,0 @@
-
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-__author__ = "Ayana.Holloway@cern.ch"
-__doc__ = """Arguments for streaming batch test."""
-
-from copy import copy
-from PyJobTransformsCore.basic_trfarg import *
-from RecJobTransforms.MixStreamConfig import *
-
-class PartitionArg(IntegerArg):
-    """Batch job ('partition') number of this job.  The trf will calculate the run/lumi/sfo number, and the offset into the input file lists, from this."""
-    def __init__(self,help='default',name='default'):
-        IntegerArg.__init__(self,help,name)
-        self.__mixPartitioner = MixingPartitioner()
-
-    def metaData(self):
-        val = self.value()
-        if val is None:
-            return {}
-        else:            
-            return { self.name() : self.value(),
-                     "pseudoRun" : mixStreamConfig.WhichRunNumber(self.value()),
-                     "pseudoSFO" : mixStreamConfig.WhichSFO(self.value()),
-                     "pseudoLumiBlock" : mixStreamConfig.WhichLumiBlock(self.value()),
-                     "pseudoLumiFraction" : mixStreamConfig.ThisLuminosityFraction(self.value()) }        
-                     
-    def GetPartitioner(self):
-        return self.__mixPartitioner
-
-    def isFullArgument(self):
-        return True
-
-    def jobOrTask(self):        
-        return 'job'
-
-    def preRunAction(self):
-        self.__mixPartitioner.SetPartition(self.value())
-        self.__mixPartitioner.ConfigureSelectors()
-        self.__mixPartitioner.preStageInputFiles()
-
-    def WritePartitionJobOptions(self):
-        EventMixerList, outstring = self.__mixPartitioner.ConfigureServices()
-        el = "',\n'"
-        sp = ", "
-
-        outstring += '\nprint ":::::::::: STREAMING JOB CONFIGURATION: LHC INSTANTANEOUS LUMINOSITY= %f x 10^%i cm^-2 s^-1"' % (self.__mixPartitioner.ScaleFactor(), 31)
-        outstring += "\nEventMixer.TriggerList += [ '%s' ]\n" % el.join(EventMixerList)
-
-        weighted = [str(i) for i in self.__mixPartitioner.ListOfSamplesToWeight()]
-        weights = [str(f) for f in self.__mixPartitioner.ListOfSampleFractions()]
-        if len(self.__mixPartitioner.ListOfSampleColonWeights()):
-            outstring += "\nWeightConfiguration = [ '%s' ]\n" % el.join(self.__mixPartitioner.ListOfSampleColonWeights())
-        else:
-            outstring += "\nWeightConfiguration = [ ]\n"
-        outstring += "\nListOfSamplesToWeight =  [%s]\n" %  sp.join(weighted)
-        outstring += "\nListOfSampleFractions =  [%s]\n" %  (sp).join(weights) 
-        return outstring
-
-
-#####################################
-
-class FakeTableArg(BoolArg):
-    """Toggle between simple trigger table and full table"""
-    def __init__(self,help='Toggle between simple trigger table and full table',name='default'):
-        BoolArg.__init__(self,help,name)
-
-    def isFullArgument(self):
-        return True
-
-    def jobOrTask(self):
-        return 'task'
diff --git a/Reconstruction/RecJobTransforms/share/TrigConfigForCosmic09RerunHLT.py b/Reconstruction/RecJobTransforms/share/TrigConfigForCosmic09RerunHLT.py
deleted file mode 100644
index c05889d25cb0c795c0896c09fa83a0725df554fd..0000000000000000000000000000000000000000
--- a/Reconstruction/RecJobTransforms/share/TrigConfigForCosmic09RerunHLT.py
+++ /dev/null
@@ -1,16 +0,0 @@
-# This sets up the trigger config for a BStoESD job
-# to use the HLT output XML file generated by a previous BStoBS step
-# and a fixed LVL1 file from the release which is broadly compatible
-# with the 2009 cosmic runs.
-# It is intended for special trigger reprocessing only.
-# Contact: Sylvie Brunet, Clemencia Mora or other trigger configuration experts
-
-##preInclude for all steps but enable only for RAWtoESD
-from RecExConfig.RecFlags import rec
-if rec.readRDO and rec.doESD:
-    from TriggerJobOpts.TriggerFlags import TriggerFlags as tf
-    tf.inputHLTconfigFile.set_Value_and_Lock("outputHLTconfig.xml")
-    tf.inputLVL1configFile.set_Value_and_Lock("TriggerMenuXML/LVL1config_Cosmic2009_v1_7-bit_trigger_types.xml")
-    tf.configForStartup.set_Value_and_Lock("HLToffline")
-    tf.configurationSourceList.set_Value_and_Lock(['xml'])
-    #don't set this in ESDtoAOD, it works with HLTonline since DS folders are stored in ESD metadata.
diff --git a/Reconstruction/RecJobTransforms/share/rawtodpd.py b/Reconstruction/RecJobTransforms/share/rawtodpd.py
deleted file mode 100644
index ea118d46a1d03365736dbc8eadfdfb2d354e804c..0000000000000000000000000000000000000000
--- a/Reconstruction/RecJobTransforms/share/rawtodpd.py
+++ /dev/null
@@ -1,12 +0,0 @@
-###############################################################
-#
-# Skeleton top job options for RAW->DESD
-# Put here outputs that require rec.doDPD=True
-#
-# TODO: Review of options supported here...
-#
-#==============================================================
-
-rec.doDPD = True
-rec.DPDMakerScripts.append("PrimaryDPDMaker/PrimaryDPDMaker.py")
-include( "RecExCommon/RecExCommon_topOptions.py" )
\ No newline at end of file
diff --git a/Reconstruction/RecoAlgs/IsolationAlgs/src/IsolationBuilder.cxx b/Reconstruction/RecoAlgs/IsolationAlgs/src/IsolationBuilder.cxx
index 4a52a704bee1968c34892df956390086fb366761..b2d683b7b41efe79be3e9a2f36b28d072f1892f4 100644
--- a/Reconstruction/RecoAlgs/IsolationAlgs/src/IsolationBuilder.cxx
+++ b/Reconstruction/RecoAlgs/IsolationAlgs/src/IsolationBuilder.cxx
@@ -4,55 +4,69 @@
   Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-// IsolationBuilder.cxx 
+// IsolationBuilder.cxx
 // Implementation file for class IsolationBuilder
-/////////////////////////////////////////////////////////////////// 
-
+///////////////////////////////////////////////////////////////////
 
 // Isolation includes
 #include "IsolationBuilder.h"
 #include "xAODEgamma/Egamma.h"
-#include "xAODEgamma/Photon.h"
 #include "xAODEgamma/EgammaxAODHelpers.h"
+#include "xAODEgamma/Photon.h"
 
-IsolationBuilder::IsolationBuilder( const std::string& name, 
-				    ISvcLocator* pSvcLocator ) : 
-  ::AthAlgorithm( name, pSvcLocator )
-{
-}
+IsolationBuilder::IsolationBuilder(const std::string& name,
+                                   ISvcLocator* pSvcLocator)
+  : ::AthReentrantAlgorithm(name, pSvcLocator)
+{}
 
 IsolationBuilder::~IsolationBuilder() {}
 
-StatusCode IsolationBuilder::initialize()
+StatusCode
+IsolationBuilder::initialize()
 {
-  ATH_MSG_INFO ("Initializing " << name() << "...");
-  
+  ATH_MSG_INFO("Initializing " << name() << "...");
+
   std::set<xAOD::Iso::IsolationFlavour> runIsoType;
-  
+
   ATH_MSG_DEBUG("Initializing central electrons");
-  ATH_CHECK(initializeIso(runIsoType, &m_elCaloIso, &m_elTrackIso, 
-			  m_ElectronContainerName,
-			  m_elisoInts, m_elcorInts, m_elcorIntsExtra,
-			  m_customConfigEl));
-  
+  ATH_CHECK(initializeIso(runIsoType,
+                          &m_elCaloIso,
+                          &m_elTrackIso,
+                          m_ElectronContainerName,
+                          m_elisoInts,
+                          m_elcorInts,
+                          m_elcorIntsExtra,
+                          m_customConfigEl));
+
   ATH_MSG_DEBUG("Initializing central photons");
-  ATH_CHECK(initializeIso(runIsoType, &m_phCaloIso, &m_phTrackIso, 
-			  m_PhotonContainerName,
-			  m_phisoInts, m_phcorInts, m_phcorIntsExtra,
-			  m_customConfigPh));
-  
+  ATH_CHECK(initializeIso(runIsoType,
+                          &m_phCaloIso,
+                          &m_phTrackIso,
+                          m_PhotonContainerName,
+                          m_phisoInts,
+                          m_phcorInts,
+                          m_phcorIntsExtra,
+                          m_customConfigPh));
+
   ATH_MSG_DEBUG("Initializing forward electrons");
-  ATH_CHECK(initializeIso(runIsoType, &m_feCaloIso, nullptr, 
-			  m_FwdElectronContainerName,
-			  m_feisoInts, m_fecorInts, m_fecorIntsExtra,
-			  m_customConfigFwd));
+  ATH_CHECK(initializeIso(runIsoType,
+                          &m_feCaloIso,
+                          nullptr,
+                          m_FwdElectronContainerName,
+                          m_feisoInts,
+                          m_fecorInts,
+                          m_fecorIntsExtra,
+                          m_customConfigFwd));
 
   ATH_MSG_DEBUG("Initializing muons");
-  ATH_CHECK(initializeIso(runIsoType, &m_muCaloIso, &m_muTrackIso, 
-			  m_MuonContainerName,
-			  m_muisoInts, m_mucorInts, m_mucorIntsExtra,
-			  m_customConfigMu));
-			  
+  ATH_CHECK(initializeIso(runIsoType,
+                          &m_muCaloIso,
+                          &m_muTrackIso,
+                          m_MuonContainerName,
+                          m_muisoInts,
+                          m_mucorInts,
+                          m_mucorIntsExtra,
+                          m_customConfigMu));
 
   // declare the dependencies
   // (need to do this since the WriteDecorHandleKeys are not properties
@@ -66,72 +80,76 @@ StatusCode IsolationBuilder::initialize()
   declareIso(m_muTrackIso);
 
   // Retrieve the tools (there three Calo ones are the same in fact)
-  if (!m_cellIsolationTool.empty() && runIsoType.find(xAOD::Iso::etcone) != runIsoType.end()) {
+  if (!m_cellIsolationTool.empty() &&
+      runIsoType.find(xAOD::Iso::etcone) != runIsoType.end()) {
     ATH_CHECK(m_cellIsolationTool.retrieve());
   } else {
     m_cellIsolationTool.disable();
   }
 
-  if (!m_topoIsolationTool.empty() && runIsoType.find(xAOD::Iso::topoetcone) != runIsoType.end()) {
+  if (!m_topoIsolationTool.empty() &&
+      runIsoType.find(xAOD::Iso::topoetcone) != runIsoType.end()) {
     ATH_CHECK(m_topoIsolationTool.retrieve());
   } else {
     m_topoIsolationTool.disable();
   }
 
-  if (!m_pflowIsolationTool.empty() && runIsoType.find(xAOD::Iso::neflowisol) != runIsoType.end()) {
+  if (!m_pflowIsolationTool.empty() &&
+      runIsoType.find(xAOD::Iso::neflowisol) != runIsoType.end()) {
     ATH_CHECK(m_pflowIsolationTool.retrieve());
   } else {
     m_pflowIsolationTool.disable();
   }
 
-  if (!m_trackIsolationTool.empty() && runIsoType.find(xAOD::Iso::IsolationFlavour::ptcone) != runIsoType.end()) {
+  if (!m_trackIsolationTool.empty() &&
+      runIsoType.find(xAOD::Iso::IsolationFlavour::ptcone) !=
+        runIsoType.end()) {
     ATH_CHECK(m_trackIsolationTool.retrieve());
   } else {
     m_trackIsolationTool.disable();
   }
-  
-  //initialise data handles
+
+  // initialise data handles
   ATH_CHECK(m_cellsKey.initialize(!m_cellIsolationTool.empty()));
 
   return StatusCode::SUCCESS;
 }
 
-StatusCode IsolationBuilder::finalize()
+StatusCode
+IsolationBuilder::finalize()
 {
-  ATH_MSG_INFO ("Finalizing " << name() << "...");
+  ATH_MSG_INFO("Finalizing " << name() << "...");
 
   return StatusCode::SUCCESS;
 }
 
-StatusCode IsolationBuilder::execute()
-{  
-  ATH_MSG_DEBUG ("Executing " << name() << "...");
+StatusCode
+IsolationBuilder::execute(const EventContext& ctx) const
+{
+  ATH_MSG_DEBUG("Executing " << name() << "...");
 
   // For etcone, needs the cells
+
+  const CaloCellContainer* cellColl = nullptr;
   if (!m_cellIsolationTool.empty()) {
-    SG::ReadHandle<CaloCellContainer> cellcoll(m_cellsKey);
-    
+    SG::ReadHandle<CaloCellContainer> cellcoll(m_cellsKey, ctx);
     // check is only used for serial running; remove when MT scheduler used
-    if(!cellcoll.isValid()) {
-      ATH_MSG_FATAL("Failed to retrieve cell container: "<< m_cellsKey.key());
+    if (!cellcoll.isValid()) {
+      ATH_MSG_FATAL("Failed to retrieve cell container: " << m_cellsKey.key());
       return StatusCode::FAILURE;
     }
-    
-    m_cellColl = cellcoll.cptr();
-  } else {
-    m_cellColl = nullptr;
+    cellColl = cellcoll.cptr();
   }
-
   // Compute isolations
 
   ATH_MSG_DEBUG("About to execute Electron calo iso");
-  ATH_CHECK(executeCaloIso(m_elCaloIso));
+  ATH_CHECK(executeCaloIso(m_elCaloIso, cellColl));
   ATH_MSG_DEBUG("About to execute Photon calo iso");
-  ATH_CHECK(executeCaloIso(m_phCaloIso));
+  ATH_CHECK(executeCaloIso(m_phCaloIso, cellColl));
   ATH_MSG_DEBUG("About to execute Forwerd Electron calo iso");
-  ATH_CHECK(executeCaloIso(m_feCaloIso));
+  ATH_CHECK(executeCaloIso(m_feCaloIso, cellColl));
   ATH_MSG_DEBUG("About to execute muon calo iso");
-  ATH_CHECK(executeCaloIso(m_muCaloIso));
+  ATH_CHECK(executeCaloIso(m_muCaloIso, cellColl));
 
   ATH_MSG_DEBUG("About to execute Electron track iso");
   ATH_CHECK(executeTrackIso(m_elTrackIso));
@@ -139,7 +157,7 @@ StatusCode IsolationBuilder::execute()
   ATH_CHECK(executeTrackIso(m_phTrackIso));
   ATH_MSG_DEBUG("About to execute Muon track iso");
   ATH_CHECK(executeTrackIso(m_muTrackIso));
-  
+
   return StatusCode::SUCCESS;
 }
 
@@ -151,7 +169,8 @@ IsolationBuilder::CaloIsoHelpKey::CaloIsoHelpKey(IDataHandleHolder* owningAlg)
 }
 
 // declare dependencies
-void IsolationBuilder::CaloIsoHelpKey::declare(IDataHandleHolder* owningAlg)
+void
+IsolationBuilder::CaloIsoHelpKey::declare(IDataHandleHolder* owningAlg)
 {
   isoDeco.declare(owningAlg);
   owningAlg->declare(corrBitsetDeco);
@@ -174,7 +193,8 @@ IsolationBuilder::TrackIsoHelpKey::TrackIsoHelpKey(IDataHandleHolder* owningAlg)
 }
 
 // declare dependencies
-void IsolationBuilder::TrackIsoHelpKey::declare(IDataHandleHolder* owningAlg)
+void
+IsolationBuilder::TrackIsoHelpKey::declare(IDataHandleHolder* owningAlg)
 {
   isoDeco.declare(owningAlg);
   isoDecoV.declare(owningAlg);
@@ -186,8 +206,9 @@ void IsolationBuilder::TrackIsoHelpKey::declare(IDataHandleHolder* owningAlg)
 }
 
 // constructor
-IsolationBuilder::CaloIsoHelpHandles::CaloIsoHelpHandles(const IsolationBuilder::CaloIsoHelpKey& keys) :
-  corrBitsetDeco(keys.corrBitsetDeco)
+IsolationBuilder::CaloIsoHelpHandles::CaloIsoHelpHandles(
+  const IsolationBuilder::CaloIsoHelpKey& keys)
+  : corrBitsetDeco(keys.corrBitsetDeco)
 {
   for (const auto& key : keys.isoDeco) {
     isoDeco.emplace_back(key);
@@ -196,15 +217,16 @@ IsolationBuilder::CaloIsoHelpHandles::CaloIsoHelpHandles(const IsolationBuilder:
     coreCorDeco.emplace(coreCor);
   }
   for (const auto& noncoreCor : keys.noncoreCorDeco) {
-    noncoreCorDeco.emplace(noncoreCor.first, 
-			   std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float> >{
-			     std::begin(noncoreCor.second),
-			       std::end(noncoreCor.second)});
+    noncoreCorDeco.emplace(
+      noncoreCor.first,
+      std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float>>{
+        std::begin(noncoreCor.second), std::end(noncoreCor.second) });
   }
 }
 
-IsolationBuilder::TrackIsoHelpHandles::TrackIsoHelpHandles(const IsolationBuilder::TrackIsoHelpKey& keys) :
-  corrBitsetDeco(keys.corrBitsetDeco)
+IsolationBuilder::TrackIsoHelpHandles::TrackIsoHelpHandles(
+  const IsolationBuilder::TrackIsoHelpKey& keys)
+  : corrBitsetDeco(keys.corrBitsetDeco)
 {
   for (const auto& key : keys.isoDeco) {
     isoDeco.emplace_back(key);
@@ -217,26 +239,29 @@ IsolationBuilder::TrackIsoHelpHandles::TrackIsoHelpHandles(const IsolationBuilde
   }
 }
 
-bool IsolationBuilder::isCoreCor(xAOD::Iso::IsolationCaloCorrection cor) {
-  return (cor == xAOD::Iso::coreCone || 
-	  cor == xAOD::Iso::coreConeSC || 
-	  cor == xAOD::Iso::coreMuon ||
-	  cor == xAOD::Iso::core57cells);
+bool
+IsolationBuilder::isCoreCor(xAOD::Iso::IsolationCaloCorrection cor)
+{
+  return (cor == xAOD::Iso::coreCone || cor == xAOD::Iso::coreConeSC ||
+          cor == xAOD::Iso::coreMuon || cor == xAOD::Iso::core57cells);
 }
 
-
-StatusCode IsolationBuilder::initializeIso(std::set<xAOD::Iso::IsolationFlavour>& runIsoType, // out
-					   std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey> >*  caloIsoMap, // out
-					   std::vector<std::pair<xAOD::Iso::IsolationFlavour,TrackIsoHelpKey> >* trackIsoMap, // out
-					   const std::string& containerName,
-					   const std::vector<std::vector<int> >& isoInts,
-					   const std::vector<std::vector<int> >& corInts,
-					   const std::vector<std::vector<int> >& corIntsExtra,
-					   const std::string& customConfig)
+StatusCode
+IsolationBuilder::initializeIso(
+  std::set<xAOD::Iso::IsolationFlavour>& runIsoType, // out
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>*
+    caloIsoMap, // out
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, TrackIsoHelpKey>>*
+    trackIsoMap, // out
+  const std::string& containerName,
+  const std::vector<std::vector<int>>& isoInts,
+  const std::vector<std::vector<int>>& corInts,
+  const std::vector<std::vector<int>>& corIntsExtra,
+  const std::string& customConfig)
 {
-  
+
   std::string prefix = containerName + ".";
-  
+
   for (size_t flavor = 0; flavor < isoInts.size(); flavor++) {
     // iterate over the flavor (cell, topo, eflow, track
     //   Note: it is a configuration error if different types
@@ -244,50 +269,56 @@ StatusCode IsolationBuilder::initializeIso(std::set<xAOD::Iso::IsolationFlavour>
 
     CaloIsoHelpKey cisoH(this);
     TrackIsoHelpKey tisoH(this);
-    
-    //std::vector<SG::AuxElement::Decorator<float>*> Deco;
-    xAOD::Iso::IsolationFlavour isoFlav =
-      xAOD::Iso::numIsolationFlavours;
-    xAOD::Iso::IsolationFlavour oldIsoFlav =
-      xAOD::Iso::numIsolationFlavours;
-
-    for (size_t type = 0; type < isoInts[flavor].size();type++) { 
+
+    // std::vector<SG::AuxElement::Decorator<float>*> Deco;
+    xAOD::Iso::IsolationFlavour isoFlav = xAOD::Iso::numIsolationFlavours;
+    xAOD::Iso::IsolationFlavour oldIsoFlav = xAOD::Iso::numIsolationFlavours;
+
+    for (size_t type = 0; type < isoInts[flavor].size(); type++) {
       // iterate over the cone sizes for a given flavor.
-      // (also check that the cone sizes really are of the same flavor; otherwise an error)
-      
-      xAOD::Iso::IsolationType isoType = static_cast<xAOD::Iso::IsolationType>(isoInts[flavor][type]);
+      // (also check that the cone sizes really are of the same flavor;
+      // otherwise an error)
+
+      xAOD::Iso::IsolationType isoType =
+        static_cast<xAOD::Iso::IsolationType>(isoInts[flavor][type]);
       isoFlav = xAOD::Iso::isolationFlavour(isoType);
       ATH_MSG_DEBUG("Saw isoType " << isoType << " and isoFlav " << isoFlav);
-      if (oldIsoFlav != xAOD::Iso::numIsolationFlavours && oldIsoFlav != isoFlav) {
-	ATH_MSG_FATAL("Configuration error:  can only have one type of isolation in inner vector");
-	return StatusCode::FAILURE;
+      if (oldIsoFlav != xAOD::Iso::numIsolationFlavours &&
+          oldIsoFlav != isoFlav) {
+        ATH_MSG_FATAL("Configuration error:  can only have one type of "
+                      "isolation in inner vector");
+        return StatusCode::FAILURE;
       }
       oldIsoFlav = isoFlav;
       std::string isoName = prefix + xAOD::Iso::toString(isoType);
-      if (customConfig != "") {
-	isoName += "_" + customConfig;
+      if (!customConfig.empty()) {
+        isoName += "_" + customConfig;
       }
-      if (isoFlav == xAOD::Iso::etcone || isoFlav == xAOD::Iso::topoetcone || isoFlav == xAOD::Iso::neflowisol) {
-	cisoH.isoTypes.push_back(isoType);
-	cisoH.isoDeco.emplace_back(isoName);
+      if (isoFlav == xAOD::Iso::etcone || isoFlav == xAOD::Iso::topoetcone ||
+          isoFlav == xAOD::Iso::neflowisol) {
+        cisoH.isoTypes.push_back(isoType);
+        cisoH.isoDeco.emplace_back(isoName);
       } else if (isoFlav == xAOD::Iso::ptcone) {
-	tisoH.isoTypes.push_back(isoType);
-	tisoH.isoDeco.emplace_back(isoName);
-	auto coneSize = static_cast<int>(round(100*xAOD::Iso::coneSize(isoType)));
-	std::string isoNameV = prefix + "ptvarcone" + std::to_string(coneSize);
-	if (customConfig != "") {
-	  isoNameV += "_" + customConfig;
-	}
-	tisoH.isoDecoV.emplace_back(isoNameV);
+        tisoH.isoTypes.push_back(isoType);
+        tisoH.isoDeco.emplace_back(isoName);
+        auto coneSize =
+          static_cast<int>(round(100 * xAOD::Iso::coneSize(isoType)));
+        std::string isoNameV = prefix + "ptvarcone" + std::to_string(coneSize);
+        if (!customConfig.empty()) {
+          isoNameV += "_" + customConfig;
+        }
+        tisoH.isoDecoV.emplace_back(isoNameV);
       } else {
-	ATH_MSG_FATAL("Configuration error: Isolation flavor " << isoFlav << " not supported.");
-	return StatusCode::FAILURE;
-      }	
+        ATH_MSG_FATAL("Configuration error: Isolation flavor "
+                      << isoFlav << " not supported.");
+        return StatusCode::FAILURE;
+      }
     }
-  
+
     // check that there were isolations configured
     if (isoFlav == xAOD::Iso::numIsolationFlavours) {
-      ATH_MSG_WARNING("The configuration was malformed: an empty inner vector was added; ignoring");
+      ATH_MSG_WARNING("The configuration was malformed: an empty inner vector "
+                      "was added; ignoring");
       continue;
     }
 
@@ -298,133 +329,149 @@ StatusCode IsolationBuilder::initializeIso(std::set<xAOD::Iso::IsolationFlavour>
     // and finally add it to the IsoMap.
     ///////////////////////////////
 
-    if (isoFlav == xAOD::Iso::etcone || isoFlav == xAOD::Iso::topoetcone || isoFlav == xAOD::Iso::neflowisol) {
-      
+    if (isoFlav == xAOD::Iso::etcone || isoFlav == xAOD::Iso::topoetcone ||
+        isoFlav == xAOD::Iso::neflowisol) {
+
       // let's initialize the decos
       ATH_MSG_DEBUG("Initializing cisoH.isoDeco");
       ATH_CHECK(cisoH.isoDeco.initialize());
 
-      ATH_CHECK(addCaloIsoCorrections(flavor, isoFlav, cisoH, corInts, false, prefix, customConfig));
-      ATH_CHECK(addCaloIsoCorrections(flavor, isoFlav, cisoH, corIntsExtra, true, prefix, customConfig));
-      
+      ATH_CHECK(addCaloIsoCorrections(
+        flavor, isoFlav, cisoH, corInts, false, prefix, customConfig));
+      ATH_CHECK(addCaloIsoCorrections(
+        flavor, isoFlav, cisoH, corIntsExtra, true, prefix, customConfig));
+
       if (caloIsoMap) {
-	caloIsoMap->push_back(std::make_pair(isoFlav,cisoH));
+        caloIsoMap->push_back(std::make_pair(isoFlav, cisoH));
       } else {
-	ATH_MSG_FATAL("caloIsoMap was nullptr but the configuration attempted to use it");
-	return StatusCode::FAILURE;
+        ATH_MSG_FATAL(
+          "caloIsoMap was nullptr but the configuration attempted to use it");
+        return StatusCode::FAILURE;
       }
     } else if (isoFlav == xAOD::Iso::ptcone) {
-      
+
       // let's initialize the decos
       ATH_MSG_DEBUG("Initializing tisoH.isoDeco");
       ATH_CHECK(tisoH.isoDeco.initialize());
       ATH_MSG_DEBUG("Initializing tisoH.isoDecoV");
       ATH_CHECK(tisoH.isoDecoV.initialize());
-      
-      ATH_CHECK(addTrackIsoCorrections(flavor, isoFlav, tisoH, corInts, false, prefix, customConfig));
-      ATH_CHECK(addTrackIsoCorrections(flavor, isoFlav, tisoH, corIntsExtra, true, prefix, customConfig));
-      
+
+      ATH_CHECK(addTrackIsoCorrections(
+        flavor, isoFlav, tisoH, corInts, false, prefix, customConfig));
+      ATH_CHECK(addTrackIsoCorrections(
+        flavor, isoFlav, tisoH, corIntsExtra, true, prefix, customConfig));
+
       if (trackIsoMap) {
-	trackIsoMap->push_back(std::make_pair(isoFlav,tisoH));
+        trackIsoMap->push_back(std::make_pair(isoFlav, tisoH));
       } else {
-	ATH_MSG_FATAL("trackIsoMap was nullptr but the configuration attempted to use it");
-	return StatusCode::FAILURE;
-      }	
+        ATH_MSG_FATAL(
+          "trackIsoMap was nullptr but the configuration attempted to use it");
+        return StatusCode::FAILURE;
+      }
     } else {
-      ATH_MSG_WARNING("Isolation flavour " << xAOD::Iso::toCString(isoFlav) << " does not exist ! Check your inputs");
+      ATH_MSG_WARNING("Isolation flavour "
+                      << xAOD::Iso::toCString(isoFlav)
+                      << " does not exist ! Check your inputs");
     }
     runIsoType.insert(isoFlav);
   }
   return StatusCode::SUCCESS;
 }
 
-
-StatusCode IsolationBuilder::addCaloIsoCorrections(size_t flavor, 
-						   xAOD::Iso::IsolationFlavour isoFlav,
-						   CaloIsoHelpKey& cisoH,
-						   const std::vector<std::vector<int> >& corInts,
-						   bool corrsAreExtra,
-						   const std::string& prefix,
-						   const std::string& customConfig )
+StatusCode
+IsolationBuilder::addCaloIsoCorrections(
+  size_t flavor,
+  xAOD::Iso::IsolationFlavour isoFlav,
+  CaloIsoHelpKey& cisoH,
+  const std::vector<std::vector<int>>& corInts,
+  bool corrsAreExtra,
+  const std::string& prefix,
+  const std::string& customConfig)
 {
-  
+
   if (!corrsAreExtra) {
-    std::string bitsetName = prefix + xAOD::Iso::toString(isoFlav) + "CorrBitset";
-    if (customConfig != "") {
+    std::string bitsetName =
+      prefix + xAOD::Iso::toString(isoFlav) + "CorrBitset";
+    if (!customConfig.empty()) {
       bitsetName += "_" + customConfig;
     }
-    
+
     cisoH.corrBitsetDeco = bitsetName;
     ATH_MSG_DEBUG("Initializing " << cisoH.corrBitsetDeco.key());
     ATH_CHECK(cisoH.corrBitsetDeco.initialize());
   }
 
   for (size_t corrType = 0; corrType < corInts[flavor].size(); corrType++) {
-    
+
     // iterate over the calo isolation corrections
     const auto cor = static_cast<unsigned int>(corInts[flavor][corrType]);
-    if (!corrsAreExtra) cisoH.CorrList.calobitset.set(cor);
-    const xAOD::Iso::IsolationCaloCorrection isoCor = static_cast<xAOD::Iso::IsolationCaloCorrection>(cor);
-    
-    // ATH_MSG_DEBUG("for corrections, prefix = " << prefix << ", flavor = " << xAOD::Iso::toString(isoFlav)
-    // 	      << ", cor = " << xAOD::Iso::toString(isoCor) << ", coreEnergy " << xAOD::Iso::toString(xAOD::Iso::coreEnergy));
-    
-    
+    if (!corrsAreExtra)
+      cisoH.CorrList.calobitset.set(cor);
+    const xAOD::Iso::IsolationCaloCorrection isoCor =
+      static_cast<xAOD::Iso::IsolationCaloCorrection>(cor);
+
     if (isCoreCor(isoCor)) {
       std::string isoCorName = prefix;
-      
+
       if (isoCor != xAOD::Iso::core57cells) {
-	isoCorName += xAOD::Iso::toString(isoFlav); // since this doesn't depend on the flavor, just have one
+        isoCorName += xAOD::Iso::toString(
+          isoFlav); // since this doesn't depend on the flavor, just have one
       }
-      
+
       // a core correction; only store core energy, not the core area
-      isoCorName += xAOD::Iso::toString(isoCor) + xAOD::Iso::toString(xAOD::Iso::coreEnergy)
-	+ "Correction";
-      if (customConfig != "") {
-	isoCorName += "_" + customConfig;
+      isoCorName += xAOD::Iso::toString(isoCor) +
+                    xAOD::Iso::toString(xAOD::Iso::coreEnergy) + "Correction";
+      if (!customConfig.empty()) {
+        isoCorName += "_" + customConfig;
       }
       cisoH.coreCorDeco.emplace(isoCor, isoCorName);
       cisoH.coreCorDeco[isoCor].setOwner(this);
       ATH_MSG_DEBUG("initializing " << cisoH.coreCorDeco[isoCor].key());
       ATH_CHECK(cisoH.coreCorDeco[isoCor].initialize());
     } else if (isoCor == xAOD::Iso::pileupCorrection) {
-      // do not store pileup corrections as they are rho * pi * (R**2 - areaCore) and rho is stored...
+      // do not store pileup corrections as they are rho * pi * (R**2 -
+      // areaCore) and rho is stored...
       continue;
-    } else {	  
+    } else {
       // noncore correction
-      cisoH.noncoreCorDeco.emplace(isoCor, SG::WriteDecorHandleKeyArray<xAOD::IParticleContainer>() );
+      cisoH.noncoreCorDeco.emplace(
+        isoCor, SG::WriteDecorHandleKeyArray<xAOD::IParticleContainer>());
       auto& vec = cisoH.noncoreCorDeco[isoCor];
       vec.setOwner(this);
       for (auto type : cisoH.isoTypes) {
-	std::string corName = prefix + xAOD::Iso::toString(type) + xAOD::Iso::toString(isoCor) + "Correction";
-	if (customConfig != "") {
-	  corName += "_" + customConfig;
-	}
-	vec.emplace_back(corName);
+        std::string corName = prefix + xAOD::Iso::toString(type) +
+                              xAOD::Iso::toString(isoCor) + "Correction";
+        if (!customConfig.empty()) {
+          corName += "_" + customConfig;
+        }
+        vec.emplace_back(corName);
       }
-      ATH_MSG_DEBUG("Initializing " << xAOD::Iso::toString(isoCor) << " Corrections");
+      ATH_MSG_DEBUG("Initializing " << xAOD::Iso::toString(isoCor)
+                                    << " Corrections");
       ATH_CHECK(vec.initialize());
     }
   }
   return StatusCode::SUCCESS;
 }
 
-
-StatusCode IsolationBuilder::addTrackIsoCorrections(size_t flavor, 
-						    xAOD::Iso::IsolationFlavour isoFlav,
-						    TrackIsoHelpKey& tisoH,
-						    const std::vector<std::vector<int> >& corInts,
-						    bool corrsAreExtra,
-						    const std::string& prefix,
-						    const std::string& customConfig)
+StatusCode
+IsolationBuilder::addTrackIsoCorrections(
+  size_t flavor,
+  xAOD::Iso::IsolationFlavour isoFlav,
+  TrackIsoHelpKey& tisoH,
+  const std::vector<std::vector<int>>& corInts,
+  bool corrsAreExtra,
+  const std::string& prefix,
+  const std::string& customConfig)
 {
 
   if (!corrsAreExtra) {
-    std::string bitsetName = prefix + xAOD::Iso::toString(isoFlav) + "CorrBitset";
-    if (customConfig != "") {
+    std::string bitsetName =
+      prefix + xAOD::Iso::toString(isoFlav) + "CorrBitset";
+    if (!customConfig.empty()) {
       bitsetName += "_" + customConfig;
     }
-    
+
     tisoH.corrBitsetDeco = bitsetName;
     ATH_MSG_DEBUG("Initializing " << tisoH.corrBitsetDeco.key());
     ATH_CHECK(tisoH.corrBitsetDeco.initialize());
@@ -432,14 +479,16 @@ StatusCode IsolationBuilder::addTrackIsoCorrections(size_t flavor,
 
   for (size_t corrType = 0; corrType < corInts[flavor].size(); corrType++) {
     const auto cor = static_cast<unsigned int>(corInts[flavor][corrType]);
-    if (!corrsAreExtra) tisoH.CorrList.trackbitset.set(cor);
-    const xAOD::Iso::IsolationTrackCorrection isoCor = static_cast<xAOD::Iso::IsolationTrackCorrection>(cor);
-    
+    if (!corrsAreExtra)
+      tisoH.CorrList.trackbitset.set(cor);
+    const xAOD::Iso::IsolationTrackCorrection isoCor =
+      static_cast<xAOD::Iso::IsolationTrackCorrection>(cor);
+
     // all pt corrections are core type
-    std::string isoCorName = prefix + xAOD::Iso::toString(isoFlav) + 
-      xAOD::Iso::toString(isoCor) + "Correction";
-    
-    if (customConfig != "") {
+    std::string isoCorName = prefix + xAOD::Iso::toString(isoFlav) +
+                             xAOD::Iso::toString(isoCor) + "Correction";
+
+    if (!customConfig.empty()) {
       isoCorName += "_" + customConfig;
     }
     tisoH.coreCorDeco.emplace(isoCor, isoCorName);
@@ -450,227 +499,236 @@ StatusCode IsolationBuilder::addTrackIsoCorrections(size_t flavor,
   return StatusCode::SUCCESS;
 }
 
-StatusCode IsolationBuilder::executeCaloIso(const std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey> >& caloIsoMap)
+StatusCode
+IsolationBuilder::executeCaloIso(
+  const std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>&
+    caloIsoMap,
+  const CaloCellContainer* cellColl) const
 {
   for (const auto& pr : caloIsoMap) {
 
     const xAOD::Iso::IsolationFlavour flav = pr.first;
-    const auto& keys =  pr.second;
+    const auto& keys = pr.second;
     CaloIsoHelpHandles handles(keys);
 
     ATH_MSG_DEBUG("Executing calo iso flavor: " << xAOD::Iso::toString(flav));
 
     if (handles.isoDeco.empty()) {
-      ATH_MSG_FATAL("Have a CaloIsoHelpHandles with no actual isolations; something wrong happened");
+      ATH_MSG_FATAL("Have a CaloIsoHelpHandles with no actual isolations; "
+                    "something wrong happened");
       return StatusCode::FAILURE;
     }
-    auto& readHandle = handles.isoDeco[0]; // can treat the writeDecorHandle as a read handle;
+    auto& readHandle =
+      handles.isoDeco[0]; // can treat the writeDecorHandle as a read handle;
     if (!readHandle.isValid()) {
-      ATH_MSG_FATAL("Could not retrieve read handle for " << keys.isoDeco[0].key());
+      ATH_MSG_FATAL("Could not retrieve read handle for "
+                    << keys.isoDeco[0].key());
       return StatusCode::FAILURE;
     }
 
-    for (auto part : *readHandle) {
+    for (const auto *part : *readHandle) {
       xAOD::CaloIsolation CaloIsoResult;
       bool successfulCalc = false;
-      if (flav == xAOD::Iso::IsolationFlavour::etcone && m_cellColl) {
-	successfulCalc = m_cellIsolationTool->caloCellIsolation(CaloIsoResult, *part, keys.isoTypes, keys.CorrList, m_cellColl);
+      if (flav == xAOD::Iso::IsolationFlavour::etcone && cellColl) {
+        successfulCalc = m_cellIsolationTool->caloCellIsolation(
+          CaloIsoResult, *part, keys.isoTypes, keys.CorrList, cellColl);
       } else if (flav == xAOD::Iso::IsolationFlavour::topoetcone) {
-	successfulCalc = m_topoIsolationTool->caloTopoClusterIsolation(CaloIsoResult, *part, keys.isoTypes, keys.CorrList);
+        successfulCalc = m_topoIsolationTool->caloTopoClusterIsolation(
+          CaloIsoResult, *part, keys.isoTypes, keys.CorrList);
       } else if (flav == xAOD::Iso::IsolationFlavour::neflowisol) {
-	successfulCalc = m_pflowIsolationTool->neutralEflowIsolation(CaloIsoResult, *part, keys.isoTypes, keys.CorrList);
+        successfulCalc = m_pflowIsolationTool->neutralEflowIsolation(
+          CaloIsoResult, *part, keys.isoTypes, keys.CorrList);
       }
 
       if (successfulCalc) {
-	for (unsigned int i = 0; i < keys.isoTypes.size(); i++) {
-	  float iso = CaloIsoResult.etcones[i];
-	  ATH_MSG_DEBUG("custom Iso " << xAOD::Iso::toCString(keys.isoTypes[i]) << " = " << iso/1e3);
-	  (handles.isoDeco[i])(*part) = iso;
-	}
-	// corrections
-	(handles.corrBitsetDeco)(*part) = keys.CorrList.calobitset.to_ulong();
-
-	// // let's do the core corrections
-	// for (const auto& coreCorPr : CaloIsoResult.coreCorrections) {
-	//   std::map<xAOD::Iso::IsolationCorrectionParameter,float>::const_iterator it = 
-	//     coreCorPr.second.find(xAOD::Iso::coreEnergy);
-	//   if (it != coreCorPr.second.end()) {
-	//     ATH_MSG_DEBUG("About to write core correction: " << coreCorPr.first);
-	//     try {
-	//       (handles.coreCorDeco.at(coreCorPr.first))(*part) = it->second;
-	//     } catch (const std::exception& e) {
-	//       ATH_MSG_FATAL("Failed writing the core iso correction: " << e.what());
-	//       return StatusCode::FAILURE;
-	//     }
-	//   }
-	// }
-
-	// let's do the core corrections
-
-	// iterate over the values we want to store
-	for (auto& coreCorDecoPr : handles.coreCorDeco) {
-	  // find the matching result
-	  auto corIter = CaloIsoResult.coreCorrections.find(coreCorDecoPr.first);
-	  if (corIter == CaloIsoResult.coreCorrections.end()) {
-	    ATH_MSG_FATAL("Could not find core correction of required type: " << xAOD::Iso::toCString(coreCorDecoPr.first));
-	    ATH_MSG_FATAL("Check configuration");
-	    return StatusCode::FAILURE;
-	  }
-	  // now that we have the match, let's find the energy
-	  std::map<xAOD::Iso::IsolationCorrectionParameter,float>::const_iterator it = 
-	    corIter->second.find(xAOD::Iso::coreEnergy);
-	  if (it == corIter->second.end()) {
-	    ATH_MSG_FATAL("Could not find coreEnergy correction for: "  << xAOD::Iso::toCString(coreCorDecoPr.first));
-	    ATH_MSG_FATAL("Check configuration");
-	    return StatusCode::FAILURE;
-	  }
-	  ATH_MSG_DEBUG("About to write core correction: " << xAOD::Iso::toCString(coreCorDecoPr.first));
-	  (coreCorDecoPr.second)(*part) = it->second;
-	}
-
-	// // let's do the noncore corrections
-	// for (const auto& noncoreCorPr : CaloIsoResult.noncoreCorrections) {
-	//   auto& vecHandles = handles.noncoreCorDeco[noncoreCorPr.first];
-	//   if (vecHandles.size() != noncoreCorPr.second.size()) {
-	//     ATH_MSG_FATAL("Got back the wrong number of corrections for " << noncoreCorPr.first);
-	//     ATH_MSG_FATAL("  Expected: " << vecHandles.size() << ", received: " << noncoreCorPr.second.size());
-	//     return StatusCode::FAILURE;
-	//   }
-	//   for (size_t i = 0; i < vecHandles.size(); i++) {
-	//     (vecHandles[i])(*part) = noncoreCorPr.second[i];
-	//   }
-	// }
-
-	// let's do the noncore corrections
-	for (auto& noncoreCorDecoPr : handles.noncoreCorDeco) {
-	  // find the matching result
-	  auto corIter = CaloIsoResult.noncoreCorrections.find(noncoreCorDecoPr.first);
-	  if (corIter == CaloIsoResult.noncoreCorrections.end()) {
-	    ATH_MSG_FATAL("Could not find noncore correction of required type: " << xAOD::Iso::toCString(noncoreCorDecoPr.first));
-	    ATH_MSG_FATAL("Check configuration");
-	    return StatusCode::FAILURE;
-	  }
-
-	  ATH_MSG_DEBUG("About to write noncore correction: " << xAOD::Iso::toCString(noncoreCorDecoPr.first));
-	  auto& vecHandles = noncoreCorDecoPr.second;
-	  for (size_t i = 0; i < vecHandles.size(); i++) {
-	    (vecHandles[i])(*part) = corIter->second[i];
-	  }
-	}
+        for (unsigned int i = 0; i < keys.isoTypes.size(); i++) {
+          float iso = CaloIsoResult.etcones[i];
+          ATH_MSG_DEBUG("custom Iso " << xAOD::Iso::toCString(keys.isoTypes[i])
+                                      << " = " << iso / 1e3);
+          (handles.isoDeco[i])(*part) = iso;
+        }
+        // corrections
+        (handles.corrBitsetDeco)(*part) = keys.CorrList.calobitset.to_ulong();
+
+        // let's do the core corrections
+
+        // iterate over the values we want to store
+        for (auto& coreCorDecoPr : handles.coreCorDeco) {
+          // find the matching result
+          auto corIter =
+            CaloIsoResult.coreCorrections.find(coreCorDecoPr.first);
+          if (corIter == CaloIsoResult.coreCorrections.end()) {
+            ATH_MSG_FATAL("Could not find core correction of required type: "
+                          << xAOD::Iso::toCString(coreCorDecoPr.first));
+            ATH_MSG_FATAL("Check configuration");
+            return StatusCode::FAILURE;
+          }
+          // now that we have the match, let's find the energy
+          std::map<xAOD::Iso::IsolationCorrectionParameter,
+                   float>::const_iterator it =
+            corIter->second.find(xAOD::Iso::coreEnergy);
+          if (it == corIter->second.end()) {
+            ATH_MSG_FATAL("Could not find coreEnergy correction for: "
+                          << xAOD::Iso::toCString(coreCorDecoPr.first));
+            ATH_MSG_FATAL("Check configuration");
+            return StatusCode::FAILURE;
+          }
+          ATH_MSG_DEBUG("About to write core correction: "
+                        << xAOD::Iso::toCString(coreCorDecoPr.first));
+          (coreCorDecoPr.second)(*part) = it->second;
+        }
+
+        // let's do the noncore corrections
+        for (auto& noncoreCorDecoPr : handles.noncoreCorDeco) {
+          // find the matching result
+          auto corIter =
+            CaloIsoResult.noncoreCorrections.find(noncoreCorDecoPr.first);
+          if (corIter == CaloIsoResult.noncoreCorrections.end()) {
+            ATH_MSG_FATAL("Could not find noncore correction of required type: "
+                          << xAOD::Iso::toCString(noncoreCorDecoPr.first));
+            ATH_MSG_FATAL("Check configuration");
+            return StatusCode::FAILURE;
+          }
+
+          ATH_MSG_DEBUG("About to write noncore correction: "
+                        << xAOD::Iso::toCString(noncoreCorDecoPr.first));
+          auto& vecHandles = noncoreCorDecoPr.second;
+          for (size_t i = 0; i < vecHandles.size(); i++) {
+            (vecHandles[i])(*part) = corIter->second[i];
+          }
+        }
       } else {
-	ATH_MSG_FATAL("Call to CaloIsolationTool failed for flavor " << xAOD::Iso::toCString(flav));
-	return StatusCode::FAILURE;
+        ATH_MSG_FATAL("Call to CaloIsolationTool failed for flavor "
+                      << xAOD::Iso::toCString(flav));
+        return StatusCode::FAILURE;
       }
     }
   }
   return StatusCode::SUCCESS;
 }
 
-// FIXME:  need to add the electron bremAssoc
-StatusCode IsolationBuilder::executeTrackIso(const std::vector<std::pair<xAOD::Iso::IsolationFlavour,TrackIsoHelpKey > >& trackIsoMap)
+StatusCode
+IsolationBuilder::executeTrackIso(
+  const std::vector<std::pair<xAOD::Iso::IsolationFlavour, TrackIsoHelpKey>>&
+    trackIsoMap) const
 {
   for (const auto& pr : trackIsoMap) {
     const xAOD::Iso::IsolationFlavour flav = pr.first;
-    const auto& keys =  pr.second;
+    const auto& keys = pr.second;
     TrackIsoHelpHandles handles(keys);
 
     ATH_MSG_DEBUG("Executing track iso flavor: " << xAOD::Iso::toString(flav));
 
     if (handles.isoDeco.empty()) {
-      ATH_MSG_FATAL("Have a TrackIsoHelpHandles with no actual isolations; something wrong happened");
+      ATH_MSG_FATAL("Have a TrackIsoHelpHandles with no actual isolations; "
+                    "something wrong happened");
       return StatusCode::FAILURE;
     }
-    auto& readHandle = handles.isoDeco[0]; // can treat the writeDecorHandle as a read handle;
+    auto& readHandle =
+      handles.isoDeco[0]; // can treat the writeDecorHandle as a read handle;
     if (!readHandle.isValid()) {
-      ATH_MSG_FATAL("Could not retrieve read handle for " << keys.isoDeco[0].key());
+      ATH_MSG_FATAL("Could not retrieve read handle for "
+                    << keys.isoDeco[0].key());
       return StatusCode::FAILURE;
     }
 
-    for (auto part : *readHandle) {
+    for (const auto *part : *readHandle) {
       xAOD::TrackIsolation TrackIsoResult;
       bool successfulCalc = false;
       // check to see if we are dealing with an electron
-      auto *eg = dynamic_cast<const xAOD::Egamma*>(part);
+      const auto * eg = dynamic_cast<const xAOD::Egamma*>(part);
       if (eg) {
-	ATH_MSG_DEBUG("Doing track isolation on an egamma particle");
-	std::set<const xAOD::TrackParticle*> tracksToExclude;
-	if (xAOD::EgammaHelpers::isElectron(eg)) {
-	  tracksToExclude = xAOD::EgammaHelpers::getTrackParticles(eg, m_useBremAssoc);
-	} else {
-	  if (m_allTrackRemoval) { //New (from ??/??/16) : now this gives all tracks
-	    tracksToExclude = xAOD::EgammaHelpers::getTrackParticles(eg, m_useBremAssoc);
-	  } else { // this is just to be able to have the 2015+2016 default case (only tracks from first vertex)
-	    auto *gam = dynamic_cast<const xAOD::Photon *>(eg);
-	    if (gam && gam->nVertices() > 0) {
-	      const xAOD::Vertex *phvtx = gam->vertex(0);
-	      for (unsigned int itk = 0; itk < phvtx->nTrackParticles(); itk++)
-		tracksToExclude.insert(m_useBremAssoc ? xAOD::EgammaHelpers::getOriginalTrackParticleFromGSF(phvtx->trackParticle(itk)) : phvtx->trackParticle(itk));
-	    }
-	  }
-	}
-	successfulCalc = m_trackIsolationTool->trackIsolation(TrackIsoResult, *part, keys.isoTypes, keys.CorrList, nullptr, &tracksToExclude);
+        ATH_MSG_DEBUG("Doing track isolation on an egamma particle");
+        std::set<const xAOD::TrackParticle*> tracksToExclude;
+        if (xAOD::EgammaHelpers::isElectron(eg)) {
+          tracksToExclude =
+            xAOD::EgammaHelpers::getTrackParticles(eg, m_useBremAssoc);
+        } else {
+          if (m_allTrackRemoval) { // New (from ??/??/16) : now this gives all
+                                   // tracks
+            tracksToExclude =
+              xAOD::EgammaHelpers::getTrackParticles(eg, m_useBremAssoc);
+          } else { // this is just to be able to have the 2015+2016 default case
+                   // (only tracks from first vertex)
+            const auto * gam = dynamic_cast<const xAOD::Photon*>(eg);
+            if (gam && gam->nVertices() > 0) {
+              const xAOD::Vertex* phvtx = gam->vertex(0);
+              for (unsigned int itk = 0; itk < phvtx->nTrackParticles(); itk++)
+                tracksToExclude.insert(
+                  m_useBremAssoc
+                    ? xAOD::EgammaHelpers::getOriginalTrackParticleFromGSF(
+                        phvtx->trackParticle(itk))
+                    : phvtx->trackParticle(itk));
+            }
+          }
+        }
+        successfulCalc = m_trackIsolationTool->trackIsolation(TrackIsoResult,
+                                                              *part,
+                                                              keys.isoTypes,
+                                                              keys.CorrList,
+                                                              nullptr,
+                                                              &tracksToExclude);
       } else {
-	ATH_MSG_DEBUG("Not doing track isolation on an egamma particle");
-	successfulCalc = m_trackIsolationTool->trackIsolation(TrackIsoResult, *part, keys.isoTypes, keys.CorrList);
+        ATH_MSG_DEBUG("Not doing track isolation on an egamma particle");
+        successfulCalc = m_trackIsolationTool->trackIsolation(
+          TrackIsoResult, *part, keys.isoTypes, keys.CorrList);
       }
 
       if (successfulCalc) {
-	for (unsigned int i = 0; i < keys.isoTypes.size(); i++) {
-	  float iso = TrackIsoResult.ptcones[i];
-	  float isoV = TrackIsoResult.ptvarcones_10GeVDivPt[i];
-	  ATH_MSG_DEBUG("custom Iso " << xAOD::Iso::toCString(keys.isoTypes[i]) << " = " << iso/1e3 << ", var cone = " << isoV/1e3);
-	  (handles.isoDeco[i])(*part) = iso;
-	  (handles.isoDecoV[i])(*part) = isoV;
-	}
-
-	// corrections
-	(handles.corrBitsetDeco)(*part) = keys.CorrList.trackbitset.to_ulong();
-
-	// // let's do the core corrections
-	// for (const auto& coreCorPr : TrackIsoResult.coreCorrections) {
-	//   ATH_MSG_DEBUG("About to write track correction: " << coreCorPr.first);
-	//   try {
-	//     (handles.coreCorDeco.at(coreCorPr.first))(*part) = coreCorPr.second;
-	//   } catch (const std::exception& e) {
-	//     ATH_MSG_FATAL("Failed writing the track iso correction: " << e.what());
-	//     return StatusCode::FAILURE;
-	//   }
-	// }
-
-	// let's do the core corrections
-
-	// iterate over the values we want to store
-	for (auto& coreCorDecoPr : handles.coreCorDeco) {
-	  // find the matching result
-	  auto corIter = TrackIsoResult.coreCorrections.find(coreCorDecoPr.first);
-	  if (corIter == TrackIsoResult.coreCorrections.end()) {
-	    ATH_MSG_FATAL("Could not find core correction of required type: " << xAOD::Iso::toCString(coreCorDecoPr.first));
-	    ATH_MSG_FATAL("Check configuration");
-	    return StatusCode::FAILURE;
-	  }
-	  ATH_MSG_DEBUG("About to write tracking core correction: " << xAOD::Iso::toCString(coreCorDecoPr.first));
-	  (coreCorDecoPr.second)(*part) = corIter->second;
-	}
+        for (unsigned int i = 0; i < keys.isoTypes.size(); i++) {
+          float iso = TrackIsoResult.ptcones[i];
+          float isoV = TrackIsoResult.ptvarcones_10GeVDivPt[i];
+          ATH_MSG_DEBUG("custom Iso " << xAOD::Iso::toCString(keys.isoTypes[i])
+                                      << " = " << iso / 1e3
+                                      << ", var cone = " << isoV / 1e3);
+          (handles.isoDeco[i])(*part) = iso;
+          (handles.isoDecoV[i])(*part) = isoV;
+        }
+
+        // corrections
+        (handles.corrBitsetDeco)(*part) = keys.CorrList.trackbitset.to_ulong();
+        // let's do the core corrections
+        // iterate over the values we want to store
+        for (auto& coreCorDecoPr : handles.coreCorDeco) {
+          // find the matching result
+          auto corIter =
+            TrackIsoResult.coreCorrections.find(coreCorDecoPr.first);
+          if (corIter == TrackIsoResult.coreCorrections.end()) {
+            ATH_MSG_FATAL("Could not find core correction of required type: "
+                          << xAOD::Iso::toCString(coreCorDecoPr.first));
+            ATH_MSG_FATAL("Check configuration");
+            return StatusCode::FAILURE;
+          }
+          ATH_MSG_DEBUG("About to write tracking core correction: "
+                        << xAOD::Iso::toCString(coreCorDecoPr.first));
+          (coreCorDecoPr.second)(*part) = corIter->second;
+        }
 
       } else {
-	ATH_MSG_FATAL("Call to TrackIsolationTool failed for flavor " << xAOD::Iso::toCString(flav));
-	return StatusCode::FAILURE;
+        ATH_MSG_FATAL("Call to TrackIsolationTool failed for flavor "
+                      << xAOD::Iso::toCString(flav));
+        return StatusCode::FAILURE;
       }
     }
   }
   return StatusCode::SUCCESS;
 }
 
-void IsolationBuilder::declareIso(std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey> >& caloIso)
+void
+IsolationBuilder::declareIso(
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>& caloIso)
 {
-  for (auto &iso : caloIso) {
+  for (auto& iso : caloIso) {
     iso.second.declare(this);
   }
 }
 
-void IsolationBuilder::declareIso(std::vector<std::pair<xAOD::Iso::IsolationFlavour,TrackIsoHelpKey> >& trackIso)
+void
+IsolationBuilder::declareIso(
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, TrackIsoHelpKey>>&
+    trackIso)
 {
-  for (auto &iso : trackIso) {
+  for (auto& iso : trackIso) {
     iso.second.declare(this);
   }
 }
diff --git a/Reconstruction/RecoAlgs/IsolationAlgs/src/IsolationBuilder.h b/Reconstruction/RecoAlgs/IsolationAlgs/src/IsolationBuilder.h
index f5906ea2540d6e63a7ba48d9965c2ba4b3e576f1..fe82e54b96b0f8a8d7e12309077e2dd27656266e 100644
--- a/Reconstruction/RecoAlgs/IsolationAlgs/src/IsolationBuilder.h
+++ b/Reconstruction/RecoAlgs/IsolationAlgs/src/IsolationBuilder.h
@@ -1,12 +1,12 @@
 ///////////////////////// -*- C++ -*- /////////////////////////////
 
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
-// IsolationBuilder.h 
+// IsolationBuilder.h
 // Header file for class IsolationBuilder
-/////////////////////////////////////////////////////////////////// 
+///////////////////////////////////////////////////////////////////
 #ifndef ISOLATIONALGS_ISOLATIONBUILDER_H
 #define ISOLATIONALGS_ISOLATIONBUILDER_H 1
 
@@ -14,205 +14,287 @@
 #include "VectorVectorIntParser.h"
 
 // STL includes
-#include <string>
 #include <set>
-#include <vector>
+#include <string>
 #include <utility>
+#include <vector>
 
 // FrameWork includes
-#include "AthenaBaseComps/AthAlgorithm.h"
-#include "GaudiKernel/ToolHandle.h"
 #include "AthContainers/AuxElement.h"
+#include "AthenaBaseComps/AthReentrantAlgorithm.h"
+#include "GaudiKernel/ToolHandle.h"
 #include "StoreGate/ReadHandleKey.h"
-#include "StoreGate/WriteDecorHandleKeyArray.h"
-#include "StoreGate/WriteDecorHandleKey.h"
 #include "StoreGate/WriteDecorHandle.h"
+#include "StoreGate/WriteDecorHandleKey.h"
+#include "StoreGate/WriteDecorHandleKeyArray.h"
 
-#include "xAODPrimitives/IsolationType.h"
-#include "xAODPrimitives/IsolationFlavour.h"
 #include "RecoToolInterfaces/IsolationCommon.h"
+#include "xAODPrimitives/IsolationFlavour.h"
+#include "xAODPrimitives/IsolationType.h"
 
 #include "IsolationCorrections/IIsolationCorrectionTool.h"
+#include "xAODBase/IParticleContainer.h"
 #include "xAODPrimitives/IsolationConeSize.h"
 #include "xAODPrimitives/IsolationHelpers.h"
-#include "xAODPrimitives/IsolationFlavour.h"
-#include "xAODBase/IParticleContainer.h"
 
 #include "RecoToolInterfaces/ICaloCellIsolationTool.h"
 #include "RecoToolInterfaces/ICaloTopoClusterIsolationTool.h"
-#include "RecoToolInterfaces/ITrackIsolationTool.h"
 #include "RecoToolInterfaces/INeutralEFlowIsolationTool.h"
+#include "RecoToolInterfaces/ITrackIsolationTool.h"
 
 #include "CaloEvent/CaloCellContainer.h"
 
+class IsolationBuilder : public AthReentrantAlgorithm
+{
 
-class IsolationBuilder
-  : public ::AthAlgorithm
-{ 
-
-  /////////////////////////////////////////////////////////////////// 
-  // Public methods: 
-  /////////////////////////////////////////////////////////////////// 
- public: 
-
-  // Copy constructor: 
+  ///////////////////////////////////////////////////////////////////
+  // Public methods:
+  ///////////////////////////////////////////////////////////////////
+public:
+  // Copy constructor:
 
-  /// Constructor with parameters: 
-  IsolationBuilder( const std::string& name, ISvcLocator* pSvcLocator );
+  /// Constructor with parameters:
+  IsolationBuilder(const std::string& name, ISvcLocator* pSvcLocator);
 
-  /// Destructor: 
-  virtual ~IsolationBuilder(); 
+  /// Destructor:
+  virtual ~IsolationBuilder();
 
   // Athena algorithm's Hooks
-  virtual StatusCode  initialize();
-  virtual StatusCode  execute();
-  virtual StatusCode  finalize();
+  virtual StatusCode initialize() override final;
+  virtual StatusCode execute(const EventContext& ctx) const override final;
+  virtual StatusCode finalize() override final;
 
-  /////////////////////////////////////////////////////////////////// 
-  // Const methods: 
+  ///////////////////////////////////////////////////////////////////
+  // Const methods:
   ///////////////////////////////////////////////////////////////////
 
-  /////////////////////////////////////////////////////////////////// 
-  // Non-const methods: 
-  /////////////////////////////////////////////////////////////////// 
-
-  /////////////////////////////////////////////////////////////////// 
-  // Private data: 
-  /////////////////////////////////////////////////////////////////// 
- private: 
+  ///////////////////////////////////////////////////////////////////
+  // Non-const methods:
+  ///////////////////////////////////////////////////////////////////
 
-  /// Default constructor: 
+  ///////////////////////////////////////////////////////////////////
+  // Private data:
+  ///////////////////////////////////////////////////////////////////
+private:
+  /// Default constructor:
   IsolationBuilder();
 
   /// Containers (Is it best to make them as strings? Used by multiple handles)
-  Gaudi::Property <std::string> m_ElectronContainerName {this,
-      "ElectronCollectionContainerName", "Electrons"};
+  Gaudi::Property<std::string> m_ElectronContainerName{
+    this,
+    "ElectronCollectionContainerName",
+    "Electrons"
+  };
 
-  Gaudi::Property <std::string> m_FwdElectronContainerName {this,
-      "FwdElectronCollectionContainerName", "ForwardElectrons"};
+  Gaudi::Property<std::string> m_FwdElectronContainerName{
+    this,
+    "FwdElectronCollectionContainerName",
+    "ForwardElectrons"
+  };
 
-  Gaudi::Property <std::string> m_PhotonContainerName {this,
-      "PhotonCollectionContainerName", "Photons"};
+  Gaudi::Property<std::string> m_PhotonContainerName{
+    this,
+    "PhotonCollectionContainerName",
+    "Photons"
+  };
 
-  Gaudi::Property <std::string> m_MuonContainerName {this,
-      "MuonCollectionContainerName", "Muons"};
+  Gaudi::Property<std::string> m_MuonContainerName{
+    this,
+    "MuonCollectionContainerName",
+    "Muons"
+  };
 
   /** @brief Tool for cell isolation calculation */
-  ToolHandle<xAOD::ICaloCellIsolationTool> m_cellIsolationTool {this, 
-      "CaloCellIsolationTool", "", "Handle of the calo cell IsolationTool"};
+  ToolHandle<xAOD::ICaloCellIsolationTool> m_cellIsolationTool{
+    this,
+    "CaloCellIsolationTool",
+    "",
+    "Handle of the calo cell IsolationTool"
+  };
 
   /** @brief Cell container*/
-  SG::ReadHandleKey<CaloCellContainer> m_cellsKey {this,
-            "CellCollectionName", "AllCalo", "Name of container which contain calo cells"};
-  const CaloCellContainer* m_cellColl = nullptr;
-
+  SG::ReadHandleKey<CaloCellContainer> m_cellsKey{
+    this,
+    "CellCollectionName",
+    "AllCalo",
+    "Name of container which contain calo cells"
+  };
 
   /** @brief Tool for topo isolation calculation */
-  ToolHandle<xAOD::ICaloTopoClusterIsolationTool> m_topoIsolationTool {this,
-      "CaloTopoIsolationTool", "", "Handle of the calo topo IsolationTool"};
+  ToolHandle<xAOD::ICaloTopoClusterIsolationTool> m_topoIsolationTool{
+    this,
+    "CaloTopoIsolationTool",
+    "",
+    "Handle of the calo topo IsolationTool"
+  };
 
   /** @brief Tool for neutral pflow isolation calculation */
-  ToolHandle<xAOD::INeutralEFlowIsolationTool> m_pflowIsolationTool {this,
-      "PFlowIsolationTool", "", "Handle of the pflow IsolationTool"};
+  ToolHandle<xAOD::INeutralEFlowIsolationTool> m_pflowIsolationTool{
+    this,
+    "PFlowIsolationTool",
+    "",
+    "Handle of the pflow IsolationTool"
+  };
 
   /** @brief Tool for neutral pflow isolation calculation */
-  ToolHandle<xAOD::ITrackIsolationTool> m_trackIsolationTool {this,
-      "TrackIsolationTool", "", "Handle of the track IsolationTool"};
+  ToolHandle<xAOD::ITrackIsolationTool> m_trackIsolationTool{
+    this,
+    "TrackIsolationTool",
+    "",
+    "Handle of the track IsolationTool"
+  };
 
   // FIXME:  need to add the electron bremAssoc stuff
-  Gaudi::Property<bool> m_useBremAssoc {this, 
-      "useBremAssoc", true, "use track to track assoc after brem"};
+  Gaudi::Property<bool> m_useBremAssoc{ this,
+                                        "useBremAssoc",
+                                        true,
+                                        "use track to track assoc after brem" };
 
-  Gaudi::Property<bool> m_allTrackRemoval {this, 
-      "AllTrackRemoval", true};
+  Gaudi::Property<bool> m_allTrackRemoval{ this, "AllTrackRemoval", true };
 
   /** @brief Isolation types */
-  Gaudi::Property<std::vector<std::vector<int> > > m_elisoInts {this,
-      "ElIsoTypes", {}, 
-      "The isolation types to do for electrons: vector of vector of enum type Iso::IsolationType"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_elisoInts{
+    this,
+    "ElIsoTypes",
+    {},
+    "The isolation types to do for electrons: vector of vector of enum type "
+    "Iso::IsolationType"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_elcorInts {this,
-      "ElCorTypes", {}, 
-      "The correction types to do for electron iso: vector of vector of enum type Iso::IsolationCalo/TrackCorrection"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_elcorInts{
+    this,
+    "ElCorTypes",
+    {},
+    "The correction types to do for electron iso: vector of vector of enum "
+    "type Iso::IsolationCalo/TrackCorrection"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_elcorIntsExtra {this,
-      "ElCorTypesExtra", {}, 
-      "The extra correction types to store but not apply for electrons"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_elcorIntsExtra{
+    this,
+    "ElCorTypesExtra",
+    {},
+    "The extra correction types to store but not apply for electrons"
+  };
 
-  /** @brief Isolation types (for the alg. properties, only vector<vector<double>> available */
-  Gaudi::Property<std::vector<std::vector<int> > > m_phisoInts {this,
-      "PhIsoTypes", {}, 
-      "The isolation types to do for photons: vector of vector of enum type Iso::IsolationType"};
+  /** @brief Isolation types (for the alg. properties, only
+   * vector<vector<double>> available */
+  Gaudi::Property<std::vector<std::vector<int>>> m_phisoInts{
+    this,
+    "PhIsoTypes",
+    {},
+    "The isolation types to do for photons: vector of vector of enum type "
+    "Iso::IsolationType"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_phcorInts {this,
-      "PhCorTypes", {}, 
-      "The correction types to do for photons iso: vector of vector of enum type Iso::IsolationCalo/TrackCorrection"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_phcorInts{
+    this,
+    "PhCorTypes",
+    {},
+    "The correction types to do for photons iso: vector of vector of enum type "
+    "Iso::IsolationCalo/TrackCorrection"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_phcorIntsExtra {this,
-      "PhCorTypesExtra", {}, 
-      "The extra correction types to store but not apply for photons"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_phcorIntsExtra{
+    this,
+    "PhCorTypesExtra",
+    {},
+    "The extra correction types to store but not apply for photons"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_muisoInts {this,
-      "MuIsoTypes", {}, 
-      "The isolation types to do for Muons : vector of vector of enum type Iso::IsolationType"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_muisoInts{
+    this,
+    "MuIsoTypes",
+    {},
+    "The isolation types to do for Muons : vector of vector of enum type "
+    "Iso::IsolationType"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_mucorInts {this,
-      "MuCorTypes", {}, 
-      "The correction types to do for Muon iso: vector of vector of enum type Iso::IsolationCalo/TrackCorrection"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_mucorInts{
+    this,
+    "MuCorTypes",
+    {},
+    "The correction types to do for Muon iso: vector of vector of enum type "
+    "Iso::IsolationCalo/TrackCorrection"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_mucorIntsExtra {this,
-      "MuCorTypesExtra", {}, 
-      "The extra correction types to store but not apply for muons"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_mucorIntsExtra{
+    this,
+    "MuCorTypesExtra",
+    {},
+    "The extra correction types to store but not apply for muons"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_feisoInts {this,
-      "FeIsoTypes", {},
-      "The isolation types to do for forward electron: vector of vector of enum type Iso::IsolationType"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_feisoInts{
+    this,
+    "FeIsoTypes",
+    {},
+    "The isolation types to do for forward electron: vector of vector of enum "
+    "type Iso::IsolationType"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_fecorInts {this,
-      "FeCorTypes", {}, 
-      "The correction types to do for forward electron iso: vector of vector of enum type Iso::IsolationCalo/TrackCorrection"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_fecorInts{
+    this,
+    "FeCorTypes",
+    {},
+    "The correction types to do for forward electron iso: vector of vector of "
+    "enum type Iso::IsolationCalo/TrackCorrection"
+  };
 
-  Gaudi::Property<std::vector<std::vector<int> > > m_fecorIntsExtra {this,
-      "FeCorTypesExtra", {}, 
-      "The extra correction types to store but not apply for forward electrons"};
+  Gaudi::Property<std::vector<std::vector<int>>> m_fecorIntsExtra{
+    this,
+    "FeCorTypesExtra",
+    {},
+    "The extra correction types to store but not apply for forward electrons"
+  };
 
-  struct CaloIsoHelpKey {
+  struct CaloIsoHelpKey
+  {
     /// constructor
     CaloIsoHelpKey(IDataHandleHolder* owningAlg);
 
-    /// only to be called after placed in the final location, to propagate dependencies
+    /// only to be called after placed in the final location, to propagate
+    /// dependencies
     void declare(IDataHandleHolder* owningAlg);
 
     /// The actual isolations
     SG::WriteDecorHandleKeyArray<xAOD::IParticleContainer> isoDeco;
 
     /// The corrections (one per flavor)
-    std::map<xAOD::Iso::IsolationCaloCorrection, 
-	     SG::WriteDecorHandleKey<xAOD::IParticleContainer> > coreCorDeco;
+    std::map<xAOD::Iso::IsolationCaloCorrection,
+             SG::WriteDecorHandleKey<xAOD::IParticleContainer>>
+      coreCorDeco;
 
     /// The corrections (one per flavor/type combination)
-    std::map<xAOD::Iso::IsolationCaloCorrection, 
-	     SG::WriteDecorHandleKeyArray<xAOD::IParticleContainer> > noncoreCorDeco;
+    std::map<xAOD::Iso::IsolationCaloCorrection,
+             SG::WriteDecorHandleKeyArray<xAOD::IParticleContainer>>
+      noncoreCorDeco;
 
     /// the types of isolations to calculate
     std::vector<xAOD::Iso::IsolationType> isoTypes;
 
     /// to keep track of the corrections
-    xAOD::CaloCorrection CorrList; 
-    // xAOD::CaloCorrection CorrListExtra; // should ideally pass this, but not possible yet
+    xAOD::CaloCorrection CorrList;
+    // xAOD::CaloCorrection CorrListExtra; // should ideally pass this, but not
+    // possible yet
     SG::WriteDecorHandleKey<xAOD::IParticleContainer> corrBitsetDeco;
   };
 
-  std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey> > m_elCaloIso;
-  std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey> > m_phCaloIso;
-  std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey> > m_feCaloIso;
-  std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey> > m_muCaloIso;
-
-  struct TrackIsoHelpKey {
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>
+    m_elCaloIso;
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>
+    m_phCaloIso;
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>
+    m_feCaloIso;
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>
+    m_muCaloIso;
+
+  struct TrackIsoHelpKey
+  {
     /// constructor
     TrackIsoHelpKey(IDataHandleHolder* owningAlg);
 
-    /// only to be called after placed in the final location, to propagate dependencies
+    /// only to be called after placed in the final location, to propagate
+    /// dependencies
     void declare(IDataHandleHolder* owningAlg);
 
     /// The actual isolations
@@ -220,103 +302,134 @@ class IsolationBuilder
     SG::WriteDecorHandleKeyArray<xAOD::IParticleContainer> isoDecoV;
 
     /// The corrections
-    std::map<xAOD::Iso::IsolationTrackCorrection, 
-	     SG::WriteDecorHandleKey<xAOD::IParticleContainer> > coreCorDeco;
+    std::map<xAOD::Iso::IsolationTrackCorrection,
+             SG::WriteDecorHandleKey<xAOD::IParticleContainer>>
+      coreCorDeco;
 
     /// the types of isolations to calculate
     std::vector<xAOD::Iso::IsolationType> isoTypes;
 
     /// to keep track of the corrections
     xAOD::TrackCorrection CorrList;
-    // xAOD::TrackCorrection CorrListExtra; // should ideally pass this, but not possible yet
+    // xAOD::TrackCorrection CorrListExtra; // should ideally pass this, but not
+    // possible yet
     SG::WriteDecorHandleKey<xAOD::IParticleContainer> corrBitsetDeco;
   };
 
-  std::vector<std::pair<xAOD::Iso::IsolationFlavour,TrackIsoHelpKey> > m_elTrackIso;
-  std::vector<std::pair<xAOD::Iso::IsolationFlavour,TrackIsoHelpKey> > m_phTrackIso;
-  std::vector<std::pair<xAOD::Iso::IsolationFlavour,TrackIsoHelpKey> > m_muTrackIso;
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, TrackIsoHelpKey>>
+    m_elTrackIso;
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, TrackIsoHelpKey>>
+    m_phTrackIso;
+  std::vector<std::pair<xAOD::Iso::IsolationFlavour, TrackIsoHelpKey>>
+    m_muTrackIso;
 
-  struct CaloIsoHelpHandles {
+  struct CaloIsoHelpHandles
+  {
 
     CaloIsoHelpHandles(const CaloIsoHelpKey& keys);
 
-    std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float> > isoDeco;
-    std::map<xAOD::Iso::IsolationCaloCorrection, 
-	     SG::WriteDecorHandle<xAOD::IParticleContainer, float> > coreCorDeco;
-    std::map<xAOD::Iso::IsolationCaloCorrection, 
-	     std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float> > > noncoreCorDeco;
+    std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float>> isoDeco;
+    std::map<xAOD::Iso::IsolationCaloCorrection,
+             SG::WriteDecorHandle<xAOD::IParticleContainer, float>>
+      coreCorDeco;
+    std::map<xAOD::Iso::IsolationCaloCorrection,
+             std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float>>>
+      noncoreCorDeco;
     SG::WriteDecorHandle<xAOD::IParticleContainer, uint32_t> corrBitsetDeco;
   };
 
-
-  struct TrackIsoHelpHandles {
+  struct TrackIsoHelpHandles
+  {
 
     TrackIsoHelpHandles(const TrackIsoHelpKey& keys);
 
-    std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float> > isoDeco;
-    std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float> > isoDecoV;
-    std::map<xAOD::Iso::IsolationTrackCorrection, 
-	     SG::WriteDecorHandle<xAOD::IParticleContainer, float> > coreCorDeco;
+    std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float>> isoDeco;
+    std::vector<SG::WriteDecorHandle<xAOD::IParticleContainer, float>> isoDecoV;
+    std::map<xAOD::Iso::IsolationTrackCorrection,
+             SG::WriteDecorHandle<xAOD::IParticleContainer, float>>
+      coreCorDeco;
     SG::WriteDecorHandle<xAOD::IParticleContainer, uint32_t> corrBitsetDeco;
   };
 
-
   // for the time being, only mu vs eg, no separation in eg
-  Gaudi::Property<std::string> m_customConfigEl {this,
-      "CustomConfigurationNameEl", "", 
-      "use a custom configuration for electron"};
-
-  Gaudi::Property<std::string> m_customConfigPh {this,
-      "CustomConfigurationNamePh", "", 
-      "use a custom configuration for photon"};
+  Gaudi::Property<std::string> m_customConfigEl{
+    this,
+    "CustomConfigurationNameEl",
+    "",
+    "use a custom configuration for electron"
+  };
 
-  Gaudi::Property<std::string> m_customConfigFwd {this,
-      "CustomConfigurationNameFwd", "", 
-      "use a custom configuration for forward electron"};
+  Gaudi::Property<std::string> m_customConfigPh{
+    this,
+    "CustomConfigurationNamePh",
+    "",
+    "use a custom configuration for photon"
+  };
 
-  Gaudi::Property<std::string> m_customConfigMu {this,
-      "CustomConfigurationNameMu", "",
-      "use a custom configuration for muon"}; 
+  Gaudi::Property<std::string> m_customConfigFwd{
+    this,
+    "CustomConfigurationNameFwd",
+    "",
+    "use a custom configuration for forward electron"
+  };
 
+  Gaudi::Property<std::string> m_customConfigMu{
+    this,
+    "CustomConfigurationNameMu",
+    "",
+    "use a custom configuration for muon"
+  };
 
   static bool isCoreCor(xAOD::Iso::IsolationCaloCorrection corr);
 
-  /// called by algorithm initialize per object (electron, photon, forward electron, muon)
-  StatusCode initializeIso(std::set<xAOD::Iso::IsolationFlavour>& runIsoType, // out
-			   std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey > >* caloIsoMap, // out
-			   std::vector<std::pair<xAOD::Iso::IsolationFlavour,TrackIsoHelpKey > >* trackIsoMap, // out
-			   const std::string& containerName,
-			   const std::vector<std::vector<int> >& isoInts,
-			   const std::vector<std::vector<int> >& corInts,
-			   const std::vector<std::vector<int> >& corIntsExtra,
-			   const std::string& customConfig);
+  /// called by algorithm initialize per object (electron, photon, forward
+  /// electron, muon)
+  StatusCode initializeIso(
+    std::set<xAOD::Iso::IsolationFlavour>& runIsoType, // out
+    std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>*
+      caloIsoMap, // out
+    std::vector<std::pair<xAOD::Iso::IsolationFlavour, TrackIsoHelpKey>>*
+      trackIsoMap, // out
+    const std::string& containerName,
+    const std::vector<std::vector<int>>& isoInts,
+    const std::vector<std::vector<int>>& corInts,
+    const std::vector<std::vector<int>>& corIntsExtra,
+    const std::string& customConfig);
 
   /// called by initializeIso
-  StatusCode addCaloIsoCorrections(size_t flavor, 
-				   xAOD::Iso::IsolationFlavour isoFlav,
-				   CaloIsoHelpKey& cisoH, // in-out
-				   const std::vector<std::vector<int> >& corInts,
-				   bool corrsAreExtra,
-				   const std::string& prefix,
-				   const std::string& customConfig);
+  StatusCode addCaloIsoCorrections(size_t flavor,
+                                   xAOD::Iso::IsolationFlavour isoFlav,
+                                   CaloIsoHelpKey& cisoH, // in-out
+                                   const std::vector<std::vector<int>>& corInts,
+                                   bool corrsAreExtra,
+                                   const std::string& prefix,
+                                   const std::string& customConfig);
 
   /// called by initializeIso
-  StatusCode addTrackIsoCorrections(size_t flavor, 
-				    xAOD::Iso::IsolationFlavour isoFlav,
-				    TrackIsoHelpKey& tisoH, // in-out
-				    const std::vector<std::vector<int> >& corInts,
-				    bool corrsAreExtra,
-				    const std::string& prefix,
-				    const std::string& customConfig);
-
-  StatusCode executeCaloIso(const std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey> >& caloIsoMap);
-
-  StatusCode executeTrackIso(const std::vector<std::pair<xAOD::Iso::IsolationFlavour,TrackIsoHelpKey> >& trackIsoMap);
-  
-  void declareIso(std::vector<std::pair<xAOD::Iso::IsolationFlavour,CaloIsoHelpKey> >& caloIso);
-  void declareIso(std::vector<std::pair<xAOD::Iso::IsolationFlavour,TrackIsoHelpKey> >& trackIso);
- 
-}; 
-
+  StatusCode addTrackIsoCorrections(
+    size_t flavor,
+    xAOD::Iso::IsolationFlavour isoFlav,
+    TrackIsoHelpKey& tisoH, // in-out
+    const std::vector<std::vector<int>>& corInts,
+    bool corrsAreExtra,
+    const std::string& prefix,
+    const std::string& customConfig);
+
+  StatusCode executeCaloIso(
+    const std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>&
+      caloIsoMap,
+    const CaloCellContainer* cellColl) const;
+
+  StatusCode executeTrackIso(
+    const std::vector<std::pair<xAOD::Iso::IsolationFlavour, TrackIsoHelpKey>>&
+      trackIsoMap) const;
+
+  void declareIso(
+    std::vector<std::pair<xAOD::Iso::IsolationFlavour, CaloIsoHelpKey>>&
+      caloIso);
+  void declareIso(
+    std::vector<std::pair<xAOD::Iso::IsolationFlavour, TrackIsoHelpKey>>&
+      trackIso);
+};
 
 #endif //> !ISOLATIONALGS_ISOLATIONBUILDER_H
diff --git a/Reconstruction/RecoTools/TrackToCalo/src/CaloCellCollector.cxx b/Reconstruction/RecoTools/TrackToCalo/src/CaloCellCollector.cxx
index 357a422426f02d9e2b72674548c2b910a5d63280..8f77e037543c1e25522bff758abad9411832a15d 100644
--- a/Reconstruction/RecoTools/TrackToCalo/src/CaloCellCollector.cxx
+++ b/Reconstruction/RecoTools/TrackToCalo/src/CaloCellCollector.cxx
@@ -11,7 +11,6 @@
 #include "CaloEvent/CaloCellContainer.h"
 
 #include "CaloUtils/CaloCellList.h"
-#include "CaloEvent/CaloCellContainer.h"
 #include "CaloIdentifier/CaloCell_ID.h"
 #include "CaloDetDescr/CaloDetDescrManager.h"
 #include "CaloIdentifier/CaloIdManager.h"
diff --git a/Reconstruction/RecoTools/TrackToCalo/src/ParticleCaloCellAssociationTool.cxx b/Reconstruction/RecoTools/TrackToCalo/src/ParticleCaloCellAssociationTool.cxx
index cd37cc80bf6d45846112ec49a538741fe64f57eb..3271afdb171b77c051501fe9a6b0ab97dde27b0c 100644
--- a/Reconstruction/RecoTools/TrackToCalo/src/ParticleCaloCellAssociationTool.cxx
+++ b/Reconstruction/RecoTools/TrackToCalo/src/ParticleCaloCellAssociationTool.cxx
@@ -15,8 +15,6 @@
 #include "TrkCaloExtension/CaloExtension.h"
 #include "TrkCaloExtension/CaloExtensionHelpers.h"
 
-#include "CaloUtils/CaloCellList.h"
-
 #include "xAODTracking/TrackingPrimitives.h"
 #include <cmath>
 #include <memory>
diff --git a/Reconstruction/TrackCaloClusterRec/TrackCaloClusterRecValidation/src/TCCPlots.h b/Reconstruction/TrackCaloClusterRec/TrackCaloClusterRecValidation/src/TCCPlots.h
index e2827ab150f173cd47cd2bfee63753f43d4419e5..f5ca7981093fbb9c05f0871ce474c459b5b6ebe6 100644
--- a/Reconstruction/TrackCaloClusterRec/TrackCaloClusterRecValidation/src/TCCPlots.h
+++ b/Reconstruction/TrackCaloClusterRec/TrackCaloClusterRecValidation/src/TCCPlots.h
@@ -13,7 +13,6 @@
 #include "TCCPlotsBase.h"
 #include "xAODJet/JetContainer.h"
 #include "xAODTracking/TrackParticleContainer.h"
-#include "xAODTracking/TrackParticleContainer.h"
 #include "xAODCaloEvent/CaloClusterContainer.h"
 #include "xAODPFlow/TrackCaloClusterContainer.h"
 #include "xAODTruth/TruthParticleContainer.h"
@@ -694,4 +693,4 @@ inline const xAOD::TrackParticle* TCCPlots::getTrackParticlePtr(const xAOD::Trac
 
 
 
-#endif // TRACKCALOCLUSTERREC_TRACKCALOCLUSTERRECVALIDATION_TCCPLOTS_H
\ No newline at end of file
+#endif // TRACKCALOCLUSTERREC_TRACKCALOCLUSTERRECVALIDATION_TCCPLOTS_H
diff --git a/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp1.h b/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp1.h
index 2821e98b6a0abd71989da2c525b696469d26ee07..2972db15e063ba1df4f382244ad2a542dc94fd8b 100755
--- a/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp1.h
+++ b/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp1.h
@@ -77,7 +77,6 @@
 
 // next line can be removed as soon as TPCnvTokenList_p1.h is fixed (i.e. includes string)
 #include <string>
-#include "AthenaPoolUtilities/TPCnvTokenList_p1.h"
 
 #include <ios>
 
diff --git a/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp2.h b/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp2.h
index 145234daa5388be83f635e187436aeb3135f2a1c..4e524ed9aa5b83c701d83206832631d7f6f13ad0 100644
--- a/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp2.h
+++ b/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp2.h
@@ -69,7 +69,6 @@
 
 // next line can be removed as soon as TPCnvTokenList_p1.h is fixed (i.e. includes string)
 #include <string>
-#include "AthenaPoolUtilities/TPCnvTokenList_p1.h"
 
 #include <ios>
 
diff --git a/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp3.h b/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp3.h
index f6adc16d9fade075e982ae3850b6ae4d94749984..1918b4d644b9a3f93f7518fd470a2dc6b2d1f572 100644
--- a/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp3.h
+++ b/Reconstruction/TrackParticleTPCnv/TrackParticleTPCnv/TrackParticleContainer_tlp3.h
@@ -30,10 +30,6 @@
 
 #include <ios>
 
-#include "AthenaPoolUtilities/TPCnvTokenList_p1.h"
-
-#include <ios>
-
 namespace Rec
 {
     class TrackParticleContainer_tlp3
diff --git a/Reconstruction/eflowRec/src/eflowSubtractor.cxx b/Reconstruction/eflowRec/src/eflowSubtractor.cxx
index 32e8cdb511fc63c6085119ec08f0a3198d7fc192..4fe94c0c0175b0d7681e25f9dfa420ac936db207 100644
--- a/Reconstruction/eflowRec/src/eflowSubtractor.cxx
+++ b/Reconstruction/eflowRec/src/eflowSubtractor.cxx
@@ -9,7 +9,6 @@
  *      Author: zhangrui
  */
 
-#include "xAODCaloEvent/CaloCluster.h"
 #include "xAODCaloEvent/CaloCluster.h"
 #include "xAODCaloEvent/CaloClusterKineHelper.h"
 #include "eflowRec/eflowRecTrack.h"
@@ -21,7 +20,6 @@
 #include "eflowRec/eflowLayerIntegrator.h"
 #include "eflowRec/eflowEEtaBinnedParameters.h"
 #include "eflowRec/eflowSubtractor.h"
-#include "xAODCaloEvent/CaloClusterKineHelper.h"
 
 
 namespace eflowSubtract {
diff --git a/Reconstruction/egamma/EgammaPhysValMonitoring/src/ElectronPlots.cxx b/Reconstruction/egamma/EgammaPhysValMonitoring/src/ElectronPlots.cxx
index 42b93e86d4a470fc1ac3e488193c1c65d7a4f7e2..aaaf3241a06a6ed0991f13ad587118a42f8df702 100755
--- a/Reconstruction/egamma/EgammaPhysValMonitoring/src/ElectronPlots.cxx
+++ b/Reconstruction/egamma/EgammaPhysValMonitoring/src/ElectronPlots.cxx
@@ -7,18 +7,13 @@
 #include "xAODTruth/TruthParticle.h"
 #include "xAODTruth/TruthParticleContainer.h"
 #include "xAODTruth/TruthParticleAuxContainer.h"
-
-#include "xAODTruth/TruthParticle.h"
-#include "xAODTruth/TruthParticleContainer.h"
-#include "xAODTruth/TruthParticleAuxContainer.h"
-
 #include <iostream>
 using namespace std;
 using namespace MCTruthPartClassifier;
 
 namespace Egamma{
 
-ElectronPlots::ElectronPlots(PlotBase* pParent, const std::string& sDir, 
+ElectronPlots::ElectronPlots(PlotBase* pParent, const std::string& sDir,
 			     const std::string& sParticleType):PlotBase(pParent, sDir),
 							m_oKinAllRecoPlots(this, "All/KinPlots/", "All Reco "+ sParticleType +" Electron"),
 							m_oShowerShapesAllRecoPlots(this, "All/ShowerShapesPlots/","All Reco "+ sParticleType +" Electron"  ),
@@ -37,7 +32,7 @@ ElectronPlots::ElectronPlots(PlotBase* pParent, const std::string& sDir,
 						        nParticles(nullptr),
 							nTypeParticles(nullptr),
 							m_sParticleType(sParticleType)
-{}	
+{}
 
 void ElectronPlots::initializePlots(){
   nParticles = Book1D("n", "Number of"+ m_sParticleType + "s;#" + m_sParticleType + " electrons;Events", 15, 0, 15.);
@@ -50,27 +45,27 @@ void ElectronPlots::initializePlots(){
   m_oShowerShapesAllRecoPlots.fill(electron);
   m_oIsolationAllRecoPlots.fill(electron);
   m_oTrackAllRecoPlots.fill(electron);
- 
-  if(!isPrompt) return; 
-   
+
+  if(!isPrompt) return;
+
   m_oKinIsoRecoPlots.fill(electron);
   m_oShowerShapesIsoRecoPlots.fill(electron);
   m_oIsolationIsoRecoPlots.fill(electron);
   m_oTrackIsoRecoPlots.fill(electron);
- 
-  bool val_loose=false;    
+
+  bool val_loose=false;
   electron.passSelection(val_loose, "Loose");
   if(val_loose) {
     m_oKinIsoLoosePPPlots.fill(electron);
   }
 
-  bool val_med=false;  
+  bool val_med=false;
   electron.passSelection(val_med, "Medium");
   if(val_med) {
     m_oKinIsoMediumPPPlots.fill(electron);
   }
 
-  bool val_tight=false;    
+  bool val_tight=false;
   electron.passSelection(val_tight, "Tight");
   if(val_tight) {
     m_oKinIsoTightPPPlots.fill(electron);
diff --git a/Reconstruction/egamma/egammaRec/python/LRTEgammaConfig.py b/Reconstruction/egamma/egammaRec/python/LRTEgammaConfig.py
index baf2f75fb8e2977efa59300e852ccb638d863130..1c42694c654cfe95f8fe9da3d8f20b9bcd16b3a8 100644
--- a/Reconstruction/egamma/egammaRec/python/LRTEgammaConfig.py
+++ b/Reconstruction/egamma/egammaRec/python/LRTEgammaConfig.py
@@ -1,19 +1,23 @@
-from egammaRec.Factories import AlgFactory
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+
 from egammaRec import egammaKeys
 from egammaRec.egammaTruthAssociationAlg import egammaTruthAssociationAlg
 from egammaAlgs.egammaSelectedTrackCopy import egammaSelectedTrackCopy
 from egammaAlgs.EMBremCollectionBuilder import EMBremCollectionBuilder
 from egammaAlgs.EMGSFCaloExtensionBuilder import EMGSFCaloExtensionBuilder
 from egammaAlgs.egammaRecBuilder import egammaRecBuilder
-from egammaAlgs.egammaSuperClusterBuilder import electronSuperClusterBuilder, photonSuperClusterBuilder
+from egammaAlgs.egammaSuperClusterBuilder import (
+    electronSuperClusterBuilder, photonSuperClusterBuilder)
 from egammaAlgs.topoEgammaBuilder import topoEgammaBuilder
-from egammaAlgs.egammaLargeClusterMakerAlg import egammaLargeClusterMakerAlg
 from egammaTools.EMTrackMatchBuilder import EMTrackMatchBuilder
-from egammaTrackTools.egammaTrackToolsFactories import *
+from egammaTrackTools.egammaTrackToolsFactories import (
+    EMExtrapolationToolsCommonCache, EMExtrapolationToolsCache)
 from InDetRecExample.InDetKeys import InDetKeys
-from egammaTools.egammaToolsFactories import EMClusterTool, EMFourMomBuilder, EMShowerBuilder, egammaOQFlagsBuilder, ElectronPIDBuilder
+from egammaTools.egammaToolsFactories import (
+    EMClusterTool, EMFourMomBuilder,
+    EMShowerBuilder, egammaOQFlagsBuilder, ElectronPIDBuilder)
 
-LRTEMExtrapolationToolsCommonCache=EMExtrapolationToolsCommonCache.copy(
+LRTEMExtrapolationToolsCommonCache = EMExtrapolationToolsCommonCache.copy(
     name="LRTEMExtrapolationToolsCommonCache",
     LastCache='ParticleCaloExtension_LRT'
 )
@@ -26,7 +30,7 @@ LRTegammaSelectedTrackCopy = egammaSelectedTrackCopy.copy(
 )
 
 LRTEMBremCollectionBuilder = EMBremCollectionBuilder.copy(
-    name = "LRTEMBremCollectionBuilder",
+    name="LRTEMBremCollectionBuilder",
     TrackParticleContainerName=InDetKeys.xAODLargeD0TrackParticleContainer(),
     SelectedTrackParticleContainerName="LRTegammaSelectedTrackParticles",
     OutputTrkPartContainerName="LRT"+egammaKeys.outputTrackParticleKey(),
@@ -40,11 +44,11 @@ LRTEMGSFCaloExtensionBuilder = EMGSFCaloExtensionBuilder.copy(
     GFFTrkPartContainerName="LRT"+egammaKeys.outputTrackParticleKey())
 
 LRTEMExtrapolationToolsCache = EMExtrapolationToolsCache.copy(
-     name="LRTEMExtrapolationToolsCache",
-     PerigeeCache='LRTGSFPerigeeCaloExtension',
-     LastCache='LRTGSFLastCaloExtension',
-     useCaching=True,
-     useLastCaching=True
+    name="LRTEMExtrapolationToolsCache",
+    PerigeeCache='LRTGSFPerigeeCaloExtension',
+    LastCache='LRTGSFLastCaloExtension',
+    useCaching=True,
+    useLastCaching=True
 )
 
 LRTEMTrackMatchBuilder = EMTrackMatchBuilder.copy(
@@ -62,45 +66,41 @@ LRTegammaRecBuilder = egammaRecBuilder.copy(
 )
 
 LRTelectronSuperClusterBuilder = electronSuperClusterBuilder.copy(
-     name='LRTelectronSuperClusterBuilder',
-     InputEgammaRecContainerName="LRT"+egammaKeys.EgammaRecKey(),
-     SuperElectronRecCollectionName="LRT"+egammaKeys.ElectronSuperRecKey(),
-     SuperClusterCollectionName='LRTElectronSuperClusters',
-     TrackMatchBuilderTool=LRTEMTrackMatchBuilder
+    name='LRTelectronSuperClusterBuilder',
+    InputEgammaRecContainerName="LRT"+egammaKeys.EgammaRecKey(),
+    SuperElectronRecCollectionName="LRT"+egammaKeys.ElectronSuperRecKey(),
+    SuperClusterCollectionName='LRTElectronSuperClusters',
+    TrackMatchBuilderTool=LRTEMTrackMatchBuilder
 )
-    
+
 LRTphotonSuperClusterBuilder = photonSuperClusterBuilder.copy(
-     name='LRTphotonSuperClusterBuilder',
-     InputEgammaRecContainerName="LRT"+egammaKeys.EgammaRecKey(),
-     SuperPhotonRecCollectionName="LRT"+egammaKeys.PhotonSuperRecKey(),
-     SuperClusterCollectionName='LRTPhotonSuperClusters',
+    name='LRTphotonSuperClusterBuilder',
+    InputEgammaRecContainerName="LRT"+egammaKeys.EgammaRecKey(),
+    SuperPhotonRecCollectionName="LRT"+egammaKeys.PhotonSuperRecKey(),
+    SuperClusterCollectionName='LRTPhotonSuperClusters',
 )
 
 LRTEMClusterTool = EMClusterTool.copy(
     name='LRTEMClusterTool',
     OutputClusterContainerName="LRT"+egammaKeys.outputClusterKey(),
-    OutputTopoSeededClusterContainerName='LRT'+egammaKeys.outputTopoSeededClusterKey(),
+    OutputTopoSeededClusterContainerName='LRT' +
+    egammaKeys.outputTopoSeededClusterKey(),
 )
 
 LRTtopoEgammaBuilder = topoEgammaBuilder.copy(
-     name='LRTtopoEgammaBuilder',
-     SuperElectronRecCollectionName="LRT"+egammaKeys.ElectronSuperRecKey(),
-     ElectronOutputName="LRT"+egammaKeys.outputElectronKey(),
-     SuperPhotonRecCollectionName="LRT"+egammaKeys.PhotonSuperRecKey(),
-     PhotonOutputName="LRT"+egammaKeys.outputPhotonKey(),
-     EMClusterTool=LRTEMClusterTool,
-     EMShowerTool=EMShowerBuilder,
-     ObjectQualityTool=egammaOQFlagsBuilder,
-     egammaTools= [EMFourMomBuilder()],
-     ElectronTools= [ElectronPIDBuilder()],
-     doPhotons = False
+    name='LRTtopoEgammaBuilder',
+    SuperElectronRecCollectionName="LRT"+egammaKeys.ElectronSuperRecKey(),
+    ElectronOutputName="LRT"+egammaKeys.outputElectronKey(),
+    SuperPhotonRecCollectionName="LRT"+egammaKeys.PhotonSuperRecKey(),
+    PhotonOutputName="LRT"+egammaKeys.outputPhotonKey(),
+    EMClusterTool=LRTEMClusterTool,
+    EMShowerTool=EMShowerBuilder,
+    ObjectQualityTool=egammaOQFlagsBuilder,
+    egammaTools=[EMFourMomBuilder()],
+    ElectronTools=[ElectronPIDBuilder()],
+    doPhotons=False
 )
 
-#LRTegammaLargeClusterMakerAlg=egammaLargeClusterMakerAlg.copy(
-#     name="LRTegammaLargeClusterMaker",
-#     ClustersOutputName="LRT"+egammaKeys.EgammaLargeClustersKey(),
-#)
-
 LRTegammaTruthAssociationAlg = egammaTruthAssociationAlg.copy(
     name='LRTegammaTruthAssociationAlg',
     ElectronContainerName="LRT"+egammaKeys.outputElectronKey(),
@@ -109,4 +109,3 @@ LRTegammaTruthAssociationAlg = egammaTruthAssociationAlg.copy(
     MatchPhotons=False,
     MatchForwardElectrons=False,
 )
-
diff --git a/Reconstruction/egamma/egammaRec/python/LRTtopoEgammaGetter.py b/Reconstruction/egamma/egammaRec/python/LRTtopoEgammaGetter.py
index e516d1cc41c616d55eccdeb9dd1763f3459fec2f..1f07c77ff7c3f788bb215a838ff4220cf2f0d686 100644
--- a/Reconstruction/egamma/egammaRec/python/LRTtopoEgammaGetter.py
+++ b/Reconstruction/egamma/egammaRec/python/LRTtopoEgammaGetter.py
@@ -1,15 +1,11 @@
 # Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 from __future__ import print_function
-from egammaTools.egammaToolsFactories import \
-    EMClusterTool, EMFourMomBuilder, EMShowerBuilder, egammaOQFlagsBuilder, \
-    ElectronPIDBuilder, PhotonPIDBuilder
 
 # specifies standard (supercluster) egamma.
 from AthenaCommon.Logging import logging
 from AthenaCommon.DetFlags import DetFlags
 from RecExConfig.Configured import Configured
-from egammaRec.Factories import FcnWrapper
 from egammaRec import egammaRecFlags as egRecFlags
 egammaRecFlags = egRecFlags.jobproperties.egammaRecFlags
 
@@ -20,22 +16,6 @@ def doConversions():
 # The tools used to add properties
 
 
-def egammaDecorationTools():
-    "Return a list with the tools that decorate both electrons and photons"
-    return [EMFourMomBuilder()]
-
-
-def electronDecorationTools():
-    "Return a list with the tools that decorate only electrons"
-    return [ElectronPIDBuilder()]
-
-
-def photonDecorationTools():
-    "Return a list with the tools that decorate only photons"
-    return [PhotonPIDBuilder()]
-#
-
-
 class LRTtopoEgammaGetter (Configured):
 
     def configure(self):
@@ -55,8 +35,8 @@ class LRTtopoEgammaGetter (Configured):
             return False
 
         # the supercluster builders
-        from egammaRec.LRTEgammaConfig import \
-            LRTelectronSuperClusterBuilder, LRTphotonSuperClusterBuilder
+        from egammaRec.LRTEgammaConfig import (
+            LRTelectronSuperClusterBuilder, LRTphotonSuperClusterBuilder)
         try:
             self._LRTelectronSuperClusterBuilder = LRTelectronSuperClusterBuilder(
                 doTrackMatching=DetFlags.detdescr.ID_on())
@@ -69,16 +49,9 @@ class LRTtopoEgammaGetter (Configured):
             return False
 
         # the topoEgammaBuilder (the part that puts everything together
-        from egammaRec.LRTEgammaConfig import LRTtopoEgammaBuilder, LRTEMClusterTool
+        from egammaRec.LRTEgammaConfig import LRTtopoEgammaBuilder
         try:
             self._LRTtopoEgammaBuilder = LRTtopoEgammaBuilder(
-                EMClusterTool=LRTEMClusterTool,
-                EMShowerTool=EMShowerBuilder,
-                ObjectQualityTool=egammaOQFlagsBuilder,
-                # Decoration tools
-                egammaTools=FcnWrapper(egammaDecorationTools),
-                ElectronTools=FcnWrapper(electronDecorationTools),
-                PhotonTools=FcnWrapper(photonDecorationTools),
                 doPhotons=False
             )
         except Exception:
@@ -87,16 +60,4 @@ class LRTtopoEgammaGetter (Configured):
             traceback.print_exc()
             return False
 
-#        # the egammaLargeClusterMaker
-#        # (Which chooses the cells to store in the AOD)
-#        from egammaAlgs.egammaLargeClusterMakerAlg import (
-#            egammaLargeClusterMakerAlg)
-#        try:
-#            self._egammaLargeClusterMaker = egammaLargeClusterMakerAlg()
-#        except Exception:
-#            mlog.error("could not get handle to egammaLargeClusterMaker")
-#            import traceback
-#            traceback.print_exc()
-#            return False
-
         return True
diff --git a/Reconstruction/egamma/egammaRec/python/egammaAODGetter.py b/Reconstruction/egamma/egammaRec/python/egammaAODGetter.py
index 44d7027ea218d462a84e589c890d2af34114488a..ce77b114612ec17597f8d64bc38483aa1c553a55 100755
--- a/Reconstruction/egamma/egammaRec/python/egammaAODGetter.py
+++ b/Reconstruction/egamma/egammaRec/python/egammaAODGetter.py
@@ -1,9 +1,6 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 # xAOD this should do nothing
 # Exists just for compatibility
 class egammaAODGetter:
-  pass
-
-
-
+    pass
diff --git a/Reconstruction/egamma/egammaUtils/CMakeLists.txt b/Reconstruction/egamma/egammaUtils/CMakeLists.txt
index a62403a29994d6d05685c3232652d0f63988e7eb..ae76cabe806c99c6e5df52553a5f69c6b08e7ff3 100644
--- a/Reconstruction/egamma/egammaUtils/CMakeLists.txt
+++ b/Reconstruction/egamma/egammaUtils/CMakeLists.txt
@@ -13,10 +13,10 @@ atlas_add_library( egammaUtils
                    Root/*.cxx
                    PUBLIC_HEADERS egammaUtils
                    INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
-		   PRIVATE_INCLUDE_DIRS 
-		   LINK_LIBRARIES  ${ROOT_LIBRARIES} xAODCaloEvent xAODTracking xAODEgamma GeoPrimitives  
+		   PRIVATE_INCLUDE_DIRS
+         LINK_LIBRARIES  ${ROOT_LIBRARIES} AsgMessagingLib xAODCaloEvent xAODTracking xAODEgamma GeoPrimitives
 		   PRIVATE_LINK_LIBRARIES FourMomUtils PathResolver AnalysisUtilsLib)
-	  
+
 atlas_add_dictionary( egammaUtilsDict
 		      egammaUtils/egammaUtilsDict.h
 		      egammaUtils/selection.xml
diff --git a/Reconstruction/egamma/egammaUtils/Root/eg_resolution.cxx b/Reconstruction/egamma/egammaUtils/Root/eg_resolution.cxx
index 5332c3e0299c222b9bd877fec7c503a4091a9522..ada3bf0eeefba7daa45d5cfa1a18ed825704fc40 100644
--- a/Reconstruction/egamma/egammaUtils/Root/eg_resolution.cxx
+++ b/Reconstruction/egamma/egammaUtils/Root/eg_resolution.cxx
@@ -18,10 +18,10 @@ T* get_object(TFile& file, const std::string& name){
 }
 
 eg_resolution::eg_resolution(const std::string& configuration)
-  : m_file0()
-  , m_file1()
-  , m_file2()
-  , m_file3()
+  : m_file0(),
+    m_file1(),
+    m_file2(),
+    m_file3()
 {
   if (configuration == "run1") {
     m_file0 = std::make_unique<TFile> (PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v5/resolutionFit_electron_run1.root").c_str() );
@@ -35,10 +35,16 @@ eg_resolution::eg_resolution(const std::string& configuration)
     m_file2 = std::make_unique<TFile> (PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v5/resolutionFit_recoConv_run2_pre.root").c_str());
     m_file3 = std::make_unique<TFile> (PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v5/resolutionFit_trueUnconv_run2_pre.root").c_str());
   }
-
+  else if (configuration == "run2_R21_v1") {
+    m_file0 = std::make_unique<TFile> (PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v20/resolutionFit_electron_run2_release21_es2017_R21_v1.root").c_str());
+    m_file1 = std::make_unique<TFile> (PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v20/resolutionFit_recoUnconv_run2_release21_es2017_R21_v1.root").c_str());
+    m_file2 = std::make_unique<TFile> (PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v20/resolutionFit_recoConv_run2_release21_es2017_R21_v1.root").c_str());
+    m_file3 = std::make_unique<TFile> (PathResolverFindCalibFile("ElectronPhotonFourMomentumCorrection/v20/resolutionFit_trueUnconvertedPhoton_run2_release21_es2017_R21_v1.root").c_str()); // assume reco and true unconv having similar resolutions
+  }
   if (!m_file0 or !m_file1 or !m_file2 or !m_file3) {
     throw std::runtime_error("cannot find input file for resolutions");
   }
+
   m_hSampling[0][0] = get_object<TH1>(*m_file0, "hsamplingG");
   m_hSampling[0][1] = get_object<TH1>(*m_file0, "hsampling80");
   m_hSampling[0][2] = get_object<TH1>(*m_file0, "hsampling90");
@@ -120,6 +126,7 @@ double eg_resolution::getResolution(int particle_type, double energy, double eta
    const double rsampling = m_hSampling[particle_type][resolution_type]->GetBinContent(ibinEta + 1);
    const double rnoise    = m_hNoise[particle_type][resolution_type]->GetBinContent(ibinEta + 1);
    const double rconst    = m_hConst[particle_type][resolution_type]->GetBinContent(ibinEta + 1);
+
    const double sigma2 = rsampling*rsampling/energyGeV + rnoise*rnoise/energyGeV/energyGeV + rconst*rconst;
    return sqrt(sigma2);
 }
diff --git a/Reconstruction/egamma/egammaUtils/egammaUtils/eg_resolution.h b/Reconstruction/egamma/egammaUtils/egammaUtils/eg_resolution.h
index d214c49d9147ebed2fc140c3bb3ffa443663cfbd..0cf2365e0f26fbb081c6dbcea7031c124c814bb7 100644
--- a/Reconstruction/egamma/egammaUtils/egammaUtils/eg_resolution.h
+++ b/Reconstruction/egamma/egammaUtils/egammaUtils/eg_resolution.h
@@ -7,11 +7,12 @@
 
 #include <cstdlib>
 #include <cmath>
+#include <memory>
+
 #include "xAODEgamma/Egamma.h"
 #include "TH1.h"
 #include "TFile.h"
 #include "TArrayD.h"
-#include <memory>
 /**
   @class eg_resolution
   @brief get resolution for electron and photons (converted / unconverted) vs E,eta
diff --git a/Reconstruction/tauRec/python/TauAlgorithmsHolder.py b/Reconstruction/tauRec/python/TauAlgorithmsHolder.py
index 36736c809530963090d7a551011356ff68d438c2..0813b0abb0204113bb691ab6954d13e8f618347c 100644
--- a/Reconstruction/tauRec/python/TauAlgorithmsHolder.py
+++ b/Reconstruction/tauRec/python/TauAlgorithmsHolder.py
@@ -74,19 +74,10 @@ def getTauAxis():
     if _name in cached_instances:
         return cached_instances[_name]
     
-    from JetRec.JetRecFlags import jetFlags
-    
-    doJetVertexCorrection = False
-    if tauFlags.isStandalone:
-        doJetVertexCorrection = True
-    if jetFlags.useVertices() and jetFlags.useTracks():
-        doJetVertexCorrection = True
-    
     from tauRecTools.tauRecToolsConf import TauAxisSetter
     TauAxisSetter = TauAxisSetter(  name = _name, 
                                     ClusterCone = 0.2,
-                                    VertexCorrection = True,
-                                    JetVertexCorrection = doJetVertexCorrection)
+                                    VertexCorrection = True )
                                     
     cached_instances[_name] = TauAxisSetter                
     return TauAxisSetter
@@ -1035,23 +1026,15 @@ def getTauVertexCorrection():
 def getTauVertexedClusterDecorator():
     from tauRec.tauRecFlags import tauFlags
     from tauRecTools.tauRecToolsConf import TauVertexedClusterDecorator
-    from JetRec.JetRecFlags import jetFlags
 
     _name = sPrefix + 'TauVertexedClusterDecorator'
     
     if _name in cached_instances:
         return cached_instances[_name]
   
-    doJetVertexCorrection = False
-    if tauFlags.isStandalone:
-        doJetVertexCorrection = True
-    if jetFlags.useVertices() and jetFlags.useTracks():
-        doJetVertexCorrection = True
-
     myTauVertexedClusterDecorator = TauVertexedClusterDecorator(name = _name,
                                                                 SeedJet = tauFlags.tauRecSeedJetCollection(), 
-                                                                VertexCorrection = True,
-                                                                JetVertexCorrection = doJetVertexCorrection)
+                                                                VertexCorrection = True)
     
     cached_instances[_name] = myTauVertexedClusterDecorator
     return myTauVertexedClusterDecorator
diff --git a/Reconstruction/tauRec/share/tau_standalone_EMTopo_ESDtoAOD.py b/Reconstruction/tauRec/share/tau_standalone_EMTopo_ESDtoAOD.py
index 142ce1b8b5bb2353fbea01e4c2a8b1ee791220df..7f3d1a46dd7277b434ef5305a5e3ae6a66a70224 100644
--- a/Reconstruction/tauRec/share/tau_standalone_EMTopo_ESDtoAOD.py
+++ b/Reconstruction/tauRec/share/tau_standalone_EMTopo_ESDtoAOD.py
@@ -1,6 +1,6 @@
 from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
 athenaCommonFlags.FilesInput = ["/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/tauRec/input/standalone.ESD.pool.root"]
-athenaCommonFlags.PoolAODOutput = "EMPFlow_AOD.pool.root"
+athenaCommonFlags.PoolAODOutput = "EMTopo_AOD.pool.root"
 
 from RecExConfig.RecFlags import rec
 rec.doEgamma.set_Value_and_Lock(False)
diff --git a/Reconstruction/tauRecTools/Root/HelperFunctions.cxx b/Reconstruction/tauRecTools/Root/HelperFunctions.cxx
index ceba5edcb3c923781b94c7df27892fd940a88adf..980c6aad09f6cf74ca4cdf15da65288465e04201 100644
--- a/Reconstruction/tauRecTools/Root/HelperFunctions.cxx
+++ b/Reconstruction/tauRecTools/Root/HelperFunctions.cxx
@@ -17,9 +17,43 @@ namespace tauRecTools {
 
 
 
+const xAOD::Vertex* tauRecTools::getJetVertex(const xAOD::Jet& jet) {
+  const xAOD::Vertex* jetVertex = nullptr;
+  
+  bool isAvailable = jet.getAssociatedObject("OriginVertex", jetVertex); 
+  if (! isAvailable) {
+    return nullptr;
+  }
+
+  return jetVertex;
+}
+
+
+
+const xAOD::Vertex* tauRecTools::getTauVertex(const xAOD::TauJet& tau, bool inTrigger) {
+  using namespace tauRecTools::msgHelperFunction;
+  
+  const xAOD::Vertex* tauVertex = nullptr;
+  if (tau.vertexLink().isValid()) {
+    tauVertex = tau.vertex();
+  }
+  else if (! inTrigger) {
+    if (! tau.jetLink().isValid()) {
+      ANA_MSG_WARNING("Link to seed jet is not valid !");
+      return nullptr;
+    } 
+    const xAOD::Jet* seedJet = tau.jet();
+    tauVertex = tauRecTools::getJetVertex(*seedJet);
+  }
+
+  return tauVertex;
+}
+
+
+
 TLorentzVector tauRecTools::getTauAxis(const xAOD::TauJet& tau, bool doVertexCorrection) {
   TLorentzVector tauAxis;
-  if (doVertexCorrection && tau.vertexLink().isValid()) {
+  if (doVertexCorrection) {
     tauAxis = tau.p4(xAOD::TauJetParameters::IntermediateAxis);
   }
   else {
@@ -29,7 +63,6 @@ TLorentzVector tauRecTools::getTauAxis(const xAOD::TauJet& tau, bool doVertexCor
   return tauAxis;
 }
 
-
 //________________________________________________________________________________
 xAOD::TauTrack::TrackFlagType tauRecTools::isolateClassifiedBits(xAOD::TauTrack::TrackFlagType flag){
   const int flagsize=sizeof(flag)*8;
diff --git a/Reconstruction/tauRecTools/Root/TauVertexedClusterDecorator.cxx b/Reconstruction/tauRecTools/Root/TauVertexedClusterDecorator.cxx
index b3357e50c7177c6d1d97e7005b818bdb4fc8821b..08b004206d6d6009123a2934fe1a92940832d4e5 100644
--- a/Reconstruction/tauRecTools/Root/TauVertexedClusterDecorator.cxx
+++ b/Reconstruction/tauRecTools/Root/TauVertexedClusterDecorator.cxx
@@ -3,6 +3,7 @@
 */
 
 #include "tauRecTools/TauVertexedClusterDecorator.h"
+#include "tauRecTools/HelperFunctions.h"
 
 #include "xAODCaloEvent/CaloVertexedTopoCluster.h"
 
@@ -10,7 +11,6 @@ TauVertexedClusterDecorator::TauVertexedClusterDecorator(const std::string& name
   TauRecToolBase(name) {
   declareProperty("SeedJet", m_seedJet = ""); 
   declareProperty("VertexCorrection", m_doVertexCorrection = true);
-  declareProperty("JetVertexCorrection", m_doJetVertexCorrection = true);
 }
 
 
@@ -35,23 +35,6 @@ StatusCode TauVertexedClusterDecorator::initialize() {
 
 
   
-const xAOD::Vertex* TauVertexedClusterDecorator::getJetVertex(const xAOD::Jet& jet) const {
-  
-  const xAOD::Vertex* jetVertex = nullptr;
-  
-  if (m_doJetVertexCorrection && !inTrigger()) {
-    bool isAvailable = jet.getAssociatedObject("OriginVertex", jetVertex);
-    if (!isAvailable) {
-      ATH_MSG_WARNING("OriginVertex not available !");
-      jetVertex = nullptr;
-    }
-  }
-
-  return jetVertex;
-}
-
-
-
 StatusCode TauVertexedClusterDecorator::execute(xAOD::TauJet& tau) const {
   if (! tau.jetLink().isValid()) {
     ATH_MSG_WARNING("Link to the seed jet is invalid");
@@ -59,31 +42,29 @@ StatusCode TauVertexedClusterDecorator::execute(xAOD::TauJet& tau) const {
   }
   
   // Obtain the vertex to correct the cluster
-  const xAOD::Vertex* vertex = nullptr;
-  if (m_doVertexCorrection) {
-    if (tau.vertexLink().isValid()) {
-      vertex = tau.vertex();
-    }
-  }
-  else {
-    const xAOD::Jet* jetSeed = tau.jet();
-    vertex = getJetVertex(*jetSeed);
-  }
+  const xAOD::Vertex* vertex = tauRecTools::getTauVertex(tau, inTrigger());
 
   std::vector<const xAOD::IParticle*> particleList = tau.clusters();
   
   std::vector<xAOD::CaloVertexedTopoCluster> vertexedClusterList;
   for (const xAOD::IParticle* particle : particleList) {
     const xAOD::CaloCluster* cluster = static_cast<const xAOD::CaloCluster*>(particle);
-    
-    if (vertex) {
-      vertexedClusterList.emplace_back(*cluster, m_clusterState, vertex->position());
-    }
-    else if (!inTrigger()) {
-      vertexedClusterList.emplace_back(*cluster, m_clusterState);
+   
+    if (inTrigger()) { // In trigger, we use the default calibration state
+      if (vertex) {
+        vertexedClusterList.emplace_back(*cluster, vertex->position());
+      }
+      else {
+        vertexedClusterList.emplace_back(*cluster);
+      }
     }
-    else {
-      vertexedClusterList.emplace_back(*cluster);
+    else { // In offline reconstruction, the calibration state is based on the name of seed jet
+      if (vertex) {
+        vertexedClusterList.emplace_back(*cluster, m_clusterState, vertex->position());
+      }
+      else {
+        vertexedClusterList.emplace_back(*cluster, m_clusterState);
+      }
     }
   }
 
diff --git a/Reconstruction/tauRecTools/src/TauAxisSetter.cxx b/Reconstruction/tauRecTools/src/TauAxisSetter.cxx
index 04260136c458c00ce963ceff4713276106f67199..c1f321116dedf5f0071a4daa221d3850ad96a20d 100644
--- a/Reconstruction/tauRecTools/src/TauAxisSetter.cxx
+++ b/Reconstruction/tauRecTools/src/TauAxisSetter.cxx
@@ -66,10 +66,13 @@ StatusCode TauAxisSetter::execute(xAOD::TauJet& tau) const {
     // Tau intermediate axis (corrected for tau vertex)
     TLorentzVector tauInterAxis;
 
-    const xAOD::Vertex* jetVertex = getJetVertex(*jetSeed);
-    
-    const xAOD::Vertex* tauVertex = nullptr;
-    if (tau.vertexLink().isValid()) tauVertex = tau.vertex();
+    // In trigger, jet candidate do not have a vertex
+    const xAOD::Vertex* jetVertex = nullptr;
+    if (!inTrigger()) {
+      jetVertex = tauRecTools::getJetVertex(*jetSeed);
+    }
+
+    const xAOD::Vertex* tauVertex = tauRecTools::getTauVertex(tau, inTrigger());
 
     // Redo the vertex correction when tau vertex is different from jet vertex
     if (jetVertex != tauVertex) {
@@ -120,23 +123,6 @@ StatusCode TauAxisSetter::execute(xAOD::TauJet& tau) const {
 
 
 
-const xAOD::Vertex* TauAxisSetter::getJetVertex(const xAOD::Jet& jet) const {
-  
-  const xAOD::Vertex* jetVertex = nullptr;
-  
-  if (m_doJetVertexCorrection && !inTrigger()) {
-    bool isAvailable = jet.getAssociatedObject("OriginVertex", jetVertex);
-    if (!isAvailable) {
-      ATH_MSG_WARNING("OriginVertex not available !");
-      jetVertex = nullptr;
-    }
-  }
-
-  return jetVertex;
-}
-
-
-
 TLorentzVector TauAxisSetter::getVertexCorrectedP4(const xAOD::JetConstituent& constituent,
                                                    const Amg::Vector3D& position) const {
   TLorentzVector vertexCorrectedP4;
@@ -170,15 +156,9 @@ TLorentzVector TauAxisSetter::getVertexCorrectedP4(const xAOD::PFO& pfo,
 
     // If there is a vertex correction in jet reconstruction, then pfo.p4() is the four momentum 
     // at EM scale. Otherwise, pfo.p4() is at LC scale (not clear), and pfo.p4EM() is the four 
-    // momentum at EM scale. 
-    // TODO: May need further modifications, depending on how the jet reconstruction fix ATLJETMET-1280
-    // The strategy only works for PFlow at EM scale.
-    if (m_doJetVertexCorrection && !inTrigger()) {
-      vertexCorrectedP4 = pfo.GetVertexCorrectedFourVec(pos);
-    }
-    else {
-      vertexCorrectedP4 = pfo.GetVertexCorrectedEMFourVec(pos);
-    }
+    // momentum at EM scale. Here, we assume jet always perform the vertex correction in offline 
+    // reconstruction.
+    vertexCorrectedP4 = pfo.GetVertexCorrectedFourVec(pos);
   }
   else {
     vertexCorrectedP4 = pfo.p4();
diff --git a/Reconstruction/tauRecTools/src/TauAxisSetter.h b/Reconstruction/tauRecTools/src/TauAxisSetter.h
index 3205430370c043c326b2ffdd419304d48afc50ad..909b6e9318e161f3b77bc385004f7f7f0c12dc80 100644
--- a/Reconstruction/tauRecTools/src/TauAxisSetter.h
+++ b/Reconstruction/tauRecTools/src/TauAxisSetter.h
@@ -24,35 +24,31 @@
 
 class TauAxisSetter : public TauRecToolBase {
 
-  public:
-    
-    ASG_TOOL_CLASS2(TauAxisSetter, TauRecToolBase, ITauToolBase);
-    
-    /** @brief Constructor */ 
-    TauAxisSetter(const std::string& name);
+public:
+  
+  ASG_TOOL_CLASS2(TauAxisSetter, TauRecToolBase, ITauToolBase)
+  
+  /** @brief Constructor */ 
+  TauAxisSetter(const std::string& name);
 
-    /** @brief Destructor */
-    virtual ~TauAxisSetter() = default;
+  /** @brief Destructor */
+  virtual ~TauAxisSetter() = default;
 
-    /** @brief Execution of this tool */ 
-    virtual StatusCode execute(xAOD::TauJet& tau) const override;
+  /** @brief Execution of this tool */ 
+  virtual StatusCode execute(xAOD::TauJet& tau) const override;
 
-  private:
+private:
   
-    /** Get the jet vertex */
-    const xAOD::Vertex* getJetVertex(const xAOD::Jet& jet) const;
-
-    /**@brief Get the vertex corrected four momentum */
-     TLorentzVector getVertexCorrectedP4(const xAOD::JetConstituent& constituent, 
-                                         const Amg::Vector3D& position) const; 
-    
-     /**@brief Get the vertex corrected four momentum */
-     TLorentzVector getVertexCorrectedP4(const xAOD::PFO& pfo, 
-                                         const Amg::Vector3D& position) const; 
-
-    Gaudi::Property<double> m_clusterCone {this, "ClusterCone", 0.2, "cone of tau candidate"};
-    Gaudi::Property<bool> m_doVertexCorrection {this, "VertexCorrection", true, "switch of tau vertex correction"};
-    Gaudi::Property<bool> m_doJetVertexCorrection {this, "JetVertexCorrection", true, "switch of jet vertex correction"};
+  /**@brief Get the vertex corrected four momentum */
+  TLorentzVector getVertexCorrectedP4(const xAOD::JetConstituent& constituent, 
+                                      const Amg::Vector3D& position) const; 
+  
+  /**@brief Get the vertex corrected four momentum */
+  TLorentzVector getVertexCorrectedP4(const xAOD::PFO& pfo, 
+                                      const Amg::Vector3D& position) const; 
+
+  Gaudi::Property<double> m_clusterCone {this, "ClusterCone", 0.2, "cone of tau candidate"};
+  Gaudi::Property<bool> m_doVertexCorrection {this, "VertexCorrection", true, "switch of tau vertex correction"};
 };
 
 #endif
diff --git a/Reconstruction/tauRecTools/tauRecTools/HelperFunctions.h b/Reconstruction/tauRecTools/tauRecTools/HelperFunctions.h
index 763799a7cfaebdb4b9acf86a2627288d92084c2c..b7b1c92c8d8043370d4703cf9a26ab0663a49a28 100644
--- a/Reconstruction/tauRecTools/tauRecTools/HelperFunctions.h
+++ b/Reconstruction/tauRecTools/tauRecTools/HelperFunctions.h
@@ -5,14 +5,15 @@
 #ifndef TAURECTOOLS_HELPERFUNCTIONS_H
 #define TAURECTOOLS_HELPERFUNCTIONS_H
 
-#include "AsgMessaging/MessageCheck.h"
 #include "xAODTracking/VertexContainer.h"
+#include "xAODJet/Jet.h"
 #include "xAODTau/TauJet.h"
 #include "xAODCaloEvent/CaloCluster.h"
 #include "xAODPFlow/PFO.h"
 
-#include "MVAUtils/BDT.h"
+#include "AsgMessaging/MessageCheck.h"
 
+#include "MVAUtils/BDT.h"
 #include "TLorentzVector.h"
 #include "TString.h"
 
@@ -24,6 +25,26 @@ namespace tauRecTools
 {
   ANA_MSG_HEADER(msgHelperFunction)
 
+  /**
+   * @brief Return the vertex of jet candidate
+   * @warning In trigger, jet candidate does not have a candidate, and an ERROR
+   *          message will be print out !
+   */ 
+  const xAOD::Vertex* getJetVertex(const xAOD::Jet& jet);
+ 
+  /**
+   * @brief Return the vertex of tau candidate
+   *        If the vertex link of tau candidate is valid, then the vertex which the link point to will
+   *        be returned. Otherwise, it will try to retrieve the vertex of the seed jet in offline reconstruction
+   */  
+  const xAOD::Vertex* getTauVertex(const xAOD::TauJet& tau, bool inTrigger = false);
+
+  /**
+   * @brief Return the four momentum of the tau axis
+   *        The tau axis is widely used to select clusters and cells in tau reconstruction.
+   *        If doVertexCorrection is true, then IntermediateAxis is returned. Otherwise, 
+   *        DetectorAxis is returned.  
+   */ 
   TLorentzVector getTauAxis(const xAOD::TauJet& tau, bool doVertexCorrection = true);
 
   TLorentzVector GetConstituentP4(const xAOD::JetConstituent& constituent);
diff --git a/Reconstruction/tauRecTools/tauRecTools/TauVertexedClusterDecorator.h b/Reconstruction/tauRecTools/tauRecTools/TauVertexedClusterDecorator.h
index f48bfa3eac23fc2e98e7e372b658d6474f919efc..5dcb7ad604ccfbf209ec8ac3ffd75c84dc4f6a93 100644
--- a/Reconstruction/tauRecTools/tauRecTools/TauVertexedClusterDecorator.h
+++ b/Reconstruction/tauRecTools/tauRecTools/TauVertexedClusterDecorator.h
@@ -30,8 +30,6 @@ public:
   virtual StatusCode execute(xAOD::TauJet& tau) const override;
   
 private:
-  //* Get the vertex used in jet reconstruction */
-  const xAOD::Vertex* getJetVertex(const xAOD::Jet& jet) const;
 
   /// Name of the seed jet
   std::string m_seedJet;  
@@ -39,9 +37,6 @@ private:
   /// Switch of the tau vertex correction
   bool m_doVertexCorrection;
   
-  /// Switch of the jet vertex correction
-  bool m_doJetVertexCorrection;
-
   /// Calibration state of cluster
   xAOD::CaloCluster::State m_clusterState; //!
 };
diff --git a/Simulation/FastShower/FastCaloSim/CMakeLists.txt b/Simulation/FastShower/FastCaloSim/CMakeLists.txt
index f11b4f864f8efc5a79fef1f49f3e0f671ab92138..ef97bdd2e0bd1ebe6228b6bbf687f1eb6cb358ec 100644
--- a/Simulation/FastShower/FastCaloSim/CMakeLists.txt
+++ b/Simulation/FastShower/FastCaloSim/CMakeLists.txt
@@ -54,7 +54,7 @@ atlas_add_component( FastCaloSim
                      LINK_LIBRARIES FastCaloSimLib )
 
 # Install files from the package:
-atlas_install_python_modules( python/*.py )
+atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 atlas_install_joboptions( share/*.py )
 
 atlas_add_test( FastShowerCellBuilderTool_test
diff --git a/Simulation/FastShower/FastCaloSim/python/FastCaloSimFactory.py b/Simulation/FastShower/FastCaloSim/python/FastCaloSimFactory.py
index f6b8a8a5332e741afa1c86bdea21bd8f38901783..f4151b25110dbf2e9eadb87680e9b23d2f422ef5 100644
--- a/Simulation/FastShower/FastCaloSim/python/FastCaloSimFactory.py
+++ b/Simulation/FastShower/FastCaloSim/python/FastCaloSimFactory.py
@@ -1,14 +1,10 @@
 # Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-from AthenaCommon.Constants import *
-from RecExConfig.Configured import Configured
-
 def FastCaloSimFactory(name="FastCaloSimFactory", **kwargs):
 
     from AthenaCommon.Logging import logging
     mlog = logging.getLogger( 'FastCaloSimFactory::configure:' )
 
-    from CaloRec.CaloCellFlags import jobproperties
     from AthenaCommon.AppMgr import ToolSvc
 
     #########################################################################################################
@@ -45,11 +41,10 @@ def FastCaloSimFactory(name="FastCaloSimFactory", **kwargs):
     #theFastShowerCellBuilderTool.Invisibles=[12, 14, 16, 1000022]
     
     #########################################################################################################
-    import os
 
     try:
         ParticleParametrizationFileName=theFastShowerCellBuilderTool.ParticleParametrizationFileName
-    except:
+    except Exception:
         ParticleParametrizationFileName=""
     
     if ParticleParametrizationFileName=="" and len(theFastShowerCellBuilderTool.AdditionalParticleParametrizationFileNames)==0:
@@ -66,8 +61,3 @@ def FastCaloSimFactory(name="FastCaloSimFactory", **kwargs):
     mlog.info (theFastShowerCellBuilderTool)
 
     return theFastShowerCellBuilderTool
-
-def getFastShowerCellBuilderTool(name="FastShowerCellBuilderTool", **kwargs):
-
-    return FastShowerCellBuilderTool()
-
diff --git a/Simulation/FastShower/FastCaloSim/python/JetRec_FastCaloSim.py b/Simulation/FastShower/FastCaloSim/python/JetRec_FastCaloSim.py
index 1237d101518ee6884e42a61d259f2ca1e149c54b..ea35841d45dd6c5055d205137ba71e3d20f2db36 100755
--- a/Simulation/FastShower/FastCaloSim/python/JetRec_FastCaloSim.py
+++ b/Simulation/FastShower/FastCaloSim/python/JetRec_FastCaloSim.py
@@ -1,8 +1,6 @@
 # Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
-    
-
-from JetRec.JetGetters import *
+from JetRec.JetGetters import make_StandardJetGetter
 from JetRec.JetRecFlags import jetFlags
 
 def make_FastCaloSimJets(doTowerJet = True, doTopoJet = True, doTruthJet = True, doLocalCalib = False ,
diff --git a/Simulation/FastShower/FastCaloSim/share/AddNoiseCellBuilderTool_test.ref b/Simulation/FastShower/FastCaloSim/share/AddNoiseCellBuilderTool_test.ref
index 8ad952b0e532cbe2202d457b127f13cf6db4c630..b8f5f62ea3cbebbe70f206a8588eea9d77f9d3a3 100644
--- a/Simulation/FastShower/FastCaloSim/share/AddNoiseCellBuilderTool_test.ref
+++ b/Simulation/FastShower/FastCaloSim/share/AddNoiseCellBuilderTool_test.ref
@@ -1,7 +1,8 @@
 Py:AutoConfigFlags    INFO Obtaining metadata of auto-configuration by peeking into /cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root
 Py:MetaReader        INFO Current mode used: peeker
+Py:MetaReader        INFO Current filenames: ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/Tier0ChainTests/q221/21.0/v1/myRDO.pool.root']
 Py:MetaReader        INFO MetaReader is called with the parameter "unique_tag_info_values" set to True. This is a workaround to remove all duplicate values from "/TagInfo" key
-Py:Athena            INFO using release [WorkDir-22.0.7] [x86_64-centos7-gcc8-dbg] [atlas-work3/e0befe65d8e8] -- built on [2019-10-19T2025]
+Py:Athena            INFO using release [WorkDir-22.0.22] [x86_64-centos7-gcc8-opt] [MainServiceMsgFormat/f665cad] -- built on [2020-12-03T1657]
 Py:TileCablingSvc    INFO Forcing RUN2 (2014-2017) cabling for run 284500 with geometry ATLAS-R2-2016-01-00-01
 Py:TileInfoLoaderCfg    INFO Adjusting TileInfo to return cell noise for Opt.Filter without iterations
 Py:TileCablingSvc    INFO Forcing RUN2 (2014-2017) cabling for run 284500 with geometry ATLAS-R2-2016-01-00-01
@@ -10,244 +11,247 @@ Py:CaloNoiseToolCfg    INFO Configuring CaloNoiseCondAlg for MC data processing
 Py:CaloNoiseToolCfg    INFO offline mode: use luminosity from /CALO/Ofl/Noise/PileuUpNoiseLumi to scale pileup noise
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v32r2)
-                                          running on lxplus758.cern.ch on Sun Oct 20 00:22:37 2019
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on pcaz001 on Thu Dec  3 18:11:31 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-Py:ConfigurableDb    INFO Read module info for 5590 configurables from 44 genConfDb files
-Py:ConfigurableDb    INFO No duplicates have been found: that's good !
-CoreDumpSvc          INFO install f-a-t-a-l handler... (flag = 438)
-CoreDumpSvc          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
-ClassIDSvc           INFO  getRegistryEntries: read 16428 CLIDRegistry entries for module ALL
-PoolSvc              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
-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/2019-10-18T2133/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-dbg/share/dbreplica.config
-DBReplicaSvc         INFO Total of 10 servers found for host lxplus758.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              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
-PoolSvc           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
-PoolSvc              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
-DbSession            INFO     Open     DbSession    
-Domain[ROOT_All]     INFO >   Access   DbDomain     READ      [ROOT_All] 
-IOVDbSvc             INFO Opened read transaction for POOL PersistencySvc
-IOVDbSvc             INFO Only 5 POOL conditions files will be open at once
-IOVDbSvc             INFO Cache alignment will be done in 3 slices
-IOVDbSvc             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
-IOVDbSvc             INFO Initialised with 4 connections and 22 folders
-IOVDbSvc             INFO Service IOVDbSvc initialised successfully
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
-IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
-IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
-ClassIDSvc           INFO  getRegistryEntries: read 937 CLIDRegistry entries for module ALL
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_TILE/OFLP200
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_CALO/OFLP200
-IOVDbSvc             INFO Disconnecting from COOLOFL_TILE/OFLP200
-IOVDbSvc             INFO Disconnecting from COOLOFL_CALO/OFLP200
-IOVDbSvc             INFO Added taginfo remove for /CALO/Ofl/Noise/CellNoise
-IOVDbSvc             INFO Added taginfo remove for /CALO/Ofl/Noise/PileUpNoiseLumi
-IOVDbSvc             INFO Added taginfo remove for /LAR/Align
-IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/CalibIdMap
-IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/FebRodMap
-IOVDbSvc             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
-IOVDbSvc             INFO Added taginfo remove for /LAR/NoiseOfl/CellNoise
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/CES
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/CIS/FIT/LIN
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/CIS/FIT/NLN
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/EMS
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/FIBER
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/LIN
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/NLN
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/NOISE/CELL
-IOVDbSvc             INFO Added taginfo remove for /TILE/OFL02/NOISE/SAMPLE
-IOVDbSvc             INFO Added taginfo remove for /LAR/LArCellPositionShift
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/DAC2uA
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/HVScaleCorr
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/MphysOverMcal
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/Ramp
-IOVDbSvc             INFO Added taginfo remove for /LAR/ElecCalibMC/uA2MeV
-ClassIDSvc           INFO  getRegistryEntries: read 18 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 1868 CLIDRegistry entries for module ALL
-GeoModelSvc          INFO Explicitly initializing DetDescrCnvSvc
-DetDescrCnvSvc       INFO  initializing 
-DetDescrCnvSvc       INFO Found DetectorStore service
-DetDescrCnvSvc       INFO  filling proxies for detector managers 
-DetDescrCnvSvc       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
-DetDescrCnvSvc       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
-GeoModelSvc::RD...WARNING  Getting PixTBMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting PixTBMaterials with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMatComponents with default tag
-GeoModelSvc::RD...WARNING  Getting InDetMaterials with default tag
-EventPersistenc...   INFO Added successfully Conversion service:McCnvSvc
-EventPersistenc...   INFO Added successfully Conversion service:DetDescrCnvSvc
-LArElectrodeIDD...   INFO in createObj: creating a LArElectrodeID helper object in the detector store
-IdDictDetDescrCnv    INFO in initialize
-IdDictDetDescrCnv    INFO in createObj: creating a IdDictManager object in the detector store
-IdDictDetDescrCnv    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
-IdDictDetDescrCnv    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
-IdDictDetDescrCnv    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Found id dicts:
-IdDictDetDescrCnv    INFO Using dictionary tag: null
-IdDictDetDescrCnv    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
-IdDictDetDescrCnv    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
-IdDictDetDescrCnv    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
-IdDictDetDescrCnv    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
-IdDictDetDescrCnv    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
-IdDictDetDescrCnv    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
-IdDictDetDescrCnv    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
-LArElectrodeID       INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineIDDetD...   INFO in createObj: creating a LArHVLineID helper object in the detector store
-LArHVLineID          INFO  => initialize_from_dictionary()
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-LArHVLineID          INFO  => initialize_from_dictionary(dict_mgr) =0
-LArHVLineID          INFO Register_dict_tag of LArHighVoltage is OK
-LArHVLineID          INFO setDictVersion of LArHighVoltage is OK
-LArHVLineID          INFO [initLevelsFromDict] m_dict OK ... 
-LArHVLineID          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
-LArHVLineID          INFO [init_hashes()] > Hvline_size= 5008
-GeoModelSvc.LAr...   INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
-GeoModelSvc.LAr...   INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
-GeoModelSvc.LAr...   INFO LAr Geometry Options:
-GeoModelSvc.LAr...   INFO   Sagging           = false
-GeoModelSvc.LAr...   INFO   Barrel            = ON
-GeoModelSvc.LAr...   INFO   Endcap            = ON
-BarrelConstruction   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
-BarrelConstruction   INFO   Makes detailed absorber sandwich  ? 1 1
-BarrelConstruction   INFO   Use sagging in geometry  ? 0
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Pos::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Pos::OuterWheel
-ClassIDSvc           INFO  getRegistryEntries: read 2958 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a TileTBID helper object in the detector store
-TileTBID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-EndcapDMConstru...   INFO Start building EC electronics geometry
-EMECConstruction     INFO multi-layered version of absorbers activated, parameter value is 1
-EMECConstruction     INFO activating LAr::EMEC::Neg::InnerWheel
-EMECConstruction     INFO activating LAr::EMEC::Neg::OuterWheel
-EndcapDMConstru...   INFO Start building EC electronics geometry
-GeoModelSvc          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 36160Kb 	 Time = 2.22S
-GeoModelSvc.Til...   INFO  Entering TileDetectorTool::create()
-TileDddbManager      INFO m_tag = ATLAS-R2-2016-01-00-01
-TileDddbManager      INFO n_tiglob = 5
-TileDddbManager      INFO n_timod = 320
-TileDddbManager      INFO n_cuts = 9
-TileDddbManager      INFO n_saddle = 1
-TileDddbManager      INFO n_tilb = 21
-TileDddbManager      INFO n_tileSwitches = 1
-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/2019-10-18T2133/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-dbg/share/TileNeighbour_reduced.txt
-TileHWIDDetDesc...   INFO in createObj: creating a TileHWID helper object in the detector store
-TileHWID             INFO initialize_from_dictionary 
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-ClassIDSvc           INFO  getRegistryEntries: read 55 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_ID helper object in the detector store
-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/2019-10-18T2133/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-dbg/share/FCal2DNeighbors-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2019-10-18T2133/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-dbg/share/FCal3DNeighborsNext-April2011.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2019-10-18T2133/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-dbg/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.
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-GeoModelSvc.Til...   INFO  U-shape parameter from database is: 1
-GeoModelSvc.Til...   INFO  Glue parameter from database is: 1
-GeoModelSvc.Til...   INFO  Cs Tube parameter from database is: 0
-GeoModelSvc.Til...   INFO  Entering TileAtlasFactory::create()
-GeoModelSvc.Til...   INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
-GeoModelSvc.Til...   INFO  => New BFingerLengthPos 430.5
-GeoModelSvc.Til...   INFO  => New BFingerLengthNeg 420.5
-GeoModelSvc.Til...   INFO  Positioning barrel with translation 0
-GeoModelSvc.Til...   INFO  Positioning positive barrel finger with translation 3035.25
-GeoModelSvc.Til...   INFO  Positioning negative barrel finger with translation -3030.25
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel with translation 4854.75
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
-GeoModelSvc.Til...   INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
-GeoModelSvc.Til...   INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning positive ITC with translation 3405
-GeoModelSvc.Til...   INFO  Positioning positive Gap with translation 3552
-GeoModelSvc.Til...   INFO  Positioning positive Crack with translation 3536
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel with translation ztrans -4854.75
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
-GeoModelSvc.Til...   INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
-GeoModelSvc.Til...   INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
-GeoModelSvc.Til...   INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
-GeoModelSvc.Til...   INFO  Positioning negative ITC with translation -3405
-GeoModelSvc.Til...   INFO  Positioning negative Gap with translation -3552
-GeoModelSvc.Til...   INFO  Positioning negative Crack with translation -3536
-GeoModelSvc.Til...   INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
-GeoModelSvc.Til...   INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
-TileDetDescrMan...   INFO Entering create_elements()
-GeoModelSvc          INFO GeoModelSvc.TileDetectorTool	 SZ= 4776Kb 	 Time = 1.96S
-ClassIDSvc           INFO  getRegistryEntries: read 66 CLIDRegistry entries for module ALL
-TileInfoLoader       INFO Changing TTL1 calib from 4.1 to 6.9
-TileInfoLoader       INFO Changing TTL1 noise sigma from 2.5 to 2.8
-CaloIDHelper_ID...   INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
-CaloLVL1_ID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-TileCablingSvc       INFO RUN2 ATLAS geometry flag detected for geometry: ATLAS-R2-2016-01-00-01
-TileCablingSvc       INFO Cabling for RUN2 (2014-2017) ATLAS geometry is set via jobOptions 
-TileCablingSvc       INFO Setting Cabling type to 4
-AthenaEventLoopMgr   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
-ClassIDSvc           INFO  getRegistryEntries: read 4939 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 704 CLIDRegistry entries for module ALL
-CondInputLoader      INFO Initializing CondInputLoader...
-CondInputLoader      INFO Adding base classes:
+CoreDumpSvc                                          INFO Handling signals: 11(Segmentation fault) 7(Bus error) 4(Illegal instruction) 8(Floating point exception) 
+ClassIDSvc                                           INFO  getRegistryEntries: read 18497 CLIDRegistry entries for module ALL
+TagInfoMgr                                           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
+IOVDbSvc                                             INFO Only 5 POOL conditions files will be open at once
+IOVDbSvc                                             INFO Cache alignment will be done in 3 slices
+IOVDbSvc                                             INFO Global tag: OFLCOND-MC16-SDR-17 set from joboptions
+IOVDbSvc                                             INFO Initialised with 4 connections and 22 folders
+IOVDbSvc                                             INFO Service IOVDbSvc initialised successfully
+IOVDbSvc                                             INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+MetaDataSvc                                          INFO Initializing MetaDataSvc - package version AthenaServices-00-00-00
+PoolSvc                                              INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.xml) [ok]
+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://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy-atlas.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy.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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/dbreplica.config
+DBReplicaSvc                                         INFO Total of 10 servers found for host pcaz001.dyndns.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                                              INFO Resolved path (via ATLAS_POOLCOND_PATH) is /cvmfs/atlas-condb.cern.ch/repo/conditions/poolcond/PoolFileCatalog.xml
+PoolSvc                                           WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                           WARNING Unable to locate catalog for apcfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables
+PoolSvc                                              INFO POOL WriteCatalog is xmlcatalog_file:PoolFileCatalog.xml
+DbSession                                            INFO     Open     DbSession    
+Domain[ROOT_All]                                     INFO >   Access   DbDomain     READ      [ROOT_All] 
+MetaDataSvc                                          INFO Found MetaDataTools = PublicToolHandleArray(['IOVDbMetaDataTool/IOVDbMetaDataTool'])
+OutputStreamSequencerSvc                             INFO Initializing OutputStreamSequencerSvc - package version AthenaServices-00-00-00
+MetaDataSvc                                          INFO   AlgTool: ToolSvc.IOVDbMetaDataTool
+ClassIDSvc                                           INFO  getRegistryEntries: read 1178 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVSvc                                               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool                                    INFO IOVRanges will be checked at every Event
+ClassIDSvc                                           INFO  getRegistryEntries: read 273 CLIDRegistry entries for module ALL
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_TILE/OFLP200
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_CALO/OFLP200
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_TILE/OFLP200
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_CALO/OFLP200
+IOVDbSvc                                             INFO Added taginfo remove for /CALO/Ofl/Noise/CellNoise
+IOVDbSvc                                             INFO Added taginfo remove for /CALO/Ofl/Noise/PileUpNoiseLumi
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Align
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Identifier/CalibIdMap
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Identifier/FebRodMap
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/Identifier/OnOffIdMap
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/NoiseOfl/CellNoise
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/CES
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/CIS/FIT/LIN
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/CIS/FIT/NLN
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/EMS
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/FIBER
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/LIN
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/CALIB/LAS/NLN
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/NOISE/CELL
+IOVDbSvc                                             INFO Added taginfo remove for /TILE/OFL02/NOISE/SAMPLE
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/LArCellPositionShift
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/DAC2uA
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/HVScaleCorr
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/MphysOverMcal
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/Ramp
+IOVDbSvc                                             INFO Added taginfo remove for /LAR/ElecCalibMC/uA2MeV
+ClassIDSvc                                           INFO  getRegistryEntries: read 20 CLIDRegistry entries for module ALL
+DetDescrCnvSvc                                       INFO  initializing 
+DetDescrCnvSvc                                       INFO Found DetectorStore service
+DetDescrCnvSvc                                       INFO  filling proxies for detector managers 
+DetDescrCnvSvc                                       INFO  filling address for CaloTTMgr with CLID 117659265 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloMgr with CLID 4548337 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloSuperCellMgr with CLID 241807251 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloIdManager with CLID 125856940 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArIdManager with CLID 79554919 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for IdDict with CLID 2411 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for AtlasID with CLID 164875623 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for PixelID with CLID 2516 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SCT_ID with CLID 2517 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TRT_ID with CLID 2518 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for SiliconID with CLID 129452393 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_ID with CLID 163583365 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArEM_SuperCell_ID with CLID 99488227 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_ID with CLID 3870484 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHEC_SuperCell_ID with CLID 254277678 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_ID with CLID 45738051 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArFCAL_SuperCell_ID with CLID 12829437 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArMiniFCAL_ID with CLID 79264204 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnlineID with CLID 158698068 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TTOnlineID with CLID 38321944 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArOnline_SuperCellID with CLID 115600394 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArHVLineID with CLID 27863673 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for LArElectrodeID with CLID 80757351 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileID with CLID 2901 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for Tile_SuperCell_ID with CLID 49557789 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileHWID with CLID 2902 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TileTBID with CLID 2903 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for MDTIDHELPER with CLID 4170 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CSCIDHELPER with CLID 4171 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for RPCIDHELPER with CLID 4172 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for TGCIDHELPER with CLID 4173 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloLVL1_ID with CLID 108133391 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_ID with CLID 123500438 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
+DetDescrCnvSvc                                       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting PixTBMaterials with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMatComponents with default tag
+GeoModelSvc::RDBMaterialManager                   WARNING  Getting InDetMaterials with default tag
+EventPersistencySvc                                  INFO Added successfully Conversion service:McCnvSvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:DetDescrCnvSvc
+LArElectrodeIDDetDescrCnv                            INFO in createObj: creating a LArElectrodeID helper object in the detector store
+IdDictDetDescrCnv                                    INFO in initialize
+IdDictDetDescrCnv                                    INFO in createObj: creating a IdDictManager object in the detector store
+IdDictDetDescrCnv                                    INFO IdDictName:  IdDictParser/ATLAS_IDS.xml
+IdDictDetDescrCnv                                    INFO Reading InnerDetector    IdDict file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Reading LArCalorimeter   IdDict file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Reading TileCalorimeter  IdDict file IdDictParser/IdDictTileCalorimeter.xml
+IdDictDetDescrCnv                                    INFO Reading Calorimeter      IdDict file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Reading MuonSpectrometer IdDict file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Reading ForwardDetectors IdDict file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Found id dicts:
+IdDictDetDescrCnv                                    INFO Using dictionary tag: null
+IdDictDetDescrCnv                                    INFO Dictionary ATLAS                version default              DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary Calorimeter          version default              DetDescr tag CaloIdentifier-LVL1-02 file IdDictParser/IdDictCalorimeter_L1Onl.xml
+IdDictDetDescrCnv                                    INFO Dictionary ForwardDetectors     version default              DetDescr tag ForDetIdentifier-01       file IdDictParser/IdDictForwardDetectors_2010.xml
+IdDictDetDescrCnv                                    INFO Dictionary InnerDetector        version IBL-DBM              DetDescr tag InDetIdentifier-IBL3D25-02 file InDetIdDictFiles/IdDictInnerDetector_IBL3D25-03.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArCalorimeter       version fullAtlas            DetDescr tag LArIdentifier-DC3-05-Comm file IdDictParser/IdDictLArCalorimeter_DC3-05-Comm-01.xml
+IdDictDetDescrCnv                                    INFO Dictionary LArElectrode         version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary LArHighVoltage       version fullAtlas            DetDescr tag (using default) file 
+IdDictDetDescrCnv                                    INFO Dictionary MuonSpectrometer     version R.03                 DetDescr tag MuonIdentifier-08         file IdDictParser/IdDictMuonSpectrometer_R.03.xml
+IdDictDetDescrCnv                                    INFO Dictionary TileCalorimeter      version fullAtlasAndTestBeam DetDescr tag TileIdentifier-00         file IdDictParser/IdDictTileCalorimeter.xml
+LArElectrodeID                                       INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineIDDetDescrCnv                               INFO in createObj: creating a LArHVLineID helper object in the detector store
+LArHVLineID                                          INFO  => initialize_from_dictionary()
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+LArHVLineID                                          INFO  => initialize_from_dictionary(dict_mgr) =0
+LArHVLineID                                          INFO Register_dict_tag of LArHighVoltage is OK
+LArHVLineID                                          INFO setDictVersion of LArHighVoltage is OK
+LArHVLineID                                          INFO [initLevelsFromDict] m_dict OK ... 
+LArHVLineID                                          INFO [initialize_from_dictionary] >  HV line range -> 11/1/48:79/0:15 | 11/1/148:179/0:15 | 11/1/80:93/0:7 | 11/1/180:193/0:7 | 11/1/200:231/0:15 | 11/1/232:263/0:15 | 11/1/296,297,306,307/0:15 | 11/1/299,304,305,308,309/0:15 | 11/1/264:279/0:15 | 11/1/280:295/0:15 | 11/1/0:47/0:15 | 11/1/320:322/0:15 | 11/1/100:147/0:15 | 11/1/324,325/0:15 | 11/1/312:315/0:15 | 11/1/316:319/0:15 | 11/1/300:303/0:15 | 11/1/310,311/0:15 | 11/1/323/0:15 | 11/1/326,327/0:15 | 11/1/94:99/0:15 | 11/1/194:199/0:15
+LArHVLineID                                          INFO [init_hashes()] > Hvline_size= 5008
+GeoModelSvc.LArDetectorToolNV                        INFO Keys for LAr are ATLAS-R2-2016-01-00-01  ATLAS
+GeoModelSvc.LArDetectorToolNV                        INFO Building LAr version LAr-Revised-17-01 while ATLAS version is ATLAS-R2-2016-01-00-01
+GeoModelSvc.LArDetectorToolNV                        INFO LAr Geometry Options:
+GeoModelSvc.LArDetectorToolNV                        INFO   Sagging           = false
+GeoModelSvc.LArDetectorToolNV                        INFO   Barrel            = ON
+GeoModelSvc.LArDetectorToolNV                        INFO   Endcap            = ON
+BarrelConstruction                                   INFO Getting primary numbers for ATLAS, ATLAS-R2-2016-01-00-01
+BarrelConstruction                                   INFO   Makes detailed absorber sandwich  ? 1 1
+BarrelConstruction                                   INFO   Use sagging in geometry  ? 0
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Pos::OuterWheel
+ClassIDSvc                                           INFO  getRegistryEntries: read 2973 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TileTBID helper object in the detector store
+TileTBID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+EMECConstruction                                     INFO multi-layered version of absorbers activated, parameter value is 1
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::InnerWheel
+EMECConstruction                                     INFO activating LAr::EMEC::Neg::OuterWheel
+EndcapDMConstruction                                 INFO Start building EC electronics geometry
+GeoModelSvc                                          INFO GeoModelSvc.LArDetectorToolNV	 SZ= 26148Kb 	 Time = 1.03S
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileDetectorTool::create()
+TileDddbManager                                      INFO m_tag = ATLAS-R2-2016-01-00-01
+TileDddbManager                                      INFO n_tiglob = 5
+TileDddbManager                                      INFO n_timod = 320
+TileDddbManager                                      INFO n_cuts = 9
+TileDddbManager                                      INFO n_saddle = 1
+TileDddbManager                                      INFO n_tilb = 21
+TileDddbManager                                      INFO n_tileSwitches = 1
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileNeighbour_reduced.txt
+TileHWIDDetDescrCnv                                  INFO in createObj: creating a TileHWID helper object in the detector store
+TileHWID                                             INFO initialize_from_dictionary 
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+ClassIDSvc                                           INFO  getRegistryEntries: read 55 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal2DNeighbors-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsNext-April2011.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCal3DNeighborsPrev-April2011.txt
+CaloIDHelper_IDDetDescrCnv                           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.
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+GeoModelSvc.TileDetectorTool                         INFO  U-shape parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Glue parameter from database is: 1
+GeoModelSvc.TileDetectorTool                         INFO  Cs Tube parameter from database is: 0
+GeoModelSvc.TileDetectorTool                         INFO  Entering TileAtlasFactory::create()
+GeoModelSvc.TileDetectorTool                         INFO  Tile Geometry with Saddle supports, starting from TileCal-CSC-02 xxx
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthPos 430.5
+GeoModelSvc.TileDetectorTool                         INFO  => New BFingerLengthNeg 420.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning barrel with translation 0
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive barrel finger with translation 3035.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative barrel finger with translation -3030.25
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel with translation 4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel finger with translation ztrans= 6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ext.barrel saddle with translation ztrans= 6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Positive ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive ITC with translation 3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Gap with translation 3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning positive Crack with translation 3536
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel with translation ztrans -4854.75
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel finger with translation ztrans= -6338.5
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ext.barrel saddle with translation ztrans= -6192.5
+GeoModelSvc.TileDetectorTool                         INFO  Negative ITC envelope parameters: PLUG1  Rmin= 3438.85 Rmax= 4250 dzITC1= 154.5
+GeoModelSvc.TileDetectorTool                         INFO                                    PLUG2  Rmin= 2981 Rmax= 3440 dzITC2= 47.425
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative ITC with translation -3405
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Gap with translation -3552
+GeoModelSvc.TileDetectorTool                         INFO  Positioning negative Crack with translation -3536
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of positive ext.barrel with rotation (0,0,0)) and translation (0,0,0) Gaudi::Units::cm
+GeoModelSvc.TileDetectorTool                         INFO  Global positioning of negative ext.barrel with rotation (0,0,0)) and translation (0,0,1) Gaudi::Units::cm
+TileDetDescrManager                                  INFO Entering create_elements()
+GeoModelSvc                                          INFO GeoModelSvc.TileDetectorTool	 SZ= 4532Kb 	 Time = 0.34S
+ClassIDSvc                                           INFO  getRegistryEntries: read 67 CLIDRegistry entries for module ALL
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.LArDetectorToolNV
+GeoModelSvc                                          INFO   AlgTool: GeoModelSvc.TileDetectorTool
+TileInfoLoader                                       INFO Changing TTL1 calib from 4.1 to 6.9
+TileInfoLoader                                       INFO Changing TTL1 noise sigma from 2.5 to 2.8
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloLVL1_ID helper object in the detector store
+CaloLVL1_ID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+TileCablingSvc                                       INFO RUN2 ATLAS geometry flag detected for geometry: ATLAS-R2-2016-01-00-01
+TileCablingSvc                                       INFO Cabling for RUN2 (2014-2017) ATLAS geometry is set via jobOptions 
+TileCablingSvc                                       INFO Setting Cabling type to 4
+AthenaEventLoopMgr                                   INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00
+ClassIDSvc                                           INFO  getRegistryEntries: read 5023 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 713 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO Initializing CondInputLoader...
+CondInputLoader                                      INFO Adding base classes:
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/CalibIdMap' )   ->
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/FebRodMap' )   ->
   +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' )   ->
@@ -268,7 +272,7 @@ CondInputLoader      INFO Adding base classes:
   +  ( 'LArMphysOverMcalMC' , 'ConditionStore+LArMphysOverMcal' )   -> ILArMphysOverMcal (128308807)
   +  ( 'LArRampMC' , 'ConditionStore+LArRamp' )   -> ILArRamp (8123)
   +  ( 'LAruA2MeVMC' , 'ConditionStore+LAruA2MeV' )   -> ILAruA2MeV (154639332)
-CondInputLoader      INFO Will create WriteCondHandle dependencies for the following DataObjects:
+CondInputLoader                                      INFO Will create WriteCondHandle dependencies for the following DataObjects:
     +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/CalibIdMap' ) 
     +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/FebRodMap' ) 
     +  ( 'AthenaAttributeList' , 'ConditionStore+/LAR/Identifier/OnOffIdMap' ) 
@@ -294,256 +298,257 @@ CondInputLoader      INFO Will create WriteCondHandle dependencies for the follo
     +  ( 'LArMphysOverMcalMC' , 'ConditionStore+LArMphysOverMcal' ) 
     +  ( 'LArRampMC' , 'ConditionStore+LArRamp' ) 
     +  ( 'LAruA2MeVMC' , 'ConditionStore+LAruA2MeV' ) 
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCisLin) for folder: "/TILE/OFL02/CALIB/CIS/FIT/LIN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCisNln) for folder: "/TILE/OFL02/CALIB/CIS/FIT/NLN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasLin) for folder: "/TILE/OFL02/CALIB/LAS/LIN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasNln) for folder: "/TILE/OFL02/CALIB/LAS/NLN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasFib) for folder: "/TILE/OFL02/CALIB/LAS/FIBER"
-TileEMScaleCondAlg   INFO ProxyOflLasFib is set up and can be used
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCes) for folder: "/TILE/OFL02/CALIB/CES"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflEms) for folder: "/TILE/OFL02/CALIB/EMS"
-TileEMScaleCondAlg   INFO Undoing online calibration is not requested, since OnlCacheUnit= 'OnlCacheUnit':Invalid
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlCis) for folder: "/TILE/OFL02/CALIB/CIS/FIT/LIN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlLas) for folder: "/TILE/OFL02/CALIB/LAS/LIN"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlCes) for folder: "/TILE/OFL02/CALIB/CES"
-TileEMScaleCond...   INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlEms) for folder: "/TILE/OFL02/CALIB/EMS"
-TileSampleNoise...   INFO Creating TileCondProxyCool(TileSampleNoiseCondAlg.TileCondProxyCool_NoiseSample) for folder: "/TILE/OFL02/NOISE/SAMPLE"
-LArOnlineIDDetD...   INFO in createObj: creating a LArOnlineID helper object in the detector store
-LArOnlineID          INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-Calo_electronic...   INFO Will compute electronic noise
-PyComponentMgr       INFO Initializing PyComponentMgr...
-TestAlg              INFO Initializing TestAlg...
-ClassIDSvc           INFO  getRegistryEntries: read 1029 CLIDRegistry entries for module ALL
-HistogramPersis...WARNING Histograms saving not required.
-EventSelector        INFO  Enter McEventSelector Initialization 
-AthenaEventLoopMgr   INFO Setup EventSelector service EventSelector
-ApplicationMgr       INFO Application Manager Initialized successfully
-ApplicationMgr    SUCCESS ****************************** Algorithm Sequence ****************************
-ApplicationMgr    SUCCESS AthSequencer/AthMasterSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthAlgEvtSeq
-ApplicationMgr    SUCCESS           AthSequencer/AthBeginSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg1
-ApplicationMgr    SUCCESS           AthSequencer/AthAllAlgSeq
-ApplicationMgr    SUCCESS                AthSequencer/AthCondSeq
-ApplicationMgr    SUCCESS                     CondInputLoader/CondInputLoader
-ApplicationMgr    SUCCESS                     LArFebRodMappingAlg/LArFebRodMappingAlg
-ApplicationMgr    SUCCESS                     LArCalibLineMappingAlg/LArCalibLineMappingAlg
-ApplicationMgr    SUCCESS                     TileEMScaleCondAlg/TileEMScaleCondAlg
-ApplicationMgr    SUCCESS                     TileCalibCondAlg<TileCalibDrawerFlt>/TileSampleNoiseCondAlg
-ApplicationMgr    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
-ApplicationMgr    SUCCESS                     LArMCSymCondAlg/LArMCSymCondAlg
-ApplicationMgr    SUCCESS                     LArSymConditionsAlg<LArRampMC, LArRampSym>/LArSymConditionsAlg<LArRampMC, LArRampSym>
-ApplicationMgr    SUCCESS                     LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>/LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>
-ApplicationMgr    SUCCESS                     LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>/LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>
-ApplicationMgr    SUCCESS                     LArSymConditionsAlg<LArMphysOverMcalMC, LArMphysOverMcalSym>/LArSymConditionsAlg<LArMphysOverMcalMC, LArMphysOverMcalSym>
-ApplicationMgr    SUCCESS                     LArADC2MeVCondAlg/LArADC2MeVCondAlg
-ApplicationMgr    SUCCESS                     CaloNoiseCondAlg/Calo_electronicNoiseAlg
-ApplicationMgr    SUCCESS                AthSequencer/AthAlgSeq
-ApplicationMgr    SUCCESS                     PyAthena::Alg/TestAlg
-ApplicationMgr    SUCCESS           AthSequencer/AthEndSeq
-ApplicationMgr    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
-ApplicationMgr    SUCCESS                IncidentProcAlg/IncidentProcAlg2
-ApplicationMgr    SUCCESS      AthSequencer/AthOutSeq
-ApplicationMgr    SUCCESS      AthSequencer/AthRegSeq
-ApplicationMgr    SUCCESS ******************************************************************************
-ClassIDSvc           INFO  getRegistryEntries: read 265 CLIDRegistry entries for module ALL
-CondInputLoader      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/CalibIdMap'
-CondInputLoader      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/FebRodMap'
-CondInputLoader      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CALO/Ofl/Noise/CellNoise'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CALO/Ofl/Noise/PileUpNoiseLumi'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/LAR/NoiseOfl/CellNoise'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CES'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CIS/FIT/LIN'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CIS/FIT/NLN'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/EMS'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/FIBER'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/LIN'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/NLN'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/NOISE/CELL'
-CondInputLoader      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/NOISE/SAMPLE'
-CondInputLoader      INFO created CondCont<LArDAC2uAMC> with key 'ConditionStore+LArDAC2uA'
-CondInputLoader      INFO created CondCont<LArHVScaleCorrComplete> with key 'ConditionStore+LArHVScaleCorr'
-CondInputLoader      INFO created CondCont<LArMphysOverMcalMC> with key 'ConditionStore+LArMphysOverMcal'
-CondInputLoader      INFO created CondCont<LArRampMC> with key 'ConditionStore+LArRamp'
-CondInputLoader      INFO created CondCont<LAruA2MeVMC> with key 'ConditionStore+LAruA2MeV'
-ApplicationMgr       INFO Application Manager Started successfully
-AthenaEventLoopMgr   INFO   ===>>>  start of run 284500    <<<===
-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
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARNoiseOflCellNoise-IOVDEP-05 for folder /LAR/NoiseOfl/CellNoise
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCDAC2uA-IOVDEP-00 for folder /LAR/ElecCalibMC/DAC2uA
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCHVScaleCorr-IOVDEP-01 for folder /LAR/ElecCalibMC/HVScaleCorr
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCMphysOverMcal-CSC02-I for folder /LAR/ElecCalibMC/MphysOverMcal
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCRamp-IOVDEP-00 for folder /LAR/ElecCalibMC/Ramp
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCuA2MeV-IOVDEP-00 for folder /LAR/ElecCalibMC/uA2MeV
-IOVDbSvc             INFO Disconnecting from COOLOFL_LAR/OFLP200
-AthenaPoolCnvSvc     INFO Initializing AthenaPoolCnvSvc - package version AthenaPoolCnvSvc-00-00-00
-EventPersistenc...   INFO Added successfully Conversion service:AthenaPoolCnvSvc
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root File version:52200
-CaloMgrDetDescrCnv   INFO in createObj: creating a Calo Detector Manager object in the detector store
-CaloIdMgrDetDes...   INFO in createObj: creating a CaloDescrManager object in the detector store
-ClassIDSvc           INFO  getRegistryEntries: read 544 CLIDRegistry entries for module ALL
-CaloIDHelper_ID...   INFO in createObj: creating a CaloDM_ID helper object in the detector store
-CaloDM_ID            INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a TTOnlineID helper object in the detector store
-TTOnlineID           INFO initialize_from_dictionary
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
-CaloIDHelper_ID...   INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIDHelper_ID...   INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
-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/2019-10-18T2133/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-dbg/share/FCalSuperCells2DNeighborsNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2019-10-18T2133/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-dbg/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
-LArFCAL_Base_ID      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2019-10-18T2133/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-dbg/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/2019-10-18T2133/Athena/22.0.7/InstallArea/x86_64-centos7-gcc8-dbg/share/TileSuperCellNeighbour.txt
-AtlasDetectorID      INFO initialize_from_dictionary - OK
-CaloIdMgrDetDes...   INFO  Finished 
-CaloIdMgrDetDes...   INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
-AthenaEventLoopMgr   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_CALO/OFLP200
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to CaloOflNoiseCellnoise-empty for folder /CALO/Ofl/Noise/CellNoise
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to CALOOflNoisePileUpNoiseLumi-IOVDEP-11 for folder /CALO/Ofl/Noise/PileUpNoiseLumi
-IOVDbSvc             INFO Disconnecting from COOLOFL_CALO/OFLP200
-IOVDbSvc             INFO Opening COOL connection for COOLOFL_TILE/OFLP200
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCes-SIM-07 for folder /TILE/OFL02/CALIB/CES
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCisFitLin-COM-00 for folder /TILE/OFL02/CALIB/CIS/FIT/LIN
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCisFitNln-COM-00 for folder /TILE/OFL02/CALIB/CIS/FIT/NLN
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibEms-COM-00 for folder /TILE/OFL02/CALIB/EMS
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasFiber-000-00 for folder /TILE/OFL02/CALIB/LAS/FIBER
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasLin-COM-00 for folder /TILE/OFL02/CALIB/LAS/LIN
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasNln-COM-00 for folder /TILE/OFL02/CALIB/LAS/NLN
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02NoiseCell-OF2-13 for folder /TILE/OFL02/NOISE/CELL
-IOVDbFolder          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02NoiseSample-TwoGauss-21 for folder /TILE/OFL02/NOISE/SAMPLE
-IOVDbSvc             INFO Disconnecting from COOLOFL_TILE/OFLP200
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 64ADE389-CABD-DD11-8D4C-000423D950B0
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000001.gen.COND/cond08_mc.000001.gen.COND._0053.pool.root
+TileEMScaleCondAlg.TileCondProxyCool_OflCisLin       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCisLin) for folder: "/TILE/OFL02/CALIB/CIS/FIT/LIN"
+TileEMScaleCondAlg.TileCondProxyCool_OflCisNln       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCisNln) for folder: "/TILE/OFL02/CALIB/CIS/FIT/NLN"
+TileEMScaleCondAlg.TileCondProxyCool_OflLasLin       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasLin) for folder: "/TILE/OFL02/CALIB/LAS/LIN"
+TileEMScaleCondAlg.TileCondProxyCool_OflLasNln       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasNln) for folder: "/TILE/OFL02/CALIB/LAS/NLN"
+TileEMScaleCondAlg.TileCondProxyCool_OflLasFib       INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflLasFib) for folder: "/TILE/OFL02/CALIB/LAS/FIBER"
+TileEMScaleCondAlg                                   INFO ProxyOflLasFib is set up and can be used
+TileEMScaleCondAlg.TileCondProxyCool_OflCes          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflCes) for folder: "/TILE/OFL02/CALIB/CES"
+TileEMScaleCondAlg.TileCondProxyCool_OflEms          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OflEms) for folder: "/TILE/OFL02/CALIB/EMS"
+TileEMScaleCondAlg                                   INFO Undoing online calibration is not requested, since OnlCacheUnit= 'OnlCacheUnit':'Invalid'
+TileEMScaleCondAlg.TileCondProxyCool_OnlCis          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlCis) for folder: "/TILE/OFL02/CALIB/CIS/FIT/LIN"
+TileEMScaleCondAlg.TileCondProxyCool_OnlLas          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlLas) for folder: "/TILE/OFL02/CALIB/LAS/LIN"
+TileEMScaleCondAlg.TileCondProxyCool_OnlCes          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlCes) for folder: "/TILE/OFL02/CALIB/CES"
+TileEMScaleCondAlg.TileCondProxyCool_OnlEms          INFO Creating TileCondProxyCool(TileEMScaleCondAlg.TileCondProxyCool_OnlEms) for folder: "/TILE/OFL02/CALIB/EMS"
+TileSampleNoiseCon...TileCondProxyCool_NoiseSample   INFO Creating TileCondProxyCool(TileSampleNoiseCondAlg.TileCondProxyCool_NoiseSample) for folder: "/TILE/OFL02/NOISE/SAMPLE"
+LArOnlineIDDetDescrCnv                               INFO in createObj: creating a LArOnlineID helper object in the detector store
+LArOnlineID                                          INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+Calo_electronicNoiseAlg                              INFO Will compute electronic noise
+PyComponentMgr                                       INFO Initializing PyComponentMgr...
+TestAlg                                              INFO Initializing TestAlg...
+ClassIDSvc                                           INFO  getRegistryEntries: read 996 CLIDRegistry entries for module ALL
+EventSelector                                        INFO  Enter McEventSelector Initialization 
+AthenaEventLoopMgr                                   INFO Setup EventSelector service EventSelector
+ApplicationMgr                                       INFO Application Manager Initialized successfully
+ApplicationMgr                                    SUCCESS ****************************** Algorithm Sequence ****************************
+ApplicationMgr                                    SUCCESS AthSequencer/AthMasterSeq
+ApplicationMgr                                    SUCCESS      AthSequencer/AthAlgEvtSeq
+ApplicationMgr                                    SUCCESS           AthSequencer/AthBeginSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/BeginIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg1
+ApplicationMgr                                    SUCCESS           AthSequencer/AthAllAlgSeq
+ApplicationMgr                                    SUCCESS                AthSequencer/AthCondSeq
+ApplicationMgr                                    SUCCESS                     CondInputLoader/CondInputLoader
+ApplicationMgr                                    SUCCESS                     LArFebRodMappingAlg/LArFebRodMappingAlg
+ApplicationMgr                                    SUCCESS                     LArCalibLineMappingAlg/LArCalibLineMappingAlg
+ApplicationMgr                                    SUCCESS                     TileEMScaleCondAlg/TileEMScaleCondAlg
+ApplicationMgr                                    SUCCESS                     TileCalibCondAlg<TileCalibDrawerFlt>/TileSampleNoiseCondAlg
+ApplicationMgr                                    SUCCESS                     LArOnOffMappingAlg/LArOnOffMappingAlg
+ApplicationMgr                                    SUCCESS                     LArMCSymCondAlg/LArMCSymCondAlg
+ApplicationMgr                                    SUCCESS                     LArSymConditionsAlg<LArRampMC, LArRampSym>/LArSymConditionsAlg<LArRampMC, LArRampSym>
+ApplicationMgr                                    SUCCESS                     LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>/LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>
+ApplicationMgr                                    SUCCESS                     LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>/LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>
+ApplicationMgr                                    SUCCESS                     LArSymConditionsAlg<LArMphysOverMcalMC, LArMphysOverMcalSym>/LArSymConditionsAlg<LArMphysOverMcalMC, LArMphysOverMcalSym>
+ApplicationMgr                                    SUCCESS                     LArADC2MeVCondAlg/LArADC2MeVCondAlg
+ApplicationMgr                                    SUCCESS                     CaloNoiseCondAlg/Calo_electronicNoiseAlg
+ApplicationMgr                                    SUCCESS                AthSequencer/AthAlgSeq
+ApplicationMgr                                    SUCCESS                     PyAthena::Alg/TestAlg
+ApplicationMgr                                    SUCCESS           AthSequencer/AthEndSeq
+ApplicationMgr                                    SUCCESS                AthIncFirerAlg/EndIncFiringAlg
+ApplicationMgr                                    SUCCESS                IncidentProcAlg/IncidentProcAlg2
+ApplicationMgr                                    SUCCESS      AthSequencer/AthOutSeq
+ApplicationMgr                                    SUCCESS ******************************************************************************
+ClassIDSvc                                           INFO  getRegistryEntries: read 270 CLIDRegistry entries for module ALL
+CondInputLoader                                      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/CalibIdMap'
+CondInputLoader                                      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/FebRodMap'
+CondInputLoader                                      INFO created CondCont<AthenaAttributeList> with key 'ConditionStore+/LAR/Identifier/OnOffIdMap'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CALO/Ofl/Noise/CellNoise'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/CALO/Ofl/Noise/PileUpNoiseLumi'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/LAR/NoiseOfl/CellNoise'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CES'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CIS/FIT/LIN'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/CIS/FIT/NLN'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/EMS'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/FIBER'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/LIN'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/CALIB/LAS/NLN'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/NOISE/CELL'
+CondInputLoader                                      INFO created CondCont<CondAttrListCollection> with key 'ConditionStore+/TILE/OFL02/NOISE/SAMPLE'
+CondInputLoader                                      INFO created CondCont<LArDAC2uAMC> with key 'ConditionStore+LArDAC2uA'
+CondInputLoader                                      INFO created CondCont<LArHVScaleCorrComplete> with key 'ConditionStore+LArHVScaleCorr'
+CondInputLoader                                      INFO created CondCont<LArMphysOverMcalMC> with key 'ConditionStore+LArMphysOverMcal'
+CondInputLoader                                      INFO created CondCont<LArRampMC> with key 'ConditionStore+LArRamp'
+CondInputLoader                                      INFO created CondCont<LAruA2MeVMC> with key 'ConditionStore+LAruA2MeV'
+ApplicationMgr                                       INFO Application Manager Started successfully
+AthenaEventLoopMgr                                   INFO   ===>>>  start of run 284500    <<<===
+EventPersistencySvc                                  INFO Added successfully Conversion service:TagInfoMgr
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_LAR/OFLP200
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARAlign-IOVDEP-01 for folder /LAR/Align
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARNoiseOflCellNoise-IOVDEP-05 for folder /LAR/NoiseOfl/CellNoise
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LArCellPositionShift-IOVDEP-00 for folder /LAR/LArCellPositionShift
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCDAC2uA-IOVDEP-00 for folder /LAR/ElecCalibMC/DAC2uA
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCHVScaleCorr-IOVDEP-01 for folder /LAR/ElecCalibMC/HVScaleCorr
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCMphysOverMcal-CSC02-I for folder /LAR/ElecCalibMC/MphysOverMcal
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCRamp-IOVDEP-00 for folder /LAR/ElecCalibMC/Ramp
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to LARElecCalibMCuA2MeV-IOVDEP-00 for folder /LAR/ElecCalibMC/uA2MeV
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_LAR/OFLP200
+IOVDbSvc                                             INFO Opened read transaction for POOL PersistencySvc
+EventPersistencySvc                                  INFO Added successfully Conversion service:AthenaPoolCnvSvc
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000114.gen.COND/cond09_mc.000114.gen.COND._0003.pool.root File version:52200
+CaloMgrDetDescrCnv                                   INFO in createObj: creating a Calo Detector Manager object in the detector store
+CaloIdMgrDetDescrCnv                                 INFO in createObj: creating a CaloDescrManager object in the detector store
+ClassIDSvc                                           INFO  getRegistryEntries: read 196 CLIDRegistry entries for module ALL
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloDM_ID helper object in the detector store
+CaloDM_ID                                            INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a TTOnlineID helper object in the detector store
+TTOnlineID                                           INFO initialize_from_dictionary
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a CaloCell_SuperCell_ID helper object in the detector store
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArEM_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           INFO in createObj: creating a LArHEC_SuperCell_ID helper object in the detector store
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt
+LArFCAL_Base_ID                                      INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/FCalSuperCells3DNeighborsPrevNew-April2014.txt
+CaloIDHelper_IDDetDescrCnv                           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_Athena_x86_64-centos7-gcc8-opt/2020-12-02T2101/Athena/22.0.22/InstallArea/x86_64-centos7-gcc8-opt/share/TileSuperCellNeighbour.txt
+AtlasDetectorID                                      INFO initialize_from_dictionary - OK
+CaloIdMgrDetDescrCnv                                 INFO  Finished 
+CaloIdMgrDetDescrCnv                                 INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv 
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000003.gen.COND/cond08_mc.000003.gen.COND._0064.pool.root File version:52200
+AthenaEventLoopMgr                                   INFO   ===>>>  start processing event #0, run #284500 0 events processed so far  <<<===
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_CALO/OFLP200
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to CaloOflNoiseCellnoise-empty for folder /CALO/Ofl/Noise/CellNoise
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to CALOOflNoisePileUpNoiseLumi-IOVDEP-11 for folder /CALO/Ofl/Noise/PileUpNoiseLumi
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_CALO/OFLP200
+IOVDbSvc                                             INFO Opening COOL connection for COOLOFL_TILE/OFLP200
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCes-SIM-07 for folder /TILE/OFL02/CALIB/CES
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCisFitLin-COM-00 for folder /TILE/OFL02/CALIB/CIS/FIT/LIN
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibCisFitNln-COM-00 for folder /TILE/OFL02/CALIB/CIS/FIT/NLN
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibEms-COM-00 for folder /TILE/OFL02/CALIB/EMS
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasFiber-000-00 for folder /TILE/OFL02/CALIB/LAS/FIBER
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasLin-COM-00 for folder /TILE/OFL02/CALIB/LAS/LIN
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02CalibLasNln-COM-00 for folder /TILE/OFL02/CALIB/LAS/NLN
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02NoiseCell-OF2-13 for folder /TILE/OFL02/NOISE/CELL
+IOVDbFolder                                          INFO HVS tag OFLCOND-MC16-SDR-17 resolved to TileOfl02NoiseSample-TwoGauss-21 for folder /TILE/OFL02/NOISE/SAMPLE
+IOVDbSvc                                             INFO Disconnecting from COOLOFL_TILE/OFLP200
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 64ADE389-CABD-DD11-8D4C-000423D950B0
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000001.gen.COND/cond08_mc.000001.gen.COND._0053.pool.root
 Warning in <TClass::Init>: no dictionary for class DataHeader_p2 is available
 Warning in <TClass::Init>: no dictionary for class DataHeaderElement_p2 is available
 Warning in <TClass::Init>: no dictionary for class PoolToken_p1 is available
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000001.gen.COND/cond08_mc.000001.gen.COND._0053.pool.root File version:51800
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 83456E4C-ADF9-0D41-B210-7A12B0C9753B
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000085.gen.COND/cond09_mc.000085.gen.COND._0002.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000085.gen.COND/cond09_mc.000085.gen.COND._0002.pool.root File version:53005
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
-Domain[ROOT_All]     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662
-Domain[ROOT_All]     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/comcond/comcond.000004.lar_conditions.recon.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0044.pool.root
-RootDatabase.open    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/comcond/comcond.000004.lar_conditions.recon.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0044.pool.root File version:51400
-/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
-/cvmfs/atlas-co...   INFO Database being retired...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 64ADE389-CABD-DD11-8D4C-000423D950B0
-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] 83456E4C-ADF9-0D41-B210-7A12B0C9753B
-LArFebRodMappin...   INFO Done reading Feb/Rod mapping. Found 1524 Febs and 762 Rods
-LArFebRodMappin...   INFO recorded new LArFebRodMap with range {[0,l:0] - [INVALID]} into Conditions Store
-LArCalibLineMap...   INFO Done reading readout/calibration line mapping.
-LArCalibLineMap...   INFO recorded new LArCalibLineMap with range {[0,l:0] - [INVALID]} into Conditions Store
-LArOnOffMappingAlg   INFO Done reading online/offline identifier mapping
-LArOnOffMappingAlg   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
-LArOnOffMappingAlg   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
-LArMCSymCondAlg      INFO recorded new LArMCSym with range {[0,l:0] - [INVALID]} into Conditions Store
-LArSymCondition...   INFO recorded new LArRampSym with range {[250000,l:0] - [INVALID]} into Conditions Store
-LArSymCondition...   INFO recorded new LArDAC2uASym with range {[250000,l:0] - [INVALID]} into Conditions Store
-LArSymCondition...   INFO recorded new LAruA2MeVSym with range {[250000,l:0] - [INVALID]} into Conditions Store
-LArSymCondition...   INFO recorded new LArMphysOverMcalSym with range {[0,l:0] - [INVALID]} into Conditions Store
-LArADC2MeVCondAlg    INFO IOV of ADC2MeV object is {[250000,t:0,l:0] - [INVALID]}
-LArADC2MeVCondAlg    INFO Working with a ramp polynom of degree 3
-Calo_electronic...   INFO Calculated noise for lumi 13.793 without HV Scale correction
-Calo_electronic...   INFO Gain 0 Nbr of cells: 187652
-Calo_electronic...   INFO Gain 1 Nbr of cells: 187652
-Calo_electronic...   INFO Gain 2 Nbr of cells: 187652
-Calo_electronic...   INFO Gain 3 Nbr of cells: 5184
-Calo_electronic...   INFO recorded new CaloNoise object with key electronicNoise and range {[282483,t:0,l:0] - [290000,t:4294967294.4294967294,l:0]}
-AthDictLoaderSvc     INFO in initialize...
-AthDictLoaderSvc     INFO acquired Dso-registry
-ClassIDSvc           INFO  getRegistryEntries: read 958 CLIDRegistry entries for module ALL
-ClassIDSvc           INFO  getRegistryEntries: read 89 CLIDRegistry entries for module ALL
-AtRndmGenSvc         INFO  Stream =  FastCaloSimNoiseRnd, Seed1 =  895357174, Seed2 = 1992898523
-ToolSvc.AddNois...   INFO Executing start calo size=14 Event=0
-ToolSvc.AddNois...   INFO Executing finished calo size=14 ; e=1.95293e+06 ; et=698754
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond08_mc.000001.gen.COND/cond08_mc.000001.gen.COND._0053.pool.root File version:51800
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 83456E4C-ADF9-0D41-B210-7A12B0C9753B
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000085.gen.COND/cond09_mc.000085.gen.COND._0002.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000085.gen.COND/cond09_mc.000085.gen.COND._0002.pool.root File version:53005
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3263C697-E1F7-E511-A1C4-02163E010D43
+Domain[ROOT_All]                                     INFO ->  Access   DbDatabase   READ      [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662
+Domain[ROOT_All]                                     INFO                           /cvmfs/atlas-condb.cern.ch/repo/conditions/comcond/comcond.000004.lar_conditions.recon.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0044.pool.root
+RootDatabase.open                                    INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/comcond/comcond.000004.lar_conditions.recon.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0044.pool.root File version:51400
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   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
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 64ADE389-CABD-DD11-8D4C-000423D950B0
+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-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 83456E4C-ADF9-0D41-B210-7A12B0C9753B
+LArFebRodMappingAlg                                  INFO Done reading Feb/Rod mapping. Found 1524 Febs and 762 Rods
+LArFebRodMappingAlg                                  INFO recorded new LArFebRodMap with range {[0,l:0] - [INVALID]} into Conditions Store
+LArCalibLineMappingAlg                               INFO Done reading readout/calibration line mapping.
+LArCalibLineMappingAlg                               INFO recorded new LArCalibLineMap with range {[0,l:0] - [INVALID]} into Conditions Store
+LArOnOffMappingAlg                                   INFO Done reading online/offline identifier mapping
+LArOnOffMappingAlg                                   INFO Found 195072 online identifier and 182468 offline identifier. 12604 disconnected channels.
+LArOnOffMappingAlg                                   INFO recorded new LArOnOffIdMap with range {[0,l:0] - [INVALID]} into Conditions Store
+LArMCSymCondAlg                                      INFO recorded new LArMCSym with range {[0,l:0] - [INVALID]} into Conditions Store
+LArSymConditionsAlg<LArRampMC, LArRampSym>           INFO recorded new LArRampSym with range {[250000,t:0,l:0] - [INVALID]} into Conditions Store
+LArSymConditionsAlg<LArDAC2uAMC, LArDAC2uASym>       INFO recorded new LArDAC2uASym with range {[250000,t:0,l:0] - [INVALID]} into Conditions Store
+LArSymConditionsAlg<LAruA2MeVMC, LAruA2MeVSym>       INFO recorded new LAruA2MeVSym with range {[250000,t:0,l:0] - [INVALID]} into Conditions Store
+LArSymConditionsAlg<LA...lMC, LArMphysOverMcalSym>   INFO recorded new LArMphysOverMcalSym with range {[0,t:0,l:0] - [INVALID]} into Conditions Store
+LArADC2MeVCondAlg                                    INFO IOV of ADC2MeV object is {[250000,t:0,l:0] - [INVALID]}
+LArADC2MeVCondAlg                                    INFO Working with a ramp polynom of degree 3
+Calo_electronicNoiseAlg                              INFO Calculated noise for lumi 13.793 without HV Scale correction
+Calo_electronicNoiseAlg                              INFO Gain 0 Nbr of cells: 187652
+Calo_electronicNoiseAlg                              INFO Gain 1 Nbr of cells: 187652
+Calo_electronicNoiseAlg                              INFO Gain 2 Nbr of cells: 187652
+Calo_electronicNoiseAlg                              INFO Gain 3 Nbr of cells: 5184
+Calo_electronicNoiseAlg                              INFO recorded new CaloNoise object with key electronicNoise and range {[282483,t:0,l:0] - [290000,l:0]}
+Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
+Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_ostream<char,char_traits<char> >!
+Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
+Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent basic_stringbuf<char,char_traits<char>,allocator<char> >!
+Error in <TProtoClass::FindDataMember>: data member with index 0 is not found in class locale
+Error in <CreateRealData>: Cannot find data member # 0 of class locale for parent GaudiPython::CallbackStreamBuf!
+AthDictLoaderSvc                                     INFO in initialize...
+AthDictLoaderSvc                                     INFO acquired Dso-registry
+ClassIDSvc                                           INFO  getRegistryEntries: read 1100 CLIDRegistry entries for module ALL
+ClassIDSvc                                           INFO  getRegistryEntries: read 90 CLIDRegistry entries for module ALL
+AthRNGSvc                                            INFO Creating engine ToolSvc.AddNoiseCellBuilderTool
+ToolSvc.AddNoiseCellBuilderTool                      INFO Executing start calo size=14 Event=0
+ToolSvc.AddNoiseCellBuilderTool                      INFO Executing finished calo size=14 ; e=1.94837e+06 ; et=698051
 Py:TestAlg           INFO finished
-AtRndmGenSvc         INFO  Stream =  FastCaloSimNoiseRnd, Seed1 =  598401354, Seed2 = 880181214
-AthenaEventLoopMgr   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
-/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] 303FCBD8-653E-DD11-ABBD-000423D99862
-/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...
-Domain[ROOT_All]     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662
-Domain[ROOT_All]     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
-ApplicationMgr       INFO Application Manager Stopped successfully
-IncidentProcAlg1     INFO Finalize
-CondInputLoader      INFO Finalizing CondInputLoader...
-TestAlg              INFO Finalizing TestAlg...
-IncidentProcAlg2     INFO Finalize
-AthDictLoaderSvc     INFO in finalize...
-EventSelector        INFO finalize
-AtRndmGenSvc         INFO  FINALISING 
-PyComponentMgr       INFO Finalizing PyComponentMgr...
-ToolSvc              INFO Removing all tools created by ToolSvc
-IOVDbFolder          INFO Folder /CALO/Ofl/Noise/CellNoise (AttrListColl) db-read 1/1 objs/chan/bytes 7/7/0 ((     0.14 ))s
-IOVDbFolder          INFO Folder /CALO/Ofl/Noise/PileUpNoiseLumi (AttrListColl) db-read 1/1 objs/chan/bytes 2/2/16 ((     0.06 ))s
-IOVDbFolder          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.92 ))s
-IOVDbFolder          INFO Folder /LAR/Identifier/CalibIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/1520148 ((     0.37 ))s
-IOVDbFolder          INFO Folder /LAR/Identifier/FebRodMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/6100 ((     0.03 ))s
-IOVDbFolder          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     0.04 ))s
-IOVDbFolder          INFO Folder /LAR/NoiseOfl/CellNoise (AttrListColl) db-read 1/1 objs/chan/bytes 6/6/4379568 ((     0.12 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/CES (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/109620 ((     0.12 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/CIS/FIT/LIN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/80 ((     0.09 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/CIS/FIT/NLN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/80 ((     0.10 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/EMS (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/92 ((     0.08 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/LAS/FIBER (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/940 ((     0.09 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/LAS/LIN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/72 ((     0.09 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/CALIB/LAS/NLN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/76 ((     0.08 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/NOISE/CELL (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/414740 ((     0.15 ))s
-IOVDbFolder          INFO Folder /TILE/OFL02/NOISE/SAMPLE (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/641600 ((     1.03 ))s
-IOVDbFolder          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     0.06 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/DAC2uA (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.06 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/HVScaleCorr (PoolRefColl) db-read 1/1 objs/chan/bytes 12/12/1980 ((     0.06 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/MphysOverMcal (PoolRefColl) db-read 1/1 objs/chan/bytes 3/3/516 ((     0.06 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/Ramp (PoolRefColl) db-read 1/1 objs/chan/bytes 3/3/489 ((     0.05 ))s
-IOVDbFolder          INFO Folder /LAR/ElecCalibMC/uA2MeV (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/165 ((     0.06 ))s
-IOVDbSvc             INFO  bytes in ((      3.85 ))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: 11 ReadTime: ((     1.82 ))s
-IOVDbSvc             INFO Connection COOLOFL_TILE/OFLP200 : nConnect: 2 nFolders: 9 ReadTime: ((     1.83 ))s
-IOVDbSvc             INFO Connection COOLOFL_CALO/OFLP200 : nConnect: 2 nFolders: 2 ReadTime: ((     0.20 ))s
-IdDictDetDescrCnv    INFO in finalize
-*****Chrono*****     INFO ****************************************************************************************************
-*****Chrono*****     INFO  The Final CPU consumption ( Chrono ) Table (ordered)
-*****Chrono*****     INFO ****************************************************************************************************
-cObjR_ALL            INFO Time User   : Tot=  0.5  [s] Ave/Min/Max=0.0227(+-0.0788)/    0/ 0.38  [s] #= 22
-cObj_ALL             INFO Time User   : Tot= 0.79  [s] Ave/Min/Max=0.0359(+-0.0949)/    0/ 0.42  [s] #= 22
-ChronoStatSvc        INFO Time User   : Tot= 56.8  [s]                                             #=  1
-*****Chrono*****     INFO ****************************************************************************************************
-ChronoStatSvc.f...   INFO  Service finalized successfully 
-ApplicationMgr       INFO Application Manager Finalized successfully
-ApplicationMgr       INFO Application Manager Terminated successfully
+AthenaEventLoopMgr                                   INFO   ===>>>  done processing event #0, run #284500 1 events processed so far  <<<===
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] 303FCBD8-653E-DD11-ABBD-000423D99862
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO ->  Deaccess DbDatabase   READ      [ROOT_All] D27D07D4-C135-E011-84A9-003048F0E01E
+/cvmfs/atlas-condb.cern.ch/repo/conditions/...root   INFO Database being retired...
+Domain[ROOT_All]                                     INFO >   Deaccess DbDomain     READ      [ROOT_All] 
+ApplicationMgr                                       INFO Application Manager Stopped successfully
+IncidentProcAlg1                                     INFO Finalize
+CondInputLoader                                      INFO Finalizing CondInputLoader...
+TestAlg                                              INFO Finalizing TestAlg...
+IncidentProcAlg2                                     INFO Finalize
+AthDictLoaderSvc                                     INFO in finalize...
+EventSelector                                        INFO finalize
+PyComponentMgr                                       INFO Finalizing PyComponentMgr...
+IdDictDetDescrCnv                                    INFO in finalize
+IOVDbFolder                                          INFO Folder /CALO/Ofl/Noise/CellNoise (AttrListColl) db-read 1/1 objs/chan/bytes 7/7/0 ((     0.05 ))s
+IOVDbFolder                                          INFO Folder /CALO/Ofl/Noise/PileUpNoiseLumi (AttrListColl) db-read 1/1 objs/chan/bytes 2/2/16 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /LAR/Identifier/CalibIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/1520148 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/Identifier/FebRodMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/6100 ((     0.01 ))s
+IOVDbFolder                                          INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/1 objs/chan/bytes 1/1/780292 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /LAR/NoiseOfl/CellNoise (AttrListColl) db-read 1/1 objs/chan/bytes 6/6/4379568 ((     0.05 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/CES (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/109620 ((     0.05 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/CIS/FIT/LIN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/80 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/CIS/FIT/NLN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/80 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/EMS (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/92 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/LAS/FIBER (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/940 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/LAS/LIN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/72 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/CALIB/LAS/NLN (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/76 ((     0.03 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/NOISE/CELL (AttrListColl) db-read 1/1 objs/chan/bytes 1/1/414740 ((     0.04 ))s
+IOVDbFolder                                          INFO Folder /TILE/OFL02/NOISE/SAMPLE (AttrListColl) db-read 1/1 objs/chan/bytes 277/277/641600 ((     0.05 ))s
+IOVDbFolder                                          INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/DAC2uA (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/170 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/HVScaleCorr (PoolRefColl) db-read 1/1 objs/chan/bytes 12/12/1980 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/MphysOverMcal (PoolRefColl) db-read 1/1 objs/chan/bytes 3/3/516 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/Ramp (PoolRefColl) db-read 1/1 objs/chan/bytes 3/3/489 ((     0.02 ))s
+IOVDbFolder                                          INFO Folder /LAR/ElecCalibMC/uA2MeV (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/165 ((     0.02 ))s
+IOVDbSvc                                             INFO  bytes in ((      0.66 ))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: 11 ReadTime: ((     0.28 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_TILE/OFLP200 : nConnect: 2 nFolders: 9 ReadTime: ((     0.31 ))s
+IOVDbSvc                                             INFO Connection COOLOFL_CALO/OFLP200 : nConnect: 2 nFolders: 2 ReadTime: ((     0.07 ))s
+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= 0.83  [s] Ave/Min/Max=  0.0377(+-   0.134)/       0/    0.64  [s] #= 22
+cObj_ALL                                             INFO Time User   : Tot= 1.05  [s] Ave/Min/Max=  0.0477(+-   0.144)/       0/    0.67  [s] #= 22
+ChronoStatSvc                                        INFO Time User   : Tot= 50.2  [s]  #=  1
+*****Chrono*****                                     INFO ****************************************************************************************************
+ChronoStatSvc.finalize()                             INFO  Service finalized successfully 
+ApplicationMgr                                       INFO Application Manager Finalized successfully
+ApplicationMgr                                       INFO Application Manager Terminated successfully
diff --git a/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthWithTrigT1Calo.py b/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthWithTrigT1Calo.py
index cadae1f573992a8478b65ab7bea30487d3c94ec2..49bd812c5fa71185494cb358cbc1c466de60d3f1 100755
--- a/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthWithTrigT1Calo.py
+++ b/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthWithTrigT1Calo.py
@@ -75,8 +75,7 @@ TriggerFlags.doID   = False
 TriggerFlags.doCalo = True
 TriggerFlags.doMuon = False
 
-TriggerFlags.doLVL2 = False
-TriggerFlags.doEF   = False
+TriggerFlags.doHLT = False
 
 
 # if needed to configure AOD building
diff --git a/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthv13WithTrigT1Calo.py b/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthv13WithTrigT1Calo.py
index 827ad87d181af6654468a3603d9580e52f182685..579a5225311d786107801fe5c26fffc7d91a347d 100755
--- a/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthv13WithTrigT1Calo.py
+++ b/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthv13WithTrigT1Calo.py
@@ -33,7 +33,6 @@ TriggerFlags.doID   = False
 TriggerFlags.doCalo = True
 TriggerFlags.doMuon = False
 
-TriggerFlags.doLVL2 = False
-TriggerFlags.doEF   = False
+TriggerFlags.doHLT   = False
 
 include ( "FastCaloSim/FastCaloSimFromTruthv13.py" )
diff --git a/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthv14WithTrigT1Calo.py b/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthv14WithTrigT1Calo.py
index 48a86649efec57af63144a4769b0497b5d1b16e7..758e4c5c05b48c7acfa54d52e252035d0304fc23 100644
--- a/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthv14WithTrigT1Calo.py
+++ b/Simulation/FastShower/FastCaloSim/share/FastCaloSimFromTruthv14WithTrigT1Calo.py
@@ -33,7 +33,6 @@ TriggerFlags.doID   = False
 TriggerFlags.doCalo = True
 TriggerFlags.doMuon = False
 
-TriggerFlags.doLVL2 = False
-TriggerFlags.doEF   = False
+TriggerFlags.doHLT   = False
 
 include ( "FastCaloSim/FastCaloSimFromTruthv14.py" )
diff --git a/Simulation/FastSimulation/FastChainPileup/src/MultiParticleGunPileup.cxx b/Simulation/FastSimulation/FastChainPileup/src/MultiParticleGunPileup.cxx
index 09bcbe38e5bb615c1f6d813adaad973a74061327..049e5f0c8e95e29af0c03dfa024426e08e577c6a 100644
--- a/Simulation/FastSimulation/FastChainPileup/src/MultiParticleGunPileup.cxx
+++ b/Simulation/FastSimulation/FastChainPileup/src/MultiParticleGunPileup.cxx
@@ -138,7 +138,7 @@ StatusCode MultiParticleGunPileup::callGenerator() {
 
       // change the process ID to incorporate the BCID * 10000
       int pid=HepMC::signal_process_id(evt);
-      evt->set_signal_process_id(pid+10000*bcid);
+      HepMC::set_signal_process_id(evt,pid+10000*bcid);
       ATH_MSG_DEBUG("Signal process ID " << pid << " set to " <<
 		    HepMC::signal_process_id(evt) << " for BCID " << bcid);
       m_evts.push_back(evt);
diff --git a/Simulation/FastSimulation/FastChainPileup/src/MultiPy8Pileup.cxx b/Simulation/FastSimulation/FastChainPileup/src/MultiPy8Pileup.cxx
index 6e00ebcf27b49f63d14250a6d89206ede3d4d96e..dde8ab93aa6e35cf623511d0bbcc64d33259bd06 100644
--- a/Simulation/FastSimulation/FastChainPileup/src/MultiPy8Pileup.cxx
+++ b/Simulation/FastSimulation/FastChainPileup/src/MultiPy8Pileup.cxx
@@ -107,7 +107,7 @@ StatusCode MultiPy8Pileup::callGenerator() {
 	if (Pythia8_i::fillEvt(evt)==StatusCode::SUCCESS) {
 	  // change the process ID to incorporate the BCID * 10000
 	  int pid=HepMC::signal_process_id(evt);
-	  evt->set_signal_process_id(pid+10000*bcid);
+	  HepMC::set_signal_process_id(evt,pid+10000*bcid);
 	  ATH_MSG_DEBUG("Signal process ID " << pid << " set to " <<
 			HepMC::signal_process_id(evt) << " for BCID " << bcid);
 	  m_evts.push_back(evt);
diff --git a/Simulation/G4Utilities/G4PhysicsLists/src/FTFP_BERT_ATL.hh b/Simulation/G4Utilities/G4PhysicsLists/src/FTFP_BERT_ATL.hh
deleted file mode 100644
index af02d838795574ea47298428a160044bce411d39..0000000000000000000000000000000000000000
--- a/Simulation/G4Utilities/G4PhysicsLists/src/FTFP_BERT_ATL.hh
+++ /dev/null
@@ -1,66 +0,0 @@
-//
-// ********************************************************************
-// * License and Disclaimer                                           *
-// *                                                                  *
-// * The  Geant4 software  is  copyright of the Copyright Holders  of *
-// * the Geant4 Collaboration.  It is provided  under  the terms  and *
-// * conditions of the Geant4 Software License,  included in the file *
-// * LICENSE and available at  http://cern.ch/geant4/license .  These *
-// * include a list of copyright holders.                             *
-// *                                                                  *
-// * Neither the authors of this software system, nor their employing *
-// * institutes,nor the agencies providing financial support for this *
-// * work  make  any representation or  warranty, express or implied, *
-// * regarding  this  software system or assume any liability for its *
-// * use.  Please see the license in the file  LICENSE  and URL above *
-// * for the full disclaimer and the limitation of liability.         *
-// *                                                                  *
-// * This  code  implementation is the result of  the  scientific and *
-// * technical work of the GEANT4 collaboration.                      *
-// * By using,  copying,  modifying or  distributing the software (or *
-// * any work based  on the software)  you  agree  to acknowledge its *
-// * use  in  resulting  scientific  publications,  and indicate your *
-// * acceptance of all terms of the Geant4 Software license.          *
-// ********************************************************************
-//
-// $Id$
-//
-//---------------------------------------------------------------------------
-// Author: Alberto Ribon
-// Date:   April 2016
-//
-// New physics list FTFP_BERT_ATL.
-// This is a modified version of the FTFP_BERT physics list for ATLAS.
-// The physics list FTFP_BERT_ATL has the transition between Bertini (BERT)
-// intra-nuclear cascade model and Fritiof (FTF) string model in the
-// energy region [9, 12] GeV (instead of [4, 5] GeV as in FTFP_BERT).
-//----------------------------------------------------------------------------
-//
-#ifndef TFTFP_BERT_ATL_h
-#define TFTFP_BERT_ATL_h 1
-
-#include <CLHEP/Units/SystemOfUnits.h>
-
-#include "globals.hh"
-#include "G4VModularPhysicsList.hh"
-#include "CompileTimeConstraints.hh"
-
-template<class T>
-class TFTFP_BERT_ATL: public T
-{
-public:
-  TFTFP_BERT_ATL(G4int ver = 1);
-  virtual ~TFTFP_BERT_ATL();
-  
-public:
-  // SetCuts() 
-  virtual void SetCuts();
-
-private:
-  enum {ok = CompileTimeConstraints::IsA<T, G4VModularPhysicsList>::ok };
-};
-#include "FTFP_BERT_ATL.icc"
-typedef TFTFP_BERT_ATL<G4VModularPhysicsList> FTFP_BERT_ATL;
-
-#endif
-
diff --git a/Simulation/G4Utilities/G4PhysicsLists/src/FTFP_BERT_ATL.icc b/Simulation/G4Utilities/G4PhysicsLists/src/FTFP_BERT_ATL.icc
deleted file mode 100644
index 7fd7cc8c33bfa7bccada7ad098d403ca0d37a5ab..0000000000000000000000000000000000000000
--- a/Simulation/G4Utilities/G4PhysicsLists/src/FTFP_BERT_ATL.icc
+++ /dev/null
@@ -1,111 +0,0 @@
-//
-// ********************************************************************
-// * License and Disclaimer                                           *
-// *                                                                  *
-// * The  Geant4 software  is  copyright of the Copyright Holders  of *
-// * the Geant4 Collaboration.  It is provided  under  the terms  and *
-// * conditions of the Geant4 Software License,  included in the file *
-// * LICENSE and available at  http://cern.ch/geant4/license .  These *
-// * include a list of copyright holders.                             *
-// *                                                                  *
-// * Neither the authors of this software system, nor their employing *
-// * institutes,nor the agencies providing financial support for this *
-// * work  make  any representation or  warranty, express or implied, *
-// * regarding  this  software system or assume any liability for its *
-// * use.  Please see the license in the file  LICENSE  and URL above *
-// * for the full disclaimer and the limitation of liability.         *
-// *                                                                  *
-// * This  code  implementation is the result of  the  scientific and *
-// * technical work of the GEANT4 collaboration.                      *
-// * By using,  copying,  modifying or  distributing the software (or *
-// * any work based  on the software)  you  agree  to acknowledge its *
-// * use  in  resulting  scientific  publications,  and indicate your *
-// * acceptance of all terms of the Geant4 Software license.          *
-// ********************************************************************
-//
-// $Id$
-//
-//---------------------------------------------------------------------------
-// Author: Alberto Ribon
-// Date:   April 2016
-//
-// New physics list FTFP_BERT_ATL.
-// This is a modified version of the FTFP_BERT physics list for ATLAS.
-// The physics list FTFP_BERT_ATL has the transition between Bertini (BERT)
-// intra-nuclear cascade model and Fritiof (FTF) string model in the
-// energy region [9, 12] GeV (instead of [4, 5] GeV as in FTFP_BERT).
-//----------------------------------------------------------------------------
-//
-#include <iomanip>   
-
-#include "globals.hh"
-#include "G4ios.hh"
-#include "G4ProcessManager.hh"
-#include "G4ProcessVector.hh"
-#include "G4ParticleTypes.hh"
-#include "G4ParticleTable.hh"
-
-#include "G4Material.hh"
-#include "G4MaterialTable.hh"
-
-#include "G4DecayPhysics.hh"
-#include "G4EmStandardPhysics.hh"
-#include "G4EmExtraPhysics.hh"
-#include "G4IonPhysics.hh"
-#include "G4StoppingPhysics.hh"
-#include "G4HadronElasticPhysics.hh"
-#include "G4NeutronTrackingCut.hh"
-
-#include "G4HadronPhysicsFTFP_BERT_ATL.hh"
-
-template<class T> TFTFP_BERT_ATL<T>::TFTFP_BERT_ATL(G4int ver):  T()
-{
-  // default cut value  (1.0mm) 
-  // defaultCutValue = 1.0*CLHEP::mm;
-  G4cout << "<<< Geant4 Physics List simulation engine: FTFP_BERT_ATL 2.0"<<G4endl;
-  G4cout <<G4endl;
-  this->defaultCutValue = 0.7*CLHEP::mm;  
-  this->SetVerboseLevel(ver);
-
- // EM Physics
-  this->RegisterPhysics( new G4EmStandardPhysics(ver));
-
-  // Synchroton Radiation & GN Physics
-  this->RegisterPhysics( new G4EmExtraPhysics(ver) );
-
-  // Decays 
-  this->RegisterPhysics( new G4DecayPhysics(ver) );
-
-   // Hadron Elastic scattering
-  this->RegisterPhysics( new G4HadronElasticPhysics(ver) );
-
-   // Hadron Physics
-  this->RegisterPhysics(  new G4HadronPhysicsFTFP_BERT_ATL(ver));
-
-  // Stopping Physics
-  this->RegisterPhysics( new G4StoppingPhysics(ver) );
-
-  // Ion Physics
-  this->RegisterPhysics( new G4IonPhysics(ver));
-  
-  // Neutron tracking cut
-  this->RegisterPhysics( new G4NeutronTrackingCut(ver));
-}
-
-template<class T> TFTFP_BERT_ATL<T>::~TFTFP_BERT_ATL()
-{
-}
-
-template<class T> void TFTFP_BERT_ATL<T>::SetCuts()
-{
-  if (this->verboseLevel >1){
-    G4cout << "FTFP_BERT_ATL::SetCuts:";
-  }  
-  //  " G4VUserPhysicsList::SetCutsWithDefault" method sets 
-  //   the default cut value for all particle types 
-
-  this->SetCutsWithDefault();   
- 
-//  if (this->verboseLevel > 0)
-//    G4VUserPhysicsList::DumpCutValuesTable();  
-}
diff --git a/Simulation/G4Utilities/MCTruthSimAlgs/src/NewMergeMcEventCollTool.cxx b/Simulation/G4Utilities/MCTruthSimAlgs/src/NewMergeMcEventCollTool.cxx
index 3c3871c34a6c15ae2a7d484add40fe28644982ff..e5db164ce0fc68fbc0651474363deb9fb1a49081 100644
--- a/Simulation/G4Utilities/MCTruthSimAlgs/src/NewMergeMcEventCollTool.cxx
+++ b/Simulation/G4Utilities/MCTruthSimAlgs/src/NewMergeMcEventCollTool.cxx
@@ -127,12 +127,21 @@ StatusCode NewMergeMcEventCollTool::processEvent(const McEventCollection *pMcEvt
   if (!pMcEvtColl->empty()) {
     for (unsigned int iEv=0; iEv<pMcEvtColl->size(); iEv++) {
       const HepMC::GenEvent& c_evt(*((*pMcEvtColl)[iEv]));
+#ifdef HEPMC3
+      HepMC::GenEvent * evt = new HepMC::GenEvent(c_evt);
+      for (auto  itVer:  evt->vertice()) {
+        HepMC::FourVector newPos(itVer->position().x(),itVer->position().y(),itVer->position().z(),itVer->position().t()+timeOffset);
+        itVer->set_position(newPos);
+      }
+      outputMcEventCollection->push_back(evt);
+#else
       HepMC::GenEvent * evt = new HepMC::GenEvent(c_evt);
       for (HepMC::GenEvent::vertex_iterator itVer=evt->vertices_begin(); itVer!=evt->vertices_end(); ++itVer) {
         HepMC::FourVector newPos((*itVer)->position().x(),(*itVer)->position().y(),(*itVer)->position().z(),(*itVer)->position().t()+timeOffset);
         (*itVer)->set_position(newPos);
       }
       outputMcEventCollection->push_back(evt);
+#endif
     }
   }
   return StatusCode::SUCCESS;
@@ -149,11 +158,15 @@ void NewMergeMcEventCollTool::printDetailsOfMergedMcEventCollection(McEventColle
   while(outputEventItr!=endOfEvents) {
     const int signal_process_id(HepMC::signal_process_id((*outputEventItr)));
     const int event_number((*outputEventItr)->event_number());
+#ifdef HEPMC3
+    ATH_MSG_INFO ( "GenEvent #"<<event_number<<", signal_process_id="<<signal_process_id<</*", category="<<event->second<<*/", number of Vertices="<<(*outputEventItr)->vertices().size() );
+#else
     ATH_MSG_INFO ( "GenEvent #"<<event_number<<", signal_process_id="<<signal_process_id<</*", category="<<event->second<<*/", number of Vertices="<<(*outputEventItr)->vertices_size() );
+#endif
     char fname[80];
     sprintf(fname,"%s.event%d.txt",m_truthCollInputKey.value().c_str(),event_number);
     std::ofstream of(fname);
-    (*outputEventItr)->print(of); // verbose output
+    HepMC::Print::line(of,(*outputEventItr)); // verbose output
     of.close();
     ++outputEventItr;
   }
diff --git a/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimParametrization/src/FastCaloSimParamAlg.cxx b/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimParametrization/src/FastCaloSimParamAlg.cxx
index f5788d0a8f03ecb6200f012d4d7e6479dc772f75..1d518a44c24274526139961bafbc0c6d69707207 100755
--- a/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimParametrization/src/FastCaloSimParamAlg.cxx
+++ b/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimParametrization/src/FastCaloSimParamAlg.cxx
@@ -14,18 +14,11 @@
 #include <sstream>
 #include <map>
 
-// local include(s):
-//#include "LArG4Code/EnergySpot.h"
-//#include "LArG4ShowerLib/Shower.h"
-//#include "LArG4ShowerLib/ShowerLibList.h"
-
 #include "ISF_FastCaloSimEvent/FCS_StepInfo.h"
 #include "ISF_FastCaloSimEvent/FCS_StepInfoCollection.h"
 
 // athena includes
 #include "GeoModelInterfaces/IGeoModelSvc.h"
-#include "EventInfo/TagInfo.h"
-
 
 #include "CaloIdentifier/CaloCell_ID.h"
 #include "CaloGeoHelpers/CaloSampling.h"
diff --git a/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimSD/CMakeLists.txt b/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimSD/CMakeLists.txt
index 1853b41a02f7ad644467b40741891f3a9ec188eb..4ec076a55f929800e4d12274f7cf7904af2358bf 100644
--- a/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimSD/CMakeLists.txt
+++ b/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimSD/CMakeLists.txt
@@ -19,5 +19,5 @@ atlas_add_component( ISF_FastCaloSimSD
                      LINK_LIBRARIES ${ROOT_LIBRARIES} ${XERCESC_LIBRARIES} ${GEANT4_LIBRARIES} ${CLHEP_LIBRARIES} StoreGateLib SGtests GaudiKernel G4AtlasInterfaces G4AtlasToolsLib CaloDetDescrLib CaloIdentifier GeneratorObjects LArG4Code ISF_FastCaloSimEvent Identifier TileG4InterfacesLib )
 
 # Install files from the package:
-atlas_install_python_modules( python/*.py )
+atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 
diff --git a/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimServices/CMakeLists.txt b/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimServices/CMakeLists.txt
index 38f60d7b5de766c8abba229b1f5349655a26983e..f0e196d732163a517514e30aba88b3021caa42fd 100644
--- a/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimServices/CMakeLists.txt
+++ b/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimServices/CMakeLists.txt
@@ -17,7 +17,7 @@ atlas_add_component( ISF_FastCaloSimServices
                      LINK_LIBRARIES ${CLHEP_LIBRARIES} AtlasHepMCLib ${LWTNN_LIBRARIES} AthenaBaseComps AthenaKernel GaudiKernel IdDictParser ISF_InterfacesLib TrkEventPrimitives TrkExInterfaces CaloEvent StoreGateLib SGtests NavFourMom GeneratorObjects FastCaloSimLib ISF_Event ISF_FastCaloSimEvent ISF_FastCaloSimInterfaces ISF_FastCaloSimParametrizationLib PathResolver)
 
 # Install files from the package:
-atlas_install_python_modules( python/*.py )
+atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
 
 atlas_add_test( ISF_FastCaloSimServices_Config_test
                 SCRIPT test/FastCaloSimServices_test.py)
\ No newline at end of file
diff --git a/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimServices/python/AdditionalConfig.py b/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimServices/python/AdditionalConfig.py
index b3377782370c9d963c60001b53ebbdf96b8dc58b..e28f360523a822b06f5ee6ec00350c1a22206763 100644
--- a/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimServices/python/AdditionalConfig.py
+++ b/Simulation/ISF/ISF_FastCaloSim/ISF_FastCaloSimServices/python/AdditionalConfig.py
@@ -5,17 +5,10 @@ Tools configurations for ISF_FastCaloSimServices
 KG Tan, 04/12/2012
 """
 
-from AthenaCommon.CfgGetter import getPrivateTool,getPrivateToolClone,getPublicTool,getPublicToolClone,\
-        getService,getServiceClone,getAlgorithm,getAlgorithmClone
-
+from AthenaCommon.CfgGetter import getService
 from AthenaCommon import CfgMgr
-from AthenaCommon.Constants import *  # FATAL,ERROR etc.
-from AthenaCommon.SystemOfUnits import *
-from AthenaCommon.DetFlags import DetFlags
 
-from ISF_Config.ISF_jobProperties import ISF_Flags # IMPORTANT: Flags must be set before tools are retrieved
 from ISF_FastCaloSimServices.ISF_FastCaloSimJobProperties import ISF_FastCaloSimFlags
-
 from ISF_Algorithms.collection_merger_helpers import generate_mergeable_collection_name
 
 
diff --git a/Simulation/ISF/ISF_Fatras/ISF_FatrasRecoTools/ISF_FatrasRecoTools/ISF_TrackSummaryHelperTool.h b/Simulation/ISF/ISF_Fatras/ISF_FatrasRecoTools/ISF_FatrasRecoTools/ISF_TrackSummaryHelperTool.h
index f1478e30d46c23998fead8b51a9a6778473d54f4..dc4609482708b3ac794c85d128e9d14715de14e0 100644
--- a/Simulation/ISF/ISF_Fatras/ISF_FatrasRecoTools/ISF_FatrasRecoTools/ISF_TrackSummaryHelperTool.h
+++ b/Simulation/ISF/ISF_Fatras/ISF_FatrasRecoTools/ISF_FatrasRecoTools/ISF_TrackSummaryHelperTool.h
@@ -46,76 +46,55 @@ namespace iFatras {
     */
     using IExtendedTrackSummaryHelperTool::analyse;
     using IExtendedTrackSummaryHelperTool::updateSharedHitCount;
-    virtual void analyse(const Trk::Track& track,
-                         const Trk::PRDtoTrackMap *prd_to_track_map,
-                         const Trk::RIO_OnTrack* rot,
-                         const Trk::TrackStateOnSurface* tsos,
-                         std::vector<int>& information,
-                         std::bitset<Trk::numberOfDetectorTypes>& hitPattern ) const override;
-
-    virtual void analyse(const Trk::Track& track,
-                         const Trk::PRDtoTrackMap *prd_to_track_map,
-                         const Trk::CompetingRIOsOnTrack* crot,
-                         const Trk::TrackStateOnSurface* tsos,
-                         std::vector<int>& information,
-                         std::bitset<Trk::numberOfDetectorTypes>& hitPattern ) const override;
-
-    /** Input : rot, tsos
-	Output: Changes in information and hitPattern
-	Input: quantities rot, tsos are used to increment the counts for hits and outliers in information and to set the proper bits inhitPattern.
-    */
-    virtual void analyse(const Trk::Track& track,
-			 const Trk::RIO_OnTrack* rot,
-			 const Trk::TrackStateOnSurface* tsos,
-			 std::vector<int>& information,
-			 std::bitset<Trk::numberOfDetectorTypes>& hitPattern ) const override
-    {
-      analyse(track,nullptr,rot,tsos,information,hitPattern);
-    }
+    using IExtendedTrackSummaryHelperTool::addDetailedTrackSummary;
+    virtual void analyse(
+      const EventContext& ctx,
+      const Trk::Track& track,
+      const Trk::PRDtoTrackMap* prd_to_track_map,
+      const Trk::RIO_OnTrack* rot,
+      const Trk::TrackStateOnSurface* tsos,
+      std::vector<int>& information,
+      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override final;
 
     /** Not used --> running with RIO_OnTrack only
-    */
-    virtual void analyse(const Trk::Track& track,
-			 const Trk::CompetingRIOsOnTrack* crot,
-			 const Trk::TrackStateOnSurface* tsos,
-			 std::vector<int>& information,
-			 std::bitset<Trk::numberOfDetectorTypes>& hitPattern ) const override
-    {
-      analyse(track,nullptr, crot,tsos,information,hitPattern);
-    }
+     */
+    virtual void analyse(
+      const Trk::Track& track,
+      const Trk::CompetingRIOsOnTrack* crot,
+      const Trk::TrackStateOnSurface* tsos,
+      std::vector<int>& information,
+      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override final;
 
     /** Not used --> HoleSearchTool not used
-    */
-    virtual
-    void searchForHoles(const Trk::Track& track,
-			std::vector<int>& information ,
-			const Trk::ParticleHypothesis partHyp = Trk::pion) const override;
+     */
+    virtual void searchForHoles(
+      const Trk::Track& track,
+      std::vector<int>& information,
+      const Trk::ParticleHypothesis partHyp = Trk::pion) const override final;
 
-      /** this method simply updaes the shared hit content - it is designed/optimised for track collection merging */
-    virtual void updateSharedHitCount(const Trk::Track& track,
-                                      const Trk::PRDtoTrackMap *prd_to_track_map,
-                                      Trk::TrackSummary& summary) const override;
-
-  /** this method simply updaes the shared hit content - it is designed/optimised for track collection merging */
-    virtual
-    void updateSharedHitCount(const Trk::Track& /*track*/,
-                              Trk::TrackSummary& /*summary*/) const override
-    {
-      ATH_MSG_DEBUG("updateSharedHitCount not implemented !!");
-    }
+    /** this method simply updaes the shared hit content - it is
+     * designed/optimised for track collection merging */
+    virtual void updateSharedHitCount(
+      const Trk::Track& track,
+      const Trk::PRDtoTrackMap* prd_to_track_map,
+      Trk::TrackSummary& summary) const override final;
 
     /** this method simply updaes the electron PID content - it is designed/optimised for track collection merging */
-    virtual
-    void updateAdditionalInfo(Trk::TrackSummary& summary,std::vector<float>& eprob,float& dedx, int& nclus, int& noverflowclus) const override;
+    virtual void updateAdditionalInfo(Trk::TrackSummary& summary,
+                                      std::vector<float>& eprob,
+                                      float& dedx,
+                                      int& nclus,
+                                      int& noverflowclus) const override final;
     /** This method updates the expect... hit info*/
-    virtual
-    void updateExpectedHitInfo(const Trk::Track& track, Trk::TrackSummary& summary) const override;
-    
+    virtual void updateExpectedHitInfo(
+      const Trk::Track& track,
+      Trk::TrackSummary& summary) const override final;
+
     /** @copydoc Trk::ITrackSummaryHelperTool::addDetailedTrackSummary(const Trk::Track&, Trk::TrackSummary&)*/
-    
-    virtual void addDetailedTrackSummary(const Trk::Track&, Trk::TrackSummary&) const override;
-    
-    
+
+    virtual void addDetailedTrackSummary(const Trk::Track&,
+                                         Trk::TrackSummary&) const override final;
+
   private:
 
     inline
diff --git a/Simulation/ISF/ISF_Fatras/ISF_FatrasRecoTools/src/ISF_TrackSummaryHelperTool.cxx b/Simulation/ISF/ISF_Fatras/ISF_FatrasRecoTools/src/ISF_TrackSummaryHelperTool.cxx
index 4190d8771d8f69f649cc011d9ff7ae3a077ad702..f0ac78edac983b2c5996049fd7456685a23fe1bf 100644
--- a/Simulation/ISF/ISF_Fatras/ISF_FatrasRecoTools/src/ISF_TrackSummaryHelperTool.cxx
+++ b/Simulation/ISF/ISF_Fatras/ISF_FatrasRecoTools/src/ISF_TrackSummaryHelperTool.cxx
@@ -23,7 +23,7 @@ iFatras::ISF_TrackSummaryHelperTool::ISF_TrackSummaryHelperTool(const std::strin
   base_class(t,n,p),
   m_pixelId(0),
   m_sctId(0),
-  m_assoTool("iFatras::ISF_PRD_AssociationTool"), 
+  m_assoTool("iFatras::ISF_PRD_AssociationTool"),
   m_doSharedHits(false)
 {
   declareProperty("AssoTool",            m_assoTool);
@@ -31,7 +31,7 @@ iFatras::ISF_TrackSummaryHelperTool::ISF_TrackSummaryHelperTool(const std::strin
   declareProperty("usePixel",            m_usePixel = true);
   declareProperty("useSCT",              m_useSCT   = true);
   declareProperty("OverwriteIDSummary",  m_overwriteidsummary = false);
-} 
+}
 
 //==========================================================================
 
@@ -47,14 +47,14 @@ StatusCode iFatras::ISF_TrackSummaryHelperTool::initialize()
       return StatusCode::FAILURE;
     } else msg(MSG::VERBOSE) << "PixelID helper retrieved successfully!" << endmsg;
   }
-  
+
   if (m_useSCT) {
     if (detStore()->retrieve(m_sctId, "SCT_ID").isFailure()) {
       msg(MSG::ERROR) << "Could not get SCT_ID helper !" << endmsg;
       return StatusCode::FAILURE;
     } else msg(MSG::VERBOSE) << "PixelID helper retrieved successfully!" << endmsg;
   }
-  
+
   ATH_CHECK(m_assoTool.retrieve(DisableTool{!m_doSharedHits || m_assoTool.empty() } ) );
 
   msg(MSG::INFO) << "initialize() successful in " << name() << endmsg;
@@ -64,25 +64,28 @@ StatusCode iFatras::ISF_TrackSummaryHelperTool::initialize()
 
 //==========================================================================
 
-void iFatras::ISF_TrackSummaryHelperTool::analyse(const Trk::Track& track,
-                                                  const Trk::PRDtoTrackMap *prd_to_track_map,
-						  const Trk::RIO_OnTrack* rot,
-						  const Trk::TrackStateOnSurface* tsos,
-						  std::vector<int>& information,
-						  std::bitset<Trk::numberOfDetectorTypes>& hitPattern ) const
+void
+iFatras::ISF_TrackSummaryHelperTool::analyse(
+  const EventContext&,
+  const Trk::Track& track,
+  const Trk::PRDtoTrackMap* prd_to_track_map,
+  const Trk::RIO_OnTrack* rot,
+  const Trk::TrackStateOnSurface* tsos,
+  std::vector<int>& information,
+  std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const
 {
   const Identifier& id = rot->identify();
   bool  isOutlier      = (tsos->type(Trk::TrackStateOnSurface::Outlier));
   bool  ispatterntrack =  (track.info().trackFitter()==Trk::TrackInfo::Unknown);
-  
+
   if (msgLvl(MSG::DEBUG)) msg() << "Starting analyse()" << endmsg;
 
   if ( m_usePixel && m_pixelId->is_pixel(id) ) {
 
     if (msgLvl(MSG::DEBUG)) msg() << "Pixel hit found" << endmsg;
-    
+
     if (isOutlier && !ispatterntrack ) { // ME: outliers on pattern tracks may be reintegrated by fitter, so count them as hits
-      
+
       if (msgLvl(MSG::DEBUG)) msg() << "Pixel outlier info storing" << endmsg;
 
       information[Trk::numberOfPixelOutliers]++;
@@ -93,16 +96,16 @@ void iFatras::ISF_TrackSummaryHelperTool::analyse(const Trk::Track& track,
 	information[Trk::numberOfNextToInnermostPixelLayerOutliers]++;
       }
     } else {
-      
+
       if (msgLvl(MSG::DEBUG)) msg() << "Pixel info storing" << endmsg;
 
       information[Trk::numberOfPixelHits]++;
       if (m_pixelId->layer_disk(id)==0 && m_pixelId->is_barrel(id)) information[Trk::numberOfInnermostPixelLayerHits]++;
-      if (m_pixelId->layer_disk(id)==1 && m_pixelId->is_barrel(id)) information[Trk::numberOfNextToInnermostPixelLayerHits]++;  
-      
+      if (m_pixelId->layer_disk(id)==1 && m_pixelId->is_barrel(id)) information[Trk::numberOfNextToInnermostPixelLayerHits]++;
+
       if ( ( m_pixelId->is_barrel(id) ) ) {
 	if (msgLvl(MSG::DEBUG)) msg() << "Barrel hit" << endmsg;
-	int offset = m_pixelId->layer_disk(id); 
+	int offset = m_pixelId->layer_disk(id);
 	if (!hitPattern.test(offset)) information[Trk::numberOfContribPixelLayers]++;
 	hitPattern.set(offset); // assumes numbered consecutively
       } else {
@@ -120,20 +123,20 @@ void iFatras::ISF_TrackSummaryHelperTool::analyse(const Trk::Track& track,
 	  information[Trk::numberOfPixelSharedHits]++;
 	  if ( (m_pixelId->is_barrel(id) && m_pixelId->layer_disk(id)==0) ) {
 	    if (msgLvl(MSG::DEBUG)) msg() << "--> shared Pixel hit is in innermost layer" << endmsg;
-	    information[Trk::numberOfInnermostPixelLayerSharedHits]++;        
-	  } 
+	    information[Trk::numberOfInnermostPixelLayerSharedHits]++;
+	  }
 	  if ( (m_pixelId->is_barrel(id) && m_pixelId->layer_disk(id)==1) ) {
 	    if (msgLvl(MSG::DEBUG)) msg() << "--> shared Pixel hit is in next to innermost layer" << endmsg;
-	    information[Trk::numberOfNextToInnermostPixelLayerSharedHits]++;        
+	    information[Trk::numberOfNextToInnermostPixelLayerSharedHits]++;
 	  }
 	} else ATH_MSG_DEBUG("shared Pixel hit NOT found");
       }
     }
   } else if (m_useSCT && m_sctId->is_sct(id) ) {
-    
+
     if (msgLvl(MSG::DEBUG)) msg() << "SCT hit found" << endmsg;
-    
-    if (isOutlier && !ispatterntrack ) { // ME: outliers on pattern tracks may be reintegrated by fitter, so count them as hits    
+
+    if (isOutlier && !ispatterntrack ) { // ME: outliers on pattern tracks may be reintegrated by fitter, so count them as hits
       if (msgLvl(MSG::DEBUG)) msg() << "SCT outlier info storing" << endmsg;
       information[Trk::numberOfSCTOutliers]++;
     } else {
@@ -164,18 +167,19 @@ void iFatras::ISF_TrackSummaryHelperTool::analyse(const Trk::Track& track,
       }
     }
   } else  ATH_MSG_WARNING("Nor Pixel or SCT used... Check!!");
-  
+
   return;
 }
-
-void iFatras::ISF_TrackSummaryHelperTool::analyse(const Trk::Track&,
-                                                  const Trk::PRDtoTrackMap *,
-						  const Trk::CompetingRIOsOnTrack*,
-						  const Trk::TrackStateOnSurface*,
-						  std::vector<int>&,
-						  std::bitset<Trk::numberOfDetectorTypes>&) const
+void
+iFatras::ISF_TrackSummaryHelperTool::analyse(
+  const Trk::Track&,
+  const Trk::CompetingRIOsOnTrack*,
+  const Trk::TrackStateOnSurface*,
+  std::vector<int>& ,
+  std::bitset<Trk::numberOfDetectorTypes>&) const
 {
-  ATH_MSG_DEBUG("analyse not implemented for Trk::CompetingRIOsOnTrack !!");
+
+  ATH_MSG_DEBUG("Analyze not implemented for Trk::CompetingRIOsOnTrack!!");
   return;
 }
 
diff --git a/Simulation/SimuJobTransforms/share/CommonSkeletonJobOptions.py b/Simulation/SimuJobTransforms/share/CommonSkeletonJobOptions.py
index f25b14d8815e7ec66e3f89d3a62688d2373bfc18..791a3031c5bdcd11f52723c528cce137d27dd870 100644
--- a/Simulation/SimuJobTransforms/share/CommonSkeletonJobOptions.py
+++ b/Simulation/SimuJobTransforms/share/CommonSkeletonJobOptions.py
@@ -37,10 +37,6 @@ if hasattr(runArgs,"beamType"):
 if hasattr(runArgs, "eventService") and runArgs.eventService:
     import AthenaMP.EventService
 
-# Disable this while MC still uses old alignment folders
-from AtlasGeoModel.InDetGMJobProperties import InDetGeometryFlags
-InDetGeometryFlags.useDynamicAlignFolders=False
-
 ## autoConfiguration keywords triggering pre-defined functions
 ## if hasattr(runArgs,"autoConfiguration"):
 ##     for key in runArgs.autoConfiguration:
diff --git a/TileCalorimeter/TileConditions/share/TileDCSComponents_test.ref b/TileCalorimeter/TileConditions/share/TileDCSComponents_test.ref
index 53b4bf5c998c81fd6044ccb6f4fd7fb5d07e7eb1..7da753cc374beb1c7603e4d44eaa4cae95a76dfe 100644
--- a/TileCalorimeter/TileConditions/share/TileDCSComponents_test.ref
+++ b/TileCalorimeter/TileConditions/share/TileDCSComponents_test.ref
@@ -1,21 +1,20 @@
 
 
 Initializing Gaudi ApplicationMgr using job opts jobOptions_TileDCSTest.txt
-JobOptionsSvc        INFO # =======> /home/sss/atlas/dvtest/build/../tests/jobOptions_TileDCSTest.txt
+JobOptionsSvc        INFO # =======> /tmp/mnowak/build/jobOptions_TileDCSTest.txt
 JobOptionsSvc        INFO # (1,1): ApplicationMgr.ExtSvc += ["StoreGateSvc/DetectorStore", "StoreGateSvc/ConditionStore"]
 JobOptionsSvc        INFO # (2,1): GeoModelSvc.SupportedGeometry = 21
 JobOptionsSvc        INFO # (3,1): GeoModelSvc.AtlasVersion = "ATLAS-R2-2016-01-00-01"
 JobOptionsSvc        INFO Job options successfully read in from jobOptions_TileDCSTest.txt
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v27r1p99)
-                                          running on karma on Mon Oct  1 13:23:29 2018
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on aibuild20-040.cern.ch on Wed Dec  2 17:39:01 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-ClassIDSvc           INFO  getRegistryEntries: read 5402 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 4742 CLIDRegistry entries for module ALL
 EventLoopMgr      WARNING Unable to locate service "EventSelector" 
 EventLoopMgr      WARNING No events will be processed from external input.
-HistogramPersis...WARNING Histograms saving not required.
 ApplicationMgr       INFO Application Manager Initialized successfully
 ApplicationMgr Ready
 TileHWID             INFO initialize_from_dictionary 
@@ -42,7 +41,7 @@ AtlasDetectorID      DEBUG Could not get value for label 'no_side' of field 'Det
 Test TileDCSState
 
 Test TileDCSCondAlg
-ClassIDSvc           INFO  getRegistryEntries: read 372 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 379 CLIDRegistry entries for module ALL
 TileDCSCondAlgTest   INFO Will read the following folders: /TILE/TEST/DCS/HV  /TILE/TEST/DCS/STATES
 DetDescrCnvSvc       INFO  initializing 
 DetDescrCnvSvc       INFO Found DetectorStore service
@@ -85,11 +84,14 @@ DetDescrCnvSvc       INFO  filling address for CaloCell_ID with CLID 123500438 a
 DetDescrCnvSvc       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
 DetDescrCnvSvc       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
 DetDescrCnvSvc       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
+TagInfoMgr           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
 GeoModelSvc::RD...WARNING  Getting PixTBMatComponents with default tag
 GeoModelSvc::RD...WARNING  Getting PixTBMaterials with default tag
 GeoModelSvc::RD...WARNING  Getting InDetMatComponents with default tag
 GeoModelSvc::RD...WARNING  Getting InDetMaterials with default tag
-GeoModelSvc       WARNING Cannot register compareTags function for key ProcessingTags
+IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
+ClassIDSvc           INFO  getRegistryEntries: read 1137 CLIDRegistry entries for module ALL
 TileCablingSvc       INFO RUN2 ATLAS geometry flag detected for geometry: ATLAS-R2-2016-01-00-01
 TileCablingSvc       INFO Setting RUN2 (2014-2017) cabling
 TileCablingSvc       INFO Setting Cabling type to 4
@@ -99,7 +101,7 @@ TileCablingSvc    WARNING Unable to retrieve TileDetDescrManager from DetectorSt
 TileCablingSvc    WARNING Will not set Tile online hash ID in CaloDetDescrElements
 TileDCSCondAlgTest   INFO Will read the following folders: /TILE/TEST/DCS/HV  /TILE/TEST/DCS/STATES
 Tile cabling type: 5
-ClassIDSvc           INFO  getRegistryEntries: read 2528 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 1878 CLIDRegistry entries for module ALL
 FOLDER [{[536870911,l:536870911] - [2147483647,l:2147483647]}]: 
 min range: {[0,0] - [2147483647,4294967295]}
 chan, attr: 15
diff --git a/TileCalorimeter/TileConditions/share/TileEMScaleComponents_test.ref b/TileCalorimeter/TileConditions/share/TileEMScaleComponents_test.ref
index 6321e11545b514454b0649ce05b50054fd9a2529..1cd39ddbc62be2755f463db853b008a75fb32046 100644
--- a/TileCalorimeter/TileConditions/share/TileEMScaleComponents_test.ref
+++ b/TileCalorimeter/TileConditions/share/TileEMScaleComponents_test.ref
@@ -1,21 +1,20 @@
 
 
 Initializing Gaudi ApplicationMgr using job opts jobOptions_TileCalibEmsTest.txt
-JobOptionsSvc        INFO # =======> /home/harkusha/bad_chan/build/TileCalorimeter/TileConditions/CMakeFiles/unitTestRun/jobOptions_TileCalibEmsTest.txt
+JobOptionsSvc        INFO # =======> /tmp/mnowak/build/jobOptions_TileCalibEmsTest.txt
 JobOptionsSvc        INFO # (1,1): ApplicationMgr.ExtSvc += ["StoreGateSvc/DetectorStore", "StoreGateSvc/ConditionStore"]
 JobOptionsSvc        INFO # (2,1): GeoModelSvc.SupportedGeometry = 21
 JobOptionsSvc        INFO # (3,1): GeoModelSvc.AtlasVersion = "ATLAS-R2-2016-01-00-01"
 JobOptionsSvc        INFO Job options successfully read in from jobOptions_TileCalibEmsTest.txt
 ApplicationMgr    SUCCESS 
 ====================================================================================================================================
-                                                   Welcome to ApplicationMgr (GaudiCoreSvc v32r0)
-                                          running on pcatltiltb08.cern.ch on Fri Jun 21 02:21:24 2019
+                                                   Welcome to ApplicationMgr (GaudiCoreSvc v35r0p1)
+                                          running on aibuild20-040.cern.ch on Wed Dec  2 17:23:34 2020
 ====================================================================================================================================
 ApplicationMgr       INFO Application Manager Configured successfully
-ClassIDSvc           INFO  getRegistryEntries: read 4904 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 4740 CLIDRegistry entries for module ALL
 EventLoopMgr      WARNING Unable to locate service "EventSelector" 
 EventLoopMgr      WARNING No events will be processed from external input.
-HistogramPersis...WARNING Histograms saving not required.
 ApplicationMgr       INFO Application Manager Initialized successfully
 ApplicationMgr Ready
 TileHWID             INFO initialize_from_dictionary 
@@ -55,7 +54,7 @@ OFL EMS: 1.0001
 
 
 Test TileCalibEmsCondAlg
-ClassIDSvc           INFO  getRegistryEntries: read 372 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 379 CLIDRegistry entries for module ALL
 DetDescrCnvSvc       INFO  initializing 
 DetDescrCnvSvc       INFO Found DetectorStore service
 DetDescrCnvSvc       INFO  filling proxies for detector managers 
@@ -97,11 +96,14 @@ DetDescrCnvSvc       INFO  filling address for CaloCell_ID with CLID 123500438 a
 DetDescrCnvSvc       INFO  filling address for CaloCell_SuperCell_ID with CLID 128365736 and storage type 68 to detector store 
 DetDescrCnvSvc       INFO  filling address for CaloDM_ID with CLID 167756483 and storage type 68 to detector store 
 DetDescrCnvSvc       INFO  filling address for ZdcID with CLID 190591643 and storage type 68 to detector store 
+TagInfoMgr           INFO   AlgTool: TagInfoMgr.IOVDbMetaDataTool
 GeoModelSvc::RD...WARNING  Getting PixTBMatComponents with default tag
 GeoModelSvc::RD...WARNING  Getting PixTBMaterials with default tag
 GeoModelSvc::RD...WARNING  Getting InDetMatComponents with default tag
 GeoModelSvc::RD...WARNING  Getting InDetMaterials with default tag
-GeoModelSvc       WARNING Cannot register compareTags function for key ProcessingTags
+IOVSvc               INFO No IOVSvcTool associated with store "StoreGateSvc"
+IOVSvc.IOVSvcTool    INFO IOVRanges will be checked at every Event
+ClassIDSvc           INFO  getRegistryEntries: read 1137 CLIDRegistry entries for module ALL
 TileCablingSvc       INFO RUN2 ATLAS geometry flag detected for geometry: ATLAS-R2-2016-01-00-01
 TileCablingSvc       INFO Setting RUN2 (2014-2017) cabling
 TileCablingSvc       INFO Setting Cabling type to 4
@@ -110,6 +112,6 @@ DetectorStore     WARNING retrieve(default): No valid proxy for default object
 TileCablingSvc    WARNING Unable to retrieve TileDetDescrManager from DetectorStore
 TileCablingSvc    WARNING Will not set Tile online hash ID in CaloDetDescrElements
 TileCalibEmsCon...   INFO ProxyOflLasFib is not set up and cannot be used
-ClassIDSvc           INFO  getRegistryEntries: read 2980 CLIDRegistry entries for module ALL
+ClassIDSvc           INFO  getRegistryEntries: read 1878 CLIDRegistry entries for module ALL
 
 Test TileCondToolEmscale
diff --git a/Tools/OnlineRecoTests/CMakeLists.txt b/Tools/OnlineRecoTests/CMakeLists.txt
deleted file mode 100644
index c988ddb57288397be7e594c04542fd535dcdf430..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/CMakeLists.txt
+++ /dev/null
@@ -1,14 +0,0 @@
-################################################################################
-# Package: OnlineRecoTests
-################################################################################
-
-# Declare the package name:
-atlas_subdir( OnlineRecoTests )
-
-# External dependencies:
-find_package( ROOT COMPONENTS Core Tree MathCore Hist RIO pthread )
-
-# Install files from the package:
-atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
-atlas_install_joboptions( share/*.py )
-atlas_install_scripts( scripts/ort_*.py scripts/ort_*.sh )
diff --git a/Tools/OnlineRecoTests/python/__init__.py b/Tools/OnlineRecoTests/python/__init__.py
deleted file mode 100644
index 74583d364ec2ca794156596c7254d9b234a940c6..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/python/__init__.py
+++ /dev/null
@@ -1,2 +0,0 @@
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
diff --git a/Tools/OnlineRecoTests/python/ort_interpretTimestamp.py b/Tools/OnlineRecoTests/python/ort_interpretTimestamp.py
deleted file mode 100755
index 70ff4a5e3d3b6094bc61854f1925dbd3b3606888..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/python/ort_interpretTimestamp.py
+++ /dev/null
@@ -1,100 +0,0 @@
-#!/usr/bin/env python
-
-# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-
-from __future__ import print_function
-
-import os,sys
-from datetime import datetime
-
-from future import standard_library
-standard_library.install_aliases()
-import subprocess
-
-
-def getFile(timestampfile):
-  ## weblocation?
-  if timestampfile.find("http")==0:
-    tsfArr = timestampfile.split("/")
-    tmpstampfile = tsfArr[len(tsfArr)-1]
-    cmd = "export http_proxy=\"http://atlasgw.cern.ch:3128/\"; wget -O %s %s" % (tmpstampfile,timestampfile)
-    s,o = subprocess.getstatusoutput(cmd)
-    timestampfile = tmpstampfile
-
-  ## file exists?
-  if not os.path.exists( timestampfile ):
-    print("ERROR : File <%s> does not exist. Exit." % timestampfile)
-    sys.exit(1)
-
-  return timestampfile
-
-
-def readTimestamp(timestampfile):
-  fileLine=open(timestampfile,"r").readlines()
-
-  if len(fileLine)<2: 
-    print("ERROR : Cannot interpret timestampfile <%s>. Exit." % timestampfile)
-    sys.exit(1)
-
-  timestamp = int(fileLine[0].strip())
-  pacmankey = fileLine[1].strip()
-
-  return timestamp,pacmankey
-
-
-def interpretNewTimestamp(newtimestampfile,prvtimestampfile=""):
-
-  datenow = int(datetime.today().strftime("%Y%m%d")) #("%Y%m%d.%H%M")
-
-  ## interpret timestamps
-  dateprv = -1
-  if len(prvtimestampfile)>0:
-    dateprv,prvpacmankey = readTimestamp(getFile(prvtimestampfile))
-  datenew,newpacmankey = readTimestamp(getFile(newtimestampfile))
-
-  doInstall = False
-  if (datenew>dateprv) and (datenew==datenow):
-    doInstall = True
-
-  return doInstall,newpacmankey
-
-
-def updatePreviousTimestamp(newtimestampfile,prvtimestampfile):
-  cpcmd = "cp -f %s %s" % (getFile(newtimestampfile),prvtimestampfile)
-  s,o = subprocess.getstatusoutput(cpcmd)
-  return s
-
-
-## main
-if __name__ == "__main__":
-
-  usageline = "usage: " + sys.argv[0] + " <newtimestampfile> [<previoustimestampfile>] [<updatePreviousTimestamp>]"
-  if (len(sys.argv)<2):
-    print(usageline)
-    sys.exit(1)
-
-  ## getopts
-  newtimestampfile = sys.argv[1]
-  prvtimestampfile = ""
-  if (len(sys.argv)>2):
-    prvtimestampfile = sys.argv[2]
-  updateTimestamp = 0
-  if (len(sys.argv)>3):
-    updateTimestamp = int(sys.argv[3])
-
-  ## interpret timestamp
-  doInstall,pacmankey = interpretNewTimestamp(newtimestampfile,
-                                              prvtimestampfile)
-  if doInstall:
-    print("Install new nightly kit ? %s" % str(doInstall))
-    print(pacmankey)
-  else:
-    print("No need to install new nightly kit.")
-
-  if doInstall and updateTimestamp:
-    if len(prvtimestampfile)==0:
-      prvtimestampfile="previous_copied_release"
-    updatePreviousTimestamp(newtimestampfile,prvtimestampfile)
-    print("Timestamp has been updated, stored as <%s>." % prvtimestampfile)
-
-  print("\nErrorCode=0 (OK)")
diff --git a/Tools/OnlineRecoTests/scripts/ort_checkLogfiles.py b/Tools/OnlineRecoTests/scripts/ort_checkLogfiles.py
deleted file mode 100755
index 5b8d2450802a57a4a289823c9122571739fa74b8..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/scripts/ort_checkLogfiles.py
+++ /dev/null
@@ -1,237 +0,0 @@
-#!/usr/bin/env python
-
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-
-import os,sys,string,commands
-from datetime import datetime
-import pickle
-import shutil
-
-def makePickle(argdict,outpickle):
-  file = open(outpickle,'w')
-  pickle.dump(argdict,file)
-  file.close()
-  return
-
-def searchLogfiles(logArr):
-
-  ## strings to search for in logfile(s)
-  successArr = ['leaving with code 0','ErrorCode=0 (OK)','successful run']
-  failureArr = ['FATAL','Core dump','stack trace','Shortened traceback','traceback']
-
-  print "Searching for success/failure strings: "
-  #print successArr ## printing this gives fake errors when scanning logfiles!
-  #print failureArr
-
-  ## default success is False
-  ## if no search strings found, status stays False
-  myOk = True
-
-  for log in logArr:
-    allOk = False
-    ## logical OR of success search strings
-    for search in successArr:
-      cmd = 'grep "%s" %s' % (search,log)
-      s,o = commands.getstatusoutput(cmd)
-      if len(o)>0:
-        #print o
-        allOk = True
-        break
-    ## logical AND of failure search strings. These overwrite possible earlier success.
-    for search in failureArr:
-      cmd = 'grep "%s" %s' % (search,log)
-      s,o = commands.getstatusoutput(cmd)
-      if len(o)>0:
-        print ">> Found ERROR string : %s" % o
-        allOk = False
-        break
-    myOk = (allOk and myOk)
-    print "> Scanned through log file: %s ... Ok ? %s" % (log,allOk)
-
-  return myOk
-
-
-def printTimestamp(timestampfile,outpickle,tocpfile,
-		   kitbasedir="/afs/cern.ch/atlas/software/builds/kitrel/nightlies/",
-		   webbasedir="http://atlas-computing.web.cern.ch/atlas-computing/links/buildDirectory/kitrel/nightlies/"
-                  ):
-
-  ## info we need for our timestampfile
-  paccmd = "pacman -allow trust-all-caches tar-overwrite -get "
-  timenow = datetime.today().strftime("%Y%m%d") #("%Y%m%d.%H%M")
-  print "timenow=", timenow
-  version = os.environ["AtlasVersion"]
-  print "version=", version
-  area = os.environ["AtlasArea"].replace("/afs/cern.ch/atlas/software/builds/nightlies/","")
-  print "area=", area
-  areaArr = area.split("/")
-  print "areaArr=", areaArr
-  release = areaArr[0]
-  print "release=", release
-  project = areaArr[1]
-  print "project=", project
-  setupstr= "-tag=%s,%s,%s" % (release,project,version)
-  print "setupstr=", setupstr 
-  newcache= ""
-  suffix  = ""
-  if project=="AtlasTier0": suffix="-T0/"
-  if project=="AtlasProduction": suffix="-Prod/"
-  print "project=", project
-  cmtconfig = os.environ["CMTCONFIG"].replace("-","_")
-  print "cmtconfig", cmtconfig
-  
-  kitdir = kitbasedir + release + suffix + "i686-slc5-gcc43-opt/" + version + "/cache/"
-  print "kitdir=", kitdir
-  pacman = webbasedir + release + suffix + "i686-slc5-gcc43-opt/" + version + "/cache/"
-  print "pacman=", pacman
-  tardir = kitbasedir + release + suffix +"i686-slc5-gcc43-opt/" + version + "/kits/"
-  print "tardir=", tardir
-
-  #webdir = webbasedir + release + suffix + version + "/kits/"
-  webdir = "http://atlas-project-fullchaintest.web.cern.ch/atlas-project-FullChainTest/tier0/rtt/OnlineRecoTests/"
-  print "webdir=", webdir
-  rttdir = "/afs/cern.ch/atlas/offline/external/FullChainTest/tier0/rtt/OnlineRecoTests/"
-  print "rttdir=", rttdir
-
-  tarfiles = []
-  files=os.listdir(tardir)
-  print "List of tardir =", files
-  for tgzfile in files:
-    if tgzfile.find(project)==0 and \
-       tgzfile.endswith(".tar.gz"):
-       shutil.copy(tardir+tgzfile,rttdir)
-       tarfiles.append(webdir+tgzfile)
-  print "tarfiles=", tarfiles
-  
-  files=os.listdir(kitdir)
-  print "List of kitdir =", files  
-  pacfileFound=False
-  print "Is pacfileFound? ", pacfileFound
-  print "Looking for %s*%s*pacman " % (project, cmtconfig)
-  for pacfile in files:  
-    print "pacfile=", pacfile
-    if pacfile.find(project)==0 and \
-       pacfile.endswith("_opt.pacman"):
-       print "found pacfile = ", pacfile 
-       #newcache = pacfile.replace(".pacman","")
-       #print "newcache=", newcache
-       pacfileTokens=pacfile.split("_")
-       newcache=pacfileTokens[1]+"."+pacfileTokens[2]+"."+pacfileTokens[3]+"."+pacfileTokens[4]
-       pacman+=pacfile
-       print "pacman",pacman
-       pacfileFound=True
-       print "Is pacfileFound? ", pacfileFound
-       break
-
-  if not pacfileFound: 
-    print "ERROR : Could not find pacman file for : %s %s %s." % (release,project,version)
-    print "        Pacman basedir used : %s" % pacman
-    print "        Timestamp file not updated. Exit."
-    sys.exit(1)
-
-  #newcache = newcache.replace("_"+cmtconfig,"")
-  #print "newcache after replacing in cmtconfig:", newcache
-  #newcache = newcache.replace(project+"_","")
-  #print "newcache after replacing project:", newcache
-  #newcache = newcache.replace("_",".")
-  #print "final newcache:", newcache
-
-  
-
-  argdict = {}
-  argdict['pacman'] = pacman 
-  argdict['paccmd'] = paccmd+pacman
-  argdict['setupstr'] = setupstr
-  argdict['version'] = version
-  argdict['area'] = area
-  argdict['timenow'] = timenow
-  argdict['project'] = project
-  argdict['release'] = newcache
-  argdict['projectrelease'] = project+"-"+release
-
-  ## first line: timestamp
-  ## following lines: files to copy over to p1
-  file1 = open(timestampfile,'w')
-  file1.write(timenow+"\n")
-  for copyfile in tocpfile:
-    file1.write(copyfile+"\n")
-  for tgzfile in tarfiles:
-    file1.write(tgzfile+"\n")
-  file1.close()
-
-  print "argdict: ", argdict 
-  return argdict
-
-
-def compileDict(argdict,inpickleArr,outpickle):
-
-  for inpickle in inpickleArr:
-    f = open(inpickle, 'r')
-    map = pickle.load(f)
-    f.close()
-    keys = map.keys()
-    for key in keys:
-      argdict[key] = map[key]
-
-  print "Saving pickled dictionary: %s" % outpickle
-  makePickle(argdict,outpickle)
-
-  return
-
-
-## main
-if __name__ == "__main__":
-
-  usageline = "usage: " + sys.argv[0] + " <logfile1,logfile2,etc> <timestampfile> [<indic1.pickle,indic2.pickle,etc>] [<outdic.pickle>] [<tocpfile1,tocpfile2,etc>] [<forceAllOk>] [<kitbasedir>] [<webbasedir>]"
-  if (len(sys.argv)<3):
-    print usageline
-    sys.exit(1)
-
-  ## getopts
-  logList = sys.argv[1]
-  timestampfile = sys.argv[2] # 14.5.2.Y-VAL/AtlasProduction/latest_copied_release
-  logArr = logList.split(",")
- 
-  inpickleArr = []
-  if len(sys.argv)>3:
-    inpickleStr = sys.argv[3]
-    inpickleArr = inpickleStr.split(",")
-
-  outpickle = "outdict.pickle"
-  if len(sys.argv)>4:
-    outpickle = sys.argv[4]
-
-  tocpfile = []
-  if len(sys.argv)>5:
-    tocpfile = sys.argv[5].split(",")
-
-  ## following dirs are preset
-  outdir     = "/afs/cern.ch/atlas/offline/external/FullChainTest/tier0-vol3/rtt/fallbackfiles/ort/"
-  kitbasedir = "/afs/cern.ch/atlas/software/builds/kitrel/nightlies/" # /14.5.X.Y-T0/rel_3/cache/AtlasTier0_14_5_0_6_noarch.pacman
-  webbasedir = "http://atlas-computing.web.cern.ch/atlas-computing/links/buildDirectory/kitrel/nightlies/"
-  ## eg: http://atlas-computing.web.cern.ch/atlas-computing/links/buildDirectory/kitrel/nightlies/14.5.X.Y-T0/rel_0/cache:AtlasTier0_14_5_0_6_i686_slc4_gcc34_opt.pacman
-
-  forceAllOk = False
-  if len(sys.argv)>6:
-    forceAllOk = ("True"==sys.argv[6])
-
-  if len(sys.argv)>7:
-    kitbasedir = sys.argv[7]
-  if ( not kitbasedir.endswith("/") ): kitbasedir+="/"
-  if len(sys.argv)>8:
-    webbasedir = sys.argv[8]
-  if ( not webbasedir.endswith("/") ): webbasedir+="/"
-
-  ## process logfiles and write timestamp
-  allOk = searchLogfiles(logArr) or forceAllOk
-  if allOk:
-    ## force okay?
-    print "\nForce all okay ? %s" % forceAllOk
-    print "\nAll logfile(s) okay.\nSaving updated timestamp file: %s" % timestampfile
-    argdict = printTimestamp(timestampfile,outpickle,tocpfile,kitbasedir,webbasedir)
-    compileDict(argdict,inpickleArr,outpickle)
-  else:
-    print "\nProblem found in logfile(s). Timestamp file not updated. Exit."
-
-  print "\nErrorCode=0 (OK)"
-
diff --git a/Tools/OnlineRecoTests/scripts/ort_examplecmdsoffline.sh b/Tools/OnlineRecoTests/scripts/ort_examplecmdsoffline.sh
deleted file mode 100755
index 1d87ae2e448c976635c0207bb74ad36865ea5e3a..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/scripts/ort_examplecmdsoffline.sh
+++ /dev/null
@@ -1,47 +0,0 @@
-#!/bin/sh
-## runcmds found in <../test/OnlineRecoTests_DefaultConfiguration.xml> : 
-
-##
-tct_getAmiTag.py f100 ami_recotrf.cmdargs ami_recotrf.pickle
-
-##
-export RUNNUMBER=96544; tct_recotrf.sh 0 IDCosmic 3 500 /castor/cern.ch/grid/atlas/DAQ/2008/00${RUNNUMBER} ami_recotrf.cmdargs False offlineReco0_isOnlineFalse.log
-
-##
-export RUNNUMBER=96544; tct_recotrf.sh 1 TRTCosmic 3 500 /castor/cern.ch/grid/atlas/DAQ/2008/00${RUNNUMBER} ami_recotrf.cmdargs False offlineReco1_isOnlineFalse.log
-
-##
-export RUNNUMBER=96544; tct_recotrf.sh 2 IDCosmic 1 100 /castor/cern.ch/grid/atlas/DAQ/2008/00${RUNNUMBER} ami_recotrf.cmdargs False offlineReco2_isOnlineTrue.log
-
-##
-export POSTINC=OnlineRecoTests/OnlineRecoTests_autoconfiguration.py; tct_recotrf.sh 1 L1Calo 1 100 /castor/cern.ch/grid/atlas/DAQ/2009 ami_recotrf.cmdargs True
-
-##
-athena RecExOnline/RecExOnline_Test_Offline.py | tee offlineReco3_isOnlineFalse.log
-
-##
-export PREEXEC="rec.doInDet.set_Value_and_Lock(True),,rec.doMuon.set_Value_and_Lock(False),,rec.doLArg.set_Value_and_Lock(False),,rec.doTile.set_Value_and_Lock(False),,DQMonFlags.doMonitoring.set_Value_and_Lock(False)"; export RUNNUMBER=91890; tct_recotrf.sh 0 IDCosmic 1 100 /castor/cern.ch/grid/atlas/DAQ/2008/${RUNNUMBER} ami_recotrf.cmdargs
-
-##
-export PREEXEC="rec.doInDet.set_Value_and_Lock(False),,rec.doMuon.set_Value_and_Lock(True),,rec.doLArg.set_Value_and_Lock(False),,rec.doTile.set_Value_and_Lock(False),,DQMonFlags.doMonitoring.set_Value_and_Lock(False)"; export RUNNUMBER=91890; tct_recotrf.sh 0 IDCosmic 1 100 /castor/cern.ch/grid/atlas/DAQ/2008/${RUNNUMBER} ami_recotrf.cmdargs
-
-##
-export PREEXEC="rec.doInDet.set_Value_and_Lock(False),,rec.doMuon.set_Value_and_Lock(False),,rec.doLArg.set_Value_and_Lock(True),,rec.doTile.set_Value_and_Lock(False),,DQMonFlags.doMonitoring.set_Value_and_Lock(False)"; export RUNNUMBER=91890; tct_recotrf.sh 0 L1CaloEM 1 100 /castor/cern.ch/grid/atlas/DAQ/2008/${RUNNUMBER} ami_recotrf.cmdargs
-
-##
-export PREEXEC="rec.doInDet.set_Value_and_Lock(False),,rec.doMuon.set_Value_and_Lock(False),,rec.doLArg.set_Value_and_Lock(False),,rec.doTile.set_Value_and_Lock(True),,DQMonFlags.doMonitoring.set_Value_and_Lock(False)"; export RUNNUMBER=91890; tct_recotrf.sh 0 L1CaloEM 1 100 /castor/cern.ch/grid/atlas/DAQ/2008/${RUNNUMBER} ami_recotrf.cmdargs
-
-##
-export PREEXEC="rec.doInDet.set_Value_and_Lock(False),,rec.doMuon.set_Value_and_Lock(False),,rec.doLArg.set_Value_and_Lock(True),,rec.doTile.set_Value_and_Lock(True),,DQMonFlags.doMonitoring.set_Value_and_Lock(False)"; export RUNNUMBER=91890; tct_recotrf.sh 0 L1CaloEM 1 100 /castor/cern.ch/grid/atlas/DAQ/2008/${RUNNUMBER} ami_recotrf.cmdargs
-
-##
-ort_checkLogfiles.py offlineReco0_isOnlineFalse.log,offlineReco1_isOnlineFalse.log,offlineReco2_isOnlineTrue.log,offlineReco3_isOnlineFalse.log latest_copied_release ami_recotrf.pickle,globalflags.pickle latest_data.argdict.pickle http://atlas-project-fullchaintest.web.cern.ch/atlas-project-FullChainTest/tier0-vol3/rtt/fallbackfiles/ort/latest_data.argdict.pickle,http://atlas-project-fullchaintest.web.cern.ch/atlas-project-FullChainTest/tier0-vol3/rtt/fallbackfiles/ort/latest.data True
-
-##
-echo "ErrorCode=0 (OK)" ; cp -f 0.data /afs/cern.ch/atlas/offline/external/FullChainTest/tier0-vol3/rtt/fallbackfiles/ort/latest.data; cp -f latest_data.argdict.pickle /afs/cern.ch/atlas/offline/external/FullChainTest/tier0-vol3/rtt/fallbackfiles/ort/ ; cp -f latest_copied_release /afs/cern.ch/atlas/offline/external/FullChainTest/tier0-vol3/rtt/fallbackfiles/ort/
-
-##
-## Now start the online jobs
-##
-#ort_examplecmdsonline.sh
-
diff --git a/Tools/OnlineRecoTests/scripts/ort_examplecmdsonline.sh b/Tools/OnlineRecoTests/scripts/ort_examplecmdsonline.sh
deleted file mode 100755
index a9eda14b38d938ebeaaea81125d30ebb6a9a3790..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/scripts/ort_examplecmdsonline.sh
+++ /dev/null
@@ -1,22 +0,0 @@
-#!/bin/sh
-## runcmds found in <../test/OnlineRecoTests_DefaultConfiguration.xml> : 
-
-
-## The following (offline) jobs wait for the online jobs, and copy over the online results
-## They need the offline timestampfile: latest_copied_release to see if the jobs need to be evaluated.
-
-##
-ort_getOnlineResults.py latest_copied_release http://atlas-project-fullchaintest.web.cern.ch/atlas-project-FullChainTest/tier0/rtt/webtimestamp http://atlas-project-fullchaintest.web.cern.ch/atlas-project-FullChainTest/tier0/rtt/webfilelist0
-
-##
-ort_getOnlineResults.py latest_copied_release webtimestamp http://atlas-project-fullchaintest.web.cern.ch/atlas-project-FullChainTest/tier0/rtt/webfilelist1
-
-##
-ort_getOnlineResults.py latest_copied_release webtimestamp http://atlas-project-fullchaintest.web.cern.ch/atlas-project-FullChainTest/tier0/rtt/webfilelist2
-
-##
-ort_finishedMail.py latest_copied_release mbaak@cern.ch,Anadi.Canepa@cern.ch
-
-##
-tct_finishedMail.py mbaak@cern.ch,acanepa@cern.ch,stelzer-chilton@triumf.ca,bernd.stelzer@cern.ch http://atlas-project-fullchaintest.web.cern.ch/atlas-project-FullChainTest/tier0/rtt/TCT.Results/page0.php
-
diff --git a/Tools/OnlineRecoTests/scripts/ort_finishedMail.py b/Tools/OnlineRecoTests/scripts/ort_finishedMail.py
deleted file mode 100755
index c85b7a1f00a119c0b8d81b0942e630807a6777e2..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/scripts/ort_finishedMail.py
+++ /dev/null
@@ -1,59 +0,0 @@
-#!/usr/bin/env python
-
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-#
-# usage: tct_finishedMail.py
-
-import cgi, commands, pickle, sys, string, re, os, smtplib
-from datetime import datetime
-from OnlineRecoTests.ort_interpretTimestamp import *
-
-
-def sendSms(msg,toAdd='0041762725254@sms.switch.ch'):
-  yourCernMailAdd = 'fct@cern.ch'
-  cernSMTPsrv='cernmx.cern.ch'
-  s=smtplib.SMTP(cernSMTPsrv)
-  toList=[toAdd]
-  s.sendmail(yourCernMailAdd,toList,msg)
-  print "<br>%s<br>A notification has been sent to the admin<br>" % msg
-  s.quit()
-  return
-
-
-def sendMail(msg,toList):
-  yourCernMailAdd = 'fct@cern.ch'
-  cernSMTPsrv='cernmx.cern.ch'
-  s=smtplib.SMTP(cernSMTPsrv)
-  s.sendmail(yourCernMailAdd,toList,msg)
-  s.quit()
-  return
-
-
-## main
-if __name__ == "__main__":
-
-  usageline = "usage: " + sys.argv[0] + " <timestampfile> <emailaddress1,emailaddress2,emailaddress3,etc> [<body>]"
-  if (len(sys.argv)<3):
-    print usageline
-    sys.exit(1)
-
-  release = os.environ["AtlasArea"]
-  timestampfile = sys.argv[1]
-  eList = sys.argv[2]
-  body = ""
-  if len(sys.argv)>3:
-    body = sys.argv[3]
-
-  newkitInstalled,pacmankey = interpretNewTimestamp(timestampfile)  
-
-  if newkitInstalled:
-    ## send emails
-    print "Sending emails to: " + eList
-    msg = "From: fct@mail.cern.ch\nSubject: Finished ORT: %s\nTo: %s\n\n%s\n" % (release,eList,body)
-
-    toList = eList.split(",")
-    for address in toList:
-      sendMail(msg,address)
-
-  print "ErrorCode=0 (OK)"
-
diff --git a/Tools/OnlineRecoTests/scripts/ort_getOnlineResults.py b/Tools/OnlineRecoTests/scripts/ort_getOnlineResults.py
deleted file mode 100755
index 3cc65e47a00df055315a8e1528ab357d14f9e861..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/scripts/ort_getOnlineResults.py
+++ /dev/null
@@ -1,104 +0,0 @@
-#!/usr/bin/env python
-
-# Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
- 
-import commands, pickle, sys, string, os
-from datetime import datetime
-from OnlineRecoTests.ort_interpretTimestamp import *
-import time
-
-
-def waitForOnlineResults(webtimestampURL):
-  datenow = int(datetime.today().strftime("%Y%m%d")) #("%Y%m%d.%H%M")
-
-  fileList = []
-  onlineTestsFinished = False
-
-  ## wait till online tests finished
-  while (not onlineTestsFinished):
-    webtimestamp = getFile(webtimestampURL)
-    if os.path.exists( webtimestamp ):
-      if os.path.getsize( webtimestamp )>0:
-        fileList = open(webtimestamp,"r").readlines()
-        timestamp = int(fileList[0].strip())
-        if (timestamp==datenow): ## ready 
-          onlineTestsFinished=True
-      else: os.remove( webtimestamp ) 
-    if (not onlineTestsFinished):
-      print "%s : Now sleeping one hour ..." % datetime.today().strftime("%Y%m%d.%H%M")
-      time.sleep(3600)
-
-  return onlineTestsFinished
-
-
-def getWebfiles(weblistfile):
-
-  weblistfile = getFile(weblistfile)
-  fileList = open(weblistfile,"r").readlines()
-
-  for webfile in fileList:
-    webfile = webfile.strip()
-    ## skip obvious lines
-    if len(webfile)==0: continue
-    if webfile.find("#")==0: continue
-    if webfile.find("http")!=0: continue
-    ## retrieve files
-    print "Now retreiving : %s" % webfile
-    cmd = "wget %s" % webfile
-    o,s=commands.getstatusoutput(cmd)
-
-  return 
-
-
-def printLogfiles(weblistfile):
-
-  weblistfile = getFile(weblistfile)
-  fileList = open(weblistfile,"r").readlines()
-
-  for webfile in fileList:
-    webfile = webfile.strip()
-    ## skip obvious lines
-    if len(webfile)==0: continue
-    if webfile.find("#")==0: continue
-    if webfile.find("http")!=0: continue
-    if not webfile.endswith(".log"): continue
-    ## print logfiles
-    logArr = webfile.split("/")
-    logFile = logArr[len(logArr)-1]
-
-    print "\n----------------------------------------------------------------------"
-    print "> Now printing logfile : %s" % logFile
-    print "----------------------------------------------------------------------\n"
-    #cmd = 'cat %s' % logFile
-    #os.system(cmd)
-    logLines = open(logFile,"r").readlines()
-    for line in logLines: print line.strip()
-    print "\n----------------------------------------------------------------------"
-    print "> Finished printing logfile : %s" % logFile
-    print "----------------------------------------------------------------------\n"
-
-  return
-
-
-## main
-if __name__ == "__main__":
-
-  usageline = "usage: " + sys.argv[0] + " <localtimestampfile> <webtimestamp> <weblistfile>"
-  if (len(sys.argv)<4):
-    print usageline
-    sys.exit(1)
-
-  timestampfile = sys.argv[1]
-  webtimestamp = sys.argv[2]
-  weblistfile = sys.argv[3]
-
-  newkitInstalled,pacmankey = interpretNewTimestamp(timestampfile)  
-
-  if newkitInstalled:
-    finished = waitForOnlineResults(webtimestamp)
-    if finished: 
-      getWebfiles(weblistfile)
-      printLogfiles(weblistfile)
-
-  print "\nErrorCode=0 (OK)"
-
diff --git a/Tools/OnlineRecoTests/scripts/ort_runAllOffline.sh b/Tools/OnlineRecoTests/scripts/ort_runAllOffline.sh
deleted file mode 100755
index c88bb46c29df8576cbb2567a5651e7a12fa530de..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/scripts/ort_runAllOffline.sh
+++ /dev/null
@@ -1,49 +0,0 @@
-#!/bin/sh
-
-## Check arguments
-if [ $# -lt 1 ] ; then
-   echo "Usage: ort_runAll.sh <xmlfile>"
-   exit 1 
-fi
-
-## Intercept dryrun option if given
-DRYRUN=0 
-if [ "$1" = "-d" ] ; then
-  DRYRUN=1
-  shift
-fi
-
-## set configuration parameters
-XMLFILE=$1
-if [ ! -f $XMLFILE ]; then 
-  echo "Input xmlfile ${XMLFILE} not found. Exit."
-  exit 1
-fi
-
-RUNALLCMDS="runallcmds.sh"
-if [ -f ${RUNALLCMDS} ]; then
-  rm -f ${RUNALLCMDS}
-fi
-
-echo "#!/bin/sh" > ${RUNALLCMDS}
-tct_readxmlcmds.py $XMLFILE >> ${RUNALLCMDS}
-chmod +x ${RUNALLCMDS}
-
-## run all commands
-RUNCMD=${RUNALLCMDS}
-echo
-echo ">> Now running command:"
-echo ">> ===================="
-echo ${RUNCMD}
-echo 
-if [ $DRYRUN -ne 1 ]; then
-  mkdir -p run; cd run
-  ../$RUNCMD
-  cd ..
-fi
-echo 
-echo ">> Finished command:"
-echo ">> ===================="
-echo ${RUNCMD}
-echo 
-
diff --git a/Tools/OnlineRecoTests/share/OnlineRecoTests_autoconfiguration.py b/Tools/OnlineRecoTests/share/OnlineRecoTests_autoconfiguration.py
deleted file mode 100644
index 0f6c85b1b11824c94d571e41e6d5921e71dfd917..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/share/OnlineRecoTests_autoconfiguration.py
+++ /dev/null
@@ -1,17 +0,0 @@
-import pickle
-
-from AthenaCommon.GlobalFlags import globalflags
-from AthenaCommon.AthenaCommonFlags import jobproperties,athenaCommonFlags
-
-onlinegoodies = {}
-
-onlinegoodies['DataSource'] = globalflags.DataSource()
-onlinegoodies['InputFormat'] = globalflags.InputFormat()
-onlinegoodies['ConditionsTag'] = globalflags.ConditionsTag()
-onlinegoodies['beamType'] = jobproperties.Beam.beamType()
-onlinegoodies['DetDescrVersion'] = globalflags.DetDescrVersion()
-
-file = open("globalflags.pickle",'wb')
-pickle.dump(onlinegoodies,file)
-file.close()
-
diff --git a/Tools/OnlineRecoTests/test/OnlineRecoTests_DefaultConfiguration.xml b/Tools/OnlineRecoTests/test/OnlineRecoTests_DefaultConfiguration.xml
deleted file mode 100644
index 28fb43cf5e36e90cc7acb0eec32c06134bad4367..0000000000000000000000000000000000000000
--- a/Tools/OnlineRecoTests/test/OnlineRecoTests_DefaultConfiguration.xml
+++ /dev/null
@@ -1,68 +0,0 @@
-<?xml version="1.0"?>
-<!DOCTYPE unifiedTestConfiguration SYSTEM "http://www.hep.ucl.ac.uk/atlas/AtlasTesting/DTD/unifiedTestConfiguration.dtd"> <!-- official -->
-
-<unifiedTestConfiguration>
-   
-<atn>    
-
-	<!-- ENABLE-IN-PROJECT-BEGIN: AtlasProduction -->
-	<TEST name="HelloWorldREO" type="athena" suite="RecExOnline_ATN_Offline">
-      		<options_atn>AthExHelloWorld/HelloWorldOptions.py</options_atn>
-      		<timelimit>2</timelimit>
-      		<author> Atlas Developer </author>
-      		<mailto> somebody@somewhere.ch </mailto>
-      		<expectations>
-         		<errorMessage>FAILURE (ERROR)</errorMessage>
-         		<successMessage>FATAL A FATAL</successMessage>
-         		<returnValue>0</returnValue>
-      		</expectations>
-   	</TEST>
-
-
-	<TEST name="RecExOnline_isOnline_False" type="athena" suite="RecExOnline_ATN_Offline">
-      		<options_atn>RecExOnline/RecExOnline_User_Offline.py</options_atn>
-      		<timelimit>30</timelimit>
-      		<author> Alex Koutsman </author>
-      		<mailto> alex.koutsman@cern.ch </mailto>
-      		<expectations>
-         		<returnValue>0</returnValue>
-      		</expectations>
-   	</TEST>
-
-	<TEST name="RecExOnline_isOnline_True" type="athena" suite="RecExOnline_ATN_isOnline_autoconfigEverything">
-   		<options_atn>-c "REO_doAutoConfiguration=True" RecExOnline/RecExOnline_User_Offline_isOnlineTrue.py</options_atn> 
-                <!-- FIXME: Finalization takes a long time due to RecursiveRemove in root.  See ATLASRECTS-4431. -->
-      		<timelimit>90</timelimit>
-      		<author> Alex Koutsman </author>
-      		<mailto> alex.koutsman@cern.ch </mailto>
-      		<expectations>
-         		<returnValue>0</returnValue>
-      		</expectations>
-   	</TEST>
-
-	<TEST name="RecExOnline_isOnline_True" type="athena" suite="RecExOnline_ATN_isOnline_autoconfigOnline">
-   		<options_atn>-c "REO_doAutoConfiguration=False" RecExOnline/RecExOnline_User_Offline_isOnlineTrue.py</options_atn> 
-                <!-- FIXME: Finalization takes a long time due to RecursiveRemove in root.  See ATLASRECTS-4431. -->
-      		<timelimit>90</timelimit>
-      		<author> Alex Koutsman </author>
-      		<mailto> alex.koutsman@cern.ch </mailto>
-      		<expectations>
-         		<returnValue>0</returnValue>
-      		</expectations>
-   	</TEST>
-
-	<TEST name="RecExOnline_isOnline_True" type="athena" suite="RecExOnline_ATN_isOnline_cosmics">
-   		<options_atn>-c "REO_doAutoConfiguration=False; beamType='cosmics'" RecExOnline/RecExOnline_User_Offline_isOnlineTrue.py</options_atn> 
-                <!-- FIXME: Finalization takes a long time due to RecursiveRemove in root.  See ATLASRECTS-4431. -->
-      		<timelimit>90</timelimit>
-      		<author> Alex Koutsman </author>
-      		<mailto> alex.koutsman@cern.ch </mailto>
-      		<expectations>
-         		<returnValue>0</returnValue>
-      		</expectations>
-   	</TEST>
-
-
-</atn>
-</unifiedTestConfiguration>
-
diff --git a/Tools/Tier0ChainTests/scripts/tct_runAll.sh b/Tools/Tier0ChainTests/scripts/tct_runAll.sh
index fc2e8269793b329af04d7ee453242999f6384ca0..fbf5914aebb5a82808ed19ee9d71f55bf7d05a2d 100755
--- a/Tools/Tier0ChainTests/scripts/tct_runAll.sh
+++ b/Tools/Tier0ChainTests/scripts/tct_runAll.sh
@@ -87,7 +87,7 @@ do
   idx=`expr $idx + 1`
 done
 
-TRFARGS="preInclude=RecExCommission/MinimalCommissioningSetup.py --ignoreunknown"
+TRFARGS="preInclude=RecExCond/MinimalCommissioningSetup.py --ignoreunknown"
 
 ## merge aods
 INFILE=job_${TRIGSTR}_0.AOD.pool.root
diff --git a/Tools/Tier0ChainTests/test/test_q221.sh b/Tools/Tier0ChainTests/test/test_q221.sh
index 9aea26ea5de36297f8ada84c62c061e2048f47a8..e40936e53fb8827390a56f112f26316a8760b255 100755
--- a/Tools/Tier0ChainTests/test/test_q221.sh
+++ b/Tools/Tier0ChainTests/test/test_q221.sh
@@ -8,7 +8,7 @@
 # art-include: 21.3/Athena
 # art-include: 21.9/Athena
 
-Reco_tf.py --AMI=q221 --outputRDOFile=myRDO.pool.root --outputAODFile=myAOD.pool.root --outputESDFile=myESD.pool.root --outputHISTFile=myHIST.root --imf False
+Reco_tf.py --AMI=q221 --outputRDOFile=myRDO.pool.root --outputAODFile=myAOD.pool.root --outputESDFile=myESD.pool.root --outputHISTFile=myHIST.root --imf False  --preExec="all:from IOVDbSvc.CondDB import conddb; conddb.addOverride('/PIXEL/PixMapOverlay','PixMapOverlay-SIM-MC16-000-03');"
 echo "art-result: $? Reco"
 
 Reco_tf.py --validationFlags 'doExample,doMET,doPFlow,doTau,doEgamma,doBtag,doZee,doJet,doTopoCluster,doMuon,doTrigMinBias,doTrigIDtrk,doTrigBphys,doTrigMET,doTrigJet,doTrigTau, doTrigEgamma,doTrigMuon,doTrigBjet,doTrigHLTResult' --inputAODFile=myAOD.pool.root  --outputNTUP_PHYSVALFile=myNTUP_PHYSVAL.root
diff --git a/Tools/Tier0ChainTests/test/test_q221_mp.sh b/Tools/Tier0ChainTests/test/test_q221_mp.sh
index f43cfc50341025aade41942b4ec172490edbcaab..679fcf87c8f0b6dd713c23196fffd12cf8c6a961 100755
--- a/Tools/Tier0ChainTests/test/test_q221_mp.sh
+++ b/Tools/Tier0ChainTests/test/test_q221_mp.sh
@@ -8,7 +8,7 @@
 # art-include: 21.3/Athena
 # art-include: 21.9/Athena
 
-Reco_tf.py --AMI=q221 --athenaopts='--nprocs=2' --outputRDOFile=myRDO.pool.root --outputAODFile=myAOD.pool.root --outputESDFile=myESD.pool.root --outputHISTFile=myHIST.root --imf False
+Reco_tf.py --AMI=q221 --athenaopts='--nprocs=2' --outputRDOFile=myRDO.pool.root --outputAODFile=myAOD.pool.root --outputESDFile=myESD.pool.root --outputHISTFile=myHIST.root --imf False  --preExec="all:from IOVDbSvc.CondDB import conddb; conddb.addOverride('/PIXEL/PixMapOverlay','PixMapOverlay-SIM-MC16-000-03');" 
 echo "art-result: $? Reco"
 
 Reco_tf.py --validationFlags 'doExample,doMET,doPFlow,doTau,doEgamma,doBtag,doZee,doJet,doTopoCluster,doMuon,doTrigMinBias,doTrigIDtrk,doTrigBphys,doTrigMET,doTrigJet,doTrigTau, doTrigEgamma,doTrigMuon,doTrigBjet,doTrigHLTResult' --inputAODFile=myAOD.pool.root  --outputNTUP_PHYSVALFile=myNTUP_PHYSVAL.root
diff --git a/Tools/Tier0ChainTests/test/test_q221_mt.sh b/Tools/Tier0ChainTests/test/test_q221_mt.sh
index 3f0f16038f62f6d90089df844d7dee9e425e85bf..72ae6d3a1b63b6c3c577518086580ffed6ef1537 100755
--- a/Tools/Tier0ChainTests/test/test_q221_mt.sh
+++ b/Tools/Tier0ChainTests/test/test_q221_mt.sh
@@ -8,7 +8,7 @@
 # art-include: 21.3/Athena
 # art-include: 21.9/Athena
 
-Reco_tf.py --AMI=q221 --athenaopts='--threads=1' --outputRDOFile=myRDO.pool.root --outputAODFile=myAOD.pool.root --outputESDFile=myESD.pool.root --imf False
+Reco_tf.py --AMI=q221 --athenaopts='--threads=1' --outputRDOFile=myRDO.pool.root --outputAODFile=myAOD.pool.root --outputESDFile=myESD.pool.root --imf False  --preExec="all:from IOVDbSvc.CondDB import conddb; conddb.addOverride('/PIXEL/PixMapOverlay','PixMapOverlay-SIM-MC16-000-03');"
 echo "art-result: $? Reco"
 
 Reco_tf.py --validationFlags 'doExample,doMET,doPFlow,doTau,doEgamma,doBtag,doZee,doJet,doTopoCluster,doMuon,doTrigMinBias,doTrigIDtrk,doTrigBphys,doTrigMET,doTrigJet,doTrigTau, doTrigEgamma,doTrigMuon,doTrigBjet,doTrigHLTResult' --inputAODFile=myAOD.pool.root  --outputNTUP_PHYSVALFile=myNTUP_PHYSVAL.root --preExec="TriggerFlags.EDMDecodingVersion.set_Value_and_Lock(3)"
diff --git a/Tracking/TrkAlgorithms/TrkTrackSummaryUpdater/src/components/TrkTrackSummaryUpdater_entries.cxx b/Tracking/TrkAlgorithms/TrkTrackSummaryUpdater/src/components/TrkTrackSummaryUpdater_entries.cxx
index 40c34fef6ad154109700e2cd43a0cc3863d565b7..80e5e3956fd049e026184bb5ec1af94f3526f41d 100644
--- a/Tracking/TrkAlgorithms/TrkTrackSummaryUpdater/src/components/TrkTrackSummaryUpdater_entries.cxx
+++ b/Tracking/TrkAlgorithms/TrkTrackSummaryUpdater/src/components/TrkTrackSummaryUpdater_entries.cxx
@@ -1,10 +1,8 @@
 
 #include "TrkTrackSummaryUpdater/TrackSummaryUpdater.h"
 #include "test/SummaryToolStub.h"
-#include "test/PutTrackCollectionsInSG.h"
 
 DECLARE_COMPONENT( Trk::TrackSummaryUpdater )
 DECLARE_COMPONENT(SummaryToolStub)
-DECLARE_COMPONENT( PutTrackCollectionsInSG )
 
 
diff --git a/Tracking/TrkConfig/python/AtlasTrackingGeometrySvcConfig.py b/Tracking/TrkConfig/python/AtlasTrackingGeometrySvcConfig.py
index ee09b77c6b78972ff9fc75fc2bb8a64812a3bdb7..66077f23ed22bdf16aaeeb6bd805e853bd7e81ce 100644
--- a/Tracking/TrkConfig/python/AtlasTrackingGeometrySvcConfig.py
+++ b/Tracking/TrkConfig/python/AtlasTrackingGeometrySvcConfig.py
@@ -242,6 +242,9 @@ def TrackingGeometrySvcCfg( flags , name = 'AtlasTrackingGeometrySvc', doMateria
 
     if flags.Detector.GeometryMuon:
       # Copied from from MuonTrackingGeometry.ConfiguredMuonTrackingGeometry import MuonTrackingGeometryBuilder
+      # Add the muon geometry model to the CA
+      from MuonConfig.MuonGeometryConfig import MuonGeoModelCfg
+      result.merge(MuonGeoModelCfg(flags))
       Muon__MuonStationTypeBuilder=CompFactory.Muon.MuonStationTypeBuilder
       muonStationTypeBuilder= Muon__MuonStationTypeBuilder(name = 'MuonStationTypeBuilder')
     
diff --git a/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignablePlaneSurface.h b/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignablePlaneSurface.h
index d9e1181d8a122fde0e7609aefd649d0529f305d9..f46dfb51d9e1e0a86428b5dd7cdaa46337277b3c 100644
--- a/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignablePlaneSurface.h
+++ b/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignablePlaneSurface.h
@@ -43,7 +43,7 @@ class TrkDetElementBase;
  @author Andreas.Salzburger@cern.ch
 */
 
-class AlignablePlaneSurface
+class AlignablePlaneSurface final
   : public PlaneSurface
   , public AlignableSurface
 {
@@ -66,12 +66,12 @@ public:
   /**Assignment operator */
   AlignablePlaneSurface& operator=(const AlignablePlaneSurface& sf);
   /**Equality operator*/
-  virtual bool operator==(const Surface& sf) const override;
+  virtual bool operator==(const Surface& sf) const override final;
   /**Implicit constructor - uses the copy constructor */
-  virtual AlignablePlaneSurface* clone() const override;
+  virtual AlignablePlaneSurface* clone() const override final;
 
   /** return associated Detector Element - forwarded from nominal Surface */
-  const TrkDetElementBase* associatedDetectorElement() const;
+  const TrkDetElementBase* associatedDetectorElement() const ;
 
   /** return Identifier of the associated Detector Element - forwarded from nominal Surface */
   Identifier associatedDetectorElementIdentifier() const;
@@ -80,72 +80,30 @@ public:
   const Layer* associatedLayer() const;
 
   /** -------------------------- interface from AlignableSurface ------------------ */
-
   /** Get the Surface representation */
-  virtual const PlaneSurface& surfaceRepresentation() const override;
+  virtual const PlaneSurface& surfaceRepresentation() const override final;
 
   /** Get the nominal surface */
-  virtual const PlaneSurface& nominalSurface() const override; 
+  virtual const PlaneSurface& nominalSurface() const override final; 
 
   /** Get the nominal transformation */
-  virtual const Amg::Transform3D& nominalTransform() const override;
+  virtual const Amg::Transform3D& nominalTransform() const override final;
 
   /** Add an alignment correction on top of the actual one */
-  virtual void addAlignmentCorrection(Amg::Transform3D& corr) override;
+  virtual void addAlignmentCorrection(Amg::Transform3D& corr) override final;
 
   /** Set an alignment correction on top of the nominal one */
-  virtual void setAlignmentCorrection(Amg::Transform3D& corr) override;
+  virtual void setAlignmentCorrection(Amg::Transform3D& corr) override final;
 
   /** Set an alignment correction on top of the nominal one */
-  virtual void setAlignableTransform(Amg::Transform3D& trans) override;
+  virtual void setAlignableTransform(Amg::Transform3D& trans) override final ;
 
 protected:
   /** The pointer ro the nominal Surface */
   const PlaneSurface* m_nominalSurface;
 };
 
-inline AlignablePlaneSurface*
-AlignablePlaneSurface::clone() const
-{
-  return new AlignablePlaneSurface(*this);
-}
-
-inline const TrkDetElementBase*
-AlignablePlaneSurface::associatedDetectorElement() const
-{
-  return m_nominalSurface->associatedDetectorElement();
-}
-
-inline Identifier
-AlignablePlaneSurface::associatedDetectorElementIdentifier() const
-{
-  return m_nominalSurface->associatedDetectorElementIdentifier();
-}
-
-inline const Trk::Layer*
-AlignablePlaneSurface::associatedLayer() const
-{
-  return m_nominalSurface->associatedLayer();
-}
-
-inline const PlaneSurface&
-AlignablePlaneSurface::surfaceRepresentation() const
-{
-  return (*this);
-}
-
-inline const PlaneSurface&
-AlignablePlaneSurface::nominalSurface() const
-{
-  return (*m_nominalSurface);
-}
-
-inline const Amg::Transform3D&
-AlignablePlaneSurface::nominalTransform() const
-{
-  return m_nominalSurface->transform();
-}
-
 } // end of namespace Trk
 
+#include "TrkAlignableSurfaces/AlignablePlaneSurface.icc"
 #endif // TRKALIGNABLESURFACES_ALGINABLESURFACE_H
diff --git a/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignablePlaneSurface.icc b/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignablePlaneSurface.icc
new file mode 100644
index 0000000000000000000000000000000000000000..bd4f8d21275f80d1fa39a471fa476161fb739710
--- /dev/null
+++ b/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignablePlaneSurface.icc
@@ -0,0 +1,50 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
+namespace Trk {
+
+inline AlignablePlaneSurface*
+AlignablePlaneSurface::clone() const
+{
+  return new AlignablePlaneSurface(*this);
+}
+
+inline const TrkDetElementBase*
+AlignablePlaneSurface::associatedDetectorElement() const
+{
+  return m_nominalSurface->associatedDetectorElement();
+}
+
+inline Identifier
+AlignablePlaneSurface::associatedDetectorElementIdentifier() const
+{
+  return m_nominalSurface->associatedDetectorElementIdentifier();
+}
+
+inline const Trk::Layer*
+AlignablePlaneSurface::associatedLayer() const
+{
+  return m_nominalSurface->associatedLayer();
+}
+
+inline const PlaneSurface&
+AlignablePlaneSurface::surfaceRepresentation() const
+{
+  return (*this);
+}
+
+inline const PlaneSurface&
+AlignablePlaneSurface::nominalSurface() const
+{
+  return (*m_nominalSurface);
+}
+
+inline const Amg::Transform3D&
+AlignablePlaneSurface::nominalTransform() const
+{
+  return m_nominalSurface->transform();
+}
+
+}
+
diff --git a/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignableSurface.h b/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignableSurface.h
index 7b91c2ce771b43811ee259cfc226aebb04edcafb..74e84b3e478bf144b6680c7b4faba302c5c0debd 100644
--- a/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignableSurface.h
+++ b/Tracking/TrkDetDescr/TrkAlignableSurfaces/TrkAlignableSurfaces/AlignableSurface.h
@@ -43,10 +43,10 @@ class AlignableSurface
 
 public:
   /** Default Constructor - needed for pool and inherited classes */
-  AlignableSurface();
+  AlignableSurface() = default;
 
   /** Destructor */
-  virtual ~AlignableSurface();
+  virtual ~AlignableSurface() = default;
 
   /** Get the Surface representation */
   virtual const Surface& surfaceRepresentation() const = 0;
diff --git a/Tracking/TrkDetDescr/TrkAlignableSurfaces/src/AlignableSurface.cxx b/Tracking/TrkDetDescr/TrkAlignableSurfaces/src/AlignableSurface.cxx
deleted file mode 100644
index 7a534c5197e44220ffc63de11c49430ce2a9f4e4..0000000000000000000000000000000000000000
--- a/Tracking/TrkDetDescr/TrkAlignableSurfaces/src/AlignableSurface.cxx
+++ /dev/null
@@ -1,14 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-///////////////////////////////////////////////////////////////////
-// AlignableSurface.cxx, (c) ATLAS Detector software
-///////////////////////////////////////////////////////////////////
-
-// Trk
-#include "TrkAlignableSurfaces/AlignableSurface.h"
-
-Trk::AlignableSurface::AlignableSurface() {}
-
-Trk::AlignableSurface::~AlignableSurface() {}
diff --git a/Tracking/TrkDetDescr/TrkDetDescrInterfaces/TrkDetDescrInterfaces/ITrackingGeometrySvc.h b/Tracking/TrkDetDescr/TrkDetDescrInterfaces/TrkDetDescrInterfaces/ITrackingGeometrySvc.h
index d685c143e64c6c298cee9e82978dd7fa5498c7d6..1b38816cc62379fb6ad1d5925b9b9ca73a57beea 100755
--- a/Tracking/TrkDetDescr/TrkDetDescrInterfaces/TrkDetDescrInterfaces/ITrackingGeometrySvc.h
+++ b/Tracking/TrkDetDescr/TrkDetDescrInterfaces/TrkDetDescrInterfaces/ITrackingGeometrySvc.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 ///////////////////////////////////////////////////////////////////
@@ -12,7 +12,6 @@
 // Include Files
 #include "GaudiKernel/IInterface.h"
 #include "GaudiKernel/StatusCode.h"
-#include "AthenaKernel/IOVSvcDefs.h"
 
 
 /** Declaration of the interface ID ( interface id, major version, minor version) */
@@ -34,16 +33,11 @@ namespace Trk {
     //!< Retrieve interface ID
     static const InterfaceID& interfaceID() { return IID_ITrackingGeometrySvc; }
 
-    /** Create the geometry */
-    virtual StatusCode trackingGeometryInit(IOVSVC_CALLBACK_ARGS) = 0;
-
     /** Provide the TrackingGeometry */
     virtual const Trk::TrackingGeometry* trackingGeometry() const = 0;
 
     //!< Returns the name of the TrackingGeometry built with this Svc
     virtual const std::string& trackingGeometryName() const = 0;
-
-
   };
 }
 
diff --git a/Tracking/TrkDetDescr/TrkDetDescrSvc/CMakeLists.txt b/Tracking/TrkDetDescr/TrkDetDescrSvc/CMakeLists.txt
index 6e11813894cf61bf7a07904d0ce6f4e4ffd76099..aed315e3b0e91fe91f1bd26486bd2cabfbd01941 100644
--- a/Tracking/TrkDetDescr/TrkDetDescrSvc/CMakeLists.txt
+++ b/Tracking/TrkDetDescr/TrkDetDescrSvc/CMakeLists.txt
@@ -7,8 +7,8 @@ atlas_subdir( TrkDetDescrSvc )
 atlas_add_library( TrkDetDescrSvcLib
                    src/*.cxx
                    PUBLIC_HEADERS TrkDetDescrSvc
-                   LINK_LIBRARIES AthenaBaseComps AthenaKernel GaudiKernel TrkDetDescrInterfaces TrkDetDescrUtils TrkGeometry TrkVolumes
-                   PRIVATE_LINK_LIBRARIES EventInfo StoreGateLib )
+                   LINK_LIBRARIES AthenaBaseComps AthenaKernel GaudiKernel TrkDetDescrInterfaces TrkDetDescrUtils TrkGeometry TrkVolumes EventInfoMgtLib
+                   PRIVATE_LINK_LIBRARIES StoreGateLib )
 
 atlas_add_component( TrkDetDescrSvc
                      src/components/*.cxx
diff --git a/Tracking/TrkDetDescr/TrkDetDescrSvc/TrkDetDescrSvc/TrackingGeometrySvc.h b/Tracking/TrkDetDescr/TrkDetDescrSvc/TrkDetDescrSvc/TrackingGeometrySvc.h
index 2a7bf6788b1028fe721b43e0ef8c5cc46c69b056..1de1c71903499896bbe15ccfd026660cb1a1d32e 100755
--- a/Tracking/TrkDetDescr/TrkDetDescrSvc/TrkDetDescrSvc/TrackingGeometrySvc.h
+++ b/Tracking/TrkDetDescr/TrkDetDescrSvc/TrkDetDescrSvc/TrackingGeometrySvc.h
@@ -16,8 +16,8 @@
 #include "TrkDetDescrInterfaces/IGeometryProcessor.h"
 #include "Gaudi/Property.h"
 #include "GaudiKernel/ToolHandle.h"
-#include "AthenaKernel/IOVSvcDefs.h"
 #include "AthenaBaseComps/AthService.h"
+#include "EventInfoMgt/ITagInfoMgr.h"
 
 #ifdef TRKDETDESCR_MEMUSAGE   
 #include "TrkDetDescrUtils/MemoryLogger.h"
@@ -42,8 +42,11 @@ namespace Trk {
   
       @author Andreas.Salzburger@cern.ch */
      
-  class ATLAS_NOT_THREAD_SAFE TrackingGeometrySvc : public AthService, virtual public ITrackingGeometrySvc {
-  
+  class ATLAS_NOT_THREAD_SAFE TrackingGeometrySvc :
+      public AthService,
+      virtual public ITrackingGeometrySvc,
+      virtual public ITagInfoMgr::Listener
+  {
     public:
   
       //!< Retrieve interface ID
@@ -59,8 +62,11 @@ namespace Trk {
       / N.B. Don't forget to release the interface after use!!! **/
       StatusCode queryInterface( const InterfaceID& riid, void** ppvInterface );
   
+      // TagInfoMgr callback
+      virtual void tagInfoUpdated() override final;
+
       /** Create the geometry */
-      StatusCode trackingGeometryInit(IOVSVC_CALLBACK_ARGS);
+      StatusCode trackingGeometryInit(bool needsInit = true);
   
       /** Provide the TrackingGeometry */
       const Trk::TrackingGeometry* trackingGeometry() const;
@@ -100,9 +106,6 @@ namespace Trk {
       float                                       m_changeRss   {0.0};
   #endif
       
-      Gaudi::Property<bool>                       m_callbackStringForced {this, "CallbackStringForced",false};
-      Gaudi::Property<std::string>                m_callbackString {this, "CallbackString", ""};//!< the name of the callback string
-      Gaudi::Property<bool>                       m_callbackStringCheck{this, "CallbackStringCheck", true};
       Gaudi::Property<bool>                       m_rerunOnCallback {this, "RerunOnCallback", false};
       //!< enables the callback
       Gaudi::Property<bool>                       m_buildGeometryFromTagInfo {this, "BuildGeometryFromTagInfo", true};
diff --git a/Tracking/TrkDetDescr/TrkDetDescrSvc/src/TrackingGeometrySvc.cxx b/Tracking/TrkDetDescr/TrkDetDescrSvc/src/TrackingGeometrySvc.cxx
index 51d552db99908270c207b57163a865db41f71b7a..0c3698dbad94638ecaca8fe49c68bba36a46e90d 100755
--- a/Tracking/TrkDetDescr/TrkDetDescrSvc/src/TrackingGeometrySvc.cxx
+++ b/Tracking/TrkDetDescr/TrkDetDescrSvc/src/TrackingGeometrySvc.cxx
@@ -20,14 +20,13 @@
 #include "GaudiKernel/ISvcLocator.h"
 #include "GaudiKernel/MsgStream.h"
 #include "StoreGate/StoreGateSvc.h"
-// needed for callback function
-#include "EventInfo/TagInfo.h"
 
 // monitor memory usage
 #ifdef TRKDETDESCR_MEMUSAGE   
 #include <unistd.h>
 #endif
 
+
 /** Constructor **/
 Trk::TrackingGeometrySvc::TrackingGeometrySvc(const std::string& name,ISvcLocator* svc) : 
     AthService(name,svc),
@@ -65,43 +64,36 @@ StatusCode Trk::TrackingGeometrySvc::initialize()
       return StatusCode::FAILURE;
   }
 
-  // get the key -- from StoreGate (DetectorStore)
-  std::vector< std::string > tagInfoKeys = m_pDetStore->keys<TagInfo> ();
-  std::string tagInfoKey = "";
-
-  if(tagInfoKeys.empty())   ATH_MSG_WARNING( " No TagInfo keys in DetectorStore ");
-  else {
-    if(tagInfoKeys.size() > 1) ATH_MSG_WARNING( " More than one TagInfo key in the DetectorStore, using the first one " );
-    tagInfoKey = tagInfoKeys[0];
-  }
-
-  if (!m_callbackStringForced) m_callbackString = tagInfoKey;
-        
   if (m_buildGeometryFromTagInfo){
-    // register the Callback
-    const DataHandle<TagInfo> tagInfoH;
-    if ( (m_pDetStore->regFcn(&ITrackingGeometrySvc::trackingGeometryInit,
-        dynamic_cast<ITrackingGeometrySvc*>(this),tagInfoH,m_callbackString)).isFailure() ){
-      ATH_MSG_WARNING( "Unable to register regFcn callback from DetectorStore" );
-    } 
+     ATH_MSG_INFO( "Building Geometry from TagInfo" );
+     // register a callback on TagInfo updates
+     ServiceHandle<ITagInfoMgr> tagInfoMgr("TagInfoMgr", name());
+     ATH_CHECK(tagInfoMgr.retrieve());
+     tagInfoMgr->addListener(this);
   } else {
-    ATH_MSG_INFO( "Building Geometry at initialisation time." );
-    // call with dummy parameters
-    int par1 = 0;
-    std::list<std::string> par2;
-    // build with no dependency on COOL
-    if (trackingGeometryInit(par1,par2).isFailure()) { 
-      ATH_MSG_FATAL( "Unable to build the TrackingGeometry!" );
-      return StatusCode::FAILURE;
-    }
+     ATH_MSG_INFO( "Building Geometry at initialisation time." );
+     // build with no dependency on COOL
+     if(trackingGeometryInit(false).isFailure()) {
+        ATH_MSG_FATAL( "Unable to build the TrackingGeometry!" );
+        return StatusCode::FAILURE;
+     }
   }
   ATH_MSG_INFO( "initialize() successful! " );
   return StatusCode::SUCCESS;
 }
 
 
-StatusCode Trk::TrackingGeometrySvc::trackingGeometryInit(IOVSVC_CALLBACK_ARGS_P(I,keys))
+void Trk::TrackingGeometrySvc::tagInfoUpdated()
+{
+   ATH_MSG_INFO("tagInfoUpdated() callback trigerred");
+   trackingGeometryInit().ignore();
+}
+
+
+StatusCode Trk::TrackingGeometrySvc::trackingGeometryInit(bool needsInit)
 {
+   ATH_MSG_INFO( "Trk::TrackingGeometrySvc::trackingGeometryInit" );
+
     if (m_useConditionsData) {
        ATH_MSG_FATAL("Logic error: TrackingGeometry init callback called despite being configured to use external TrackingGeometries provided by a conditions algorithm.");
     }
@@ -119,22 +111,10 @@ StatusCode Trk::TrackingGeometrySvc::trackingGeometryInit(IOVSVC_CALLBACK_ARGS_P
     if (m_pDetStore->contains<Trk::TrackingGeometry>(m_trackingGeometryName) && !m_rerunOnCallback) 
         return StatusCode::SUCCESS;
 
-    // avoid warning of unused parameter
-    (void) I;
-
-    bool needsInit = false;
-
-    if (m_callbackStringCheck) {
-        // check if the string is ESD for guaranteeing that misalignment has been introduced already
-        for (std::list<std::string>::const_iterator itr=keys.begin(); itr!=keys.end(); ++itr) {
-            if (*itr == m_callbackString) {
-                needsInit = true; break;
-            }
-        }
-    }
-
     // only build if the callback string was true
-    if (needsInit || !m_callbackStringCheck) {
+    // (MN: I set this to alwaus true if called on TagInfo update)
+    if (needsInit) {
+       ATH_MSG_INFO( "trackingGeometryInit - initialize on TagInfoMgr callback" );
         // cleanup the geometry if you have one 
         // (will delete what is in detector store, because new one will overwrite old one)
         m_trackingGeometry = nullptr;
@@ -245,7 +225,6 @@ void Trk::TrackingGeometrySvc::trackingGeometryNotSet() const {
 /** Finalize Service */
 StatusCode Trk::TrackingGeometrySvc::finalize()
 {
-
 #ifdef TRKDETDESCR_MEMUSAGE
     ATH_MSG_INFO( "[ memory usage ] Change in memory usage -------------------------------- "   );
     ATH_MSG_INFO( "[ memory usage ]    Virtual memory change (vsize) : " <<  m_changeVsize      );
diff --git a/Tracking/TrkDetDescr/TrkDetDescrUtils/TrkDetDescrUtils/BinnedArrayArray.h b/Tracking/TrkDetDescr/TrkDetDescrUtils/TrkDetDescrUtils/BinnedArrayArray.h
index 98eb72538f36747da6b93324f94308d8b9e26003..1e3940f88d034b2bd44764d2124c81a5597333f2 100644
--- a/Tracking/TrkDetDescr/TrkDetDescrUtils/TrkDetDescrUtils/BinnedArrayArray.h
+++ b/Tracking/TrkDetDescr/TrkDetDescrUtils/TrkDetDescrUtils/BinnedArrayArray.h
@@ -32,7 +32,7 @@ namespace Trk {
    */
 
 template<class T>
-class BinnedArrayArrayT : public BinnedArrayT<T>
+class BinnedArrayArrayT final: public BinnedArrayT<T>
 {
 
 public:
diff --git a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SlidingCylinderSurface.h b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SlidingCylinderSurface.h
index 3e85e902b6031ba66afb976ddae407845d3b0c22..8d2e901d0ff05331f3d463430d780f1156ede0e9 100644
--- a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SlidingCylinderSurface.h
+++ b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SlidingCylinderSurface.h
@@ -57,7 +57,7 @@ public:
   SlidingCylinderSurface& operator=(const SlidingCylinderSurface& psf);
 
   /**Equality operator*/
-  virtual bool operator==(const Surface& sf) const override;
+  virtual bool operator==(const Surface& sf) const override final;
 
   /** This method returns true if the GlobalPosition is on the Surface for both,
     within or without check of whether the local position is inside boundaries
@@ -65,31 +65,31 @@ public:
   virtual bool isOnSurface(const Amg::Vector3D& glopo,
                            BoundaryCheck bchk = true,
                            double tol1 = 0.,
-                           double tol2 = 0.) const override;
+                           double tol2 = 0.) const override final;
 
   /** Specialized for DiscSurface: LocalToGlobal method without dynamic memory
    * allocation */
   virtual void localToGlobal(const Amg::Vector2D& locp,
                              const Amg::Vector3D& mom,
-                             Amg::Vector3D& glob) const override;
+                             Amg::Vector3D& glob) const override final;
 
   /** Specialized for DiscSurface: GlobalToLocal method without dynamic memory
    * allocation - boolean checks if on surface
    */
   virtual bool globalToLocal(const Amg::Vector3D& glob,
                              const Amg::Vector3D& mom,
-                             Amg::Vector2D& loc) const override;
+                             Amg::Vector2D& loc) const override final;
 
   /** fast straight line distance evaluation to Surface */
   virtual DistanceSolution straightLineDistanceEstimate(
     const Amg::Vector3D& pos,
-    const Amg::Vector3D& dir) const override;
+    const Amg::Vector3D& dir) const override final;
 
   /** fast straight line distance evaluation to Surface - with bound option*/
   virtual DistanceSolution straightLineDistanceEstimate(
     const Amg::Vector3D& pos,
     const Amg::Vector3D& dir,
-    bool Bound) const override;
+    bool Bound) const override final;
 
   /**This method allows access to the bin utility*/
   const Trk::BinUtility* binUtility() const { return m_etaBin; }
diff --git a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SlidingDiscSurface.h b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SlidingDiscSurface.h
index bb73a4b58aaaadef2547133ed8247ee78c9e6ac3..7c31a6971978de089d037aff569e040c28b2a67f 100644
--- a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SlidingDiscSurface.h
+++ b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SlidingDiscSurface.h
@@ -77,10 +77,10 @@ public:
   SlidingDiscSurface& operator=(const SlidingDiscSurface& dsf);
 
   /**Equality operator*/
-  virtual bool operator==(const Surface& sf) const override;
+  virtual bool operator==(const Surface& sf) const override final;
 
   /** Virtual constructor*/
-  virtual SlidingDiscSurface* clone() const override;
+  virtual SlidingDiscSurface* clone() const override final;
 
   /** This method returns true if the GlobalPosition is on the Surface for both,
     within or without check of whether the local position is inside boundaries
@@ -88,20 +88,20 @@ public:
   virtual bool isOnSurface(const Amg::Vector3D& glopo,
                            BoundaryCheck bchk = true,
                            double tol1 = 0.,
-                           double tol2 = 0.) const override;
+                           double tol2 = 0.) const override final;
 
   /** Specialized for DiscSurface: LocalToGlobal method without dynamic memory
    * allocation */
   virtual void localToGlobal(const Amg::Vector2D& locp,
                              const Amg::Vector3D& mom,
-                             Amg::Vector3D& glob) const override;
+                             Amg::Vector3D& glob) const override final;
 
   /** Specialized for DiscSurface: GlobalToLocal method without dynamic memory
    * allocation - boolean checks if on surface
    */
   virtual bool globalToLocal(const Amg::Vector3D& glob,
                              const Amg::Vector3D& mom,
-                             Amg::Vector2D& loc) const override;
+                             Amg::Vector2D& loc) const override final;
 
   /** fast straight line intersection schema - standard: provides closest
      intersection and (signed) path length forceDir is to provide the closest
@@ -127,13 +127,13 @@ public:
   /** fast straight line distance evaluation to Surface */
   virtual DistanceSolution straightLineDistanceEstimate(
     const Amg::Vector3D& pos,
-    const Amg::Vector3D& dir) const override;
+    const Amg::Vector3D& dir) const override final;
 
   /** fast straight line distance evaluation to Surface - with bound option*/
   virtual DistanceSolution straightLineDistanceEstimate(
     const Amg::Vector3D& pos,
     const Amg::Vector3D& dir,
-    bool Bound) const override;
+    bool Bound) const override final;
 
   /**This method allows access to the bin utility*/
   const Trk::BinUtility* binUtility() const { return m_etaBin; }
diff --git a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedCylinderSurface.h b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedCylinderSurface.h
index 15c897631148786354e0b3a8f69f12892a1bc397..6d701a72ddf3c1a8a2b175d1750bbc24d47bfaaf 100644
--- a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedCylinderSurface.h
+++ b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedCylinderSurface.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 ///////////////////////////////////////////////////////////////////
@@ -51,56 +51,30 @@ public:
   SubtractedCylinderSurface& operator=(const SubtractedCylinderSurface& psf);
 
   /**Equality operator*/
-  bool operator==(const Surface& sf) const;
+  virtual bool operator==(const Surface& sf) const override final;
 
   /** This method indicates the subtraction mode */
   bool shared() const;
 
   /**This method calls the inside() method of the Bounds*/
-  bool insideBounds(const Amg::Vector2D& locpos, double tol1 = 0., double tol2 = 0.) const;
+  virtual bool insideBounds(const Amg::Vector2D& locpos,
+                            double tol1 = 0.,
+                            double tol2 = 0.) const override final;
 
   /**This method allows access to the subtracted part*/
   SharedObject<AreaExcluder> subtractedVolume() const;
 
   /** Return properly formatted class name for screen output */
-  std::string name() const { return "Trk::SubtractedCylinderSurface"; }
+  virtual std::string name() const override final
+  {
+    return "Trk::SubtractedCylinderSurface";
+  }
 
 protected:
   SharedObject<AreaExcluder> m_subtrVol;
   bool m_shared;
 };
-
-inline bool
-SubtractedCylinderSurface::insideBounds(const Amg::Vector2D& locpos, double tol1, double tol2) const
-{
-  // no subtracted volume exists
-  if (!m_subtrVol.get())
-    return (this->bounds().inside(locpos, tol1, tol2));
-  // subtracted volume exists, needs to be checked
-  double rCyl = bounds().r();
-  double phiPos = locpos[Trk::locRPhi] / rCyl;
-  const Amg::Vector3D gp(rCyl * cos(phiPos), rCyl * sin(phiPos), locpos[Trk::locZ]);
-
-  bool inside_shared(this->bounds().inside(locpos, tol1, tol2) && m_subtrVol.get()->inside(gp, 0.));
-  bool inside(this->bounds().inside(locpos, tol1, tol2) && !m_subtrVol.get()->inside(gp, 0.));
-
-  if (m_shared)
-    return inside_shared;
-  return inside;
-}
-
-inline bool
-SubtractedCylinderSurface::shared() const
-{
-  return m_shared;
-}
-
-inline SharedObject<AreaExcluder>
-SubtractedCylinderSurface::subtractedVolume() const
-{
-  return m_subtrVol;
-}
-
 } // end of namespace
 
+#include "TrkGeometrySurfaces/SubtractedCylinderSurface.icc"
 #endif // TRKGEOMETRYSURFACES_SUBTRACTEDCYLINDERSURFACE_H
diff --git a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedCylinderSurface.icc b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedCylinderSurface.icc
new file mode 100644
index 0000000000000000000000000000000000000000..119c6af3adbf04cf0ea26265828fa65faa81dbf6
--- /dev/null
+++ b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedCylinderSurface.icc
@@ -0,0 +1,41 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
+namespace Trk {
+inline bool
+SubtractedCylinderSurface::insideBounds(const Amg::Vector2D& locpos,
+                                        double tol1,
+                                        double tol2) const
+{
+  // no subtracted volume exists
+  if (!m_subtrVol.get())
+    return (this->bounds().inside(locpos, tol1, tol2));
+  // subtracted volume exists, needs to be checked
+  double rCyl = bounds().r();
+  double phiPos = locpos[Trk::locRPhi] / rCyl;
+  const Amg::Vector3D gp(
+    rCyl * cos(phiPos), rCyl * sin(phiPos), locpos[Trk::locZ]);
+
+  bool inside_shared(this->bounds().inside(locpos, tol1, tol2) &&
+                     m_subtrVol.get()->inside(gp, 0.));
+  bool inside(this->bounds().inside(locpos, tol1, tol2) &&
+              !m_subtrVol.get()->inside(gp, 0.));
+
+  if (m_shared)
+    return inside_shared;
+  return inside;
+}
+
+inline bool
+SubtractedCylinderSurface::shared() const
+{
+  return m_shared;
+}
+
+inline SharedObject<AreaExcluder>
+SubtractedCylinderSurface::subtractedVolume() const
+{
+  return m_subtrVol;
+}
+}
diff --git a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedPlaneSurface.h b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedPlaneSurface.h
index f089c6e90529ed216b6af031556a993a32ed6375..657383585b75457dd44a191cd93af73c109eca2c 100644
--- a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedPlaneSurface.h
+++ b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedPlaneSurface.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 ///////////////////////////////////////////////////////////////////
@@ -50,52 +50,30 @@ public:
   SubtractedPlaneSurface& operator=(const SubtractedPlaneSurface& psf);
 
   /**Equality operator*/
-  bool operator==(const Surface& sf) const;
+  virtual bool operator==(const Surface& sf) const override final;
 
   /** This method indicates the subtraction mode */
   bool shared() const;
 
   /**This method calls the inside() method of the Bounds*/
-  bool insideBounds(const Amg::Vector2D& locpos, double tol1 = 0., double tol2 = 0.) const;
+  virtual bool insideBounds(const Amg::Vector2D& locpos,
+                            double tol1 = 0.,
+                            double tol2 = 0.) const override final;
 
   /**This method allows access to the subtracted part*/
   SharedObject<AreaExcluder> subtractedVolume() const;
 
   /** Return properly formatted class name for screen output */
-  std::string name() const { return "Trk::SubtractedPlaneSurface"; }
+  virtual std::string name() const override final
+  {
+    return "Trk::SubtractedPlaneSurface";
+  }
 
 protected:
   SharedObject<AreaExcluder> m_subtrVol;
   bool m_shared;
 };
 
-inline bool
-SubtractedPlaneSurface::insideBounds(const Amg::Vector2D& locpos, double tol1, double tol2) const
-{
-  // no subtracted volume exists
-  if (!m_subtrVol.get())
-    return (this->bounds().inside(locpos, tol1, tol2));
-  // subtracted volume exists, needs to be checked
-  Amg::Vector3D gp(locpos.x(), locpos.y(), 0.);
-  if (m_shared)
-    return (this->bounds().inside(locpos, tol1, tol2) && m_subtrVol.get()->inside(gp, 0.));
-  bool in(this->bounds().inside(locpos, tol1, tol2) && !m_subtrVol.get()->inside(gp, 0.));
-
-  return in;
-}
-
-inline bool
-SubtractedPlaneSurface::shared() const
-{
-  return m_shared;
-}
-
-inline SharedObject<AreaExcluder>
-SubtractedPlaneSurface::subtractedVolume() const
-{
-  return m_subtrVol;
-}
-
 } // end of namespace
-
+#include "TrkGeometrySurfaces/SubtractedPlaneSurface.icc"
 #endif // TRKGEOMETRYSURFACES_SUBTRACTEDPLANESURFACE_H
diff --git a/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedPlaneSurface.icc b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedPlaneSurface.icc
new file mode 100644
index 0000000000000000000000000000000000000000..529c21446b371a4ac31348ab00ae8861798ecb4c
--- /dev/null
+++ b/Tracking/TrkDetDescr/TrkGeometrySurfaces/TrkGeometrySurfaces/SubtractedPlaneSurface.icc
@@ -0,0 +1,39 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
+namespace Trk {
+inline bool
+SubtractedPlaneSurface::insideBounds(const Amg::Vector2D& locpos,
+                                     double tol1,
+                                     double tol2) const
+{
+  // no subtracted volume exists
+  if (!m_subtrVol.get()){
+    return (this->bounds().inside(locpos, tol1, tol2));
+  }
+  // subtracted volume exists, needs to be checked
+  Amg::Vector3D gp(locpos.x(), locpos.y(), 0.);
+  if (m_shared){
+    return (this->bounds().inside(locpos, tol1, tol2) &&
+            m_subtrVol.get()->inside(gp, 0.));
+  }
+  bool in(this->bounds().inside(locpos, tol1, tol2) &&
+          !m_subtrVol.get()->inside(gp, 0.));
+
+  return in;
+}
+
+inline bool
+SubtractedPlaneSurface::shared() const
+{
+  return m_shared;
+}
+
+inline SharedObject<AreaExcluder>
+SubtractedPlaneSurface::subtractedVolume() const
+{
+  return m_subtrVol;
+}
+}
+
diff --git a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryCylinderSurface.h b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryCylinderSurface.h
index 6ae1a5b5e9c1d0b65e2d3ce1564f93fab1c4c7e5..2fa158ef532e0da71d0b77dc126b0a6ee6b375b7 100755
--- a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryCylinderSurface.h
+++ b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryCylinderSurface.h
@@ -31,7 +31,7 @@ class Volume;
    @author Andreas.Salzburger@cern.ch
    */
       
-  template <class Tvol> class BoundaryCylinderSurface : 
+  template <class Tvol> class BoundaryCylinderSurface final: 
                               virtual public BoundarySurface<Tvol>, public CylinderSurface {
   
     /** typedef the BinnedArray */
@@ -68,24 +68,28 @@ class Volume;
        BoundarySurface<Tvol>(inside,outside),
        CylinderSurface(csf,tr)
      {}
-          
+
      /**Virtual Destructor*/
-     virtual ~BoundaryCylinderSurface()
-     {}
-     
-     /** Get the next Volume depending on the TrackParameters and the requested direction,
-         gives back 0 if there's no volume attached to the requested direction
-         - this is speed optimized as it doesn't invoke a local to global transformation
+     virtual ~BoundaryCylinderSurface() = default;
+
+     /** Get the next Volume depending on the TrackParameters and the requested
+        direction, gives back 0 if there's no volume attached to the requested
+        direction
+         - this is speed optimized as it doesn't invoke a local to global
+        transformation
        */
-     const Tvol* attachedVolume(const TrackParameters& parms, PropDirection dir) const override;  
-       
+     virtual const Tvol* attachedVolume(const TrackParameters& parms,
+                                        PropDirection dir) const override final;
+
      /** Get the next Volume depending on position, momentum, dir
       on the TrackParameters and the requested direction */
-     const Tvol* attachedVolume(const Amg::Vector3D& pos, const Amg::Vector3D& mom, PropDirection dir) const override;
-                                          
+     virtual const Tvol* attachedVolume(const Amg::Vector3D& pos,
+                                        const Amg::Vector3D& mom,
+                                        PropDirection dir) const override final;
+
      /** The Surface Representation of this */
-     const Surface& surfaceRepresentation() const override;
-     
+     virtual const Surface& surfaceRepresentation() const override final;
+
      /**Assignment operator*/
      BoundaryCylinderSurface& operator=(const BoundaryCylinderSurface& vol);
      
diff --git a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryDiscSurface.h b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryDiscSurface.h
index f7e16a68bb01c548532b6e60c786ddfb9255fe52..2e4e32b35fc1c5cb16394c661d238025f0ae78ce 100755
--- a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryDiscSurface.h
+++ b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryDiscSurface.h
@@ -35,7 +35,7 @@ class Volume;
     @author Andreas.Salzburger@cern.ch 
    */
   
-  template <class Tvol> class BoundaryDiscSurface : 
+  template <class Tvol> class BoundaryDiscSurface final: 
                        virtual public BoundarySurface<Tvol>, public DiscSurface {
                            
     /** typedef the BinnedArray */
@@ -70,24 +70,29 @@ class Volume;
      BoundaryDiscSurface(const Tvol* inside, const Tvol* outside, const DiscSurface& dsf, const Amg::Transform3D& tr) :
        BoundarySurface<Tvol>(inside,outside),
        DiscSurface(dsf,tr)
-     {}     
-     
-     /** Get the next Volume depending on the TrackParameters and the requested direction,
-         gives back 0 if there's no volume attached to the requested direction
-         - this is speed optimized as it doesn't invoke a local to global transformation
+     {}
+
+     /** Get the next Volume depending on the TrackParameters and the requested
+        direction, gives back 0 if there's no volume attached to the requested
+        direction
+         - this is speed optimized as it doesn't invoke a local to global
+        transformation
       */
-     const Tvol* attachedVolume(const TrackParameters& parms, PropDirection dir) const override;
-         
+     virtual const Tvol* attachedVolume(const TrackParameters& parms,
+                                        PropDirection dir) const override final;
+
      /** Get the next Volume depending on GlobalPosition, GlobalMomentum, dir
       on the TrackParameters and the requested direction */
-     const Tvol* attachedVolume(const Amg::Vector3D& pos, const Amg::Vector3D& mom, PropDirection dir) const override;
-          
+     virtual const Tvol* attachedVolume(const Amg::Vector3D& pos,
+                                        const Amg::Vector3D& mom,
+                                        PropDirection dir) const override final;
+
      /** The Surface Representation of this */
-     const Surface& surfaceRepresentation() const override;
-     
+     virtual const Surface& surfaceRepresentation() const override final;
+
      /**Virtual Destructor*/
-     virtual ~BoundaryDiscSurface(){}
-     
+     virtual ~BoundaryDiscSurface() = default;
+
      /**Assignment operator*/
      BoundaryDiscSurface& operator=(const BoundaryDiscSurface& vol);
              
diff --git a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryPlaneSurface.h b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryPlaneSurface.h
index 14778cf094a7a83f7a83740c401d4619fb433bbf..c56d5f389a69d2fac569c4bacd6f8eb4aa3bdb24 100755
--- a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryPlaneSurface.h
+++ b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundaryPlaneSurface.h
@@ -34,7 +34,7 @@ class Volume;
    @author Andreas.Salzburger@cern.ch 
   */
   
-  template <class Tvol> class BoundaryPlaneSurface : 
+  template <class Tvol> class BoundaryPlaneSurface final: 
                                virtual public BoundarySurface<Tvol>, public PlaneSurface {
 
     /** typedef the BinnedArray */
@@ -69,23 +69,27 @@ class Volume;
      BoundaryPlaneSurface(const Tvol* inside, const Tvol* outside, const PlaneSurface& psf, const Amg::Transform3D& tr) :
        BoundarySurface<Tvol>(inside,outside),
        PlaneSurface(psf,tr)
-     {}     
-     
-     /** Get the next Volume depending on the TrackParameters and the requested direction,
-      gives back 0 if there's no volume attached to the requested direction
+     {}
+
+     /** Get the next Volume depending on the TrackParameters and the requested
+      direction, gives back 0 if there's no volume attached to the requested
+      direction
       */
-     const Tvol* attachedVolume(const TrackParameters& parms, PropDirection dir) const override;    
-     
+     virtual const Tvol* attachedVolume(const TrackParameters& parms,
+                                        PropDirection dir) const override final;
+
      /** Get the next Volume depending on GlobalPosition, GlobalMomentum, dir
       on the TrackParameters and the requested direction */
-     const Tvol* attachedVolume(const Amg::Vector3D& pos, const Amg::Vector3D& mom, PropDirection dir) const override;
-     
+     virtual const Tvol* attachedVolume(const Amg::Vector3D& pos,
+                                        const Amg::Vector3D& mom,
+                                        PropDirection dir) const override final;
+
      /** The Surface Representation of this */
-     const Surface& surfaceRepresentation() const override;
-     
+     virtual const Surface& surfaceRepresentation() const override final;
+
      /**Virtual Destructor*/
-     virtual ~BoundaryPlaneSurface(){}
-     
+     virtual ~BoundaryPlaneSurface() = default;
+
      /**Assignment operator*/
      BoundaryPlaneSurface& operator=(const BoundaryPlaneSurface& vol);
          
diff --git a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundarySubtractedCylinderSurface.h b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundarySubtractedCylinderSurface.h
index b4f8b9649d0fea549e9ee88cf9e3bc8303473f83..c4dc325cd426977b7a4828d5f3552eccb0df906e 100755
--- a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundarySubtractedCylinderSurface.h
+++ b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundarySubtractedCylinderSurface.h
@@ -32,7 +32,7 @@ class Volume;
    @author Andreas.Salzburger@cern.ch
    */
       
-  template <class Tvol> class BoundarySubtractedCylinderSurface : 
+  template <class Tvol> class BoundarySubtractedCylinderSurface final: 
                               virtual public BoundarySurface<Tvol>, public SubtractedCylinderSurface {
   
     /** typedef the BinnedArray */
@@ -70,22 +70,24 @@ class Volume;
      {}     
      
      /**Virtual Destructor*/
-     virtual ~BoundarySubtractedCylinderSurface()
-     {}
+     virtual ~BoundarySubtractedCylinderSurface() = default;
      
      /** Get the next Volume depending on the TrackParameters and the requested direction,
          gives back 0 if there's no volume attached to the requested direction
          - this is speed optimized as it doesn't invoke a local to global transformation
        */
-     const Tvol* attachedVolume(const TrackParameters& parms, PropDirection dir) const override;    
-     
+     virtual const Tvol* attachedVolume(const TrackParameters& parms,
+                                        PropDirection dir) const override final;
+
      /** Get the next Volume depending on GlobalPosition, GlobalMomentum, dir
       on the TrackParameters and the requested direction */
-     const Tvol* attachedVolume(const Amg::Vector3D& pos, const Amg::Vector3D& mom, PropDirection dir) const override;
-                                          
+     virtual const Tvol* attachedVolume(const Amg::Vector3D& pos,
+                                        const Amg::Vector3D& mom,
+                                        PropDirection dir) const override final;
+
      /** The Surface Representation of this */
-     const Surface& surfaceRepresentation() const override;
-     
+     virtual const Surface& surfaceRepresentation() const override final;
+
      /**Assignment operator*/
      BoundarySubtractedCylinderSurface& operator=(const BoundarySubtractedCylinderSurface& vol);
      
diff --git a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundarySubtractedPlaneSurface.h b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundarySubtractedPlaneSurface.h
index 9dbf5910002dc1eb5326dc3612be539088a6e368..c4b4993d67156c1a6902444b299d1b8b31fe0683 100755
--- a/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundarySubtractedPlaneSurface.h
+++ b/Tracking/TrkDetDescr/TrkVolumes/TrkVolumes/BoundarySubtractedPlaneSurface.h
@@ -33,7 +33,7 @@ class Volume;
    @author Sarka.Todorova@cern.ch 
   */
   
-  template <class Tvol> class BoundarySubtractedPlaneSurface : 
+  template <class Tvol> class BoundarySubtractedPlaneSurface final: 
                                virtual public BoundarySurface<Tvol>, public SubtractedPlaneSurface {
 
     /** typedef the BinnedArray */
@@ -68,22 +68,26 @@ class Volume;
      BoundarySubtractedPlaneSurface(const Tvol* inside, const Tvol* outside, const SubtractedPlaneSurface& psf, const Amg::Transform3D& tr) :
        BoundarySurface<Tvol>(inside,outside),
        SubtractedPlaneSurface(psf,tr)
-     {}     
-     
-     /** Get the next Volume depending on the TrackParameters and the requested direction,
-      gives back 0 if there's no volume attached to the requested direction
+     {}
+
+     /** Get the next Volume depending on the TrackParameters and the requested
+      direction, gives back 0 if there's no volume attached to the requested
+      direction
       */
-     const Tvol* attachedVolume(const TrackParameters& parms, PropDirection dir) const override;    
-     
+     virtual const Tvol* attachedVolume(const TrackParameters& parms,
+                                        PropDirection dir) const override final;
+
      /** Get the next Volume depending on GlobalPosition, GlobalMomentum, dir
       on the TrackParameters and the requested direction */
-     const Tvol* attachedVolume(const Amg::Vector3D& pos, const Amg::Vector3D& mom, PropDirection dir) const override;
-     
+     virtual const Tvol* attachedVolume(const Amg::Vector3D& pos,
+                                        const Amg::Vector3D& mom,
+                                        PropDirection dir) const override final;
+
      /** The Surface Representation of this */
-     const Surface& surfaceRepresentation() const override;
-     
+     virtual const Surface& surfaceRepresentation() const override final;
+
      /**Virtual Destructor*/
-     virtual ~BoundarySubtractedPlaneSurface(){}
+     virtual ~BoundarySubtractedPlaneSurface() = default;
 
      /**Assignment operator*/
      BoundarySubtractedPlaneSurface& operator=(const BoundarySubtractedPlaneSurface& vol);
diff --git a/Tracking/TrkExtrapolation/TrkExRungeKuttaIntersector/src/RungeKuttaIntersector.cxx b/Tracking/TrkExtrapolation/TrkExRungeKuttaIntersector/src/RungeKuttaIntersector.cxx
index 3d03b69aaf4fe0adc7fb1afdb8d609ec66fbdc7e..022ab47d4f78c696c5bcea1bb49da0a7e2148fdf 100755
--- a/Tracking/TrkExtrapolation/TrkExRungeKuttaIntersector/src/RungeKuttaIntersector.cxx
+++ b/Tracking/TrkExtrapolation/TrkExRungeKuttaIntersector/src/RungeKuttaIntersector.cxx
@@ -81,7 +81,7 @@ RungeKuttaIntersector::RungeKuttaIntersector (const std::string&	type,
 StatusCode
 RungeKuttaIntersector::initialize(){
     // print name and package version
-    ATH_MSG_DEBUG( "RungeKuttaIntersector::initialize()" << " - package version " << PACKAGE_VERSION );
+    ATH_MSG_DEBUG( "RungeKuttaIntersector::initialize()" );
 
     // initialize base class
     if (StatusCode::SUCCESS != AlgTool::initialize()) return StatusCode::FAILURE;
@@ -107,9 +107,9 @@ RungeKuttaIntersector::initialize(){
 StatusCode
 RungeKuttaIntersector::finalize()
 {
-    msg(MSG::INFO)  << "finalized after " << m_countExtrapolations << " extrapolations,";
     if (m_countExtrapolations)
     {
+    msg(MSG::INFO)  << "finalized after " << m_countExtrapolations << " extrapolations,";
 	double norm = 1./static_cast<double>(m_countExtrapolations);
 	msg(MSG::INFO)   << std::setiosflags(std::ios::fixed)
 			 << " taking an average" << std::setw(7) << std::setprecision(1)
diff --git a/Tracking/TrkExtrapolation/TrkExSolenoidalIntersector/src/SolenoidalIntersector.cxx b/Tracking/TrkExtrapolation/TrkExSolenoidalIntersector/src/SolenoidalIntersector.cxx
index a16fc7b52090d259df8392983554f3c9b3d37c99..ed142d802a30dd85766154904e61cf288b8bb1b0 100755
--- a/Tracking/TrkExtrapolation/TrkExSolenoidalIntersector/src/SolenoidalIntersector.cxx
+++ b/Tracking/TrkExtrapolation/TrkExSolenoidalIntersector/src/SolenoidalIntersector.cxx
@@ -53,8 +53,6 @@ SolenoidalIntersector::SolenoidalIntersector (const std::string&	type,
 StatusCode
 SolenoidalIntersector::initialize()
 {
-    // print name and package version
-    ATH_MSG_INFO( "SolenoidalIntersector::initialize() - package version " << PACKAGE_VERSION );
     ATH_CHECK( m_solenoidParametrizationKey.initialize() );
     ATH_CHECK(m_rungeKuttaIntersector.retrieve());
     return StatusCode::SUCCESS;
@@ -63,7 +61,7 @@ SolenoidalIntersector::initialize()
 StatusCode
 SolenoidalIntersector::finalize()
 {
-    ATH_MSG_INFO( "finalized after " << m_countExtrapolations << " extrapolations with "
+    ATH_MSG_DEBUG( "finalized after " << m_countExtrapolations << " extrapolations with "
 		  << m_countRKSwitches << " switches to RK integration");
 
     return StatusCode::SUCCESS;
diff --git a/Tracking/TrkExtrapolation/TrkExStraightLineIntersector/TrkExStraightLineIntersector/StraightLineIntersector.h b/Tracking/TrkExtrapolation/TrkExStraightLineIntersector/TrkExStraightLineIntersector/StraightLineIntersector.h
index 37ca2bfa21be21cb5b78ac78e162a2794ac8912a..4e589d59d2a5788a117580e40c606f7bfcb41e5e 100755
--- a/Tracking/TrkExtrapolation/TrkExStraightLineIntersector/TrkExStraightLineIntersector/StraightLineIntersector.h
+++ b/Tracking/TrkExtrapolation/TrkExStraightLineIntersector/TrkExStraightLineIntersector/StraightLineIntersector.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017, 2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2017, 2019, 2020 CERN for the benefit of the ATLAS collaboration
 */
 
 //////////////////////////////////////////////////////////////////////
@@ -26,9 +26,7 @@ public:
     StraightLineIntersector	(const std::string& type, 
 				 const std::string& name,
 				 const IInterface* parent);
-    virtual ~StraightLineIntersector	(void); 	// destructor
 
-    virtual StatusCode			initialize() override;
     virtual StatusCode			finalize() override;
 
     /**IIntersector interface method for general Surface type */
diff --git a/Tracking/TrkExtrapolation/TrkExStraightLineIntersector/src/StraightLineIntersector.cxx b/Tracking/TrkExtrapolation/TrkExStraightLineIntersector/src/StraightLineIntersector.cxx
index a0865085d256749f50aed63efc064b7f80a4cdd7..4018678046a16aca24a12714ac5f56df71df3c75 100755
--- a/Tracking/TrkExtrapolation/TrkExStraightLineIntersector/src/StraightLineIntersector.cxx
+++ b/Tracking/TrkExtrapolation/TrkExStraightLineIntersector/src/StraightLineIntersector.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017, 2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2017, 2019, 2020 CERN for the benefit of the ATLAS collaboration
 */
 
 //////////////////////////////////////////////////////////////////////
@@ -32,26 +32,10 @@ StraightLineIntersector::StraightLineIntersector (const std::string&	type,
 {
 }
 
-StraightLineIntersector::~StraightLineIntersector (void)
-{}
- 
-StatusCode
-StraightLineIntersector::initialize()
-{
-    // print name and package version
-    ATH_MSG_INFO( "StraightLineIntersector::initialize()"
-		  << " - package version " << PACKAGE_VERSION );
-
-    // initialize base class
-    if (StatusCode::SUCCESS != AlgTool::initialize()) return StatusCode::FAILURE;
-
-    return StatusCode::SUCCESS;
-}
-
 StatusCode
 StraightLineIntersector::finalize()
 {
-    ATH_MSG_INFO( "finalized after " << m_countExtrapolations << " extrapolations" );
+    ATH_MSG_DEBUG( "finalized after " << m_countExtrapolations << " extrapolations" );
 
     return StatusCode::SUCCESS;
 }
diff --git a/Tracking/TrkFitter/TrkiPatFitter/src/MaterialAllocator.cxx b/Tracking/TrkFitter/TrkiPatFitter/src/MaterialAllocator.cxx
index 427273883f54cd27f2a952a6f8460676374c8caa..ce3c21a6eed06743426943cd89bb29e6b01152a9 100755
--- a/Tracking/TrkFitter/TrkiPatFitter/src/MaterialAllocator.cxx
+++ b/Tracking/TrkFitter/TrkiPatFitter/src/MaterialAllocator.cxx
@@ -82,8 +82,6 @@ namespace Trk
 
   StatusCode
   MaterialAllocator::initialize() {
-    // print name and package version
-    ATH_MSG_INFO("MaterialAllocator::initialize() - package version " << PACKAGE_VERSION);
 
     // fill WARNING messages
     m_messageHelper->setMaxNumberOfMessagesPrinted(m_maxWarnings);
@@ -99,45 +97,30 @@ namespace Trk
     m_messageHelper->setMessage(5, "spectrometerMaterial: extrapolateM finds no material on track");
 
     // retrieve the necessary Extrapolators (muon tracking geometry is very picky!)
-    if (m_extrapolator.retrieve().isFailure()) {
-      ATH_MSG_FATAL("Failed to retrieve tool " << m_extrapolator);
-      return StatusCode::FAILURE;
-    } 
-      ATH_MSG_INFO("Retrieved tool " << m_extrapolator);
-    
-    if (m_intersector.retrieve().isFailure()) {
-      ATH_MSG_FATAL("Failed to retrieve tool " << m_intersector);
-      return StatusCode::FAILURE;
-    } 
-      ATH_MSG_INFO("Retrieved tool " << m_intersector);
+    ATH_CHECK( m_extrapolator.retrieve() );
+    ATH_MSG_DEBUG("Retrieved tool " << m_extrapolator);
     
+    ATH_CHECK( m_intersector.retrieve() );
+    ATH_MSG_DEBUG("Retrieved tool " << m_intersector);
 
     // retrieve services
-    if (m_trackingGeometrySvc.retrieve().isFailure()) {
-      ATH_MSG_FATAL("Failed to retrieve Svc " << m_trackingGeometrySvc);
-      return StatusCode::FAILURE;
-    } 
-      ATH_MSG_INFO("Retrieved Svc " << m_trackingGeometrySvc);
+    ATH_CHECK( m_trackingGeometrySvc.retrieve() );
+    ATH_MSG_DEBUG("Retrieved Svc " << m_trackingGeometrySvc);
     
-
     // need to create the IndetExit and MuonEntrance TrackingVolumes
-    if (m_trackingVolumesSvc.retrieve().isFailure()) {
-      ATH_MSG_FATAL("Failed to retrieve Svc " << m_trackingVolumesSvc);
-      return StatusCode::FAILURE;
-    } 
-      ATH_MSG_INFO("Retrieved Svc " << m_trackingVolumesSvc);
-      m_calorimeterVolume = new Volume(
+    ATH_CHECK( m_trackingVolumesSvc.retrieve() );
+    ATH_MSG_DEBUG("Retrieved Svc " << m_trackingVolumesSvc);
+    m_calorimeterVolume = new Volume(
         m_trackingVolumesSvc->volume(ITrackingVolumesSvc::MuonSpectrometerEntryLayer));
-      m_indetVolume = new Volume(
+    m_indetVolume = new Volume(
         m_trackingVolumesSvc->volume(ITrackingVolumesSvc::CalorimeterEntryLayer));
-    
 
     if (m_useStepPropagator > 0 && m_stepPropagator.retrieve().isFailure()) {
       ATH_MSG_FATAL("Failed to retrieve Svc " << m_stepPropagator);
       return StatusCode::FAILURE;
     }
 
-// Field for StepPropagator
+    // Field for StepPropagator
     m_stepField = Trk::MagneticFieldProperties(Trk::FullField);
     if (m_useStepPropagator == 2) m_stepField = Trk::MagneticFieldProperties(Trk::FastField);
 
@@ -146,7 +129,6 @@ namespace Trk
 
   StatusCode
   MaterialAllocator::finalize() {
-    ATH_MSG_INFO("finalize() ");
 
     // summarize WARNINGs
     m_messageHelper->printSummary();
diff --git a/Tracking/TrkTools/TrkToolInterfaces/TrkToolInterfaces/IExtendedTrackSummaryHelperTool.h b/Tracking/TrkTools/TrkToolInterfaces/TrkToolInterfaces/IExtendedTrackSummaryHelperTool.h
index 2fd7cec77d5d10f0f218c95046da7f958cd5b6a9..2bb75e741c86e2a664f387312e10549cf1cb37ab 100644
--- a/Tracking/TrkTools/TrkToolInterfaces/TrkToolInterfaces/IExtendedTrackSummaryHelperTool.h
+++ b/Tracking/TrkTools/TrkToolInterfaces/TrkToolInterfaces/IExtendedTrackSummaryHelperTool.h
@@ -37,21 +37,13 @@ namespace Trk {
   {
   public:
     static const InterfaceID& interfaceID();
-
-    /** fill 'information' and 'hitpattern' using information from 'rot'. Should
-      be overloaded by concrete TrackSummaryHelperTools. It is mandatory that
-      the RIO_OnTrack* points to exactly the object contained inside the
-      TrackStateOnSurface. This is to avoid that the RTTI from the
-      TrackSummaryTool is done twice.
-      */
-    using ITrackSummaryHelperTool::analyse;
-    using ITrackSummaryHelperTool::updateSharedHitCount;
     using ITrackSummaryHelperTool::addDetailedTrackSummary;
+    using ITrackSummaryHelperTool::analyse;
 
-    /*
-     * First the context aware methods.
-     * If this set is not overloaded , it
-     * will call the methods without EventContext
+    /* Expand/Extend the interface , with methods  using the EventContext
+     * and Trk::PRDtoTrackMap.
+     * For now due to compatibility we provide a default  implementation
+     * in terms of the the older interface
      */
 
     virtual void analyse(
@@ -63,9 +55,10 @@ namespace Trk {
       std::vector<int>& information,
       std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const
     {
-      (void)(ctx);
-      analyse(track, prd_to_track_map, rot, tsos, information, hitPattern);
-    }
+      (void)ctx;
+      (void) prd_to_track_map;
+      analyse(track, rot, tsos, information, hitPattern);
+    };
 
     virtual void analyse(
       const EventContext& ctx,
@@ -76,27 +69,48 @@ namespace Trk {
       std::vector<int>& information,
       std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const
     {
-      (void)(ctx);
-      analyse(track, prd_to_track_map, crot, tsos, information, hitPattern);
+      (void)ctx;
+      (void)prd_to_track_map;
+      analyse(track, crot, tsos, information, hitPattern);
     }
 
+    virtual void addDetailedTrackSummary(const EventContext& ctx,
+                                         const Track& track,
+                                         Trk::TrackSummary& summary) const
+    {
+      (void)ctx;
+      addDetailedTrackSummary(track,summary);
+    };
+    virtual void updateSharedHitCount(
+      const Trk::Track&,
+      const Trk::PRDtoTrackMap*,
+      Trk::TrackSummary&) const {};
+
+    virtual void updateExpectedHitInfo(const Trk::Track&,
+                                       Trk::TrackSummary&) const {};
+
+    virtual void updateAdditionalInfo(Trk::TrackSummary&,
+                                      std::vector<float>&,
+                                      float&,
+                                      int&,
+                                      int&) const {};
+
     /*
-     * The context unaware methods.
-     * If this set is not overloaded , it
-     * will call the methods with EventContext
+     * Implement the ITrackSummaryHelperTool part
+     * of the interface for  the methods with the same
+     * name as the method above.
      */
 
     virtual void analyse(
       const Trk::Track& track,
-      const Trk::PRDtoTrackMap* prd_to_track_map,
       const RIO_OnTrack* rot,
       const TrackStateOnSurface* tsos,
       std::vector<int>& information,
-      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const
+      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override
     {
       analyse(Gaudi::Hive::currentContext(),
               track,
-              prd_to_track_map,
+              nullptr,
               rot,
               tsos,
               information,
@@ -105,29 +119,28 @@ namespace Trk {
 
     virtual void analyse(
       const Trk::Track& track,
-      const Trk::PRDtoTrackMap* prd_to_track_map,
       const CompetingRIOsOnTrack* crot,
       const TrackStateOnSurface* tsos,
       std::vector<int>& information,
-      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const
+      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const override
     {
       analyse(Gaudi::Hive::currentContext(),
               track,
-              prd_to_track_map,
+              nullptr,
               crot,
               tsos,
               information,
               hitPattern);
     }
 
-    virtual void updateSharedHitCount(
-      const Trk::Track&,
-      const Trk::PRDtoTrackMap* prd_to_track_map,
-      Trk::TrackSummary&) const = 0;
-
-    virtual void addDetailedTrackSummary(const Track& track,
-                                         Trk::TrackSummary& summary) const = 0;
+    virtual void addDetailedTrackSummary(
+      const Track& track,
+      Trk::TrackSummary& summary) const override
+    {
+      addDetailedTrackSummary(Gaudi::Hive::currentContext(), track, summary);
+    }
   };
+
   inline const InterfaceID& Trk::IExtendedTrackSummaryHelperTool::interfaceID()
   {
     return IID_ITrackSummaryHelperTool;
diff --git a/Tracking/TrkTools/TrkToolInterfaces/TrkToolInterfaces/ITrackSummaryHelperTool.h b/Tracking/TrkTools/TrkToolInterfaces/TrkToolInterfaces/ITrackSummaryHelperTool.h
index b3c29b83abeb64235c19c2b5b01097e9b4fea9d2..068e6e8f3bfd14794c3500c18a5af08d40b965cd 100755
--- a/Tracking/TrkTools/TrkToolInterfaces/TrkToolInterfaces/ITrackSummaryHelperTool.h
+++ b/Tracking/TrkTools/TrkToolInterfaces/TrkToolInterfaces/ITrackSummaryHelperTool.h
@@ -34,8 +34,6 @@ namespace Trk {
 
     @author Edward Moyse, Martin Siebel <http://consult.cern.ch/xwho>
 */
-#pragma GCC diagnostic push
-#pragma GCC diagnostic ignored "-Woverloaded-virtual"
   class ITrackSummaryHelperTool : virtual public IAlgTool {
   public:
     static const InterfaceID& interfaceID();
@@ -44,35 +42,31 @@ namespace Trk {
     TrackSummaryHelperTools. It is mandatory that the RIO_OnTrack* points to exactly the object contained
       inside the TrackStateOnSurface. This is to avoid that the RTTI from the TrackSummaryTool is done twice.
         */
-      virtual void analyse(const Trk::Track& track, 
-			   const RIO_OnTrack* rot,
-			   const TrackStateOnSurface* tsos,
-			   std::vector<int>& information, 
-			   std::bitset<Trk::numberOfDetectorTypes>& hitPattern ) const = 0;
+    virtual void analyse(
+      const Trk::Track& track,
+      const RIO_OnTrack* rot,
+      const TrackStateOnSurface* tsos,
+      std::vector<int>& information,
+      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const = 0;
 
-      virtual void analyse(const Trk::Track& track, 
-			   const CompetingRIOsOnTrack* crot,
-			   const TrackStateOnSurface* tsos,
-			   std::vector<int>& information, 
-			   std::bitset<Trk::numberOfDetectorTypes>& hitPattern ) const = 0;
-      
-      virtual void searchForHoles(const Trk::Track& track, 
-				  std::vector<int>& information ,
-				  const Trk::ParticleHypothesis partHyp = Trk::pion) const =0;
-                  
-      virtual void updateSharedHitCount(const Trk::Track&, Trk::TrackSummary&) const {};
+    virtual void analyse(
+      const Trk::Track& track,
+      const CompetingRIOsOnTrack* crot,
+      const TrackStateOnSurface* tsos,
+      std::vector<int>& information,
+      std::bitset<Trk::numberOfDetectorTypes>& hitPattern) const = 0;
 
-      virtual void  updateExpectedHitInfo(const Trk::Track&, Trk::TrackSummary&) const {};
+    virtual void searchForHoles(
+      const Trk::Track& track,
+      std::vector<int>& information,
+      const Trk::ParticleHypothesis partHyp = Trk::pion) const = 0;
 
-      virtual void updateAdditionalInfo(Trk::TrackSummary&, std::vector<float>&, float&,int&, int&) const {};
-                  
+    virtual void addDetailedTrackSummary(const Trk::Track& track,
+                                         Trk::TrackSummary& summary) const = 0;
 
-      virtual void addDetailedTrackSummary(const Trk::Track& track, Trk::TrackSummary& summary ) const = 0;
-
-    
 
   };
-#pragma GCC diagnostic pop
+  
   inline const InterfaceID& Trk::ITrackSummaryHelperTool::interfaceID()
   { 
     return IID_ITrackSummaryHelperTool; 
diff --git a/Tracking/TrkTools/TrkTrackSummaryTool/src/TrackSummaryTool.cxx b/Tracking/TrkTools/TrkTrackSummaryTool/src/TrackSummaryTool.cxx
index 10719a22b0d06fa436c91f993534e5207d6452a1..e86b1766abd7e7dc9c98b97af0c4be7375ec302a 100755
--- a/Tracking/TrkTools/TrkTrackSummaryTool/src/TrackSummaryTool.cxx
+++ b/Tracking/TrkTools/TrkTrackSummaryTool/src/TrackSummaryTool.cxx
@@ -290,11 +290,11 @@ Trk::TrackSummaryTool::fillSummary(const EventContext& ctx,
 
   // add detailed summary for indet
   if( m_addInDetDetailedSummary && !m_idTool.empty() ){
-    m_idTool->addDetailedTrackSummary(track,ts);
+    m_idTool->addDetailedTrackSummary(ctx,track,ts);
   }
   // add detailed summary for muons
   if( m_addMuonDetailedSummary && !m_muonTool.empty() ){
-    m_muonTool->addDetailedTrackSummary(track,ts);
+    m_muonTool->addDetailedTrackSummary(ctx,track,ts);
   }
 }
 
@@ -332,7 +332,9 @@ Trk::TrackSummaryTool::updateAdditionalInfo(const Track& track,
   }
   m_idTool->updateAdditionalInfo(summary, eProbability,dedx, nHitsUsed_dEdx,nOverflowHits_dEdx);
   m_idTool->updateExpectedHitInfo(track, summary);
-  if (m_addInDetDetailedSummary) m_idTool->addDetailedTrackSummary(track,summary);
+  if (m_addInDetDetailedSummary) {
+    m_idTool->addDetailedTrackSummary(track,summary);
+  }
 }
 
 /*
diff --git a/Tracking/TrkValidation/TrkValAlgs/src/TrackValidationNtupleWriter.cxx b/Tracking/TrkValidation/TrkValAlgs/src/TrackValidationNtupleWriter.cxx
index bd4bb2b95a9e0c10c15bd6113bbb80b10aab13b4..d24e097589807a0d3a9daac874f4d3879ceb6f05 100644
--- a/Tracking/TrkValidation/TrkValAlgs/src/TrackValidationNtupleWriter.cxx
+++ b/Tracking/TrkValidation/TrkValAlgs/src/TrackValidationNtupleWriter.cxx
@@ -367,13 +367,8 @@ StatusCode Trk::TrackValidationNtupleWriter::execute() {
               m_trackTruthClassifiers[toolIndex]->initClassification(*mcEventColl, selecParticles);
             }
 	    
-//	    std::cout<<"First loop done "<<std::endl;
-	    
-            //unsigned int partIndex = 0;
-            std::vector< const HepMC::GenParticle* >::const_iterator partIter = selecParticles->begin();
-            for ( ; partIter != selecParticles->end(); ++partIter) 
+            for ( auto genParticle: *selecParticles) 
               {
-                const HepMC::GenParticle* genParticle = *partIter;
                 //truthData.genParticle = (*selecParticles);
                 Trk::ValidationTrackTruthData partData;
                 partData.genParticle = genParticle;
@@ -750,68 +745,3 @@ StatusCode Trk::TrackValidationNtupleWriter::finalize() {
     return StatusCode::SUCCESS;
 }
 
-// const Trk::TrackParameters* Trk::TrackValidationNtupleWriter::associateTruthToTrack( const Trk::Track* track, 
-// 										     const TrackCollection* trackCollection, 
-// 										     const TrackTruth*& trackTruth )
-// {
-//     
-//    if (msgLvl(MSG::VERBOSE)) msg(MSG::VERBOSE) << "Starting InDet::FitterValidationTool::determineGeneratedPerigee()..." << endmsg;
-// 
-//   StatusCode sc;
-// 
-//   const TrackTruthCollection* trackTruthCollection = 0;
-// 
-//   sc = evtStore()->retrieve( trackTruthCollection, m_trackTruthCollectionName );
-// 
-//   if ( sc.isFailure() ){
-//     msg(MSG::ERROR) << "Attempt to retrieve track truth using StoreGate collection name " << m_trackTruthCollectionName << " failed... Exiting" << endmsg;
-//     return 0;
-//   }
-// 
-//   ElementLink<TrackCollection> trackLink;
-// 
-//   trackLink.setElement( const_cast<Trk::Track*>( track ) );
-//   trackLink.setStorableObject( *trackCollection );
-//  
-//   typedef TrackTruthCollection::const_iterator TruthIterator;
-//   // typedef std::map<ElementLink< DataVector<Trk::Track> >, TrackTruth>::const_iterator TruthIterator; 
-//  
-//   TruthIterator truthIterator = trackTruthCollection->find( trackLink );
-// 
-//   if ( truthIterator == trackTruthCollection->end() ){
-//     if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << "Truth could not be found... exiting" << endmsg;
-//     return 0;
-//   }
-// 
-//   trackTruth = new TrackTruth( ( *truthIterator ).second );
-// 
-//   const HepMcParticleLink& particleLink = trackTruth->particleLink();
-//   
-//   const HepMC::GenParticle* genParticle = particleLink.cptr();
-//   
-//   if ( !genParticle ){
-//     if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << "Link to generated particle information cannot be found... No truth association possible" << endmsg;
-//     return 0;
-//   }
-//  
-//   int particleID = genParticle->pdg_id();
-//   
-//   if ( particleID == 0 ){
-//     if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << "Associated Particle ID " << particleID << " does not conform to PDG requirements... exiting" << endmsg;
-//     return 0;
-//   }
-//  
-//   else
-//     if (msgLvl(MSG::VERBOSE)) msg(MSG::VERBOSE) << "Associated Particle ID: " << particleID << endmsg;
-// 
-//   const Trk::TrackParameters* generatedTrackPerigee(0);
-// 
-//   // Perform extrapolation to generate perigee parameters
-//   if ( genParticle->production_vertex() )
-//     generatedTrackPerigee = m_truthToTrack->makePerigeeParameters( genParticle );
-// 
-//   return generatedTrackPerigee;
-// 
-// }
-
-
diff --git a/Tracking/TrkValidation/TrkValTools/src/InDetHaloSelector.cxx b/Tracking/TrkValidation/TrkValTools/src/InDetHaloSelector.cxx
index ff4fa1575205d75a56876d6b943f31a8fd062e30..5e698f2e5c8d5c598771efe385f149273e9f6852 100644
--- a/Tracking/TrkValidation/TrkValTools/src/InDetHaloSelector.cxx
+++ b/Tracking/TrkValidation/TrkValTools/src/InDetHaloSelector.cxx
@@ -63,12 +63,8 @@ Trk::InDetHaloSelector::selectGenSignal (const McEventCollection* SimTracks) con
   
   for( ; itCollision != SimTracks->end(); ++itCollision ) {
     const HepMC::GenEvent*    genEvent = *itCollision;
-    HepMC::GenParticle * particle = NULL;
     
-    for (HepMC::GenEvent::particle_const_iterator it = genEvent->particles_begin();
-         it != genEvent->particles_end(); ++it) {
-
-      particle = *it;
+    for (auto particle: *genEvent) {
 
       // 1) require stable particle from generation or simulation
       if ((particle->status()%1000) != 1 )    continue;
@@ -76,17 +72,17 @@ Trk::InDetHaloSelector::selectGenSignal (const McEventCollection* SimTracks) con
       
       int   pdgCode         = particle->pdg_id();
       if (abs(pdgCode) > 1000000000 ) continue; // ignore nuclei from hadronic interactions
-      const HepPDT::ParticleData* pd = m_particleDataTable->particle(abs(pdgCode));
-      ATH_MSG_DEBUG( "checking particle barcode = " <<  particle->barcode() );
+      const HepPDT::ParticleData* pd = m_particleDataTable->particle(std::abs(pdgCode));
+      ATH_MSG_DEBUG( "checking particle barcode = " <<  HepMC::barcode(particle) );
       if (!pd) { // nuclei excluded, still problems with a given type?
 	ATH_MSG_INFO ("Could not get particle data for particle with pdgCode="<<pdgCode
-		      << ", status=" << particle->status() << ", barcode=" << particle->barcode());
-	ATH_MSG_INFO ("GenParticle= " << *particle);
+		      << ", status=" << particle->status() << ", barcode=" << HepMC::barcode(particle));
+	ATH_MSG_INFO ("GenParticle= " << particle);
 	continue;
       }
       float charge          = pd->charge();
       ATH_MSG_DEBUG( "particle charge = " << charge );
-      if (fabs(charge)<0.5) continue;
+      if (std::fabs(charge)<0.5) continue;
       
       genSignal->push_back(particle);
     
diff --git a/Tracking/TrkValidation/TrkVertexFitterValidationTools/src/TrueTracksNtupleTool.cxx b/Tracking/TrkValidation/TrkVertexFitterValidationTools/src/TrueTracksNtupleTool.cxx
index d42f765b5ed9433de3e5ab1262c55d5f60199d18..11814b238395f428619a8d7e8808867e51557b17 100755
--- a/Tracking/TrkValidation/TrkVertexFitterValidationTools/src/TrueTracksNtupleTool.cxx
+++ b/Tracking/TrkValidation/TrkVertexFitterValidationTools/src/TrueTracksNtupleTool.cxx
@@ -134,15 +134,18 @@ StatusCode Trk::TrueTracksNtupleTool::fillTrueTracksInfo(const TrackCollection&
             if (msgLvl(MSG::DEBUG)) msg (MSG::DEBUG) << " truth is missing" << endmsg;
          } else {  
              TrackTruth trk_truth=found->second;
-             const HepMC::GenParticle * particle;
-             particle = trk_truth.particleLink();
-             HepMC:: GenVertex* prod_vtx = particle->production_vertex();
+             auto particle = trk_truth.particleLink();
+             auto prod_vtx = particle->production_vertex();
              //fill prod vertex
              m_prod_x->push_back(prod_vtx->position().x());
              m_prod_y->push_back(prod_vtx->position().y());
              m_prod_z->push_back(prod_vtx->position().z());
 
+#ifdef HEPMC3
+             auto   parent_iter = prod_vtx->particles_in().begin();
+#else
              HepMC::GenVertex::particle_iterator   parent_iter = prod_vtx->particles_begin(HepMC::parents);
+#endif
              m_parent_id->push_back((*parent_iter)->pdg_id());
              m_particle_id->push_back(particle->pdg_id());
             }
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterHelper.h b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterHelper.h
index 2d66357c20ca0e16ca2f8f8b6d9fa745f4bf088a..222bea9e38e3b1907b86650392a6b288a163f104 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterHelper.h
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterHelper.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /**
@@ -49,9 +49,6 @@ namespace Trk {
       return IID_JetFitterHelper;
     }
 
-    StatusCode initialize();
-    StatusCode finalize();
-
     /**
      * Constructor
      */
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterInitializationHelper.h b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterInitializationHelper.h
index 32216d66e1b52856ec20fdb850650dcdd2f49939..ee6df945073c74bdc207474e1ce4484492877e90 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterInitializationHelper.h
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterInitializationHelper.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /**
@@ -49,8 +49,7 @@ namespace Trk {
       return IID_JetFitterInitializationHelper;
     }
 
-    StatusCode initialize();
-    StatusCode finalize();
+    virtual StatusCode initialize() override;
 
     /**
      * Constructor
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterRoutines.h b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterRoutines.h
index e960a452f07b3b14a8ac232d6582d71bc9b150a9..a63bba83f5533190f37c8aab2dd2aa46b21395a2 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterRoutines.h
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/JetFitterRoutines.h
@@ -63,8 +63,7 @@ namespace Trk {
     }
  
 
-    StatusCode initialize();
-    StatusCode finalize();
+    virtual StatusCode initialize() override;
 
     /**
      * Constructor
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/KalmanVertexOnJetAxisSmoother.h b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/KalmanVertexOnJetAxisSmoother.h
index fb080e021f1493f86335a50bc373ebf6649d33a6..cdb9656c2fdccdd601d8983d7ff60cc9592d9aa4 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/KalmanVertexOnJetAxisSmoother.h
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/KalmanVertexOnJetAxisSmoother.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /**
@@ -49,9 +49,8 @@ namespace Trk
  {
   public: 
   
-   StatusCode initialize();
-   StatusCode finalize();
- 
+   virtual StatusCode initialize() override;
+
    /**
     * Constructor
     */
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/KalmanVertexOnJetAxisUpdator.h b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/KalmanVertexOnJetAxisUpdator.h
index cff8b3c5a9714690f37c4154f7c2588be224c80e..91c722ded1ca34e7b158e9daecb0ab64c502f43d 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/KalmanVertexOnJetAxisUpdator.h
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/KalmanVertexOnJetAxisUpdator.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /**
@@ -61,9 +61,7 @@ namespace Trk
      };
 
 
-
-  StatusCode initialize();
-  StatusCode finalize();
+  virtual StatusCode initialize() override;
 
   /**
    * Constructor
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/TrkDistanceFinderNeutralCharged.h b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/TrkDistanceFinderNeutralCharged.h
index 0e6f7a8c7b4e01d1f2e130e3373c9086651b50c0..2b46b420abbfc0deca07d776c06882624497fcf9 100644
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/TrkDistanceFinderNeutralCharged.h
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/TrkDistanceFinderNeutralCharged.h
@@ -36,9 +36,6 @@ class TrkDistanceFinderNeutralCharged : public AthAlgTool
       return IID_TrkDistanceFinderNeutralCharged;
     };
 
-    StatusCode initialize();
-    StatusCode finalize();
-
  private:
 
   //parameters for precision
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/TrkDistanceFinderNeutralNeutral.h b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/TrkDistanceFinderNeutralNeutral.h
index 080f4e628539163f30e09116d84f511bb598dc92..3b56d0df2ca78ddc6f00da990fddd1cd3b6a2e0d 100644
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/TrkDistanceFinderNeutralNeutral.h
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/TrkJetVxFitter/TrkDistanceFinderNeutralNeutral.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef DISTNEUNEU_H
@@ -31,12 +31,6 @@ class TrkDistanceFinderNeutralNeutral : public AthAlgTool
       return IID_TrkDistanceFinderNeutralNeutral;
     };
 
-    StatusCode initialize();
-    StatusCode finalize();
-
- private:
-
-
 };
 
 //no error possible: an analytic solution is possible here!
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterHelper.cxx b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterHelper.cxx
index 39fbb58d78b6783a9deb82620e7ad481e49b1c44..c094b1ae95194552ec32d31496b198967fcc1020 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterHelper.cxx
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterHelper.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /***************************************************************************
@@ -44,20 +44,6 @@ namespace Trk
   JetFitterHelper::~JetFitterHelper() = default;
 
 
-  StatusCode JetFitterHelper::initialize() {
-
-    ATH_MSG_INFO( "Initialize successful" );
-    return StatusCode::SUCCESS;
-
-  }
-
-  StatusCode JetFitterHelper::finalize() {
-
-    ATH_MSG_INFO( "Finalize successful" );
-    return StatusCode::SUCCESS;
-
-  }
-  
   void JetFitterHelper::addTracksOfFirstVertexToSecondVertex(const VxVertexOnJetAxis & first,VxVertexOnJetAxis & second) const {
     
     
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterInitializationHelper.cxx b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterInitializationHelper.cxx
index 8232277534f136562fd7551f20428a8745ed99d4..d1c5ce62fa4697619bff7caefec3aa5d35b4a7de 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterInitializationHelper.cxx
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterInitializationHelper.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /***************************************************************************
@@ -99,19 +99,11 @@ namespace Trk
     }
     
 
-   ATH_MSG_INFO ("Initialize successful");
     return StatusCode::SUCCESS;
 
   }
 
-  StatusCode JetFitterInitializationHelper::finalize() {
 
-    ATH_MSG_INFO ("Finalize successful");
-    return StatusCode::SUCCESS;
-
-  }
-
-  
   /**
    * Initialize the JetCandidate using a vector of Trk::ITrackLink* - needed for example 
    * if you run on ESD (Track*), but you have additional neutral tracks (TrackParticleBase*)
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterRoutines.cxx b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterRoutines.cxx
index cf5bc4daeb12042476a578c03622d6a92505a544..48d38c6b352a79f15511c088d6a10dbbd4e2ee78 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterRoutines.cxx
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/JetFitterRoutines.cxx
@@ -108,16 +108,9 @@ namespace Trk
 
     ATH_CHECK( m_smoother.retrieve() );
 
-    ATH_MSG_INFO( "Initialize successful" );
     return StatusCode::SUCCESS;
   }
 
-  StatusCode JetFitterRoutines::finalize() {
-
-    ATH_MSG_INFO( "Finalize successful" );
-    return StatusCode::SUCCESS;
-
-  }
 
   void JetFitterRoutines::initializeToMinDistancesToJetAxis(VxJetCandidate* myJetCandidate) const {
     
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/KalmanVertexOnJetAxisSmoother.cxx b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/KalmanVertexOnJetAxisSmoother.cxx
index dbe2ed27947bd2819bd57b33460c2e35fed78b08..794569e3a4b99a140730b52955dc1d0e6b0056a7 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/KalmanVertexOnJetAxisSmoother.cxx
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/KalmanVertexOnJetAxisSmoother.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "TrkJetVxFitter/KalmanVertexOnJetAxisSmoother.h"
@@ -43,12 +43,7 @@ namespace Trk
 
   return StatusCode::SUCCESS;
  }
- 
- StatusCode KalmanVertexOnJetAxisSmoother::finalize()
- {
-   ATH_MSG_INFO( "Finalize successful" );
-  return StatusCode::SUCCESS;
- }
+
  
  KalmanVertexOnJetAxisSmoother::KalmanVertexOnJetAxisSmoother(const std::string& t, const std::string& n, const IInterface*  p):
    AthAlgTool(t,n,p),
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/KalmanVertexOnJetAxisUpdator.cxx b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/KalmanVertexOnJetAxisUpdator.cxx
index fd380247508c228025ff85d53d550d946cd0f812..9174452f37c68bf1d9e2b91ddc6997c90cd1e891 100755
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/KalmanVertexOnJetAxisUpdator.cxx
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/KalmanVertexOnJetAxisUpdator.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "TrkJetVxFitter/KalmanVertexOnJetAxisUpdator.h"
@@ -48,12 +48,6 @@ namespace Trk{
   return StatusCode::SUCCESS;
  }
 
- StatusCode KalmanVertexOnJetAxisUpdator::finalize()
- {
-   ATH_MSG_INFO( "Finalize successful" );
-   return StatusCode::SUCCESS;
- }
-
 
   void KalmanVertexOnJetAxisUpdator::add(VxTrackAtVertex* trackToAdd,
                                          const VxVertexOnJetAxis* vertexToUpdate,
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/TrkDistanceFinderNeutralCharged.cxx b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/TrkDistanceFinderNeutralCharged.cxx
index 2efc9e6fa13c64396540f9df5ead1a2c09e97539..7dc6d0e07fd1bf4eb38cefda8b00f793f33d39c6 100644
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/TrkDistanceFinderNeutralCharged.cxx
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/TrkDistanceFinderNeutralCharged.cxx
@@ -31,20 +31,6 @@ TrkDistanceFinderNeutralCharged::TrkDistanceFinderNeutralCharged(const std::stri
 }
 
 
-StatusCode TrkDistanceFinderNeutralCharged::initialize() 
-  { 
-    StatusCode s = AthAlgTool::initialize();
-    ATH_MSG_INFO("Initialize successful");
-    return StatusCode::SUCCESS;
-  }
-
-StatusCode TrkDistanceFinderNeutralCharged::finalize() 
-{
-  ATH_MSG_INFO("Finalize successful");
-  return StatusCode::SUCCESS;
-}
-
-
 TrkDistanceFinderNeutralCharged::~TrkDistanceFinderNeutralCharged() = default;
 
 std::pair<Amg::Vector3D,double>  
diff --git a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/TrkDistanceFinderNeutralNeutral.cxx b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/TrkDistanceFinderNeutralNeutral.cxx
index 3e0bdf521e191fc3e482e040f6acf19fb614c450..6423af17af9eec38214dab4757f8b81cd49f4525 100644
--- a/Tracking/TrkVertexFitter/TrkJetVxFitter/src/TrkDistanceFinderNeutralNeutral.cxx
+++ b/Tracking/TrkVertexFitter/TrkJetVxFitter/src/TrkDistanceFinderNeutralNeutral.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "TrkJetVxFitter/TrkDistanceFinderNeutralNeutral.h"
@@ -17,21 +17,6 @@ TrkDistanceFinderNeutralNeutral::TrkDistanceFinderNeutralNeutral(const std::stri
   
 }
 
-
-StatusCode TrkDistanceFinderNeutralNeutral::initialize() 
-  { 
-    StatusCode s = AthAlgTool::initialize();
-    ATH_MSG_INFO("Initialize successful");
-    return s;
-  }
-
-StatusCode TrkDistanceFinderNeutralNeutral::finalize() 
-{
-  ATH_MSG_INFO("Finalize successful");
-  return StatusCode::SUCCESS;
-}
-
-
 TrkDistanceFinderNeutralNeutral::~TrkDistanceFinderNeutralNeutral() = default;
 
 std::pair<Amg::Vector3D,double>  
diff --git a/Tracking/TrkVertexFitter/TrkVertexBilloirTools/TrkVertexBilloirTools/FastVertexFitter.h b/Tracking/TrkVertexFitter/TrkVertexBilloirTools/TrkVertexBilloirTools/FastVertexFitter.h
index 09eff0b9df5463ba1b129c3ce87248b9f244904b..c81deec9ee766677518bdd8de30b391684830011 100755
--- a/Tracking/TrkVertexFitter/TrkVertexBilloirTools/TrkVertexBilloirTools/FastVertexFitter.h
+++ b/Tracking/TrkVertexFitter/TrkVertexBilloirTools/TrkVertexBilloirTools/FastVertexFitter.h
@@ -41,7 +41,6 @@ public:
   using Trk::IVertexFitter::fit;
 
   virtual StatusCode initialize() override;
-  virtual StatusCode finalize() override;
 
   FastVertexFitter(const std::string& t,
                    const std::string& n,
diff --git a/Tracking/TrkVertexFitter/TrkVertexBilloirTools/TrkVertexBilloirTools/FullVertexFitter.h b/Tracking/TrkVertexFitter/TrkVertexBilloirTools/TrkVertexBilloirTools/FullVertexFitter.h
index 7cf0ae1e4142cbfd670814131e71055857108557..245cef913f1da68706b824ccec6ef3782f31e6ab 100755
--- a/Tracking/TrkVertexFitter/TrkVertexBilloirTools/TrkVertexBilloirTools/FullVertexFitter.h
+++ b/Tracking/TrkVertexFitter/TrkVertexBilloirTools/TrkVertexBilloirTools/FullVertexFitter.h
@@ -42,7 +42,6 @@ namespace Trk
     using Trk::IVertexFitter::fit;
 
     virtual StatusCode initialize() override;
-    virtual StatusCode finalize() override;
 
     enum FitError
     {
diff --git a/Tracking/TrkVertexFitter/TrkVertexBilloirTools/src/FastVertexFitter.cxx b/Tracking/TrkVertexFitter/TrkVertexBilloirTools/src/FastVertexFitter.cxx
index 3de822d35296e74fa4b975c05f810549f55c8472..0a5eb2d83527fcc7e4a613040f851cf349147393 100755
--- a/Tracking/TrkVertexFitter/TrkVertexBilloirTools/src/FastVertexFitter.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexBilloirTools/src/FastVertexFitter.cxx
@@ -76,17 +76,9 @@ namespace Trk
 			msg(MSG::INFO) << "Retrieved tool " << m_linFactory << endmsg;
 		
 
-
-
-		msg(MSG::INFO)  << "Initialize successful" << endmsg;
 		return StatusCode::SUCCESS;
 	}
 
-	StatusCode FastVertexFitter::finalize()
-	{
-		msg(MSG::INFO)  << "Finalize successful" << endmsg;
-		return StatusCode::SUCCESS;
-	}
 
 	FastVertexFitter::FastVertexFitter ( const std::string& t, const std::string& n, const IInterface*  p ) : base_class ( t,n,p ),
 														  m_maxIterations ( 3 ),
diff --git a/Tracking/TrkVertexFitter/TrkVertexBilloirTools/src/FullVertexFitter.cxx b/Tracking/TrkVertexFitter/TrkVertexBilloirTools/src/FullVertexFitter.cxx
index 1d5abc635ad84777603e660ebb9714d647d86459..ef05a7a790b69baa98339c6582720cb2c5572e34 100755
--- a/Tracking/TrkVertexFitter/TrkVertexBilloirTools/src/FullVertexFitter.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexBilloirTools/src/FullVertexFitter.cxx
@@ -110,13 +110,6 @@ namespace Trk
 			msg(MSG::INFO) << "Retrieved tool " << m_linFactory << endmsg;
 		
 
-		msg(MSG::INFO)  << "Initialize successful" << endmsg;
-		return StatusCode::SUCCESS;
-	}
-
-	StatusCode FullVertexFitter::finalize()
-	{
-		msg(MSG::INFO)  << "Finalize successful" << endmsg;
 		return StatusCode::SUCCESS;
 	}
 
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/FullLinearizedTrackFactory.h b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/FullLinearizedTrackFactory.h
index ee646536959e9dd358a07c962fcda1754017550c..b86c5ae8728922a7bf9b21dc1cffaf9e6046193e 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/FullLinearizedTrackFactory.h
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/FullLinearizedTrackFactory.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TrkVertexFitterUtils_FULLLINEARIZEDTRACKFACTORY_H
@@ -59,10 +59,8 @@ namespace Trk
   /**
    * Standard AlgToolMethods
    */
-    StatusCode initialize();
+    virtual StatusCode initialize() override;
   
-    StatusCode finalize();
-    
   /**
    * Default constructor due to Athena interface
    */
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/KalmanVertexTrackUpdator.h b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/KalmanVertexTrackUpdator.h
index f0291b8ebd499edbf9fd328bebf82d3fa1552593..fe6369ccc351d4dcbefd65472d7e85386d06ba75 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/KalmanVertexTrackUpdator.h
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/KalmanVertexTrackUpdator.h
@@ -41,9 +41,8 @@ namespace Trk
  {
   public: 
   
-   StatusCode initialize();
-   StatusCode finalize();
- 
+   virtual StatusCode initialize() override;
+
 /**
  * Constructor
  */
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/KalmanVertexUpdator.h b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/KalmanVertexUpdator.h
index 5505a8a783c9a684cd35e929b3ee9e0fb6f4c9b8..5e129192a152d928e6220fe1ef17ce52fbbffb8c 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/KalmanVertexUpdator.h
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/KalmanVertexUpdator.h
@@ -37,8 +37,7 @@ namespace Trk
  {
   public:
   
-  StatusCode initialize();
-  StatusCode finalize();
+  virtual StatusCode initialize() override;
 /**
  * Constructor 
  */
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/TrackToVertexIPEstimator.h b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/TrackToVertexIPEstimator.h
index 3dd1fda2cf0f2a3f46b474590673856f95355b5a..7354c548e76e759a073fe9f60efdfc8cc34881b3 100644
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/TrackToVertexIPEstimator.h
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/TrkVertexFitterUtils/TrackToVertexIPEstimator.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRKVERTEXFITTERUTILS_TRACKTOVERTEXIPESTIMATOR_H
@@ -78,9 +78,8 @@ namespace Trk
  /**
   * Default Athena interface methods
   */
-    StatusCode initialize();
-    
-    StatusCode finalize();
+    virtual StatusCode initialize() override;
+
  
  /**
   * Default Athena interface constructor and destructor 
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/FullLinearizedTrackFactory.cxx b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/FullLinearizedTrackFactory.cxx
index 0260e27e35aa0a34192458bd4ceaff6711c9f6d6..afe995262c64acf0e0ea08d48164b41d810cb3dd 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/FullLinearizedTrackFactory.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/FullLinearizedTrackFactory.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /*********************************************************************
@@ -37,17 +37,10 @@ namespace Trk
     ATH_CHECK( m_extrapolator.retrieve() );
     ATH_CHECK( m_fieldCacheCondObjInputKey.initialize() );
 
-    msg(MSG::INFO)  << "Initialize successful" << endmsg;
     return StatusCode::SUCCESS;
   }
 
-  StatusCode FullLinearizedTrackFactory::finalize() 
-  {
-    ATH_MSG_INFO ("Finalize successful");
-    return StatusCode::SUCCESS;
-  }
-
-  void FullLinearizedTrackFactory::linearize(VxTrackAtVertex & theTrack,const Amg::Vector3D & linPoint) const 
+  void FullLinearizedTrackFactory::linearize(VxTrackAtVertex & theTrack,const Amg::Vector3D & linPoint) const
   {
     if (theTrack.initialPerigee())
       theTrack.setLinTrack(linearizedTrack(theTrack.initialPerigee(),linPoint));
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/KalmanVertexTrackUpdator.cxx b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/KalmanVertexTrackUpdator.cxx
index 92e066272cdef4ec52106c18cd98b29b6d28b754..53d18abd8e8130748c16b640446e35c595aea2ed 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/KalmanVertexTrackUpdator.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/KalmanVertexTrackUpdator.cxx
@@ -24,12 +24,6 @@ namespace Trk
   return StatusCode::SUCCESS;
  }
  
- StatusCode KalmanVertexTrackUpdator::finalize()
- {
-  ATH_MSG_INFO("Finalize successful");
-  return StatusCode::SUCCESS;
- }
- 
  KalmanVertexTrackUpdator::KalmanVertexTrackUpdator(const std::string& t, const std::string& n, const IInterface*  p):
  AthAlgTool(t,n,p),m_Updator("Trk::KalmanVertexUpdator", this),m_maxWeight(0.001)
  { 
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/KalmanVertexUpdator.cxx b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/KalmanVertexUpdator.cxx
index b00a39fe9b2d92bf3b88bc5829cd2cb1f3e1f211..59150eedd0d49ef9d0870482a3052dc4cedfc639 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/KalmanVertexUpdator.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/KalmanVertexUpdator.cxx
@@ -32,13 +32,7 @@ namespace Trk{
   return StatusCode::SUCCESS;
  }
 
- StatusCode KalmanVertexUpdator::finalize()
- {
-  msg(MSG::INFO)  << "Finalize successful" << endmsg;
-  return StatusCode::SUCCESS;
- }
 
- 
  xAOD::Vertex * KalmanVertexUpdator:: add(xAOD::Vertex& vtx, VxTrackAtVertex& trk) const
  {
    return update(vtx,trk,IVertexUpdator::addTrack);
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/NeutralParticleParameterCalculator.cxx b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/NeutralParticleParameterCalculator.cxx
index 5616c970351a6d732019e389738a9cc98dd8c808..9ca11c041bf0cfd4b85c70b17bcedc0d23169e5a 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/NeutralParticleParameterCalculator.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/NeutralParticleParameterCalculator.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /*********************************************************************
@@ -44,16 +44,9 @@ namespace Trk
       }
     }
 
-    msg(MSG::INFO)  << "Initialize successful" << endmsg;
     return StatusCode::SUCCESS;
   }
   
-  StatusCode NeutralParticleParameterCalculator::finalize() 
-  {
-    msg(MSG::INFO)  << "Finalize successful" << endmsg;
-    return StatusCode::SUCCESS;
-  }
-
 
   NeutralPerigee* NeutralParticleParameterCalculator::createNeutralTrackFromVertex
     (const xAOD::Vertex & myVertex) const
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/NeutralParticleParameterCalculator.h b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/NeutralParticleParameterCalculator.h
index b6a5486e7aa473522c07aa39847f3ffd61724ca6..f483e52c63740314eb58f67040a48cbe9b198683 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/NeutralParticleParameterCalculator.h
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/NeutralParticleParameterCalculator.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRKVERTEXFITTERUTILS_NEUTRALPARTICLEPARCALCULATOR_H
@@ -43,9 +43,8 @@ namespace Trk
   class NeutralParticleParameterCalculator : public AthAlgTool, virtual public INeutralParticleParameterCalculator
   {
   public:
-    StatusCode initialize();
-    StatusCode finalize();
-    
+    virtual StatusCode initialize() override;
+
   /**
    * Default constructor due to Athena interface
    */
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/TrackToVertexIPEstimator.cxx b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/TrackToVertexIPEstimator.cxx
index 6d916c4897ad0160ff19b5cb6be6998b67868138..f125774d3752f38e8c1c0f99077a1b2c2d49931f 100644
--- a/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/TrackToVertexIPEstimator.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexFitterUtils/src/TrackToVertexIPEstimator.cxx
@@ -66,11 +66,6 @@ namespace Trk
    return StatusCode::SUCCESS;  
  }//end of initialize method
     
- StatusCode TrackToVertexIPEstimator::finalize()
- { 
-  msg(MSG::INFO)  << "Finalize successful" << endmsg;
-  return StatusCode::SUCCESS;
- }
 
  const  ImpactParametersAndSigma * TrackToVertexIPEstimator::estimate(const xAOD::TrackParticle * track, const xAOD::Vertex * vtx, bool doRemoval) const
  {
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitters/TrkVertexFitters/AdaptiveVertexFitter.h b/Tracking/TrkVertexFitter/TrkVertexFitters/TrkVertexFitters/AdaptiveVertexFitter.h
index 4f79ed3c139d9712fe3beb8ba1a2104f1233ab3a..f012ebe42d17e40bae3830a9c0a95bd319c12cd0 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitters/TrkVertexFitters/AdaptiveVertexFitter.h
+++ b/Tracking/TrkVertexFitter/TrkVertexFitters/TrkVertexFitters/AdaptiveVertexFitter.h
@@ -88,8 +88,7 @@ namespace Trk
     using Trk::IVertexFitter::fit;
   
     virtual StatusCode initialize() override;
-    virtual StatusCode finalize() override;
-    
+
     //same kind error as FullVertexFitter code to be similar in error response - NOT IMPLEMENTED YET
     //enum FitError {FITOK,MATINV,NEGTRCHI2,MAXCHI2,MAXTRCHI2,NOTRKS,NOFIT};
     
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitters/TrkVertexFitters/SequentialVertexSmoother.h b/Tracking/TrkVertexFitter/TrkVertexFitters/TrkVertexFitters/SequentialVertexSmoother.h
index 455c25becf8b035834f2f2bd34c70eea09f9f430..cc25da13f2c8473ec149075c80f950b15f9a2eba 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitters/TrkVertexFitters/SequentialVertexSmoother.h
+++ b/Tracking/TrkVertexFitter/TrkVertexFitters/TrkVertexFitters/SequentialVertexSmoother.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TrkVertexFitters_SequentialVertexSmoother_H
@@ -46,8 +46,7 @@ namespace Trk
 /**
  * default AlgTools methods  
  */
-   StatusCode initialize();
-   StatusCode finalize();
+   virtual StatusCode initialize() override;
   
 /**
  *constructor and destructor  
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitters/src/AdaptiveVertexFitter.cxx b/Tracking/TrkVertexFitter/TrkVertexFitters/src/AdaptiveVertexFitter.cxx
index cfff8d0176011951f8dd32041784a74da9d3ecb6..1409b9518c1a6ca6a6298a41457d18c125e3adcc 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitters/src/AdaptiveVertexFitter.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexFitters/src/AdaptiveVertexFitter.cxx
@@ -126,16 +126,10 @@ namespace Trk
   } 
     msg(MSG::INFO) << "Retrieved tool " << m_AnnealingMaker << endmsg;
   
-  
-    msg(MSG::INFO)  << "Initialize successful" << endmsg;
+
     return StatusCode::SUCCESS;
   }
   
-  StatusCode AdaptiveVertexFitter::finalize()
-  {
-    msg(MSG::INFO)  << "Finalize successful" << endmsg;
-    return StatusCode::SUCCESS;
-  }
 
   xAOD::Vertex*
   AdaptiveVertexFitter::_fit(
diff --git a/Tracking/TrkVertexFitter/TrkVertexFitters/src/SequentialVertexSmoother.cxx b/Tracking/TrkVertexFitter/TrkVertexFitters/src/SequentialVertexSmoother.cxx
index dea280af62832d6a67d637033e51e5f0fc249b72..dc25055a7038bdf8cdff05737d1104ecc5c6b040 100755
--- a/Tracking/TrkVertexFitter/TrkVertexFitters/src/SequentialVertexSmoother.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexFitters/src/SequentialVertexSmoother.cxx
@@ -19,18 +19,11 @@ namespace  Trk
     return StatusCode::FAILURE;
   } 
     msg(MSG::INFO) << "Retrieved tool " << m_vertexTrackUpdator << endmsg;
-  
-  
-  msg(MSG::INFO)<<"Initialization successfull"<<endmsg;
+
   return StatusCode::SUCCESS;
  }//end of initialize method
  
- StatusCode SequentialVertexSmoother::finalize()
- {
-  msg(MSG::INFO)  << "Finalize successful" << endmsg;
-  return StatusCode::SUCCESS;
- }//end of finalize method
- 
+
  //class constructor 
  SequentialVertexSmoother::SequentialVertexSmoother(const std::string& t, const std::string& n, const IInterface*  p):
     AthAlgTool(t,n,p),
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/CrossDistancesSeedFinder.h b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/CrossDistancesSeedFinder.h
index e1c34c980582ca95f0c27ae52c503838cf4554d4..941ce22dc12f9c4a9baf75dfcbc3bb0343669edd 100755
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/CrossDistancesSeedFinder.h
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/CrossDistancesSeedFinder.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRKVERTEXSEEDFINDERTOOLS_CROSSDISTANCESSEEDFINDER_H
@@ -50,7 +50,6 @@ namespace Trk
     virtual ~CrossDistancesSeedFinder();
 
     virtual StatusCode initialize() override;
-    virtual StatusCode finalize() override;
 
 
     using IVertexSeedFinder::findSeed;
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/IndexedCrossDistancesSeedFinder.h b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/IndexedCrossDistancesSeedFinder.h
index 0e21fd21002661b1343a3960fae976537033bc9a..80d86503f6db542c70c0901ed3fe62a923a494f6 100755
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/IndexedCrossDistancesSeedFinder.h
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/IndexedCrossDistancesSeedFinder.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 #ifndef TRKVERTEXSEEDFINDERTOOLS_INDEXCROSSDISTANCESSEEDFINDER_H
 #define TRKVERTEXSEEDFINDERTOOLS_INDEXCROSSDISTANCESSEEDFINDER_H
@@ -43,7 +43,6 @@ namespace Trk
 
 
     virtual StatusCode initialize() override;
-    virtual StatusCode finalize() override;
 
     
     /**
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/MCTrueSeedFinder.h b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/MCTrueSeedFinder.h
index dbd5e0cfaaea953b6394c402ea7dc3922de51823..c657e49cb65b7033102f5cca4ce490bedc440666 100755
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/MCTrueSeedFinder.h
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/TrkVertexSeedFinderTools/MCTrueSeedFinder.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRKVERTEXSEEDFINDERTOOLS_MCTRUESEEDFINDER_H
@@ -45,7 +45,6 @@ namespace Trk
 
 
     virtual StatusCode initialize() override;
-    virtual StatusCode finalize() override;
 
 
     using IVertexSeedFinder::findSeed;
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/CrossDistancesSeedFinder.cxx b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/CrossDistancesSeedFinder.cxx
index 313d4f5887faabaa3d9e832c67e0b423e5ec44f1..0d9061800bf189296de0d6d2c00f661c01c257d7 100755
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/CrossDistancesSeedFinder.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/CrossDistancesSeedFinder.cxx
@@ -75,17 +75,9 @@ namespace Trk
   { 
     ATH_CHECK( m_mode3dfinder.retrieve() );
     ATH_CHECK( m_distancefinder.retrieve() );
-    ATH_MSG_INFO( "Initialize successful"  );
     return StatusCode::SUCCESS;
   }
 
-  StatusCode CrossDistancesSeedFinder::finalize() 
-  {
-    ATH_MSG_INFO( "Finalize successful"  );
-    return StatusCode::SUCCESS;
-  }
-
-
   Amg::Vector3D CrossDistancesSeedFinder::findSeed(const std::vector<const Trk::Track*> & VectorTrk,const xAOD::Vertex * constraint) const {
     
 
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/IndexedCrossDistancesSeedFinder.cxx b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/IndexedCrossDistancesSeedFinder.cxx
index 3e8bb44af2a0a65dea2fac4ef5901ea64de5f864..59d4829555be32cba4fb2bd92ca82872a5aa00b4 100755
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/IndexedCrossDistancesSeedFinder.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/IndexedCrossDistancesSeedFinder.cxx
@@ -60,13 +60,6 @@ namespace Trk
   { 
     ATH_CHECK( m_mode3dfinder.retrieve() );
     ATH_CHECK( m_distancefinder.retrieve() );
-    ATH_MSG_INFO( "Initialize successful" );
-    return StatusCode::SUCCESS;
-  }
-
-  StatusCode IndexedCrossDistancesSeedFinder::finalize() 
-  {
-    ATH_MSG_INFO( "Finalize successful" );
     return StatusCode::SUCCESS;
   }
 
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/MCTrueSeedFinder.cxx b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/MCTrueSeedFinder.cxx
index c89f173cfde2ea7519fd38be9ded8019856ad7f2..55d7697af59ff8fa164f13a180f8eaf8d24932c6 100755
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/MCTrueSeedFinder.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderTools/src/MCTrueSeedFinder.cxx
@@ -67,13 +67,6 @@ namespace Trk
   StatusCode MCTrueSeedFinder::initialize() 
   { 
     ATH_CHECK( m_mcEventCollectionKey.initialize() );
-    msg(MSG::INFO)  << "Initialize successful" << endmsg;
-    return StatusCode::SUCCESS;
-  }
-
-  StatusCode MCTrueSeedFinder::finalize() 
-  {
-    msg(MSG::INFO)  << "Finalize successful" << endmsg;
     return StatusCode::SUCCESS;
   }
 
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/FsmwMode1dFinder.h b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/FsmwMode1dFinder.h
index 66e2cdabfeeaef4531b4d3d38d7c2e1550b1a547..3810fad952e38624b39bf0914bf22e98614b46bf 100644
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/FsmwMode1dFinder.h
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/FsmwMode1dFinder.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRKVERTEXSEEDFINDERUTILS_FSMWMODE1DFINDERALGO_H
@@ -37,9 +37,6 @@ namespace Trk
   class FsmwMode1dFinder : public AthAlgTool, virtual public IMode1dFinder
   {
   public:
-    StatusCode initialize();
-    StatusCode finalize();
-
     //default constructor due to Athena interface
     FsmwMode1dFinder(const std::string& t, const std::string& n, const IInterface*  p);
     
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/Mode3dFromFsmw1dFinder.h b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/Mode3dFromFsmw1dFinder.h
index 8ccaaa87280e6ae073a25f89701863788ddb86e1..45364008f25f8de91b61061234d22c17064349c4 100644
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/Mode3dFromFsmw1dFinder.h
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/Mode3dFromFsmw1dFinder.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 //Author: Lianyou Shan <lianyou.shan@cern.ch>
 #ifndef TRKVERTEXSEEDFINDERUTILS_MODE3DTOFSMW1DFINDER_H
@@ -37,10 +37,6 @@ namespace Trk
                            const IInterface*  p);
       
 
-    virtual StatusCode initialize() override;
-    virtual StatusCode finalize() override;
-    
-
     /**
      * @brief Obtain the 3d-mode (position) from a list of positions
      *        (distribution in space)
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/Mode3dTo1dFinder.h b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/Mode3dTo1dFinder.h
index 9850153e76d13ea023b82401c599fbb395fd1d99..4cb7faca0d105e7f52d3db5cc360727d74afb07d 100644
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/Mode3dTo1dFinder.h
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/TrkVertexSeedFinderUtils/Mode3dTo1dFinder.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRKVERTEXSEEDFINDERUTILS_MODE3DTO1DFINDER_H
@@ -39,8 +39,7 @@ namespace Trk
 
 
     virtual StatusCode initialize() override;
-    virtual StatusCode finalize() override;
-    
+
     
     /**
      * @brief Obtain the 3d-mode (position) from a list of positions
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/share/Mode3dFromFsmw1dFinder_test.ref b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/share/Mode3dFromFsmw1dFinder_test.ref
index c95c87668b18df951f65f269ab4b54617dbc7805..d6381cd44551c8d214dbb78e64167e8e4c8fe399 100644
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/share/Mode3dFromFsmw1dFinder_test.ref
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/share/Mode3dFromFsmw1dFinder_test.ref
@@ -13,5 +13,4 @@ EventLoopMgr      WARNING Unable to locate service "EventSelector"
 EventLoopMgr      WARNING No events will be processed from external input.
 ApplicationMgr       INFO Application Manager Initialized successfully
 ApplicationMgr Ready
-ToolSvc.Trk::Mo...   INFO Initialize successful
 test1
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/share/Mode3dTo1dFinder_test.ref b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/share/Mode3dTo1dFinder_test.ref
index ac386076ea9c27b4ec59af5ec41e7026e9772d29..c40b05b87c3edbf6f8ea7a694f5501432b1f727d 100644
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/share/Mode3dTo1dFinder_test.ref
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/share/Mode3dTo1dFinder_test.ref
@@ -13,6 +13,4 @@ EventLoopMgr      WARNING Unable to locate service "EventSelector"
 EventLoopMgr      WARNING No events will be processed from external input.
 ApplicationMgr       INFO Application Manager Initialized successfully
 ApplicationMgr Ready
-ToolSvc.Trk::Mo...   INFO Initialize successfull
-ToolSvc.Trk::Mo...   INFO Initialize successfull
 test1
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/FsmwMode1dFinder.cxx b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/FsmwMode1dFinder.cxx
index 536899b89fadacad978cc85075352f4d97fea2f8..45cfc3bb6da9041b09a1c1d95363667063b8a287 100644
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/FsmwMode1dFinder.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/FsmwMode1dFinder.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /*********************************************************************
@@ -28,17 +28,6 @@ namespace Trk
 
   FsmwMode1dFinder::~FsmwMode1dFinder() = default;
 
-  StatusCode FsmwMode1dFinder::initialize() 
-  { 
-    msg(MSG::INFO) << "Initialize successfull" << endmsg;
-    return StatusCode::SUCCESS;
-  }
-
-  StatusCode FsmwMode1dFinder::finalize() 
-  {
-    msg(MSG::INFO)  << "Finalize successfull" << endmsg;
-    return StatusCode::SUCCESS;
-  }
 
 #ifdef FSMWMODE1DFINDER_DEBUG
   namespace {
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/Mode3dFromFsmw1dFinder.cxx b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/Mode3dFromFsmw1dFinder.cxx
index ce301ea0bac75282ee8e8f495527375e61766527..f665719757825ecd7ce018b4d6696035ae536b17 100644
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/Mode3dFromFsmw1dFinder.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/Mode3dFromFsmw1dFinder.cxx
@@ -42,21 +42,6 @@ Mode3dFromFsmw1dFinder::Mode3dFromFsmw1dFinder(const std::string& t, const std::
 //  6 : phi mode with coincided radius mode then coincide with Z mode
 
 
-StatusCode Mode3dFromFsmw1dFinder::initialize() 
-{ 
-  ATH_CHECK(  AlgTool::initialize() );
-  ATH_MSG_INFO("Initialize successful" );
-  return StatusCode::SUCCESS;
-}
-
-
-StatusCode Mode3dFromFsmw1dFinder::finalize() 
-{
-  ATH_MSG_INFO("Finalize successful" );
-  return StatusCode::SUCCESS;
-}
-
-
 Amg::Vector3D
 Mode3dFromFsmw1dFinder::getMode(const double vx,
                                 const double vy,
diff --git a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/Mode3dTo1dFinder.cxx b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/Mode3dTo1dFinder.cxx
index bb0cbbde03ebf8ae5116108f772d0bd584cf221f..b3b10a23c64f15248e1db460b161ca27c5e271bd 100644
--- a/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/Mode3dTo1dFinder.cxx
+++ b/Tracking/TrkVertexFitter/TrkVertexSeedFinderUtils/src/Mode3dTo1dFinder.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 /*********************************************************************
@@ -27,14 +27,6 @@ namespace Trk
   { 
     ATH_CHECK( AlgTool::initialize() );
     ATH_CHECK( m_mode1dfinder.retrieve() );
-    ATH_MSG_INFO( "Initialize successfull"  );
-    return StatusCode::SUCCESS;
-  }
-
-
-  StatusCode Mode3dTo1dFinder::finalize() 
-  {
-    ATH_MSG_INFO( "Finalize successfull"  );
     return StatusCode::SUCCESS;
   }
 
diff --git a/Trigger/TrigAlgorithms/TrigFastTrackFinder/python/TrigFastTrackFinder_Config.py b/Trigger/TrigAlgorithms/TrigFastTrackFinder/python/TrigFastTrackFinder_Config.py
index 189943c2024abd9b46b877cf9f442fef654edac3..05c345cf6530afc9ca3a34836d03e1442af6f31b 100755
--- a/Trigger/TrigAlgorithms/TrigFastTrackFinder/python/TrigFastTrackFinder_Config.py
+++ b/Trigger/TrigAlgorithms/TrigFastTrackFinder/python/TrigFastTrackFinder_Config.py
@@ -39,7 +39,7 @@ class TrigFastTrackFinderMonitoring(GenericMonitoringTool):
     def addDataErrorHistograms(self):
         self.defineHistogram('roi_lastStageExecuted',path='EXPERT',type='TH1F',title="Last Step Successfully Executed", xbins = 8 , xmin=-0.5, xmax=7.5,
                              xlabels=["Start","GetRoI","GetSPs","ZFinder","Triplets","TrackMaker","TrackFitter","TrackConverter"])
-   
+
     def addTimingHistograms(self, type):
         if type=='FS' or type=='JetFS' or type=='FullScan' or type=='fullScan':
             self.defineHistogram('roi_nSPs, TIME_PattReco',   path='EXPERT',type='TH2F',title="PattReco time; nSPs",    xbins = 200, xmin=0.0, xmax=200000.0, ybins = 100, ymin=0.0, ymax=40000.0)
@@ -168,55 +168,62 @@ remap  = {
     "minBias"  : "minBias400"
 }
 
+lrtSliceNames = ["electronLRT", "muonLRT", "tauLRT", "bjetLRT", "fullScanLRT"]
+
 class TrigFastTrackFinderBase(TrigFastTrackFinder):
     __slots__ = []
-    def __init__(self, name, type):
+    def __init__(self, name, slice_name):
         TrigFastTrackFinder.__init__(self,name)
 
         #Remapping should be now covered by SliceConfigurationSetting
-        remapped_type = type
+        remapped_type = slice_name
 
-        #There are still some places which relies on this remapping such as:         
+        #There are still some places which relies on this remapping such as:
         #https://gitlab.cern.ch/atlas/athena/-/blob/master/Trigger/TrigTools/TrigInDetConf/python/TrigInDetSequence.py
         #I guess eventually this should be removed
-        if type in remap:
-            remapped_type = remap[type]
-        
+        if slice_name in remap:
+            remapped_type = remap[slice_name]
+
+        isLRT = False
 
-        #Global keys/names for collections 
+        if remapped_type in lrtSliceNames:
+            isLRT = True
+
+
+        #Global keys/names for collections
         from TrigInDetConfig.InDetTrigCollectionKeys import TrigPixelKeys, TrigSCTKeys
 
 
         self.useNewLayerNumberScheme = True
-        
-        self.OutputCollectionSuffix = type
+
+        self.OutputCollectionSuffix = slice_name
         from AthenaCommon.AppMgr import ToolSvc
 
         numberingTool = TrigL2LayerNumberTool(name = "TrigL2LayerNumberTool_FTF")
         numberingTool.UseNewLayerScheme = self.useNewLayerNumberScheme
         ToolSvc += numberingTool
         self.LayerNumberTool = numberingTool
-        
+
         from InDetTrigRecExample.InDetTrigSliceSettings import InDetTrigSliceSettings
 
-        # GPU offloading config begins 
-        
+        # GPU offloading config begins
+
         self.useGPU = False
-        
+
         #if type == "FS" : self.useGPU = True
-        
+
         if self.useGPU :
             from TrigInDetAccelerationTool.TrigInDetAccelerationToolConf import TrigInDetAccelerationTool
             accelTool = TrigInDetAccelerationTool(name = "TrigInDetAccelerationTool_FTF")
             ToolSvc += accelTool
-            
-        
+
+
         # GPU offloading config ends
 
         self.doResMon = InDetTrigSliceSettings[('doResMon',remapped_type)]
 
         # switch between Run-2/3 monitoring
-        self.MonTool = TrigFastTrackFinderMonitoring(type, self.doResMon)
+        self.MonTool = TrigFastTrackFinderMonitoring(slice_name, self.doResMon)
         from TrigInDetConf.TrigInDetRecCommonTools import InDetTrigFastTrackSummaryTool
         self.TrackSummaryTool = InDetTrigFastTrackSummaryTool
 
@@ -233,30 +240,33 @@ class TrigFastTrackFinderBase(TrigFastTrackFinder):
         spTool.PixelSP_ContainerName = TrigPixelKeys.SpacePoints
         spTool.SCT_SP_ContainerName  = TrigSCTKeys.SpacePoints
         spTool.layerNumberTool = numberingTool
+        spTool.UsePixelSpacePoints = InDetTrigSliceSettings[('usePixelSP',remapped_type)]
 
         from RegionSelector.RegSelToolConfig import makeRegSelTool_Pixel
         from RegionSelector.RegSelToolConfig import makeRegSelTool_SCT
-      
+
         spTool.RegSelTool_Pixel = makeRegSelTool_Pixel()
         spTool.RegSelTool_SCT   = makeRegSelTool_SCT()
 
+        spTool.UsePixelSpacePoints=InDetTrigSliceSettings[('usePixelSP',remapped_type)]
+
         ToolSvc += spTool
         self.SpacePointProviderTool=spTool
         self.MinHits = 5 #Only process RoI with more than 5 spacepoints
-        
+
         self.Triplet_MinPtFrac = 1
         self.Triplet_nMaxPhiSlice = 53
         if remapped_type=="cosmics":
           self.Triplet_nMaxPhiSlice = 2 #Divide detector in 2 halves for cosmics
-        
+
+        self.LRT_Mode = isLRT
+
         self.Triplet_MaxBufferLength = 3
         self.doSeedRedundancyCheck = InDetTrigSliceSettings[('checkRedundantSeeds',remapped_type)]
         self.Triplet_D0Max        = InDetTrigSliceSettings[('d0SeedMax',remapped_type)]
-        self.Triplet_D0_PPS_Max   = InDetTrigSliceSettings[('d0SeedPPSMax',remapped_type)] 
-        self.TrackInitialD0Max = 20.
-        if remapped_type=='cosmics':
-          self.TrackInitialD0Max = 1000.
-          self.TrackZ0Max   = 1000.
+        self.Triplet_D0_PPS_Max   = InDetTrigSliceSettings[('d0SeedPPSMax',remapped_type)]
+        self.TrackInitialD0Max = InDetTrigSliceSettings[('d0TrackMax',remapped_type)]
+        self.TrackZ0Max = InDetTrigSliceSettings[('z0TrackMax',remapped_type)]
 
         self.TripletDoPSS   = False
         self.pTmin = InDetTrigSliceSettings[('pTmin',remapped_type)]
@@ -281,17 +291,20 @@ class TrigFastTrackFinderBase(TrigFastTrackFinder):
         from SCT_ConditionsTools.SCT_ConditionsToolsConf import SCT_ConditionsSummaryTool
         InDetTrigSiComTrackFinder_FTF.SctSummaryTool = SCT_ConditionsSummaryTool(SCT_ConditionsSetup.instanceName('InDetSCT_ConditionsSummaryToolWithoutFlagged'))
         ToolSvc += InDetTrigSiComTrackFinder_FTF
-        
-        
+
+
         from InDetTrigRecExample.ConfiguredNewTrackingTrigCuts import EFIDTrackingCuts
         TrackingCuts = EFIDTrackingCuts
         if remapped_type=="cosmics":
           from InDetTrigRecExample.ConfiguredNewTrackingTrigCuts import EFIDTrackingCutsCosmics
           TrackingCuts = EFIDTrackingCutsCosmics
+        if isLRT:
+            from InDetTrigRecExample.ConfiguredNewTrackingTrigCuts import EFIDTrackingCutLRT
+            TrackingCuts = EFIDTrackingCutLRT
 
         from SiTrackMakerTool_xk.SiTrackMakerTool_xkConf import InDet__SiTrackMaker_xk
 
-        TrackMaker_FTF = InDet__SiTrackMaker_xk(name = 'InDetTrigSiTrackMaker_FTF_'+type,
+        TrackMaker_FTF = InDet__SiTrackMaker_xk(name = 'InDetTrigSiTrackMaker_FTF_'+slice_name,
                                               RoadTool       = InDetTrigSiDetElementsRoadMaker_FTF,
                                               CombinatorialTrackFinder = InDetTrigSiComTrackFinder_FTF,
                                               pTmin          = InDetTrigSliceSettings[('pTmin',remapped_type)],
@@ -306,9 +319,9 @@ class TrigFastTrackFinderBase(TrigFastTrackFinder):
                                               UseAssociationTool       = False)
 
         from InDetTrigRecExample.InDetTrigFlags import InDetTrigFlags
-        if type=='eGamma' and InDetTrigFlags.doBremRecovery():
+        if slice_name=='eGamma' and InDetTrigFlags.doBremRecovery():
           TrackMaker_FTF.useBremModel = True
-  
+
         if remapped_type=="cosmics":
           TrackMaker_FTF.CosmicTrack=True
 
@@ -320,14 +333,14 @@ class TrigFastTrackFinderBase(TrigFastTrackFinder):
         #theTrigInDetTrackFitter.correctClusterPos = False #Flag to control whether to correct cluster position
         theTrigInDetTrackFitter.correctClusterPos = True  #temporarily to true to improve err(z0) estimates
 
-          
+
 
         from InDetTrigRecExample.InDetTrigConfigRecLoadTools import InDetTrigRotCreator
         theTrigInDetTrackFitter.ROTcreator = InDetTrigRotCreator
         ToolSvc += theTrigInDetTrackFitter
         self.trigInDetTrackFitter = theTrigInDetTrackFitter
         from InDetTrigRecExample.InDetTrigFlags import InDetTrigFlags
-        if type=='eGamma' and InDetTrigFlags.doBremRecovery():
+        if slice_name=='eGamma' and InDetTrigFlags.doBremRecovery():
           theTrigInDetTrackFitterBrem = TrigInDetTrackFitter(name='theTrigInDetTrackFitterBrem',
                                                              doBremmCorrection = True)
           ToolSvc += theTrigInDetTrackFitterBrem
@@ -339,8 +352,8 @@ class TrigFastTrackFinderBase(TrigFastTrackFinder):
           theTrigZFinder = TrigZFinder( name="TrigZFinder_"+remapped_type )
           theTrigZFinder.NumberOfPeaks = 3
           theTrigZFinder.LayerNumberTool=numberingTool
-          
-          if remapped_type == "beamSpot" : 
+
+          if remapped_type == "beamSpot" :
             theTrigZFinder.TripletMode = 1
             theTrigZFinder.TripletDZ   = 1
             theTrigZFinder.PhiBinSize  = 0.1
@@ -355,8 +368,8 @@ class TrigFastTrackFinderBase(TrigFastTrackFinder):
 
         TrackMaker_FTF.InputClusterContainerName = ""
         TrackMaker_FTF.InputHadClusterContainerName = ""
-        
-        
+
+
         from TrigInDetConf.TrigInDetRecCommonTools import InDetTrigFastTrackSummaryTool
         self.TrackSummaryTool = InDetTrigFastTrackSummaryTool
 
diff --git a/Trigger/TrigAlgorithms/TrigMuSuperEF/CMakeLists.txt b/Trigger/TrigAlgorithms/TrigMuSuperEF/CMakeLists.txt
index e7469ef16b51e36afe08b1cdb7cf15db35908fcf..78eb5422cf181c05454ae8f89cd99d90d0c12358 100644
--- a/Trigger/TrigAlgorithms/TrigMuSuperEF/CMakeLists.txt
+++ b/Trigger/TrigAlgorithms/TrigMuSuperEF/CMakeLists.txt
@@ -11,5 +11,3 @@ atlas_add_component( TrigMuSuperEF
 
 # Install files from the package:
 atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} --extend-extensions=ATL900,ATL901 )
-atlas_install_joboptions( share/test_TrigMuSuperEF.py share/TrigMuSuperEF_debug_postOptions.py )
-
diff --git a/Trigger/TrigAlgorithms/TrigMuSuperEF/share/TrigMuSuperEF_debug_postOptions.py b/Trigger/TrigAlgorithms/TrigMuSuperEF/share/TrigMuSuperEF_debug_postOptions.py
deleted file mode 100644
index 1341e653f2f212d992f934ad86d9152c134c17a3..0000000000000000000000000000000000000000
--- a/Trigger/TrigAlgorithms/TrigMuSuperEF/share/TrigMuSuperEF_debug_postOptions.py
+++ /dev/null
@@ -1,171 +0,0 @@
-#
-# JobOptions for setting some output levels in Muon HLT Trigger Algorithms
-# Available output level variables to tune the levels:
-# ConfigOutputLevel
-# L2OutputLvl    for muFast and muComb
-# TMEFOutputLvl  for TrigMuonEF algorithms
-# TMEFSummary    for TrigMuonEF algorithms printing summary per event per stage
-# MGOutputLvl    for TrigMuGirl algorithms
-#
-
-from AthenaCommon.Logging import logging
-
-# a few default OUTPUT levels depending on the number of events processing
-log = logging.getLogger()
-defaultOutputLvl = log.mapLevelLoggingToGaudi(log.getEffectiveLevel())
-
-if athenaCommonFlags.EvtMax() == -1 or athenaCommonFlags.EvtMax() > 1000:
-    if "ConfigOutputLevel" not in dir(): ConfigOutputLevel = defaultOutputLvl
-    if "L2OutputLvl"       not in dir(): L2OutputLvl = defaultOutputLvl
-    if "TMEFOutputLvl"     not in dir(): TMEFOutputLvl = defaultOutputLvl
-    if "MGOutputLvl"       not in dir(): MGOutputLvl = defaultOutputLvl
-    if "TMEFSummary"       not in dir(): TMEFSummary = False
-
-elif athenaCommonFlags.EvtMax() > 100:
-    if "ConfigOutputLevel" not in dir(): ConfigOutputLevel = VERBOSE
-    if "L2OutputLvl"       not in dir(): L2OutputLvl = INFO
-    if "TMEFOutputLvl"     not in dir(): TMEFOutputLvl = DEBUG
-    if "MGOutputLvl"       not in dir(): MGOutputLvl = DEBUG
-    if "TMEFSummary"       not in dir(): TMEFSummary = True
-else: # <= 100 events
-    if "ConfigOutputLevel" not in dir(): ConfigOutputLevel = VERBOSE
-    if "L2OutputLvl"       not in dir(): L2OutputLvl = INFO
-    if "TMEFOutputLvl"     not in dir(): TMEFOutputLvl = VERBOSE
-    if "MGOutputLvl"       not in dir(): MGOutputLvl = VERBOSE
-    if "TMEFSummary"       not in dir(): TMEFSummary = True
-
-
-# helper function for nice OutputLevel setting printout
-OutputLevelNames = {}
-OutputLevelNames[ALL] = "ALL"
-OutputLevelNames[VERBOSE]="VERBOSE"
-OutputLevelNames[DEBUG]="DEBUG"
-OutputLevelNames[INFO]="INFO"
-OutputLevelNames[WARNING]="WARNING"
-OutputLevelNames[ERROR]="ERROR"
-OutputLevelNames[FATAL]="FATAL"
-
-def setOutputLevel(conf,level):
-    print "Setting %s.OutputLevel = %s" % (conf.getJobOptName(),OutputLevelNames[level])
-    conf.OutputLevel = level
-    
-
-MessageSvc.debugLimit = 10000
-MessageSvc.Format = "% F%65W%S%7W%R%T %0W%M"
-
-try:
-    L2_sequence = topSequence.TrigSteer_HLT.getChildren()
-except AttributeError:
-    try:
-        L2_sequence = topSequence.TrigSteer_L2.getChildren()
-    except AttributeError:
-        L2_sequence = []
-
-################################################################################
-# L2 tweeking
-################################################################################
-for L2_alg in L2_sequence:
-    algType = L2_alg.getType()
-
-    # set output levels
-    if algType.startswith("Mufast") or algType.startswith("Mucomb"):
-        setOutputLevel(L2_alg,L2OutputLvl)
-
-
-################################################################################
-# EF tweeking
-################################################################################
-try:
-    EF_sequence = topSequence.TrigSteer_HLT.getChildren()
-except AttributeError:
-    try:
-        EF_sequence = topSequence.TrigSteer_EF.getChildren()
-    except AttributeError:
-        EF_sequence = []
-
-#
-# here we add the algorithm used for debugging TrigMuSuperEF
-#
-for EF_alg in EF_sequence:
-    algType = EF_alg.getType()
-
-    # set output levels
-    if algType.startswith('TrigMuonEF'):
-        setOutputLevel(EF_alg,TMEFOutputLvl)            
-    elif algType.startswith('TrigMuGirl'):
-       setOutputLevel(EF_alg,MGOutputLvl)            
-    elif algType.startswith('TrigMuSuperEF'):
-       setOutputLevel(EF_alg,min(MGOutputLvl,TMEFOutputLvl))
-    elif algType.startswith('TrigCaloClusterMaker'):
-        setOutputLevel(EF_alg,INFO)
-
-    TMEF_SegmentFinder = None
-    TMEF_TrackBuilder = None
-    TMEF_Extrapolator = None
-    TMEF_Combiner = None
-    TMEF_CombinerHypo = None
-    TMEF_Isolation = None
-    TMEF_IsolationHypo = None
-    TrigMuGirl = None
-    TrigMuGirlHypo = None
-
-
-    if algType == 'TrigMuSuperEF':
-        TMEF_SegmentFinder = getattr(ToolSvc,EF_alg.TMEF_standaloneTrackTool.getName())
-        TMEF_TrackBuilder  = getattr(ToolSvc,EF_alg.TMEF_standaloneTrackTool.getName())
-        TMEF_Extrapolator  = getattr(ToolSvc,EF_alg.TMEF_standaloneTrackTool.getName())
-        TMEF_Combiner      = getattr(ToolSvc,EF_alg.TMEF_combinerTool.getName())
-        TrigMuGirl         = getattr(ToolSvc,EF_alg.TrigMuGirlTool.getName())
-    elif algType == 'TrigMuonEFSegmentFinder':
-        TMEF_SegmentFinder = EF_alg
-    elif algType == 'TrigMuonEFTrackBuilder':
-        TMEF_TrackBuilder = EF_alg
-    elif algType == 'TrigMuonEFExtrapolator':
-        TMEF_Extrapolator = EF_alg
-    elif algType == 'TrigMuonEFCombiner':
-        TMEF_Combiner = EF_alg
-    elif algType == 'TrigMuGirl':
-        TrigMuGirl = EF_alg
-    else:
-        continue            
-
-    # set some properties
-    if TMEF_SegmentFinder is not None:
-        setOutputLevel(TMEF_SegmentFinder,TMEFOutputLvl)
-        # activate summaries for offline tools (or not)
-        TMEF_SegmentFinder.SegmentsFinderTool.DoSummary = TMEFSummary
-
-
-    if TMEF_TrackBuilder is not None:
-        setOutputLevel(TMEF_TrackBuilder,TMEFOutputLvl)
-        # activate summaries for offline tools (or not)
-        TMEF_TrackBuilder.TrackBuilderTool.DoSummary = TMEFSummary
-
-    if TMEF_Extrapolator is not None:
-        setOutputLevel(TMEF_Extrapolator,TMEFOutputLvl)
-
-    if TMEF_Combiner is not None:
-        setOutputLevel(TMEF_Combiner,TMEFOutputLvl)
-
-    if TrigMuGirl is not None:
-        setOutputLevel(TrigMuGirl,MGOutputLvl)
-        
-
-# less output on some algs
-# only way to shut up CTPSimulation
-from TriggerJobOpts import Lvl1TriggerGetter
-Lvl1TriggerGetter.Lvl1OutputLevel = defaultOutputLvl
-try:
-    topSequence.CTPSimulation.OutputLevel = defaultOutputLvl
-except AttributeError:
-    pass
-
-if ConfigOutputLevel <= DEBUG:
-    from AthenaCommon import CfgGetter
-    CfgGetter.printStats()
-
-from AthenaCommon.ConfigurationShelve import saveToAscii
-from MuonRecExample.MuonRecUtils import dumpDetFlags
-saveToAscii("config.txt")
-dumpDetFlags("config.txt")
-
diff --git a/Trigger/TrigAlgorithms/TrigMuSuperEF/share/test_TrigMuSuperEF.py b/Trigger/TrigAlgorithms/TrigMuSuperEF/share/test_TrigMuSuperEF.py
deleted file mode 100755
index 4c9b99cb9caf864f1ff54a3056bfc9a2a80ef223..0000000000000000000000000000000000000000
--- a/Trigger/TrigAlgorithms/TrigMuSuperEF/share/test_TrigMuSuperEF.py
+++ /dev/null
@@ -1,535 +0,0 @@
-#
-# steering file for testing muon trigger slice with offline supertools
-#
-from RecExConfig.RecFlags import rec
-from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
-from AthenaCommon.GlobalFlags import globalflags
-from AthenaCommon.CfgGetter import getAlgorithm
-from AthenaCommon.Logging import logging
-
-from TriggerJobOpts.TriggerFlags import TriggerFlags
-
-from PerfMonComps import PerfMonFlags
-
-from MuonRecExample.MuonRecFlags import muonRecFlags
-from MuonCombinedRecExample.MuonCombinedRecFlags import muonCombinedRecFlags
-
-include("TriggerTest/TrigScanFiles.py")
-
-
-if 'doOldChains' not in dir():
-    doOldChains=True
-
-if 'doNewChains' not in dir():
-    doNewChains=True
-
-if 'doIsolation' not in dir():
-    doIsolation=True
-
-if 'doOffline' not in dir():
-    doOffline=True
-
-if 'makeESD' not in dir():
-    makeESD=True
-
-if 'makeAOD' not in dir():
-    makeAOD=False
-
-if 'doMuonCombined' not in dir():
-    doMuonCombined=True
-
-if 'doTrackPerformance' not in dir():
-    doTrackPerformance=False
-
-# if 'doMuonSA' not in dir():
-#     doMuonSA=False
-
-# if 'doMuonSA_only' not in dir():
-#     doMuonSA_only=False
-
-if 'v4Menus' not in dir():
-    v4Menus=True
-
-if 'v4MenuValidation' not in dir():
-    v4MenuValidation = False
-
-if 'EvtMax' not in dir():
-    athenaCommonFlags.EvtMax = 1
-else:
-    athenaCommonFlags.EvtMax = EvtMax
-    del EvtMax # no longer needed and gives WARNING or ERROR from RecExCommon
-
-if 'Input' not in dir():
-    Input='T1'
-
-
-# a few specific OUTPUT levels
-if athenaCommonFlags.EvtMax() <= 100:
-    ConfigOutputLevel = VERBOSE
-    L2OutputLvl = INFO
-    EFOutputLvl = VERBOSE
-    TMEFOutputLvl = VERBOSE
-    MGOutputLvl = VERBOSE
-elif athenaCommonFlags.EvtMax() <= 1000:
-    ConfigOutputLevel = VERBOSE
-    L2OutputLvl = INFO
-    EFOutputLvl = VERBOSE
-    TMEFOutputLvl = DEBUG
-    MGOutputLvl = DEBUG
-else:
-    ConfigOutputLevel = INFO
-    L2OutputLvl = INFO
-    EFOutputLvl = INFO
-    TMEFOutputLvl = INFO
-    MGOutputLvl = INFO
-
-
-#athenaCommonFlags.FilesInput = getEOSDirectoryList( "/eos/atlas/atlasgroupdisk/trig-daq/validation/test_data/EnhancedBias10TeV15315m31.digit.RDO.e357_s462_d148_t93a97/", [1,20] )
-
-#athenaCommonFlags.FilesInput = [ "root://eosatlas.cern.ch//eos/atlas/atlascerngroupdisk/trig-daq/validation/test_data/data11_7TeV.00191628.physics_eb_zee_zmumu._0001.data" ]
-
-if Input=='Zmumu':
-    athenaCommonFlags.FilesInput = getEOSDirectoryList( "/eos/atlas/atlascerngroupdisk/trig-daq/validation/test_data/mc10_7TeV.106047.PythiaZmumu_no_filter.digit.RDO.e574_s1021_d423_tid211907_00", [1,20] )
-elif Input == "T1":
-    athenaCommonFlags.FilesInput = getEOSDirectoryList( "/eos/atlas/atlascerngroupdisk/trig-daq/validation/test_data/mc10_7TeV.105200.T1_McAtNlo_Jimmy.digit.RDO.e598_s933_s946_d366_tid197091_00", [1,20] )
-elif Input != "user":
-    raise RuntimeError("Unknown input data: %r" % Input)
-else:
-    # assumes user has set athenaCommonFlags.FilesInput
-    pass
-
-# do trigger
-rec.doTrigger.set_Value_and_Lock(True)
-TriggerFlags.doLVL1.set_Value_and_Lock(True)
-TriggerFlags.doLVL2.set_Value_and_Lock(True)
-TriggerFlags.doEF.set_Value_and_Lock(True)
-rec.doESD      = True
-
-# detector flags
-rec.doMuon          = True
-rec.doInDet         = True
-rec.doCalo          = True
-rec.doLArg          = True
-rec.doTile          = True
-rec.doLucid         = True
-
-rec.doNameAuditor = True
-
-muonRecFlags.doMuonboy = True
-muonRecFlags.doStandalone = False
-muonRecFlags.doMoore = True
-
-muonRecFlags.Enabled = doOffline
-
-muonCombinedRecFlags.doMuidMuonCollection = True
-muonCombinedRecFlags.doStacoMuonCollection = False
-muonCombinedRecFlags.doMuonCollection = False
-muonCombinedRecFlags.doCaloMuonCollection = False
-
-muonCombinedRecFlags.Enabled = doOffline
-
-# muon flags
-# from MuonRecExample.MuonRecFlags import muonRecFlags
-# muonRecFlags.doStandalone = True
-
-#from MuonRecExample.MuonStandaloneFlags import muonStandaloneFlags
-#muonStandaloneFlags.trackBuilder = 'Moore'
-
-#from TrigMuonSuperEF.TrigMuonFlags import trigMuonFlags
-#trigMuonFlags.doStandalone = True
-#trigMuonFlags.trackBuilder = 'Moore'
-
-
-# input/output
-rec.readESD         = False
-rec.doWriteESD      = makeESD 
-rec.doCBNT          = False
-rec.doWriteAOD      = makeAOD
-rec.doWriteTAG      = False
-rec.doWriteBS       = False
-
-if not doOffline: doMuonCombined = False
-
-# don't do unnecessary stuff
-rec.doMuonCombined  = doMuonCombined
-rec.doAOD           = makeAOD
-rec.doAODall        = False
-rec.doJiveXML       = False
-
-# physics flags
-rec.doHeavyIon        = False
-rec.doEgamma          = False
-rec.doTau             = False
-rec.doJetMissingETTag = False
-
-# monitoring/auditing
-rec.doPerfMon             = False
-rec.doDetailedPerfMon     = False
-rec.doSemiDetailedPerfMon = False
-rec.doMonitoring          = False
-rec.doFastPhysMonitoring  = False
-rec.doDetailedAuditor     = False
-rec.doSGAuditor           = False
-
-# algorithms
-from RecExConfig.RecAlgsFlags import recAlgs
-recAlgs.doTrigger           = True
-recAlgs.doTrackRecordFilter = True # filter truth muons getting into the spectrometer
-recAlgs.doMissingET         = False
-recAlgs.doMissingETSig      = False
-recAlgs.doObjMissingET      = False
-recAlgs.doEFlow             = False
-recAlgs.doEFlowJet          = False
-recAlgs.doAtlfast           = False
-recAlgs.doMuonSpShower      = False
-recAlgs.doTileMuID          = False
-recAlgs.doMuTag             = False
-recAlgs.doCaloTrkMuId       = False
-recAlgs.doEgammaBremReco    = False
-recAlgs.doAtlfast           = False
-
-from CaloRec.CaloRecFlags import jobproperties
-jobproperties.CaloRecFlags.Enabled=doMuonCombined
-
-from InDetRecExample.InDetJobProperties import InDetFlags
-jobproperties.InDetJobProperties.disableInDetReco=not doMuonCombined
-
-from MuonRecExample.MuonRecFlags import muonRecFlags
-jobproperties.MuonRec.Enabled=doMuonCombined
-
-from MuonCombinedRecExample.MuonCombinedRecFlags import muonCombinedRecFlags 
-jobproperties.MuonCombinedRec.Enabled=doMuonCombined
-
-from MuonCombinedRecExample.MuidFlags import muidFlags 
-jobproperties.Muid.Enabled=doMuonCombined
-
-from egammaRec.egammaRecFlags import jobproperties
-jobproperties.egammaRecFlags.Enabled=False
-
-from JetRec.JetRecFlags import jobproperties
-jobproperties.JetRecFlags.Enabled=False
-   
-from tauRec.tauRecFlags import jobproperties
-jobproperties.tauRecFlags.Enabled=False
- 
-# disable JetRec (no RecFlags flag for that)
-try:
-    from JetRec.JetRecFlags import jetFlags
-    jetFlags.Enabled = False
-except ImportError:
-    pass
-
-# bug in RecExCond does not pass rec.doTau()
-try:
-    from tauRec.tauRecFlags import jobproperties
-    jobproperties.tauRecFlags.Enabled = rec.doTau()
-except ImportError:
-    pass
-
-
-if ConfigOutputLevel <= DEBUG:
-    from AthenaCommon import CfgGetter
-    CfgGetter.setLogLevel(ConfigOutputLevel)
-
-
-def MuonOnly():
-    global TriggerFlags,doOldChains,doNewChains,doIsolation,v4Menus
-    from TriggerMenuPython.StreamingSliceFlags  import StreamingSliceFlags # not included in TriggerFlags
-    TriggerFlags.Slices_all_setOff()
-    TriggerFlags.MuonSlice.setAll()
-
-    from AthenaCommon.JobProperties import JobPropertyContainer
-    for prop in TriggerFlags.__dict__.values():
-        if isinstance( prop, JobPropertyContainer ) and prop.__name__ != 'MuonSlice':
-            try:
-                prop.signatures = []
-            except AttributeError:
-                pass
-
-
-    Muons = []
-
-    if v4Menus:
-        if v4MenuValidation:
-            # only use a matching sub-set, so the monitoring histograms can be used for validation
-            #     if not doMuonSA_only:
-            #                 Muons += [ 'mu24_tight', 'mu24_tight_MuonEF', 'mu24_tight_MG' ]
-            #                 if doIsolation:
-            #                     Muons += [ 'mu24i_tight', 'mu24i_tight_MuonEF', 'mu24i_tight_MG']
-            #             if doMuonSA and doIsolation:
-            #                 Muons += [ 'mu24i_tight_newMuonSA' ]
-            
-            #Muons += [ 'mu24_tight', 'mu24_tight_MuonEF', 'mu24_tight_MG' ]
-            if doIsolation:
-                Muons += [ 'mu24i_tight' ]#, 'mu24i_tight_MuonEF', 'mu24i_tight_MG']
-            
-            TriggerFlags.MuonSlice.signatures = Muons
-        else: # full v4 Menu for Muon
-            if not doOldChains:
-                Muons = [ m for m in TriggerFlags.MuonSlice.signatures() if not m.endswith('_MuonEF') and not m.endswith('_MG') ]
-                TriggerFlags.MuonSlice.signatures = Muons
-            pass
-
-        return
-
-
-    # v3 menus
-    if doNewChains:
-        # TrigMuSuperEF chains
-        Muons += [
-
-        # 'mu18_OR_medium', 
-
-        # special versions for performance comparison
-        'mu18_OR_medium_MGfirst',
-        'mu18_OR_medium_TMEFfirst',
-        'mu18_OR_medium_both',
-
-        # special versions for validation
-        'mu18_OR_medium_MGonly',
-        'mu18_OR_medium_TMEFonly',
-        ]
-
-        if doIsolation:
-            Muons += [
-
-                # isolation chains
-                # 'mu18i1_OR_medium',
-                # 'mu18i2_OR_medium',
-                # 'mu18i3_OR_medium',
-                # 'mu18i4_OR_medium',
-                # 'mu24i1_OR_tight',
-                # 'mu24i2_OR_tight',
-                # 'mu24i3_OR_tight',
-                # 'mu24i4_OR_tight',
-                # 'mu24i5_OR_tight',
-
-                # special versions for performance comparison
-                'mu24i5_OR_tight_MGfirst',
-                'mu24i5_OR_tight_TMEFfirst',
-                'mu24i5_OR_tight_both',
-
-                # special versions for validation
-                # 'mu24i1_OR_tight_TMEFonly',
-                # 'mu24i2_OR_tight_TMEFonly',
-                # 'mu24i3_OR_tight_TMEFonly',
-                # 'mu24i4_OR_tight_TMEFonly',
-                'mu24i5_OR_tight_TMEFonly',
-                'mu24i5_OR_tight_MGonly',
-
-                ]
-
-    if doOldChains:
-        # MuGirl chains
-        Muons += [
-            'mu18_MG_medium', 
-            ]
-
-        # TrigMuonEF chains
-        Muons += [
-            # non-isolation chains
-            'mu18_medium', 
-            ]
-
-        if doIsolation:
-            Muons += [
-                # isolation chains
-                'mu24i5_tight',
-                ]
-
-
-    TriggerFlags.MuonSlice.signatures = Muons
-
-
-
-
-# to get fast error feedback
-MuonOnly()
-
-
-try:
-    #-----------------------------------------------------------
-    include("RecExCond/RecExCommon_flags.py")
-    #-----------------------------------------------------------
-
-
-    # from testMuonAthenaTrigRDO.py
-    # set up trigger monitoring
-    TriggerFlags.enableMonitoring = [ 'Validation', 'Time', 'Log' ]
-
-    # set trigger menu
-    TriggerFlags.readHLTconfigFromXML=False
-    TriggerFlags.readLVL1configFromXML=False
-    if v4Menus:
-        TriggerFlags.triggerMenuSetup = 'MC_pp_v4'
-    else:
-        TriggerFlags.triggerMenuSetup = 'MC_pp_v3'
-    TriggerFlags.L1PrescaleSet = 'None' 
-    TriggerFlags.HLTPrescaleSet = 'None' 
-    TriggerFlags.useL1CaloCalibration = True
-
-    logging.getLogger("TriggerMenuPython.MuonDef").setLevel(ConfigOutputLevel)
-
-    # enable only Muon slice
-    from TriggerMenuPython.GenerateMenu import GenerateMenu
-    GenerateMenu.overwriteSignaturesWith(MuonOnly)
-
-    # main jobOption
-    include ("RecExCommon/RecExCommon_topOptions.py")
-
-    include("TriggerTest/TriggerTestCommon.py")
-
-    print "printing topSequence: "
-    print topSequence
-
-    ################################################################################
-    # L2 tweeking
-    ################################################################################
-    for L2_alg in topSequence.TrigSteer_L2.getChildren():
-        algType = L2_alg.getType()
-
-        # special setting for some algs
-        if algType == "muFast":
-            L2_alg.MUlvl1INFO  = False
-            L2_alg.MUtrackINFO = False
-            L2_alg.MUroadsINFO = False
-            L2_alg.MUdecoINFO  = False
-            L2_alg.MUcontINFO  = False
-            L2_alg.MUfitINFO   = False
-            L2_alg.MUsagINFO   = False
-            L2_alg.MUptINFO    = True
-            L2_alg.TestString = L2_alg.getName()+"  REGTEST "
-
-
-    ################################################################################
-    # EF tweeking
-    ################################################################################
-    TrigSteer_EF = topSequence.TrigSteer_EF
-
-    #
-    # here we add the algorithm used for debugging TrigMuSuperEF
-    #
-    for EF_alg in TrigSteer_EF.getChildren():
-        algType = EF_alg.getType()
-
-        TMEF_SegmentFinder = None
-        TMEF_TrackBuilder = None
-        TMEF_Extrapolator = None
-        TMEF_Combiner = None
-        TMEF_CombinerHypo = None
-        TMEF_Isolation = None
-        TMEF_IsolationHypo = None
-        TrigMuGirl = None
-        TrigMuGirlHypo = None
-
-        if algType == 'TrigMuSuperEF':
-            TMEF_SegmentFinder = EF_alg
-            TMEF_TrackBuilder  = EF_alg
-        elif algType == 'TrigMuonEFSegmentFinder':
-            TMEF_SegmentFinder = EF_alg
-        elif algType == 'TrigMuonEFTrackBuilder':
-            TMEF_TrackBuilder = EF_alg
-        elif algType == 'TrigMuonEFExtrapolator':
-            TMEF_Extrapolator = EF_alg
-        elif algType == 'TrigMuonEFCombiner':
-            TMEF_Combiner = EF_alg
-        elif algType == 'TrigMuGirl':
-            TrigMuGirl = EF_alg
-        else:
-            continue            
-
-        # set some properties
-        if TMEF_SegmentFinder is not None:
-            TMEF_SegmentFinder.recordSegmentCombinations = False
-            TMEF_SegmentFinder.recordPatternCombinations = False
-
- 
-            #           if TMEF_TrackBuilder is not None:
-            # for debug purposes write TrackCollection in StoreGate and use MuonTrackPerformanceAlg
-            #            if doTrackPerformance:
-            #                TMEF_TrackBuilder.recordTrackCollection = True
-    
-    if doTrackPerformance:
-        from MuonTrackPerformance.MuonTrackPerformanceConf import MuonTrackPerformanceAlg
-        topSequence += MuonTrackPerformanceAlg("MuonTrackPerformanceAlg",
-                                               TrackInputLocation = "TrigMuonEFTBTracks",
-                                               SegmentCombitLocation = "TrigMuonEFSegments" )
-        topSequence.MuonTrackPerformanceAlg.DoSummary = 1
-        topSequence.MuonTrackPerformanceAlg.DoTrackDebug = 5
-        
-
-    include("TrigMuSuperEF/TrigMuSuperEF_debug_postOptions.py")
-
-
-    if makeESD:
-        # Remove the following outputs defined in
-        # MuonSpectrometer/MuonReconstruction/MuonRecExample/share/MuonRecOutputItemList_jobOptions.py.
-        # To fix bug #79056: ERROR INCORRECT Object/count: Muon PRDs
-        
-        from AthenaCommon.AppMgr import theApp
-        StreamESD = theApp.getOutputStream( "StreamESD" )
-
-        while "Muon::CscPrepDataContainer#CSC_Clusters" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::CscPrepDataContainer#CSC_Clusters")
-        while "Muon::CscPrepDataContainer#CSC_Clusters" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::CscPrepDataContainer#CSC_Clusters")
-        while "Muon::CscPrepDataContainer#CSC_Clusters" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::CscPrepDataContainer#CSC_Clusters")
-        while "Muon::CscStripPrepDataContainer#CSC_Measurements" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::CscStripPrepDataContainer#CSC_Measurements")
-        while "Muon::RpcPrepDataContainer#RPC_Measurements" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::RpcPrepDataContainer#RPC_Measurements")
-        while "Muon::TgcPrepDataContainer#TGC_Measurements" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::TgcPrepDataContainer#TGC_Measurements")
-        while "Muon::MdtPrepDataContainer#MDT_DriftCircles" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::MdtPrepDataContainer#MDT_DriftCircles")
-        
-        while "Muon::TgcPrepDataContainer#TGC_MeasurementsPriorBC" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::TgcPrepDataContainer#TGC_MeasurementsPriorBC")
-        while "Muon::TgcPrepDataContainer#TGC_MeasurementsNextBC" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::TgcPrepDataContainer#TGC_MeasurementsNextBC")
-        
-        while "Muon::TgcCoinDataContainer#TrigT1CoinDataCollection" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::TgcCoinDataContainer#TrigT1CoinDataCollection")
-        while "Muon::TgcCoinDataContainer#TrigT1CoinDataCollectionPriorBC" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::TgcCoinDataContainer#TrigT1CoinDataCollectionPriorBC")
-        while "Muon::TgcCoinDataContainer#TrigT1CoinDataCollectionNextBC" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::TgcCoinDataContainer#TrigT1CoinDataCollectionNextBC")
-        
-        while "Muon::RpcCoinDataContainer#RPC_triggerHits" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("Muon::RpcCoinDataContainer#RPC_triggerHits")
-        while "RpcSectorLogicContainer#RPC_SECTORLOGIC" in StreamESD.ItemList:
-            StreamESD.ItemList.remove("RpcSectorLogicContainer#RPC_SECTORLOGIC")
-        
-except:
-    # still do a few things in case of error
-    if ConfigOutputLevel <= DEBUG:
-        from AthenaCommon import CfgGetter
-        CfgGetter.printStats()
-
-    from AthenaCommon.ConfigurationShelve import saveToAscii
-    from MuonRecExample.MuonRecUtils import dumpDetFlags
-    saveToAscii("config.txt")
-    dumpDetFlags("config.txt")
-
-    print 80*"="
-    print "TriggerFlags"
-    print 80*"="
-    print TriggerFlags
-
-    raise
-
-else:
-    if ConfigOutputLevel <= DEBUG:
-        from AthenaCommon import CfgGetter
-        CfgGetter.printStats()
-
-    from AthenaCommon.ConfigurationShelve import saveToAscii
-    from MuonRecExample.MuonRecUtils import dumpDetFlags
-    saveToAscii("config.txt")
-    dumpDetFlags("config.txt")
-
-    print 80*"="
-    print "TriggerFlags"
-    print 80*"="
-    print TriggerFlags
diff --git a/Trigger/TrigAlgorithms/TrigT2BeamSpot/CMakeLists.txt b/Trigger/TrigAlgorithms/TrigT2BeamSpot/CMakeLists.txt
index 082eba673cd8c903f0c65156caa7c149899acdf1..ce22c00a73fea15bc07068db2fe0e838af85d5d2 100644
--- a/Trigger/TrigAlgorithms/TrigT2BeamSpot/CMakeLists.txt
+++ b/Trigger/TrigAlgorithms/TrigT2BeamSpot/CMakeLists.txt
@@ -15,5 +15,3 @@ atlas_add_component( TrigT2BeamSpot
 
 # Install files from the package:
 atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
-atlas_install_joboptions( share/*.py )
-
diff --git a/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/myNewTrigger_jobOptions.py b/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/myNewTrigger_jobOptions.py
deleted file mode 100644
index 83d68c2896658efc0ec80ffa7a5b802c3f21527f..0000000000000000000000000000000000000000
--- a/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/myNewTrigger_jobOptions.py
+++ /dev/null
@@ -1,226 +0,0 @@
-#----------------------------------------
-# Return a file list given a directory
-#----------------------------------------
-
-import os,commands
-def getDirectoryList(path):
-    cmd  = 'ls %s/' % (path)
-    file = ["%s/%s" % (path,i) for i in commands.getoutput(cmd).split('\n')]
-    return file
-
-def getMixedDirectoryList(path):
-    cmd  = 'ls %s/*.root*' % (path)
-    file = ["%s" % (i) for i in commands.getoutput(cmd).split('\n')]
-    return file    
-    
-def getCastorDirectoryList(path):
-    cmd  = 'nsls %s/ ' % (path)
-    file = ["rfio:%s/%s" % (path,i) for i in commands.getoutput(cmd).split('\n')]
-    return files
-
-#-----------------
-# Input files
-#-----------------
-if ('Data' in dir()):
-    if Data == "shift":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/ttbar_shift')
-    elif Data == "gashalo":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/gashalo')
-    elif Data == "mixed":
-        PoolRDOInput  = getMixedDirectoryList('/u1/iaracena/data/MixedEventsEnhancedb/RDO')
-    elif Data == "EnhancedBias":
-        PoolRDOInput  = getMixedDirectoryList('/u1/data/user09.SethCaughron.EnhancedBias_10TeV.digit.RDO.e357_s462_d126') 
-    elif Data == "J2":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/J2')
-    elif Data == "J3":
-        PoolRDOInput  = getDirectoryList('/u1/data/J3_RDO_rel12')
-    elif Data == "J1":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/J1')
-    elif Data == "J4":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/J4') 
-    elif Data == "J0":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/J0')
-else:
-    Data = "shift"
-    PoolRDOInput  = getDirectoryList('/u1/fizisist/ttbar_shift')
-
-#-----------------
-# Output files
-#-----------------    
-PoolESDOutput = 'rfio:/castor/cern.ch/user/f/fizisist/beamspot/myTriggerTest2.mixed.ESD.pool.root'
-PoolAODOutput = 'rfio:/castor/cern.ch/user/f/fizisist/beamspot/myTriggerTest2.mixed.AOD.pool.root'
-
-if not ('EvtMax' in dir()):                                   
-    EvtMax=1000
-
-NEvents = "%d" % EvtMax
-
-#-----------------
-# Global Flags
-#-----------------
-from AthenaCommon.GlobalFlags import GlobalFlags
-GlobalFlags.Print()
-DetDescrVersion = "ATLAS-GEO-02-01-00"
-GlobalFlags.DetDescrVersion = DetDescrVersion
-
-#-----------------
-# Global Setup
-#-----------------
-doTAG          = False
-doEgamma       = False
-doMuon         = False
-doJet          = False
-doTauRec       = False
-doObjMissingET = False
-doMuGirl       = False
-doMoore        = False
-doMuonIDStandAlone = False
-doMuonIDCombined   = False 
-
-doCBNT     = False
-doWriteAOD = False
-doWriteESD = False
-doWriteTAG = False
-doAOD      = False 
-doESD      = False 
-doTAG      = False
-doTruth    = False
-doAtlfast  = False
-
-#-----------------
-# Trigger Setup
-#-----------------
-doTrigger           = True
-
-#-----------------------------------------------------------
-include("RecExCommon/RecExCommon_flags.py")
-#-----------------------------------------------------------
-
-#-----------------
-# InDet Flags
-#-----------------
-from InDetRecExample.InDetJobProperties import InDetFlags
-from AthenaCommon.JobProperties import jobproperties
-from InDetTrigRecExample.InDetTrigFlags import InDetTrigFlags
-if Data == "gashalo":
-  InDetFlags.Enabled                 = True
-  InDetFlags.doBeamGas               = True
-  InDetFlags.doBeamHalo              = True
-  InDetFlags.doSiSPSeededTrackFinder = True
-  InDetFlags.doPrintConfigurables    = True
-  InDetTrigFlags.doBeamGas  = True
-  InDetTrigFlags.doBeamHalo = True
-
-#-----------------
-# Trigger Flags
-#-----------------
-from TriggerJobOpts.TriggerFlags import TriggerFlags
-from TriggerMenuPython.BeamSpotSliceFlags import *
-BeamSpotSliceFlags.setAll()
-
-#-----------------
-# BeamSpot Menu
-#-----------------
-def MyBeamSpotMenu():
-  if ('Seed' in dir()):
-      if Seed == "list":
-        TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_list' ]
-      elif Seed == "jet10":
-        TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_jet10' ]
-      elif Seed == "bjet18":
-        TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_bjet18' ]
-      elif Seed == "FSTracks":
-        TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_FSTracks' ]
-      elif Seed == "tau16i_loose":
-        TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_tau16i_loose' ]
-      elif Seed == "e10_medium":
-        TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_e10_medium' ]
-      elif Seed == "e10_medium_SiTrk":
-        TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_e10_medium_SiTrk' ]
-      elif Seed == "e10_medium_SiTrk_robust":
-        TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_e10_medium_SiTrk_robust' ]
-      elif Seed == "trk9i_calib":
-        TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_trk9i_calib' ]
-  else:
-      TriggerFlags.BeamSpotSlice.signatures = [ 'beamspot_vertex_FSTracks' ]
-
-from TriggerMenuPython.GenerateMenu import GenerateMenu
-GenerateMenu.overwriteSignaturesWith(MyBeamSpotMenu)
-
-#-----------------
-# Trigger Options
-#-----------------
-TriggerFlags.doCalo = True
-TriggerFlags.doMuon = True
-TriggerFlags.doID   = True
-TriggerFlags.doLVL2 = True
-TriggerFlags.doLVL1 = True
-TriggerFlags.doEF   = False
-TriggerFlags.readHLTconfigFromXML  = False
-TriggerFlags.readLVL1configFromXML = False
-TriggerFlags.Slices_all_setOn()
-TriggerFlags.doNtuple         = True
-TriggerFlags.enableMonitoring = [ 'Validation', 'Time', ]
-TriggerFlags.triggerMenuSetup = 'default'
-#TriggerFlags.triggerMenuSetup='Test_lumi1E31'
-TriggerFlags.abortOnConfigurationError = True
-TriggerFlags.doHypo = True
-TriggerFlags.doFEX  = True
-
-#-----------------
-# BeamSpot Config
-#-----------------
-from TrigT2BeamSpot.TrigT2BeamSpotConf import PESA__T2VertexBeamSpot
-PESA__T2VertexBeamSpot.TrackAlgoID             = 2
-PESA__T2VertexBeamSpot.HistoTrackAlgs          = True
-PESA__T2VertexBeamSpot.SaveAllVertices         = False
-
-PESA__T2VertexBeamSpot.TotalNTrackMin          = 3
-PESA__T2VertexBeamSpot.TrackMinPt              = 0.7
-PESA__T2VertexBeamSpot.TrackSeedPt             = 1.0
-PESA__T2VertexBeamSpot.TrackMaxZ0              = 200.0
-PESA__T2VertexBeamSpot.TrackMaxD0              = 10.0
-PESA__T2VertexBeamSpot.TrackMaxZ0err           = 1.0
-PESA__T2VertexBeamSpot.TrackMaxD0err           = 1.0
-PESA__T2VertexBeamSpot.TrackMinQual            = 0.0
-PESA__T2VertexBeamSpot.TrackMaxQual            = 10.0
-PESA__T2VertexBeamSpot.TrackMinSiHits          = 4
-PESA__T2VertexBeamSpot.TrackMinTRTHits         = 1
-
-PESA__T2VertexBeamSpot.VertexMinNTrk           = 3
-PESA__T2VertexBeamSpot.VertexMaxNTrk           = 30
-PESA__T2VertexBeamSpot.VertexMaxXerr           = 0.2
-PESA__T2VertexBeamSpot.VertexMaxYerr           = 0.2
-PESA__T2VertexBeamSpot.VertexMaxQual           = 1000.0
-
-
-#-----------------------------------------------------------
-include("RecExCommon/RecExCommon_topOptions.py")
-#-----------------------------------------------------------
-
-from GaudiSvc.GaudiSvcConf import THistSvc
-ServiceMgr += THistSvc()
-ServiceMgr.THistSvc.Output = ["SHIFT DATAFILE='shift-monitoring.root' OPT='RECREATE'", 
-                              "EXPERT DATAFILE='expert-monitoring." + SiTrackOpt + "." + Data + "." + Seed + "." + NEvents + "evt." + TrackType + ".root' OPT='RECREATE'", 
-                              "RUNSTAT DATAFILE='runstat-monitoring.root' OPT='RECREATE'", 
-                              "DEBUG DATAFILE='debug-monitoring.root' OPT='RECREATE'"]
-
-jobproperties.PerfMonFlags.doMonitoring = False
-
-Service ("StoreGateSvc" ).ActivateHistory = True
-
-print AlgSequence
-print ServiceMgr
-
-if not ('OutputLevel' in dir()):
-    OutputLevel = INFO 
-    
-AlgSequence().TrigSteer_L2.OutputLevel = OutputLevel
-for algo in AlgSequence().TrigSteer_L2.getChildren():
-   algo.OutputLevel = OutputLevel 
-
-MessageSvc.debugLimit  = 1000000
-MessageSvc.OutputLevel = OutputLevel
-MessageSvc.Format      = "% F%48W%S%7W%R%T %0W%M"
-
-ServiceMgr.StoreGateSvc.Dump = False 
diff --git a/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/myTrigger_jobOptions.py b/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/myTrigger_jobOptions.py
deleted file mode 100644
index a6a34f1b81121ff39fb749a54c9f889ae44189ac..0000000000000000000000000000000000000000
--- a/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/myTrigger_jobOptions.py
+++ /dev/null
@@ -1,234 +0,0 @@
-#----------------------------------------
-# Return a file list given a directory
-#----------------------------------------
-
-import os,commands
-
-def getDirectoryList(path):
-    cmd  = 'ls %s/' % (path)
-    file = ["%s/%s" % (path,i) for i in commands.getoutput(cmd).split('\n')]
-    return file
-
-def getMixedDirectoryList(path):
-    cmd  = 'ls %s/*.root*' % (path)
-    file = ["%s" % (i) for i in commands.getoutput(cmd).split('\n')]
-    return file    
-    
-def getCastorDirectoryList(path):
-    cmd  = 'nsls %s/ ' % (path)
-    file = ["rfio:%s/%s" % (path,i) for i in commands.getoutput(cmd).split('\n')]
-    return files
-
-#-----------------
-# Input/Output
-#-----------------
-
-if ('Data' in dir()):
-    if Data == "shift":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/ttbar_shift')
-    elif Data == "gashalo":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/gashalo')
-    elif Data == "mixed":
-        PoolRDOInput  = getMixedDirectoryList('/u1/iaracena/data/MixedEventsEnhancedb/RDO')
-    elif Data == "J2":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/J2')
-    elif Data == "J3":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/J3_2')
-    elif Data == "J1":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/J1')
-    elif Data == "J4":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/J4') 
-    elif Data == "J0":
-        PoolRDOInput  = getDirectoryList('/u1/fizisist/J0')
-else:
-    Data = "shift"
-    PoolRDOInput  = getDirectoryList('/u1/fizisist/ttbar_shift')
-
-#PoolRDOInput=["/afs/cern.ch/atlas/offline/data/testfile/calib1_csc11.005200.T1_McAtNlo_Jimmy.digit.RDO.v12000301_tid003138._00016_extract_10evt.pool.root"]
-#PoolRDOInput  = ["rfio:/castor/cern.ch/user/f/fizisist/beamspot/misal1_csc11.005013.J4_pythia_jetjet.digit.RDO.v12003103_tid004016._02277.pool.root.1"]
-
-#PoolRDOInput  = getCastorDirectoryList('/castor/cern.ch/user/f/fizisist/beamspot/ttbarShift')
-#PoolRDOInput  = getCastorDirectoryList('/castor/cern.ch/grid/atlas/caf/mc12/mc12.005012.J3_pythia_jetjet.digit.RDO.v12000003')
-#PoolRDOInput  = getCastorDirectoryList('/castor/cern.ch/grid/atlas/dq2/misal1_csc11/misal1_csc11.005013.J4_pythia_jetjet.digit.RDO.v12003103_tid004016')
-#readRDOBS=["/u1/iaracena/data/14.0.X/Mixed_lumi1E31/daq.csc13.0000000.Single.Stream.LB0000.Athena._0001.data"]
-#PoolRDOInput  = getDirectoryList('/u1/fizisist/ttbar_shift')
-#PoolRDOInput  = getMixedDirectoryList('/u1/iaracena/data/MixedEventsEnhancedb')
-#PoolRDOInput  = getDirectoryList('/u1/fizisist/J2')
-#PoolRDOInput  = getDirectoryList('/u1/fizisist/J3') 
-           
-PoolESDOutput = 'rfio:/castor/cern.ch/user/f/fizisist/beamspot/myTriggerTest2.mixed.ESD.pool.root'
-PoolAODOutput = 'rfio:/castor/cern.ch/user/f/fizisist/beamspot/myTriggerTest2.mixed.AOD.pool.root'
-
-if not ('EvtMax' in dir()):                                   
-    EvtMax=1000
-
-NEvents = "%d" % EvtMax
-
-#-----------------
-# Global Flags
-#-----------------
-from AthenaCommon.GlobalFlags import GlobalFlags
-GlobalFlags.Print()
-#GlobalFlags.DetDescrVersion ="ATLAS-CSC-01-02-00"
-#DetDescrVersion = "ATLAS-CSC-01-02-00"
-
-#-----------------
-# Global Setup
-#-----------------
-doTAG          = False
-doEgamma       = False
-doMuon         = False
-doJet          = False
-doTauRec       = False
-doObjMissingET = False
-doMuGirl       = False
-doMoore        = False
-doMuonIDStandAlone = False
-doMuonIDCombined   = False 
-
-doCBNT     = False
-doWriteAOD = False
-doWriteESD = False
-doWriteTAG = False
-doAOD      = False 
-doESD      = False 
-doTAG      = False
-doTruth    = False
-doAtlfast  = False
-
-#-----------------
-# Trigger Setup
-#-----------------
-doTrigger           = True
-
-#-----------------------------------------------------------
-include("RecExCommon/RecExCommon_flags.py")
-#-----------------------------------------------------------
-
-#-----------------
-# InDet Flags
-#-----------------
-from InDetRecExample.InDetJobProperties import InDetFlags
-from AthenaCommon.JobProperties import jobproperties
-from InDetTrigRecExample.InDetTrigFlags import InDetTrigFlags
-if Data == "gashalo":
-  InDetFlags.Enabled                 = True
-  InDetFlags.doBeamGas               = True
-  InDetFlags.doBeamHalo              = True
-  InDetFlags.doSiSPSeededTrackFinder = True
-  InDetFlags.doPrintConfigurables    = True
-  InDetTrigFlags.doBeamGas  = True
-  InDetTrigFlags.doBeamHalo = True
-
-#-----------------
-# Trigger Flags
-#-----------------
-
-TriggerFlags.doCalo = True
-TriggerFlags.doMuon = True
-TriggerFlags.doID   = True
-TriggerFlags.doLVL2 = True
-TriggerFlags.doLVL1 = True
-TriggerFlags.doEF   = False
-TriggerFlags.readHLTconfigFromXML  = False
-TriggerFlags.readLVL1configFromXML = False
-TriggerFlags.Slices_all_setOn()
-TriggerFlags.doNtuple         = True
-TriggerFlags.enableMonitoring = [ 'Validation', 'Time', ]
-TriggerFlags.triggerMenuSetup = 'default'
-TriggerFlags.abortOnConfigurationError = True
-TriggerFlags.doHypo = True
-TriggerFlags.doFEX  = True
-
-#-----------------
-# SiTrack Setup
-#-----------------
-
-#from TrigSiTrack.TrigSiTrack_Config import *
-#if ('SiTrackOpt' in dir()):
-#    if SiTrackOpt == "loose.v2":
-#        TrigSiTrackFlags.LoosenCuts = True
-#    else:
-#        TrigSiTrackFlags.LoosenCuts = False 
-#else:
-SiTrackOpt = "defaults"
-#    TrigSiTrackFlags.LoosenCuts = False
-    
-#-----------------
-# Beamspot Setup
-#-----------------
-
-from TriggerMenuPython.BeamSpotSliceFlags import *
-BeamSpotSliceFlags.unsetAll()
-TriggerFlags.BeamSpotSlice.signatures = [ 'vertex_bjet18' ]
-
-from TrigT2BeamSpot.TrigT2BeamSpotConf import PESA__T2VertexBeamSpot
-
-# Track Algorithm: SiTrack = 1, IdScan = 2
-if ('TrackType' in dir()):
-    if TrackType == "SiTrack":
-        PESA__T2VertexBeamSpot.TrackAlgoID = 1
-    else:
-        PESA__T2VertexBeamSpot.TrackAlgoID = 2 
-else:
-    TrackType = "IdScan"
-    PESA__T2VertexBeamSpot.TrackAlgoID = 2
-
-PESA__T2VertexBeamSpot.UseBeamConditionService = True
-
-PESA__T2VertexBeamSpot.DoPerLBHistograms       = True 
-PESA__T2VertexBeamSpot.LBHistoryLength         = 10
-PESA__T2VertexBeamSpot.MonitoringHistoPath     = "/EXPERT/T2VertexBeamSpot_Fex/"
-PESA__T2VertexBeamSpot.ExpressHistoPath        = "/EXPERT/T2VertexBeamSpot_Fex/"
-
-PESA__T2VertexBeamSpot.HistoTrackAlgs          = False
-PESA__T2VertexBeamSpot.SaveAllVertices         = False
-    
-PESA__T2VertexBeamSpot.TotalNTrackMin          = 6
-PESA__T2VertexBeamSpot.TrackMinPt              = 1.0
-PESA__T2VertexBeamSpot.TrackSeedPt             = 4.0
-PESA__T2VertexBeamSpot.TrackMaxZ0              = 200.0
-PESA__T2VertexBeamSpot.TrackMaxD0              = 10.0
-PESA__T2VertexBeamSpot.TrackMaxZ0err           = 1.0
-PESA__T2VertexBeamSpot.TrackMaxD0err           = 1.0
-PESA__T2VertexBeamSpot.TrackMinQual            = 0.0
-PESA__T2VertexBeamSpot.TrackMaxQual            = 10.0
-PESA__T2VertexBeamSpot.TrackMinSiHits          = 5
-PESA__T2VertexBeamSpot.TrackMinTRTHits         = -1
-
-PESA__T2VertexBeamSpot.VertexMinNTrk           = 6
-PESA__T2VertexBeamSpot.VertexMaxNTrk           = 30
-PESA__T2VertexBeamSpot.VertexMaxXerr           = 0.1
-PESA__T2VertexBeamSpot.VertexMaxYerr           = 0.1
-PESA__T2VertexBeamSpot.VertexMaxQual           = 30.0
-
-#-----------------------------------------------------------
-include("RecExCommon/RecExCommon_topOptions.py")
-#-----------------------------------------------------------
-
-from GaudiSvc.GaudiSvcConf import THistSvc
-ServiceMgr += THistSvc()
-ServiceMgr.THistSvc.Output = ["SHIFT DATAFILE='shift-monitoring.root' OPT='RECREATE'", 
-                              "EXPERT DATAFILE='/u1/fizisist/beamspot/rootHistos/expert-monitoring.b18." + SiTrackOpt + "." + Data + "." + NEvents + "evt." + TrackType + ".root' OPT='RECREATE'", 
-                              "RUNSTAT DATAFILE='runstat-monitoring.root' OPT='RECREATE'", 
-                              "DEBUG DATAFILE='debug-monitoring.root' OPT='RECREATE'"]
-
-jobproperties.PerfMonFlags.doMonitoring = False
-
-Service ("StoreGateSvc" ).ActivateHistory = True
-
-print AlgSequence
-print ServiceMgr
-
-if not ('OutputLevel' in dir()):
-    OutputLevel = INFO 
-    
-AlgSequence().TrigSteer_L2.OutputLevel = OutputLevel
-for algo in AlgSequence().TrigSteer_L2.getChildren():
-   algo.OutputLevel = INFO 
-
-MessageSvc.debugLimit  = 1000000
-MessageSvc.OutputLevel = OutputLevel
-MessageSvc.Format      = "% F%48W%S%7W%R%T %0W%M"
-
-ServiceMgr.StoreGateSvc.Dump = True
diff --git a/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/runBeamSpotTests.sh b/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/runBeamSpotTests.sh
deleted file mode 100755
index 55daf83dd61573c4c0f8df5011ccf3f5a3a38485..0000000000000000000000000000000000000000
--- a/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/runBeamSpotTests.sh
+++ /dev/null
@@ -1,38 +0,0 @@
-#!/bin/bash
-
-
-echo 
-echo "We will now be running several jobs for testing the beam spot code"
-echo
-
-homeDir=/afs/cern.ch/user/f/fizisist
-baseDir=/u1/fizisist/beamspot
-logDir=${baseDir}
-jobOptions=${baseDir}/myTrigger_jobOptions.py
-dataList="gashalo J1 J3 mixed shift"    # Data
-trackList="SiTrack IdScan"              # TrackType
-optsList="defaults.v8"                  # SiTrackOpt
-
-#source ${homeDir}/work/14.0.0/cmt/setup.sh -tag=14.0.0,32
-
-cd ${baseDir}  
-
-for datatype in ${dataList}; do
-  for trktype in ${trackList}; do
-    for cutstype in ${optsList}; do
-      outDir=${baseDir}/${datatype}/${trktype}/${cutstype}
-      if [ ! -d ${outDir} ]; then
-        mkdir ${outDir}
-      fi
-      cd ${outDir}
-      echo "*** ${trktype} (SiTrack=${cutstype}) on ${datatype} events"
-    #echo "athena.py -c EvtMax=$1;Data='${datatype}';TrackType='${trktype}';SiTrackOpt='${cutstype}'; ${jobOptions} >& ${logDir}/beamspot.${datatype}.$1evt.${trktype}.${cutstype}.log & "
-      athena.py -c "EvtMax=$1;Data='${datatype}';TrackType='${trktype}';SiTrackOpt='${cutstype}';" ${jobOptions} >& ${logDir}/beamspot.b18.${datatype}.$1evt.${trktype}.${cutstype}.log & 
-    done
-  done
-done  
-    
-echo
-
-cd ${baseDir}
-
diff --git a/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/runJob_beamspot.sh b/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/runJob_beamspot.sh
deleted file mode 100644
index 8f8ceea009727ce6e9017ff2a505fba7dddb1ada..0000000000000000000000000000000000000000
--- a/Trigger/TrigAlgorithms/TrigT2BeamSpot/share/runJob_beamspot.sh
+++ /dev/null
@@ -1,36 +0,0 @@
-#!/bin/bash
-
-echo
-echo "Running single job"
-echo
-
-##--------------
-## Seed choices
-##--------------
-# beamspot_vertex_list
-# beamspot_vertex_jet10 
-# beamspot_vertex_bjet18
-# beamspot_vertex_FSTracks
-# beamspot_vertex_tau16i_loose
-# beamspot_vertex_e10_medium
-# beamspot_vertex_e10_medium_SiTrk 
-# beamspot_vertex_e10_medium_SiTrk_robust
-# beamspot_vertex_trk9i_calib
-
-
-mydate=`date '+%Y-%m-%d-%HH-%MM-%SS'`
-evtMax=1000
-datatype=EnhancedBias
-L2Seed=beamspot_vertex_FSTracks
-trktype=IdScan
-cutstype=${mydate}
-jobOptions=myNewTrigger_jobOptions.py
-logDir=/u1/fizisist/beamspot
-Output=DEBUG
-
-athena.py -c "EvtMax=${evtMax};OutputLevel=${Output};Data='${datatype}';Seed='${L2Seed}';TrackType='${trktype}';SiTrackOpt='${cutstype}';" ${jobOptions} >& ${logDir}/beamspot.${datatype}.${evtMax}evt.${trktype}.${L2Seed}.${cutstype}.${mydate}.log & 
-
-#mydate=`date '+%Y-%m-%d-%HH-%MM-%SS'`
-#athenaMT.py -M -W -c isOnline=True -l INFO -f Raw.data -n 10000 testHLT_standalone.py >& /u1/fizisist/beamspot/testMT.raw.withOH.${mydate}.log &
-
-
diff --git a/Trigger/TrigAlgorithms/TrigT2CaloCommon/python/TrigT2CaloCommonConfig.py b/Trigger/TrigAlgorithms/TrigT2CaloCommon/python/TrigT2CaloCommonConfig.py
index d7362e1066dc07e74a6a70e271017a61a40d1994..da261e7bd2ffbc73e675b56cc4fbe3a13b4f718e 100644
--- a/Trigger/TrigAlgorithms/TrigT2CaloCommon/python/TrigT2CaloCommonConfig.py
+++ b/Trigger/TrigAlgorithms/TrigT2CaloCommon/python/TrigT2CaloCommonConfig.py
@@ -15,8 +15,8 @@ class TrigDataAccess(_TrigDataAccess):
         from AthenaCommon.Logging import logging
         log = logging.getLogger(name)
      
-        self.loadFullCollections = ( TriggerFlags.doEF() or TriggerFlags.doHLT() )
-        self.loadAllSamplings    = ( TriggerFlags.doLVL2() or TriggerFlags.doHLT() )
+        self.loadFullCollections = TriggerFlags.doHLT()
+        self.loadAllSamplings    = TriggerFlags.doHLT()
         log.info('Not possible anymore to enable HLT calo offset correction, tools deprecated')
 
         from RecExConfig.RecFlags import rec
diff --git a/Trigger/TrigAlgorithms/TrigTauRec/python/TrigTauAlgorithmsHolder.py b/Trigger/TrigAlgorithms/TrigTauRec/python/TrigTauAlgorithmsHolder.py
index d7a5d98d0d469a69d15d5080de65049a7108bb41..8fd01362166d534ea16bf1ea0c189553637df7c4 100644
--- a/Trigger/TrigAlgorithms/TrigTauRec/python/TrigTauAlgorithmsHolder.py
+++ b/Trigger/TrigAlgorithms/TrigTauRec/python/TrigTauAlgorithmsHolder.py
@@ -100,9 +100,7 @@ def getTauAxis():
     from tauRecTools.tauRecToolsConf import TauAxisSetter
     TauAxisSetter = TauAxisSetter(  name = _name, 
                                     ClusterCone = 0.2,
-                                    VertexCorrection = doVertexCorrection,
-                                    JetVertexCorrection = False
-                                  )
+                                    VertexCorrection = doVertexCorrection )
     # No Axis correction at trigger level
                                     
     cached_instances[_name] = TauAxisSetter                
@@ -738,8 +736,7 @@ def getTauVertexedClusterDecorator():
   
     myTauVertexedClusterDecorator = TauVertexedClusterDecorator(name = _name,
                                                                 SeedJet = "",
-                                                                VertexCorrection = doVertexCorrection,
-                                                                JetVertexCorrection = False)
+                                                                VertexCorrection = doVertexCorrection)
     
     cached_instances[_name] = myTauVertexedClusterDecorator
     return myTauVertexedClusterDecorator
diff --git a/Trigger/TrigConfiguration/TrigConfData/TrigConfData/L1Connector.h b/Trigger/TrigConfiguration/TrigConfData/TrigConfData/L1Connector.h
index 69cd439b7ec972f06603675d78524a47c9b696d0..5b85a067afabffc709437479114397047b6691f5 100644
--- a/Trigger/TrigConfiguration/TrigConfData/TrigConfData/L1Connector.h
+++ b/Trigger/TrigConfiguration/TrigConfData/TrigConfData/L1Connector.h
@@ -20,8 +20,8 @@ namespace TrigConf {
     */
    class TriggerLine {
    public:
-      TriggerLine(const std::string & name, unsigned int startbit, unsigned int nbits, unsigned int fpga=0, unsigned int clock=0) :
-         m_name(name), m_startbit(startbit), m_nbits(nbits), m_fpga(fpga), m_clock(clock)
+   TriggerLine(const std::string & name, unsigned int startbit, unsigned int nbits, unsigned int fpga=0, unsigned int clock=0, const std::string & connName="") :
+     m_name(name), m_startbit(startbit), m_nbits(nbits), m_fpga(fpga), m_clock(clock), m_connName(connName)
       {}
       const std::string & name() const { return m_name; }
       unsigned int startbit() const { return  m_startbit; }
@@ -29,12 +29,14 @@ namespace TrigConf {
       unsigned int nbits() const { return m_nbits; }
       unsigned int fpga() const { return m_fpga; }
       unsigned int clock() const { return m_clock; }
+      const std::string & connName() const { return m_connName; }
    private:
       std::string m_name{""};      // the name of the threshold whose multiplicity is transmitted
       unsigned int m_startbit{0};  // the location on the cable - first bit
       unsigned int m_nbits{0};     // the location on the cable - number of bits used to encode the multiplicity
       unsigned int m_fpga{0};      // for electrical signals from L1Topo boards only: the fpga the signal is coming from
       unsigned int m_clock{0};     // for electrical signals from L1Topo boards only: the clock of the signal
+      std::string m_connName{""};  // the name of the connector where the triggerline is allocated
    };
 
    /** @brief L1 connectors configuration */
diff --git a/Trigger/TrigConfiguration/TrigConfData/src/L1Connector.cxx b/Trigger/TrigConfiguration/TrigConfData/src/L1Connector.cxx
index 3d7de39fe718199f18ac10d63949e17473a802ee..7a08959afc26af703a9aecd23d2038cea389d4a1 100644
--- a/Trigger/TrigConfiguration/TrigConfData/src/L1Connector.cxx
+++ b/Trigger/TrigConfiguration/TrigConfData/src/L1Connector.cxx
@@ -52,10 +52,10 @@ TrigConf::L1Connector::update()
       for( size_t clock = 0; clock < m_maxClock; ++clock ) {
          std::string path = "triggerlines";
          if( m_type == ConnectorType::ELECTRICAL ) {
-            if(hasMultipleFPGAs) {
-               path += ".fpga";
-               path += std::to_string(fpga);
-            }
+	    if(hasMultipleFPGAs) {
+ 	       path += ".fpga";
+	       path += std::to_string(fpga);
+	    }
             path += ".clock";
             path += std::to_string(clock);
          }
@@ -66,7 +66,7 @@ TrigConf::L1Connector::update()
             m_triggerLines[fpga][clock].emplace_back( name,
                                                       tl.second.get_child("startbit").get_value<unsigned int>(),
                                                       tl.second.get_child("nbits").get_value<unsigned int>(),
-                                                      fpga, clock);
+                                                      fpga, clock, m_name);
             m_lineByName[name] = & m_triggerLines[fpga][clock].back();
          }
       }
diff --git a/Trigger/TrigConfiguration/TrigConfigSvc/python/TrigConfigSvcConfig.py b/Trigger/TrigConfiguration/TrigConfigSvc/python/TrigConfigSvcConfig.py
index 59b620da65188398096f77ff782781665c077125..6da3ac898f0e3bc3b9c2a55ac2575828d984a6ed 100755
--- a/Trigger/TrigConfiguration/TrigConfigSvc/python/TrigConfigSvcConfig.py
+++ b/Trigger/TrigConfiguration/TrigConfigSvc/python/TrigConfigSvcConfig.py
@@ -354,19 +354,37 @@ class SetupTrigConfigSvc(object):
                 from TriggerJobOpts.TriggerFlags import TriggerFlags
 
 
-                if TriggerFlags.doLVL2() or TriggerFlags.doEF() or TriggerFlags.doHLT() or TriggerFlags.configForStartup()=='HLToffline':
+                if TriggerFlags.doHLT() or TriggerFlags.configForStartup()=='HLToffline':
                     self.mlog.info( "setup HLTConfigSvc and add instance to ServiceMgr (xml file="+self.hltXmlFile+")" )
                     hlt = HLTConfigSvc("HLTConfigSvc")
                     hlt.XMLMenuFile = self.hltXmlFile
                     hlt.doMergedHLT = TriggerFlags.doHLT()
                     ServiceMgr += hlt
                 else:
-                    self.mlog.info( "Will not setup HLTConfigSvc, since TriggerFlags doLVL2(), doEF(), and doHLT() are all False" )
+                    self.mlog.info( "Will not setup HLTConfigSvc, since doHLT() is False" )
                     self.states[self.states.index("xml")] = "xmll1"
 
-                self.mlog.info( "setup LVL1ConfigSvc and add instance to ServiceMgr (xml file="+self.l1XmlFile+")" )
+                # generating a json L1 menu for Physics_pp_v7_primaries
+                # is needed for a transition period where we still have jobs
+                # running on this old menu, but the software expects a
+                # json-style L1 menu
+                menuName = TriggerFlags.triggerMenuSetup()
+                doGenerateJsonMenuForRun2Menu = (menuName == "Physics_pp_v7_primaries")
+                if doGenerateJsonMenuForRun2Menu:
+                    self.mlog.info("Generating L1 menu %s", menuName)
+                    from TriggerMenuMT.L1.L1MenuConfig import L1MenuConfig
+                    l1cfg = L1MenuConfig(menuName = menuName) # create menu
+                    fileName = 'L1Menu_' + menuName + '.json'
+                    l1JsonFileName = l1cfg.writeJSON(outputFile = fileName) # write menu
+                self.mlog.info("setup LVL1 ConfigSvc and add instance to ServiceMgr")
+                self.mlog.info("xml file = %s", self.l1XmlFile)
+                if doGenerateJsonMenuForRun2Menu:
+                    self.mlog.info("json file= %s", l1JsonFileName)
                 l1 = LVL1ConfigSvc("LVL1ConfigSvc")
                 l1.XMLMenuFile = self.l1XmlFile
+                if doGenerateJsonMenuForRun2Menu:
+                    l1.JsonFileName = l1JsonFileName
+
                 ServiceMgr += l1
 
                 self.mlog.info( "setup L1TopoConfigSvc and add instance to ServiceMgr (xml file="+self.l1topoXmlFile+")" )
diff --git a/Trigger/TrigHypothesis/TrigBphysHypo/src/TrigMultiTrkComboHypo.h b/Trigger/TrigHypothesis/TrigBphysHypo/src/TrigMultiTrkComboHypo.h
index 80315771043cb201a18e25fd4323fee52ec4fc16..8d497279ee3e1f16522a06d3509978c574f83d68 100644
--- a/Trigger/TrigHypothesis/TrigBphysHypo/src/TrigMultiTrkComboHypo.h
+++ b/Trigger/TrigHypothesis/TrigBphysHypo/src/TrigMultiTrkComboHypo.h
@@ -48,8 +48,6 @@ class TrigMultiTrkComboHypo: public ::ComboHypo {
   virtual StatusCode finalize() override;
 
  protected:
-  // the vertexing tool is not reentrant so this algorithm cannot be used reentrantly
-  bool isReEntrant() const override { return false; }
 
  private:
   StatusCode executeL2(const EventContext& context) const;
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/AllJetsGrouper.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/AllJetsGrouper.h
index f2d3190d77eb6e892d1f91ce9262b4ba3c696524..9bc4ae4008f925838d45a82f05162d0f03d551de 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/AllJetsGrouper.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/AllJetsGrouper.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRIGHLTJETHYPO_ALLJETSGROUPER_H
@@ -9,12 +9,21 @@
 
 class AllJetsGrouper: public IJetGrouper{
  public:
+  AllJetsGrouper();
+  AllJetsGrouper(const HypoJetIter& b, const HypoJetIter& e);
+  AllJetsGrouper(const HypoJetVector&);
+  
   std::vector<HypoJetGroupVector> group(HypoJetIter&,
 					HypoJetIter&) const override;
   
-  std::optional<HypoJetGroupVector> next(HypoJetIter&,
-					 HypoJetIter&) const override;
+  std::optional<HypoJetGroupVector> next();
+  
   std::string getName() const override; 
   std::string toString() const override;
+
+private:
+  HypoJetVector m_jets{};
+  bool m_done{false};
+
 };
 #endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/CombinationsGrouper.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/CombinationsGrouper.h
index 72b1b60b62cf920812a9ea56241e84afc68bafb5..57f5f57d3a091299d112f793eaee4943df6a2a16 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/CombinationsGrouper.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/CombinationsGrouper.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRIGHLTJETHYPO_COMBINATIONSGROUPER_H
@@ -9,14 +9,26 @@
 
 class CombinationsGrouper: public IJetGrouper{
  public:
+  CombinationsGrouper();
+
   CombinationsGrouper(unsigned int);
+
+  CombinationsGrouper(unsigned int, const HypoJetVector&);
+
+  CombinationsGrouper(unsigned int,
+		      const HypoJetCIter& b,
+		      const HypoJetCIter& e
+		      );
+  
   std::vector<HypoJetGroupVector> group(HypoJetIter&,
 					HypoJetIter&) const override;
-  std::optional<HypoJetGroupVector> next(HypoJetIter&,
-					 HypoJetIter&) const override;
+  std::optional<HypoJetGroupVector> next() override;
+
   std::string getName() const override; 
   std::string toString() const override;
  private:
   unsigned int m_groupSize;
+  HypoJetVector m_jets;
+
 };
 #endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/IJetGrouper.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/IJetGrouper.h
index ba22e5f47ac904357c71fa2fa9fbe0ca2b058ff0..5830516dece0a3cebb3cfb0e2a479cd43f06e47e 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/IJetGrouper.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/IJetGrouper.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRIGHLTJETHYPO_IJETGROUPER_H
@@ -25,8 +25,7 @@ class IJetGrouper{
    */
   virtual std::vector<HypoJetGroupVector> group(HypoJetIter&,
 						HypoJetIter&) const = 0;
-  virtual std::optional<HypoJetGroupVector> next(HypoJetIter&,
-						 HypoJetIter&) const = 0;
+  virtual std::optional<HypoJetGroupVector> next() = 0;
   virtual std::string toString() const = 0; 
   virtual std::string getName() const = 0; 
 };
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/IndexedJetsGrouper.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/IndexedJetsGrouper.h
index 64bcbd240c5590793bdb816bef9bddd6f0f06022..e26d29639fe834fea8aefe375a13160799005102 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/IndexedJetsGrouper.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/IndexedJetsGrouper.h
@@ -22,18 +22,27 @@
 class IndexedJetsGrouper: public IJetGrouper{
   /* Select jets ordered all jets in descnding Et at goven index positions.*/
 public:
+  IndexedJetsGrouper(const std::vector<unsigned int>& indices,
+		     const HypoJetVector& jets);
+
+  IndexedJetsGrouper(const std::vector<unsigned int>& indices,
+		     const HypoJetCIter& b,
+		     const HypoJetCIter& e);
+
   IndexedJetsGrouper(const std::vector<unsigned int>& indices);
+
   virtual ~IndexedJetsGrouper(){}
 
   std::vector<HypoJetGroupVector>
-    group(HypoJetIter&, HypoJetIter&) const override;
-
-    std::optional<HypoJetGroupVector> next(HypoJetIter&,
-					 HypoJetIter&) const override;
-    
+  group(HypoJetIter&, HypoJetIter&) const override;
+  
+  std::optional<HypoJetGroupVector> next() override;
+      
   std::string getName() const override;
   std::string toString() const override;
 private:
-  std::vector<unsigned int> m_indices;
+  std::vector<unsigned int> m_indices{};
+  HypoJetVector m_jets{};
+  bool m_done{false};
 };
 #endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/PartitionsGrouper.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/PartitionsGrouper.h
deleted file mode 100644
index ff5a2c0241b40670de51db183039bab7386bd3ad..0000000000000000000000000000000000000000
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/PartitionsGrouper.h
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
-*/
-
-#ifndef TRIGHLTJETHYPO_PARTITIONSGROUPER_H
-#define TRIGHLTJETHYPO_PARTITIONSGROUPER_H
-
-/*
- * Find all non-overlapping allocation of jet groups to conditions.
- * The number pf jets needed by a contition is input.
- *
- * std::vector<HypoJetGroupVector is a vector of ..
- *  ... a vector of a vector of jet indicies.
- * The permutations engine finds all the index  allocactions of jets to
- * condtions. Schematically, if the engine is told that c0 needs 2 jets
- * and c3 needs 3 jets,
- *
- * (i0, i1) (i3, i4, i5) assigns indices i0, i1 to c0 and  i3, i4, i5
- * to c1.
- * There will be many such assignments. The next one may be
- * (i0, i2) (i1, i3, i4)
- */
-
-
-#include "TrigHLTJetHypo/TrigHLTJetHypoUtils/IJetGrouper.h"
-#include <vector>
-#include <fstream>
-
-class PartitionsGrouper: public IJetGrouper{
- public:
-  PartitionsGrouper(const std::vector<std::size_t>& mults);
-  std::vector<HypoJetGroupVector> group(HypoJetIter&,
-					HypoJetIter&) const override;
-  
-  std::optional<HypoJetGroupVector> next(HypoJetIter&,
-					 HypoJetIter&) const override;
-  std::string getName() const override; 
-  std::string toString() const override;
- private:
-
-  // m_mults entry at position i gives the number of jets required by the
-  // ith condition.
-  std::vector<std::size_t> m_mults;
-};
-#endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/SingleJetGrouper.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/SingleJetGrouper.h
index bdcb22d7b4fa14263ed96a310a72c7139e5ae48c..5d0b474276c72be54531855b3e134cd85978b2a1 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/SingleJetGrouper.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/TrigHLTJetHypo/TrigHLTJetHypoUtils/SingleJetGrouper.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRIGHLTJETHYPO_SINGLEJETGROUPER_H
@@ -9,12 +9,20 @@
 
 class SingleJetGrouper: public IJetGrouper{
  public:
+  SingleJetGrouper();
+  SingleJetGrouper(const HypoJetVector&);
+  SingleJetGrouper(const HypoJetCIter& b, const HypoJetCIter& e);
+
   std::vector<HypoJetGroupVector> group(HypoJetIter&,
 					HypoJetIter&) const override;
 
-  std::optional<HypoJetGroupVector> next(HypoJetIter&,
-					 HypoJetIter&) const override;
+  std::optional<HypoJetGroupVector> next() override;
   std::string getName() const override; 
   std::string toString() const override;
+
+private:
+  HypoJetVector m_jets;
+  std::size_t m_size;
+  std::size_t m_index{0};
 };
 #endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/ConditionsToolSetterFastReduction.py b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/ConditionsToolSetterFastReduction.py
index 2162fa0f2f638fcef1d5f34454c1065c6cb53cce..6e545440dd3f09d68aff988528a65e79c955faa6 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/ConditionsToolSetterFastReduction.py
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/ConditionsToolSetterFastReduction.py
@@ -10,8 +10,6 @@ from AthenaConfiguration.ComponentFactory import CompFactory
 
 from collections import defaultdict
 
-import copy
-
 from AthenaCommon.Logging import logging
 log = logging.getLogger( 'ConditionsToolSetterFastReduction' )
 
@@ -33,9 +31,8 @@ class ConditionsToolSetterFastReduction(object):
         'hecfrac' : 'HECFrac',
     }
 
-    def __init__(self, name):
+    def __init__(self):
 
-        self.name = name
         # for simple, use TrigJetConditionConfig_etaet. Needs to be
         # completed because simple can conain any single jet condition
         self.tool_factories = {
@@ -73,51 +70,7 @@ class ConditionsToolSetterFastReduction(object):
             self._set_conditions(cn)
 
 
-    def _remove_combgen(self, node):                       
-        """Combination nodes represent parent children relationships.
-        The child may be a subtree. For now, the parent will be in the 
-        child list at position 0, and the child subtree in position 1."""
-
-        parent_children = {}
-        ipos  = 0
-
-        # identify the combgen nodes, and rotate them
-        for cn in node.children:
-            if cn.scenario == 'combgen':
-                assert (len(cn.children) == 2)
-                parent_children[ipos] = cn.children
-            ipos += 1
-
-        # rotate the first combgen child (parent) into the position of the
-        # combgen node, and set its child node.
-        for pos, p_c in parent_children.items():
-            node.children[pos] = p_c[0]
-            node.children[pos].children = [p_c[1]]
-
-        for cn in node.children:
-            self._remove_combgen(cn)
-
-    def _remove_scenario(self, node, scenario):                       
-        """Remove Partgen nodes by adding their children to their 
-        parent's children."""
-
-        def remove_scenario(node, scenario):
-            for cn in node.children:
-                if cn.scenario == scenario:
-                    node.children.remove(cn)
-                    node.children.extend(cn.children)
-                    return True
-
-            return False
-
-        more = True
-        while(more):
-            more = remove_scenario(node, scenario)
-
-        for cn in node.children:
-            self._remove_scenario(cn, scenario)
-
-  
+ 
     def _get_tool_instance(self, key, extra=''):
    
         klass = self.tool_factories[key][0]
@@ -138,7 +91,15 @@ class ConditionsToolSetterFastReduction(object):
 
         # loop  over elements of node.conf_attrs. The elements are (dict, int)
         # int is multiplicity, dict holds Condition parameters.
-        for c, mult in node.conf_attrs:
+
+        for i in range(len(node.conf_attrs)):
+            c, mult = node.conf_attrs[i]
+            cpi = ''
+            if node.chainpartinds:
+                cpi = node.chainpartinds[i][0]
+                assert mult == node.chainpartinds[i][1]
+                    
+                
             condition_tools = [] # elemental conditions for this compounnd ct.
             for k, v in c.items(): # loop over elemental conditions
                 condition_tool = self._get_tool_instance(k)
@@ -159,12 +120,17 @@ class ConditionsToolSetterFastReduction(object):
 
             # create capacitychecked condition from elemental condition
             condition_tool =self._get_tool_instance('capacitychecked')
+
+            if cpi:
+                condition_tool.chainLegLabel = cpi
+            else:
+                condition_tool.chainLegLabel = ''
+            
             condition_tool.conditionMakers = condition_tools
             condition_tool.multiplicity = mult
-
             # add capacitychecked condition to list
             outer_condition_tools.append(condition_tool)
-
+            
         return outer_condition_tools
 
     def _mod_leaf(self, node):
@@ -186,59 +152,6 @@ class ConditionsToolSetterFastReduction(object):
         node.compound_condition_tools = self._make_compound_condition_tools(
             node)
 
-    def _split_leaves(self, node):
-        """Recursively replace leaf nodes with >1 Condition tools by nodes with
-        one Condition tool."""
-
-        def split_leaves(node):   
-            for cn in node.children:
-                if is_leaf(cn):
-                    if len(cn.compound_condition_tools) > 1:
-                        new_children =  []
-                        new_node = copy.deepcopy(cn)
-                        # set scenarrio to other than leaf results in 
-                        # the assignement of  an acceptall condition
-                        new_node.scenario = 'inserted'
-                        new_node.compound_condition_tools = []
-                        for ct in cn.compound_condition_tools:
-                            new_children.append(copy.deepcopy(cn))
-                            new_children[-1].compound_condition_tools = [ct]
-                            new_children[-1].conf_attrs = []
-                        new_node.children.extend(new_children)
-                        node.children.remove(cn)
-                        node.children.append(new_node)
-                        return True # return after first modification
-
-            return False
-
-
-        more = True
-        while(more):
-            more = split_leaves(node)
-
-        for cn in node.children:
-            self._split_leaves(cn)
-
-
-    def _find_shared(self, node, shared):
-        """Determine which nodes are "shared" - shared nodes
-        are nodes that see the input jet collection. There
-        more than one set of shared nodes. These are generated
-        if an "And" not is present in the hypo tree"""
-
-        if node.scenario == 'simple':
-            shared.append(node.node_id)
-        else:
-            shared.append(-1)
-            
-        for cn in node.children:
-            self._find_shared(cn, shared)
-
-
-        return shared
-
-
-
     def report(self):
         wid = max(len(k) for k in self.tool_factories.keys())
         rep = '\n%s: ' % self.__class__.__name__
@@ -289,9 +202,8 @@ class ConditionsToolSetterFastReduction(object):
     def mod(self, tree):
         """Entry point for this module. 
         Modifies a  (usually compound) hypo tree node to 
-        reduce it to form from whuch the treevector, conditionsVector and
-        sharedNodes list can be extracted. These will be used to initialise
-        FastReductionMatcher.
+        reduce it to form from whuch the treevector, and conditionsVector
+        These will be used to initialise FastReductionMatcher.
 
         In particular: all leaf nodes will have a single ConmpoundCondition
         All other nodes will be assigned an AcceptAll condition.
@@ -304,41 +216,24 @@ class ConditionsToolSetterFastReduction(object):
         
         # add Condition builders to leaf nodes.
         self._set_conditions(tree)
-        
-#         # Alg step 2: remove combgen nodes
-#         self._remove_combgen(root)
-
-        # Alg step 3: split leaf nodes with multiple Conditions with a
-        # single Condition
-#         self._split_leaves(root)
-        
-        # Alg step 4: remove partgen nodes
-        # single Condition
-
-        # Alg step 5: identify the leaf nodes that are to shared
-        # ie that see the input jet collection. Then remove And nodes
-        shared = []
-        self.shared = self._find_shared(tree, shared)
-        if shared[-1] != -1: self.shared.append(-1)
+  
 
-        print ('shared ', self.shared)
         tree_map = {}
         self._fill_tree_map(tree, tree_map)
 
         for k, v in tree_map.items():
             log.debug("Tree map debug ", str(k), str(v))
             
-        self.treeVec = self._map_2_vec(tree_map)
+        treeVec = self._map_2_vec(tree_map)
 
         conditionsMap = {}
         self._fill_conditions_map(tree, conditionsMap)
-        self.conditionsVec = self._map_2_vec(conditionsMap)
+        conditionsVec = self._map_2_vec(conditionsMap)
                
         # make a config tool and provide it with condition makers
         config_tool = self._get_tool_instance('fastreduction')
-        config_tool.conditionMakers = self.conditionsVec
-        config_tool.treeVector = self.treeVec
-        config_tool.sharedVector = self.shared
+        config_tool.conditionMakers = conditionsVec
+        config_tool.treeVector = treeVec
 
         nodestr = 'n%dp%d' % (tree.node_id, tree.parent_id)
         helper_tool = self._get_tool_instance('helper', extra=nodestr)
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/ConditionsToolSetterHT.py b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/ConditionsToolSetterHT.py
index bc866daca9b8a002ccf706229377d0cc9007bafe..c2727f25f3f6eb1065cd5a5683d2d2e18e069edf 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/ConditionsToolSetterHT.py
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/ConditionsToolSetterHT.py
@@ -16,9 +16,8 @@ class ConditionsToolSetterHT(object):
 
     """Visitor to set instantiated AlgTools to a jet hypo tree"""
     
-    def __init__(self, name):
+    def __init__(self):
 
-        self.name = name
         # for simple, use TrigJetConditionConfig_etaet. Needs to be
         # completed because simple can conain any single jet condition
         self.tool_factories = {
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/NodeSplitterVisitor.py b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/NodeSplitterVisitor.py
index 8a6c8187a022bdce144f3f611a58134a89305e7c..21f3ebb23e71077cbbc4dcbfedee76f3353f4d97 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/NodeSplitterVisitor.py
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/NodeSplitterVisitor.py
@@ -17,7 +17,6 @@ def is_leaf(node):
 
 
 def is_inner(node):
-    # return node.scenario in ('root', 'and', 'combgen', 'partgen' , 'inserted')
     return node.scenario in ('root', 'all', 'inserted')
 
 
@@ -31,9 +30,12 @@ class NodeSplitterVisitor(object):
         new_children = []
         for c in node.children:
             if c.scenario == 'simple':
-                for c_a in c.conf_attrs:
+                assert ((len(c.chainpartinds) ==
+                        len(c.conf_attrs))) or not c.chainpartinds
+                for cpi, c_a in zip(c.chainpartinds, c.conf_attrs):
                     n_c = copy.deepcopy(c)
                     n_c.conf_attrs = [c_a]
+                    n_c.chainpartinds = [cpi]
                     new_children.append(n_c)
             else:
                 new_children.append(c)
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/TrigJetHypoToolConfig.py b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/TrigJetHypoToolConfig.py
index e5be52b755bf1dd20bce953e4d71c5f63d19bad0..b73f20f38c93557ed2cdee6323ca082561dc269b 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/TrigJetHypoToolConfig.py
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/TrigJetHypoToolConfig.py
@@ -20,9 +20,10 @@ from TrigHLTJetHypo.NodeSplitterVisitor import NodeSplitterVisitor
 from AthenaCommon.Logging import logging
 log = logging.getLogger( 'TrigJetHypoToolConfig' )
 
-def  trigJetHypoToolHelperFromDict_(chain_label,
-                                    chain_name,
-                                    toolSetter=None):
+def  trigJetHypoToolHelperFromDict_(
+        chain_label, # simple([(260et,320eta490, leg000)])
+        chain_name, # HLT_j260_320eta490_L1J75_31ETA49
+        toolSetter=None):
 
     parser = ChainLabelParser(chain_label, debug=False)
 
@@ -92,22 +93,22 @@ def  trigJetHypoToolHelperFromDict(chain_dict):
 
     toolSetter = None
     if 'agg' in chain_name:
-        toolSetter=ConditionsToolSetterHT(chain_name)
+        toolSetter=ConditionsToolSetterHT()
     else:
-        toolSetter=ConditionsToolSetterFastReduction(chain_name)
+        toolSetter=ConditionsToolSetterFastReduction()
 
     return trigJetHypoToolHelperFromDict_(chain_label,
                                           chain_name,
                                           toolSetter)
 
 
-def  trigJetHypoToolFromDict(chain_dict):
+def  trigJetHypoToolFromDict_(chain_dict, tool):
     """Produce  a jet trigger hypo tool from a chainDict"""
 
-    log.debug('trigJetHypoToolFromDict chainDict %s', str(chain_dict))
-
-    chain_name = chain_dict['chainName']
-    tool = CompFactory.TrigJetHypoToolMT(name=chain_name)
+    log.debug('trigJetHypoToolFromDict_ tool type ',
+              tool.__class__.__name__,
+              ' chainDict ',
+              str(chain_dict))
 
     # obtain  a Helper Tool (possibly a tree of tools) to
     # make the hypo decision.
@@ -120,25 +121,16 @@ def  trigJetHypoToolFromDict(chain_dict):
 
     return tool
 
-def  trigJetTLAHypoToolFromDict(chain_dict):
-    """Produce  a TLA jet trigger hypo tool from a chainDict"""
-
-    log.info('trigJetTLAHypoToolFromDict chainDict %s', str(chain_dict))
 
-    chain_name = chain_dict['chainName']
-    tool = CompFactory.TrigJetTLAHypoToolMT(name=chain_name)
+def  trigJetTLAHypoToolFromDict(chain_dict):
+    tool = CompFactory.TrigJetTLAHypoToolMT(name=chain_dict['chainName'])
+    return trigJetHypoToolFromDict_(chain_dict, tool)
 
-    # obtain  a Helper Tool (possibly a tree of tools) to
-    # make the hypo decision.
-    # CD: why do we do this? Question to TJ
-    tool.helper_tool = trigJetHypoToolHelperFromDict(chain_dict)
 
-    # controls whether debug visitor is sent to helper tool
-    debug = False  # SET TO False WHEN COMMITTING
-    tool.visit_debug = debug
-    log.debug('%s', tool)
+def  trigJetHypoToolFromDict(chain_dict):
+    tool = CompFactory.TrigJetHypoToolMT(name=chain_dict['chainName'])
+    return trigJetHypoToolFromDict_(chain_dict, tool)
 
-    return tool
 
 import unittest
 class TestStringMethods(unittest.TestCase):
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/chainDict2jetLabel.py b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/chainDict2jetLabel.py
index c1e28d3aaf21eab59af17ce70fe90327ab454a5c..d01c48a6395663499eab149a73489f913a6efa31 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/chainDict2jetLabel.py
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/chainDict2jetLabel.py
@@ -28,10 +28,12 @@ def _select_simple_chainparts(chain_parts):
     return True
 
 
-def _make_simple_label(chain_parts):
+def _make_simple_label(chain_parts, leg_label):
     """Marshal information deom the selected chainParts to create a
     'simple' label. NOTE: THIS IS A SPECIAL CASE - IT DOES NOT DEPEND
     SOLELY ON THE HYPO SCENARIO.
+    Argument leg_label is not used - rather the leg label is fouNd
+    from the chain parts.
     """
     
     if not _select_simple_chainparts(chain_parts):
@@ -39,7 +41,8 @@ def _make_simple_label(chain_parts):
               'chain fails substring selection: not "simple" '
 
         raise NotImplementedError(msg)
-    
+
+    chainpartind = 0
     label = 'simple(['
     for cp in chain_parts:
         smcstr =  str(cp['smc'])
@@ -65,9 +68,12 @@ def _make_simple_label(chain_parts):
                         condition_str += ',%s' % cut
                 else:
                     condition_str += ',%s' % momstr
+            condition_str += ', leg{:0>3}'.format(chainpartind)
             if not condition_str.endswith(')'):
                 condition_str += ')'
             label += condition_str
+        chainpartind += 1
+
     label += '])'
     return label
 
@@ -89,7 +95,7 @@ def _cuts_from_momCuts(momCuts):
     return ''
 
 
-def _make_vbenf_label(chain_parts):
+def _make_vbenf_label(chain_parts, leg_label):
     """Marshal information from the selected chainParts to create a
     vbenf label. Use a Reducer for elimination of unusable jets
     """
@@ -100,6 +106,7 @@ def _make_vbenf_label(chain_parts):
     # scenario requires a dijet of mass > 900, and opening angle in phi > 2.6
 
     assert len(chain_parts) == 1
+    
     scenario = chain_parts[0]['hypoScenario']
     assert scenario.startswith('vbenf')
     args = _args_from_scenario(scenario)
@@ -141,26 +148,27 @@ def _make_vbenf_label(chain_parts):
     assert len(args) == len(arg_res)
     assert len(args) == 0
 
+    argvals['leg_label'] = leg_label
     return """
     all
     (
       []
       simple
       (
-        [(%(etlo).0fet, 500neta)(%(etlo).0fet, peta500)]
+        [(%(etlo).0fet, 500neta, leg000)(%(etlo).0fet, peta500, %(leg_label)s)]
       )
       dijet
       (
         [(%(masslo).0fdjmass, 26djdphi)]
         simple
         (
-          [(10et, 0eta320)(20et, 0eta320)]
+          [(10et, 0eta320, leg000)(20et, 0eta320, %(leg_label)s)]
         )
       )
     )""" % argvals
 
 
-def _make_dijet_label(chain_parts):
+def _make_dijet_label(chain_parts, leg_label):
     """dijet label. supports dijet cuts, and cuts on particpating jets
     Currently supported cuts:
     - dijet mass
@@ -219,16 +227,16 @@ def _make_dijet_label(chain_parts):
     assert len(args) == len(arg_res)
     assert len(args) == 0
 
+    argvals['leg_label'] = leg_label
+    
     return """
-    all([]
-        dijet(
-              [(%(djmasslo).0fdjmass)])
-        simple([(%(j1etlo).0fet, %(j1etalo).0feta%(j1etahi).0f)
-                (%(j2etlo).0fet, %(j2etalo).0feta%(j2etahi).0f)])
-    )""" % argvals
+    dijet(
+    [(%(djmasslo).0fdjmass)]
+    simple([(%(j1etlo).0fet, %(j1etalo).0feta%(j1etahi).0f, %(leg_label)s)
+    (%(j2etlo).0fet, %(j2etalo).0feta%(j2etahi).0f, %(leg_label)s)]))""" % argvals
 
 
-def _make_agg_label(chain_parts):
+def _make_agg_label(chain_parts, leg_label):
     """agg label. cuts on aggregate quantities, and cuts on particpating jets
     Only partway migrated from pure ht to more general agg
     Currently supported cuts:
@@ -285,12 +293,11 @@ def _make_agg_label(chain_parts):
                     hi = float(defaults[key][1])
                 argvals[key+'hi'] =  hi
 
-    print (argvals)
     assert len(argvals) == 2*nargs, 'no of args: %d, expected %d' % (len(argvals), 2*nargs)
 
-    print ('sent 100')
+    argvals['leg_label'] = leg_label
     result =  """
-    ht([(%(htlo).0fht)
+    ht([(%(htlo).0fht, %(leg_label)s)
         (%(etlo).0fet)
         (%(etalo).0feta%(etahi).0f)
     ])"""  % argvals
@@ -322,7 +329,8 @@ def chainDict2jetLabel(chain_dict):
     cp_sorter = {}
     for k in router: cp_sorter[k] = []
 
-    for cp in chain_dict['chainParts']:
+    chain_parts = chain_dict['chainParts']
+    for cp in chain_parts:
         if cp['signature'] != 'Jet' and cp['signature'] != 'Bjet': 
             continue
         for k in cp_sorter:
@@ -332,8 +340,11 @@ def chainDict2jetLabel(chain_dict):
 
     # obtain labels by scenario.
     labels = []
+
+    leg_label = 'leg%03d' % (len(chain_parts) - 1)
     for k, chain_parts in cp_sorter.items():
-        if chain_parts: labels.append(router[k](chain_parts))
+        if chain_parts:
+            labels.append(router[k](chain_parts, leg_label))
 
     assert labels
     nlabels = len(labels)
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/node.py b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/node.py
index 0b21c68951108579703549316f8444ceb08bbb15..7b75c37525d04072399faa426506afecf2c9919d 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/node.py
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/node.py
@@ -33,6 +33,7 @@ class Node(object):
         # self.compound_condition_tools = []
         # self.tree_top kludge carensure top level tools get chain name
         # as Tool name
+        self.chainpartinds = []
         self.tree_top = False
         self.tool = None
         
@@ -85,6 +86,7 @@ class Node(object):
              indent + 'parent node id: %s' % self.parent_id,
              indent + 'is tree top? %s' % self.tree_top,
              indent + 'parameters: %s' % str(self.parameters),
+             indent + 'chainpartinds %s' % str(self.chainpartinds),
              indent + 'conf_attrs [%d]:' % len(self.conf_attrs)]
         for ca in self.conf_attrs:
             s.append(indent + str(ca))
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/treeVisitors.py b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/treeVisitors.py
index a226fec52b7ccdc72db13870755088eb32be2343..3133ab0191dbd3fb0f113c2a1f41fb9d3330eb66 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/python/treeVisitors.py
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/python/treeVisitors.py
@@ -124,7 +124,7 @@ class ConditionsDictMaker(object):
         r'^(?P<lo>\d*)(?P<attr>[%s]+)(?P<hi>\d*)' % lchars)
 
 
-    # key: substring from chain label. value: asttribute of python
+    # key: substring from chain label. value: attribute of python
     # component proxy
     
     def get_conditions(self, params):
@@ -155,6 +155,7 @@ class ConditionsDictMaker(object):
 
 
     def makeDict(self, params):
+
         # conditions example: ['10et,0eta320', '20et']
         conditions = self.get_conditions(params)
 
@@ -164,14 +165,21 @@ class ConditionsDictMaker(object):
         for c in conditions: mult_conditions[c] += 1
         
         result = []
+        chainpartinds = []
         msgs = []
 
 
         # process each parameter string once.
         for c, mult in mult_conditions.items(): # c is condition string
             cdict = defaultdict(dict)
+            
             toks = c.split(',')  # parameters in par string are separated by ','
             toks = [t.strip() for t in toks]
+            cpis = [t for t in toks if t.startswith('leg')]
+            assert len(cpis) < 2
+            if cpis:
+                chainpartinds.append((cpis[0], mult))
+                toks.remove(chainpartinds[-1][0])
 
             for t in toks:
                 m = self.window_re.match(t)
@@ -248,7 +256,7 @@ class ConditionsDictMaker(object):
 
         msgs = ['ConditionsDict OK']
         error = False
-        return result, error, msgs
+        return result, chainpartinds, error, msgs
 
 
 class TreeParameterExpander_simple(object):
@@ -267,10 +275,11 @@ class TreeParameterExpander_simple(object):
     def mod(self, node):
 
         cdm = ConditionsDictMaker()
-        d, error, msgs = cdm.makeDict(node.parameters)
+        d, chainpartinds, error, msgs = cdm.makeDict(node.parameters)
         self.msgs.extend(msgs)
         node.conf_attrs = d
-
+        node.chainpartinds = chainpartinds
+        
     def report(self):
         return '%s: ' % self.__class__.__name__ + '\n'.join(self.msgs) 
 
@@ -295,9 +304,10 @@ class TreeParameterExpander_dijet(object):
     def mod(self, node):
 
         cdm = ConditionsDictMaker()
-        d, error, msgs = cdm.makeDict(node.parameters)
+        d, chainpartinds, error, msgs = cdm.makeDict(node.parameters)
         self.msgs.extend(msgs)
         node.conf_attrs = d
+        node.chainpartinds = chainpartinds
 
     def report(self):
         return '%s: ' % self.__class__.__name__ + '\n'.join(self.msgs)
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/CapacityCheckedCondition.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/CapacityCheckedCondition.cxx
index bcf2cfe05335583b7c13ec757b2992e3f5acc40a..87146ac19127369e0906971c465917dc1756c850 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/CapacityCheckedCondition.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/CapacityCheckedCondition.cxx
@@ -8,8 +8,10 @@
 #include <string>
 
 
-CapacityCheckedCondition::CapacityCheckedCondition(std::unique_ptr<IConditionMT> cp,  std::size_t mult):
-  m_condition{std::move(cp)}, m_multiplicity{mult} {}
+CapacityCheckedCondition::CapacityCheckedCondition(std::unique_ptr<IConditionMT> cp,
+						   std::size_t mult,
+						   const std::string& label):
+  m_condition{std::move(cp)}, m_multiplicity{mult}, m_label{label}{}
 
 
 CapacityCheckedCondition::~CapacityCheckedCondition(){}
@@ -35,7 +37,20 @@ std::string CapacityCheckedCondition::toString() const {
   const void* address = static_cast<const void*>(this);
   
   ss << "CapacityCheckedCondition (" << address << ") Multiplicity: "
-     << m_multiplicity << '\n' << m_condition->toString();
+     << m_multiplicity << " label "
+     << m_label << '\n'
+     << m_condition->toString();
 
   return ss.str();
 }
+
+std::string CapacityCheckedCondition::label() const {
+  return m_label;
+}
+
+std::ostream& operator<<(std::ostream& out,
+			 const CapacityCheckedCondition& c){
+
+  out << c.toString();
+  return out;
+}
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/CapacityCheckedCondition.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/CapacityCheckedCondition.h
index e01bcc13918d18baafbeb8412aa7e269ea32ca94..90d6e03fbd2a003249cfb782f1148af6b14136ee 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/CapacityCheckedCondition.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/CapacityCheckedCondition.h
@@ -21,6 +21,7 @@
 
 #include <memory>
 #include <string>
+#include <ostream>
 
 
 class ITrigJetHypoInfoCollector;
@@ -28,7 +29,8 @@ class ITrigJetHypoInfoCollector;
 class CapacityCheckedCondition: public ICapacityCheckedCondition {
  public:
  CapacityCheckedCondition(std::unique_ptr<IConditionMT> cp,
-			  std::size_t mult);
+			  std::size_t mult,
+			  const std::string& label="");
   virtual ~CapacityCheckedCondition();
   
   virtual bool
@@ -42,10 +44,16 @@ class CapacityCheckedCondition: public ICapacityCheckedCondition {
   
   virtual std::string toString() const override;
 
+  virtual std::string label() const override;
+
 private:
 
   std::unique_ptr<IConditionMT> m_condition;
   std::size_t m_multiplicity;
+  std::string m_label;
 };
 
+std::ostream& operator<<(std::ostream&,
+			 const CapacityCheckedCondition&);
+
 #endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReducer.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReducer.cxx
index 3a56736c333e8929a90b83472101f3b33b87e15b..7e174e07d330c3df6b6781fd99feba301e4039f6 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReducer.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReducer.cxx
@@ -40,13 +40,9 @@ FastReducer::FastReducer(const HypoJetGroupCIter& groups_b,
                          const HypoJetGroupCIter& groups_e,
                          const ConditionPtrs& conditions,
                          const Tree& tree,
-                         const std::vector<std::vector<int>>& sharedConditions,
                          xAODJetCollector& jetCollector,
                          const Collector& collector):
-  m_conditions(conditions),
-  m_tree(tree),
-  m_sharedConditions(std::move(sharedConditions))
-{
+  m_conditions(conditions),  m_tree(tree) {
 
   // create an empty vector of indices of satisfying jet groups
   // for each Condition.
@@ -56,18 +52,15 @@ FastReducer::FastReducer(const HypoJetGroupCIter& groups_b,
   }
 
 
-  for(const auto& leaves: m_sharedConditions){
-    if(!findInitialJetGroups(leaves,
-			     groups_b,
-			     groups_e,
-			     collector)){
-      if(collector){
-	collector->collect("FastReducer early return",
-			   "from findInitialJetGroups");
-	dumpDataStructures(collector);
-      }
-      return;  // m_pass retains initial value ie false 
+  if(!findInitialJetGroups(groups_b,
+			   groups_e,
+			   collector)){
+    if(collector){
+      collector->collect("FastReducer early return",
+			 "from findInitialJetGroups");
+      dumpDataStructures(collector);
     }
+    return;  // m_pass retains initial value ie false 
   }
 
   
@@ -97,43 +90,79 @@ void FastReducer::collectLeafJets(xAODJetCollector& jetCollector,
 
   // basic passing jet reporting
 
-  // find the indices of the leaf nodes
-  std::set<int> leafCondInds;
-  for (const auto& leaves: m_sharedConditions){
-    leafCondInds.insert(leaves.begin(), leaves.end());
+  // find the indices of the jets that make up the jet groups that pass
+  // the root node.
+
+  //.. obtain the passing jet groups for the root node...
+
+  std::set<std::size_t> rootSatJetGroupInds(m_satisfiedBy.at(0).begin(),
+					    m_satisfiedBy.at(0).end());
+
+  // ...obtain the elemental jet group indicies...
+
+  std::set<std::size_t> rootElSatJetGroupInds;
+  for (const auto& ji : rootSatJetGroupInds) {
+    rootElSatJetGroupInds.insert(m_jg2elemjgs.at(ji).begin(),
+				 m_jg2elemjgs.at(ji).end());
   }
 
-  // obtain the jet group indices for the jet groups satisfying the leaf conds
-  std::set<std::size_t> satJetGroupInds;
-  for (const auto& ci : leafCondInds) {
+    
+
+  // now do the same for the leaf nodes
+  
 
+  auto leaves = m_tree.leaves();
+  // obtain the jet group indices for the jet groups satisfying the leaf conds
+  for (const auto& ci : leaves) {  // for each leaf node...
+    std::set<std::size_t> satJetGroupInds;
+    
+    // ... collect the (possibly compound) jet group indices...
     satJetGroupInds.insert(m_satisfiedBy.at(ci).cbegin(),
                            m_satisfiedBy.at(ci).cend());
-  }
-  
-  // obtain the corresponding elemental jet group indices
-  std::set<std::size_t> elSatJetGroupInds;
-  for (const auto& ji : satJetGroupInds) {
-    elSatJetGroupInds.insert(m_jg2elemjgs.at(ji).begin(),
-			     m_jg2elemjgs.at(ji).end());
-  }
+    
+    // ...obtain the corresponding elemental jet group indices...
+    std::set<std::size_t> elSatJetGroupInds;
+    for (const auto& ji : satJetGroupInds) {
+      elSatJetGroupInds.insert(m_jg2elemjgs.at(ji).begin(),
+			       m_jg2elemjgs.at(ji).end());
+    }
+    
+    // .. get the leg label for the condition (possibly "")
+    auto conditionLabel = (m_conditions.at(ci))->label();
+    
+    if (collector) {
+      std::stringstream ss;
+      ss <<  "elSatJettGroupInds.size() "
+	 << conditionLabel
+	 << ": "
+	 << elSatJetGroupInds.size();
+      collector->collect("FastReducer", ss.str());
+    }
 
-  if (collector) {
-    std::stringstream ss;
-    ss <<  "elSatJettGroupInds.size() " << elSatJetGroupInds.size();
-    collector->collect("FastReducer", ss.str());
+    // ... use the elemental jet group induces to recover the jets
+
+    // if the leaf not jet is one of the jets that contributes to
+    // passing root, store it in the collector, labelled by the leaf node
+    // chainLegLabel
+    
+    auto end = rootElSatJetGroupInds.end();
+    for(const auto& ji : elSatJetGroupInds) {
+      
+      if (rootElSatJetGroupInds.find(ji) != end){  /// jets by indices
+	jetCollector.addJets(m_indJetGroup.at(ji).begin(), //jets py ptrs
+			     m_indJetGroup.at(ji).end(),
+			     conditionLabel);
+      }
+    }
   }
-  
-  for(const auto& ji : elSatJetGroupInds) {
-    jetCollector.addJets(m_indJetGroup.at(ji).begin(),
-                         m_indJetGroup.at(ji).end());
+  if (collector) {
+    collector->collect("FastReducer",
+		       "collected " + std::to_string(jetCollector.size()));
   }
-
 }
 
 
-bool FastReducer::findInitialJetGroups(const std::vector<int>& leaves,
-				       const HypoJetGroupCIter& groups_b,
+bool FastReducer::findInitialJetGroups(const HypoJetGroupCIter& groups_b,
 				       const HypoJetGroupCIter& groups_e,
 				       const Collector& collector) {
   
@@ -141,8 +170,10 @@ bool FastReducer::findInitialJetGroups(const std::vector<int>& leaves,
   /*
     Will now test the incoming jet groups against the leaf conditions.
   */
-  
+
   std::size_t ijg{0};
+  auto leaves = m_tree.leaves();
+
   for(auto iter = groups_b; iter != groups_e; ++iter){
     auto jg = *iter;
     
@@ -160,17 +191,19 @@ bool FastReducer::findInitialJetGroups(const std::vector<int>& leaves,
       
       m_testedBy[leaf].insert(cur_jg);
       if (m_conditions[leaf]->isSatisfied(jg, collector)){
-	  jg_used= true;
-	  if(collector){recordJetGroup(cur_jg, jg, collector);}
-	  // do the following for each satisfied condition ...
-	  m_satisfiedBy[leaf].push_back(cur_jg);
+	jg_used= true;
+	if(collector){recordJetGroup(cur_jg, jg, collector);}
+	// do the following for each satisfied condition ...
+	m_satisfiedBy[leaf].push_back(cur_jg);
       }
     }
+    
     if(jg_used){
       m_jg2elemjgs[cur_jg] =  std::vector<std::size_t>{cur_jg};
       m_indJetGroup.emplace(cur_jg, jg);
       ++ijg;
     }
+    
   }
   
   if(collector){
@@ -186,7 +219,7 @@ bool FastReducer::findInitialJetGroups(const std::vector<int>& leaves,
       return false;
     }
   }
-
+  
   /*
     For the special but important case where all leaf nodes have
     the root node as a parent, check that there are enough jets
@@ -213,7 +246,7 @@ bool FastReducer::findInitialJetGroups(const std::vector<int>& leaves,
   if (std::all_of(m_tree.cbegin(),
 		  m_tree.cend(),
 		  [](std::size_t i){return i == 0;})) {
-
+    
     if (m_conditions[0]->capacity() > ijg) {
       
       if (collector){
@@ -406,14 +439,6 @@ std::string FastReducer::toString() const {
   std::stringstream ss;
   ss << "FastReducer:\n";
   ss << "  treeVector: " << m_tree << '\n';;
-  ss << "  shared node sets [" << m_sharedConditions.size() << "]:\n";
-  for(const auto& snodelist : m_sharedConditions){
-    for(const auto el : snodelist){
-      ss << el << " ";
-    }
-    ss << '\n';
-  }
-
   ss << "FastReducer Conditions ["
      << m_conditions.size() << "]: \n";
 
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReducer.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReducer.h
index 9cb957d1dfe4ae96e9742420164eab5c4499d5c9..7f3d1191fdd18e53c32bec702fa71b4bd4c992fb 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReducer.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReducer.h
@@ -10,6 +10,7 @@
 #include "./JetGroupProduct.h"
 #include "./JetGroupIndAllocator.h"
 #include "./xAODJetCollector.h"
+#include "./ITrigJetHypoInfoCollector.h"
 #include <string>
 
 using TreeVec = std::vector<std::size_t>;
@@ -22,7 +23,6 @@ typedef std::unique_ptr<ITrigJetHypoInfoCollector> Collector;
 
 using JetGroupInd2ElemInds = std::map<int, std::vector<std::size_t>>;
 
-class ITrigJetHypoInfoCollector;
 
 class FastReducer {
  public:
@@ -31,7 +31,6 @@ class FastReducer {
               const HypoJetGroupCIter& groups_e,
               const ConditionPtrs& conditionObjects,
               const Tree& conditionsTree,
-              const std::vector<std::vector<int>>& sharedConditions,
               xAODJetCollector& jetCollector,
               const Collector& collector);
 
@@ -55,12 +54,6 @@ class FastReducer {
   
   Tree m_tree;
 
-  /** A vector of shared Condition indices. All shared Conditions are leaf
-   Conditions  that see the jet icoming jets.
-  */
-  
-  std::vector<std::vector<int>> m_sharedConditions;
-
   // map Condition index onto a list of indices of satisfying job groups.
   CondInd2JetGroupsInds m_satisfiedBy;
 
@@ -89,8 +82,7 @@ class FastReducer {
    in preparration for testing against parent conditions.
   */
   
-  bool findInitialJetGroups(const std::vector<int>& leaves,
-			    const HypoJetGroupCIter& groups_b,
+  bool findInitialJetGroups(const HypoJetGroupCIter& groups_b,
 			    const HypoJetGroupCIter& groups_e,
 			    const Collector& collector);
   
@@ -108,7 +100,7 @@ class FastReducer {
   
   void recordJetGroup(std::size_t ind,
 		      const HypoJetVector& jg,
-		      const std::unique_ptr<ITrigJetHypoInfoCollector>& collector) const;
+		      const Collector& collector) const;
 
   void collectLeafJets(xAODJetCollector& jetCollector,
 		       const Collector& collector) const;
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReductionMatcher.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReductionMatcher.cxx
index 4dfffac4ca42c542b11b33516585717d0b95716a..350de12c4b287444bf9397ece869e0348a79b86c 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReductionMatcher.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReductionMatcher.cxx
@@ -10,16 +10,20 @@
 #include <algorithm>
 #include <sstream>
 
-
-
 FastReductionMatcher::FastReductionMatcher(ConditionPtrs conditions,
-					   const Tree& tree,
-					   const std::vector<std::vector<int>>& sharedNodes):
+					   const Tree& tree):
   m_conditions(std::move(conditions)),
-  m_tree(tree),
-  m_sharedNodes(sharedNodes){
-  }
+  m_tree(tree){
 
+  for (const auto& il : m_tree.leaves()){
+    auto label = m_conditions[il]->label();
+    if (label.rfind("leg", 0) != 0) { // startswith "leg"
+      throw std::runtime_error("Leaf condition " + std::to_string(il) +
+			       "has no leg label");
+    }
+  }
+}
+	 
 
 
 std::optional<bool>
@@ -46,7 +50,6 @@ FastReductionMatcher::match(const HypoJetGroupCIter& groups_b,
                       groups_e,
                       m_conditions,
                       m_tree,
-                      m_sharedNodes,
                       jetCollector,
                       collector);
 
@@ -56,17 +59,9 @@ FastReductionMatcher::match(const HypoJetGroupCIter& groups_b,
 
 std::string FastReductionMatcher::toString() const {
   std::stringstream ss;
-  ss << "FastReductionMatcher:\n";
-  ss << "  treeVector: " << m_tree << '\n';;
-  ss << "  shared node sets [" << m_sharedNodes.size() << "]:\n";
-  for(const auto& snodelist : m_sharedNodes){
-    for(const auto el : snodelist){
-      ss << el << " ";
-    }
-    ss << '\n';
-  }
-
-  ss << "FastReductionMatcher Conditions ["
+  ss << "FastReductionMatcher:\n"
+     << "  treeVector: " << m_tree << '\n'
+     << "FastReductionMatcher Conditions ["
      << m_conditions.size() << "]: \n";
 
   std::size_t count{0u};
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReductionMatcher.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReductionMatcher.h
index 62210f404a39f23639f2a4984ecba85e4ed2855b..9b1e68b8a6ff7639cc816a945e1b359d5f4863a1 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReductionMatcher.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/FastReductionMatcher.h
@@ -17,8 +17,7 @@ class FastReductionMatcher: public IGroupsMatcherMT {
  public:
 
   FastReductionMatcher(ConditionPtrs,
-		       const Tree&,
-		       const std::vector<std::vector<int>>&);
+		       const Tree&);
 
 
   /** determine whether a set of jets satisfies all hypo conditions.
@@ -51,11 +50,5 @@ class FastReductionMatcher: public IGroupsMatcherMT {
   
   Tree m_tree;
 
-  /** a vector of shared nodes. All shared nodes are leaf node that
-  see the jet collection.
-  */
-  
-  std::vector<std::vector<int>> m_sharedNodes;
-
 };
 #endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/ICapacityCheckedCondition.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/ICapacityCheckedCondition.h
index c49ea11ab1f8fc7cba13df0122ff0a42f0f497c4..c38345684e6136d4fe57416e09dc525560e929f2 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/ICapacityCheckedCondition.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/ICapacityCheckedCondition.h
@@ -32,7 +32,10 @@ class ICapacityCheckedCondition: public IConditionMT {
 
   virtual bool multiplicitySatisfied(std::size_t jgMultiplicity,
 				     const Collector&) const = 0;
-  
+
+  virtual std::string label() const = 0;
+  virtual std::string toString() const = 0;
+
 };
 
 #endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/PartitionsGroupsMatcherMT.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/PartitionsGroupsMatcherMT.cxx
deleted file mode 100644
index 25f1a293e85dc775d4eb2b8b146b0e106f98de30..0000000000000000000000000000000000000000
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/PartitionsGroupsMatcherMT.cxx
+++ /dev/null
@@ -1,88 +0,0 @@
-/*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
-*/
-
-// ********************************************************************
-//
-// NAME:     PartitionsGroupsMatcherMT.cxx
-// PACKAGE:  Trigger/TrigHypothesis/TrigHLTJetHypo
-//
-// AUTHOR:   P Sherwood
-//
-// ********************************************************************
-//
-
-#include "./PartitionsGroupsMatcherMT.h"
-#include "./ITrigJetHypoInfoCollector.h"
-#include "./xAODJetCollector.h"
-
-// #include <cmath>
-// #include <sstream>
-#include <algorithm>
-// #include <map>
-
-PartitionsGroupsMatcherMT::PartitionsGroupsMatcherMT(ConditionsMT&& cs):
-  m_conditions(std::move(cs)), m_nConditions(m_conditions.size()){
-  std::size_t minNjets{0};
-  for(const auto& c : m_conditions){minNjets += c->capacity();}
-  m_minNjets = minNjets;
-}
-
-std::optional<bool>
-PartitionsGroupsMatcherMT::match(const HypoJetGroupCIter& groups_b,
-				 const HypoJetGroupCIter& groups_e,
-				 xAODJetCollector& jetCollector,
-				 const std::unique_ptr<ITrigJetHypoInfoCollector>& collector,
-				 bool) const {
-  
-
-
-  // minimal input correctness checks. More detailed checking
-  // responsibility of the caller.
-
-  auto iter_diff = groups_e - groups_b;
-  if (iter_diff < 0){return std::optional<bool>();}
-  auto n_jetvecs = static_cast<std::size_t>(iter_diff);
-  auto n_conditions = m_conditions.size();
-  
-  if(n_conditions != n_jetvecs){
-    if(collector){
-      std::string msg = "Number of HypoJetVectors " +
-	std::to_string(n_jetvecs) + " !=  number of children " +
-	std::to_string(n_conditions);
-      
-      collector->collect("PartitionsGroupsMatcherMT", msg);
-    }
-    return std::optional<bool>();
-  }
-
-  for(std::size_t i = 0;  i != n_conditions; ++i){
-    // Pass each job group to its corresposonding child, check if pass.
-    // Return false any child does not pass.
-    if (!m_conditions[i]->isSatisfied(*(groups_b +i), collector)){
-      return std::make_optional<bool>(false);
-    }
-
-    // passed....
-    if(collector){
-      collector->collect("PartitionsGroupsMatcherMT", "passed");
-    }
-    for(auto iter = groups_b; iter != groups_e; ++iter){
-      jetCollector.addJets((*iter).begin(), (*iter).end());
-    }
-  }
-  
-  return std::make_optional<bool>(true);  
-} 
-
-
-std::string PartitionsGroupsMatcherMT::toString() const noexcept {
-  std::stringstream ss;
-
-  ss << "PartitionsMatcherMT. No of conditions: "
-     << m_conditions.size() << '\n';
-  for(const auto& c : m_conditions){ ss <<"  "<< c->toString() << '\n';}
-  return ss.str();
-}
-
-
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/PartitionsGroupsMatcherMT.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/PartitionsGroupsMatcherMT.h
deleted file mode 100644
index 3e7c7aaafdd2a523f4bf23b35b4adfe2f583de8c..0000000000000000000000000000000000000000
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/PartitionsGroupsMatcherMT.h
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
-*/
-
-#ifndef TRIGHLTJETHYPO_PARTITIONSGROUPSMATCHERMT_H
-#define TRIGHLTJETHYPO_PARTITIONSGROUPSMATCHERMT_H
-
-// ********************************************************************
-//
-// NAME:     PartitionsGroupsMatcherMT.h
-// PACKAGE:  Trigger/TrigHypothesis/TrigHLTJetHypo
-//
-// AUTHOR:  P Sherwood
-//
-// ********************************************************************
-//
-
-#include "./IGroupsMatcherMT.h"
-#include "./ConditionsDefsMT.h"
-#include "TrigHLTJetHypo/TrigHLTJetHypoUtils/HypoJetDefs.h"
-#include "TrigHLTJetHypo/TrigHLTJetHypoUtils/IJet.h"
-#include <optional>
-
-class ITrigJetHypoInfoCollector;
-class xAODJetCollector;
-
-class PartitionsGroupsMatcherMT:
-virtual public IGroupsMatcherMT {
-
-  /* Given a two equi-length containers of HypoJetVectors
-     and Conditions , associate the ith elements, and determine if,
-     for each i, the Condition is datisfoied by the HypoJetVector.
-  */
-
-public:
-  PartitionsGroupsMatcherMT(ConditionsMT&& cs);
-  ~PartitionsGroupsMatcherMT(){}
-
-  std::optional<bool> match(const HypoJetGroupCIter&,
-			    const HypoJetGroupCIter&,
-			    xAODJetCollector&,
-			    const std::unique_ptr<ITrigJetHypoInfoCollector>&,
-			    bool debug=false) const override;
-  std::string toString() const noexcept override;
-
-private:
-  ConditionsMT m_conditions;
-  std::size_t m_nConditions{0};
-  std::size_t m_minNjets{0};
-
-};
-
-#endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/SingleConditionMatcherMT.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/SingleConditionMatcherMT.cxx
index bd19c59ce858d9b4f64a7296919bd7d6049e1da4..448399ad38380097578432e041fa63a0b4cc1191 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/SingleConditionMatcherMT.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/SingleConditionMatcherMT.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 // ********************************************************************
@@ -32,7 +32,10 @@ SingleConditionMatcherMT::match(const HypoJetGroupCIter& jets_b,
 
   for(auto i=jets_b; i != jets_e; ++i){
     if (m_condition->isSatisfied(*i, v)){
-      jetCollector.addJets((*i).cbegin(), (*i).cend());
+      // Note that this slightly out-of-date code does not expect
+      // chains with simple and non-simple scenarios to be present in the
+      // same chain. The leg label is hard coded here.
+      jetCollector.addJets((*i).cbegin(), (*i).cend(), "leg000");
       return std::make_optional<bool>(true);
     }
   }
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/AllJetsGrouper.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/AllJetsGrouper.cxx
index 6f2daf8f9450fe8117adde16b849c813ceaeda61..fcbfca501e77312285ce97dd51b1eae48480a0a6 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/AllJetsGrouper.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/AllJetsGrouper.cxx
@@ -1,10 +1,21 @@
 
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/AllJetsGrouper.h"
 
+AllJetsGrouper:: AllJetsGrouper(){}
+
+AllJetsGrouper:: AllJetsGrouper(const HypoJetIter& b,
+				const HypoJetIter& e): m_jets(b, e){
+}
+
+AllJetsGrouper:: AllJetsGrouper(const HypoJetVector& jets): m_jets{jets}{
+}
+
+
+
 std::vector<HypoJetGroupVector> AllJetsGrouper::group(HypoJetIter& begin,
 						      HypoJetIter& end
 						      ) const {
@@ -12,10 +23,13 @@ std::vector<HypoJetGroupVector> AllJetsGrouper::group(HypoJetIter& begin,
   return std::vector<HypoJetGroupVector>{hjgv};
 }
 
-std::optional<HypoJetGroupVector> AllJetsGrouper::next(HypoJetIter& begin,
-						       HypoJetIter& end
-						       ) const {
-  HypoJetGroupVector hjgv{HypoJetVector(begin, end)};
+std::optional<HypoJetGroupVector> AllJetsGrouper::next(){
+  if (m_done){
+    return std::optional<HypoJetGroupVector>();
+  }
+  
+  HypoJetGroupVector hjgv{HypoJetVector(m_jets)};
+  m_done = true;
   return std::make_optional<HypoJetGroupVector>(hjgv);
 }
 
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/CombinationsGrouper.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/CombinationsGrouper.cxx
index c69f387e4ddf6f77d975767c0b5a2d76bf359270..e05b643e00c4e575c5bb3d70fa1dfebe2b2d97d8 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/CombinationsGrouper.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/CombinationsGrouper.cxx
@@ -1,13 +1,28 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/CombinationsGrouper.h"
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/CombinationsGen.h"
 
 #include <sstream>
+
+CombinationsGrouper::CombinationsGrouper(){}
+
 CombinationsGrouper::CombinationsGrouper(unsigned int groupSize):
-  m_groupSize(groupSize){
+  m_groupSize{groupSize}{}
+
+
+CombinationsGrouper::CombinationsGrouper(unsigned int groupSize,
+					 const HypoJetVector& jets):
+  m_groupSize(groupSize), m_jets{jets}{
+}
+
+
+CombinationsGrouper::CombinationsGrouper(unsigned int groupSize,
+					 const HypoJetCIter& b,
+					 const HypoJetCIter& e):
+  m_groupSize(groupSize), m_jets{b, e}{
 }
 
 
@@ -32,12 +47,12 @@ CombinationsGrouper::group(HypoJetIter& begin, HypoJetIter& end) const {
 }
 
 std::optional<HypoJetGroupVector>
-CombinationsGrouper::next(HypoJetIter& begin, HypoJetIter& end) const {
+CombinationsGrouper::next() {
   HypoJetGroupVector hjgv;
   
   // create a combinations generator. Used to select the jets
   // to be tested by the condition objects
-  CombinationsGen combgen(end-begin, m_groupSize);
+  CombinationsGen combgen(m_jets.size(), m_groupSize);
   
   auto combs = combgen.next();
   if (combs.second == false){
@@ -45,7 +60,7 @@ CombinationsGrouper::next(HypoJetIter& begin, HypoJetIter& end) const {
   }
   
   HypoJetVector v;
-  for(auto i : combs.first){ v.push_back(*(begin + i));}
+  for(auto i : combs.first){ v.push_back(*(m_jets.begin() + i));}
   
   return std::make_optional<HypoJetGroupVector>(hjgv);
 }
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/IndexedJetsGrouper.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/IndexedJetsGrouper.cxx
index d4619f894be4faeb63008927aec2226edc7bc859..1abd209d030ccaf7b58acdac5423e6240711ba41 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/IndexedJetsGrouper.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/IndexedJetsGrouper.cxx
@@ -22,13 +22,24 @@
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/IndexedJetsGrouper.h"
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/DescendingEt.h"
 
-IndexedJetsGrouper::IndexedJetsGrouper(const std::vector<unsigned int>& indices):
-  m_indices(indices){
-  if (indices.empty()) {
-    std::string m = "IndexedJetsGrouper: Attempt to iniatialize with an ";
-    m += "empty indices vector";
-    throw std::out_of_range(m); 
-  }
+
+IndexedJetsGrouper::IndexedJetsGrouper(const std::vector<unsigned int>& inds):
+  m_indices(inds){
+}
+
+IndexedJetsGrouper::IndexedJetsGrouper(const std::vector<unsigned int>& indices,
+				       const HypoJetVector& jets):
+  m_indices(indices), m_jets(jets){
+    
+  //sort the indices because the last one will be used to 
+  // check there are enough jets to process;
+  std::sort(m_indices.begin(), m_indices.end());
+}
+
+IndexedJetsGrouper::IndexedJetsGrouper(const std::vector<unsigned int>& indices,
+				       const HypoJetCIter& b,
+				       const HypoJetCIter& e):
+  m_indices(indices), m_jets(b, e){
     
   //sort the indices because the last one will be used to 
   // check there are enough jets to process;
@@ -39,6 +50,9 @@ IndexedJetsGrouper::IndexedJetsGrouper(const std::vector<unsigned int>& indices)
 std::vector<HypoJetGroupVector>
 IndexedJetsGrouper::group(HypoJetIter& begin, HypoJetIter& end) const{
   
+
+  if (m_indices.empty()) {return std::vector<HypoJetGroupVector>{};}
+
   // check if there are enough jets find the highest (last, as the vector is
   // ordered) and see if it lies within the jet vector
   
@@ -65,27 +79,36 @@ IndexedJetsGrouper::group(HypoJetIter& begin, HypoJetIter& end) const{
 
 
 std::optional<HypoJetGroupVector>
-IndexedJetsGrouper::next(HypoJetIter& begin, HypoJetIter& end) const{
+IndexedJetsGrouper::next(){
+
+  // exhausts after a single group
   
   // check if there are enough jets find the highest (last, as the vector is
   // ordered) and see if it lies within the jet vector
+
+  if (m_done) { return std::optional<HypoJetGroupVector>(); }
+  if (m_indices.empty()) { return std::optional<HypoJetGroupVector>(); }
   
   auto hjgv = HypoJetGroupVector();
   auto last_jet_pos =  m_indices.back();
-  if(end - begin - 1 < last_jet_pos){return std::optional<HypoJetGroupVector>();}
+  if (m_jets.size() <= last_jet_pos) {
+    m_done = true;
+    return std::optional<HypoJetGroupVector>();
+  }
   
   // sort jets by descending Et
-  std::partial_sort (begin,
-                     begin + last_jet_pos + 1,
-                     end,
+  std::partial_sort (m_jets.begin(),
+                     m_jets.begin() + last_jet_pos + 1,
+                     m_jets.end(),
                      DescendingEt());
   
   // place the jets at positions in the index vector into the inner vector
   HypoJetVector inner;
-  for (auto i : m_indices){inner.push_back(*(begin + i));}
+  for (auto i : m_indices){inner.push_back(*(m_jets.begin() + i));}
   
   // push the inner vector into the outer vector
   hjgv.push_back(inner);
+  m_done = true;
   return std::make_optional<HypoJetGroupVector>(hjgv);
 }
 
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/PartitionsGrouper.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/PartitionsGrouper.cxx
deleted file mode 100644
index 003caaae10d5a4254d592b7d5b2a2ad19b8639a5..0000000000000000000000000000000000000000
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/PartitionsGrouper.cxx
+++ /dev/null
@@ -1,88 +0,0 @@
-/*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
-*/
-
-#include "TrigHLTJetHypo/TrigHLTJetHypoUtils/PartitionsGrouper.h"
-#include "TrigHLTJetHypo/TrigHLTJetHypoUtils/PartitionsGen.h"
-#include "TrigHLTJetHypo/TrigHLTJetHypoUtils/HypoJetDefs.h"
-
-#include <sstream>
-PartitionsGrouper::PartitionsGrouper(const std::vector<std::size_t>& mults) :
-  m_mults(mults){
-}
-
-
-std::vector<HypoJetGroupVector>
-PartitionsGrouper::group(HypoJetIter& begin,
-			 HypoJetIter& end) const {
-
-
-  
-  std::vector<HypoJetGroupVector> result;
-
-  auto pg = PartitionsGen(end-begin, m_mults);
-  while(true){
-
-    auto p = pg.next();
-    if(!p.has_value()){break;}
-
-    HypoJetGroupVector hjgv;
-    for(const auto& iv : *p){
-      // iv is a vector of indices
-      HypoJetVector hjv;
-      for(const auto i : iv) {
-	// i is an index
-	hjv.push_back(*(begin + i));
-      }
-      hjgv.push_back(hjv);
-    }
-
-    result.push_back(hjgv);
-  }
-
-  return result;
-}
-
-
-std::optional<HypoJetGroupVector>
-PartitionsGrouper::next(HypoJetIter& begin,
-			HypoJetIter& end) const {
-
-  auto pg = PartitionsGen(end-begin, m_mults);
-
-  auto p = pg.next();
-  
-  if(!p.has_value()){
-    return std::optional<HypoJetGroupVector>();
-  }
-
-  HypoJetGroupVector hjgv;
-  for(const auto& iv : *p){
-    // iv is a vector of indices
-    HypoJetVector hjv;
-    for(const auto i : iv) {
-      // i is an index
-      hjv.push_back(*(begin + i));
-    }
-    hjgv.push_back(hjv);
-  }
-  
-  return std::make_optional<HypoJetGroupVector>(hjgv);
-}
-
-
-std::string PartitionsGrouper::getName() const {
-  return "PartitionsGrouper";
-}
-
-std::string PartitionsGrouper::toString() const {
-
-  std::stringstream ss;
-
-  ss << "PartitionsGrouper - allocate jets to Conditions. jets/condition: ";
-  for(const auto & i : m_mults){ss << i << " ";}
-  ss << '\n';
-  return ss.str();
-}
-
-
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/SingleJetGrouper.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/SingleJetGrouper.cxx
index 12df76c5c21ee53a267c1fc7303763c717148f3e..80441003fc073e648cd432ff0d7c48e109d87be8 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/SingleJetGrouper.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigHLTJetHypoUtils/SingleJetGrouper.cxx
@@ -1,9 +1,20 @@
 /*
-  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/SingleJetGrouper.h"
 
+
+SingleJetGrouper::SingleJetGrouper(){}
+
+SingleJetGrouper::SingleJetGrouper(const HypoJetVector& v): m_jets(v){
+}
+
+SingleJetGrouper::SingleJetGrouper(const HypoJetCIter& b,
+				   const HypoJetCIter& e):
+  m_jets(b, e){
+}
+
 std::vector<HypoJetGroupVector> SingleJetGrouper::group(HypoJetIter& begin,
 							HypoJetIter& end
 							) const {
@@ -18,17 +29,14 @@ std::vector<HypoJetGroupVector> SingleJetGrouper::group(HypoJetIter& begin,
 }
 
 std::optional<HypoJetGroupVector>
-SingleJetGrouper::next(HypoJetIter& begin,
-		       HypoJetIter& end
-		       ) const {
-  HypoJetGroupVector hjgv;
-  for(; begin != end; ++begin){
-    HypoJetVector v;
-    v.push_back(*begin);
-    hjgv.push_back(v);
+SingleJetGrouper::next() {
+  if (m_index == m_size){
+    return std::optional<HypoJetGroupVector>();
   }
   
-  return std::make_optional<HypoJetGroupVector>(hjgv);
+  HypoJetGroupVector result;
+  result.push_back(HypoJetVector{m_jets[m_index++]});
+  return std::make_optional<HypoJetGroupVector>(result);
 }
 
 std::string SingleJetGrouper::getName() const {
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetConditionConfig_capacitychecked.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetConditionConfig_capacitychecked.cxx
index 94be844cd6b0673dd86622258fd6eb814892b093..7e6b83429a575f303a08c2a93ffa8d3db86cd565 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetConditionConfig_capacitychecked.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetConditionConfig_capacitychecked.cxx
@@ -35,7 +35,8 @@ TrigJetConditionConfig_capacitychecked::getCapacityCheckedCondition() const {
   auto cc =  std::make_unique<CompoundConditionMT>(elements);
 
   return std::make_unique<CapacityCheckedCondition>(std::move(cc),
-						    m_multiplicity);
+						    m_multiplicity,
+						    m_chainLegLabel);
 }
 				     
 
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetConditionConfig_capacitychecked.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetConditionConfig_capacitychecked.h
index 7f7b4031ef8903673fffe78762bcf95c2e317d37..c96b40a34059c35a3c48f7c60d0aa4a37ddc6376 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetConditionConfig_capacitychecked.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetConditionConfig_capacitychecked.h
@@ -35,6 +35,14 @@ public extends<AthAlgTool, ITrigJetCapacityCheckedConditionConfig> {
   Gaudi::Property<std::size_t> m_multiplicity {this, "multiplicity", {1},
       "no. of occurences of identical condition"};
 
+  
+  Gaudi::Property<std::string> m_chainLegLabel {this,
+    "chainLegLabel",
+    {""},
+    "identifier for chain leg - used to group jets for jet hypo clients "};
+
+
+
   StatusCode checkVals()  const;
  
 };
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx
index 12e20c532fcad7afaa9e795f4bd75d2bb629e287..6ef03eaee4841d1675d8130e495ec028577dd381 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx
@@ -1,9 +1,8 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include <algorithm>
-#include "Gaudi/Property.h"
 #include "TrigJetHypoAlgMT.h"
 #include "TrigCompositeUtils/HLTIdentifier.h"
 #include "TrigCompositeUtils/TrigCompositeUtils.h"
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolConfig_fastreduction.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolConfig_fastreduction.cxx
index 06a7b234ac8b30dca7ce6f3be04860cc3878e5f5..f407bcf776c44e383135eb661b09e5397aa64acd 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolConfig_fastreduction.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolConfig_fastreduction.cxx
@@ -11,7 +11,6 @@
 
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/SingleJetGrouper.h"
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/xAODJetAsIJetFactory.h"
-// #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/groupsMatcherFactory.h"
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/CleanerFactory.h"
 #include "TrigHLTJetHypo/TrigHLTJetHypoUtils/TrigHLTJetHypoHelper2.h"
 #include "./groupsMatcherFactoryMT.h"
@@ -46,25 +45,6 @@ StatusCode TrigJetHypoToolConfig_fastreduction::initialize() {
     return StatusCode::FAILURE;
   }
   
-  // gymnastics as cannot pass vecor<vecotr<int>> as a Gaudi::Property
-  if(m_sharedNodesVec.empty()){
-    ATH_MSG_ERROR("shared node vector empty");
-
-    return StatusCode::FAILURE;}
-
-  std::vector<int> shared;
-  for(const auto& i : m_sharedNodesVec){
-    if(i  == -1){
-      m_sharedNodes.push_back(shared);
-      shared = std::vector<int>();
-    } else {
-      shared.push_back(i);
-    }
-  }
-  if(!shared.empty()){
-    m_sharedNodes.push_back(shared);
-  }
-
   
   /* set the capacity of the acceptAll nodes (or nay
      nodes with modifiable capciity.
@@ -176,8 +156,7 @@ TrigJetHypoToolConfig_fastreduction::getMatcher () const {
   }
 
   return groupsMatcherFactoryMT_FastReduction(std::move(*opt_conds),
-					      m_treeVec,
-					      m_sharedNodes);
+					      m_treeVec);
 }
 
 StatusCode TrigJetHypoToolConfig_fastreduction::checkVals() const {
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolConfig_fastreduction.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolConfig_fastreduction.h
index 008405edf4d50a944893da8a6dd1254dfc4e7dfc..26a33fe89d6c5d78534ddfbd548e17c318e5e9e3 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolConfig_fastreduction.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolConfig_fastreduction.h
@@ -53,10 +53,8 @@ public extends<AthAlgTool, ITrigJetHypoToolConfig> {
   Gaudi::Property<std::vector<std::size_t>> m_treeVec{
     this, "treeVector", {}, "integer sequence representation of jet hypo tree"};
 
-  Gaudi::Property<std::vector<int>> m_sharedNodesVec{
-    this, "sharedVector", {}, "nodeID groups for nodes that see input jets"};
-
-  std::vector<std::vector<int>> m_sharedNodes{};
+  Gaudi::Property<std::vector<int>> m_leafNodes{
+    this, "leafVector", {}, "node ids for leaf nodes"};
 
   std::optional<ConditionPtrs> getCapacityCheckedConditions() const;
 
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolMT.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolMT.cxx
index 63ab69cb60f45da312add040cdf573c1c7123e39..448bd35a3cd2635e16d4c473e3eeec9e5da2d0d3 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolMT.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolMT.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 // ********************************************************************
@@ -23,6 +23,8 @@
 #include "TrigCompositeUtils/HLTIdentifier.h"
 #include "TrigCompositeUtils/TrigCompositeUtils.h"
 
+#include <sstream>
+
 using TrigCompositeUtils::DecisionID;
 using TrigCompositeUtils::Decision;
 using TrigCompositeUtils::DecisionContainer;
@@ -120,8 +122,22 @@ TrigJetHypoToolMT::decide(const xAOD::JetContainer* jets,
       infocollector->
 	collect(name(),
 		"no of xAODJets " + std::to_string(participating_jets.size()));
+
+      auto labels = jetCollector.legLabels();
+      std::stringstream ss;
+      
+      for(const auto& label : labels){
+	auto jets = jetCollector.xAODJets(label);
+	ss << label << " [\n";
+	for(const auto& j : jets){
+	  ss << static_cast<const void*>(j) << '\n';
+	}
+	ss << "]\n";
+      }
+      infocollector->collect(name(), ss.str());
     }
 
+
     for (auto& pair : jetHypoInputs) { 
       auto it = std::find(participating_jets.begin(),
                           participating_jets.end(),
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolMT.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolMT.h
index 3eb88c784342294ca141737b865752f3067ac8bb..b16024c67da37af3ed714241892128af3d79e0d2 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolMT.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoToolMT.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRIGJETHYPOTOOLMT_H
@@ -23,6 +23,8 @@
 #include "xAODEventInfo/EventInfo.h"
 #include "xAODJet/JetContainer.h"
 
+#include <string>
+
 struct EventSN{
   std::size_t m_id{0};
   std::size_t getSN(){return m_id++;}
@@ -60,8 +62,11 @@ public:
   ToolHandle<ITrigJetHypoToolHelperMT> m_helper {
     this, "helper_tool", {}, "Jet hypo helper AlgTool"};
   
-  Gaudi::Property<bool>
-    m_visitDebug {this, "visit_debug", false, "debug flag"};
+  Gaudi::Property<bool> m_visitDebug {
+    this, "visit_debug", false, "debug flag"};
+
+  Gaudi::Property<std::string> m_chainName {
+    this, "chain_name", {}, "chain name"};
   
   
   std::unique_ptr<EventSN> m_eventSN;
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetTLAHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetTLAHypoAlgMT.cxx
index 894cc90bcbe6a4529d4137d4db82a698f16aa1bc..950268afffe59f4485498a169323b58c7cb2b1c5 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetTLAHypoAlgMT.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetTLAHypoAlgMT.cxx
@@ -1,9 +1,8 @@
 /*
-   Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+   Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
    */
 
 #include <algorithm>
-#include "Gaudi/Property.h"
 #include "TrigJetTLAHypoAlgMT.h"
 #include "TrigCompositeUtils/HLTIdentifier.h"
 #include "TrigCompositeUtils/TrigCompositeUtils.h"
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/groupsMatcherFactoryMT.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/groupsMatcherFactoryMT.cxx
index a580b25257e508076ea4c922811da62bac5ac510..b34ebadffb584129d617aa6e72c7055113d2bee4 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/groupsMatcherFactoryMT.cxx
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/groupsMatcherFactoryMT.cxx
@@ -3,8 +3,6 @@
 */
 
 #include "./groupsMatcherFactoryMT.h"
-#include "./MaximumBipartiteGroupsMatcherMT.h"
-#include "./PartitionsGroupsMatcherMT.h"
 #include "./SingleConditionMatcherMT.h"
 #include "./FastReductionMatcher.h"
 
@@ -18,45 +16,16 @@ groupsMatcherFactoryMT_SingleCondition (ConditionsMT&& conditions){
   return std::make_unique<SingleConditionMatcherMT>(std::move(conditions[0]));
 }
 
-std::unique_ptr<IGroupsMatcherMT> 
-groupsMatcherFactoryMT_MaxBipartite (ConditionsMT&& conditions){
-
-  if (conditions.empty()){
-    return std::make_unique<SingleConditionMatcherMT>(nullptr);
-  }
-
-  // check the number of conditions to decide the Matcher type.
-  if (conditions.size() == 1) {
-    return std::make_unique<SingleConditionMatcherMT>(std::move(conditions[0]));
-  } else {
-    return std::make_unique<MaximumBipartiteGroupsMatcherMT>(std::move(conditions));
-  }
-  
-}
-
-
-std::unique_ptr<IGroupsMatcherMT> 
-groupsMatcherFactoryMT_Partitions (ConditionsMT&& conditions){
-  
-  if (conditions.size() == 1) {
-    return std::make_unique<SingleConditionMatcherMT>(std::move(conditions[0]));
-  } else {
-    return std::make_unique<PartitionsGroupsMatcherMT>(std::move(conditions));
-  }
-}
-
 
 std::unique_ptr<IGroupsMatcherMT> 
 groupsMatcherFactoryMT_FastReduction (ConditionPtrs&& conditions,
-				      const std::vector<std::size_t>& treeVec,
-				      const std::vector<std::vector<int>>& sharedNodes){
+				      const std::vector<std::size_t>& treeVec){
   
   if (conditions.size() == 1) {
     return std::make_unique<SingleConditionMatcherMT>(std::move(conditions[0]));
   } else {
     return std::make_unique<FastReductionMatcher>(std::move(conditions),
-						  treeVec,
-						  sharedNodes);
+						  treeVec);
   } 
 }
 
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/groupsMatcherFactoryMT.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/groupsMatcherFactoryMT.h
index 1865de3d94bf3f4a37849b295db109fa3c1a7924..b91b74c3df2786e801e0cf1f1c410097ed48a22b 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/groupsMatcherFactoryMT.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/groupsMatcherFactoryMT.h
@@ -16,12 +16,7 @@ groupsMatcherFactoryMT_SingleCondition(ConditionsMT&&);
 std::unique_ptr<IGroupsMatcherMT>
 groupsMatcherFactoryMT_MaxBipartite(ConditionsMT&&);
 
-std::unique_ptr<IGroupsMatcherMT>
-groupsMatcherFactoryMT_Partitions(ConditionsMT&&);
-
-
 std::unique_ptr<IGroupsMatcherMT>
 groupsMatcherFactoryMT_FastReduction(ConditionPtrs&&,
-				     const std::vector<std::size_t>& treeVec,
-				     const std::vector<std::vector<int>>&);
+				     const std::vector<std::size_t>& treeVec);
 #endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/xAODJetCollector.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/xAODJetCollector.cxx
new file mode 100644
index 0000000000000000000000000000000000000000..646b1dbb682ac25fd1eb4fbde0cc2392b5fe4db2
--- /dev/null
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/xAODJetCollector.cxx
@@ -0,0 +1,108 @@
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
+#include  "xAODJetCollector.h"
+
+#include <algorithm>
+#include <cassert>
+
+void xAODJetCollector::addJets(const HypoJetCIter& begin,
+			       const HypoJetCIter& end,
+			       const std::string& label){
+  auto& jets = m_jets[label];
+  jets.insert(jets.end(), begin, end);
+}
+  
+
+std::vector<const xAOD::Jet*> xAODJetCollector::xAODJets() const {
+  
+  HypoJetVector all;
+  for (const auto& p : m_jets){
+    std::copy(p.second.cbegin(),
+	      p.second.cend(),
+	      std::back_inserter(all)
+	      );
+  }
+  return xAODJets_(all.cbegin(), all.cend());
+}
+
+
+std::vector<const xAOD::Jet*>
+xAODJetCollector::xAODJets(const std::string& label) const {
+  
+  if (m_jets.count(label) == 0){
+    std::vector<const xAOD::Jet*> empty;
+    return empty;
+  }
+  
+  const auto& jets = m_jets.at(label);
+  return xAODJets_(jets.cbegin(), jets.cend());
+}
+
+  
+HypoJetVector xAODJetCollector::hypoJets() const {
+  HypoJetVector all;
+  for (const auto& p : m_jets){
+    std::copy(p.second.cbegin(),
+	      p.second.cend(),
+	      std::back_inserter(all)
+	      );
+  }
+  HypoJetSet js(all.begin(), all.end());
+  return HypoJetVector(js.begin(), js.end());
+}
+
+  
+HypoJetVector xAODJetCollector::hypoJets(const std::string& label) const {
+  auto begin = m_jets.at(label).cbegin();
+  auto end = m_jets.at(label).cend();
+  HypoJetSet js(begin, end);
+  return HypoJetVector(js.begin(), js.end());
+}
+
+
+void xAODJetCollector::addOneJet(const pHypoJet jet,
+				 const std::string& label){
+  m_jets[label].push_back(jet);
+}
+
+
+std::size_t xAODJetCollector::size() const {return hypoJets().size();}
+
+bool xAODJetCollector::empty() const {return hypoJets().empty();}
+
+std::vector<const xAOD::Jet*>
+xAODJetCollector::xAODJets_(const HypoJetVector::const_iterator begin,
+			    const HypoJetVector::const_iterator end
+			    )  const {
+  
+  HypoJetVector hypoJets(begin, end);
+  
+  auto new_end =
+    std::partition(hypoJets.begin(),
+		   hypoJets.end(),
+		   [](const pHypoJet& j){
+		     return (j->xAODJet()).has_value();});
+  // add xAOD::Jet* to m_jets
+  std::vector<const xAOD::Jet*> xJets;
+  xJets.reserve(new_end - hypoJets.begin());
+  std::transform(hypoJets.begin(),
+		 new_end,
+		 back_inserter(xJets),
+		 [](const pHypoJet j){return *(j->xAODJet());});
+  
+  std::set<const xAOD::Jet*> js(xJets.begin(), xJets.end());
+  return std::vector<const xAOD::Jet*> (js.begin(), js.end());
+}
+
+
+std::vector<std::string>  xAODJetCollector::legLabels() const {
+  std::vector<std::string> labels;
+
+  for(auto it = m_jets.begin(); it != m_jets.end(); ++it){
+    labels.push_back(it->first);
+  }
+
+  return labels;
+}
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/xAODJetCollector.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/xAODJetCollector.h
index f6c6cdb026fee9071eea39ae34d1eeab66dc3699..74b03b97301b46ea8664ecd82cce1325e46d8bc3 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/xAODJetCollector.h
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/xAODJetCollector.h
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #ifndef TRIGLHLTJETHYPO_XAODJETCOLLECTOR_H
@@ -8,59 +8,49 @@
 #include  "xAODJet/Jet.h"
 #include  "TrigHLTJetHypo/TrigHLTJetHypoUtils/HypoJetDefs.h"
 
+#include <string>
 #include <vector>
-#include <algorithm>
-#include <cassert>
+#include <map>
 
 // xAODJetCollector - an object send to a (possibly recursive)
 // TrigJetHypoToolHelpers to obtain xAOD jets
 
+using CI = std::map<std::string, HypoJetVector>::const_iterator;
 
 class xAODJetCollector {
 
 public:
 
-  void addJets(const HypoJetCIter& begin, const HypoJetCIter& end){
-    m_jets.insert(m_jets.end(), begin, end);
-  }
+  void addJets(const HypoJetCIter& begin,
+	       const HypoJetCIter& end,
+	       const std::string& label="");
   
-  std::vector<const xAOD::Jet*> xAODJets() const {
+  std::vector<const xAOD::Jet*> xAODJets() const;
     
-    HypoJetVector hypoJets(m_jets.begin(), m_jets.end());
-    
-    auto new_end =
-      std::partition(hypoJets.begin(),
-		     hypoJets.end(),
-		     [](const pHypoJet& j){
-		       return (j->xAODJet()).has_value();});
-    // add xAOD::Jet* to m_jets
-    std::vector<const xAOD::Jet*> xJets;
-    xJets.reserve(new_end - hypoJets.begin());
-    std::transform(hypoJets.begin(),
-		   new_end,
-		   back_inserter(xJets),
-		   [](const pHypoJet j){return *(j->xAODJet());});
-
-    std::set<const xAOD::Jet*> js(xJets.begin(), xJets.end());
-    return std::vector<const xAOD::Jet*> (js.begin(), js.end());
-  }
-
-  
-  HypoJetVector hypoJets() const {
-    HypoJetSet js(m_jets.begin(), m_jets.end());
-    return HypoJetVector(js.begin(), js.end());
-  }
+  std::vector<const xAOD::Jet*> xAODJets(const std::string& label) const;
   
-  void addOneJet(const pHypoJet jet){
-    m_jets.push_back(jet);
-  }
+  HypoJetVector hypoJets() const;
+  HypoJetVector hypoJets(const std::string& label) const;
+
+  void addOneJet(const pHypoJet jet, const std::string& label="");
+
+  std::size_t size() const;
+  bool empty() const;
+
 
-  std::size_t size() const {return m_jets.size();}
-  bool empty() const {return m_jets.empty();}
- 
+  std::vector<std::string> legLabels() const;
+  
  private:
-  HypoJetVector m_jets;
 
+  std::map<std::string, HypoJetVector> m_jets;
+
+    
+  std::vector<const xAOD::Jet*>
+
+  xAODJets_(const HypoJetVector::const_iterator begin,
+	    const HypoJetVector::const_iterator end
+	    )  const;
+    
 };
 
 #endif
diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypoUnitTests/CMakeLists.txt b/Trigger/TrigHypothesis/TrigHLTJetHypoUnitTests/CMakeLists.txt
index b04652d5be4fbc4753af892140a9c4790a2f7751..4b33b0daaaf3659e0275769404c7680e105938d1 100644
--- a/Trigger/TrigHypothesis/TrigHLTJetHypoUnitTests/CMakeLists.txt
+++ b/Trigger/TrigHypothesis/TrigHLTJetHypoUnitTests/CMakeLists.txt
@@ -33,15 +33,9 @@ atlas_add_test( TrigHLTJetHypoUnitTests
    tests/FlowNetworkTest.cxx
    tests/LlpCleanerTest.cxx
    tests/LooseCleanerTest.cxx
-   tests/MaximumBipartiteGroupsMatcherTest.cxx
-   tests/MaximumBipartiteGroupsMatcherMTTest.cxx
-   tests/MaximumBipartiteGroupsMatcherMTTest_Multijet.cxx
-   tests/PartitionsGenTest.cxx
-   tests/PartitionsGroupsMatcherMTTest.cxx
    tests/TLorentzVectorFactoryTest.cxx
    tests/TightCleanerTest.cxx
    tests/xAODJetCollectorTest.cxx
-   tests/PartitionsGrouperTest.cxx
    INCLUDE_DIRS ${ROOT_INCLUDE_DIRS} ${GMOCK_INCLUDE_DIRS}
    LINK_LIBRARIES ${ROOT_LIBRARIES} GoogleTestTools ${GMOCK_LIBRARIES} TrigHLTJetHypoLib TrigHLTJetHypoUnitTestsLib )
    
diff --git a/Trigger/TrigHypothesis/TrigTauHypo/CMakeLists.txt b/Trigger/TrigHypothesis/TrigTauHypo/CMakeLists.txt
index 1f70c5acf6882e11d272a4c471eaa41dbf398038..670ac60d751a6d8f2fd6ba5145d59834df4eca31 100644
--- a/Trigger/TrigHypothesis/TrigTauHypo/CMakeLists.txt
+++ b/Trigger/TrigHypothesis/TrigTauHypo/CMakeLists.txt
@@ -10,7 +10,7 @@ find_package( ROOT COMPONENTS Core MathCore Hist )
 atlas_add_component( TrigTauHypo
                      src/*.cxx src/components/*.cxx
                      INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
-                     LINK_LIBRARIES ${ROOT_LIBRARIES} AthContainers AthViews AthenaBaseComps AthenaMonitoringKernelLib CaloEvent CxxUtils DecisionHandlingLib EventInfo GaudiKernel ITrackToVertex MuidEvent Particle PathResolver StoreGateLib TrigCaloEvent TrigCompositeUtilsLib TrigInDetEvent TrigInterfacesLib TrigMuonEvent TrigNavStructure TrigParticle TrigSteeringEvent TrigTopoEvent TrkTrack TrkTrackSummary VxVertex egammaEvent tauEvent xAODBase xAODCaloEvent xAODEgamma xAODJet xAODMuon xAODTau xAODTracking xAODTrigger )
+                     LINK_LIBRARIES ${ROOT_LIBRARIES} AthContainers AthViews AthenaBaseComps AthenaMonitoringKernelLib CaloEvent CxxUtils DecisionHandlingLib EventInfo GaudiKernel ITrackToVertex MuidEvent Particle PathResolver StoreGateLib TrigCaloEvent TrigCompositeUtilsLib TrigInDetEvent TrigInterfacesLib TrigMuonEvent TrigNavStructure TrigParticle TrigSteeringEvent TrigTopoEvent TrkTrack TrkTrackSummary VxVertex egammaEvent tauEvent xAODBase xAODCaloEvent xAODEgamma xAODJet xAODMuon xAODTau xAODTracking xAODTrigger MVAUtils tauRecToolsLib)
 
 # Install files from the package:
 atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} --extend-extensions=ATL900,ATL901 )
diff --git a/Trigger/TrigHypothesis/TrigTauHypo/src/TrigTauTrackRoiUpdaterMT.cxx b/Trigger/TrigHypothesis/TrigTauHypo/src/TrigTauTrackRoiUpdaterMT.cxx
index 47abcaaaef0c1116a7e7f1144f48082764f664af..8881a4e261c6f8b00ea0c1aa1c33a674910928d2 100644
--- a/Trigger/TrigHypothesis/TrigTauHypo/src/TrigTauTrackRoiUpdaterMT.cxx
+++ b/Trigger/TrigHypothesis/TrigTauHypo/src/TrigTauTrackRoiUpdaterMT.cxx
@@ -19,6 +19,8 @@
 #include "TrkTrackSummary/TrackSummary.h"
 #include "xAODTrigger/TrigPassBits.h"
 
+#include "PathResolver/PathResolver.h"
+#include "tauRecTools/HelperFunctions.h"
 
 TrigTauTrackRoiUpdaterMT::TrigTauTrackRoiUpdaterMT(const std::string & name, ISvcLocator* pSvcLocator) :
   AthReentrantAlgorithm(name, pSvcLocator)
@@ -41,13 +43,22 @@ StatusCode TrigTauTrackRoiUpdaterMT::initialize()
   ATH_MSG_DEBUG( " nSiHoles            		" 	<< m_nSiHoles );
   ATH_MSG_DEBUG( " UpdateEta            		" 	<< m_updateEta );
   ATH_MSG_DEBUG( " UpdatePhi            		" 	<< m_updatePhi );
+  ATH_MSG_DEBUG(  " useBDT               		" 	<< m_useBDT );
 
+  if(m_useBDT) {
+    ATH_MSG_DEBUG( " BDTweights     	        	" << m_BDTweights );
+
+    std::string inputWeightsPath = PathResolverFindCalibFile(m_BDTweights);
+    ATH_MSG_INFO(" InputWeightsPath: " << inputWeightsPath);
+    m_reader = std::make_unique<tauRecTools::BDTHelper>();
+    ATH_CHECK(m_reader->initialize(inputWeightsPath));
+  }
 
   ATH_MSG_DEBUG( "Initialising HandleKeys" );
   CHECK( m_roIInputKey.initialize()        );
-  CHECK( m_tracksKey.initialize() );
-  CHECK( m_roIOutputKey.initialize()  );
-
+  CHECK( m_tracksKey.initialize()          );
+  CHECK( m_roIOutputKey.initialize()       );
+  CHECK( m_tauJetKey.initialize(!m_tauJetKey.key().empty()));
   return StatusCode::SUCCESS;
 
 }
@@ -100,38 +111,67 @@ StatusCode TrigTauTrackRoiUpdaterMT::execute(const EventContext& ctx) const
   double trkPtMax = 0;
   
   if(foundTracks!=0){
-    
+
+    //Find the track with the highest BDT score
+    if(m_useBDT) {
+      
+      // retrieve TauJet from TrigTauRecCaloOnlyMVASequence
+      SG::ReadHandle< xAOD::TauJetContainer > tauJetHandle = SG::makeHandle( m_tauJetKey,ctx );
+      const xAOD::TauJetContainer *foundTaus = tauJetHandle.get();
+
+      if (foundTaus->size()==0) {
+	      ATH_MSG_ERROR( "No TauJetContainer feature was found." );
+      }
+
+      const Trk::Track *leadTrackBDT = nullptr;
+      for(const Trk::Track* trk_it : *foundTracks)
+        if(trk_it->perigeeParameters()->pT() > trkPtMax) {
+          trkPtMax = trk_it->perigeeParameters()->pT();
+          leadTrackBDT = trk_it;
+        }
+      double trkBDTMax = 0.;
+
+      for(const Trk::Track* trk_it : *foundTracks) {
+        double BDTscore = getBDTscore( foundTaus->at(0), trk_it, leadTrackBDT );
+
+        if(BDTscore > trkBDTMax) {
+          trkBDTMax = BDTscore;
+          leadTrack = trk_it;
+        }
+      }
+    }
     // Find leading track
-    for (const Trk::Track* track : *foundTracks){
-      trackPer = track->perigeeParameters();
-      summary = track->trackSummary();
-      if(summary==nullptr) ATH_MSG_ERROR(" track summary not available in RoI updater " << trkPtMax << " " << name() );
-      if(trackPer && summary){
- 	     float trackPt = trackPer->pT();
-	     if ( trackPt > trkPtMax ) {
-	       int nPix  = summary->get(Trk::numberOfPixelHits);
-	       if(nPix<0) nPix=0;
-	       if(nPix < m_nHitPix) {
-            if(msgLvl(MSG::DEBUG))  msg() << MSG::DEBUG <<" Track rejected because of nHitPix " << nPix << " < " << m_nHitPix
-            << " " << name() << ": in execute()" << endmsg;
-	         continue;
-	       }
-	       int nPixHole = summary->get(Trk::numberOfPixelHoles);
-	       if (nPixHole < 0) nPixHole = 0;
-	       int nSCTHole = summary->get(Trk::numberOfSCTHoles);
-	       if (nSCTHole < 0) nSCTHole = 0;
-	       if((nPixHole + nSCTHole) > m_nSiHoles) {
-            if(msgLvl(MSG::DEBUG) )  msg() << MSG::DEBUG <<" Track rejected because of nSiHoles " << nPixHole+nSCTHole << " > " << m_nSiHoles 
-            << " " << name() << ": in execute()" << endmsg;
-	         continue;
-	       }
-	       leadTrack = track;
-	       trkPtMax = trackPt;
-	     }
+    else{
+      for (const Trk::Track* track : *foundTracks){
+        trackPer = track->perigeeParameters();
+        summary = track->trackSummary();
+        if(summary==nullptr) ATH_MSG_ERROR(" track summary not available in RoI updater " << trkPtMax << " " << name() );
+        if(trackPer && summary){
+        float trackPt = trackPer->pT();
+        if ( trackPt > trkPtMax ) {
+          int nPix  = summary->get(Trk::numberOfPixelHits);
+          if(nPix<0) nPix=0;
+          if(nPix < m_nHitPix) {
+              if(msgLvl(MSG::DEBUG))  msg() << MSG::DEBUG <<" Track rejected because of nHitPix " << nPix << " < " << m_nHitPix
+              << " " << name() << ": in execute()" << endmsg;
+            continue;
+          }
+          int nPixHole = summary->get(Trk::numberOfPixelHoles);
+          if (nPixHole < 0) nPixHole = 0;
+          int nSCTHole = summary->get(Trk::numberOfSCTHoles);
+          if (nSCTHole < 0) nSCTHole = 0;
+          if((nPixHole + nSCTHole) > m_nSiHoles) {
+              if(msgLvl(MSG::DEBUG) )  msg() << MSG::DEBUG <<" Track rejected because of nSiHoles " << nPixHole+nSCTHole << " > " << m_nSiHoles 
+              << " " << name() << ": in execute()" << endmsg;
+            continue;
+          }
+          leadTrack = track;
+          trkPtMax = trackPt;
+        }
+        }
       }
     }
-
-
+    
     if(leadTrack) {
       ATH_MSG_DEBUG(" leading track pT " << trkPtMax );
       leadTrkZ0  = leadTrack->perigeeParameters()->parameters()[Trk::z0];
@@ -191,3 +231,67 @@ StatusCode TrigTauTrackRoiUpdaterMT::execute(const EventContext& ctx) const
   return StatusCode::SUCCESS;
 
 }
+
+double TrigTauTrackRoiUpdaterMT::getBDTscore(const xAOD::TauJet* tau, const Trk::Track* track, const Trk::Track* leadtrack ) const
+{
+
+  std::map<TString, float*> BDTvars;
+  BDTInputVariables vars;
+    
+  BDTvars = {
+    {"log(Coretrack_pt)", &vars.logtrk_pt}, 
+    {"fabs(Coretrack_z0)", &vars.abstrck_z0},
+    {"fabs(Coretrack_d0)", &vars.abstrk_d0},
+    {"Coretrack_nPiHits", &vars.trk_nPiHits},
+    {"Coretrack_nSiHoles", &vars.trk_nSiHoles},
+    {"log(Coretrack_ratioptCalo)", &vars.logtrk_ratiopt},
+    {"Coretrack_dR", &vars.trk_dR},
+    {"Coretrack_dRleadtrk", &vars.trk_dRtoleadtrk},
+    {"Coretrack_CaloHadpt", &vars.CaloHad_pt},
+    {"Coretrack_CaloEMpt", &vars.CaloEM_pt}
+  };
+
+  const Trk::Perigee* trkPerigee = track->perigeeParameters();
+  const Trk::TrackSummary* trkSummary = track->trackSummary();
+
+  int nPixHit = trkSummary->get(Trk::numberOfPixelHits);
+  int nPixDead = trkSummary->get(Trk::numberOfPixelDeadSensors);
+
+  int nPixHole = trkSummary->get(Trk::numberOfPixelHoles);
+  int nSCTHole = trkSummary->get(Trk::numberOfSCTHoles);
+
+  float ratio_pt = tau->ptTrigCaloOnly() ? trkPerigee->pT()/tau->ptTrigCaloOnly() : 0.;
+
+  float dEta = tau->eta() - trkPerigee->eta();
+  float dPhi = CxxUtils::wrapToPi(tau->phi() - trkPerigee->parameters()[Trk::phi0]);
+  float dR = sqrt(dEta*dEta + dPhi*dPhi);
+
+  const Trk::Perigee* leadtrkPerigee = leadtrack->perigeeParameters();
+  float dEta_leadtrk = trkPerigee->eta() - leadtrkPerigee->eta();
+  float dPhi_leadtrk = CxxUtils::wrapToPi(trkPerigee->parameters()[Trk::phi0] - leadtrkPerigee->parameters()[Trk::phi0]);
+  float dR_leadtrk = sqrt(dEta_leadtrk*dEta_leadtrk + dPhi_leadtrk*dPhi_leadtrk);
+
+  float tau_emscale_ptEM = 0;
+  float tau_emscale_ptHad = 0;
+  if ( !tau->detail( xAOD::TauJetParameters::etEMAtEMScale, tau_emscale_ptEM ) ) {
+    ATH_MSG_WARNING("Retrieval of tau etEMAtEMScale detail failed.");
+  }
+  if ( !tau->detail( xAOD::TauJetParameters::etHadAtEMScale, tau_emscale_ptHad ) ) {
+    ATH_MSG_WARNING("Retrieval of tau etHadAtEMScale detail failed.");
+  }
+
+  vars.logtrk_pt = log( trkPerigee->pT() );
+  vars.abstrck_z0 = std::abs( trkPerigee->parameters()[Trk::z0] );
+  vars.abstrk_d0 = std::abs( trkPerigee->parameters()[Trk::d0] );
+  vars.trk_nPiHits = nPixHit + nPixDead;
+  vars.trk_nSiHoles = nPixHole + nSCTHole;
+  vars.logtrk_ratiopt = log( ratio_pt );
+  vars.trk_dR = dR;
+  vars.trk_dRtoleadtrk = dR_leadtrk;
+  vars.CaloHad_pt = tau_emscale_ptHad;
+  vars.CaloEM_pt = tau_emscale_ptEM;
+
+  double BDTval = m_reader->getResponse(BDTvars);
+
+  return BDTval;
+}
diff --git a/Trigger/TrigHypothesis/TrigTauHypo/src/TrigTauTrackRoiUpdaterMT.h b/Trigger/TrigHypothesis/TrigTauHypo/src/TrigTauTrackRoiUpdaterMT.h
index 548677aa721df2e1232a8fb11ba4962d97ed46e9..90ba646fdce9cd00b52ea7c707af99fc4d6b75d1 100644
--- a/Trigger/TrigHypothesis/TrigTauHypo/src/TrigTauTrackRoiUpdaterMT.h
+++ b/Trigger/TrigHypothesis/TrigTauHypo/src/TrigTauTrackRoiUpdaterMT.h
@@ -14,6 +14,10 @@
 
 #include "TrigSteeringEvent/TrigRoiDescriptor.h"
 
+#include "MVAUtils/BDT.h"
+#include "xAODTau/TauJetContainer.h"
+#include "tauRecTools/BDTHelper.h"
+
 class TrigTauTrackRoiUpdaterMT : public AthReentrantAlgorithm {
 
  public:
@@ -30,10 +34,33 @@ class TrigTauTrackRoiUpdaterMT : public AthReentrantAlgorithm {
   Gaudi::Property< int > m_nSiHoles {this,"nSiHoles",2,"maximum number of Si holes on lead track"};
   Gaudi::Property< bool > m_updateEta {this,"updateEta",true,"flag to determine whether Roi eta should be updated using the track direction (true by default)"};
   Gaudi::Property< bool > m_updatePhi {this,"updatePhi",false,"flag to determine whether Roi phi should be updated using the track direction (false by default)"};
+  Gaudi::Property< bool > m_useBDT {this,"useBDT",false,"flag to determine whether the 1st stage of the FTF chooses the track with the highest BDT score"};
+  Gaudi::Property< std::string > m_BDTweights {this,"BDTweights","TrigTauRec/00-11-02/FTF_tauCore_BDT_v0.root","String with the path to the BDT file"};
+
+  //std::unique_ptr<MVAUtils::BDT> m_reader; //!
+  std::unique_ptr<tauRecTools::BDTHelper> m_reader;
+
+  struct BDTInputVariables
+  {
+    float logtrk_pt{0.0}; //!
+    float abstrck_z0{0.0}; //!
+    float abstrk_d0{0.0}; //!
+    float trk_nPiHits{0.0}; //!
+    float trk_nSiHoles{0.0}; //!
+    float logtrk_ratiopt{0.0}; //!
+    float trk_dR{0.0}; //!
+    float trk_dRtoleadtrk{0.0}; //!
+    float CaloHad_pt{0.0}; //!
+    float CaloEM_pt{0.0}; //!
+
+  };
 
   SG::ReadHandleKey< TrigRoiDescriptorCollection > m_roIInputKey {this,"RoIInputKey","InputRoI","Input RoI key name"};
   SG::ReadHandleKey< TrackCollection > m_tracksKey { this, "fastTracksKey", "fasttracks", "fast tracks in view" };
   SG::WriteHandleKey< TrigRoiDescriptorCollection > m_roIOutputKey {this,"RoIOutputKey","InViewRoI","Output RoI Collection Key"};
 
+  SG::ReadHandleKey< xAOD::TauJetContainer> m_tauJetKey      { this, "Key_trigTauJetInputContainer", "HLT_taujet", "input taujet container" };
+  double getBDTscore(const xAOD::TauJet* tau, const Trk::Track* track, const Trk::Track* leadtrack ) const;
+
 };
 #endif
diff --git a/Trigger/TrigMonitoring/TrigCostMonitor/python/TrigCostMonitorConfig.py b/Trigger/TrigMonitoring/TrigCostMonitor/python/TrigCostMonitorConfig.py
index 73fcf5b21c6c7b5e82343a9ac56b44135ae1eab8..0b68f913321e58fb59069f212b566be83072e058 100644
--- a/Trigger/TrigMonitoring/TrigCostMonitor/python/TrigCostMonitorConfig.py
+++ b/Trigger/TrigMonitoring/TrigCostMonitor/python/TrigCostMonitorConfig.py
@@ -444,12 +444,7 @@ def setupCostJob(config = 'OPI ROB NOPS'):
         from TriggerJobOpts.TriggerFlags import TriggerFlags
         if TriggerFlags.doHLT():
             configSteeringOPI(topSeq, 'TrigSteer_HLT', config, log)
-        else: 
-            if TriggerFlags.doEF():
-                configSteeringOPI(topSeq, 'TrigSteer_EF', config, log)
-            if TriggerFlags.doLVL2():
-                configSteeringOPI(topSeq, 'TrigSteer_L2', config, log)
-        
+
     if config.count('ROB'):
         log.info('Will try to configure online monitoring for ROBDataProviderSvc...')
         from AthenaCommon.AppMgr import ServiceMgr as svcMgr
diff --git a/Trigger/TrigMonitoring/TrigCostMonitor/share/RunTrigCost.py b/Trigger/TrigMonitoring/TrigCostMonitor/share/RunTrigCost.py
index d9bbb1f4f1cc0600edf52729ad803b189c49a6d0..f6d530f4a9f9536c9142d5b97f3105fceb0ac78a 100644
--- a/Trigger/TrigMonitoring/TrigCostMonitor/share/RunTrigCost.py
+++ b/Trigger/TrigMonitoring/TrigCostMonitor/share/RunTrigCost.py
@@ -51,13 +51,11 @@ TriggerFlags.readHLTconfigFromXML=False
 TriggerFlags.inputLVL1configFile=''
 TriggerFlags.inputHLTconfigFile=''
 TriggerFlags.doLVL1=True
-TriggerFlags.doLVL2=True
-TriggerFlags.doEF=True
+TriggerFlags.doHLT=True
 TriggerFlags.L1PrescaleSet  = 'L1Prescales100_' +TriggerFlags.triggerMenuSetup()
 TriggerFlags.HLTPrescaleSet = 'HLTPrescales100_'+TriggerFlags.triggerMenuSetup()
 TriggerFlags.configurationSourceList=['xml']
 TriggerFlags.enableMonitoring = [ 'Time', 'CostAthena' ]
-TriggerFlags.disableRandomPrescale=False
 
 if setMenu.count('simpleL1Calib') or setMenu.count('InitialBeam') or setMenu.count('Cosmic'):
     TriggerFlags.useL1CaloCalibration=False
diff --git a/Trigger/TrigMonitoring/TrigCostMonitor/share/readDataRate.py b/Trigger/TrigMonitoring/TrigCostMonitor/share/readDataRate.py
index 504f3c2fa6fcdc0e2260d8eea68115b138b96c9f..c05ac507f13db73901c1c8603a95b6777c28d84f 100644
--- a/Trigger/TrigMonitoring/TrigCostMonitor/share/readDataRate.py
+++ b/Trigger/TrigMonitoring/TrigCostMonitor/share/readDataRate.py
@@ -17,8 +17,7 @@ globalflags.DataSource  = 'data'
 from TriggerJobOpts.TriggerFlags import TriggerFlags
 TriggerFlags.readBS = True
 TriggerFlags.doLVL1 = False
-TriggerFlags.doLVL2 = False
-TriggerFlags.doEF   = False
+TriggerFlags.doHLT   = False
 
 #----------------------------------------------------------------------
 # Set services for reading BS files
diff --git a/Trigger/TrigMonitoring/TrigTauMonitoring/python/TrigTauMonitCategory.py b/Trigger/TrigMonitoring/TrigTauMonitoring/python/TrigTauMonitCategory.py
index 238d43b46d9dfd1d7c09d3753686da6463e7e379..3ae80989970dd98f776e82a9829d0cdd2357741e 100644
--- a/Trigger/TrigMonitoring/TrigTauMonitoring/python/TrigTauMonitCategory.py
+++ b/Trigger/TrigMonitoring/TrigTauMonitoring/python/TrigTauMonitCategory.py
@@ -53,6 +53,9 @@ monitoring_tau_pp = [
     'tau160_medium1_tracktwoEF_L1TAU100',
     'tau200_medium1_tracktwoEF_L1TAU100',
     'tau200_mediumRNN_tracktwoMVA_L1TAU100',
+    'tau160_perf_tracktwoMVABDT_L1TAU100',
+    'tau160_idperf_tracktwoMVABDT_L1TAU100',
+    'tau160_mediumRNN_tracktwoMVABDT_L1TAU100',
     # Will keep this commented out for now
     #'tau80_mediumRNN_tracktwoMVA_tau60_mediumRNN_tracktwoMVA_L1TAU60_2TAU40',
     #'tau80_mediumRNN_tracktwoMVA_tau35_mediumRNN_tracktwoMVA_L1TAU60_DR-TAU20ITAU12I',
@@ -98,6 +101,9 @@ monitoring_tau_validation = [
         'tau25_looseRNN_tracktwoMVABDT_L1TAU12IM',
         'tau25_mediumRNN_tracktwoMVABDT_L1TAU12IM',
         'tau25_tightRNN_tracktwoMVABDT_L1TAU12IM',
+        'tau160_perf_tracktwoMVABDT_L1TAU100',
+        'tau160_idperf_tracktwoMVABDT_L1TAU100',
+        'tau160_mediumRNN_tracktwoMVABDT_L1TAU100',
 ]
 
 monitoring_tau_cosmic = [
diff --git a/Trigger/TrigMonitoring/TrigTauMonitoring/python/TrigTauMonitoringConfigMT.py b/Trigger/TrigMonitoring/TrigTauMonitoring/python/TrigTauMonitoringConfigMT.py
index ff7c9d506a9ad0ecba001d69ae1f315c2023e9a1..32ff494856ae9e418a517db4b9d413abc6695ab4 100644
--- a/Trigger/TrigMonitoring/TrigTauMonitoring/python/TrigTauMonitoringConfigMT.py
+++ b/Trigger/TrigMonitoring/TrigTauMonitoring/python/TrigTauMonitoringConfigMT.py
@@ -162,6 +162,9 @@ class TrigTauMonAlgBuilder:
     'HLT_tau160_mediumRNN_tracktwoMVA_L1TAU100',
     'HLT_tau160_medium1_tracktwo_L1TAU100',
     'HLT_tau160_medium1_tracktwoEF_L1TAU100',
+    'HLT_tau160_perf_tracktwoMVABDT_L1TAU100',
+    'HLT_tau160_idperf_tracktwoMVABDT_L1TAU100',
+    'HLT_tau160_mediumRNN_tracktwoMVABDT_L1TAU100',
     'HLT_tau200_medium1_tracktwoEF_L1TAU100',
     'HLT_tau200_mediumRNN_tracktwoMVA_L1TAU100',
     'HLT_tau80_mediumRNN_tracktwoMVA_tau60_mediumRNN_tracktwoMVA_L1TAU60_2TAU40',
@@ -216,6 +219,11 @@ class TrigTauMonAlgBuilder:
         self.bookbasicVars( monAlg, trigger, online=False )
         self.bookHLTEffHistograms( monAlg, trigger,nProng='1P')
         self.bookHLTEffHistograms( monAlg, trigger,nProng='MP')
+      else:
+        self.bookBDTOut( monAlg, trigger, nProng='1P')
+        self.bookBDTOut( monAlg, trigger, nProng='MP')
+        self.bookBDTNoCorr( monAlg, trigger, nProng='1P')
+        self.bookBDTNoCorr( monAlg, trigger, nProng='MP')
 
     #remove duplicated from L1 seed list
     l1seeds = list(dict.fromkeys(l1seeds))
@@ -345,7 +353,6 @@ class TrigTauMonAlgBuilder:
     monGroup.defineHistogram('hEFEta;hEFPhi', type='TH2F', title='EF TrigCaloCluster Eta vs Phi; #eta ; #phi',
                                path=monGroupPath,
                                xbins=26,xmin=-2.6,xmax=2.6,ybins=16,ymin=-3.2,ymax=3.2)
-    #addHistogram(new TH2F("hEFEtaVsPhi","EF TrigCaloCluster Eta vs Phi; #eta ; #phi ; Nevents",26,-2.6,2.6,16,-3.2,3.2));
     monGroup.defineHistogram('hEFEt;hEFPhi', type='TH2F', title='Et from tau Jet vs #phi; #phi^{EF}; Raw E_{T} [GeV]',
                                path=monGroupPath,
                                xbins=16,xmin=-3.2,xmax=3.2,ybins=50,ymin=0,ymax=100)
@@ -357,5 +364,42 @@ class TrigTauMonAlgBuilder:
     monGroup.defineHistogram('hEFEtRaw', title='EF Et Raw;Uncalibrated E_{T}[GeV];Nevents',xbins=50,xmin=0,xmax=100)
     monGroup.defineHistogram('hEFnWideTrack', title='EF number of wide tracks;number of tracks;Nevents',xbins=10,xmin=0,xmax=10)
 
-    #monGroup.defineHistogram('hEFIsoFrac', title='Iso Fraction at EF; isoFrac at EF; Candidates',xbins=50,xmin=-0.1,xmax=1.1)
-    #monGroup.defineHistogram('hEFEMFraction', title='Em Fraction at EF; EM Fraction at EF; Candidates',xbins=50,xmin=-0.05,xmax=1.1)
+  #                                                                                                                                                                                                                                   
+  # Book BDT Variables                                                                                                                                                                                                                
+  #                                                  
+  def bookBDTOut( self, monAlg, trigger, nProng):
+
+    monGroupName = trigger+'_BDT_HLT_Out_'+nProng
+    monGroupPath = 'BDT/Out_'+nProng+'/'+trigger
+    monGroup = self.helper.addGroup( monAlg, monGroupName,
+                              self.basePath+'/'+monGroupPath )
+
+    print('MonGroup name is python: ', monGroupName)
+
+    monGroup.defineHistogram('BDTJetScore', title='BDT Score ('+nProng+') ; HLT BDT Score; Candidates',xbins=50,xmin=0,xmax=1)
+    monGroup.defineHistogram('BDTJetScoreSigTrans', title='Flattened BDT Score ('+nProng+') ; HLT BDT Score; Candidates',xbins=50,xmin=0,xmax=1)
+
+
+  def bookBDTNoCorr( self, monAlg, trigger, nProng ):
+
+    monGroupName = trigger+'_BDT_HLT_NoCorr_'+nProng
+    monGroupPath = 'BDT/NoCorr_'+nProng+'/'+trigger
+    monGroup = self.helper.addGroup( monAlg, monGroupName,
+                              self.basePath+'/'+monGroupPath )
+
+    monGroup.defineHistogram('CentFrac', title='Centrality Fraction ('+nProng+') non-corrected; centFrac; Candidates',xbins=50,xmin=-0.05,xmax=1.2)
+    monGroup.defineHistogram('ChPiEMEOverCaloEME', title='ChPiEMEOverCaloEME ('+nProng+') non-corrected; ChPiEMEOverCaloEME; Candidates',xbins=51,xmin=-20,xmax=20)
+    monGroup.defineHistogram('EMPOverTrkSys', title='EMPOverTrkSys ('+nProng+') non-corrected; EMPOverTrkSys; Candidates',xbins=41,xmin=0,xmax=40)
+    monGroup.defineHistogram('etOverPtLeadTrk', title='etOverPtLeadTrk ('+nProng+') non-corrected; etOverPtLeadTrk; Candidates',xbins=51,xmin=-0.1,xmax=25)
+    monGroup.defineHistogram('innerTrkAvgDist', title='innerTrkAvgDist ('+nProng+') non-corrected; innerTrkAvgDist; Candidates',xbins=50,xmin=-0.05,xmax=0.5)
+    monGroup.defineHistogram('ptRatioEflowApprox', title='ptRatioEflowApprox ('+nProng+') non-corrected; ptRatioEflowApprox; Candidates',xbins=50,xmin=0,xmax=2)
+    monGroup.defineHistogram('massTrkSys', title='massTrkSys log ('+nProng+'); massTrkSys_log; Events',xbins=50,xmin=0.,xmax=3.)
+
+    if nProng=='1P':
+      monGroup.defineHistogram('SumPtTrkFrac', title='SumPtTrkFrac ('+nProng+') non-corrected; SumPtTrkFrac; Candidates',xbins=50,xmin=-0.5,xmax=1.1)
+
+    if nProng=='MP':
+      monGroup.defineHistogram('dRmax', title='dRmax ('+nProng+') non-corrected; dRmax; Candidates',xbins=50,xmin=-0.1,xmax=0.3)
+      monGroup.defineHistogram('massTrkSys', title='massTrkSys ('+nProng+') non-corrected; massTrkSys; Candidates',xbins=50,xmin=-0.1,xmax=15)
+      monGroup.defineHistogram('mEflowApprox', title='mEflowApprox ('+nProng+') non-corrected; mEflowApprox; Candidates',xbins=61,xmin=-0.2,xmax=60.2)
+      monGroup.defineHistogram('trFlightPathSig', title='trFlightPathSig ('+nProng+') non-corrected; trFlightPathSig; Candidates',xbins=50,xmin=-20,xmax=20)
diff --git a/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool.cxx b/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool.cxx
index 25ef5578cefaaaeb601e60cf3ef15896a089269e..a0fed546a8c4d174fd7ec69491a0a7c8e76417c3 100644
--- a/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool.cxx
+++ b/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool.cxx
@@ -388,7 +388,6 @@ StatusCode HLTTauMonTool::fill() {
 
     // good reco taus
   //m_taus.clear();
-  m_taus_BDT.clear();
   m_taus_RNN.clear();
   m_tauCont = 0;
   sc = evtStore()->retrieve(m_tauCont, "TauJets");
@@ -408,12 +407,14 @@ StatusCode HLTTauMonTool::fill() {
         if(pt_Tau<m_effOffTauPtCut) continue;
         int ntrack_TAU = (*offlinetau)->nTracks();
         if(ntrack_TAU!=1 && ntrack_TAU!=3) continue;
-        bool good_tau_BDT = (*offlinetau)->isTau(xAOD::TauJetParameters::JetBDTSigMedium);
         bool good_tau_RNN = (*offlinetau)->isTau(xAOD::TauJetParameters::JetRNNSigMedium);
         if(!Selection(*offlinetau)) continue;
-        if( !(good_tau_BDT || good_tau_RNN) ) continue;
-        if (good_tau_BDT) m_taus_BDT.push_back( *offlinetau );
-        if (good_tau_RNN) m_taus_RNN.push_back( *offlinetau );
+        if( !(good_tau_RNN) ) {    
+            continue;
+        }
+        else {  
+            m_taus_RNN.push_back( *offlinetau );
+        }
       }
     }
   } //end if_else !sc.isSuccess() 
@@ -438,51 +439,53 @@ StatusCode HLTTauMonTool::fill() {
     //testL1TopoNavigation(m_trigItems[j]);
     //testPrescaleRetrieval(m_trigItems[j]);
 
-                        bool monRNN (false);
-                        for (unsigned int i=0; i<m_trigRNN_chains.size(); i++) {
-                                if ( m_trigItems[j] == m_trigRNN_chains.at(i) ) {
-                                  monRNN = true;
-                                  break;
-                                }
-                        }
-                        bool monBDT (false);
-                        for (unsigned int i=0; i<m_trigBDTRNN_chains.size(); i++) {
-                                if ( m_trigItems[j] == m_trigBDTRNN_chains.at(i) ) {
-                                  if (!monRNN) monRNN = true;
-                                  if (!monBDT) monBDT = true;
-                                  break;
-                                }
-                        } 
-                        if ( (!monBDT) && (!monRNN) ) monBDT=true; // if the chain is not listed in BDTRNN, but it is also not in RNN, then it is BDT 
+   bool monRNN (false);
+   for (unsigned int i=0; i<m_trigRNN_chains.size(); i++) {
+       if ( m_trigItems[j] == m_trigRNN_chains.at(i) ) {
+           monRNN = true;
+           break;
+       }
+   }
+                        
+   bool monBDT (false);
+   for (unsigned int i=0; i<m_trigBDTRNN_chains.size(); i++) {
+       if ( m_trigItems[j] == m_trigBDTRNN_chains.at(i) ) {
+           if (!monRNN) monRNN = true;
+           if (!monBDT) monBDT = true;
+           break;
+       }
+   } 
+                        
+   if ( (!monBDT) && (!monRNN) ) monBDT=true; // if the chain is not listed in BDTRNN, but it is also not in RNN, then it is BDT 
         
-                        std::string goodTauRefType;
-                        if (monRNN) {
-                                goodTauRefType = "RNN";
-                        } else {
-                                goodTauRefType = "BDT";
-                        }
+   std::string goodTauRefType;
+   if (monRNN) {
+       goodTauRefType = "RNN";
+   } else {
+       goodTauRefType = "BDT";
+   }
 
-      // muCut on Filling the Histograms
-      if (m_muCut40Passed)
-        {
-	  sc = fillHistogramsForItem(m_trigItems[j], monRNN, monBDT, goodTauRefType);
-    if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed at fillHistogramsForItem"); } //return sc;}  
-    if(m_doTrackCurves){
+   // muCut on Filling the Histograms
+   if (m_muCut40Passed)
+   {
+        sc = fillHistogramsForItem(m_trigItems[j], monRNN, monBDT);
+        if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed at fillHistogramsForItem"); } //return sc;}  
+        if(m_doTrackCurves){
             sc = trackCurves (m_trigItems[j], goodTauRefType);
             if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed trackCurves()"); } //return sc;}
-          }
+        }
     // if(m_doEfficiencyRatioPlots){
     //      sc = efficiencyRatioPlots (m_trigItems[j], goodTauRefType);
     //      if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed efficiencyRatioPlots()"); } //return sc;}
     //    }
-        }
-      else
-        {
-          ATH_MSG_WARNING("Pileup Cut 40 was not passed. Skipped: HistogramsForItem"); 
-        } 
+   }
+   else
+   {
+        ATH_MSG_WARNING("Pileup Cut 40 was not passed. Skipped: HistogramsForItem"); 
+   } 
 
 
-    }
+  }
 
   // do L1TopoLeptons
   for(unsigned int i=0;i<m_topo_chains.size(); ++i){
@@ -634,7 +637,7 @@ void HLTTauMonTool::cloneHistogram2(const std::string name, const std::string fo
 }
 
 
-StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, const bool & monRNN, const bool & monBDT, const std::string & goodTauRefType){
+StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, const bool & monRNN, const bool & monBDT){
     
   ATH_MSG_DEBUG ("HLTTauMonTool::fillHistogramsForItem " << trigItem);
     
@@ -679,7 +682,7 @@ StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, co
       ATH_CHECK(fillL1Tau(*itEMTau)); 
       setCurrentMonGroup("HLT/TauMon/Expert/"+trigItemShort+"/L1VsOffline");
       ATH_MSG_DEBUG("Check if L1VsOffline group exists");
-      ATH_CHECK(fillL1TauVsOffline(*itEMTau, goodTauRefType));
+      ATH_CHECK(fillL1TauVsOffline(*itEMTau));
     }
     const xAOD::TauJetContainer * tauJetCont = 0;
     StatusCode sc = evtStore()->retrieve(tauJetCont, "HLT_xAOD__TauJetContainer_TrigTauRecMerged");
@@ -712,10 +715,10 @@ StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, co
         sc = fillEFTau(*CI, trigItem, "RNN_out", monRNN, monBDT);
         if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed to Fill RNN input and output histograms for fillEFTau(). Exiting!"); return sc;}
       }
-      sc = fillEFTauVsOffline(*CI, trigItem, "basicVars", goodTauRefType);
+      sc = fillEFTauVsOffline(*CI, trigItem, "basicVars");
       if (monBDT) {
-        sc = fillEFTauVsOffline(*CI, trigItem, "1p_NonCorr", goodTauRefType);
-        sc = fillEFTauVsOffline(*CI, trigItem, "mp_NonCorr", goodTauRefType);
+        sc = fillEFTauVsOffline(*CI, trigItem, "1p_NonCorr");
+        sc = fillEFTauVsOffline(*CI, trigItem, "mp_NonCorr");
       }
       if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed to Fill histograms for fillEFTauVsOffline(). Exiting!"); return sc;}
     }
@@ -787,7 +790,7 @@ StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, co
                     return sc;
                   }
                   setCurrentMonGroup("HLT/TauMon/Expert/"+trigItem+"/L1VsOffline");
-                  sc = fillL1TauVsOffline(*itEMTau, goodTauRefType);
+                  sc = fillL1TauVsOffline(*itEMTau);
                   if(!sc.isSuccess()){ 
                     ATH_MSG_WARNING("Failed to fill L1VsOffline histo. Exiting!"); 
                     return sc;
@@ -849,7 +852,7 @@ StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, co
                 return sc;
               }
               setCurrentMonGroup("HLT/TauMon/Expert/"+trigItemShort+"/L1VsOffline");
-              sc = fillL1TauVsOffline(*itEMTau,goodTauRefType);
+              sc = fillL1TauVsOffline(*itEMTau);
               if(!sc.isSuccess()){ 
                 ATH_MSG_WARNING("Failed to fill L1VsOffline histo. Exiting!"); 
                 return sc;
@@ -929,7 +932,7 @@ StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, co
                   ATH_CHECK(fillPreselTau(*tauItr));
 
                   setCurrentMonGroup("HLT/TauMon/Expert/"+trigItem+"/PreselectionVsOffline");
-                  ATH_CHECK(fillPreselTauVsOffline(*tauItr, goodTauRefType));
+                  ATH_CHECK(fillPreselTauVsOffline(*tauItr));
                 }
               }
             }
@@ -972,10 +975,10 @@ StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, co
                 if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed to Fill RNN input and output histograms for fillEFTau(). Exiting!"); return sc;}
               }
               if(m_truth) if(*tauItr) sc = fillEFTauVsTruth(*tauItr, trigItem);
-              if(*tauItr) sc = fillEFTauVsOffline(*tauItr, trigItem, "basicVars", goodTauRefType);
+              if(*tauItr) sc = fillEFTauVsOffline(*tauItr, trigItem, "basicVars");
               if (monBDT) {
-                if(*tauItr) sc = fillEFTauVsOffline(*tauItr, trigItem, "1p_NonCorr", goodTauRefType);
-                if(*tauItr) sc = fillEFTauVsOffline(*tauItr, trigItem, "mp_NonCorr", goodTauRefType);
+                if(*tauItr) sc = fillEFTauVsOffline(*tauItr, trigItem, "1p_NonCorr");
+                if(*tauItr) sc = fillEFTauVsOffline(*tauItr, trigItem, "mp_NonCorr");
               }
               if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed to Fill histograms for fillEFTauVsOffline(). Exiting!"); return sc;}
             }
@@ -1008,7 +1011,7 @@ StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, co
           setCurrentMonGroup("HLT/TauMon/Expert/"+trigItemShort+"/PreselectionTau");
           ATH_CHECK(fillPreselTau(*tauJetEL));
           setCurrentMonGroup("HLT/TauMon/Expert/"+trigItemShort+"/PreselectionVsOffline");
-          ATH_CHECK(fillPreselTauVsOffline(*tauJetEL, goodTauRefType));
+          ATH_CHECK(fillPreselTauVsOffline(*tauJetEL));
         } // end comb loop
 
         const std::vector< TrigCompositeUtils::LinkInfo<xAOD::TauJetContainer> > featuresMerged
@@ -1043,10 +1046,10 @@ StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, co
 	    if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed to Fill RNN input and output histograms for fillEFTau(). Exiting!"); return sc;}
 	  }
 	  if(m_truth) if(*tauJetEL) sc = fillEFTauVsTruth(*tauJetEL, trigItem);
-	  if(*tauJetEL) sc = fillEFTauVsOffline(*tauJetEL, trigItem, "basicVars", goodTauRefType);
+	  if(*tauJetEL) sc = fillEFTauVsOffline(*tauJetEL, trigItem, "basicVars");
 	  if (monBDT) {
-	    if(*tauJetEL) sc = fillEFTauVsOffline(*tauJetEL, trigItem, "1p_NonCorr", goodTauRefType);
-	    if(*tauJetEL) sc = fillEFTauVsOffline(*tauJetEL, trigItem, "mp_NonCorr", goodTauRefType);
+	    if(*tauJetEL) sc = fillEFTauVsOffline(*tauJetEL, trigItem, "1p_NonCorr");
+	    if(*tauJetEL) sc = fillEFTauVsOffline(*tauJetEL, trigItem, "mp_NonCorr");
 	  }
 	  if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed to Fill histograms for fillEFTauVsOffline(). Exiting!"); return sc;}
 	  
@@ -1124,13 +1127,13 @@ StatusCode HLTTauMonTool::fillHistogramsForItem(const std::string & trigItem, co
     
   if( m_turnOnCurves) {
     if(m_truth){ 
-      sc = TruthTauEfficiency(trigItem, "Truth", goodTauRefType);
+      sc = TruthTauEfficiency(trigItem, "Truth");
       if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed to fill Truth eff curves");} //return StatusCode::FAILURE;}
-      sc = TruthTauEfficiency(trigItem, "Truth+Reco", goodTauRefType);
+      sc = TruthTauEfficiency(trigItem, "Truth+Reco");
       if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed to fill Truth+Reco eff curves");} //return StatusCode::FAILURE;}
     }
 
-    sc = TauEfficiency(trigItem,m_turnOnCurvesDenom, goodTauRefType);
+    sc = TauEfficiency(trigItem,m_turnOnCurvesDenom);
     if(!sc.isSuccess()){ ATH_MSG_WARNING("Failed to fill Reco eff curves"); } //return StatusCode::FAILURE;}
     //      if(m_truth) sc = TauEfficiencyCombo(trigItem);
     //      if(sc.isFailure()){ ATH_MSG_WARNING("Failed to fill combo eff curves. Exiting!"); return StatusCode::FAILURE;}
@@ -1847,7 +1850,7 @@ StatusCode HLTTauMonTool::fillEFTau(const xAOD::TauJet *aEFTau, const std::strin
   return StatusCode::SUCCESS;
 }
 
-StatusCode HLTTauMonTool::fillL1TauVsOffline(const xAOD::EmTauRoI *aL1Tau, const std::string & goodTauRefType){
+StatusCode HLTTauMonTool::fillL1TauVsOffline(const xAOD::EmTauRoI *aL1Tau){
 
   ATH_MSG_DEBUG ("HLTTauMonTool::fillL1TauVsOffline");
     
@@ -1857,11 +1860,8 @@ StatusCode HLTTauMonTool::fillL1TauVsOffline(const xAOD::EmTauRoI *aL1Tau, const
   }
 
   std::vector<const xAOD::TauJet *> taus_here;
-  if (goodTauRefType == "RNN") {
-    taus_here = m_taus_RNN;
-  } else {
-    taus_here = m_taus_BDT;
-  }
+    
+  taus_here = m_taus_RNN;
 
   const xAOD::TauJet *aOfflineTau = 0;
   float tmpR = 0.3;
@@ -1889,7 +1889,7 @@ StatusCode HLTTauMonTool::fillL1TauVsOffline(const xAOD::EmTauRoI *aL1Tau, const
 }
 
 
-StatusCode HLTTauMonTool::fillPreselTauVsOffline(const xAOD::TauJet *aEFTau, const std::string & goodTauRefType){
+StatusCode HLTTauMonTool::fillPreselTauVsOffline(const xAOD::TauJet *aEFTau){
     
     ATH_MSG_DEBUG ("HLTTauMonTool::fillPreselTauVsOffline");
     
@@ -1900,11 +1900,8 @@ StatusCode HLTTauMonTool::fillPreselTauVsOffline(const xAOD::TauJet *aEFTau, con
 
     
     std::vector<const xAOD::TauJet *> taus_here;
-    if (goodTauRefType == "RNN") {
-      taus_here = m_taus_RNN;
-    } else {
-      taus_here = m_taus_BDT;
-    }
+    
+    taus_here = m_taus_RNN;
 
 
     
@@ -1991,7 +1988,7 @@ StatusCode HLTTauMonTool::fillEFTauVsTruth(const xAOD::TauJet *aEFTau, const std
   return StatusCode::SUCCESS;
 }
 
-StatusCode HLTTauMonTool::fillEFTauVsOffline(const xAOD::TauJet *aEFTau, const std::string & trigItem, const std::string & BDTinput_type, const std::string & goodTauRefType)
+StatusCode HLTTauMonTool::fillEFTauVsOffline(const xAOD::TauJet *aEFTau, const std::string & trigItem, const std::string & BDTinput_type)
 {
   ATH_MSG_DEBUG ("HLTTauMonTool::fillEFTauVsOffline");
   if(!aEFTau)
@@ -2001,11 +1998,7 @@ StatusCode HLTTauMonTool::fillEFTauVsOffline(const xAOD::TauJet *aEFTau, const s
     }
 
   std::vector<const xAOD::TauJet *> taus_here;
-  if (goodTauRefType == "RNN") {
-    taus_here = m_taus_RNN;
-  } else {
-    taus_here = m_taus_BDT;
-  }
+  taus_here = m_taus_RNN;
 
  
   float innerTrkAvgDist = 0;
@@ -2797,7 +2790,7 @@ StatusCode HLTTauMonTool::examineTruthTau(const xAOD::TruthParticle& xTruthTau)
 }
 
 
-StatusCode HLTTauMonTool::TauEfficiency(const std::string & trigItem, const std::string & TauDenom, const std::string & goodTauRefType){
+StatusCode HLTTauMonTool::TauEfficiency(const std::string & trigItem, const std::string & TauDenom){
   ATH_MSG_DEBUG("Efficiency wrt "<< TauDenom << " for trigItem" << trigItem);
   if(trigItem == "Dump") {ATH_MSG_DEBUG("Not computing efficiencies for Dump"); return StatusCode::SUCCESS;};
 
@@ -2809,11 +2802,8 @@ StatusCode HLTTauMonTool::TauEfficiency(const std::string & trigItem, const std:
   std::vector<TLorentzVector> tlv_tmp;
 
   std::vector<const xAOD::TauJet *> taus_here;
-  if (goodTauRefType == "RNN") {
-    taus_here = m_taus_RNN;
-  } else {
-    taus_here = m_taus_BDT;
-  }
+    
+  taus_here = m_taus_RNN;
 
   float mu(m_mu_offline);
   int nvtx(PrimaryVertices());
@@ -3432,7 +3422,7 @@ StatusCode HLTTauMonTool::TauEfficiency(const std::string & trigItem, const std:
 // return StatusCode::SUCCESS;
 //}
 
-StatusCode HLTTauMonTool::TruthTauEfficiency(const std::string & trigItem, const std::string & TauCont_type, const std::string & goodTauRefType)
+StatusCode HLTTauMonTool::TruthTauEfficiency(const std::string & trigItem, const std::string & TauCont_type)
 {
   ATH_MSG_DEBUG("Truth Tau Matching to Offline and Online Taus for trigItem" << trigItem);
   
@@ -3450,11 +3440,8 @@ StatusCode HLTTauMonTool::TruthTauEfficiency(const std::string & trigItem, const
   std::vector<bool> truthReco_matched_to_L1;
   std::vector<bool> truthReco_matched_to_hlt;
   std::vector<const xAOD::TauJet *> taus_here;
-  if (goodTauRefType == "RNN") {
-    taus_here = m_taus_RNN;
-  } else {
-    taus_here = m_taus_BDT;
-  }
+    
+  taus_here = m_taus_RNN;
 
   for(unsigned int truth=0;truth<m_true_taus.size();truth++){
 
diff --git a/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool.h b/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool.h
index de0f548aed1dbc27700465bfb5865e40c4b30952..9ed86d39147108146ac3fd5a23c971c87eeead1f 100644
--- a/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool.h
+++ b/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool.h
@@ -69,7 +69,7 @@ class HLTTauMonTool : public IHLTMonTool {
 //#endif
 
   /// Method fills the histograms for one tau trigger item.
-  StatusCode fillHistogramsForItem(const std::string & trigItem, const bool & monRNN, const bool & monBDT, const std::string & goodTauRefType); 
+  StatusCode fillHistogramsForItem(const std::string & trigItem, const bool & monRNN, const bool & monBDT); 
   
  private:
 
@@ -87,9 +87,9 @@ class HLTTauMonTool : public IHLTMonTool {
   StatusCode fillPreselTau(const xAOD::TauJet *aEFTau);
   StatusCode fillEFTau(const xAOD::TauJet *aEFTau, const std::string & trigItem, const std::string & BDTinput_type, const bool & monRNN, const bool & monBDT);
   /// Method filling the EF vs Offline tau histograms
-  StatusCode fillEFTauVsOffline(const xAOD::TauJet *aEFTau, const std::string & trigItem, const std::string & BDTinput_type, const std::string & goodTauRefType);
-  StatusCode fillPreselTauVsOffline(const xAOD::TauJet *aEFTau, const std::string & goodTauRefType);
-  StatusCode fillL1TauVsOffline(const xAOD::EmTauRoI *aEFTau, const std::string & goodTauRefType);
+  StatusCode fillEFTauVsOffline(const xAOD::TauJet *aEFTau, const std::string & trigItem, const std::string & BDTinput_type);
+  StatusCode fillPreselTauVsOffline(const xAOD::TauJet *aEFTau);
+  StatusCode fillL1TauVsOffline(const xAOD::EmTauRoI *aEFTau);
   StatusCode fillEFTauVsTruth(const xAOD::TauJet *aEFTau, const std::string & trigItem);  
   StatusCode fillTopoValidation(const std::string & trigItem_topo, const std::string & trigItem_support);
 
@@ -98,9 +98,9 @@ class HLTTauMonTool : public IHLTMonTool {
 
   /// Method for Turn On Curves
   StatusCode examineTruthTau(const xAOD::TruthParticle& xTruthParticle) const;
-  StatusCode TruthTauEfficiency(const std::string & trigItem, const std::string & TauCont_type, const std::string & goodTauRefType);
+  StatusCode TruthTauEfficiency(const std::string & trigItem, const std::string & TauCont_type);
   StatusCode RecoTauEfficiency(const std::string & trigItem);
-  StatusCode TauEfficiency(const std::string & trigItem, const std::string & TauDenom, const std::string & goodTauRefType);
+  StatusCode TauEfficiency(const std::string & trigItem, const std::string & TauDenom);
 //  StatusCode TauEfficiencyCombo(const std::string & trigItem);
 
   StatusCode RealZTauTauEfficiency(const std::string & goodTauRefType);
diff --git a/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool_dijet.cxx b/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool_dijet.cxx
index 15b91fe01c96100e0c156e1c3b89df421f1e6654..c028460fafc0f44f8c7f93e296b8ba8d65633a4a 100644
--- a/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool_dijet.cxx
+++ b/Trigger/TrigMonitoring/TrigTauMonitoring/src/HLTTauMonTool_dijet.cxx
@@ -116,9 +116,9 @@ StatusCode HLTTauMonTool::dijetFakeTausEfficiency()
       if(!trackMatch) continue;
 
       if( offlineTauIDCut=="") ;
-      else if( offlineTauIDCut=="loose")  {if( !aTau->isTau(xAOD::TauJetParameters::JetBDTSigLoose) ) continue;}
-      else if( offlineTauIDCut=="medium") {if( !aTau->isTau(xAOD::TauJetParameters::JetBDTSigMedium) ) continue;}
-      else if( offlineTauIDCut=="tight")  {if( !aTau->isTau(xAOD::TauJetParameters::JetBDTSigTight) ) continue;}
+      else if( offlineTauIDCut=="loose")  {if( !aTau->isTau(xAOD::TauJetParameters::JetRNNSigLoose) ) continue;}
+      else if( offlineTauIDCut=="medium") {if( !aTau->isTau(xAOD::TauJetParameters::JetRNNSigMedium) ) continue;}
+      else if( offlineTauIDCut=="tight")  {if( !aTau->isTau(xAOD::TauJetParameters::JetRNNSigTight) ) continue;}
 
       /* match to subleading jet*/
       float temp_dR=subleadingJetTLV.DeltaR(aTau->p4());
diff --git a/Trigger/TrigMonitoring/TrigTauMonitoring/src/TrigTauMonitorAlgorithm.cxx b/Trigger/TrigMonitoring/TrigTauMonitoring/src/TrigTauMonitorAlgorithm.cxx
index 21e8d2ca3571eae6616046aced725407b10d28d3..0408f39bdac3f03117df1c3fc049847432884eb2 100644
--- a/Trigger/TrigMonitoring/TrigTauMonitoring/src/TrigTauMonitorAlgorithm.cxx
+++ b/Trigger/TrigMonitoring/TrigTauMonitoring/src/TrigTauMonitorAlgorithm.cxx
@@ -107,6 +107,9 @@ StatusCode TrigTauMonitorAlgorithm::executeNavigation( const EventContext& ctx,
      return StatusCode::FAILURE;
   }
 
+  std::string tauContainerName = "HLT_TrigTauRecMerged_Precision";
+  if(trigItem.find("EF_")!=std::string::npos || trigItem.find("MVA_")!=std::string::npos) tauContainerName="HLT_TrigTauRecMerged_MVA";
+
   for(const auto& Tau : *offTaus ){
 
     const TrigCompositeUtils::Decision *dec=nullptr; 
@@ -115,7 +118,7 @@ StatusCode TrigTauMonitorAlgorithm::executeNavigation( const EventContext& ctx,
 
     if((pidname.find("mediumRNN") != std::string::npos) && !Tau->isTau(xAOD::TauJetParameters::JetRNNSigMedium)) continue;
 
-    auto vec = m_trigDecTool->features<xAOD::TauJetContainer>(trigItem,TrigDefs::includeFailedDecisions ,"HLT_TrigTauRecMerged_MVA");      
+    auto vec =  m_trigDecTool->features<xAOD::TauJetContainer>(trigItem,TrigDefs::includeFailedDecisions , tauContainerName );
     for( auto &featLinkInfo : vec ){                                             
       if(! featLinkInfo.isValid() ) continue;
       const auto *feat = *(featLinkInfo.link);                   
@@ -173,7 +176,11 @@ void TrigTauMonitorAlgorithm::fillDistributions(const EventContext& ctx, std::ve
     fillbasicVars( trigger, offline_tau_vec_mp, false);
   }
 
-  auto vec =  m_trigDecTool->features<xAOD::TauJetContainer>(trigger,TrigDefs::includeFailedDecisions ,"HLT_TrigTauRecMerged_MVA" ); 
+  std::string tauContainerName = "HLT_TrigTauRecMerged_Precision";
+  if(trigger.find("EF_")!=std::string::npos || trigger.find("MVA_")!=std::string::npos) tauContainerName="HLT_TrigTauRecMerged_MVA";
+  ATH_MSG_DEBUG("Tau ContainerName is: " << tauContainerName);
+
+  auto vec =  m_trigDecTool->features<xAOD::TauJetContainer>(trigger,TrigDefs::includeFailedDecisions , tauContainerName );
   for( auto &featLinkInfo : vec ){
     const auto *feat = *(featLinkInfo.link);
     if(!feat) continue;
@@ -188,6 +195,8 @@ void TrigTauMonitorAlgorithm::fillDistributions(const EventContext& ctx, std::ve
     }
   }
 
+  if(online_tau_vec_1p.size()==0 && online_tau_vec_mp.size()==0) return;
+
   if(info.isRNN){ 
     fillRNNInputVars( trigger, online_tau_vec_1p,"1P", true );
     fillRNNInputVars( trigger, online_tau_vec_mp,"MP", true );
@@ -197,7 +206,13 @@ void TrigTauMonitorAlgorithm::fillDistributions(const EventContext& ctx, std::ve
     fillRNNCluster( trigger, online_tau_vec_mp, true );
     fillbasicVars( trigger, online_tau_vec_1p, true);
     fillbasicVars( trigger, online_tau_vec_mp, true);
+  }else {
+    fillBDTOut( trigger,online_tau_vec_1p,"1P");
+    fillBDTOut( trigger,online_tau_vec_mp,"MP");
+    fillBDTNoCorr( trigger,online_tau_vec_1p,"1P");
+    fillBDTNoCorr( trigger,online_tau_vec_mp,"MP");
   }
+
    
   if(info.isRNN){
     fillHLTEfficiencies(ctx, trigger, offline_tau_vec_1p, online_tau_vec_1p, "1P");
@@ -309,6 +324,91 @@ const xAOD::EmTauRoI* TrigTauMonitorAlgorithm::findLVL1_ROI(const EventContext&
    
 }
 
+void TrigTauMonitorAlgorithm::fillBDTOut(const std::string trigger, std::vector<const xAOD::TauJet*> tau_vec,const std::string nProng) const
+{
+  ATH_MSG_DEBUG("Fill BDT output: " << trigger);
+
+  std::string monGroupName = trigger+"_BDT_HLT_Out_"+nProng;
+
+  auto monGroup = getGroup(monGroupName);
+
+  auto BDTJetScore           = Monitored::Collection("BDTJetScore", tau_vec,  [] (const xAOD::TauJet* tau){
+      return (tau->discriminant(xAOD::TauJetParameters::TauID::BDTJetScore));});
+  auto BDTJetScoreSigTrans           = Monitored::Collection("BDTJetScoreSigTrans", tau_vec,  [] (const xAOD::TauJet* tau){
+      return (tau->discriminant(xAOD::TauJetParameters::TauID::BDTJetScoreSigTrans));});
+
+  fill(monGroup, BDTJetScore,BDTJetScoreSigTrans);
+  ATH_MSG_DEBUG("AFTER BDT output: " << trigger);
+}
+
+void TrigTauMonitorAlgorithm::fillBDTNoCorr(const std::string trigger, std::vector<const xAOD::TauJet*> tau_vec,const std::string nProng) const
+{
+  ATH_MSG_DEBUG("Fill BDT non Corrected: " << trigger);
+
+  std::string  monGroupName = trigger+"_BDT_HLT_NoCorr_"+nProng;
+
+  auto monGroup = getGroup(monGroupName);
+
+
+  auto centFrac           = Monitored::Collection("centFrac", tau_vec,  [] (const xAOD::TauJet* tau){
+      float detail = -999;
+      if (tau->detail(xAOD::TauJetParameters::centFrac, detail)){
+        detail = std::min(detail, 1.0f);
+      } return detail;});
+  auto ChPiEMEOverCaloEME           = Monitored::Collection("ChPiEMEOverCaloEME", tau_vec,  [] (const xAOD::TauJet* tau){
+      float detail = -999;
+      if (tau->detail(xAOD::TauJetParameters::ChPiEMEOverCaloEME, detail)){
+      } return detail;});
+  auto emPOverTrkSysP     = Monitored::Collection("emPOverTrkSysP", tau_vec,  [] (const xAOD::TauJet* tau){
+      float detail = -999;
+      if (tau->detail(xAOD::TauJetParameters::EMPOverTrkSysP, detail)){
+        detail = TMath::Log10(std::max(detail, 1e-3f));
+      } return detail;});
+  auto etOverPtLeadTrk    = Monitored::Collection("etOverPtLeadTrk", tau_vec,  [] (const xAOD::TauJet* tau){
+      float detail = -999;
+      if (tau->detail(xAOD::TauJetParameters::etOverPtLeadTrk, detail)){
+        detail = TMath::Log10(std::max(detail, 0.1f));
+      } return detail;});
+  auto innerTrkAvgDist           = Monitored::Collection("innerTrkAvgDist", tau_vec,  [] (const xAOD::TauJet* tau){
+      float detail = -999;
+      if (tau->detail(xAOD::TauJetParameters::innerTrkAvgDist, detail)){
+      } return detail;});
+  auto ptRatioEflowApprox = Monitored::Collection("ptRatioEflowApprox", tau_vec,  [] (const xAOD::TauJet* tau){
+      float detail = -999;
+      if (tau->detail(xAOD::TauJetParameters::ptRatioEflowApprox, detail)){
+        detail = std::min(detail, 4.0f);
+      } return detail;});
+  if(nProng=="1P"){
+    auto sumPtTrkFrac       = Monitored::Collection("sumPtTrkFrac", tau_vec,  [] (const xAOD::TauJet* tau){
+        float detail = -999;
+        if (tau->detail(xAOD::TauJetParameters::SumPtTrkFrac, detail)){
+        } return detail;});
+    fill(monGroup, centFrac,ChPiEMEOverCaloEME,emPOverTrkSysP,etOverPtLeadTrk,innerTrkAvgDist,ptRatioEflowApprox,sumPtTrkFrac);
+
+  }
+  else if(nProng=="MP"){
+    auto dRmax              = Monitored::Collection("dRmax", tau_vec,  [] (const xAOD::TauJet* tau){
+        float detail = -999;
+        if (tau->detail(xAOD::TauJetParameters::dRmax, detail)){
+        } return detail;});
+    auto massTrkSys         = Monitored::Collection("massTrkSys", tau_vec,  [&nProng] (const xAOD::TauJet* tau){
+        float detail = -999;
+        if ( tau->detail(xAOD::TauJetParameters::massTrkSys, detail) && nProng.find("MP") != std::string::npos ){
+          detail = TMath::Log10(std::max(detail, 140.0f));
+        }return detail;});
+    auto mEflowApprox       = Monitored::Collection("mEflowApprox", tau_vec,  [] (const xAOD::TauJet* tau){
+        float detail = -999;
+        if (tau->detail(xAOD::TauJetParameters::mEflowApprox, detail)){
+          detail = TMath::Log10(std::max(detail, 140.0f));
+        }return detail;});
+    auto trFlightPathSig           = Monitored::Collection("trFlightPathSig", tau_vec,  [] (const xAOD::TauJet* tau){
+        float detail = -999;
+        if (tau->detail(xAOD::TauJetParameters::trFlightPathSig, detail)){
+        } return detail;});
+    fill(monGroup, centFrac,ChPiEMEOverCaloEME,emPOverTrkSysP,etOverPtLeadTrk,innerTrkAvgDist,ptRatioEflowApprox,dRmax,massTrkSys,mEflowApprox,trFlightPathSig);
+
+  }
+}
 
 
 void TrigTauMonitorAlgorithm::fillRNNInputVars(const std::string trigger, std::vector<const xAOD::TauJet*> tau_vec,const std::string nProng, bool online) const
diff --git a/Trigger/TrigMonitoring/TrigTauMonitoring/src/TrigTauMonitorAlgorithm.h b/Trigger/TrigMonitoring/TrigTauMonitoring/src/TrigTauMonitorAlgorithm.h
index def74a7a069ef8e547eec03391be71c7887d51c9..2e02461cd9d4a5bf4e166138aba9c7ccd0a2c6ae 100644
--- a/Trigger/TrigMonitoring/TrigTauMonitoring/src/TrigTauMonitorAlgorithm.h
+++ b/Trigger/TrigMonitoring/TrigTauMonitoring/src/TrigTauMonitorAlgorithm.h
@@ -50,6 +50,8 @@ class TrigTauMonitorAlgorithm : public AthMonitorAlgorithm {
   void fillRNNTrack(const std::string trigger, std::vector<const xAOD::TauJet*> tau_vec, bool online) const;
   void fillRNNCluster(const std::string trigger, std::vector<const xAOD::TauJet*> tau_vec, bool online) const;
   void fillbasicVars(const std::string trigger, std::vector<const xAOD::TauJet*> tau_vec, bool online) const;
+  void fillBDTNoCorr(const std::string trigger, std::vector<const xAOD::TauJet*> tau_vec,const std::string nProng) const;
+  void fillBDTOut(const std::string trigger, std::vector<const xAOD::TauJet*> tau_vec,const std::string nProng) const;
   void fillDistributions(const EventContext& ctx, std::vector< std::pair< const xAOD::TauJet*, const TrigCompositeUtils::Decision * >> pairObjs, const std::string trigger, const bool fill_l1eff, const std::string trigL1Item) const;
   void fillHLTEfficiencies(const EventContext& ctx,const std::string trigger, std::vector<const xAOD::TauJet*> offline_tau_vec, std::vector<const xAOD::TauJet*> online_tau_vec, std::string nProng) const;
   void fillL1Efficiencies(const EventContext& ctx, const std::string trigger, std::vector<const xAOD::TauJet*> offline_tau_vec,std::string nProng, const std::string trigL1Item) const;
diff --git a/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/HLTResultMTMaker.h b/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/HLTResultMTMaker.h
index db3b1dfb8dc563439151693cdbb4da23231f10a1..dd076e7ee60d7debf0d48c66839765752e468a4e 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/HLTResultMTMaker.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/HLTResultMTMaker.h
@@ -25,7 +25,7 @@ public:
   /// Standard constructor
   HLTResultMTMaker(const std::string& type, const std::string& name, const IInterface* parent);
   /// Standard destructor
-  virtual ~HLTResultMTMaker();
+  virtual ~HLTResultMTMaker() override = default;
 
   // ------------------------- IStateful methods -------------------------------
   virtual StatusCode initialize() override;
@@ -63,6 +63,11 @@ private:
     this, "MonTool", "",
     "Monitoring tool"
   };
+  /// Handle to JobOptionsSvc used to retrieve the DataFlowConfig property
+  ServiceHandle<Gaudi::Interfaces::IOptionsSvc> m_jobOptionsSvc {
+    this, "JobOptionsSvc", "JobOptionsSvc",
+    "Job options service to retrieve DataFlowConfig"
+  };
   /// Extra enabled ROBs
   Gaudi::Property<std::vector<uint32_t>> m_extraEnabledROBs {
     this, "ExtraEnabledROBs", {},
@@ -75,8 +80,6 @@ private:
   };
 
   // ------------------------- Other private members ---------------------------
-  /// Handle to JobOptionsSvc used to retrieve the DataFlowConfig property
-  ServiceHandle<Gaudi::Interfaces::IOptionsSvc> m_jobOptionsSvc;
   /// List of enabled ROBs retrieved during initialisation
   std::set<uint32_t> m_enabledROBs;
   /// List of enabled SubDets retrieved during initialisation
diff --git a/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/HLTResultMTMakerTool.h b/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/HLTResultMTMakerTool.h
index 7027790ee7efdd353cb783e04f0dfcb1b86d68ee..5b5e2235dde0b4173fbe379330b3205b46616ccb 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/HLTResultMTMakerTool.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/HLTResultMTMakerTool.h
@@ -19,7 +19,7 @@ public:
 
   virtual StatusCode fill( HLT::HLTResultMT& resultToFill, const EventContext& ctx ) const = 0;
   
-  virtual ~HLTResultMTMakerTool() override {}
+  virtual ~HLTResultMTMakerTool() override = default;
 }; 
 
 #endif // TRIGOUTPUTHANDLING_HLTRESULTMTMAKERTOOL_H
diff --git a/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/ITriggerBitsMakerTool.h b/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/ITriggerBitsMakerTool.h
index 03618a31db729399df5590e8c0bf177063f680f6..8ec429785d47f80f539621bdc1b143434daa822b 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/ITriggerBitsMakerTool.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/ITriggerBitsMakerTool.h
@@ -22,7 +22,7 @@ public:
     boost::dynamic_bitset<uint32_t>& rerun,
     const EventContext& ctx) const = 0;
 
-  virtual ~ITriggerBitsMakerTool() override {}
+  virtual ~ITriggerBitsMakerTool() override = default;
 }; 
 
 #endif // TRIGOUTPUTHANDLING_ITRIGGERBITSMAKERTOOL_H
diff --git a/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/TriggerBitsMakerTool.h b/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/TriggerBitsMakerTool.h
index a9d5c5fd7f873d91c4698b4c3d199cc5b19d85b4..141335146bf4472c0f51f85c8f5b95b55ae412d5 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/TriggerBitsMakerTool.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/TrigOutputHandling/TriggerBitsMakerTool.h
@@ -18,7 +18,7 @@
 class TriggerBitsMakerTool : public extends<AthAlgTool, HLTResultMTMakerTool, ITriggerBitsMakerTool> {
 public:
   TriggerBitsMakerTool(const std::string& type, const std::string& name, const IInterface* parent);
-  virtual ~TriggerBitsMakerTool() override;
+  virtual ~TriggerBitsMakerTool() override = default;
 
   virtual StatusCode fill( HLT::HLTResultMT& resultToFill, const EventContext& ctx ) const override;
 
@@ -55,10 +55,10 @@ private:
   Gaudi::Property<std::map<std::string, uint32_t>> m_extraChainToBit { this, "ExtraChainToBit", {},
     "Special case and testing purposes hard-coded chain-to-bit mappings to use in addition to those from the HLT menu."};
 
-  typedef std::map< TrigCompositeUtils::DecisionID, uint32_t> ChainToBitMap;
+  using ChainToBitMap = std::map< TrigCompositeUtils::DecisionID, uint32_t>;
   ChainToBitMap m_mapping; //!< Mapping of each chain's hash ID to its chain counter
 
-  uint32_t m_largestBit; //!< Largest chain counter hence largest bit needed to be stored in result bitmap
+  uint32_t m_largestBit{0}; //!< Largest chain counter hence largest bit needed to be stored in result bitmap
 };
 
 #endif // TRIGOUTPUTHANDLING_TRIGGERBITSMAKERTOOL_H
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/BareDataBucket.h b/Trigger/TrigSteer/TrigOutputHandling/src/BareDataBucket.h
index fdb304ec8ae454f8226e30fd39286ad1227a8229..f3e9445a04801d45b69cb2c44018babaded15eea 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/BareDataBucket.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/BareDataBucket.h
@@ -15,14 +15,19 @@ class BareDataBucket: public DataBucketBase {
 public:
   BareDataBucket() = delete;
 
-  BareDataBucket( void * data, CLID clid, const RootType& type )
-    : m_data(data), m_clid(clid), m_type( type ){}
+  BareDataBucket( void * data, CLID clid, RootType type )
+    : m_data(data), m_clid(clid), m_type( std::move(type) ){}
 
-  virtual ~BareDataBucket() {
-    if ( m_data )
+  virtual ~BareDataBucket() override {
+    if ( m_data != nullptr )
       m_type.Destruct( m_data );
   }
 
+  BareDataBucket(const BareDataBucket&) = delete;
+  BareDataBucket(BareDataBucket&&) = delete;
+  BareDataBucket& operator=(const BareDataBucket&) = delete;
+  BareDataBucket& operator=(BareDataBucket&&) = delete;
+
   // DataObject overrides
   virtual const CLID& clID() const override {
     return m_clid;
@@ -40,13 +45,13 @@ public:
 
   using DataBucketBase::cast;
   virtual void* cast (CLID clid,
-                      SG::IRegisterTransient* ,
+                      SG::IRegisterTransient* /*irt*/,
                       bool isConst = true) override {
     return ( m_clid == clid and isConst ) ? m_data : nullptr;
   }
 
   virtual void* cast (const std::type_info& tinfo,
-                      SG::IRegisterTransient* ,
+                      SG::IRegisterTransient* /*irt*/,
                       bool isConst = true) override {
     return ( tinfo == m_type.TypeInfo() and isConst ) ? m_data : nullptr;
   }
@@ -58,7 +63,7 @@ public:
   virtual void lock() override { /*not lockable I think */ };
 
 private:
-  void* m_data = 0;
+  void* m_data = nullptr;
   CLID m_clid  = 0;
   RootType m_type;
 };
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx
index 531fc13566e0b564d5535f04dadb3fc095bc84f3..3002b155a27267d903c28c375735a9bd71ac80a2 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx
@@ -4,21 +4,20 @@
 #include "TrigCompositeUtils/HLTIdentifier.h"
 #include "DecisionSummaryMakerAlg.h"
 
-DecisionSummaryMakerAlg::DecisionSummaryMakerAlg(const std::string& name, ISvcLocator* pSvcLocator) 
+DecisionSummaryMakerAlg::DecisionSummaryMakerAlg(const std::string& name, ISvcLocator* pSvcLocator)
   : AthReentrantAlgorithm(name, pSvcLocator) {}
 
-DecisionSummaryMakerAlg::~DecisionSummaryMakerAlg() {}
-
 StatusCode DecisionSummaryMakerAlg::initialize() {
   renounceArray( m_finalDecisionKeys );
-  ATH_CHECK( m_finalDecisionKeys.initialize() ); 
+  ATH_CHECK( m_finalDecisionKeys.initialize() );
   ATH_CHECK( m_summaryKey.initialize() );
   ATH_CHECK( m_l1SummaryKey.initialize() );
-  
-  for ( auto& pair: m_lastStepForChain ) {
-    struct { std::string chain, collection; } conf { pair.first, pair.second };    
-    m_collectionFilter[ conf.collection ].insert( HLT::Identifier( conf.chain).numeric() );
-    ATH_MSG_DEBUG( "Final decision of the chain " << conf.chain << " will be read from " << conf.collection );
+
+  for ( auto& [chain, collections]: m_lastStepForChain ) {
+    for ( auto& collection: collections ) {
+      m_collectionFilter[ collection ].insert( HLT::Identifier( chain ).numeric() );
+      ATH_MSG_DEBUG( "Final decision of the chain " << chain << " will be read from " << collection );
+    }
   }
 
   ATH_CHECK( m_costWriteHandleKey.initialize( m_doCostMonitoring ) );
@@ -26,7 +25,7 @@ StatusCode DecisionSummaryMakerAlg::initialize() {
   if (m_doCostMonitoring) {
     ATH_CHECK( m_trigCostSvcHandle.retrieve() );
   }
-  
+
   return StatusCode::SUCCESS;
 }
 
@@ -55,7 +54,7 @@ StatusCode DecisionSummaryMakerAlg::execute(const EventContext& context) const {
     }
     const auto thisCollFilter = m_collectionFilter.find( key.key() );
     if ( thisCollFilter == m_collectionFilter.end() ) {
-      ATH_MSG_WARNING( "The collection " << key.key() << " is not configured to contain any final decision," 
+      ATH_MSG_WARNING( "The collection " << key.key() << " is not configured to contain any final decision,"
                        << "remove it from the configuration of " << name() << " to save time" );
       continue;
     }
@@ -68,10 +67,10 @@ StatusCode DecisionSummaryMakerAlg::execute(const EventContext& context) const {
       // Filter out chains for which this is NOT the final step of their processing
       DecisionIDContainer passingFinalIDs;
       std::set_intersection( passingIDs.begin(), passingIDs.end(),
-          thisCollFilter->second.begin(), thisCollFilter->second.end(), 
+          thisCollFilter->second.begin(), thisCollFilter->second.end(),
           std::inserter(passingFinalIDs, passingFinalIDs.begin() ) ); // should be faster than remove_if
 
-      if (passingFinalIDs.size() == 0) {
+      if (passingFinalIDs.empty()) {
         continue;
       }
 
@@ -148,10 +147,9 @@ StatusCode DecisionSummaryMakerAlg::execute(const EventContext& context) const {
   // in events which are accepted by one ore more chains.
   bool filterStatus = true;
   if (m_setFilterStatus) {
-    filterStatus = (allPassingFinalIDs.size() > 0);
+    filterStatus = (not allPassingFinalIDs.empty());
   }
   setFilterPassed(filterStatus, context );
 
   return StatusCode::SUCCESS;
 }
-
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h
index 7b050aac8d3af106f434f9095a3cf0689823902c..91f8a81efdd67d7e6fd26cf74d9ca6d4794cd9c9 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h
@@ -19,17 +19,17 @@
 class DecisionSummaryMakerAlg : public AthReentrantAlgorithm {
 public:
   DecisionSummaryMakerAlg(const std::string& name, ISvcLocator* pSvcLocator);
-  virtual ~DecisionSummaryMakerAlg() override;
+  virtual ~DecisionSummaryMakerAlg() override = default;
 
   virtual StatusCode initialize() override;
   virtual StatusCode execute(const EventContext& context) const override;
   virtual StatusCode finalize() override;
 
 private:
-  SG::WriteHandleKey<TrigCompositeUtils::DecisionContainer> m_summaryKey{ this, "DecisionsSummaryKey", "HLTNav_Summary", 
+  SG::WriteHandleKey<TrigCompositeUtils::DecisionContainer> m_summaryKey{ this, "DecisionsSummaryKey", "HLTNav_Summary",
       "Location of final decision" };
 
-  SG::ReadHandleKeyArray<TrigCompositeUtils::DecisionContainer> m_finalDecisionKeys{ this, "FinalDecisionKeys", {}, 
+  SG::ReadHandleKeyArray<TrigCompositeUtils::DecisionContainer> m_finalDecisionKeys{ this, "FinalDecisionKeys", {},
       "Final stage of all decisions" };
 
   SG::WriteHandleKey<xAOD::TrigCompositeContainer> m_costWriteHandleKey { this, "CostWriteHandleKey", "HLT_TrigCostContainer",
@@ -41,16 +41,16 @@ private:
   SG::ReadHandleKey<xAOD::TrigCompositeContainer> m_l1SummaryKey { this, "L1DecoderSummaryKey", "L1DecoderSummary",
     "Chains status after L1 and prescaling" };
 
-  ServiceHandle<ITrigCostMTSvc> m_trigCostSvcHandle { this, "TrigCostMTSvc", "TrigCostMTSvc", 
+  ServiceHandle<ITrigCostMTSvc> m_trigCostSvcHandle { this, "TrigCostMTSvc", "TrigCostMTSvc",
     "The trigger cost service" };
 
-  Gaudi::Property< std::map< std::string, std::string > > m_lastStepForChain{ this, "FinalStepDecisions", {}, 
-    "The map of chain name to name of the collection in which the final decision is found" };
+  Gaudi::Property< std::map< std::string, std::vector<std::string> > > m_lastStepForChain{ this, "FinalStepDecisions", {},
+    "The map of chain name to names of the collections in which the final decision is found" };
 
-  Gaudi::Property<bool> m_doCostMonitoring{this, "DoCostMonitoring", false, 
+  Gaudi::Property<bool> m_doCostMonitoring{this, "DoCostMonitoring", false,
     "Enables end-of-event cost monitoring behavior."};
 
-  Gaudi::Property<bool> m_setFilterStatus{this, "SetFilterStatus", false, 
+  Gaudi::Property<bool> m_setFilterStatus{this, "SetFilterStatus", false,
     "Enables chain-passed filter. This will cause the downstream EDMCreator to not run if no chains pass, saving CPU in rejected events. "
     "Cannot be used in jobs producing RDO output."};
 
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreator.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreator.cxx
index 2915265ca876aaa21c205a51b302f3af7eae4f13..1ebbc05f0effe72fb49513c5215be18c6f1f6d53 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreator.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreator.cxx
@@ -24,8 +24,8 @@ StatusCode HLTEDMCreator::initHandles( const HandlesGroup<T>&  handles ) {
   renounceArray( handles.views );
 
   // the case w/o reading from views, both views handles and collection in views should be empty
-  if ( handles.views.size() == 0 ) {
-    ATH_CHECK( handles.in.size() == 0 );
+  if ( handles.views.empty() ) {
+    ATH_CHECK( handles.in.empty() );
   } else {
     // the case with views, for every output we expect an input View and an input collection inside that View
     ATH_CHECK( handles.out.size() == handles.in.size() );
@@ -167,7 +167,7 @@ template<typename T>
 StatusCode  HLTEDMCreator::viewsMerge( ViewContainer const& views, const SG::ReadHandleKey<T>& inViewKey,
                EventContext const& context, T & output ) const {
   
-  typedef typename T::base_value_type type_in_container;
+  using type_in_container = typename T::base_value_type;
   StoreGateSvc* sg = evtStore().operator->(); // why the get() method is returing a null ptr is a puzzle, we have to use this ugly call to operator instead of it
   ATH_CHECK( sg != nullptr );
   ViewHelper::ViewMerger merger( sg, msg() );
@@ -178,7 +178,7 @@ StatusCode  HLTEDMCreator::viewsMerge( ViewContainer const& views, const SG::Rea
 
  
 StatusCode HLTEDMCreator::fixLinks() const {
-  if ( m_fixLinks.size() == 0 ) {
+  if ( m_fixLinks.value().empty() ) {
     ATH_MSG_DEBUG("fixLinks: No collections defined for this tool");
     return StatusCode::SUCCESS;
   }
@@ -269,7 +269,7 @@ StatusCode HLTEDMCreator::createIfMissing( const EventContext& context, const Co
   for (size_t i = 0; i < handles.out.size(); ++i) {
     SG::WriteHandleKey<T> writeHandleKey = handles.out.at(i);
 
-    if ( handles.views.size() == 0 ) { // no merging will be needed
+    if ( handles.views.empty() ) { // no merging will be needed
       // Note: This is correct. We are testing if we can read, and if we cannot then we write.
       // What we write will either be a dummy (empty) container, or be populated from N in-View collections.
       SG::ReadHandle<T> readHandle( writeHandleKey.key() );
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreator.h b/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreator.h
index 95cb1bae0678f1caecf4767b029337d18752d28a..ac1b9b56717e64c795e6b1a63146b074710d9215 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreator.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreator.h
@@ -87,7 +87,7 @@ class HLTEDMCreator: public extends<AthAlgTool, IHLTOutputTool>  {
 	     const std::string& name, 
 	     const IInterface* parent );
 
-  virtual ~HLTEDMCreator(){}
+  virtual ~HLTEDMCreator() override = default;
   virtual StatusCode createOutput(const EventContext& context) const override;
   virtual StatusCode initialize() override;
 
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreatorAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreatorAlg.cxx
index fd6e5b6802149263875322e87b07ca2019a187be..6839877a2012cdbac35814cf016a450a7178a675 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreatorAlg.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreatorAlg.cxx
@@ -9,24 +9,15 @@ HLTEDMCreatorAlg::HLTEDMCreatorAlg(const std::string& name, ISvcLocator* pSvcLoc
 {
 }
 
-HLTEDMCreatorAlg::~HLTEDMCreatorAlg()
-{
-}
-
 StatusCode HLTEDMCreatorAlg::initialize()
 {
   ATH_CHECK( m_tools.retrieve() );
   return StatusCode::SUCCESS;
 }
 
-StatusCode HLTEDMCreatorAlg::finalize()
-{
-  return StatusCode::SUCCESS;
-}
-
 StatusCode HLTEDMCreatorAlg::execute(const EventContext& context) const
 {
-  for ( auto& t: m_tools )  {
+  for ( const auto& t: m_tools )  {
     ATH_CHECK( t->createOutput( context ) );
   }
   return StatusCode::SUCCESS;
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreatorAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreatorAlg.h
index 41c6b4ca08e4c89fb736120eeafe5c02430eb78e..46a7a37ccf0e53001d26e4adcdbb7e9a0b335062 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreatorAlg.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTEDMCreatorAlg.h
@@ -17,11 +17,10 @@
 class HLTEDMCreatorAlg : public AthReentrantAlgorithm {
 public:
   HLTEDMCreatorAlg(const std::string& name, ISvcLocator* pSvcLocator);
-  virtual ~HLTEDMCreatorAlg() override;
+  virtual ~HLTEDMCreatorAlg() override = default;
 
   virtual StatusCode initialize() override;
   virtual StatusCode execute(const EventContext& context) const override;
-  virtual StatusCode finalize() override;
 
 private:
   ToolHandleArray<IHLTOutputTool> m_tools{ this, "OutputTools", {}, "Tools that generate output"};
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMaker.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMaker.cxx
index f4d9754b0b2304a1f704613ed0e79edec8e50df6..c153a02a38479a56d36db6b25529d742638c30b9 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMaker.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMaker.cxx
@@ -50,13 +50,7 @@ namespace {
 // Standard constructor
 // =============================================================================
 HLTResultMTMaker::HLTResultMTMaker(const std::string& type, const std::string& name, const IInterface* parent)
-  : AthAlgTool(type, name, parent),
-  m_jobOptionsSvc("JobOptionsSvc", name) {}
-
-// =============================================================================
-// Standard destructor
-// =============================================================================
-HLTResultMTMaker::~HLTResultMTMaker() {}
+  : AthAlgTool(type, name, parent) {}
 
 // =============================================================================
 // Implementation of IStateful::initialize
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx
index 17fae8a7e6be48423e159404ed0655add3a3022e..3a094bb496beb070e6485a84e066715e70f45773 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx
@@ -7,8 +7,6 @@
 HLTResultMTMakerAlg::HLTResultMTMakerAlg(const std::string& name, ISvcLocator* pSvcLocator) :
   AthReentrantAlgorithm(name, pSvcLocator) {}
 
-HLTResultMTMakerAlg::~HLTResultMTMakerAlg() {}
-
 StatusCode HLTResultMTMakerAlg::initialize() {
   ATH_CHECK( m_resultMaker.retrieve() );
   return StatusCode::SUCCESS;
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h
index e02b400dec6cfee837a7bc2b65606ac07cb3fcb8..f3a22d19565d099f241228ace19884230f76fc04 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h
@@ -15,7 +15,7 @@
 class HLTResultMTMakerAlg : public AthReentrantAlgorithm {
 public:
   HLTResultMTMakerAlg(const std::string& name, ISvcLocator* pSvcLocator);
-  virtual ~HLTResultMTMakerAlg() override;
+  virtual ~HLTResultMTMakerAlg() override = default;
 
   virtual StatusCode initialize() override;
   virtual StatusCode execute(const EventContext& context) const override;
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/StreamTagMakerTool.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/StreamTagMakerTool.cxx
index cab9fec63227a05542d39b922032b6ec98619397..e7eaefdfa89223e50e4df566be6628c841164a16 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/StreamTagMakerTool.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/StreamTagMakerTool.cxx
@@ -11,15 +11,18 @@
 
 using namespace TrigCompositeUtils;
 
-// =============================================================================
-
-StreamTagMakerTool::StreamTagMakerTool( const std::string& type, const std::string& name, const IInterface* parent ):
-   base_class( type, name, parent )
-{}
+namespace {
+  std::string formatStreamTagInfo(const StreamTagMakerTool::StreamTagInfo& info) {
+    std::ostringstream ss;
+    ss << "[" << std::get<0>(info) << ", " << std::get<1>(info) << ", " << std::get<2>(info) << ", " << std::get<3>(info) << "]";
+    return ss.str();
+  }
+}
 
 // =============================================================================
 
-StreamTagMakerTool::~StreamTagMakerTool() {}
+StreamTagMakerTool::StreamTagMakerTool( const std::string& type, const std::string& name, const IInterface* parent ):
+  base_class( type, name, parent ) {}
 
 // =============================================================================
 
@@ -141,7 +144,7 @@ StatusCode StreamTagMakerTool::fill( HLT::HLTResultMT& resultToFill, const Event
     
     const std::vector<StreamTagInfo>& streams = mappingIter->second;
     for (const StreamTagInfo& streamTagInfo : streams) {
-      auto [st_name, st_type, obeysLB, forceFullEvent] = streamTagInfo;
+      const auto& [st_name, st_type, obeysLB, forceFullEvent] = streamTagInfo;
       ATH_MSG_DEBUG("Chain " << HLT::Identifier( chain ) << " accepted event into stream " << st_type << "_" << st_name
                     << " (obeysLB=" << obeysLB << ", forceFullEvent=" << forceFullEvent << ")");
       std::set<uint32_t> robs;
@@ -209,14 +212,3 @@ StatusCode StreamTagMakerTool::fillPEBInfoMap(std::unordered_map<DecisionID, PEB
   } // Loop over decision containers
   return StatusCode::SUCCESS;
 }
-
-// =============================================================================
-
-std::string
-StreamTagMakerTool::formatStreamTagInfo (const StreamTagInfo& info) const
-{
-  std::ostringstream ss;
-  ss << "[" << std::get<0>(info) << ", " << std::get<1>(info) << ", " << std::get<2>(info) << ", " << std::get<3>(info) << "]";
-  return ss.str();
-}
-
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/StreamTagMakerTool.h b/Trigger/TrigSteer/TrigOutputHandling/src/StreamTagMakerTool.h
index 6291d9724608d25e6e86d246dbad35f5a7fedf8c..b31af48bdae129ac403683a96481a4471eb8c6dd 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/StreamTagMakerTool.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/StreamTagMakerTool.h
@@ -26,7 +26,7 @@
 class StreamTagMakerTool : public extends<AthAlgTool, HLTResultMTMakerTool> {
 public:
   StreamTagMakerTool(const std::string& type, const std::string& name, const IInterface* parent);
-  virtual ~StreamTagMakerTool() override;
+  virtual ~StreamTagMakerTool() override = default;
 
   virtual StatusCode fill( HLT::HLTResultMT& resultToFill, const EventContext& ctx ) const override;
 
@@ -35,11 +35,9 @@ public:
   virtual StatusCode finalize() override;
 
   /// Type describing StreamTag information needed by the tool: {name, type, obeysLumiBlock, forceFullEventBuilding}
-  typedef std::tuple<std::string, std::string, bool, bool> StreamTagInfo;
+  using StreamTagInfo = std::tuple<std::string, std::string, bool, bool>;
 
 private:
-  std::string formatStreamTagInfo (const StreamTagInfo& info) const;
-
   SG::ReadHandleKey<TrigConf::HLTMenu> m_hltMenuKey{"DetectorStore+HLTTriggerMenu"};
 
   SG::ReadHandleKey<TrigCompositeUtils::DecisionContainer> m_finalChainDecisions {this, "ChainDecisions", "HLTNav_Summary",
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerBitsMakerTool.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerBitsMakerTool.cxx
index e9212abad358ccc4acf74923ae86aa5d894fb7b3..649719934a91008b0c23adb315d4c629bcc8a9b9 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerBitsMakerTool.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerBitsMakerTool.cxx
@@ -11,8 +11,6 @@
 TriggerBitsMakerTool::TriggerBitsMakerTool(const std::string& type, const std::string& name, const IInterface* parent) :
   base_class(type, name, parent){}
 
-TriggerBitsMakerTool::~TriggerBitsMakerTool() {}
-
 StatusCode TriggerBitsMakerTool::initialize() {
 
   ATH_CHECK( m_finalChainDecisions.initialize() );
@@ -115,7 +113,7 @@ StatusCode TriggerBitsMakerTool::getBits(boost::dynamic_bitset<uint32_t>& passRa
     } else if (decisionObject->name() == "HLTPrescaled") {
       HLTPrescaled = decisionObject;
     }
-    if (HLTPassRaw && HLTPrescaled) {
+    if (HLTPassRaw != nullptr && HLTPrescaled != nullptr) {
       break;
     }
   }
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx
index d7a5a53be823a046d04877c8c94f8b36e5a82b65..2a194819a45e99a05b651fb3e0febedc606d7efe 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx
@@ -28,7 +28,7 @@
 
 class TriggerEDMDeserialiserAlg::WritableAuxStore : public SG::AuxStoreInternal {
 public:
-  WritableAuxStore() {}
+  WritableAuxStore() = default;
   using SG::AuxStoreInternal::addVector;
 };
 
@@ -44,10 +44,10 @@ namespace  {
   const std::type_info* getElementType ( const std::string& tname,
 					 std::string& elementTypeName ) {
     TClass* cls = TClass::GetClass( tname.c_str() );
-    if ( !cls ) return nullptr;
+    if ( cls == nullptr ) return nullptr;
     TVirtualCollectionProxy* prox = cls->GetCollectionProxy();
-    if ( !prox ) return nullptr;
-    if ( prox->GetValueClass() ) {
+    if ( prox == nullptr ) return nullptr;
+    if ( prox->GetValueClass() != nullptr ) {
       elementTypeName = prox->GetValueClass()->GetName();
       return prox->GetValueClass()->GetTypeInfo();
     }
@@ -68,12 +68,73 @@ namespace  {
   
 }
 
+/**
+ * Collection of helper functions for raw pointer operations on the bytestream payload
+ *
+ * Most functions can be constexpr if the compiler implements ConstexprIterator (P0858R0)
+ * Tested it works in clang9+ regardless of --std flag and in gcc10+ only with --std=c++20
+ * TODO: Remove the C++ version checks when the release is built with --std=c++20 or newer
+ */
+namespace PayloadHelpers {
+  using TDA = TriggerEDMDeserialiserAlg;
+
+  /// CLID of the collection stored in the next fragment
+  #if __cpp_lib_array_constexpr >= 201811L || __clang_major__ >= 9
+  constexpr
+  #endif
+  CLID collectionCLID(TDA::PayloadIterator start) {
+    return *( start + TDA::CLIDOffset );
+  }
+
+  /// Length of the serialised name payload
+  #if __cpp_lib_array_constexpr >= 201811L || __clang_major__ >= 9
+  constexpr
+  #endif
+  size_t nameLength(TDA::PayloadIterator start) {
+    return *( start + TDA::NameLengthOffset );
+  }
+
+  /// Size in bytes of the buffer that is needed to decode next fragment data content
+  #if __cpp_lib_array_constexpr >= 201811L || __clang_major__ >= 9
+  constexpr
+  #endif
+  size_t dataSize(TDA::PayloadIterator start) {
+    return *( start + TDA::NameOffset + nameLength(start) );
+  }
+
+  /**
+   * Returns starting point of the next fragment, can be == end()
+   *
+   * Intended to be used like this: start = advance(start); if ( start != data.end() )... decode else ... done
+   **/
+  #if __cpp_lib_array_constexpr >= 201811L || __clang_major__ >= 9
+  constexpr
+  #endif
+  TDA::PayloadIterator toNextFragment(TDA::PayloadIterator start) {
+    return start + (*start); // point ahead by the number of words pointed to by start iterator
+  }
+
+  /// String description of the collection stored in the next fragment, returns persistent type name and the SG key
+  std::vector<std::string> collectionDescription(TDA::PayloadIterator start) {
+    StringSerializer ss;
+    std::vector<std::string> labels;
+    ss.deserialize( start + TDA::NameOffset, start + TDA::NameOffset + nameLength(start), labels );
+    return labels;
+  }
+
+  /// Copies fragment to the buffer, no size checking, use @c dataSize to do so
+  void toBuffer(TDA::PayloadIterator start, char* buffer) {
+    // move to the beginning of the buffer memory
+    TDA::PayloadIterator dataStart =  start + TDA::NameOffset + nameLength(start) + 1 /*skip size*/;
+    // we rely on continuous memory layout of std::vector ...
+    std::memcpy( buffer, &(*dataStart), dataSize(start) );
+  }
+}
+
 
 TriggerEDMDeserialiserAlg::TriggerEDMDeserialiserAlg(const std::string& name, ISvcLocator* pSvcLocator) :
   AthReentrantAlgorithm(name, pSvcLocator) {}
 
-TriggerEDMDeserialiserAlg::~TriggerEDMDeserialiserAlg() {}
-
 StatusCode TriggerEDMDeserialiserAlg::initialize() {
   ATH_CHECK( m_resultKey.initialize() );
   ATH_CHECK( m_clidSvc.retrieve() );
@@ -90,8 +151,11 @@ StatusCode TriggerEDMDeserialiserAlg::finalize() {
 StatusCode TriggerEDMDeserialiserAlg::execute(const EventContext& context) const {    
 
   auto resultHandle = SG::makeHandle( m_resultKey, context );
-  if ( resultHandle.isValid() )
-    ATH_MSG_DEBUG("Obtained HLTResultMT " << m_resultKey.key() );
+  if ( not resultHandle.isValid() ) {
+    ATH_MSG_ERROR("Failed to obtain HLTResultMT with key " << m_resultKey.key());
+    return StatusCode::FAILURE;
+  }
+  ATH_MSG_DEBUG("Obtained HLTResultMT with key " << m_resultKey.key());
   
   const Payload* dataptr = nullptr;
   // TODO: check if there are use cases where result may be not available in some events and this is not an issue at all
@@ -106,13 +170,13 @@ StatusCode TriggerEDMDeserialiserAlg::execute(const EventContext& context) const
 StatusCode TriggerEDMDeserialiserAlg::deserialise(   const Payload* dataptr  ) const {
 
   size_t  buffSize = m_initialSerialisationBufferSize;
-  std::unique_ptr<char[]> buff( new char[buffSize] );
+  std::unique_ptr<char[]> buff = std::make_unique<char[]>(buffSize);
 
   // returns a char* buffer that is at minimum as large as specified in the argument
-  auto resize = [&]( size_t neededSize )  {
+  auto resize = [&buffSize, &buff]( const size_t neededSize ) -> void {
 		  if ( neededSize > buffSize ) {
 		    buffSize = neededSize;
-		    buff.reset( new char[buffSize] );
+		    buff = std::make_unique<char[]>(buffSize);
 		  }
 		};  
 
@@ -127,21 +191,21 @@ StatusCode TriggerEDMDeserialiserAlg::deserialise(   const Payload* dataptr  ) c
   PayloadIterator start = dataptr->begin();
   while ( start != dataptr->end() )  {
     fragmentCount++;
-    const CLID clid{ collectionCLID( start ) };
+    const CLID clid{ PayloadHelpers::collectionCLID( start ) };
     std::string transientTypeName;
     ATH_CHECK( m_clidSvc->getTypeNameOfID( clid, transientTypeName ) );
-    const std::vector<std::string> descr{ collectionDescription( start ) };
+    const std::vector<std::string> descr{ PayloadHelpers::collectionDescription( start ) };
     ATH_CHECK( descr.size() == 2 );
     std::string persistentTypeName{ descr[0] };
     const std::string key{ descr[1] };
-    const size_t bsize{ dataSize( start ) };
+    const size_t bsize{ PayloadHelpers::dataSize( start ) };
 
     ATH_MSG_DEBUG( "" );
     ATH_MSG_DEBUG( "fragment: " << fragmentCount << " type: "<< transientTypeName << " persistent type: " <<  persistentTypeName << " key: " << key << " size: " << bsize );
     resize( bsize );
-    toBuffer( start, buff.get() );
+    PayloadHelpers::toBuffer( start, buff.get() );
 
-    start = toNextFragment( start ); // point the start to the next chunk, irrespectively of what happens in deserialisation below
+    start = PayloadHelpers::toNextFragment( start ); // point the start to the next chunk, irrespectively of what happens in deserialisation below
         
     RootType classDesc = RootType::ByNameNoQuiet( persistentTypeName );
     ATH_CHECK( classDesc.IsComplete() );
@@ -263,7 +327,8 @@ StatusCode TriggerEDMDeserialiserAlg::checkSanity( const std::string& transientT
   if ( count == 0 ) {
     ATH_MSG_ERROR( "Could not recognise the kind of container " << transientTypeName );
     return StatusCode::FAILURE;
-  } else if (count > 1 ) {
+  }
+  if (count > 1 ) {
     ATH_MSG_ERROR( "Ambiguous container kind deduced from the transient type name " << transientTypeName );
     ATH_MSG_ERROR( "Recognised type as: " 
 		   << (isxAODInterfaceContainer ?" xAOD Interface Context":"" ) 
@@ -276,26 +341,6 @@ StatusCode TriggerEDMDeserialiserAlg::checkSanity( const std::string& transientT
 }
 
 
-size_t TriggerEDMDeserialiserAlg::nameLength( TriggerEDMDeserialiserAlg::PayloadIterator start ) const {
-  return *( start + NameLengthOffset);
-}
-
-std::vector<std::string> TriggerEDMDeserialiserAlg::collectionDescription( TriggerEDMDeserialiserAlg::PayloadIterator start ) const {
-  StringSerializer ss;
-  std::vector<std::string> labels;
-  ss.deserialize( start + NameOffset, start + NameOffset + nameLength(start), labels );
-  return labels;
-}
-size_t TriggerEDMDeserialiserAlg::dataSize( TriggerEDMDeserialiserAlg::PayloadIterator start ) const {
-  return *( start + NameOffset + nameLength( start ) );
-}
-
-void TriggerEDMDeserialiserAlg::toBuffer( TriggerEDMDeserialiserAlg::PayloadIterator start, char* buffer ) const {
-  // move to the beginning of the buffer memory
-  PayloadIterator dataStart =  start + NameOffset + nameLength(start) + 1 /*skip size*/;
-  // we rely on continuous memory layout of std::vector ...
-  std::memcpy( buffer, &(*dataStart), dataSize( start ) );
-}
 
 void TriggerEDMDeserialiserAlg::add_bs_streamerinfos(){
   std::string extStreamerInfos = "bs-streamerinfos.root";
@@ -313,8 +358,9 @@ void TriggerEDMDeserialiserAlg::add_bs_streamerinfos(){
     TStreamerInfo* inf = dynamic_cast<TStreamerInfo*>(infObj);
     inf->BuildCheck();
     TClass *cl = inf->GetClass();
-    if (cl)
+    if (cl != nullptr) {
       ATH_MSG_DEBUG( "external TStreamerInfo for " << cl->GetName()
 		     << " checksum: " << std::hex << inf->GetCheckSum()  );
+    }
   }
 }
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h
index e0c03e0a506bf7674dabd801a45679a084ffe594..ba43f5e77c08e250357b803893ede32ad4d785ca 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h
@@ -32,13 +32,14 @@ class TriggerEDMDeserialiserAlg : public AthReentrantAlgorithm {
 public:
   class WritableAuxStore;
 
-  enum Offsets {
-    CLIDOffset = 1,
-    NameLengthOffset = 2,
-    NameOffset = 3
-  };
+  using Payload = std::vector<uint32_t>;
+  using PayloadIterator = Payload::const_iterator;
+  static constexpr size_t CLIDOffset = 1;
+  static constexpr size_t NameLengthOffset = 2;
+  static constexpr size_t NameOffset = 3;
+
   TriggerEDMDeserialiserAlg(const std::string& name, ISvcLocator* pSvcLocator);
-  virtual ~TriggerEDMDeserialiserAlg() override;
+  virtual ~TriggerEDMDeserialiserAlg() override = default;
 
   virtual StatusCode initialize() override;
   virtual StatusCode execute(const EventContext& context) const override;
@@ -62,45 +63,6 @@ private:
 
   std::unique_ptr<TList> m_streamerInfoList;
 
-  typedef  std::vector<uint32_t> Payload;
-  typedef  std::vector<uint32_t>::const_iterator PayloadIterator;
-  
-  /**
-   * returns starting point of the next fragment, can be == end()
-   * intended to be used like this: start = advance(start); if ( start != data.end() )... decode else ... done
-   **/  
-  inline PayloadIterator toNextFragment( PayloadIterator start ) const {
-    return start + (*start) ; // point ahead by the number of words pointed to by start iterator
-  }
-  /**
-   * CLID of the collection stored in the next fragment
-   **/
-  inline CLID collectionCLID( PayloadIterator start  ) const {
-    return *( start + CLIDOffset );
-  }
-  /**
-   * Length of the serialised name payload
-   **/
-  size_t nameLength( TriggerEDMDeserialiserAlg::PayloadIterator start ) const;
-
-  /**
-   * string description of the collection stored in the next fragment, 
-   * returns persistent type name and the SG key
-   **/
-  std::vector<std::string> collectionDescription( PayloadIterator start ) const;
-
-  /**
-   * size of the buffer that is needed to decode next fragment data content
-   * @warning measured in bytes
-   **/  
-  size_t dataSize( PayloadIterator start ) const;
-
-  /**
-   * copies fragment to the buffer, no size checking, use above to do so
-   **/  
-  void toBuffer( PayloadIterator start, char* buffer ) const;
-
-
   /**
    * Performs actual deserialisation loop
    */ 
@@ -110,13 +72,13 @@ private:
    * Handle decoration
    */
   StatusCode deserialiseDynAux( const std::string& transientTypeName, const std::string& persistentTypeName, const std::string& decorationName, 
-				void* data,  WritableAuxStore* currentAuxStore, SG::AuxVectorBase* interface ) const;
+				void* obj,  WritableAuxStore* currentAuxStore, SG::AuxVectorBase* interface ) const;
 
 
   /**
    * Checker for data integrity, one and only one of the passed booleans can be true, else FAILURE is returned and relevant diagnostics printed
    */
-  StatusCode checkSanity( const std::string& tn, bool isxAODInterfaceContainer, bool isxAODAuxContainer, bool isDecoration, bool isTPContainer ) const;
+  StatusCode checkSanity( const std::string& transientTypeName, bool isxAODInterfaceContainer, bool isxAODAuxContainer, bool isDecoration, bool isTPContainer ) const;
   
 
 
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMSerialiserTool.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMSerialiserTool.cxx
index 18a291418dd1da63c072fe9c0af52feb97c1e513..4aefbbcd405c54fdb3e4d1f6a949d13745a29fea 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMSerialiserTool.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMSerialiserTool.cxx
@@ -32,8 +32,6 @@ TriggerEDMSerialiserTool::TriggerEDMSerialiserTool( const std::string& type,
 						    const IInterface* parent )
   : base_class( type, name, parent ) {}
 
-TriggerEDMSerialiserTool::~TriggerEDMSerialiserTool() {}
-
 StatusCode TriggerEDMSerialiserTool::initialize() {
   // Initialise tools and services
   ATH_CHECK( m_serializerSvc.retrieve() );
@@ -147,22 +145,24 @@ StatusCode TriggerEDMSerialiserTool::addCollectionToSerialise(const std::string&
       if (!allVars.empty()) {
         std::set<std::string> variableNames;
         boost::split( variableNames, allVars, [](const char c){ return c == '.'; } );
-        for ( auto el: variableNames ) {
-          ATH_MSG_DEBUG( " \"" << el << "\""  );
+        if (msgLvl(MSG::DEBUG)) {
+          for ( const auto& el: variableNames ) {
+            ATH_MSG_DEBUG( " \"" << el << "\""  );
+          }
         }
         sel.selectAux( variableNames );
       }
-      addressVec.emplace_back( transientType, persistentType, clid, key, moduleIdVec, Address::xAODAux, sel );
+      addressVec.push_back( {transientType, persistentType, clid, key, moduleIdVec, Address::Category::xAODAux, sel} );
     } else {
-    addressVec.emplace_back( transientType, persistentType, clid, key, moduleIdVec, Address::xAODInterface, xAOD::AuxSelection() );
+    addressVec.push_back( {transientType, persistentType, clid, key, moduleIdVec, Address::Category::xAODInterface} );
     }
   } else { // an old T/P type
-    addressVec.emplace_back( transientType, persistentType, clid, key, moduleIdVec, Address::OldTP, xAOD::AuxSelection() );
+    addressVec.push_back( {transientType, persistentType, clid, key, moduleIdVec, Address::Category::OldTP} );
   }
   return StatusCode::SUCCESS;
 }
 
-StatusCode TriggerEDMSerialiserTool::makeHeader(const Address& address, std::vector<uint32_t>& buffer  ) const {
+StatusCode TriggerEDMSerialiserTool::makeHeader(const Address& address, std::vector<uint32_t>& buffer  ) {
   buffer.push_back(0); // fragment size placeholder
   buffer.push_back( address.clid ); // type info via CLID
 
@@ -244,19 +244,18 @@ StatusCode TriggerEDMSerialiserTool::serialiseDynAux( DataObject* dObj, const Ad
     if ( mem == nullptr or sz == 0 ) {
       ATH_MSG_ERROR( "Serialisation of " << address.persType <<"#" << address.key << "."<< decorationName << " unsuccessful" );
       return StatusCode::FAILURE;
-    } else {
-      ATH_MSG_DEBUG( "Serialised " << address.persType <<"#" << address.key << "."<< decorationName  << " memory size " << sz );
     }
+    ATH_MSG_DEBUG( "Serialised " << address.persType <<"#" << address.key << "."<< decorationName  << " memory size " << sz );
 
     std::vector<uint32_t> fragment;
 
-    Address auxAddress = { typeName, cls->GetName(), clid, decorationName, address.moduleIdVec, Address::xAODDecoration };
+    Address auxAddress { typeName, cls->GetName(), clid, decorationName, address.moduleIdVec, Address::Category::xAODDecoration };
 
     ATH_CHECK( makeHeader( auxAddress, fragment ) );
     ATH_CHECK( fillPayload( mem, sz, fragment ) );
     fragment[0] = fragment.size();
 
-    if ( mem ) delete [] static_cast<const char*>( mem );
+    if ( mem != nullptr ) delete [] static_cast<const char*>( mem );
 
     buffer.insert( buffer.end(), fragment.begin(), fragment.end() );
     ++nDynWritten;
@@ -282,7 +281,7 @@ StatusCode TriggerEDMSerialiserTool::serialiseContainer( void* data, const Addre
   std::vector<uint32_t> fragment;
   ATH_CHECK( makeHeader( address, fragment ) );
   ATH_CHECK( fillPayload( mem, sz, fragment ) );
-  if ( mem ) delete [] static_cast<const char*>( mem );
+  if ( mem != nullptr ) delete [] static_cast<const char*>( mem );
 
 
   ATH_MSG_DEBUG( address.transType << "#" << address.key << " Fragment size :" << fragment.size()*sizeof(uint32_t) << " bytes");
@@ -305,7 +304,7 @@ StatusCode TriggerEDMSerialiserTool::serialisexAODAuxContainer( void* data,
   static const RootType interface_c = RootType::ByNameNoQuiet( "xAOD::AuxContainerBase" );
 
   void* data_interface = classDesc.Cast (interface_c, data, true);
-  if (data_interface) {
+  if (data_interface != nullptr) {
     const xAOD::AuxContainerBase* store = reinterpret_cast<const xAOD::AuxContainerBase*> (data_interface);
     copy = classDesc.Construct();
     void* copy_interface = classDesc.Cast (interface, copy, true);
@@ -340,7 +339,7 @@ StatusCode TriggerEDMSerialiserTool::serialiseTPContainer( void* data, const Add
   ATH_MSG_DEBUG("TP Container, converting from: " <<  address.transType << " to " << address.persType  );
   std::string converterPersistentType;
   void * persistent = m_tpTool->convertTP( address.transType,  data, converterPersistentType );
-  ATH_CHECK( persistent != 0 );
+  ATH_CHECK( persistent != nullptr );
   ATH_CHECK ( converterPersistentType == address.persType );
   ATH_CHECK( serialiseContainer( persistent, address, buffer ) );
 
@@ -361,16 +360,16 @@ StatusCode TriggerEDMSerialiserTool::serialise( const Address& address, std::vec
   }
   ATH_MSG_DEBUG("Obtained raw pointer " << rawptr );
 
-  if ( address.category == Address::xAODInterface ) {
+  if ( address.category == Address::Category::xAODInterface ) {
     return serialiseContainer( rawptr, address, buffer );
-  } else if ( address.category == Address::xAODAux ) {
+  }
+  if ( address.category == Address::Category::xAODAux ) {
     return serialisexAODAuxContainer( rawptr, address, buffer, evtStore );
-  } else if ( address.category == Address::OldTP ) {
+  } 
+  if ( address.category == Address::Category::OldTP ) {
     return serialiseTPContainer( rawptr, address, buffer );
-  } else {
-    ATH_MSG_ERROR("Unknown Address category - neither of xAODInterface, xAODAux, OldTP");
-    return StatusCode::FAILURE;
-  }
+  } 
+  ATH_MSG_ERROR("Unknown Address category - neither of xAODInterface, xAODAux, OldTP");
   return StatusCode::FAILURE;
 }
 
@@ -382,7 +381,7 @@ StatusCode TriggerEDMSerialiserTool::fill( HLT::HLTResultMT& resultToFill, const
     return StatusCode::FAILURE;
   }
 
-  SGImplSvc* evtStore = static_cast<SGImplSvc*>(Atlas::getExtendedEventContext(ctx).proxy());
+  SGImplSvc* evtStore = dynamic_cast<SGImplSvc*>(Atlas::getExtendedEventContext(ctx).proxy());
   ATH_CHECK( evtStore != nullptr );
 
   // Map storing information to be written out in case of truncation for each module
@@ -420,11 +419,11 @@ StatusCode TriggerEDMSerialiserTool::fill( HLT::HLTResultMT& resultToFill, const
       if (resultToFill.getTruncatedModuleIds().count(id)==0) {
         ATH_MSG_DEBUG("Module " << id << " payload after inserting " << address.persTypeName() << " has "
                       << resultToFill.getSerialisedData().at(id).size()*sizeof(uint32_t) << " bytes");
-        truncationInfoMap[id].emplace_back(&address, thisFragmentSize, true);
+        truncationInfoMap[id].push_back({&address, thisFragmentSize, true});
       }
       else {
         ATH_MSG_WARNING("HLTResult with module ID " << id << " truncated - could not add " << address.persTypeName());
-        truncationInfoMap[id].emplace_back(&address, thisFragmentSize, false);
+        truncationInfoMap[id].push_back({&address, thisFragmentSize, false});
       }
     }
   }
@@ -505,7 +504,7 @@ StatusCode TriggerEDMSerialiserTool::fillDebugInfo(const TruncationInfoMap& trun
         sizeSum += truncationInfo.size;
         typeNameVec(*debugInfoThisModule).push_back(truncationInfo.addrPtr->persTypeName());
         sizeVec(*debugInfoThisModule).push_back(truncationInfo.size);
-        isRecordedVec(*debugInfoThisModule).push_back(truncationInfo.recorded);
+        isRecordedVec(*debugInfoThisModule).push_back(static_cast<char>(truncationInfo.recorded));
         if (truncationInfo.recorded && truncationInfo.size > largestRecorded.second) {
           largestRecorded = {truncationInfo.addrPtr->persTypeName(), truncationInfo.size};
         }
@@ -549,12 +548,13 @@ StatusCode TriggerEDMSerialiserTool::fillDebugInfo(const TruncationInfoMap& trun
   return StatusCode::SUCCESS;
 }
 
-std::string TriggerEDMSerialiserTool::version( const std::string& name ) const {
+std::string TriggerEDMSerialiserTool::version( const std::string& name ) {
   if ( name.find("DataVector") != std::string::npos ) {
-    size_t start = name.find("_");
-    return name.substr( start, name.find(">") - start );
+    size_t start = name.find('_');
+    return name.substr( start, name.find('>') - start );
+  }
+  if ( name.find('_') != std::string::npos ) {
+    return name.substr( name.find('_') );
   }
-  if ( name.find("_") != std::string::npos )
-    return name.substr( name.find("_") );
   return "";
 }
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMSerialiserTool.h b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMSerialiserTool.h
index 42a4dade53985fbd901c0b013ef307e6698c834a..03ff663914a41a1fd5f7740f7b6f8d7ce7fb9b4d 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMSerialiserTool.h
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMSerialiserTool.h
@@ -42,7 +42,7 @@ class TriggerEDMSerialiserTool: public extends<AthAlgTool, HLTResultMTMakerTool>
 	     const std::string& name,
 	     const IInterface* parent );
 
-  virtual ~TriggerEDMSerialiserTool();
+  virtual ~TriggerEDMSerialiserTool() override = default;
   virtual StatusCode fill( HLT::HLTResultMT& resultToFill, const EventContext& ctx ) const override;
 
   virtual StatusCode  initialize() override;
@@ -83,33 +83,18 @@ class TriggerEDMSerialiserTool: public extends<AthAlgTool, HLTResultMTMakerTool>
    * Internal structure to keep configuration organised conveniently
    **/
   struct Address {
-    enum Category { xAODInterface, xAODAux, OldTP, xAODDecoration, None };
-    Address( const std::string& transType_,
-	     const std::string& persType_,
-	     const CLID clid_,
-	     const std::string& key_,
-	     const std::vector<uint16_t> module_={},
-	     const Category category_ = None,
-	     const xAOD::AuxSelection& sel_ = {} )
-    : transType(transType_),
-      persType(persType_),
-      clid(clid_),
-      key(key_),
-      moduleIdVec(module_),
-      category(category_),
-      sel(sel_){}
+    enum class Category : uint8_t { xAODInterface, xAODAux, OldTP, xAODDecoration, None };
 
     std::string transType;
     std::string persType; // actual versioned type
     CLID clid;
     std::string key;
-    std::vector<uint16_t> moduleIdVec;
+    std::vector<uint16_t> moduleIdVec{};
+    Category category{Category::None};
+    xAOD::AuxSelection sel{}; //!< xAOD dynamic variables selection, relevant only for xAODAux category
 
-    Category category;
-    xAOD::AuxSelection sel = {}; //!< xAOD dynamic variables selection, relevant only for xAODAux category
-
-    const std::string transTypeName() const {return transType+"#"+key;}
-    const std::string persTypeName() const {return persType+"#"+key;}
+    std::string transTypeName() const {return transType+"#"+key;}
+    std::string persTypeName() const {return persType+"#"+key;}
   };
 
   /**
@@ -117,8 +102,6 @@ class TriggerEDMSerialiserTool: public extends<AthAlgTool, HLTResultMTMakerTool>
    * Internal structure to keep information for truncation debugging
    **/
   struct TruncationInfo {
-    TruncationInfo(const Address* a, const size_t s, const bool r)
-    : addrPtr(a), size(s), recorded(r) {}
     const Address* addrPtr{nullptr};
     size_t size{0};
     bool recorded{false};
@@ -147,7 +130,7 @@ class TriggerEDMSerialiserTool: public extends<AthAlgTool, HLTResultMTMakerTool>
   /**
    * Given the ID of the collection (in address arg) insert basic streaming info into the buffer.
    */
-  StatusCode makeHeader( const TriggerEDMSerialiserTool::Address& address, std::vector<uint32_t>& buffer  ) const;
+  static StatusCode makeHeader( const TriggerEDMSerialiserTool::Address& address, std::vector<uint32_t>& buffer  );
 
   /**
    * Copy bytes from the memory into the buffer converting from char[] to uint32_t[]
@@ -200,7 +183,7 @@ class TriggerEDMSerialiserTool: public extends<AthAlgTool, HLTResultMTMakerTool>
   /**
    * Obtain version from the actual type name
    */
-  std::string version( const std::string& name ) const;
+  static std::string version( const std::string& name );
 
 };
 
diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TruncationAnalysisAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/TruncationAnalysisAlg.cxx
index f92ada5b39011f7109aa702286972e0d990b4106..15c4f45eeb6bfa8ff623f4c0e340da9f177c80dc 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/src/TruncationAnalysisAlg.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/src/TruncationAnalysisAlg.cxx
@@ -9,8 +9,6 @@
 
 namespace {
   struct CollectionDebugInfo {
-    CollectionDebugInfo(std::string_view n, const uint32_t s, const bool r)
-    : name(n), size(s), isRecorded(r) {}
     std::string_view name;
     uint32_t size;
     bool isRecorded;
@@ -52,9 +50,9 @@ StatusCode TruncationAnalysisAlg::execute(const EventContext& context) const {
     // Collect name+size+isRecorded in one structure and sort by descending size
     std::vector<CollectionDebugInfo> collections;
     for (size_t i=0; i<typeNameVec(*info).size(); ++i) {
-      collections.emplace_back(typeNameVec(*info).at(i),
-                               sizeVec(*info).at(i),
-                               static_cast<bool>(isRecordedVec(*info).at(i)));
+      collections.push_back({typeNameVec(*info).at(i),
+                             sizeVec(*info).at(i),
+                             static_cast<bool>(isRecordedVec(*info).at(i))});
     }
     std::sort(collections.begin(), collections.end(), cmpCollections);
 
diff --git a/Trigger/TrigSteer/TrigOutputHandling/test/schema_evolution_test.cxx b/Trigger/TrigSteer/TrigOutputHandling/test/schema_evolution_test.cxx
index bc8a1310390d0998c0165a037ab1af2d0226a456..3a316b6811363256772f1a781a4aba3f0ec95b9e 100644
--- a/Trigger/TrigSteer/TrigOutputHandling/test/schema_evolution_test.cxx
+++ b/Trigger/TrigSteer/TrigOutputHandling/test/schema_evolution_test.cxx
@@ -36,13 +36,15 @@ StatusCode tester( TriggerEDMSerialiserTool* ser) {
     cluster->setE277(0);
     
     // got trivial object to serialise, need to create addresses
-    TriggerEDMSerialiserTool::Address interfaceAddress( "xAOD::TrigEMClusterContainer", "xAOD::TrigEMClusterContainer_v1", 
-							1264979038/*clid*/, "HLT_one", {}, 
-							TriggerEDMSerialiserTool::Address::xAODInterface );
-
-    TriggerEDMSerialiserTool::Address auxAddress( "xAOD::TrigEMClusterAuxContainer", "xAOD::TrigEMClusterAuxContainer_v1", 
-						  1111649561/*clid*/, "HLT_oneAux.", {}, 
-						  TriggerEDMSerialiserTool::Address::xAODAux );
+    TriggerEDMSerialiserTool::Address interfaceAddress{
+      "xAOD::TrigEMClusterContainer", "xAOD::TrigEMClusterContainer_v1",
+      1264979038/*clid*/, "HLT_one", {},
+      TriggerEDMSerialiserTool::Address::Category::xAODInterface};
+
+    TriggerEDMSerialiserTool::Address auxAddress{
+      "xAOD::TrigEMClusterAuxContainer", "xAOD::TrigEMClusterAuxContainer_v1",
+      1111649561/*clid*/, "HLT_oneAux.", {},
+      TriggerEDMSerialiserTool::Address::Category::xAODAux};
      
     auto status = ser->serialiseContainer( (void*)em, interfaceAddress, serialisedData );
     VALUE( status ) EXPECTED( StatusCode::SUCCESS );
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/CMakeLists.txt b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/CMakeLists.txt
index dd086bcc87c1216ef3d4fbaac804cc0a25a04963..39c5b7d102e512c9895b2fb41ae9a926b761cdc8 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/CMakeLists.txt
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/CMakeLists.txt
@@ -13,13 +13,13 @@ atlas_add_library( L1TopoCoreSim
                    Root/*.cxx
                    PUBLIC_HEADERS L1TopoCoreSim
                    PRIVATE_INCLUDE_DIRS ${Boost_INCLUDE_DIRS} ${ROOT_INCLUDE_DIRS}
-                   LINK_LIBRARIES ${ROOT_LIBRARIES} L1TopoCommon L1TopoConfig L1TopoEvent L1TopoInterfaces TrigConfBase
+                   LINK_LIBRARIES ${ROOT_LIBRARIES} L1TopoCommon L1TopoConfig L1TopoEvent L1TopoInterfaces TrigConfBase TrigConfData
                    PRIVATE_LINK_LIBRARIES L1TopoHardware L1TopoAlgorithms )
 
 atlas_add_executable( TrigConfTopoStandAlone
                       src/test/TopoStandAlone.cxx
-                      LINK_LIBRARIES L1TopoCoreSim TrigConfBase )
+                      LINK_LIBRARIES L1TopoCoreSim TrigConfBase TrigConfIO TrigConfData)
 
 atlas_add_executable( TrigConfTopoTestSteeringConfig
                       src/test/TopoTestSteeringConfig.cxx
-                      LINK_LIBRARIES L1TopoCoreSim )
+                      LINK_LIBRARIES L1TopoCoreSim TrigConfBase TrigConfIO TrigConfData)
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/DecisionConnector.h b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/DecisionConnector.h
index cf6143617d635fb7752132cbef679e24582a4472..f66de22f6e45dc0531cc61192865b67d0d02072a 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/DecisionConnector.h
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/DecisionConnector.h
@@ -1,4 +1,6 @@
-// Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
 
 #ifndef L1TopoCoreSim_DecisionConnector
 #define L1TopoCoreSim_DecisionConnector
@@ -7,6 +9,7 @@
 
 #include "L1TopoInterfaces/Decision.h"
 #include "L1TopoConfig/L1TopoConfigOutputList.h"
+#include "TrigConfData/L1Connector.h"
 
 #include <vector>
 #include <string>
@@ -37,7 +40,7 @@ namespace TCS {
 
       bool decision(const std::string & trigger) const;
 
-      const std::vector<TXC::TriggerLine> & triggers() const { return m_triggers; }
+      const std::vector<TrigConf::TriggerLine> & triggers() const { return m_triggers; }
 
       // output data
       void attachOutputData(const std::vector<TOBArray *>&);
@@ -62,7 +65,7 @@ namespace TCS {
 
       TCS::DecisionAlg* m_decisionAlgorithm;
 
-      std::vector<TXC::TriggerLine> m_triggers;
+      std::vector<TrigConf::TriggerLine> m_triggers;
 
       // attached output data
       std::vector<TOBArray const *>  m_outputData;
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/GlobalDecision.h b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/GlobalDecision.h
index 31903997479709a83f66ec3b70751424a8368a08..b50a84421f596098d2c4e7b7bd9b06c5fc34e34b 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/GlobalDecision.h
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/GlobalDecision.h
@@ -1,4 +1,7 @@
-// Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
+
 
 #ifndef L1TopoCoreSim_GlobalDecision
 #define L1TopoCoreSim_GlobalDecision
@@ -8,6 +11,8 @@
 #include "L1TopoCommon/StatusCode.h"
 #include "L1TopoConfig/L1TopoConfigOutputList.h"
 
+#include "TrigConfData/L1Connector.h"
+
 #include <iostream>
 #include <vector>
 #include <set>
@@ -29,22 +34,22 @@ namespace TCS {
 
    class GlobalDecision : public TrigConf::TrigConfMessaging {
    public:
-      GlobalDecision();
+      GlobalDecision(const std::string & name = "L1TopoGlobalDecision");
 
-      uint64_t decision(unsigned int module) const { return m_decision[module]; }
+      uint64_t decision_field(const std::string & connName) const { return m_decision.find(connName)->second; }
 
-      uint32_t decision(unsigned int module, unsigned int clock) const;
+      uint32_t decision_field(std::string connName, unsigned int clock) const;
 
-      bool passed(unsigned int module, unsigned int bit) const { return ( ( (uint64_t)0x1 << bit) & m_decision[module]) != 0; }
-      uint64_t overflow(unsigned int module) const { return m_overflow[module]; }
-      uint32_t overflow(unsigned int module, unsigned int clock) const;
-      bool overflowed(unsigned int module, unsigned int bit) const { return ( ( (uint64_t)0x1 << bit) & m_overflow[module]) != 0; }
+      bool passed(std::string connName, unsigned int bit) const { return ( ( (uint64_t)0x1 << bit) & m_decision.find(connName)->second) != 0; }
+      uint64_t overflow_field(std::string connName) const { return m_overflow.find(connName)->second; }
+      uint32_t overflow_field(std::string connName, unsigned int clock) const;
+      bool overflowed(std::string connName, unsigned int bit) const { return ( ( (uint64_t)0x1 << bit) & m_overflow.find(connName)->second) != 0; }
 
       const Decision & decision(const std::string & algName) const;
 
       bool isValid() const { return m_valid; }
 
-      void setTriggerLines(const std::vector<TXC::TriggerLine> & triggers) { m_triggers = triggers; }
+      void setTriggerLines(const std::vector<TrigConf::TriggerLine> & triggers);
 
       StatusCode collectDecision(const std::set<DecisionConnector*> & outconn);
 
@@ -54,16 +59,16 @@ namespace TCS {
    private:
       friend std::ostream& operator<<(std::ostream&, const TCS::GlobalDecision &);
 
-      // 64 bit decision bit field
-      uint64_t m_decision[3] {0,0,0};
-      // 64 bit overflow bit field
-      uint64_t m_overflow[3] {0,0,0};
+      // 64 bit decision bit field - map connector name-decision field
+      std::map<std::string,uint64_t> m_decision;
+      // 64 bit overflow bit field - map connector name-overflow field
+      std::map<std::string,uint64_t> m_overflow;
       // flags if the decision field is up to date
       // set by @collectDecision(), unset by @resetDecision()
       bool m_valid {false};
 
       // trigger lines
-      std::vector<TXC::TriggerLine> m_triggers;
+      std::vector<TrigConf::TriggerLine> m_triggers;
    };
 
 }
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoCoreSimResult.h b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoCoreSimResult.h
index 88aecb9e2eb424adffc8d650a18b315a4c302309..de178edb6796cc15aa2ec94cb630a08ba14a66d9 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoCoreSimResult.h
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoCoreSimResult.h
@@ -10,6 +10,8 @@
 
 #include "TrigConfBase/TrigConfMessaging.h"
 
+#include "TrigConfData/L1Menu.h"
+
 #include <iostream>
 #include "L1TopoCommon/StatusCode.h"
 #include "L1TopoCoreSim/GlobalDecision.h"
@@ -43,7 +45,7 @@ namespace TCS {
 
       const std::vector<const TCS::TOBArray*> & output(const std::string & connName) const;
 
-      StatusCode setupFromMenu(const TXC::L1TopoMenu & menu, const std::map<std::string, TCS::DecisionConnector*>& outputConnectorMap);
+      StatusCode setupFromMenu(const std::map<std::string, TCS::DecisionConnector*>& outputConnectorMap);
 
       StatusCode collectResult(TCS::DecisionConnector* outputConn = nullptr );
 
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoSteering.h b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoSteering.h
index 042c4e20b000d6f27b0b9485a533df6057724a63..0f035f6597e5bd16b6a663f92ec80d819195d618 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoSteering.h
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoSteering.h
@@ -1,4 +1,6 @@
-// Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
 
 #ifndef L1TopoCoreSim_TopoSteering
 #define L1TopoCoreSim_TopoSteering
@@ -17,6 +19,9 @@
 #include "L1TopoCoreSim/TopoCoreSimResult.h"
 #include "L1TopoCoreSim/TopoSteeringStructure.h"
 
+// Menu related dependencies
+#include "TrigConfData/L1Menu.h"
+
 namespace TXC {
    class L1TopoMenu;
 }
@@ -48,16 +53,20 @@ namespace TCS {
 
       const TopoCoreSimResult & simulationResult() const { return m_simulationResult; }
 
+
       // @brief: build the execution structure and parameterspace from
       // the configuration
       StatusCode setupFromConfiguration(const TXC::L1TopoMenu& menu);
-     
+
+      StatusCode setupFromConfiguration(const TrigConf::L1Menu& l1menu);
+
       void setUseBitwise(bool useBitwise) { m_useBitwise = useBitwise; }
  
       // @brief: call the initialize function of the algorithms
       // will be called after the parameters are set and before the event loop starts
       StatusCode initializeAlgorithms();
 
+
       // run the topo simulation
       StatusCode executeEvent();
       
@@ -149,8 +158,9 @@ namespace TCS {
 
       std::bitset<numberOfL1TopoBits> m_triggerHdwBits;
       std::bitset<numberOfL1TopoBits> m_ovrflowHdwBits;
-
    };
-}
 
-#endif
+   
+} 
+
+#endif 
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoSteeringStructure.h b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoSteeringStructure.h
index 119c899410ad9c17321b720892bf858570fd3383..8aac19c35c5e14e52e8ada2414e366d82a33e190 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoSteeringStructure.h
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/L1TopoCoreSim/TopoSteeringStructure.h
@@ -3,6 +3,9 @@
 */
 #include "L1TopoCommon/StatusCode.h"
 
+#include "TrigConfData/L1Menu.h"
+#include "TrigConfData/L1TopoAlgorithm.h"
+
 #include <vector>
 #include <map>
 #include <string>
@@ -28,7 +31,7 @@ namespace TCS {
 
       ~TopoSteeringStructure();
 
-      StatusCode setupFromMenu(const TXC::L1TopoMenu& menu, bool debug = false);
+      StatusCode setupFromMenu(const TrigConf::L1Menu& l1menu, bool debug = false, bool legacy = false);
 
       // accessors
       bool isConfigured() const { return m_isConfigured; }
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/DecisionConnector.cxx b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/DecisionConnector.cxx
index 1dba9be38b4ace77b2abd6676b9a9bd4abef8ce9..ee648be0973d64ead097974551c34004a9b4167e 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/DecisionConnector.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/DecisionConnector.cxx
@@ -1,4 +1,6 @@
-// Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
 
 #include "L1TopoCoreSim/DecisionConnector.h"
 
@@ -24,7 +26,7 @@ DecisionConnector::~DecisionConnector() {
 bool
 TCS::DecisionConnector::decision(const std::string & trigger) const {
    unsigned int index(0);
-   for(const TXC::TriggerLine & tl : m_triggers) {
+   for(const TrigConf::TriggerLine & tl : m_triggers) {
       if(tl.name() == trigger)
          return m_decision.bit(index);
       ++index;
@@ -37,7 +39,7 @@ TCS::DecisionConnector::decision(const std::string & trigger) const {
 TCS::TOBArray const *
 TCS::DecisionConnector::output(const std::string & trigger) const {
    unsigned int index(0);
-   for(const TXC::TriggerLine & tl : m_triggers) {
+   for(const TrigConf::TriggerLine & tl : m_triggers) {
       if(tl.name() == trigger)
          return m_outputData[index];
       ++index;
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/GlobalDecision.cxx b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/GlobalDecision.cxx
index 5c59db406927d7f9c9064ce40b1a0bf97adc690e..e6068f8b5083ebf7832458c365679ffefc70c9b7 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/GlobalDecision.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/GlobalDecision.cxx
@@ -1,4 +1,6 @@
-// Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
 
 #include <iomanip>
 
@@ -10,33 +12,53 @@
 using namespace std;
 using namespace TCS;
 
+void
+GlobalDecision::setTriggerLines(const vector<TrigConf::TriggerLine> & triggers) {
+
+  m_triggers = triggers;
+  vector<string> connNames = {};
+  for (const TrigConf::TriggerLine & trigger : triggers){
+    auto it = find(connNames.begin(), connNames.end(), trigger.connName());
+    if (it == connNames.end()){
+      connNames.push_back(trigger.connName());
+      m_decision[trigger.connName()] = 0;
+    }
+  }
+}
+  
 uint32_t
-GlobalDecision::decision(unsigned int module, unsigned int clock) const {
-   if(clock==0) {
-      // lower 32 bit
-      return (uint32_t) (m_decision[module] & 0xffffffff);
-   } else {
-      // upper 32 bit
-      uint64_t clock1 = m_decision[module] & 0xffffffff00000000;
-      return (uint32_t) (clock1 >> 32);
+GlobalDecision::decision_field(string connName, unsigned int clock) const {
+   try {
+      if(clock==0) {
+         // lower 32 bit
+         return (uint32_t) (m_decision.at(connName) & 0xffffffff);
+      } else {
+         // upper 32 bit
+         uint64_t clock1 = m_decision.at(connName) & 0xffffffff00000000;
+         return (uint32_t) (clock1 >> 32);
+      }
+   }
+   catch(std::exception &) {
+      TRG_MSG_ERROR("Connector name " << connName << " unknown");
+      throw;
    }
 }
 
 uint32_t
-GlobalDecision::overflow(unsigned int module, unsigned int clock) const {
+GlobalDecision::overflow_field(string connName, unsigned int clock) const {
    if(clock==0) {
       // lower 32 bit
-      return (uint32_t) (m_overflow[module] & 0xffffffff);
+      return (uint32_t) (m_overflow.find(connName)->second & 0xffffffff);
    } else {
       // upper 32 bit
-      uint64_t clock1 = m_overflow[module] & 0xffffffff00000000;
+      uint64_t clock1 = m_overflow.find(connName)->second & 0xffffffff00000000;
       return (uint32_t) (clock1 >> 32);
    }
 }
 
 
-GlobalDecision::GlobalDecision() :
-   TrigConfMessaging("L1TopoGlobalDecision")
+GlobalDecision::GlobalDecision(const std::string &name) :
+   TrigConfMessaging(name)
 {}
 
 /****************************************************************
@@ -47,7 +69,7 @@ GlobalDecision::GlobalDecision() :
  *
  ****************************************************************/
 
-StatusCode
+TCS::StatusCode
 GlobalDecision::collectDecision(const set<DecisionConnector*> & outconn) {
    resetDecision();
 
@@ -56,34 +78,34 @@ GlobalDecision::collectDecision(const set<DecisionConnector*> & outconn) {
       const Decision& dec = conn->decision();
 
       unsigned int pos = 0; // for multi-output algorithms pos is the output index
-      for(const TXC::TriggerLine & trigger : conn->triggers() ) {
-
-         unsigned int bit = trigger.counter() % 64;  // trigger bit in module
+      for(const TrigConf::TriggerLine & trigger : conn->triggers() ) {
          
-         uint64_t & moduleDec = m_decision[trigger.module()];
-         uint64_t & moduleOvf = m_overflow[trigger.module()];
-         uint64_t mask(0x1);
+	      unsigned int position = trigger.startbit() + 32*trigger.fpga() + 16*trigger.clock();
 
-         //std::cout << "JOERG GlobalDecision::collectDecision: trigger line " << trigger.name() << " [counter="<<trigger.counter()<<"] on module " << trigger.module() << " and bit [0-63] " << bit << " -> dec " << dec << std::endl;
+         uint64_t & connectorDec = m_decision[trigger.connName()];
+         uint64_t & connectorOvf = m_overflow[trigger.connName()];
+         uint64_t mask(0x1);
 
          if( dec.bit(pos++) )  // bit set?
-            moduleDec |= (mask << bit);
+            connectorDec |= (mask << position);
          if( dec.overflow())
-            moduleOvf |= (mask << bit);
+            connectorOvf |= (mask << position);
       }
 
    }
    m_valid = true;
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
-StatusCode
+TCS::StatusCode
 GlobalDecision::resetDecision() {
-   m_decision[0] = m_decision[1] = m_decision[2] = 0;
-   m_overflow[0] = m_overflow[1] = m_overflow[2] = 0;
+   for(auto const& dec : m_decision)
+     m_decision[dec.first] = 0;
+   for(auto const& ovf : m_overflow)
+     m_overflow[ovf.first] = 0;
    m_valid = false;
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
@@ -96,18 +118,17 @@ operator<<(std::ostream& o, const TCS::GlobalDecision & dec) {
    if(!dec.isValid()) 
       o << "Note that the overall decision has not been calculated" << endl;
 
-   for(unsigned int module = 0; module<3; ++module)
-      o << "Overall decision module " << module << ": 0x" << right << hex << setfill('0') << setw(16) << dec.decision(module) << std::dec << setfill(' ') << endl;
-
+   for(auto const& itdec : dec.m_decision)
+      o << "Overall decision for connector " << itdec.first << ": 0x" << right << hex << setfill('0') << setw(16) << dec.decision_field(itdec.first) << std::dec << setfill(' ') << endl;
    
    if(dec.isValid()) {
-      for(const TXC::TriggerLine & trigger : dec.m_triggers)
-         o << "  " << setw(30) << left << trigger.name() << "  " << (dec.passed(trigger.module(), trigger.counter() % 64) ? "pass" : "fail") << endl;
+     for(const TrigConf::TriggerLine & trigger : dec.m_triggers){
+	 unsigned int position = trigger.startbit() + 32*trigger.fpga() + 16*trigger.clock();
+	 o << "  " << setw(30) << left << trigger.name() << "  " << (dec.passed(trigger.connName(), position) ? "pass" : "fail") << endl;}
    } else {
-      for(const TXC::TriggerLine & trigger : dec.m_triggers)
-         o << "  " << setw(30) << left << trigger.name() << "  unset" << endl;
+      for(const TrigConf::TriggerLine & trigger : dec.m_triggers)
+	o << "  " << setw(30) << left << trigger.name() << "  unset" << endl;
    }
-   
    return o;
 }
 //----------------------------------------------------------
@@ -117,17 +138,17 @@ GlobalDecision::print() const {
    if(!isValid()) 
       TRG_MSG_INFO("Note that the overall decision has not been calculated");
 
-   for(unsigned int module = 0; module<3; ++module)
-      TRG_MSG_INFO("Overall decision module " << module << ": 0x" << right << hex << setfill('0') << setw(16) << decision(module) << std::dec << setfill(' '));
+   for(auto const& dec : m_decision)
+      TRG_MSG_INFO("Overall decision from connector " << dec.first << ": 0x" << right << hex << setfill('0') << setw(16) << decision_field(dec.first) << std::dec << setfill(' '));
 
-   
    if(isValid()) {
-      for(const TXC::TriggerLine & trigger : m_triggers)
-         TRG_MSG_INFO("      " << setw(30) << left << trigger.name() << "  " << (passed(trigger.module(), trigger.counter() % 64) ? "pass" : "fail") );
+      for(const TrigConf::TriggerLine & trigger : m_triggers){
+	 unsigned int position = trigger.startbit() + 32*trigger.fpga() + 16*trigger.clock();
+ 	 TRG_MSG_INFO("      " << setw(30) << left << trigger.name() << "  " << (passed(trigger.connName(), position) ? "pass" : "fail") );}
    } else {
-      for(const TXC::TriggerLine & trigger : m_triggers)
+      for(const TrigConf::TriggerLine & trigger : m_triggers)
          TRG_MSG_INFO("      " << setw(30) << left << trigger.name() << "  unset" );
    }
-   
 }
+
 }
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoCoreSimResult.cxx b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoCoreSimResult.cxx
index f1dcd5ee5395193680b12047d826906b2edd9b6c..fe17f5cfeaf5d1956d57b605e3e2f272662c3936 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoCoreSimResult.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoCoreSimResult.cxx
@@ -15,6 +15,8 @@
 
 #include "L1TopoCommon/Exception.h"
 
+#include "TrigConfData/L1Menu.h"
+
 #include <algorithm>
 
 using namespace std;
@@ -46,9 +48,9 @@ TopoCoreSimResult::triggerOutput(const std::string & triggerName) const {
 
 
 
-StatusCode
+TCS::StatusCode
 TopoCoreSimResult::collectResult(TCS::DecisionConnector* outputConn) {
-   StatusCode sc = StatusCode::SUCCESS;
+   TCS::StatusCode sc = TCS::StatusCode::SUCCESS;
    if (outputConn == nullptr ) {
       sc = m_globalDecision.collectDecision(m_outputConnectors);
    } else {
@@ -59,31 +61,33 @@ TopoCoreSimResult::collectResult(TCS::DecisionConnector* outputConn) {
 }
 
 
-StatusCode
+TCS::StatusCode
 TopoCoreSimResult::reset() {
    return m_globalDecision.resetDecision();
 }
 
 
-StatusCode
-TopoCoreSimResult::setupFromMenu(const TXC::L1TopoMenu & menu, 
-                                 const std::map<std::string, TCS::DecisionConnector*>& outputConnectorMap) {
+TCS::StatusCode
+TopoCoreSimResult::setupFromMenu(const std::map<std::string, TCS::DecisionConnector*>& outputConnectorMap) {
 
    m_outputConnectorMap = outputConnectorMap;
 
+   vector<TrigConf::TriggerLine> triggerLines;
+
    for(auto & x : m_outputConnectorMap) {
       // fill the set
       m_outputConnectors.insert(x.second);
 
       // fill the trigger line map (trigger name --> (TCS::DecisionConnector*,unsigned int index) )
-      for( const TXC::TriggerLine & trigger : x.second->triggers() ) {
+      for( const TrigConf::TriggerLine & trigger : x.second->triggers() ) {
          m_triggerLocation[trigger.name()] = x.second;
+	 triggerLines.push_back(trigger);
       }
    }
 
-   m_globalDecision.setTriggerLines(menu.getL1TopoConfigOutputList().getTriggerLines());
+   m_globalDecision.setTriggerLines(triggerLines);
 
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
@@ -112,9 +116,9 @@ operator<<(std::ostream& o, const TCS::TopoCoreSimResult & simRes) {
 
    for( const DecisionConnector * conn : simRes.m_outputConnectors ) {
       o << conn->name() << endl;
-      for(const TXC::TriggerLine & trigger : conn->triggers()) {
-         o << "  " << trigger << endl;
-      }
+   //   for(const TrigConf::TriggerLine & trigger : conn->triggers()) {
+	//         o << "  " << trigger << endl;
+   //   }
       for(const TCS::TOBArray* output : conn->outputData())
          o << "  output " << output << endl;
    }
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoSteering.cxx b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoSteering.cxx
index 007bfc2f624648894304bf9876950011be4d1892..a7e609b804dc2b92030738257ef21a35258b6063 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoSteering.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoSteering.cxx
@@ -1,8 +1,11 @@
-// Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+/*
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
+*/
 
 #include "L1TopoInterfaces/AlgFactory.h" 
 #include "L1TopoInterfaces/IL1TopoHistSvc.h"
 
+
 #include "L1TopoInterfaces/ConfigurableAlg.h"
 #include "L1TopoInterfaces/ParameterSpace.h"
 #include "L1TopoInterfaces/SortingAlg.h"
@@ -41,22 +44,31 @@ TopoSteering::~TopoSteering() {
    AlgFactory::destroy_instance();
 }
 
-StatusCode
-TopoSteering::setupFromConfiguration(const TXC::L1TopoMenu& menu) {
-   
-   if(m_useBitwise){ TRG_MSG_INFO("Will be using bitwise implementation of algorithms");}
-   else{TRG_MSG_INFO("Will NOT be using bitwise implementation of algorithms");}
+TCS::StatusCode
+TopoSteering::setupFromConfiguration(const TXC::L1TopoMenu&){
+  
+  // Keep this method to avoid crashes. TO-DO: Switch menu loading in L1TopoSimulation.cxx
+  TRG_MSG_WARNING("Cannot configure simulation from XML. Use JSON format");
 
+  return TCS::StatusCode::SUCCESS;
 
-   StatusCode sc = m_structure.setupFromMenu( menu );
+}
 
-   // configure layout of the simulation result
-   sc &= m_simulationResult.setupFromMenu( menu, m_structure.outputConnectors() );
 
-   return sc;
+TCS::StatusCode
+TopoSteering::setupFromConfiguration(const TrigConf::L1Menu& l1menu){
+
+
+  TCS::StatusCode sc = m_structure.setupFromMenu( l1menu );
+  
+  // configure layout of the simulation result
+  sc &= m_simulationResult.setupFromMenu( m_structure.outputConnectors() );
+
+  return sc;
+
 }
 
-StatusCode
+TCS::StatusCode
 TopoSteering::reset() {
 
    ClusterTOB::clearHeap();
@@ -74,11 +86,11 @@ TopoSteering::reset() {
 
    m_simulationResult.reset();
    
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::initializeAlgorithms() {
    TRG_MSG_INFO("initializing algorithms");
    if( ! structure().isConfigured() ) {
@@ -101,7 +113,7 @@ TopoSteering::initializeAlgorithms() {
 }
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::setHistSvc(std::shared_ptr<IL1TopoHistSvc> histSvc) {
    TRG_MSG_INFO("setting L1TopoHistSvc ");
    m_histSvc = histSvc;
@@ -109,7 +121,7 @@ TopoSteering::setHistSvc(std::shared_ptr<IL1TopoHistSvc> histSvc) {
 }
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::saveHist() {
    if(m_histSvc) {
       m_histSvc->save();
@@ -120,7 +132,7 @@ TopoSteering::saveHist() {
 }
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::executeEvent() {
 
 
@@ -135,7 +147,7 @@ TopoSteering::executeEvent() {
    inputEvent().print();
 
    // execute all connectors
-   StatusCode sc = StatusCode::SUCCESS;
+   TCS::StatusCode sc = TCS::StatusCode::SUCCESS;
    TRG_MSG_INFO("Going to execute " << m_structure.outputConnectors().size() << " connectors");
    for(auto outConn: m_structure.outputConnectors()) {
       TRG_MSG_INFO("executing trigger line " << outConn.first);
@@ -148,19 +160,19 @@ TopoSteering::executeEvent() {
    m_simulationResult.globalDecision().print();
 
    TRG_MSG_INFO("finished executing event " << m_evtCounter++);
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::executeTrigger(const std::string & TrigName) {
    if( ! structure().isConfigured() )
       TCS_EXCEPTION("TopoSteering has not been configured, can't run");
    
    DecisionConnector * outConn = m_structure.outputConnector(TrigName);
 
-   StatusCode sc = executeConnector(outConn);
+   TCS::StatusCode sc = executeConnector(outConn);
 
    m_simulationResult.collectResult(outConn);
 
@@ -168,18 +180,22 @@ TopoSteering::executeTrigger(const std::string & TrigName) {
 }
 
 
-StatusCode
+
+
+
+
+TCS::StatusCode
 TopoSteering::executeConnector(TCS::Connector *conn) {
 
    if (conn == NULL) {
-     return StatusCode::FAILURE;
+     return TCS::StatusCode::FAILURE;
    }
 
    // caching
    if(conn->isExecuted())
       return conn->executionStatusCode();
   
-   StatusCode sc(StatusCode::SUCCESS);
+   TCS::StatusCode sc(TCS::StatusCode::SUCCESS);
 
    if(conn->isInputConnector()) {
       //TRG_MSG_DEBUG("  ... executing input connector '" << conn->name() << "'");
@@ -200,14 +216,14 @@ TopoSteering::executeConnector(TCS::Connector *conn) {
 
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::executeInputConnector(TCS::InputConnector *conn) {
 
    if (conn == NULL) {
-     return StatusCode::FAILURE;
+     return TCS::StatusCode::FAILURE;
    }
 
-   StatusCode sc(StatusCode::SUCCESS);
+   TCS::StatusCode sc(TCS::StatusCode::SUCCESS);
 
    // attaching data from inputEvent to input connector, depending on the configured input type
 
@@ -223,14 +239,14 @@ TopoSteering::executeInputConnector(TCS::InputConnector *conn) {
 
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::executeSortingConnector(TCS::SortingConnector *conn) {
 
    if (conn == NULL) {
      return StatusCode::FAILURE;
    }
 
-   StatusCode sc = StatusCode::SUCCESS;
+   TCS::StatusCode sc = TCS::StatusCode::SUCCESS;
   
    // execute all the prior connectors
    for( TCS::Connector* inputConn: conn->inputConnectors() ){
@@ -253,14 +269,14 @@ TopoSteering::executeSortingConnector(TCS::SortingConnector *conn) {
 
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::executeDecisionConnector(TCS::DecisionConnector *conn) {
 
    if (conn == NULL) {
-     return StatusCode::FAILURE;
+     return TCS::StatusCode::FAILURE;
    }
 
-   StatusCode sc = StatusCode::SUCCESS;
+   TCS::StatusCode sc = TCS::StatusCode::SUCCESS;
   
    // execute all the prior connectors
    for( TCS::Connector* inputConn: conn->inputConnectors() ){
@@ -305,7 +321,7 @@ TopoSteering::executeDecisionConnector(TCS::DecisionConnector *conn) {
 
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::executeSortingAlgorithm(TCS::SortingAlg *alg,
                                       TCS::InputConnector* inputConnector,
                                       TCS::TOBArray * & sortedOutput) {
@@ -318,12 +334,12 @@ TopoSteering::executeSortingAlgorithm(TCS::SortingAlg *alg,
    if(m_useBitwise) alg->sortBitCorrect(*input, *sortedOutput);
    else alg->sort(*input, *sortedOutput);
 
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
 
-StatusCode
+TCS::StatusCode
 TopoSteering::executeDecisionAlgorithm(TCS::DecisionAlg *alg,
                                        const std::vector<Connector*> & inputConnectors,
                                        const std::vector<TCS::TOBArray *> & output,
@@ -357,10 +373,11 @@ TopoSteering::executeDecisionAlgorithm(TCS::DecisionAlg *alg,
    else alg->process( input, output, decision );
    //TRG_MSG_ALWAYS("[XS1234sz]L1Topo Steering alg " << alg->name() << " has decision " << decision.decision());
      
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
+
 void
 TopoSteering::printDebugInfo() {
    TRG_MSG_INFO("Number of ClusterTOB  : " << ClusterTOB::heap().size());
@@ -422,8 +439,8 @@ void TopoSteering::propagateHardwareBitsToAlgos()
        TCS::DecisionConnector *outCon = connector.second;
         outCon->decisionAlgorithm()->resetHardwareBits();
         unsigned int pos = 0; // for multi-output algorithms pos is the output index
-        for(const TXC::TriggerLine &trigger : outCon->triggers()){
-            unsigned int bitNumber = trigger.counter();
+        for(const TrigConf::TriggerLine &trigger : outCon->triggers()){
+	    unsigned int bitNumber = trigger.startbit() + 32*trigger.fpga() + 16*clock();
             outCon->decisionAlgorithm()->setHardwareBits(pos,
                                                          m_triggerHdwBits[bitNumber],
                                                          m_ovrflowHdwBits[bitNumber]);
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoSteeringStructure.cxx b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoSteeringStructure.cxx
index e7b1fd48d0ede95226d44b8913519f309f63525b..e06236282245f3635db3b40d813a3ecd6e766848 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoSteeringStructure.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/Root/TopoSteeringStructure.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 #include "L1TopoCoreSim/TopoSteeringStructure.h"
 
@@ -20,6 +20,8 @@
 
 #include "L1TopoHardware/L1TopoHardware.h"
 
+#include "TrigConfData/L1Menu.h"
+
 #include <set>
 #include <iomanip>
 #include <boost/lexical_cast.hpp>
@@ -72,11 +74,11 @@ TopoSteeringStructure::~TopoSteeringStructure() {
 }
 
 
-StatusCode
+TCS::StatusCode
 TopoSteeringStructure::reset() {
    for(Connector* conn: m_connectors)
       conn->reset();
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
@@ -117,189 +119,319 @@ TCS::TopoSteeringStructure::printParameters(std::ostream & o) const {
 }
 
 
-
-
 TCS::StatusCode
-TCS::TopoSteeringStructure::setupFromMenu(const TXC::L1TopoMenu& menu, bool debug) {
+TCS::TopoSteeringStructure::setupFromMenu(const TrigConf::L1Menu& l1menu, bool debug, bool legacy) {
 
    if(debug)
       cout << "/***************************************************************************/" << endl
            << "           L1Topo steering structure: configuring from L1 Topo Menu          " << endl
            << "/***************************************************************************/" << endl;
 
-   set<TCS::inputTOBType_t> neededInputs;
-   if(debug)
-      cout << "... building sorting connectors" << endl;
-
-   for( const TXC::L1TopoConfigAlg & configalgo: menu.getL1TopoConfigAlgs() ) {   
-
-      if(!configalgo.isSortAlg()) continue;
-      
-      // Input
-      for(string & algoInput : configalgo.getInputNames()) {
-         TCS::inputTOBType_t en = inputType(algoInput);
-         neededInputs.insert(en);
-      }
-
-      // create connector
-      SortingConnector * conn = new SortingConnector(configalgo.getInputNames()[0], configalgo.fullname(), configalgo.output());
-      if(debug)
-         cout << "Adding sorting connector " << "[" << *conn << "]" << endl;
-      addSortingConnector( conn );
-   }
-
-
+   //   set<TCS::inputTOBType_t> neededInputs; // Stores inputs for DecisionConnectors
+   vector<string> storedConn; // Stores decision connectors in order to avoid double counting
+   vector<vector<string>> confAlgorithms; // Stores algorithm name/category that have been configured in L1Menu to be used for setting the parameters
+   // Loop over boards in L1Menu and skip the ones that are not TOPO. Use Run-2 boards if legacy flag is on
+   for (const string & boardName : l1menu.boardNames() ){
+     
+     auto & l1board = l1menu.board(boardName);
+
+     if (l1board.type() != "TOPO") continue;
+     if (l1board.legacy() != legacy) continue;
+
+     // Access the connectors in the boards
+
+     for (const string & connName : l1board.connectorNames() ){
+
+       auto & l1conn = l1menu.connector(connName);
+
+       // All topo decision algorithms are configured in boards with electrical connection to CTP - Add optical connectors when adding multiplicity algorithms
+       // Look at all Topo algorithms in each connector, and get inputs from each algorithm to configure SortingConnectors
+       if ( ! (l1conn.connectorType() == TrigConf::L1Connector::ConnectorType::ELECTRICAL ) ) continue;
+
+       for( size_t fpga : { 0, 1} ) {
+	 for( size_t clock : { 0, 1} ) {
+	   for( auto & tl : l1conn.triggerLines(fpga, clock) ) {
+	     
+	     const string & tlName = tl.name();
+	     auto & algo = l1menu.algorithmFromTriggerline(tlName);
+
+	     // One algorithm can have multiple trigger lines. Check the connector/algorithm has not been stored already
+	     auto it = find(storedConn.begin(), storedConn.end(), algo.name());
+	     if (it == storedConn.end()) { // Algorithm/Connector does not exist: create and store it
+
+	       storedConn.push_back(algo.name());
+	       vector<string> inputNames;
+	       for( auto & input : algo.inputs() ) {
+		 if( sortingConnector(input) == 0 ) { // if connector does not exist, create it
+		   if(debug) 
+		     cout << "L1TopoSteering: Decision algo( " << algo.name() << " ) input is not defined: " << input << ". Creating sortingConnector" << endl;
+		   
+		   auto & sortAlgo = l1menu.algorithm(input, algo.category());
+		   if(!(sortAlgo.type() == TrigConf::L1TopoAlgorithm::AlgorithmType::SORTING ) )
+		     TCS_EXCEPTION("L1TopoSteering: Decision algo " << algo.name() << ") has as input " << input << " which is not associated to a sorting algorithm");
+
+		   //		   TCS::inputTOBType_t en = inputType(sortAlgo.inputs().at(0));
+		   //		   neededInputs.insert(en);
+
+		   // Create connector
+		   SortingConnector * sortConn = new SortingConnector(sortAlgo.inputs().at(0), sortAlgo.klass()+"/"+input, sortAlgo.outputs().at(0));
+		   if(debug)
+		     cout << "Adding sorting connector " << "[" << *sortConn << "]" << endl;
+		   addSortingConnector( sortConn );
+		   confAlgorithms.push_back({sortAlgo.name(), sortAlgo.category()});
+
+		 } // if connector does not exist
+		 
+		 inputNames.push_back(input);
+
+	       } // loop over inputs
+
+	       DecisionConnector * conn = new DecisionConnector(algo.name(), inputNames, algo.klass()+"/"+algo.name(), algo.outputs());
+	       conn->m_decision.setNBits( algo.outputs().size() );
+
+	       if(tl.name() != "UNDEF")
+		 conn->m_triggers.push_back(tl);
+
+	       if(debug)
+		 cout << "Adding decision connector " << "[" << *conn << "]" << endl;
+	       addDecisionConnector( conn );
+	       confAlgorithms.push_back({algo.name(), algo.category()});
+
+	     } else { // Connector already exists: look for it and add the trigger line
+	       for(auto out : algo.outputs()){
+		 auto c = m_outputLookup.find(out);
+		 if (c != m_outputLookup.end()){
+		   auto conn = c->second;
+		   if(tl.name() != "UNDEF")
+		     conn->m_triggers.push_back(tl);
+		   break;
+		 }
+	       }
+	     }
+
+	   } // Trigger Line
+
+	 } // Clock
+
+       } // FPGA
+       
+     } // Connector in l1board
 
+   } // Board in l1menu
 
+   /*
    if(debug)
-      cout << "... building output connectors" << endl;
-   for( const TXC::L1TopoConfigAlg & configalgo: menu.getL1TopoConfigAlgs() ) {     
+     cout << "... building sorting connectors" << endl;
 
-      if(!configalgo.isDecAlg()) continue;
+   std::string categories[] = { "TOPO" };
 
-      for( const TXC::InputElement & input : configalgo.getInputs() ) {
-         if( sortingConnector(input.value) == 0 ) {
-            TCS_EXCEPTION("L1TopoSteering: Decision algo ( " << configalgo.fullname() << " ) input is not defined: " << input.value);
-         }
-      }
-
-      DecisionConnector * conn = new DecisionConnector(configalgo.name(), configalgo.getInputNames(), configalgo.fullname(), configalgo.getOutputNames());
-      conn->m_decision.setNBits( configalgo.getOutputs().size() );
-
-      for(const std::string & output: conn->outputNames()) {
-         const TXC::TriggerLine & trigger = menu.getL1TopoConfigOutputList().getTrigger(output);
-         if(trigger.name()!="UNDEF")
-            conn->m_triggers.push_back(trigger);
-      }
-      if(debug)
-         cout << "Adding decision connector " << "[" << *conn << "]" << endl;
-      addDecisionConnector( conn );
+   for( auto & category : categories ){
+   
+     for( auto & name : l1menu.topoAlgorithmNames(category)) {
+       
+       auto & algo = l1menu.algorithm(name, category);
+       
+       if(!(algo.type() == TrigConf::L1TopoAlgorithm::AlgorithmType::SORTING ) ) continue;
+       
+       TCS::inputTOBType_t en = inputType(algo.inputs().at(0));
+       neededInputs.insert(en);
+       
+       // create connector
+       SortingConnector * conn = new SortingConnector(algo.inputs().at(0), algo.klass()+"/"+name, algo.outputs().at(0));
+       if(debug)
+	 cout << "Adding sorting connector " << "[" << *conn << "]" << endl;
+       addSortingConnector( conn );
+     }
 
    }
+     
 
+   
+   if(debug)
+     cout << "... building output connectors" << endl;
+
+   // All topo decision algorithms are configured in boards with electrical connection to CTP
+   // Create all DecisionConnectors from L1Connectors of type ELECTRICAL
+   std::vector<std::string> storedConn;
+   for ( const string & connName : l1menu.connectorNames() ){
+
+     auto & l1conn = l1menu.connector(connName);
+
+     if ( ! (l1conn.type() == TrigConf::L1Connector::ConnectorType::ELECTRICAL ) ) continue;
+     if ( l1conn.isLegacy() ) continue;
+
+     for( size_t fpga : { 0 ,1 } ) {
+       for( size_t clock : { 0 ,1 } ) {
+	 for( auto & tl : l1conn.triggerLines(fpga, clock) ) {
+	   
+	   const string & tlName = tl.name();
+	   auto & algo = l1menu.algorithmFromTriggerline(tlName);
+	   
+	   // One algorithm can have multiple trigger lines. Check the connector/algorithm has not been stored already
+	   auto it = std::find(storedConn.begin(), storedConn.end(), algo.name());
+	   if (it == storedConn.end()) { // Algorithm/Connector do not exist: create and store it
+
+	     storedConn.push_back(algo.name());
+
+	     std::vector<std::string> inputNames;
+	     for( auto & input : algo.inputs() ) {
+	       if( sortingConnector(input) == 0 ) {
+		 TCS_EXCEPTION("L1TopoSteering: Decision algo ( " << algo.name() << " ) input is not defined: " << input);
+	       }
+	       inputNames.push_back(input);
+	     }
+
+	     DecisionConnector * conn = new DecisionConnector(algo.name(), inputNames, algo.klass()+"/"+algo.name(), algo.outputs());
+	     conn->m_decision.setNBits( algo.outputs().size() );
+	   
+	     if(tl.name() != "UNDEF")
+	       conn->m_triggers.push_back(tl);
+
+	     if(debug)
+	       cout << "Adding decision connector " << "[" << *conn << "]" << endl;
+	     addDecisionConnector( conn );
+
+	   } else { // Connector already exists: look for it and add the trigger line
+	     for(auto out : algo.outputs()){
+	       auto c = m_outputLookup.find(out);
+	       if (c != m_outputLookup.end()){
+		 auto conn = c->second;
+		 if(tl.name() != "UNDEF")
+		   conn->m_triggers.push_back(tl);
+		 break;
+	       }
+	     }
+	   }
+	 } // Trigger Line
+       } // Clock
+     } // FPGA
+   } // L1Connectors
+
+   */
 
    if(debug)
-      cout << "... building input connectors" << endl;
+     cout << "... building input connectors" << endl;
    for(auto sortConn : m_sortedLookup) {
-      const string & in = sortConn.second->inputNames()[0]; // name of input
-
-      if( m_inputLookup.count(in) > 0 ) continue; // InputConnector already exists
-
-      InputConnector * conn = new InputConnector(in);
-      m_connectors.push_back(conn);
-      m_inputLookup[in] = conn;
-      if(debug)
-         cout << "Adding input connector " << "[" << *conn << "]" << endl;
+     const string & in = sortConn.second->inputNames()[0]; // name of input
+     
+     if( m_inputLookup.count(in) > 0 ) continue; // InputConnector already exists
+
+     InputConnector * conn = new InputConnector(in);
+     m_connectors.push_back(conn);
+     m_inputLookup[in] = conn;
+     if(debug)
+       cout << "Adding input connector " << "[" << *conn << "]" << endl;
    }
 
-   
    // link the connector objects together
-   StatusCode sc = linkConnectors();
-   
+   TCS::StatusCode sc = linkConnectors();
+
    // instantiate the algorithms from the algorithm names in the connectors
    if(debug)
-      cout << "... instantiating algorithms" << endl;
+     cout << "... instantiating algorithms" << endl;
    sc &= instantiateAlgorithms(debug);
-   
 
-   // iterate through OutputList elements
-   if(debug) {
-      cout << "... checking output list" << endl;
-      cout << menu.getL1TopoConfigOutputList().getOutputList().size() << " output algorithms for " 
-           << menu.getL1TopoConfigOutputList().getTriggerLines().size() << " trigger lines." << endl;
-   }
-   
+
    // set algorithm parameters
    if(debug)
-      cout << "... setting algorithm parameters" << endl;
-   
-   for( const TXC::L1TopoConfigAlg & configalgo: menu.getL1TopoConfigAlgs() ) {
+     cout << "... setting algorithm parameters" << endl;
 
-      ConfigurableAlg * alg = AlgFactory::instance().algorithm(configalgo.name());
-
-      alg->setAlgoId( configalgo.algoID() );
-
-      if(debug)
-         cout << "Algorithm " << alg->name() << endl << "  (reading parameters)" << endl;
-
-      if(alg->isDecisionAlg())
-         ((DecisionAlg *) alg)->setNumberOutputBits(configalgo.getOutputs().size());
-
-      // create ParameterSpace for this algorithm
-      ParameterSpace * ps = new ParameterSpace(alg->name());
-
-      for(TXC::RegisterParameter pe: configalgo.getParameters()) {
-         
-         string   name = pe.name;
-         uint32_t val = lexical_cast<uint32_t, string>(pe.value);
-         uint32_t pos  = pe.position;
-         uint32_t sel  = pe.selection;
-         
-         if(debug)
-            cout << "  parameter " << pos << ": " << setw(20) << left << name << " value = " << setw(3) << left << val << " (selection " << sel << ")" << endl;
-         ps->addParameter( name, val, sel);
-      }
-
-
-      for(TXC::FixedParameter pe: configalgo.getFixedParameters()) {
-         
-         string   name = pe.name;
-         uint32_t val = interpretGenericParam(pe.value);
-         if(name=="NumResultBits") {
-            if(val != configalgo.getOutputs().size()) {
-               TCS_EXCEPTION("Algorithm " << name << " parameter OutputBits (" << val << ") is different from output size (" << configalgo.getOutputs().size() << ")");
-            }
-            continue; // ignore this, because it is defined through the output list
-         }
-         if(debug)
-            cout << "  fixed parameter : " << setw(20) << left << name << " value = " << setw(3) << left << val << endl;
-         ps->addParameter( name, val);
-      }
-
-
-      if(debug)
-         cout << "  (setting parameters)" << endl;
-      alg->setParameters( *ps );
-
-      if( alg->isDecisionAlg() ) {
-         if( m_parameters[alg->algoId()] != nullptr ) {
-            TCS_EXCEPTION("Decision algorithm " << alg->name() << " has algoId " << alg->algoId() << " which is already used");
-         }
-         m_parameters[alg->algoId()] = ps;
-      } else if( alg->isSortingAlg() ) {
-         if( m_parameters[alg->algoId() + LayoutConstraints::maxComponents()] != nullptr ) {
-            TCS_EXCEPTION("Sorting algorithm " << alg->name() << " has algoId " << alg->algoId() << " which is already used");
-         }
-         m_parameters[alg->algoId() + LayoutConstraints::maxComponents()] = ps;
-      } else {
-	// newed parameters unused so delete to avoid memory leak
-	delete ps;
-	ps=0;
-      }
+   for ( auto & confAlgo : confAlgorithms ) {
+     
+     auto & l1algo = l1menu.algorithm(confAlgo.at(0), confAlgo.at(1));
+       
+     ConfigurableAlg * alg = AlgFactory::instance().algorithm(l1algo.name());
+     alg->setAlgoId( l1algo.algId() );
+     
+     if(debug)
+       cout << "Algorithm " << alg->name() << " has algoId " << alg->algoId() <<  endl << " (reading parameters)" << endl;
+     
+     if(alg->isDecisionAlg())
+       ((DecisionAlg *) alg)->setNumberOutputBits(l1algo.outputs().size());
+
+     // create ParameterSpace for this algorithm
+     ParameterSpace * ps = new ParameterSpace(alg->name());
+
+     for(auto & pe : l1algo.parameters()) {
+	 
+       auto & pname = pe.name();
+       uint32_t val = pe.value();
+       uint32_t sel = pe.selection();
+
+       if(debug)
+	 cout << " parameter " << ": " << setw(20) << left << pname << " value = " << setw(3) << left << val << " (selection " << sel << ")" << endl;
+       ps->addParameter( pname, val, sel);
+	 
+     }
+       
+     for(auto & gen : l1algo.generics().getKeys()) {
+	 
+       auto pe = l1algo.generics().getObject(gen);
+       string pname = gen;
+       uint32_t val = interpretGenericParam(pe.getAttribute("value"));
+       if (pname == "NumResultBits"){
+	 if(val != l1algo.outputs().size()) {
+	   TCS_EXCEPTION("Algorithm " << pname << " parameter OutputBits (" << val << ") is different from output size (" << l1algo.outputs().size() << ")");
+	 }
+	 continue; // ignore this, because it is defined through the output list
+       }
+       if(debug)
+	 cout << " fixed parameter : " << setw(20) << left << pname << " value = " << setw(3) << left << val << endl;
+       ps->addParameter( pname, val );
+	 
+     }
+       
+       
+     if(debug)
+       cout << " (setting parameters)";
+     alg->setParameters( *ps );
+       
+     if(debug)
+       cout << " --> (parameters set)";
+       
+     if( alg->isDecisionAlg() ) {
+       if( m_parameters[alg->algoId()] != nullptr ) {
+	 //	   TCS_EXCEPTION("Decision algorithm " << alg->name() << " has algoId " << alg->algoId() << " which is already used");
+       }
+       m_parameters[alg->algoId()] = ps;
+     } else if (alg->isSortingAlg() ) {
+       if( m_parameters[alg->algoId() + LayoutConstraints::maxComponents()] != nullptr ) {
+	 //	   TCS_EXCEPTION("Sorting algorithm " << alg->name() << " has algoId " << alg->algoId() << " which is already used");
+       }
+       m_parameters[alg->algoId() + LayoutConstraints::maxComponents()] = ps;
+     } else {
+       // newed parameters usued so delete to avoid memory leak
+       delete ps;
+       ps=0;
+     }
+
+     if(debug)
+       cout << " --> (parameters stored)" << endl;
    }
-
+   
    m_isConfigured = true;
-
+   
    if(debug)
-      cout << "... L1TopoSteering successfully configured" << endl;
+     cout << "... L1TopoSteering successfully configured" << endl;
    
    return sc;
 }
 
+
 TCS::StatusCode
 TopoSteeringStructure::addSortingConnector(SortingConnector * conn) {
    m_connectors.push_back(conn);
    for( const string & output : conn->outputNames() )
       m_sortedLookup[output] = conn;
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 TCS::StatusCode
 TopoSteeringStructure::addDecisionConnector(DecisionConnector * conn) {
-   m_connectors.push_back(conn);
+   m_connectors.push_back(conn); 
    for( const string & output : conn->outputNames() )
-      m_outputLookup[output] = conn;
-   return StatusCode::SUCCESS;
+     m_outputLookup[output] = conn;     
+   return TCS::StatusCode::SUCCESS;
 }
 
 
@@ -310,7 +442,7 @@ TopoSteeringStructure::linkConnectors() {
       for(const std::string & inconn: conn->inputNames())
          conn->inputConnectors().push_back( connector(inconn) );
 
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
@@ -340,7 +472,7 @@ TCS::TopoSteeringStructure::instantiateAlgorithms(bool debug) {
       }
       conn->setAlgorithm(algInstance);
    }
-   return StatusCode::SUCCESS;
+   return TCS::StatusCode::SUCCESS;
 }
 
 
@@ -366,9 +498,7 @@ TopoSteeringStructure::sortingConnector(const std::string & connectorName) const
          }
       }
    }
-   if(sc==nullptr) {
-      TCS_EXCEPTION("TopoSteeringStructure: can not find SortingConnector of name " << connectorName << ". Need to abort!");
-   }
+   
    return sc;
 }
 
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/src/test/TopoStandAlone.cxx b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/src/test/TopoStandAlone.cxx
index 64eb5b92b03507b1627fb32ba354b9982ac8a122..bb8081cf36834acbb3b0bf536d205407a1b73cad 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/src/test/TopoStandAlone.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/src/test/TopoStandAlone.cxx
@@ -7,6 +7,8 @@
 #include <stdint.h>
 
 #include "TrigConfBase/TrigConfMessaging.h"
+#include "TrigConfIO/JsonFileLoader.h"
+#include "TrigConfData/L1Menu.h"
 
 #include "L1TopoConfig/L1TopoXMLParser.h"
 #include "L1TopoCoreSim/TopoSteering.h"
@@ -27,7 +29,7 @@ using namespace std;
 
 int printHelp(const char * exeName) {
    cout << "Please specify menu and data file and optionally the message levels for the framework and the algorithms:" << endl << endl;
-   cout << exeName << " <menu.xml> <data.txt> [INFO|DEBUG|WARNING] [INFO|DEBUG|WARNING] [filename.root] [optional arguments]" << endl << endl;
+   cout << exeName << " <menu.json> <data.txt> [INFO|DEBUG|WARNING] [INFO|DEBUG|WARNING] [filename.root] [optional arguments]" << endl << endl;
    cout << "optional arguments:" << endl
         << "   -o|--outfile <filename.root>" << endl
         << "   -n|--nevt <#events>" << endl
@@ -97,15 +99,14 @@ int run(int argc, const char* argv[]) {
    msg.setLevel( msgLvl );
 
    // read the menu
-   TXC::L1TopoXMLParser XMLParser;
-   XMLParser.msg().setLevel( msgLvl );
-   XMLParser.readConfiguration(argv[1]);
-   XMLParser.parseConfiguration();
-
-   //XMLParser.menu().print();
+   TrigConf::L1Menu l1menu;
+   TrigConf::JsonFileLoader fileLoader;
+fileLoader.loadFile(argv[1], l1menu);
 
 
    //TFile *f = new TFile(argc>=4 ? argv[3] : "L1TopoSimulation.root","RECREATE");
+
+   /* Change once the final number of bits per module is fixed
    TH1* h[3];
    h[0] = new TH1F("Decision/DecisionModule1", "L1 Topo Decision (Module 1)", 64, 0, 64);
    h[1] = new TH1F("Decision/DecisionModule2", "L1 Topo Decision (Module 2)", 64, 0, 64);
@@ -117,21 +118,21 @@ int run(int argc, const char* argv[]) {
    }
    for(uint i=0; i<3; ++i)
       h[i]->SetLabelSize(0.025);
-
+   */
 
    // instantiate steering
    TCS::TopoSteering steering;
    steering.setUseBitwise(false);
-   steering.setupFromConfiguration(XMLParser.takeMenu());
+   steering.setupFromConfiguration(l1menu);
 
    steering.setMsgLevel( msgLvl );
 
    steering.setAlgMsgLevel( algMsgLvl );
 
    std::shared_ptr<IL1TopoHistSvc> topoHistSvc = std::shared_ptr<IL1TopoHistSvc>( new StandaloneL1TopoHistSvc() );
-   topoHistSvc->setBaseDir("L1TopoSimulation.root:");
-   for(int i = 0; i < 3; i++ )
-      topoHistSvc->registerHist(h[i]);
+   //   topoHistSvc->setBaseDir("L1TopoSimulation.root:");
+   //   for(int i = 0; i < 3; i++ )
+   //      topoHistSvc->registerHist(h[i]);
 
    steering.setHistSvc(topoHistSvc);
 
@@ -164,14 +165,15 @@ int run(int argc, const char* argv[]) {
 
       steering.executeEvent();
 
-      const TCS::GlobalDecision & globalDec = steering.simulationResult().globalDecision();
-
+      // const TCS::GlobalDecision & globalDec = 
+      steering.simulationResult().globalDecision();
+      /*
       for(unsigned int module=0; module<3; ++module)
          for(unsigned int trigger=0; trigger<64; ++trigger)
             if( globalDec.passed(module, trigger) ) h[module]->Fill(trigger);
-
+      */
       steering.reset();
-
+     
    }
    msg << TrigConf::MSGTC::INFO << "=======================================================" << TrigConf::endmsgtc;
   
diff --git a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/src/test/TopoTestSteeringConfig.cxx b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/src/test/TopoTestSteeringConfig.cxx
index 7717d75645ef69cbeda12b55af88836be201ff8a..4f6a5ef500895d07c718d7dab06ece7e681c2e77 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoCoreSim/src/test/TopoTestSteeringConfig.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoCoreSim/src/test/TopoTestSteeringConfig.cxx
@@ -8,36 +8,37 @@
 #include "L1TopoCoreSim/TopoSteering.h"
 #include "L1TopoConfig/L1TopoXMLParser.h"
 
+#include "TrigConfIO/JsonFileLoader.h"
+#include "TrigConfData/L1Menu.h"
+
 using namespace std;
 
 int run(int argc, const char * argv[]) {
 
    if(argc<2) {
-      cout << "Please specify topo menu input XML file:\n" << argv[0] << " -v <menu.xml>" << endl;
+      cout << "Please specify topo menu input JSON file:\n" << argv[0] << " -v <menu.json>" << endl;
       return 1;
    }
 
    bool verbose = (string(argv[1])=="-v");
 
+   TrigConf::L1Menu l1menu;
+   TrigConf::JsonFileLoader fileLoader;
 
-   TXC::L1TopoXMLParser parser;
-   parser.readConfiguration(argv[argc-1]);
    try {
-      parser.parseConfiguration();
+      fileLoader.loadFile( argv[0], l1menu);
    }
    catch(std::exception & e) {
-      cout << "TopoTestSteeringConfig: Caught exception from the topo menu parser, no topo menu will be available! Exception message: " << e.what() << endl;
+      cout << "TopoTestSteeringConfig: Caught exception from the topo menu loader, no topo menu will be available! Exception message: " << e.what() << endl;
       return 1;
    }
 
-   TXC::L1TopoMenu menu = parser.takeMenu();  // since parser goes out of scope, we take the menu
-
    if (verbose)
-      menu.print();
+      l1menu.printMenu(true);
 
    TCS::TopoSteering steering;
    try {
-      steering.setupFromConfiguration( menu );
+      steering.setupFromConfiguration(l1menu);
    } catch(exception & e) {
       cerr << "TopoTestSteeringConfig: Caught exception when configuring topo steering from menu: " << endl << e.what() << endl;
       return 1;
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/CMakeLists.txt b/Trigger/TrigT1/L1Topo/L1TopoSimulation/CMakeLists.txt
index 44e9340ac2e1ead1fb1f4680610360e8830e1663..f6b3339bd028099c90146d29b9f63546906b9c66 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/CMakeLists.txt
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/CMakeLists.txt
@@ -24,7 +24,7 @@ atlas_add_component( L1TopoSimulation
 atlas_add_component( L1TopoSimulationTest
    src/test/*.h src/test/*.cxx src/test/components/*.cxx src/AthenaL1TopoHistSvc.h src/AthenaL1TopoHistSvc.cxx
    INCLUDE_DIRS ${ROOT_INCLUDE_DIRS}
-   LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaBaseComps AthenaMonitoringLib GaudiKernel L1TopoConfig L1TopoCoreSim L1TopoEvent L1TopoInterfaces StoreGateLib TrigConfBase TrigConfInterfaces )
+   LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaBaseComps AthenaMonitoringLib GaudiKernel L1TopoConfig L1TopoCoreSim L1TopoEvent L1TopoInterfaces StoreGateLib TrigConfBase TrigConfInterfaces TrigConfData TrigConfIO)
 
 # Install files from the package:
 atlas_install_python_modules( python/*.py POST_BUILD_CMD ${ATLAS_FLAKE8} )
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/python/L1TopoSimulationConfig.py b/Trigger/TrigT1/L1Topo/L1TopoSimulation/python/L1TopoSimulationConfig.py
index 8339ca2dacb0ad342c44ca27036ba7ad875d98ec..2ac3701a60a78a30c9d6df19d637e6c608f5f606 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/python/L1TopoSimulationConfig.py
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/python/L1TopoSimulationConfig.py
@@ -9,7 +9,12 @@ class L1TopoSimulation ( LVL1__L1TopoSimulation ):
 
         from L1TopoSimulation.L1TopoSimulationMonitoring import L1TopoSimulationMonitoring
         self.AthenaMonTools += [ L1TopoSimulationMonitoring() ]
-
+        enableDebugOutput = False
+        if enableDebugOutput:
+            from AthenaCommon.Constants import DEBUG
+            self.OutputLevel = DEBUG
+            self.TopoOutputLevel = DEBUG
+            self.TopoSteeringOutputLevel = DEBUG
 
 class RoiB2TopoInputDataCnv ( LVL1__RoiB2TopoInputDataCnv ):
 
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation.py b/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation.py
index 644b306b39c97017e06daa0aa3bee2acee6e856d..f9357780a7173398d857bb174b1cb87df453dd55 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation.py
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation.py
@@ -47,8 +47,6 @@ include ( "RecExCond/RecExCommon_flags.py" )
 
 TriggerFlags.doL1Topo = True
 TriggerFlags.doLVL1   = True
-TriggerFlags.doLVL2   = False
-TriggerFlags.doEF     = False
 TriggerFlags.doHLT    = True
 
 TriggerFlags.triggerMenuSetup = "MC_pp_v5"
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1TopoSimulationTest.py b/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1TopoSimulationTest.py
index b9a4f1ddca2b3876c6ef608352691fd36e5ad5c7..ada857a13518b1dfd61963fdf6db66ca670789c2 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1TopoSimulationTest.py
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1TopoSimulationTest.py
@@ -8,8 +8,10 @@ from AthenaCommon.Logging import logging
 log = logging.getLogger('L1TopoSimulationTest.py')
          
 fmenu ,fTOBs = 'L1Topoconfig_MC_pp_v8_NewNaming.xml','eventdump_new.txt'
+fjson = 'L1Menu_LS2_v1_22.0.17.json'
 
 print ('File for menu :',fmenu)
+print ('File for menu (json):', fjson)
 print ('File for TOBs :',fTOBs)
    
 from AthenaCommon.AppMgr import ServiceMgr as svcMgr, theApp
@@ -61,6 +63,8 @@ from L1TopoSimulation.L1TopoSimulationTestConfig import L1TopoSimulationTest
 topSequence += L1TopoSimulationTest()
 topSequence.L1TopoSimulationTest.InputASCIIFile = fTOBs
 topSequence.L1TopoSimulationTest.InputXMLFile = fmenu
+topSequence.L1TopoSimulationTest.InputJSONFile = fjson
+
 
 from GaudiSvc.GaudiSvcConf import THistSvc
 svcMgr += THistSvc()
@@ -71,15 +75,16 @@ svcMgr.THistSvc.Output += ["EXPERT DATAFILE='expert-monitoring.root' OPT='RECREA
 
 #  set algCardinality = 1 to disable cloning for all Algs
 algCardinality = nThreads
+
 #  Cloning can be disable for any alg  
 
-if (algCardinality > 1):
+if (algCardinality > 1):   
    for alg in topSequence:      
       name = alg.name()
-      if name in ["L1TopoSimulation"] :
+      if name in ["SGInputLoader"] :
          # suppress INFO message about Alg unclonability
          # set alg.Cardinality = 1 to disable cloning for specific Alg
-         alg.Cardinality = 1
+         alg.Cardinality = nThreads
       else:
          alg.Cardinality = algCardinality
 
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/L1TopoSimulation.cxx b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/L1TopoSimulation.cxx
index c3578f93e54c46f597df1147f1c4425ef2b74be9..bd46c92c83a0e1f4a6186b2cdc31e4eab9d51d82 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/L1TopoSimulation.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/L1TopoSimulation.cxx
@@ -3,22 +3,11 @@
 */
 
 #include "./L1TopoSimulation.h"
-#include "./AthenaL1TopoHistSvc.h"
-
-#include "TH1F.h"
 
-#include "AthenaMonitoring/IMonitorToolBase.h"
-
-#include "L1TopoCoreSim/TopoSteering.h"
 #include "L1TopoConfig/L1TopoMenu.h"
 #include "L1TopoEvent/TopoInputEvent.h"
 
-#include "L1TopoSimulation/IInputTOBConverter.h"
-#include "TrigConfInterfaces/IL1TopoConfigSvc.h"
-#include "GaudiKernel/ITHistSvc.h"
-
 #include "L1TopoInterfaces/IL1TopoHistSvc.h"
-#include "TrigT1Interfaces/TrigT1StoreGateKeys.h"
 #include "TrigT1Interfaces/TrigT1CaloDefs.h"
 #include "TrigT1CaloEvent/EmTauROI_ClassDEF.h"
 
@@ -28,93 +17,61 @@
 #include "L1TopoRDO/L1TopoTOB.h"
 #include "L1TopoRDO/L1TopoRDOCollection.h"
 
-#include "./PeriodicScaler.h"
-
+#include "./AthenaL1TopoHistSvc.h"
 
-using namespace std;
+// using namespace std;
 using namespace LVL1;
 
-
 namespace {
    // needed for monitoring
    class TopoResultBit : public IMonitoredAlgo::IGetter {
    public:
     
       //! constructor
-      TopoResultBit(const TCS::GlobalDecision & decision, unsigned int module) :
+      TopoResultBit(const TCS::GlobalDecision & decision, std::string connName) :
          m_decision(decision),
-         m_module(module)
+         m_connName(connName)
       {}
 
       //! return size of data
-      virtual unsigned int size() const { return 64; }
+      virtual unsigned int size() const { return 64; } // Change this when implementing multiplicity algorithms (size could change for Topo1)
 
       //! indexed access to data
-      virtual double get(unsigned pos) const { return m_decision.passed(m_module, pos) ? pos : -1.; }
+      virtual double get(unsigned pos) const { return m_decision.passed(m_connName, pos) ? pos : -1.; }
 
    private:
       const TCS::GlobalDecision & m_decision;
-      unsigned int m_module;
+      std::string m_connName;
    };
 }
 
 
-
 L1TopoSimulation::L1TopoSimulation(const std::string &name, ISvcLocator *pSvcLocator) :
    AthAlgorithm(name, pSvcLocator),
-   m_l1topoConfigSvc("TrigConf::TrigConfigSvc/TrigConfigSvc", name),
-   m_histSvc( "THistSvc/THistSvc", name),
-   m_monitors(this),
-   m_emtauInputProvider("LVL1::EMTauInputProvider/EMTauInputProvider", this),
-   m_jetInputProvider("LVL1::JetInputProvider/JetInputProvider", this),
-   m_energyInputProvider("LVL1::EnergyInputProvider/EnergyInputProvider", this),
-   m_muonInputProvider("LVL1::MuonInputProvider/MuonInputProvider", this),
-   m_topoSteering( unique_ptr<TCS::TopoSteering>(new TCS::TopoSteering()) )
+   m_topoSteering( std::make_unique<TCS::TopoSteering>() ),
+   m_scaler( std::make_unique<LVL1::PeriodicScaler>() )
 {
-   declareProperty( "TrigConfigSvc", m_l1topoConfigSvc, "Service to provide the L1Topo menu");
-   declareProperty( "HistSvc", m_histSvc, "Histogramming service for L1Topo algorithms");
-   declareProperty( "EMTAUInputProvider", m_emtauInputProvider, "Tool to fill the EMTAU TOBs of the topo input event");
-   declareProperty( "JetInputProvider", m_jetInputProvider, "Tool to fill the Jet TOBs of the topo input event");
-   declareProperty( "EnergyInputProvider", m_energyInputProvider, "Tool to fill the energy and MET TOBs of the topo input event");
-   declareProperty( "MuonInputProvider", m_muonInputProvider, "Tool to fill the muon TOBs of the topo input event");
-   declareProperty( "AthenaMonTools", m_monitors, "List of monitoring tools to be run with this instance, if incorrect then tool is silently skipped.");
-   declareProperty( "MonHistBaseDir", m_histBaseDir = "L1TopoAlgorithms", "Base directory for monitoring histograms will be /EXPERT/<MonHistBaseDir>" );
-   declareProperty( "EnableInputDump", m_enableInputDump, "Boolean to enable writing of input data for standalone running");
-   declareProperty( "UseBitwise", m_enableBitwise, "Boolean to enable the bitwise version of software algorithms");
-   declareProperty("FillHistoBasedOnHardware", m_fillHistogramsBasedOnHardwareDecision=true,
-                   "Boolean to fill accept/reject histograms based on hdw; default based on sim");
-   declareProperty( "InputDumpFile", m_inputDumpFile, "File name for dumping input data");
-   declareProperty( "TopoCTPLocation", m_topoCTPLocation = LVL1::DEFAULT_L1TopoCTPLocation, "StoreGate key of topo decision output for CTP" );
-   declareProperty( "TopoOverflowCTPLocation", m_topoOverflowCTPLocation = LVL1::DEFAULT_L1TopoOverflowCTPLocation, "StoreGate key of topo overflow output for CTP" );
-   declareProperty( "TopoOutputLevel", m_topoOutputLevel, "OutputLevel for L1Topo algorithms" );
-   declareProperty( "TopoSteeringOutputLevel", m_topoSteeringOutputLevel, "OutputLevel for L1Topo steering" );
-   declareProperty("Prescale", m_prescale = 1, "Internal prescale factor for this algorithm, implemented with a periodic scaler: so 1 means run every time, N means run every 1 in N times it is called; the other times it will exit without doing anything");
-   declareProperty("PrescaleDAQROBAccess", m_prescaleForDAQROBAccess = 4, "Prescale factor for requests for DAQ ROBs: can be used to avoid overloading ROS. Zero means disabled, 1 means always, N means sample only 1 in N events");
-
-
-   const TCS::GlobalDecision & dec = m_topoSteering->simulationResult().globalDecision();
-   declareMonitoredCustomVariable("DecisionModule1", new TopoResultBit(dec, 0));
-   declareMonitoredCustomVariable("DecisionModule2", new TopoResultBit(dec, 1));
-   declareMonitoredCustomVariable("DecisionModule3", new TopoResultBit(dec, 2));
-   m_scaler = new LVL1::PeriodicScaler();
-   
+   // const TCS::GlobalDecision & dec = m_topoSteering->simulationResult().globalDecision();
+   // declareMonitoredCustomVariable("DecisionModule1", new TopoResultBit(dec, 0));
+   // declareMonitoredCustomVariable("DecisionModule2", new TopoResultBit(dec, 1));
+   // declareMonitoredCustomVariable("DecisionModule3", new TopoResultBit(dec, 2));
 }
 
 
-LVL1::L1TopoSimulation::~L1TopoSimulation()
+L1TopoSimulation::~L1TopoSimulation()
 {}
 
 bool
-LVL1::L1TopoSimulation::isClonable() const
+L1TopoSimulation::isClonable() const
 {
    return true;
 }
 
 StatusCode
-LVL1::L1TopoSimulation::initialize() {
+L1TopoSimulation::initialize() {
    ATH_MSG_INFO("initialize");
 
-   m_topoSteering->setMsgLevel( TrigConf::MSGTC::Level(m_topoSteeringOutputLevel) );
+   m_topoSteering->setMsgLevel( TrigConf::MSGTC::Level((int)m_topoSteeringOutputLevel) );
 
    ATH_MSG_DEBUG("retrieving " << m_monitors);
    CHECK( m_monitors.retrieve() );
@@ -154,26 +111,22 @@ LVL1::L1TopoSimulation::initialize() {
    ATH_MSG_DEBUG("Output trigger key property " << m_topoCTPLocation);
    ATH_MSG_DEBUG("Output overflow key property " << m_topoOverflowCTPLocation);
 
-   const TXC::L1TopoMenu* menu = m_l1topoConfigSvc->menu();
-   if(menu == nullptr) {
-      ATH_MSG_FATAL("No L1 Topo menu from " << m_l1topoConfigSvc->name());
-      return StatusCode::FAILURE;
-   }
+   const TrigConf::L1Menu * l1menu = nullptr;
+   ATH_CHECK( detStore()->retrieve(l1menu) ); 
+   ATH_MSG_INFO( "initialize(): retrieving new-style L1 trigger menu from Detector Store" );
 
    m_topoSteering->setUseBitwise(m_enableBitwise);
-   std::cout << "Calling m_topoSteering->setupFromConfiguration(*menu)" << endl;
    try {
-      m_topoSteering->setupFromConfiguration(*menu);
+      m_topoSteering->setupFromConfiguration(*l1menu);
    }
-   catch(exception & e) {
+   catch(std::exception & e) {
       ATH_MSG_FATAL("Caught exception when configuring topo steering from menu: " << e.what() );
       return StatusCode::FAILURE;
    }
 
-   m_topoSteering->setAlgMsgLevel( TrigConf::MSGTC::Level(m_topoOutputLevel) );
+   m_topoSteering->setAlgMsgLevel( TrigConf::MSGTC::Level((int)m_topoOutputLevel) );
    m_topoSteering->setOutputAlgosFillBasedOnHardware(m_fillHistogramsBasedOnHardwareDecision);
 
-
    std::shared_ptr<IL1TopoHistSvc> topoHistSvc = std::shared_ptr<IL1TopoHistSvc>( new AthenaL1TopoHistSvc(m_histSvc) );
    topoHistSvc->setBaseDir("/EXPERT/" + m_histBaseDir.value());
 
@@ -184,34 +137,33 @@ LVL1::L1TopoSimulation::initialize() {
 
 // Exectued once per offline job and for every new run online
 StatusCode
-LVL1::L1TopoSimulation::stop() {
+L1TopoSimulation::stop() {
    ATH_MSG_DEBUG("stop");
 
    // monitoring
    for (auto mt : m_monitors )
       mt->finalHists().ignore();
 
-
    return StatusCode::SUCCESS;
 }
                            
 
 // Exectued once per offline job and for every new run online
 StatusCode
-LVL1::L1TopoSimulation::start() {
+L1TopoSimulation::start() {
    ATH_MSG_DEBUG("start");
 
    m_scaler->reset();
 
-   // monitoring : book histogram
-   for (auto mt : m_monitors )
-      CHECK( mt->bookHists() );
+   // TODO monitoring : book histogram
+   //   for (auto mt : m_monitors )
+   //      CHECK( mt->bookHists() );
 
 
    try {
       m_topoSteering->initializeAlgorithms();
    }
-   catch(exception & e) {
+   catch(std::exception & e) {
       ATH_MSG_FATAL("Caught exception when initializing topo algorithms" << e.what() );
       return StatusCode::FAILURE;
    }
@@ -227,7 +179,7 @@ LVL1::L1TopoSimulation::start() {
 
 
 StatusCode
-LVL1::L1TopoSimulation::execute() {
+L1TopoSimulation::execute() {
    const EventContext& ctx = Gaudi::Hive::currentContext();
 
    if (m_prescale>1 && not m_scaler->decision(m_prescale)){
@@ -282,7 +234,7 @@ LVL1::L1TopoSimulation::execute() {
    // execute the toposteering
    m_topoSteering->executeEvent();
 
-   ATH_MSG_DEBUG("" << m_topoSteering->simulationResult().globalDecision());
+   ATH_MSG_DEBUG("Global Decision:\n" << m_topoSteering->simulationResult().globalDecision());
    
 
    /**
@@ -294,49 +246,60 @@ LVL1::L1TopoSimulation::execute() {
     *
     */
 
+   // Format for CTP still undecided
+
    const TCS::GlobalDecision & dec = m_topoSteering->simulationResult().globalDecision();
    auto topoDecision2CTP = std::make_unique< LVL1::FrontPanelCTP >();
    auto topoOverflow2CTP = std::make_unique< LVL1::FrontPanelCTP >();
-   for(unsigned int clock=0; clock<2; ++clock) {
-      topoDecision2CTP->setCableWord0( clock, 0 ); // ALFA
-      topoDecision2CTP->setCableWord1( clock, dec.decision( 0, clock) );  // TOPO 0
-      topoDecision2CTP->setCableWord2( clock, dec.decision( 1, clock) );  // TOPO 1
-      topoOverflow2CTP->setCableWord0( clock, 0 ); // ALFA
-      topoOverflow2CTP->setCableWord1( clock, dec.overflow( 0, clock) );  // TOPO 0
-      topoOverflow2CTP->setCableWord2( clock, dec.overflow( 1, clock) );  // TOPO 1
-   } 
+
+   const TrigConf::L1Menu * l1menu = nullptr;
+   ATH_CHECK( detStore()->retrieve(l1menu) );
+
+   if( m_isLegacyTopo ) {
+      // to be implemented
+   } else {
+      // set electrical connectors
+      std::string conn1 = l1menu->board("Topo2").connectorNames()[0];
+      std::string conn2 = l1menu->board("Topo3").connectorNames()[0];
+      for(unsigned int clock=0; clock<2; ++clock) {
+         topoDecision2CTP->setCableWord0( clock, 0 ); // ALFA
+         ATH_MSG_DEBUG("Word 1 " << conn1 << " clock " << clock << "  " << dec.decision_field( conn1, clock) );
+         topoDecision2CTP->setCableWord1( clock, dec.decision_field( conn1, clock) );  // TOPO 0
+         ATH_MSG_DEBUG("Word 2 " << conn2 << " clock " << clock << "  " << dec.decision_field( conn2, clock) );
+         topoDecision2CTP->setCableWord2( clock, dec.decision_field( conn2, clock) );  // TOPO 1
+         // topoOverflow2CTP->setCableWord0( clock, 0 ); // ALFA
+         // topoOverflow2CTP->setCableWord1( clock, dec.overflow( 0, clock) );  // TOPO 0
+         // topoOverflow2CTP->setCableWord2( clock, dec.overflow( 1, clock) );  // TOPO 1
+      }    
+   }
+
    
    CHECK(SG::makeHandle(m_topoCTPLocation)        .record(std::move(topoDecision2CTP)));
    CHECK(SG::makeHandle(m_topoOverflowCTPLocation).record(std::move(topoOverflow2CTP)));
-   
+
 
    // TODO: get the output combination data and put into SG
 
    // fill histograms
    // Commenting out temporarily to avoid crash 
-   //when L1TopoSimulation run without menu confifuration.
-   //for (auto mt : m_monitors )
-   //   if ( ! mt->preSelector() ) 
-   //      mt->fillHists().ignore();
+   // when L1TopoSimulation run without menu confifuration. 
+   //   for (auto mt : m_monitors )
+   //      if ( ! mt->preSelector() ) 
+   //         mt->fillHists().ignore();
 
    return StatusCode::SUCCESS;
 }
 
 
-
-
 StatusCode
-LVL1::L1TopoSimulation::finalize() {
+L1TopoSimulation::finalize() {
    m_topoSteering->inputEvent().dumpFinish();
-
-   delete m_scaler;
-   m_scaler=0;
-
    return StatusCode::SUCCESS;
 }
 
+
 StatusCode
-LVL1::L1TopoSimulation::retrieveHardwareDecision()
+L1TopoSimulation::retrieveHardwareDecision()
 {
     // some duplication with L1TopoRDO::Helpers
     // getDecisionAndOverflowBits() ?
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/L1TopoSimulation.h b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/L1TopoSimulation.h
index c49166093cbbe1b4e9966c5ded451ce76da7ec54..909c66cf4c25b6b4140d054da17ad61e8945601c 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/L1TopoSimulation.h
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/L1TopoSimulation.h
@@ -5,41 +5,32 @@
 #ifndef L1Topo_L1TopoSimulation
 #define L1Topo_L1TopoSimulation
 
-#include "TrigConfBase/MsgStream.h"
+#include "L1TopoCoreSim/TopoSteering.h"
 
+#include "L1TopoSimulation/IInputTOBConverter.h"
 
-#include "AthenaBaseComps/AthAlgorithm.h"
+#include "PeriodicScaler.h"
+#include "TrigConfBase/MsgStream.h"
 #include "TrigInterfaces/IMonitoredAlgo.h"
-
-#include "GaudiKernel/ServiceHandle.h"
-#include "GaudiKernel/ToolHandle.h"
-
-#include <memory>
-
+#include "TrigConfInterfaces/IL1TopoConfigSvc.h"
+#include "TrigT1Interfaces/TrigT1StoreGateKeys.h"
+#include "TrigConfData/L1Menu.h"
 #include "TrigT1Interfaces/FrontPanelCTP.h"
 
 #include "StoreGate/ReadHandleKey.h"
 
-class TH1;
-class IMonitorToolBase;
-class ITHistSvc;
-
-namespace LVL1 {
-   class PeriodicScaler;
-}
+#include "AthenaBaseComps/AthAlgorithm.h"
+#include "AthenaMonitoring/IMonitorToolBase.h"
 
-namespace TCS {
-   class TopoSteering;
-}
+#include "GaudiKernel/ServiceHandle.h"
+#include "GaudiKernel/ToolHandle.h"
+#include "GaudiKernel/ITHistSvc.h"
 
-namespace TrigConf {
-   class IL1TopoConfigSvc;
-}
+#include "TH1F.h"
+#include <memory>
 
 namespace LVL1 {
 
-   class IInputTOBConverter;
-
    class L1TopoSimulation : public AthAlgorithm, public IMonitoredAlgo {
    public:
       L1TopoSimulation(const std::string &name, ISvcLocator *pSvcLocator);
@@ -68,41 +59,37 @@ namespace LVL1 {
 
    private:
 
-      //! \brief Alg handles to tools and services
-      //! @{
-      ServiceHandle<TrigConf::IL1TopoConfigSvc> m_l1topoConfigSvc;
-
-      ServiceHandle<ITHistSvc> m_histSvc;
-
-      ToolHandleArray < IMonitorToolBase > m_monitors;
-
-      ToolHandle<IInputTOBConverter> m_emtauInputProvider;
-
-      ToolHandle<IInputTOBConverter> m_jetInputProvider;
-
-      ToolHandle<IInputTOBConverter> m_energyInputProvider;
-
-      ToolHandle<IInputTOBConverter> m_muonInputProvider;
-
-      //! @}
-
-      BooleanProperty m_enableInputDump { false }; // for enabling input dumping
-      BooleanProperty m_enableBitwise { false }; // for enabling bitwise algorithms
-      StringProperty  m_inputDumpFile { "inputdump.txt" }; // input dump file
-      SG::WriteHandleKey<LVL1::FrontPanelCTP>  m_topoCTPLocation { "" }; ///< SG key of decision bits for CTP
-      SG::WriteHandleKey<LVL1::FrontPanelCTP>  m_topoOverflowCTPLocation { "" }; ///< SG key of overflow bits for CTP
-      int m_topoOutputLevel{TrigConf::MSGTC::WARNING};                                  // property to set the outputlevel of the topo algorithms
-      int m_topoSteeringOutputLevel{TrigConf::MSGTC::WARNING};                          // property to set the outputlevel of the topo steering
-
-      std::unique_ptr<TCS::TopoSteering>  m_topoSteering; //!< the topo steering 
-
-      BooleanProperty m_fillHistogramsBasedOnHardwareDecision { false }; // default: fill based on simulation
-      UnsignedIntegerProperty m_prescaleForDAQROBAccess {4}; ///< read hdw bits every N events (used only when m_fillHistogramsBasedOnHardwareDecision is true)
-      UnsignedIntegerProperty m_prescale; //! property for prescale factor
-      LVL1::PeriodicScaler* m_scaler; //! prescale decision tool
-
-      StringProperty m_histBaseDir; //! sets base dir for monitoring histograms
-  };
+      std::unique_ptr<TCS::TopoSteering>  m_topoSteering; //!< the topo steering
+      std::unique_ptr<LVL1::PeriodicScaler> m_scaler {nullptr}; //! prescale decision tool
+
+
+      // Services and input tools
+      ServiceHandle<TrigConf::IL1TopoConfigSvc> m_l1topoConfigSvc { this, "TrigConfigSvc", "TrigConf::TrigConfigSvc/TrigConfigSvc", "Service to provide the L1Topo menu" };
+      ServiceHandle<ITHistSvc> m_histSvc { this, "HistSvc", "THistSvc/THistSvc", "Histogramming service for L1Topo algorithms" };
+
+      ToolHandleArray < IMonitorToolBase > m_monitors { this, "AthenaMonTools", {}, "Monitoring tools"};
+      ToolHandle<IInputTOBConverter> m_emtauInputProvider  { this, "EMTAUInputProvider",  "LVL1::EMTauInputProvider/EMTauInputProvider",   "Tool to fill the EMTAU TOBs of the topo input event"         };
+      ToolHandle<IInputTOBConverter> m_jetInputProvider    { this, "JetInputProvider",    "LVL1::JetInputProvider/JetInputProvider",       "Tool to fill the Jet TOBs of the topo input event"           };
+      ToolHandle<IInputTOBConverter> m_energyInputProvider { this, "EnergyInputProvider", "LVL1::EnergyInputProvider/EnergyInputProvider", "Tool to fill the energy and MET TOBs of the topo input event"};
+      ToolHandle<IInputTOBConverter> m_muonInputProvider   { this, "MuonInputProvider",   "LVL1::MuonInputProvider/MuonInputProvider",     "Tool to fill the muon TOBs of the topo input event"          };
+
+      // outputs
+      SG::WriteHandleKey<LVL1::FrontPanelCTP>  m_topoCTPLocation { this, "TopoCTPLocation", LVL1::DEFAULT_L1TopoCTPLocation, "StoreGate key of topo decision output for CTP"}; ///< SG key of decision bits for CTP
+      SG::WriteHandleKey<LVL1::FrontPanelCTP>  m_topoOverflowCTPLocation { this, "TopoOverflowCTPLocation", LVL1::DEFAULT_L1TopoOverflowCTPLocation, "StoreGate key of topo overflow output for CTP"}; ///< SG key of overflow bits for CTP
+
+      Gaudi::Property<bool> m_isLegacyTopo { this, "IsLegacyTopo", false, "Simulation of Legacy L1Topo boards" };
+      Gaudi::Property<bool> m_enableInputDump { this, "EnableInputDump", false, "Enable writing of input data for standalone running" };
+      Gaudi::Property<bool> m_enableBitwise { this, "UseBitwise", false, "Boolean to enable the bitwise version of software algorithms"}; 
+      Gaudi::Property<std::string> m_inputDumpFile { this, "InputDumpFile", "inputdump.txt", "File name for dumping input data" };
+      Gaudi::Property<int> m_topoOutputLevel { this, "TopoOutputLevel", TrigConf::MSGTC::WARNING, "OutputLevel for L1Topo algorithms"};
+      Gaudi::Property<int> m_topoSteeringOutputLevel { this, "TopoSteeringOutputLevel", TrigConf::MSGTC::WARNING, "OutputLevel for L1Topo steering"};
+
+      // Properties for hardware monitoring
+      Gaudi::Property<bool> m_fillHistogramsBasedOnHardwareDecision { this, "FillHistoBasedOnHardware", true, "Fill accept/reject histograms based on hdw; default based on sim" };
+      Gaudi::Property<unsigned int> m_prescaleForDAQROBAccess { this, "PrescaleDAQROBAccess", 4, "Prescale factor for requests for DAQ ROBs: can be used to avoid overloading ROS. Zero means disabled, 1 means always, N means sample only 1 in N events"}; 
+      Gaudi::Property<unsigned int> m_prescale { this, "Prescale", 1, "Internal prescale factor for this algorithm, implemented with a periodic scaler: so 1 means run every time, N means run every 1 in N times it is called; the other times it will exit without doing anything"};
+      Gaudi::Property<std::string> m_histBaseDir { this, "MonHistBaseDir", "L1/L1TopoAlgorithms", "Base directory for monitoring histograms will be /EXPERT/<MonHistBaseDir>"}; 
+   };
 
 }
 #endif
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/test/L1TopoSimulationTest.cxx b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/test/L1TopoSimulationTest.cxx
index e801348c30e768adf05357d959c93f0ceb991e41..b3aa08ef47f5b094dd88aaa0505cbfee17689238 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/test/L1TopoSimulationTest.cxx
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/test/L1TopoSimulationTest.cxx
@@ -13,6 +13,11 @@
 
 #include "GaudiKernel/ITHistSvc.h"
 
+// Dependencies for new menu format
+#include "TrigConfIO/JsonFileLoader.h"
+#include "TrigConfData/L1Menu.h"
+#include "TrigConfData/L1Threshold.h"
+#include "TrigConfData/L1Connector.h"
 
 using namespace std;
 
@@ -23,6 +28,7 @@ LVL1::L1TopoSimulationTest::L1TopoSimulationTest(const std::string &name, ISvcLo
    m_OfftopoSteering( unique_ptr<TCS::TopoSteering>(new TCS::TopoSteering()) )
 {
    declareProperty( "InputXMLFile", m_OffinputXMLFile, "File name for menu XML");
+   declareProperty( "InputJSONFile", m_OffinputJSONFile, "File name for menu JSON");
    declareProperty( "InputASCIIFile", m_OffinputASCIIFile, "File name for ASCII TOB vector");
    declareProperty( "HistSvc", m_OffhistSvc, "Histogramming service for L1Topo algorithms");
    declareProperty( "MonHistBaseDir", m_OffhistBaseDir = "L1TopoAlgorithms", "Base directory for monitoring histograms will be /EXPERT/<MonHistBaseDir>" );
@@ -43,22 +49,27 @@ LVL1::L1TopoSimulationTest::isClonable() const
 
 StatusCode
 LVL1::L1TopoSimulationTest::initialize() {
-   m_OfftopoSteering->setMsgLevel( TrigConf::MSGTC::Level(m_OfftopoSteeringOutputLevel) );
 
-   if (m_OffinputXMLFile.empty()){
-      ATH_MSG_FATAL("No L1 Topo menu from XML " << m_OffinputXMLFile);
-      return StatusCode::FAILURE;
-   }
-   TXC::L1TopoXMLParser XMLParser;
-   XMLParser.msg().setLevel( TrigConf::MSGTC::Level(m_OfftopoOutputLevel) );
-   XMLParser.readConfiguration(m_OffinputXMLFile);
-   XMLParser.parseConfiguration();
+  m_OfftopoSteering->setMsgLevel( TrigConf::MSGTC::Level(m_OfftopoSteeringOutputLevel) );
+
+  ATH_MSG_INFO("initialize");
+
+  if (m_OffinputXMLFile.empty() || m_OffinputJSONFile.empty()){
+    ATH_MSG_FATAL("No L1 Topo menu from JSON " << m_OffinputJSONFile);
+    return StatusCode::FAILURE;
+  }
+
+  TrigConf::L1Menu l1menu;
+  TrigConf::JsonFileLoader fileLoader;
+  fileLoader.loadFile( m_OffinputJSONFile, l1menu);
+  m_OfftopoSteering->setupFromConfiguration(l1menu);
+    
 
-   m_OfftopoSteering->setupFromConfiguration(XMLParser.takeMenu());
-   m_OfftopoSteering->setAlgMsgLevel( TrigConf::MSGTC::Level(m_OfftopoOutputLevel) );
+  // ----------------------------------------------------
+  m_OfftopoSteering->setAlgMsgLevel( TrigConf::MSGTC::Level(m_OfftopoOutputLevel) );
 
   
-   std::shared_ptr<IL1TopoHistSvc> topoHistSvc = std::shared_ptr<IL1TopoHistSvc>( new AthenaL1TopoHistSvc(m_OffhistSvc) );
+  std::shared_ptr<IL1TopoHistSvc> topoHistSvc = std::shared_ptr<IL1TopoHistSvc>( new AthenaL1TopoHistSvc(m_OffhistSvc) );
    topoHistSvc->setBaseDir("/EXPERT/" + m_OffhistBaseDir.value());
   
    
@@ -88,15 +99,25 @@ LVL1::L1TopoSimulationTest::initialize() {
 StatusCode
 LVL1::L1TopoSimulationTest::execute() {
 
+  cout << "Reseting TopoSteering" << endl;
+
    // reset input and internal state
    m_OfftopoSteering->reset();
 
+   cout << "Getting next event from dump txt" << endl;
+
    // Obtain next events in the dump txt
    m_Offreader.getNextEvent();
 
+   cout << "Executing even in TopoSteering" << endl;
+
    // execute the toposteering
    m_OfftopoSteering->executeEvent();
 
+   // Printout the decision bits
+   cout << "Printing out decisions" << endl;
+   cout << m_OfftopoSteering->simulationResult().globalDecision();
+
    return StatusCode::SUCCESS;
 }
 
diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/test/L1TopoSimulationTest.h b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/test/L1TopoSimulationTest.h
index 21360f1df2fd124575a1980efa7d6a60cfbd7b7c..cb84a5bfaaf7f91887fc49bda28b99b6d45da00c 100644
--- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/test/L1TopoSimulationTest.h
+++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/test/L1TopoSimulationTest.h
@@ -43,6 +43,7 @@ namespace LVL1 {
     // make algorithm is clonable
     virtual bool isClonable() const override;
 
+
   private:
 
     TCS::TopoASCIIReader m_Offreader;
@@ -55,6 +56,7 @@ namespace LVL1 {
     StringProperty  m_OffhistBaseDir; //! sets base dir for monitoring histograms
     StringProperty  m_OffinputASCIIFile { "" }; // input dump file
     StringProperty  m_OffinputXMLFile { "" }; // XML file can be register in case of enabling the ASCII file read for validation purposes
+    StringProperty  m_OffinputJSONFile { "" }; // JSON file for menu
 
     std::unique_ptr<TCS::TopoSteering>  m_OfftopoSteering; //!< the topo steering
      
diff --git a/Trigger/TrigT1/TrigT1CTP/share/TrigT1CTP_standalone_xml_job.py b/Trigger/TrigT1/TrigT1CTP/share/TrigT1CTP_standalone_xml_job.py
index 3a365b2cf7205c96ca229b6b8d606b80a7f20b50..8468b24b2efb0fe477ac2be4039e98d203d686c2 100755
--- a/Trigger/TrigT1/TrigT1CTP/share/TrigT1CTP_standalone_xml_job.py
+++ b/Trigger/TrigT1/TrigT1CTP/share/TrigT1CTP_standalone_xml_job.py
@@ -42,8 +42,6 @@ include("RecExCond/AllDet_detDescr.py")
 # use TriggerGetter but disable HLT
 from TriggerJobOpts.TriggerFlags import TriggerFlags as TF
 TF.doLVL1 = True
-TF.doLVL2 = False
-TF.doEF = False
 TF.doHLT = False
 TF.readLVL1configFromXML=True
 TF.triggerMenuSetup = "MC_pp_v5"
diff --git a/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.cxx b/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.cxx
index 355395511b13ccbc7afa71122bf2089fb05b5e65..23c408107df9307e092dbe70ab5945ad5e4d4c4a 100644
--- a/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.cxx
+++ b/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.cxx
@@ -47,7 +47,7 @@ const std::function< CLHEP::HepRandomEngine*(void) > CTPSimRanluxFactory = [](vo
 
 
 LVL1CTP::CTPSimulation::CTPSimulation( const std::string& name, ISvcLocator* pSvcLocator ) :
-   AthReentrantAlgorithm ( name, pSvcLocator ), 
+   AthReentrantAlgorithm ( name, pSvcLocator ),
    m_RNGEngines( CTPSimRanluxFactory, SG::getNSlots() ),
    m_decoder( new LVL1::CPRoIDecoder() ),
    m_jetDecoder( new LVL1::JEPRoIDecoder() )
@@ -103,14 +103,14 @@ LVL1CTP::CTPSimulation::start() {
 
    const TrigConf::L1Menu * l1menu = nullptr;
    if( m_useNewConfig ) {
-      ATH_CHECK( m_detStore->retrieve(l1menu) ); 
-      ATH_MSG_INFO( "start(): use L1 trigger menu from detector store" );
+      ATH_CHECK( detStore()->retrieve(l1menu) );
+      ATH_MSG_INFO( "start(): use new-style L1 menu (json)" );
       if(l1menu == nullptr) { // if no L1 configuration is available yet
          delayConfig = true;
       }
    } else {
-      ATH_MSG_INFO( "start(): use L1 trigger menu from L1ConfigSvc" );
-      if( (m_configSvc->ctpConfig()==nullptr) || 
+      ATH_MSG_INFO( "start(): use old-style L1 menu (xml))" );
+      if( (m_configSvc->ctpConfig()==nullptr) ||
           (m_configSvc->ctpConfig()->menu().itemVector().size() == 0) ) { // if no L1 configuration is available yet
          delayConfig = true;
       }
@@ -120,7 +120,7 @@ LVL1CTP::CTPSimulation::start() {
    if( ! delayConfig ) {
       // configure the CTP ResultBuilder
       // currently both types of configuration can be given (transition period towards Run 3)
-      std::call_once(m_onceflag, [this, l1menu]{ 
+      std::call_once(m_onceflag, [this, l1menu]{
             m_resultBuilder->setConfiguration( m_configSvc->ctpConfig(), l1menu ).ignore();
             setHistLabels().ignore();
          });
@@ -137,7 +137,7 @@ LVL1CTP::CTPSimulation::execute( const EventContext& context ) const {
    std::call_once(m_onceflag, [this]{
          const TrigConf::L1Menu * l1menu = nullptr;
          if( m_useNewConfig ) {
-            m_detStore->retrieve(l1menu).ignore(); 
+            detStore()->retrieve(l1menu).ignore();
          }
          m_resultBuilder->setConfiguration( m_configSvc->ctpConfig(), l1menu ).ignore();
          setHistLabels().ignore();
@@ -154,8 +154,6 @@ LVL1CTP::CTPSimulation::execute( const EventContext& context ) const {
    return StatusCode::SUCCESS;
 }
 
-
-
 StatusCode
 LVL1CTP::CTPSimulation::createMultiplicityHist(const std::string & type, unsigned int maxMult ) const {
 
@@ -186,7 +184,6 @@ LVL1CTP::CTPSimulation::createMultiplicityHist(const std::string & type, unsigne
    return sc;
 }
 
-
 StatusCode
 LVL1CTP::CTPSimulation::setMultiplicityHistLabels(const ConfigSource & cfgSrc, const std::string & type, TrigConf::L1DataDef::TriggerType tt ) const {
    StatusCode sc;
@@ -305,7 +302,7 @@ LVL1CTP::CTPSimulation::setHistLabels() const {
 
    const TrigConf::L1Menu * l1menu = nullptr;
    if( m_useNewConfig ) {
-      ATH_CHECK( m_detStore->retrieve(l1menu) ); 
+      ATH_CHECK( detStore()->retrieve(l1menu) );
       ATH_MSG_DEBUG("setHistLabels(). L1 menu " << l1menu->size() << " items" );
    } else {
       ATH_MSG_DEBUG("setHistLabels(). ConfigSvc with " << m_configSvc->ctpConfig()->menu().itemVector().size() << " items");
@@ -321,24 +318,21 @@ LVL1CTP::CTPSimulation::setHistLabels() const {
    ATH_CHECK ( setMultiplicityHistLabels( cfgSrc, "tau",  L1DataDef::TAU ) );
 
    // Topo
-   auto hTopo0 = *get1DHist("/input/topo/l1topo0");
-   auto hTopo1 = *get1DHist("/input/topo/l1topo1");
    if ( l1menu ) {
-      // to be implemented
-   } else {
-      for(const TIP * tip : m_configSvc->ctpConfig()->menu().tipVector() ) {
-         if ( tip->tipNumber() < 384 )
+      std::vector<std::string> connNames = l1menu->connectorNames();
+      for( const std::string connName : {"LegacyTopo0", "LegacyTopo1", "Topo1El", "Topo2El", "Topo3El"}) {
+         if( find(connNames.begin(), connNames.end(), connName) == connNames.end() ) {
             continue;
-         unsigned int tipNumber = (unsigned int) ( tip->tipNumber() - 384 );
-         switch(tipNumber / 64) {
-         case 0:
-            hTopo0->GetXaxis()->SetBinLabel(1+ tipNumber % 64, tip->thresholdName().c_str() );
-            break;
-         case 1:
-            hTopo1->GetXaxis()->SetBinLabel(1+ tipNumber % 64, tip->thresholdName().c_str() );
-            break;
-         default:
-            break;
+         }
+         auto hTopo = *get1DHist("/input/topo/" + connName);
+         for(uint fpga : {0,1}) {
+            for(uint clock : {0,1}) {
+               for(auto & tl : l1menu->connector(connName).triggerLines(fpga,clock)) {
+                  //uint flatIndex = 32*tl.fpga() + 2*tl.startbit() + tl.clock(); // activate later
+                  uint flatIndex = 32*tl.fpga() + tl.startbit() + 16*tl.clock();
+                  hTopo->GetXaxis()->SetBinLabel(flatIndex+1,tl.name().c_str());
+               }         
+            }
          }
       }
    }
@@ -385,7 +379,6 @@ LVL1CTP::CTPSimulation::setHistLabels() const {
    return StatusCode::SUCCESS;
 }
 
-
 StatusCode
 LVL1CTP::CTPSimulation::bookHists() const {
 
@@ -426,10 +419,10 @@ LVL1CTP::CTPSimulation::bookHists() const {
    ATH_CHECK ( hbook( "/input/counts/", std::make_unique<TH1I>("jJets","Number of jets (jJ)", 40, 0, 40) ));
    ATH_CHECK ( hbook( "/input/counts/", std::make_unique<TH1I>("jLJets","Number of jets (jLJ)", 40, 0, 40) ));
    ATH_CHECK ( hbook( "/input/counts/", std::make_unique<TH1I>("gJets","Number of jets (gJ)", 40, 0, 40) ));
-   ATH_CHECK ( hbook( "/input/counts/", std::make_unique<TH1I>("muons","Number of muons", 10, 0, 10) ));  
+   ATH_CHECK ( hbook( "/input/counts/", std::make_unique<TH1I>("muons","Number of muons", 10, 0, 10) ));
    ATH_CHECK ( hbook( "/input/counts/", std::make_unique<TH1I>("emcluster","Number of EM clusters", 20, 0, 20) ));
    ATH_CHECK ( hbook( "/input/counts/", std::make_unique<TH1I>("taus","Number of TAU candidates", 20, 0, 20) ));
- 
+
    // threshold multiplicities
    ATH_CHECK ( createMultiplicityHist( "muon" ) );
    ATH_CHECK ( createMultiplicityHist( "jet" ) );
@@ -443,8 +436,12 @@ LVL1CTP::CTPSimulation::bookHists() const {
    ATH_CHECK ( hbook( "/multi/all", (std::unique_ptr<TH2>)std::make_unique<TH2I>("R3Mult", "New thresholds multiplicity", 1, 0, 1, 10, 0, 10) ));
 
    // Topo
-   ATH_CHECK( hbook( "/input/topo/", std::make_unique<TH1I>("l1topo0","L1Topo Decision Cable 0", 64, 0, 64) ));
-   ATH_CHECK( hbook( "/input/topo/", std::make_unique<TH1I>("l1topo1","L1Topo Decision Cable 1", 64, 0, 64) ));
+   ATH_CHECK( hbook( "/input/topo/", std::make_unique<TH1I>("LegacyTopo0","L1Topo Decision (Legacy 0)", 64, 0, 64) ));
+   ATH_CHECK( hbook( "/input/topo/", std::make_unique<TH1I>("LegacyTopo1","L1Topo Decision (Legacy 1)", 64, 0, 64) ));
+   ATH_CHECK( hbook( "/input/topo/", std::make_unique<TH1I>("Topo1El","L1Topo Decision (Topo 1 electrical)", 64, 0, 64) ));
+   ATH_CHECK( hbook( "/input/topo/", std::make_unique<TH1I>("Topo2El","L1Topo Decision (Topo 2 electrical)", 64, 0, 64) ));
+   ATH_CHECK( hbook( "/input/topo/", std::make_unique<TH1I>("Topo3El","L1Topo Decision (Topo 3 electrical)", 64, 0, 64) ));
+   ATH_CHECK( hbook( "/input/topo/", std::make_unique<TH1I>("Topo1Opt0","L1Topo Decision (Topo 1 optical 0)", 90, 0, 90) ));
 
    // item decision
    ATH_CHECK ( hbook( "/output/", std::make_unique<TH1I>("tbpById", "Items decision (tbp)", 512, 0, 512) ));
@@ -461,7 +458,6 @@ LVL1CTP::CTPSimulation::bookHists() const {
    return StatusCode::SUCCESS;
 }
 
-
 StatusCode
 LVL1CTP::CTPSimulation::fillInputHistograms(const EventContext& context) const {
 
@@ -581,24 +577,43 @@ LVL1CTP::CTPSimulation::fillInputHistograms(const EventContext& context) const {
    }
 
    // topo
+   auto legacyTopoInput = SG::makeHandle( m_iKeyLegacyTopo, context );
+   if(legacyTopoInput.isValid()) {
+      ATH_MSG_DEBUG("Retrieved input from L1Topo from StoreGate with key " << m_iKeyTopo);
+      ATH_MSG_DEBUG("L1TopoLegacy0 word 0 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << legacyTopoInput->cableWord1(0));
+      ATH_MSG_DEBUG("L1TopoLegacy0 word 1 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << legacyTopoInput->cableWord1(1));
+      ATH_MSG_DEBUG("L1TopoLegacy1 word 0 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << legacyTopoInput->cableWord2(0));
+      ATH_MSG_DEBUG("L1TopoLegacy1 word 1 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << legacyTopoInput->cableWord2(1));
+      auto h0 = *get1DHist("/input/topo/LegacyTopo0");
+      auto h1 = *get1DHist("/input/topo/LegacyTopo1");
+      for(unsigned int i=0; i<32; ++i) {
+         uint32_t mask = 0x1; mask <<= i;
+         if( (legacyTopoInput->cableWord1(0) & mask) != 0 ) h0->Fill(i); // cable 0, clock 0
+         if( (legacyTopoInput->cableWord1(1) & mask) != 0 ) h0->Fill(32 + i); // cable 0, clock 1
+         if( (legacyTopoInput->cableWord2(0) & mask) != 0 ) h1->Fill(i); // cable 1, clock 0
+         if( (legacyTopoInput->cableWord2(1) & mask) != 0 ) h1->Fill(32 + i); // cable 1, clock 1
+      }
+   }
+
    auto topoInput = SG::makeHandle( m_iKeyTopo, context );
    if(topoInput.isValid()) {
       ATH_MSG_DEBUG("Retrieved input from L1Topo from StoreGate with key " << m_iKeyTopo);
-      ATH_MSG_DEBUG("L1Topo0 word 0 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << topoInput->cableWord1(0));
-      ATH_MSG_DEBUG("L1Topo0 word 1 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << topoInput->cableWord1(1));
-      ATH_MSG_DEBUG("L1Topo1 word 0 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << topoInput->cableWord2(0));
-      ATH_MSG_DEBUG("L1Topo1 word 1 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << topoInput->cableWord2(1));
-      auto h0 = *get1DHist("/input/topo/l1topo0");
-      auto h1 = *get1DHist("/input/topo/l1topo1");
+      ATH_MSG_DEBUG("L1Topo 2 word 0 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << topoInput->cableWord1(0));
+      ATH_MSG_DEBUG("L1Topo 2 word 1 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << topoInput->cableWord1(1));
+      ATH_MSG_DEBUG("L1Topo 3 word 0 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << topoInput->cableWord2(0));
+      ATH_MSG_DEBUG("L1Topo 3 word 1 is: 0x" << std::hex << std::setw( 8 ) << std::setfill( '0' ) << topoInput->cableWord2(1));
+      auto h0 = *get1DHist("/input/topo/Topo1El");
+      auto h1 = *get1DHist("/input/topo/Topo2El");
+      auto h2 = *get1DHist("/input/topo/Topo3El");
       for(unsigned int i=0; i<32; ++i) {
          uint32_t mask = 0x1; mask <<= i;
-         if( (topoInput->cableWord1(0) & mask) != 0 ) h0->Fill(i); // cable 0, clock 0
-         if( (topoInput->cableWord1(1) & mask) != 0 ) h0->Fill(32 + i); // cable 0, clock 1
-         if( (topoInput->cableWord2(0) & mask) != 0 ) h1->Fill(i); // cable 1, clock 0
-         if( (topoInput->cableWord2(1) & mask) != 0 ) h1->Fill(32 + i); // cable 1, clock 1
+         if( (topoInput->cableWord0(0) & mask) != 0 ) h0->Fill(i); // cable 0, clock 0
+         if( (topoInput->cableWord0(1) & mask) != 0 ) h0->Fill(32 + i); // cable 0, clock 1
+         if( (topoInput->cableWord1(0) & mask) != 0 ) h1->Fill(i); // cable 0, clock 0
+         if( (topoInput->cableWord1(1) & mask) != 0 ) h1->Fill(32 + i); // cable 0, clock 1
+         if( (topoInput->cableWord2(0) & mask) != 0 ) h2->Fill(i); // cable 1, clock 0
+         if( (topoInput->cableWord2(1) & mask) != 0 ) h2->Fill(32 + i); // cable 1, clock 1
       }
-   } else {
-      ATH_MSG_DEBUG("No collection " << m_iKeyTopo);
    }
 
    // bcid
@@ -619,13 +634,66 @@ LVL1CTP::CTPSimulation::extractMultiplicities(std::map<std::string, unsigned int
 
    const TrigConf::L1Menu * l1menu = nullptr;
    if( m_useNewConfig ) {
-      ATH_CHECK( m_detStore->retrieve(l1menu) );
+      ATH_CHECK( detStore()->retrieve(l1menu) );
    }
 
    thrMultiMap.clear();
 
    if( l1menu ) {
+      std::vector<std::string> connNames = l1menu->connectorNames();
+      for( const std::string connName : {"LegacyTopo0", "LegacyTopo1", "Topo1El", "Topo2El", "Topo3El"}) {
+         if( find(connNames.begin(), connNames.end(), connName) == connNames.end() ) {
+            continue;
+         }
+         uint64_t cable {0};
+         if (connName.find("Legacy")==0) { // legacy topo
+            auto topoInput = SG::makeHandle( m_iKeyLegacyTopo, context );
+            if (not topoInput.isValid()) {
+               continue;
+            }
+            if(connName == "LegacyTopo0") {
+               cable = ( (uint64_t)topoInput->cableWord1( 1 ) << 32) + topoInput->cableWord1( 0 );
+            } else if (connName == "LegacyTopo1") {
+               cable = ( (uint64_t)topoInput->cableWord2( 1 ) << 32) + topoInput->cableWord2( 0 );
+            }
+         } else { // new topo
+            auto topoInput = SG::makeHandle( m_iKeyTopo, context );
+            if (not topoInput.isValid()) {
+               continue;
+            }
+            if(connName == "Topo1El") {
+               cable = ( (uint64_t)topoInput->cableWord0( 1 ) << 32) + topoInput->cableWord0( 0 );
+            } else if(connName == "Topo2El") {
+               cable = ( (uint64_t)topoInput->cableWord1( 1 ) << 32) + topoInput->cableWord1( 0 );
+            } else if (connName == "Topo3El") {
+               cable = ( (uint64_t)topoInput->cableWord2( 1 ) << 32) + topoInput->cableWord2( 0 );
+            }
+         }
+         auto & conn = l1menu->connector(connName);
+         for(uint fpga : {0,1}) {
+            for(uint clock : {0,1}) {
+               for(auto & tl : conn.triggerLines(fpga,clock)) {
+                  //uint flatIndex = 32*tl.fpga() + 2*tl.startbit() + tl.clock(); // activate later
+                  uint flatIndex = 32*tl.fpga() + tl.startbit() + 16*tl.clock();
+                  uint pass = (cable & (uint64_t(0x1) << flatIndex)) == 0 ? 0 : 1;
+                  if(size_t pos = tl.name().find('['); pos == std::string::npos) {
+                     thrMultiMap[tl.name()] = pass;
+                     ATH_MSG_DEBUG(tl.name() << " MULT calculated mult for topo " << pass);
+                  } else {
+                     auto thrName = tl.name().substr(0,pos);
+                     int bit = std::stoi(tl.name().substr(pos+1));
+                     thrMultiMap.try_emplace(thrName, 0);
+                     thrMultiMap[thrName] += (pass << bit);
+                     ATH_MSG_DEBUG(thrName << " MULT updated mult for topo " << pass);
+                  }
+               }
+            }
+         }
+      }
       for ( auto & thr : l1menu->thresholds() ) {
+         if(thr->type() == "TOPO" or thr->type()== "R2TOPO" or thr->type() == "MULTTOPO" or thr->type() == "MUTOPO") {
+            continue; 
+         }
          // get the multiplicity for each threshold
          unsigned int multiplicity = calculateMultiplicity( *thr, l1menu, context );
          // and record in threshold--> multiplicity map (to be used for item decision)
@@ -672,7 +740,6 @@ LVL1CTP::CTPSimulation::extractMultiplicities(std::map<std::string, unsigned int
 }
 
 
-
 unsigned int
 LVL1CTP::CTPSimulation::calculateJetMultiplicity( const TrigConf::L1Threshold & confThr, const TrigConf::L1Menu * l1menu, const EventContext& context ) const {
    unsigned int multiplicity = 0;
@@ -740,7 +807,6 @@ LVL1CTP::CTPSimulation::calculateJetMultiplicity( const TrigConf::L1Threshold &
 }
 
 
-
 unsigned int
 LVL1CTP::CTPSimulation::calculateJetMultiplicity( const TrigConf::TriggerThreshold * confThr, const EventContext& context ) const {
    unsigned int multiplicity = 0;
@@ -752,7 +818,7 @@ LVL1CTP::CTPSimulation::calculateJetMultiplicity( const TrigConf::TriggerThresho
          } else if ( confThr->cableName() == "JEP2" || confThr->cableName() == "JET2" ) {
             multiplicity = CTPUtil::getMult( ctpinJet->cableWord1(), confThr->cableStart(), confThr->cableEnd() );
          }
-      } 
+      }
    } else {
       // Run-3 threshold
       const SG::ReadHandleKey< xAOD::JetRoIContainer > * rhk { nullptr };
@@ -831,11 +897,10 @@ LVL1CTP::CTPSimulation::calculateEMMultiplicity( const TrigConf::L1Threshold & c
 }
 
 
-
 unsigned int
 LVL1CTP::CTPSimulation::calculateEMMultiplicity( const TrigConf::TriggerThreshold * confThr, const EventContext& context ) const {
    unsigned int multiplicity (0);
-   if ( confThr->name()[0]=='e' ) { 
+   if ( confThr->name()[0]=='e' ) {
       // new EM threshold from eFEX
       auto eFexCluster = SG::makeHandle( m_iKeyEFexCluster, context );
       for ( const auto & cl : *eFexCluster ) {
@@ -904,7 +969,7 @@ LVL1CTP::CTPSimulation::calculateTauMultiplicity( const TrigConf::L1Threshold &
 unsigned int
 LVL1CTP::CTPSimulation::calculateTauMultiplicity( const TrigConf::TriggerThreshold * confThr, const EventContext& context ) const {
    unsigned int multiplicity = 0;
-   if ( confThr->name()[0]=='e' ) { 
+   if ( confThr->name()[0]=='e' ) {
       // new TAU threshold from eFEX
       auto eFexTaus  = SG::makeHandle( m_iKeyEFexTau, context );
       const static SG::AuxElement::ConstAccessor<float> accR3ClET ("R3ClusterET");
@@ -938,7 +1003,6 @@ LVL1CTP::CTPSimulation::calculateTauMultiplicity( const TrigConf::TriggerThresho
 }
 
 
-
 unsigned int
 LVL1CTP::CTPSimulation::calculateMETMultiplicity( const TrigConf::L1Threshold & confThr, const TrigConf::L1Menu * l1menu, const EventContext& context ) const {
    unsigned int multiplicity = 0;
@@ -987,7 +1051,6 @@ LVL1CTP::CTPSimulation::calculateMETMultiplicity( const TrigConf::L1Threshold &
 }
 
 
-
 unsigned int
 LVL1CTP::CTPSimulation::calculateMETMultiplicity( const TrigConf::TriggerThreshold * confThr, const EventContext& context ) const {
    unsigned int multiplicity = 0;
@@ -1002,7 +1065,7 @@ LVL1CTP::CTPSimulation::calculateMETMultiplicity( const TrigConf::TriggerThresho
          }
       }
    } else if ( confThr->name().find("TE")==0 ) {
-      // old TE 
+      // old TE
       auto ctpinEnergy = SG::makeHandle( m_iKeyCtpinXE, context );
       if ( ctpinEnergy.isValid() ) {
          if ( confThr->cableName() == "JEP3" || confThr->cableName() == "EN1") {
@@ -1128,10 +1191,10 @@ LVL1CTP::CTPSimulation::calculateTopoMultiplicity( const TrigConf::TriggerThresh
 unsigned int
 LVL1CTP::CTPSimulation::calculateMultiplicity( const TrigConf::TriggerThreshold * confThr, const EventContext& context ) const {
    unsigned int multiplicity = 0;
-   if( confThr->cableName() == "CTPCAL" || 
-       confThr->cableName() == "ALFA" || 
-       confThr->cableName() == "NIM1" || 
-       confThr->cableName() == "NIM2" || 
+   if( confThr->cableName() == "CTPCAL" ||
+       confThr->cableName() == "ALFA" ||
+       confThr->cableName() == "NIM1" ||
+       confThr->cableName() == "NIM2" ||
        confThr->type() == "NIM") {
       return 0;
    }
@@ -1168,8 +1231,6 @@ LVL1CTP::CTPSimulation::calculateMultiplicity( const TrigConf::L1Threshold & con
          multiplicity = calculateJetMultiplicity( confThr, l1menu, context );
       } else if ( confThr.type() == "MU" ) {
          multiplicity = calculateMuonMultiplicity( confThr, l1menu, context );
-      } else if ( confThr.type() == "TOPO" ) {
-         multiplicity = calculateTopoMultiplicity( confThr, l1menu, context );
       }
    }
    catch(std::exception & ex) {
@@ -1238,7 +1299,7 @@ LVL1CTP::CTPSimulation::finalize() {
 
    const TrigConf::L1Menu * l1menu = nullptr;
    if( m_useNewConfig ) {
-      ATH_CHECK( m_detStore->retrieve(l1menu) );
+      ATH_CHECK( detStore()->retrieve(l1menu) );
    }
 
    constexpr unsigned int sizeOfCTPOutput = 512;
@@ -1297,7 +1358,7 @@ LVL1CTP::CTPSimulation::finalize() {
       } else {
          thrHists = { "em/em", "muon/muon", "tau/tau", "jet/jet", "xe/xe", "te/te", "xs/xs" };
       }
-      auto hist = * get2DHist( "/multi/all/LegacyMult" ); 
+      auto hist = * get2DHist( "/multi/all/LegacyMult" );
       for(const std::string & histpath : thrHists) {
          auto h = * get2DHist( "/multi/" + histpath + "Mult" );
          auto xaxis = h->GetXaxis();
@@ -1319,7 +1380,7 @@ LVL1CTP::CTPSimulation::finalize() {
    {
       // run 3 thresholds
       if( l1menu ) {
-         auto hist = * get2DHist( "/multi/all/R3Mult" ); 
+         auto hist = * get2DHist( "/multi/all/R3Mult" );
          std::vector<std::string> thrHists = { "em/eEM", "muon/MU", "tau/eTAU", "jet/jJ", "jet/gJ", "xe/gXE", "xe/jXE" };
          for(const std::string & histpath : thrHists) {
             auto h = * get2DHist( "/multi/" + histpath + "Mult" );
diff --git a/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.h b/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.h
index d6efae27b3bf51d375cc5c22e685f2c80e4434d5..efb96d9222337b94d88899a391018f4a6db54b93 100644
--- a/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.h
+++ b/Trigger/TrigT1/TrigT1CTP/src/CTPSimulation.h
@@ -133,7 +133,7 @@ namespace LVL1CTP {
       // Needed services and tools
       ServiceHandle<ITHistSvc> m_histSvc { this, "THistSvc", "THistSvc/THistSvc", "Histogramming svc" };
       ServiceHandle<TrigConf::ILVL1ConfigSvc> m_configSvc { this, "TrigConfigSvc", "TrigConf::TrigConfigSvc/TrigConfigSvc", "Trigger configuration service" };
-      ServiceHandle<StoreGateSvc> m_detStore { this, "DetectorStore", "StoreGateSvc/DetectorStore", "Detector store to get the menu" };
+      // ServiceHandle<StoreGateSvc> m_detStore { this, "DetectorStore", "StoreGateSvc/DetectorStore", "Detector store to get the menu" };
       ToolHandle<LVL1CTP::ResultBuilder> m_resultBuilder { this, "ResultBuilder", "LVL1CTP__ResultBuilder/ResultBuilder", "Builds the CTP result" };
 
       // random engine for calculating prescales
diff --git a/Trigger/TrigT1/TrigT1CTP/src/CTPTriggerItem.cxx b/Trigger/TrigT1/TrigT1CTP/src/CTPTriggerItem.cxx
index b3456445b6fc9a02677b397dbb5442a001c1ebba..253c69230d239446b828b8a0dd0f735522a5eb33 100644
--- a/Trigger/TrigT1/TrigT1CTP/src/CTPTriggerItem.cxx
+++ b/Trigger/TrigT1/TrigT1CTP/src/CTPTriggerItem.cxx
@@ -2,12 +2,11 @@
   Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
+#include "./CTPTriggerItem.h"
 #include "TrigConfData/LogicParser.h"
-
 #include "TrigConfL1Data/TriggerItem.h"
 
-#include "./CTPTriggerItem.h"
-
+#include <exception>
 
 LVL1CTP::CTPTriggerItem::CTPTriggerItem()
 {}
@@ -88,8 +87,13 @@ LVL1CTP::CTPTriggerItem::evaluate( const std::map<std::string, unsigned int> & t
       if( dec && (! m_bunchGroups.empty()) ) {
          // apply bunchgroups, if set (if not set, it is part of the logic)
          for( auto & bgName : m_bunchGroups ) {
-            if( thrDecMap.at(bgName) == 0 ) {
-               dec = false; break;
+            try {
+               if( thrDecMap.at(bgName) == 0 ) {
+                  dec = false; break;
+               }
+            }
+            catch(std::exception &) {
+               throw std::runtime_error( "Problem accessing decision for bunchgroup " + bgName);
             }
          }
       }
diff --git a/Trigger/TrigT1/TrigT1CTP/src/ResultBuilder.cxx b/Trigger/TrigT1/TrigT1CTP/src/ResultBuilder.cxx
index e277d51d9127104ed1660d8d91140fc6e2109a01..890651d8809413cd852e3b32e6741f3ad622525a 100644
--- a/Trigger/TrigT1/TrigT1CTP/src/ResultBuilder.cxx
+++ b/Trigger/TrigT1/TrigT1CTP/src/ResultBuilder.cxx
@@ -118,7 +118,6 @@ StatusCode
 LVL1CTP::ResultBuilder::constructTIPVector( const std::map<std::string, unsigned int> & thrMultiMap,
                                             std::vector<uint32_t> & tip ) const
 {
-
    tip.resize( m_ctpDataFormat->getTIPwords(), 0 );
    
    for( auto & entry : thrMultiMap ) {
@@ -184,7 +183,7 @@ LVL1CTP::ResultBuilder::buildItemDecision( const std::map<std::string, unsigned
    itemDecisionMap.clear();
 
    try {
-      for( auto itemName : m_itemConfigMap->itemNames() ) {
+      for( const auto & itemName : m_itemConfigMap->itemNames() ) {
          auto ctpItem = m_itemConfigMap->getItem(itemName);
 
          bool pass_beforePrescale =  ctpItem->evaluate(thrMultiMap);
@@ -246,7 +245,7 @@ LVL1CTP::ResultBuilder::constructResultVectors( const std::map<std::string, unsi
       ATH_MSG_DEBUG( "  --> Trigger item " << itemName << 
                      " is " << ( !passBP ? "INACTIVE" : ( passAV ? "ACTIVE" : "ACTIVE (but PRESCALED)" ) ) );
    }
-   ATH_MSG_DEBUG( "REGTEST - " << "TriggerType byte is: 0x" << std::hex << std::setw( 2 ) << std::setfill( '0' ) << triggerType );
+   ATH_MSG_DEBUG( "REGTEST - " << "TriggerType byte is: 0x" << std::setw( 2 ) << std::setfill( '0' ) << std::hex << int(triggerType) );
 
    return StatusCode::SUCCESS;
 }
diff --git a/Trigger/TrigT1/TrigT1CTP/src/ThresholdMap.cxx b/Trigger/TrigT1/TrigT1CTP/src/ThresholdMap.cxx
index 4d40dadc4bc0523c0d606cb20f8eab8ec92b38d3..901103b9f5cfeb6b585219e956eaffc73849270c 100644
--- a/Trigger/TrigT1/TrigT1CTP/src/ThresholdMap.cxx
+++ b/Trigger/TrigT1/TrigT1CTP/src/ThresholdMap.cxx
@@ -98,6 +98,11 @@ LVL1CTP::ThresholdMap::getThresholdNames() const {
 
 const LVL1CTP::CTPTriggerThreshold &
 LVL1CTP::ThresholdMap::getCTPThreshold( const std::string & thrName ) const {
-   return * m_mapByName.at( thrName );
+   try {
+      return * m_mapByName.at( thrName );
+   }
+   catch(std::exception&) {
+      throw std::runtime_error("Threshold " + thrName + " not present in CTPSimulation's internal threshold map");
+   }
 }
 
diff --git a/Trigger/TrigT1/TrigT1NSWSimTools/src/MMLoadVariables.cxx b/Trigger/TrigT1/TrigT1NSWSimTools/src/MMLoadVariables.cxx
index e07e4c49f8b0272a728351dcd852fc4f61f97489..fc429f89b5a0b20c4b4afd97e763e84173b5da94 100644
--- a/Trigger/TrigT1/TrigT1NSWSimTools/src/MMLoadVariables.cxx
+++ b/Trigger/TrigT1/TrigT1NSWSimTools/src/MMLoadVariables.cxx
@@ -71,18 +71,22 @@ MMLoadVariables::MMLoadVariables(StoreGateSvc* evtStore, const MuonGM::MuonDetec
 
       for(const auto it : *truthContainer) {  //first loop in MMT_loader::load_event
         const HepMC::GenEvent *subEvent = it;
+#ifdef HEPMC3
+        for(auto particle : subEvent->particles()) {
+#else
         HepMC::ConstGenEventParticleRange particle_range = subEvent->particle_range();
         for(const auto pit : particle_range) {
           const HepMC::GenParticle *particle = pit;
-          const HepMC::FourVector& momentum = particle->momentum();
+#endif
+          const HepMC::FourVector momentum = particle->momentum();
           int k=trackRecordCollection->size(); //number of mu entries
-          if(particle->barcode() == 10001 && std::abs(particle->pdg_id())==13){
+          if(HepMC::barcode(particle) == 10001 && std::abs(particle->pdg_id())==13){
             thePart.SetPtEtaPhiE(momentum.perp(),momentum.eta(),momentum.phi(),momentum.e());
             for(const auto & mit : *trackRecordCollection ) {
               if(k>0&&j<k){
                 const CLHEP::Hep3Vector mumomentum = mit.GetMomentum();
                 const CLHEP::Hep3Vector muposition = mit.GetPosition();
-                pdg=particle->barcode();
+                pdg=HepMC::barcode(particle);
                 phiEntry = mumomentum.getPhi();
                 etaEntry = mumomentum.getEta();
                 phiPosition = muposition.getPhi();
@@ -90,10 +94,14 @@ MMLoadVariables::MMLoadVariables(StoreGateSvc* evtStore, const MuonGM::MuonDetec
               }
             }//muentry loop
               int l=0;
+#ifdef HEPMC3
+              for(auto vertex1 : subEvent->vertices()) {
+#else
               HepMC::ConstGenEventVertexRange vertex_range = subEvent->vertex_range();
               for(const auto vit : vertex_range) {
                 if(l!=0){break;}//get first vertex of iteration, may want to change this
                 const HepMC::GenVertex *vertex1 = vit;
+#endif
                 const HepMC::FourVector& position = vertex1->position();
                 vertex=TVector3(position.x(),position.y(),position.z());
                 l++;
@@ -160,11 +168,8 @@ MMLoadVariables::MMLoadVariables(StoreGateSvc* evtStore, const MuonGM::MuonDetec
             //match to truth particle
             TLorentzVector truthPart;
             for(auto it1 : *truthContainer) {  //Must be a more elegant way... should work for now though
-              const HepMC::GenEvent *subEvent1 = it1;
-              HepMC::ConstGenEventParticleRange particle_range1 = subEvent1->particle_range();
-              for(auto pit1 : particle_range1) {
-                const HepMC::GenParticle *particle1 = pit1;
-                const HepMC::FourVector& momentum1 = particle1->momentum();
+              for(auto particle1 : *it1) {
+                const HepMC::FourVector momentum1 = particle1->momentum();
                 truthPart.SetPtEtaPhiE(momentum1.perp(),momentum1.eta(),momentum1.phi(),momentum1.e());
               }//end particle loop
             }//end truth container loop (1 iteration) for matching
diff --git a/Trigger/TrigT1/TrigT1TGC/TrigT1TGC/TGCRPhiCoincidenceMap.h b/Trigger/TrigT1/TrigT1TGC/TrigT1TGC/TGCRPhiCoincidenceMap.h
index 578346e07b5a1f296dbb76f492a353094d95004d..e36fc2f90f069212e85d1685751839569ec31fa0 100644
--- a/Trigger/TrigT1/TrigT1TGC/TrigT1TGC/TGCRPhiCoincidenceMap.h
+++ b/Trigger/TrigT1/TrigT1TGC/TrigT1TGC/TGCRPhiCoincidenceMap.h
@@ -51,18 +51,21 @@ public:
 
   const TGCArguments* tgcArgs() const;
 
-private: // hide default constructor
+ private: // hide default constructor
   TGCRPhiCoincidenceMap() = delete;
 
-protected:
+ protected:
   bool checkVersion();
   int PHIPOS(int iphi, int type) const;
   int SUBSECTORADD(int ssid, int modid, int phimod2, int type) const;
+  unsigned short getRoIAddr(const char type, const unsigned char phimod2,
+                            const unsigned short module, const unsigned short roi) const;
+
   int getMODID(int addr) const;
   int getSSID(int addr) const;
   int getTYPE(int addr) const;
   int getTYPE(int lDR, int hDR, int lDPhi, int hDPhi ) const;
- 
+
   enum {TMap_HH=0, TMap_HL, TMap_LH, TMap_LL, N_TMap};
   enum {N_PT_THRESH=6};
   enum {NumberOfCoincidenceType=4};
@@ -168,6 +171,12 @@ inline
  int TGCRPhiCoincidenceMap::getTYPE(int addr) const
  { return ((addr>>16)&0x0003); }
 
+inline
+ unsigned short TGCRPhiCoincidenceMap::getRoIAddr(const char type, const unsigned char phimod2,
+                                                  const unsigned short module, const unsigned short roi) const
+{
+  return ((type & 0x3)<<13) + ((phimod2&0x1)<<12) + (module<<8) + roi;
+}
 
 } //end of namespace bracket
 
diff --git a/Trigger/TrigT1/TrigT1TGC/src/TGCEIFICoincidenceMap.cxx b/Trigger/TrigT1/TrigT1TGC/src/TGCEIFICoincidenceMap.cxx
index 3a15c9b10b1b45b19d1b10df6dfde3dda1dfa69f..70c20172c1eea61eacab386ed33da799423ef600 100644
--- a/Trigger/TrigT1/TrigT1TGC/src/TGCEIFICoincidenceMap.cxx
+++ b/Trigger/TrigT1/TrigT1TGC/src/TGCEIFICoincidenceMap.cxx
@@ -258,7 +258,7 @@ int TGCEIFICoincidenceMap::getFlagPT(const int pt,
   if  (tgcArgs()->USE_CONDDB()) {
     SG::ReadCondHandle<TGCTriggerData> readHandle{m_readCondKey};
     const TGCTriggerData* readCdo{*readHandle};
-    return readCdo->getFlagPtEifi(m_side,pt-1,ssc,sec);
+    return readCdo->getFlagPtEifi(m_side,ssc,sec)>>(pt-1) & 0x1;  /* only 1st bit needed (0x1) */
   } else {
     return  m_flagPT[ssc][sec].test(pt-1);
   }
@@ -275,7 +275,7 @@ int  TGCEIFICoincidenceMap::getFlagROI(const int roi,
   if  (tgcArgs()->USE_CONDDB()) {
     SG::ReadCondHandle<TGCTriggerData> readHandle{m_readCondKey};
     const TGCTriggerData* readCdo{*readHandle};
-    return readCdo->getFlagRoiEifi(m_side,roi,ssc,sec);
+    return readCdo->getFlagRoiEifi(m_side,ssc,sec)>>roi & 0x1;  /* only 1st bit needed (0x1) */
   } else {
     return  m_flagROI[roi][ssc][sec];
   }
@@ -291,7 +291,8 @@ int TGCEIFICoincidenceMap::getTriggerBit(const int slot,
   if  (tgcArgs()->USE_CONDDB()) {
     SG::ReadCondHandle<TGCTriggerData> readHandle{m_readCondKey};
     const TGCTriggerData* readCdo{*readHandle};
-    return readCdo->getTrigBitEifi(m_side,slot,ssc,sec,reg,read,bit);
+    unsigned int shift = (reg<<3) + (read<<2) + bit;
+    return readCdo->getTrigBitEifi(m_side,slot,ssc,sec)>>shift & 0x1;  /* only 1st bit needed (0x1) */
   } else {
     return m_map[slot][ssc][sec].getTriggerBit(reg,read,bit);
   }
diff --git a/Trigger/TrigT1/TrigT1TGC/src/TGCRPhiCoincidenceMap.cxx b/Trigger/TrigT1/TrigT1TGC/src/TGCRPhiCoincidenceMap.cxx
index d6835b704ae523eb65a9e3e91b0eca31b9d10229..628fda4087eb0469ea975f2d268285899526285d 100644
--- a/Trigger/TrigT1/TrigT1TGC/src/TGCRPhiCoincidenceMap.cxx
+++ b/Trigger/TrigT1/TrigT1TGC/src/TGCRPhiCoincidenceMap.cxx
@@ -34,32 +34,41 @@ bool TGCRPhiCoincidenceMap::test(int octantId, int moduleId, int subsector,
 
   int sector=(moduleId-2)/3+octantId*3;
   int phimod2 = (moduleId==2||moduleId==5||moduleId==8)&&(sector%2==1) ? 1 : 0;
-  int addr=SUBSECTORADD(subsector, moduleId, phimod2,type);
 
-  SG::ReadCondHandle<TGCTriggerData> readHandle{m_readCondKey};
-  const TGCTriggerData* readCdo{*readHandle};
+  if(tgcArgs()->USE_CONDDB()) {
+    SG::ReadCondHandle<TGCTriggerData> readHandle{m_readCondKey};
+    const TGCTriggerData* readCdo{*readHandle};
 
-  std::map<int, std::map<int, int> > readMap;
+    std::map<unsigned short, std::map<unsigned short, unsigned char>> roiMap = readCdo->getPtMapBw(m_side, m_octant);
+
+    unsigned short addr = getRoIAddr((char)type, (unsigned char)phimod2, (unsigned short)moduleId, (unsigned short)subsector);
+    std::map<unsigned short, std::map<unsigned short, unsigned char> >::const_iterator it = roiMap.find(addr);
+    if(it == roiMap.end()) return false;
+
+    std::map<unsigned short, unsigned char> ptMap = it->second;
+    std::map<unsigned short, unsigned char>::const_iterator itWindow = ptMap.find( (((dr+15)&0x1f)<<4) + ((dphi+7)&0xf) );
+
+    if (itWindow == ptMap.end()) return false;
+
+    if ( (itWindow->second) == (pt+1) ) return true;
+    else return false;
 
-  if (tgcArgs()->USE_CONDDB()){
-    readMap = readCdo->getReadMapBw(m_side, m_octant, pt);
   } else {
-    readMap = m_mapDB[pt];
-  }
+    int addr=SUBSECTORADD(subsector, moduleId, phimod2,type);
+    std::map<int, std::map<int, int> > readMap = m_mapDB[pt];
 
-  std::map<int, std::map<int, int> >::const_iterator it = readMap.find(addr);
+    std::map<int, std::map<int, int> >::const_iterator it = readMap.find(addr);
+    if (it==(readMap.end())) return false;
 
-  if (it==(readMap.end())) return false;
- 
-  std::map<int, int> aMap = it->second;
-  std::map<int, int>::const_iterator itWindow= aMap.find( dr );
+    std::map<int, int> aMap = it->second;
+    std::map<int, int>::const_iterator itWindow= aMap.find( dr );
+    if (itWindow==aMap.end()) return false;
 
-  if (itWindow==aMap.end()) return false;
- 
-  if ( (itWindow->second) & ( 1<<(PHIPOS(dphi,type)) ) ) return true;
-  else return false;
-}
+    if ( (itWindow->second) & ( 1<<(PHIPOS(dphi,type)) ) ) return true;
+    else return false;
+  }
 
+}
 
 
 
diff --git a/Trigger/TrigT1/TrigT1TGC/src/TGCTileMuCoincidenceMap.cxx b/Trigger/TrigT1/TrigT1TGC/src/TGCTileMuCoincidenceMap.cxx
index e1e4395e7c201b75ed4aa838fda20cb42ccfeeaf..83ab40775cd8ffc46869001ebe7ec00b1188fe77 100644
--- a/Trigger/TrigT1/TrigT1TGC/src/TGCTileMuCoincidenceMap.cxx
+++ b/Trigger/TrigT1/TrigT1TGC/src/TGCTileMuCoincidenceMap.cxx
@@ -1,5 +1,5 @@
 /*
-  Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 */
 
 #include <iostream>
@@ -267,7 +267,7 @@ int  TGCTileMuCoincidenceMap::getMask(const int module,
   if  (tgcArgs()->USE_CONDDB()) {
     SG::ReadCondHandle<TGCTriggerData> readHandle{m_readCondKey};
     const TGCTriggerData* readCdo{*readHandle};
-    return readCdo->getTrigMaskTile(module, ssc, sec, side);
+    return readCdo->getTrigMaskTile(ssc, sec, side)>>(module*4) & 0x7;
   } else {
     return  m_map[module][ssc][sec][side];
   }
@@ -286,7 +286,7 @@ int  TGCTileMuCoincidenceMap::getFlagPT(const int pt,
   if  (tgcArgs()->USE_CONDDB()) {
     SG::ReadCondHandle<TGCTriggerData> readHandle{m_readCondKey};
     const TGCTriggerData* readCdo{*readHandle};
-    return readCdo->getFlagPtTile(pt-1, ssc, sec, side);
+    return (readCdo->getFlagPtTile(ssc, sec, side)>>(pt-1)) & 0x1;  /* only 1st bit needed (0x1) */
   } else {
     return  m_flagPT[pt-1][ssc][sec][side];
   }
@@ -305,7 +305,7 @@ int  TGCTileMuCoincidenceMap::getFlagROI(const int roi,
   if  (tgcArgs()->USE_CONDDB()) {
     SG::ReadCondHandle<TGCTriggerData> readHandle{m_readCondKey};
     const TGCTriggerData* readCdo{*readHandle};
-    return readCdo->getFlagRoiTile(roi, ssc, sec, side);
+    return (readCdo->getFlagRoiTile(ssc, sec, side)>>roi) & 0x1;  /* only 1st bit needed (0x1) */
   } else {
     return  m_flagROI[roi][ssc][sec][side];
   }
diff --git a/Trigger/TrigT1/TrigT1ZDC/src/TrigT1ZDC.cxx b/Trigger/TrigT1/TrigT1ZDC/src/TrigT1ZDC.cxx
index 3557aaa9beb143c7e846813784a78e8ba56c2dc0..0dfb5477d80f1caa6c41f28d476d50533f57121b 100644
--- a/Trigger/TrigT1/TrigT1ZDC/src/TrigT1ZDC.cxx
+++ b/Trigger/TrigT1/TrigT1ZDC/src/TrigT1ZDC.cxx
@@ -53,8 +53,7 @@ namespace LVL1 {
     // Connect to the Detector Store to retrieve ZDC identifier helper.
     sc = detStore().retrieve();
     if (sc.isFailure()) {
-      if(msgLvl(MSG::ERROR)) msg(MSG::ERROR) << "Couldn't connect to " << detStore().typeAndName()
-					     << endmsg;
+      if(msgLvl(MSG::ERROR)) msg(MSG::ERROR) << "Couldn't connect to " << detStore().typeAndName() << endmsg;
       return sc;
     } 
     else if(msgLvl(MSG::DEBUG)) {
@@ -65,26 +64,22 @@ namespace LVL1 {
     // Connect to the LVL1ConfigSvc to retrieve threshold settings.
     sc = m_configSvc.retrieve();
     if (sc.isFailure()) {
-      if(msgLvl(MSG::ERROR)) msg(MSG::ERROR) << "Couldn't connect to " << m_configSvc.typeAndName() 
-					      << endmsg;
+      if(msgLvl(MSG::ERROR)) msg(MSG::ERROR) << "Couldn't connect to " << m_configSvc.typeAndName()  << endmsg;
       return sc;
     } 
     else if(msgLvl(MSG::DEBUG)) {
-      msg(MSG::DEBUG) << "Connected to " << m_configSvc.typeAndName() 
-		      << endmsg;
+      msg(MSG::DEBUG) << "Connected to " << m_configSvc.typeAndName() << endmsg;
     }
 
     // Connect to StoreGate service to retrieve input ZDC
     // trigger simulation container.
     sc = evtStore().retrieve();
     if (sc.isFailure()) {
-      if(msgLvl(MSG::ERROR)) msg(MSG::ERROR) << "Couldn't connect to " << evtStore().typeAndName() 
-					     << endmsg;
+      if(msgLvl(MSG::ERROR)) msg(MSG::ERROR) << "Couldn't connect to " << evtStore().typeAndName() << endmsg;
       return sc;
     } 
     else if(msgLvl(MSG::DEBUG)) {
-      msg(MSG::DEBUG) << "Connected to " <<  evtStore().typeAndName() 
-		      << endmsg;
+      msg(MSG::DEBUG) << "Connected to " <<  evtStore().typeAndName() << endmsg;
     }
     
     // Get level 1 ZDC threshold settings from the level 1
@@ -171,53 +166,48 @@ namespace LVL1 {
       // Loop over MC GenParticles contained in McEventCollection
       McEventCollection::const_iterator mcCollection_itr = mcEventCollection->begin();
       McEventCollection::const_iterator mcCollection_itr_end = mcEventCollection->end();
-      HepMC::GenEvent::particle_const_iterator hepmc_part_itr;
-      HepMC::GenEvent::vertex_const_iterator hepmc_vtx_itr;
-      HepMC::GenVertex *end_vtx;
 
       // Loop over the McEventCollections
       for (; mcCollection_itr != mcCollection_itr_end; mcCollection_itr++) {
       
         // Loop over the particles and build up the particle-index map.  
-        for (hepmc_part_itr = (*mcCollection_itr)->particles_begin(); 
-	     hepmc_part_itr != (*mcCollection_itr)->particles_end();
-	     hepmc_part_itr++) {
+        for (auto hepmc_part:  *(*mcCollection_itr)) {
 
 	  //Stop after 500 particles (avoid crash on long truth logs)
 	  if(particlesProcessed > 500) break;
 	  particlesProcessed++;
 	
 	  // Exclude Geant particles
-	  if((*hepmc_part_itr)->barcode() >= 200000) continue;
+	  if(HepMC::barcode(hepmc_part) >= 200000) continue;
 	
 	  // Require stable particles, to avoid the top of the generator record.
-	  if((*hepmc_part_itr)->status() != 1) continue;
+	  if(hepmc_part->status() != 1) continue;
     
 	  // Require neutral hadronic particles which are able to penetrate LHCf and the BRAN.
 	  // This consists of neutrons along with long lived neutral mesons & baryons with
 	  // sufficient Lorentz boost to travel the 140m to the TAN where the ZDC is located.
-	  if     (abs((*hepmc_part_itr)->pdg_id()) == 2112) {} // Neutron
-	  else if(    (*hepmc_part_itr)->pdg_id()  == 22   && !m_zdcIncludeLHCf) {} // Photon (Only without LHCf)
-	  else if(    (*hepmc_part_itr)->pdg_id()  == 130  && fabs((*hepmc_part_itr)->momentum().pz()) > 4500) {} // Boosed K_L0
-	  else if(abs((*hepmc_part_itr)->pdg_id()) == 3122 && fabs((*hepmc_part_itr)->momentum().pz()) > 2e6) {} // Boosted Lambda_0
-	  else if(abs((*hepmc_part_itr)->pdg_id()) == 3322 && fabs((*hepmc_part_itr)->momentum().pz()) > 2.1e6) {} // Boosted Xi_0
+	  if     (std::abs(hepmc_part->pdg_id()) == 2112) {} // Neutron
+	  else if(    hepmc_part->pdg_id()  == 22   && !m_zdcIncludeLHCf) {} // Photon (Only without LHCf)
+	  else if(    hepmc_part->pdg_id()  == 130  && std::abs(hepmc_part->momentum().pz()) > 4500) {} // Boosed K_L0
+	  else if(std::abs(hepmc_part->pdg_id()) == 3122 && std::abs(hepmc_part->momentum().pz()) > 2e6) {} // Boosted Lambda_0
+	  else if(std::abs(hepmc_part->pdg_id()) == 3322 && std::abs(hepmc_part->momentum().pz()) > 2.1e6) {} // Boosted Xi_0
 	  else continue;
 	
 	  // Check if the particle points at the ZDC.
-	  if(fabs((*hepmc_part_itr)->momentum().pseudoRapidity()) < 8.3) continue;
+	  if(std::abs(hepmc_part->momentum().pseudoRapidity()) < 8.3) continue;
 	
 	  // If the particle has an end vertex check that it reaches the TAN.
-	  end_vtx = (*hepmc_part_itr)->end_vertex();
+	  auto end_vtx = hepmc_part->end_vertex();
 	  if(end_vtx) {
-	    if(fabs(end_vtx->position().z())/1000.0 < 140.) continue;
+	    if(std::abs(end_vtx->position().z())/1000.0 < 140.) continue;
 	  }
 	
 	  // Increment the energy deposited in this side of the ZDC
-	  if((*hepmc_part_itr)->momentum().pz() < 0) {
-	    energyECC += (*hepmc_part_itr)->momentum().e();
+	  if(hepmc_part->momentum().pz() < 0) {
+	    energyECC += hepmc_part->momentum().e();
 	  }
 	  else {
-	    energyECA += (*hepmc_part_itr)->momentum().e();
+	    energyECA += hepmc_part->momentum().e();
 	  }
         }
       }
@@ -280,8 +270,7 @@ namespace LVL1 {
       return sc;
     } 
     else if(msgLvl(MSG::DEBUG)) {
-      msg(MSG::DEBUG) << LVL1::DEFAULT_ZdcCTPLocation << " registered successfully "
-		      << endmsg;
+      msg(MSG::DEBUG) << LVL1::DEFAULT_ZdcCTPLocation << " registered successfully " << endmsg;
     }
     
     return StatusCode::SUCCESS;
diff --git a/Trigger/TrigTools/TrigInDetConf/python/TrigInDetSequence.py b/Trigger/TrigTools/TrigInDetConf/python/TrigInDetSequence.py
index 3cc82e6db4d61e51d2fab557377533054a3deb39..84501919807eb93e1a386c09a877149a41ef3a3a 100644
--- a/Trigger/TrigTools/TrigInDetConf/python/TrigInDetSequence.py
+++ b/Trigger/TrigTools/TrigInDetConf/python/TrigInDetSequence.py
@@ -128,7 +128,7 @@ class TrigInDetSequence(TrigInDetSequenceBase):
     #    modify the sequence acoording to triggerflags
     from TriggerJobOpts.TriggerFlags  import TriggerFlags
 
-    if not ( TriggerFlags.doEF() or TriggerFlags.doHLT() ) or not TriggerFlags.doFEX():
+    if not TriggerFlags.doHLT() or not TriggerFlags.doFEX():
       from TrigSteeringTest.TrigSteeringTestConf import PESA__dummyAlgo as dummyAlgo_disabledByTriggerFlags_EFID
       dummyAlgEFID = dummyAlgo_disabledByTriggerFlags_EFID("doEF_or_doFEX_False_no_EFID")
       alglist = '[dummyAlgEFID]'
diff --git a/Trigger/TrigTools/TrigInDetConfig/python/ConfigSettings.py b/Trigger/TrigTools/TrigInDetConfig/python/ConfigSettings.py
index ef1f9a654fdd0a720157098f94076d28bf1d6910..2b7f52f1bdf98ca2ab0cada0e0a1813c1b1dd913 100644
--- a/Trigger/TrigTools/TrigInDetConfig/python/ConfigSettings.py
+++ b/Trigger/TrigTools/TrigInDetConfig/python/ConfigSettings.py
@@ -1,6 +1,6 @@
 #  Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 from __future__ import print_function
- 
+
 __author__ = "Mark Sutton, Matous Vozak"
 __doc__    = "ConfigSettings"
 __all__    = [ "getInDetTrigConfig" ]
@@ -16,7 +16,7 @@ from AthenaCommon.SystemOfUnits import GeV
 def makeRecordable(getName):
    def recordCollection(*args, **kwargs):
       #Retrieve record decision
-      record=kwargs.pop("doRecord",False) 
+      record=kwargs.pop("doRecord",False)
 
       #Get the name of the collection
       collectionName = getName(*args, **kwargs)
@@ -33,11 +33,11 @@ def makeRecordable(getName):
 #     Configuration of Tracking parameters for different signatures
 #-----------------------------------------------------------------------------
 
-class _Settings : 
+class _Settings :
    def __init__(self, name = "Settings") :
       self._name = name
-      
-      # default values 
+
+      # default values
       self._pTmin               = 1.*GeV
       self._d0SeedMax           = 4.0
       self._d0SeedPPSMax        = 1.7
@@ -46,7 +46,7 @@ class _Settings :
       self._doSpPhiFiltering    = True
       self._doCloneRemoval      = True
       self._checkRedundantSeeds = False
-      self._dRdoubletMax        = 270 
+      self._dRdoubletMax        = 270
       self._seedRadBinWidth     = 2
       self._etaHalfWidth        = 0.1
       self._phiHalfWidth        = 0.1
@@ -55,132 +55,155 @@ class _Settings :
       self._monPtMin            = 1*GeV
       self._doTRT               = False #Apply TRT extension sequence after ambiguity solving
       self._keepTrackParameters = False #Keep track parameters in conversion to TrackParticles
+      self._usePixelSP          = True
+      self._d0TrackMax          = 20.
+      self._z0TrackMax          = 300.
+      self._isLRT               = False
 
 #Previous version in:
 #https://gitlab.cern.ch/atlas/athena/-/blob/master/InnerDetector/InDetExample/InDetTrigRecExample/python/InDetTrigSliceSettings.py#L70
 
-   @property  
+   @property
    def name(self):
       return self._name
-   
+
    @property
    def pTmin(self):
       return self._pTmin
-   
+
    @property
    def d0SeedMax(self):
       return self._d0SeedMax
-   
+
    @property
    def d0SeedPPSMax(self):
       return self._d0SeedPPSMax
-   
+
    @property
    def doZFinder(self):
       return self._doZFinder
-   
+
    @property
    def doResMon(self):
       return self._doResMon
-   
+
    @property
    def doSpPhiFiltering(self):
       return self._doSpPhiFiltering
-   
+
    @property
    def doCloneRemoval(self):
       return self._doCloneRemoval
-   
+
    @property
    def checkRedundantSeeds(self):
       return self._checkRedundantSeeds
-   
+
    @property
    def dRdoubletMax(self):
-      return self._dRdoubletMax 
-   
+      return self._dRdoubletMax
+
    @property
    def seedRadBinWidth(self):
       return self._seedRadBinWidth
-   
+
    @property
    def etaHalfWidth(self):
       return self._etaHalfWidth
-   
+
    @property
    def phiHalfWidth(self):
       return self._phiHalfWidth
-   
+
    @property
    def doFullScan(self):
       return self._doFullScan
-   
+
    @property
    def monPS(self):
       return self._monPS
-   
+
    @property
    def monPtMin(self):
       return self._monPtMin
-   
+
    @property
    def doTRT(self):
       return self._doTRT
 
+   @property
+   def usePixelSP(self):
+       return self._usePixelSP
+   @property
+   def d0TrackMax(self):
+       return self._d0TrackMax
+
+   @property
+   def z0TrackMax(self):
+       return self._z0TrackMax
+
    @property
    def keepTrackParameters(self):
       return self._keepTrackParameters
-   
-   def printout(self): 
+
+   @property
+   def isLRT(self):
+       return self._isLRT
+
+   def printout(self):
       print( self._name, " :")
       print( "   pTmin                : ", self._pTmin )
       print( "   d0SeedMax            : ", self._d0SeedMax )
-      print( "   d0SeedPPSMax         : ", self._d0SeedPPSMax ) 
+      print( "   d0SeedPPSMax         : ", self._d0SeedPPSMax )
       print( "   doZFinder            : ", self._doZFinder )
       print( "   doResMon             : ", self._doResMon )
-      print( "   doSpPhiFiltering     : ", self._doSpPhiFiltering ) 
+      print( "   doSpPhiFiltering     : ", self._doSpPhiFiltering )
       print( "   doCloneRemoval       : ", self._doCloneRemoval )
       print( "   checkRedundantSeeds  : ", self._checkRedundantSeeds )
       print( "   dRdoubletMax         : ", self._dRdoubletMax )
       print( "   seedRadBinWidth      : ", self._seedRadBinWidth )
       print( "   etaHalfWidth         : ", self._etaHalfWidth )
-      print( "   phiHalfWidth         : ", self._phiHalfWidth ) 
+      print( "   phiHalfWidth         : ", self._phiHalfWidth )
       print( "   doFullScan           : ", self._doFullScan )
       print( "   monPS                : ", self._monPS )
       print( "   monPtMin             : ", self._monPtMin )
-       
+
 
 #Tracking configuration for different signatures
-class _Tracking_electron( _Settings ): 
-   def __init__( self ): 
+class _Tracking_electron( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._doCloneRemoval      = True #Previously False in Run2!
       self._checkRedundantSeeds = True
       self._doTRT               = True
       self._keepTrackParameters = True
 
-class _Tracking_tauCore( _Settings ): 
-   def __init__( self ): 
+class _Tracking_photon(_Settings):
+    def __init__(self):
+        _Settings.__init__(self)
+
+class _Tracking_tauCore( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._doTRT           = True
 
-class _Tracking_tauIso( _Settings ): 
-   def __init__( self ): 
+class _Tracking_tauIso( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._etaHalfWidth       = 0.4
       self._phiHalfWidth       = 0.4
       self._doTRT               = True
 
-class _Tracking_tau( _Settings ): 
-   def __init__( self ): 
+class _Tracking_tau( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
-      self._pTmin           = 0.8*GeV 
+      self._pTmin           = 0.8*GeV
       self._etaHalfWidth    = 0.4
       self._phiHalfWidth    = 0.4
       self._doTRT               = True
 
-class _Tracking_muon( _Settings ):     
-   def __init__( self ): 
+class _Tracking_muon( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._d0SeedMax           = 10.0
       self._doResMon            = True
@@ -189,59 +212,100 @@ class _Tracking_muon( _Settings ):
       self._monPtMin            = 12*GeV
       self._doTRT               = False
 
-class _Tracking_muonCore( _Settings ):     
-   def __init__( self ): 
+class _Tracking_muonCore( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._d0SeedMax           = 10.0
       self._doSpPhiFiltering    = False
       self._checkRedundantSeeds = True
       self._doTRT               = False
 
-class _Tracking_muonIso( _Settings ):     
-   def __init__( self ): 
+class _Tracking_muonIso( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._etaHalfWidth        = 0.35
       self._phiHalfWidth        = 0.35
       self._doTRT               = False
 
-class _Tracking_bjet( _Settings ):     
-   def __init__( self ): 
+class _Tracking_bjet( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
-      self._etaHalfWidth    = 0.4
-      self._phiHalfWidth    = 0.4
+      self._etaHalfWidth    = 0.2
+      self._phiHalfWidth    = 0.201
       self._doTRT           = False
 
-class _Tracking_fullScan( _Settings ):     
-   def __init__( self ): 
+class _Tracking_bjetVtx(_Settings):
+    def __init__(self):
+        _Settings.__init__(self)
+        self._phiHalfWidth = 0.201
+        self._etaHalfWidth = 0.2
+        self._pTmin = 5.*GeV
+        self._doTRT = False
+
+class _Tracking_fullScan( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._etaHalfWidth    = 3.
       self._phiHalfWidth    = 3.14159
       self._doTRT           = False
-      self._dRdoubletMax    = 200 
+      self._dRdoubletMax    = 200
       self._seedRadBinWidth = 10
 
-class _Tracking_minBias( _Settings ):     
-   def __init__( self ): 
+class _Tracking_fullScan2(_Settings):
+    def __init__(self):
+        self._pTmin = 2. * GeV
+        self._etaHalfWidth = 3.0
+        self._phiHalfWidth = 3.14159
+        self._doFullScan = True
+
+class _Tracking_fullScan500(_Settings):
+    def __init__(self):
+        self._pTmin = 0.5 * GeV
+        self._etaHalfWidth = 3.0
+        self._phiHalfWidth = 3.14159
+        self._doFullScan = True
+
+class _Tracking_minBias400( _Settings ):
+   def __init__( self ):
+      _Settings.__init__(self)
+      self._doFullScan      = True
+      self._pTmin           = 0.39*GeV
+      self._etaHalfWidth    = 3
+      self._phiHalfWidth    = 3.14159
+      self._doTRT           = False
+
+class _Tracking_minBias( _Settings ):
+   def __init__( self ):
+      _Settings.__init__(self)
+      self._doFullScan      = True
+      self._pTmin           = 0.2*GeV
+      self._etaHalfWidth    = 3
+      self._phiHalfWidth    = 3.14159
+      self._doTRT           = False
+
+class _Tracking_minBias2( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._doFullScan      = True
-      self._pTmin           = 0.2*GeV # TODO: double check
+      self._pTmin           = 0.5*GeV
       self._etaHalfWidth    = 3
       self._phiHalfWidth    = 3.14159
       self._doTRT           = False
 
-class _Tracking_beamSpot( _Settings ):     
-   def __init__( self ): 
+class _Tracking_beamSpot( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._doFullScan      = True
       self._doZFinder       = True
-      self._dRdoubletMax    = 200 
+      self._dRdoubletMax    = 200
       self._seedRadBinWidth = 10
       self._etaHalfWidth    = 3
       self._phiHalfWidth    = 3.14159
       self._doTRT           = False
+      self._checkRedundantSeeds = True
 
-class _Tracking_cosmic( _Settings ):     
-   def __init__( self ): 
+class _Tracking_cosmic( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
       self._doFullScan      = True
       self._d0SeedMax       = 1000.0
@@ -249,38 +313,178 @@ class _Tracking_cosmic( _Settings ):
       self._etaHalfWidth    = 3
       self._phiHalfWidth    = 3.14159
       self._doTRT           = False
-
-class _Tracking_bphysics( _Settings ):     
-   def __init__( self ): 
+      #do these settings still apply, were defined in TrigFastTrackFinder_Config.py but not in slicesettings
+      self._d0TrackMax = 1000.
+      self._z0TrackMax = 1000.
+
+class _Tracking_cosmicsN(_Settings):
+    def __init__(self):
+        _Settings.__init__(self)
+        self._etaHalfWidth = 3.0
+        self._phiHalfWidth = 3.14159
+        self._doFullScan = True
+        self._pTmin = 0.5*GeV
+
+class _Tracking_beamgas(_Settings):
+    def __init__(self):
+        _Settings.__init__(self)
+        self._pTmin = 0.1 * GeV
+        self._etaHalfWidth = 3.0
+        self._phiHalfWidth = 3.14159
+        self._doFullScan = True
+
+class _Tracking_hadCalib(_Settings):
+    def __init__(self):
+        _Settings.__init__(self)
+        self._pTmin = 0.5*GeV
+        self._etaHalfWidth = 0.4
+        self._phiHalfWidth = 0.4
+
+class _Tracking_bphysics( _Settings ):
+   def __init__( self ):
       _Settings.__init__(self)
-      self._d0SeedMax           = 10. 
+      self._d0SeedMax           = 10.
       self._doSpPhiFiltering    = False
       self._etaHalfWidth        = 0.75
       self._phiHalfWidth        = 0.75
       self._checkRedundantSeeds = True
       self._doTRT               = False
 
+class _Tracking_bphysicsHighPt( _Settings ):
+   def __init__( self ):
+      _Settings.__init__(self)
+      self._d0SeedMax           = 10.
+      self._doSpPhiFiltering    = False
+      self._etaHalfWidth        = 0.75
+      self._phiHalfWidth        = 0.75
+      self._doTRT               = False
+      self._pTmin = 2. * GeV
+
+class _Tracking_heavyIon(_Settings):
+   def __init__( self ):
+      _Settings.__init__(self)
+
+class _Tracking_heavyIonFS(_Settings):
+   def __init__( self ):
+      _Settings.__init__(self)
+      self._etaHalfWidth=3.0
+      self._phiHalfWidth=3.14159
+      self._doFullScan=True
+
+class _Tracking_lowPt(_Settings):
+   def __init__( self ):
+      _Settings.__init__(self)
+      self._pTmin = 0.1 * GeV
+      self._etaHalfWidth = 3.0
+      self._phiHalfWidth = 3.14159
+      self._doFullScan = True
+
+
+class _Tracking_electronLRT(_Settings):
+    def __init__(self):
+        _Settings.__init__(self)
+        self._usePixelSP = False
+        self._d0SeedMax = 300.
+        self._d0TrackMax = 300.
+        self._z0TrackMax = 500.
+        self._isLRT = True
+
+class _Tracking_muonLRT(_Settings):
+    def __init__(self):
+        _Settings.__init__(self)
+        self._usePixelSP = False
+        self._d0SeedMax = 300.
+        self._d0TrackMax = 300.
+        self._z0TrackMax = 500.
+        self._isLRT = True
+
+class _Tracking_tauLRT( _Settings ):
+   def __init__( self ):
+      _Settings.__init__(self)
+      self._pTmin           = 0.8*GeV
+      self._etaHalfWidth    = 0.4
+      self._phiHalfWidth    = 0.4
+      self._doTRT               = True
+      self._usePixelSP = False
+      self._d0SeedMax = 300.
+      self._d0TrackMax = 300.
+      self._z0TrackMax = 500.
+      self._isLRT = True
+
+
+class _Tracking_fullScanLRT( _Settings ):
+   def __init__( self ):
+      _Settings.__init__(self)
+      self._etaHalfWidth    = 3.
+      self._phiHalfWidth    = 3.14159
+      self._doTRT           = False
+      self._checkRedundantSeeds = True
+      self._usePixelSP = False
+      self._d0SeedMax = 300.
+      self._d0TrackMax = 300.
+      self._z0TrackMax = 500.
+      self._d0SeedPPSMax = 300.
+      self._doFullScan = True
+      self._isLRT = True
+
+class _Tracking_bjetLRT(_Settings):
+    def __init__(self):
+      _Settings.__init__(self)
+      self._etaHalfWidth    = 0.4
+      self._phiHalfWidth    = 0.4
+      self._doTRT           = False
+      self._usePixelSP = False
+      self._d0SeedMax = 300.
+      self._d0TrackMax = 300.
+      self._z0TrackMax = 500.
+      self._isLRT = True
+
 
 #Map to retrieve available configurations of Tracking
-_TrackingConfigSettings = { 
+_TrackingConfigSettings = {
     "electron"     : _Tracking_electron(),
+    "electronLRT"  : _Tracking_electronLRT(),
+
+    "photon"       : _Tracking_photon(),
 
     #Muon signatures
     "muon"         : _Tracking_muon(),
     "muonIso"      : _Tracking_muonIso(),
     "muonCore"     : _Tracking_muonCore(),
+    "muonLRT"      : _Tracking_muonLRT(),
 
-    "tau"          : _Tracking_tau(), 
+    "tau"          : _Tracking_tau(),
     "tauCore"      : _Tracking_tauCore(),
     "tauIso"       : _Tracking_tauIso(),
+    "tauLRT"       : _Tracking_tauLRT(),
 
     "bjet"         : _Tracking_bjet(),
+    "bjetVtx"      : _Tracking_bjetVtx(),
+    "bjetLRT"      : _Tracking_bjetLRT(),
+
     "fullScan"     : _Tracking_fullScan(),
+    "fullScanLRT"  : _Tracking_fullScanLRT(),
+    "fullScan2"    : _Tracking_fullScan2(),
+    "fullScan500"  : _Tracking_fullScan500(),
+
+    "minBias"      : _Tracking_minBias(),
+    "minBias2"     : _Tracking_minBias2(),
+    "minBias400"   : _Tracking_minBias400(),
 
-    "minBias400"   : _Tracking_minBias(),
     "beamSpot"     : _Tracking_beamSpot(),
     "cosmics"      : _Tracking_cosmic(),
-    "bphysics"     : _Tracking_bphysics(), 
+    "cosmicsN"     : _Tracking_cosmicsN(),
+    "beamgas"      : _Tracking_beamgas(),
+
+    "bphysics"     : _Tracking_bphysics(),
+    "bphysHighPt"  : _Tracking_bphysicsHighPt(),
+
+    "lowPt"        : _Tracking_lowPt(),
+
+    "hadCalib"     : _Tracking_hadCalib(),
+
+    "heavyIon"     : _Tracking_heavyIon(),
+    "heavyIonFS"   : _Tracking_heavyIonFS()
 
                   }
 
@@ -289,144 +493,152 @@ _TrackingConfigSettings = {
 def getInDetTrigTrackingConfig( name ) :
    if name in _TrackingConfigSettings :
       return _TrackingConfigSettings[name]
-   else : 
-        #       don't just return None, and do nothing as this 
-        #       will just hide the error until people try to use 
+   else :
+        #       don't just return None, and do nothing as this
+        #       will just hide the error until people try to use
         #       the bad slice configuration
       raise Exception( "getInDetTrigTrackingConfig() called with incorrect non existent slice: "+name )
-      return None         
+      return None
 
 
 
 
-#     Full Signature Configuration of ID Trig  
+#     Full Signature Configuration of ID Trig
 #-----------------------------------------------------------------------------
 
 class _FastTracking():
-   def __init__( self, signatureType, nameSuffix ) : 
+   def __init__( self, signatureType, nameSuffix ) :
       self._signatureType = signatureType #Steer which cuts,flags to load
       self._config        = getInDetTrigTrackingConfig( signatureType )
       self._suffix        = nameSuffix
-   
+
    #Retrieve trackCollection key
    @makeRecordable #Allows to record collection if doRecord = True
    def trkTracksFTF(self, doRecord=False):
       return 'HLT_IDTrkTrack_{}_FTF'.format( self._suffix )
-   
+
    #Retrieve TrackParticle key
    @makeRecordable #Allows to record collection if doRecord = True
    def tracksFTF(self, doRecord = True):
       return 'HLT_IDTrack_{}_FTF'.format( self._suffix )
-   
+
    #Retrieve TrackParticle key
-   @property 
+   @property
    def setting(self):
       return self._config
-   
+
    def isSignature(self, signature):
       return (self._signatureType == signature)
-   
-   @property 
+
+   @property
    def signatureType(self):
       return self._signatureType
+   @property
+   def config(self):
+      return self._config
 
 class _PrecisionTracking():
-   def __init__( self, signatureType, nameSuffix ) : 
+   def __init__( self, signatureType, nameSuffix ) :
       self._signatureType = signatureType #Steer which cuts,flags to load
       self._config        = getInDetTrigTrackingConfig( signatureType ) #This might not be needed in the future as most likely the setting will be the same between FT and PT
       self._suffix        = nameSuffix
-   
-   #Retrieve final precision trackCollection 
+
+   #Retrieve final precision trackCollection
    @makeRecordable
    def trkTracksPT(self, doRecord = False):
       return 'HLT_IDTrkTrack_{}_IDTrig'.format( self._suffix )
-   
+
    #Retrieve final TrackParticle key
-   @makeRecordable 
+   @makeRecordable
    def tracksPT(self, doRecord = False):
       return 'HLT_IDTrack_{}_IDTrig'.format( self._suffix )
-   
+
    #Retrieve trackCollection from Ambiguity solving stage
    #AS might not be very descriptive, should we switch to AmbiSol at least?
    @makeRecordable
    def trkTracksAS(self, doRecord = False):
       return 'HLT_IDTrkTrack_{}_AmbSol'.format( self._suffix )
-   
+
    #Retrieve trackCollection from TRT track extension stage
    #TE might not be very descriptive, should we switch to TRTExt at least?
    @makeRecordable
    def trkTracksTE(self, doRecord = False):
       return 'HLT_IDTrkTrack_{}_TRTExt'.format( self._suffix )
-   
+
    #Retrieve TrackParticle key
-   @property 
+   @property
    def setting(self):
       return self._config
-     
+
    def isSignature(self, signature):
       return (self._signatureType == signature)
 
 
-class _GlobalSettings() : 
-   def __init__( self ) : 
+class _GlobalSettings() :
+   def __init__( self ) :
       self._name      = "" #To be appended to alg names
-      self._roi       = "" 
+      self._roi       = ""
       self._configFT  =  None #Fast tracking configuration
       self._configPT  =  None #Precision tracking configuration
       self._doRecord  = False #Allow recording of track collections
-   
+      self._isLRT     = False
+
    @property
    def FT(self):
       return self._configFT
-   
+
    @property
    def PT(self):
       return self._configPT
-   
+
    @property
    def RoI(self):
       return self._roi
-   
+
    @property
    def name(self):
       return self._name
-   
+
    @property
    def isRecordable(self):
       return self._doRecord
 
+   @property
+   def isLRT(self):
+       return self._isLRT
 
 
-class _Settings_electron( _GlobalSettings ): 
-   def __init__( self ): 
+
+class _Settings_electron( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name      = "electron" #To be appended to alg names
-      self._roi       = "HLT_Roi_Electron" 
+      self._roi       = "HLT_Roi_Electron"
       self._configFT  = _FastTracking(      signatureType = 'electron', nameSuffix = 'Electron' )
       self._configPT  = _PrecisionTracking( signatureType = 'electron', nameSuffix = 'Electron' )
       self._doRecord  = True #Allow recording of track collections
 
 
-class _Settings_muon( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_muon( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name      = "muon" #To be appended to alg names
-      self._roi       = "HLT_Roi_Muon" 
+      self._roi       = "HLT_Roi_Muon"
       self._configFT  = _FastTracking(      signatureType = 'muon', nameSuffix = 'Muon' )
       self._configPT  = _PrecisionTracking( signatureType = 'muon', nameSuffix = 'Muon' )
       self._doRecord  = True #Allow recording of track collections
 
-class _Settings_muonIso( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_muonIso( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name      = "muonIso" #To be appended to alg names
-      self._roi       = "HLT_Roi_MuonIso" 
+      self._roi       = "HLT_Roi_MuonIso"
       self._configFT  = _FastTracking(      signatureType = 'muonIso', nameSuffix = 'MuonIso' )
       self._configPT  = _PrecisionTracking( signatureType = 'muonIso', nameSuffix = 'MuonIso' )
       self._doRecord  = True #Allow recording of track collections
 
-class _Settings_muonLate( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_muonLate( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name      = "muonLate" #To be appended to alg names
       self._roi       = "HLT_Roi_Muon"  #FIXME
@@ -434,8 +646,8 @@ class _Settings_muonLate( _GlobalSettings ):
       self._configPT  = _PrecisionTracking( signatureType = 'muon', nameSuffix = 'MuonLate' )
       self._doRecord  = True #Allow recording of track collections
 
-class _Settings_muonFS( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_muonFS( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "muonFS" #To be appended to alg names
       self._roi      = "HLT_Roi_Muon"  #FIXME
@@ -443,11 +655,21 @@ class _Settings_muonFS( _GlobalSettings ):
       self._configPT =   _PrecisionTracking( signatureType = 'muon', nameSuffix = 'MuonFS' )
       self._doRecord = True #Allow recording of track collections
 
-class _Settings_muonCore( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_muonLRT( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name      = "muonLRT" #To be appended to alg names
+      self._roi       = "HLT_Roi_Muon"
+      self._configFT  = _FastTracking(      signatureType = 'muonLRT', nameSuffix = 'MuonLRT' )
+      self._configPT  = _PrecisionTracking( signatureType = 'muonLRT', nameSuffix = 'Muon' )
+      self._doRecord  = True #Allow recording of track collections
+      self._isLRT      = True
+
+class _Settings_muonCore( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "muonCore" #To be appended to alg names
-      self._roi      = "HLT_Roi_Muon" 
+      self._roi      = "HLT_Roi_Muon"
       self._configFT = _FastTracking(      signatureType = 'muonCore', nameSuffix = 'MuonCore' )
       self._configPT = _PrecisionTracking( signatureType = 'muonCore', nameSuffix = 'MuonCore' )
       self._doRecord = True #Allow recording of track collections
@@ -455,87 +677,252 @@ class _Settings_muonCore( _GlobalSettings ):
 class _Settings_tauTau( _GlobalSettings ):
    def __init__( self ):
       _GlobalSettings.__init__(self)
-      self._name     = "tauTau" #To be appended to alg names                                                                                                
-      self._roi      = "HLT_Roi_Tau" #FIXME: possibly different!                                                                                         
+      self._name     = "tauTau" #To be appended to alg names
+      self._roi      = "HLT_Roi_Tau" #FIXME: possibly different!
       self._configFT =  _FastTracking(      signatureType = 'tau', nameSuffix = 'Tau' )
-      #There should not be a need for tauCore PT!                                                                                                            
-      self._configPT =   _PrecisionTracking( signatureType = 'tau', nameSuffix = 'Tau' )                                                           
-      self._doRecord = True #Allow recording of track collections      
+      #There should not be a need for tauCore PT!
+      self._configPT =   _PrecisionTracking( signatureType = 'tau', nameSuffix = 'Tau' )
+      self._doRecord = True #Allow recording of track collections
 
-class _Settings_tauCore( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_tauCore( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "tauCore" #To be appended to alg names
-      self._roi      = "HLT_Roi_TauCore" #FIXME: possibly different!  
+      self._roi      = "HLT_Roi_TauCore" #FIXME: possibly different!
       self._configFT =  _FastTracking(      signatureType = 'tauCore', nameSuffix = 'TauCore' )
       #There should not be a need for tauCore PT!
       #self._configPT =   #_PrecisionTracking( signatureType = 'tauCore', nameSuffix = 'TauCore' )
       self._doRecord = True #Allow recording of track collections
 
-class _Settings_tauIso( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_tauLRT( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "tauLRT" #To be appended to alg names
+      self._roi      = "HLT_Roi_TauCore" #FIXME: possibly different!
+      self._configFT =  _FastTracking(      signatureType = 'tauLRT', nameSuffix = 'TauLRT' )
+      #There should not be a need for tauCore PT!
+      #self._configPT =   #_PrecisionTracking( signatureType = 'tauCore', nameSuffix = 'TauCore' )
+      self._doRecord = True #Allow recording of track collections
+      self._isLRT = True
+
+class _Settings_tauIso( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "tauIso" #To be appended to alg names
-      self._roi      = "RoiForTauIso" #FIXME: possibly different!  
+      self._roi      = "RoiForTauIso" #FIXME: possibly different!
       self._configFT = _FastTracking(      signatureType = 'tauIso', nameSuffix = 'TauIso' )
       self._configPT = _PrecisionTracking( signatureType = 'tauIso', nameSuffix = 'Tau' ) #Final collection is being renamed to just tau apparently...
       self._doRecord = True #Allow recording of track collections
 
-class _Settings_bjet( _GlobalSettings ): 
-   def __init__( self ): 
+#This might be redundant but lets keep them for the time being...
+class _Settings_tauId( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "tauId" #To be appended to alg names
+      self._roi      = "HLT_Roi_Tau" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'tau', nameSuffix = 'Tau' )
+      self._configPT = _PrecisionTracking( signatureType = 'tau', nameSuffix = 'Tau' ) #Final collection is being renamed to just tau apparently...
+      self._doRecord = False #FIXME: Do I need to record these?
+
+#This might be redundant but lets keep them for the time being...
+class _Settings_tauEF( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "tauEF" #To be appended to alg names
+      self._roi      = "HLT_Roi_TauIso" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'tauIso', nameSuffix = 'TauIso' ) #
+      self._configPT = _PrecisionTracking( signatureType = 'tau',    nameSuffix = 'Tau' ) #Final collection is being renamed to just tau apparently...
+      self._doRecord = False #FIXME: Do I need to record these?
+
+#This might be redundant but lets keep them for the time being...
+class _Settings_tauTrk( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "tauTrk" #To be appended to alg names
+      self._roi      = "HLT_Roi_Tau" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'tau',    nameSuffix = 'Tau' ) #
+      self._configPT = _PrecisionTracking( signatureType = 'tau',    nameSuffix = 'Tau' ) #Final collection is being renamed to just tau apparently...
+      self._doRecord = False #FIXME: Do I need to record these?
+
+#This might be redundant but lets keep them for the time being...
+class _Settings_tauTrkTwo( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "tauTrkTwo" #To be appended to alg names
+      self._roi      = "HLT_Roi_TauIso" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'tauIso', nameSuffix = 'TauIso' ) #
+      self._configPT = _PrecisionTracking( signatureType = 'tau',    nameSuffix = 'Tau' ) #Final collection is being renamed to just tau apparently...
+      self._doRecord = False #FIXME: Do I need to record these?
+
+class _Settings_tauIsoBDT( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "tauIsoBDT" #To be appended to alg names
+      self._roi      = "HLT_Roi_TauIsoBDT" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'tauIso', nameSuffix = 'TauIso' ) #
+      self._configPT = _PrecisionTracking( signatureType = 'tauIso',    nameSuffix = 'Tau' ) #Final collection is being renamed to just tau apparently...
+      self._doRecord = False #FIXME: Do I need to record these?
+
+class _Settings_bjet( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "bjet" #To be appended to alg names
-      self._roi      = "HLT_Roi_Bjet" #FIXME: possibly different!  
-      self._configFT = _FastTracking(      signatureType = 'bjet',   nameSuffix = 'Bjet' ) 
-      self._configPT = _PrecisionTracking( signatureType = 'bjet',   nameSuffix = 'Bjet' ) 
+      self._roi      = "HLT_Roi_Bjet" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'bjet',   nameSuffix = 'Bjet' )
+      self._configPT = _PrecisionTracking( signatureType = 'bjet',   nameSuffix = 'Bjet' )
       self._doRecord = True
 
-class _Settings_jet( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_bjetVtx( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "bjetVtx" #To be appended to alg names
+      self._roi      = "HLT_Roi_Bjet" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'bjetVtx',   nameSuffix = 'Bjet' )
+      self._configPT = _PrecisionTracking( signatureType = 'bjetVtx',   nameSuffix = 'Bjet' )
+      self._doRecord = False
+
+class _Settings_bjetLRT( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "bjetLRT" #To be appended to alg names
+      self._roi      = "HLT_Roi_Bjet" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'bjetLRT',   nameSuffix = 'BjetLRT' )
+      self._configPT = _PrecisionTracking( signatureType = 'bjetLRT',   nameSuffix = 'BjetLRT' )
+      self._isLRT = True
+      self._doRecord = True
+
+class _Settings_jet( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "jet" #To be appended to alg names
-      self._roi      = "HLT_Roi_jetFS" #FIXME: possibly different!  
+      self._roi      = "HLT_Roi_jetFS" #FIXME: possibly different!
       self._configFT = _FastTracking(      signatureType = 'fullScan',  nameSuffix = 'FS' ) #
       self._configPT = _PrecisionTracking( signatureType = 'fullScan',  nameSuffix = 'FS' ) #Final collection is being renamed to just tau apparently...
-      self._doRecord = True 
+      self._doRecord = True
+
+class _Settings_minBias( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "minBias" #To be appended to alg names
+      self._roi      = "HLT_Roi_MinBias" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'minBias',  nameSuffix = 'MinBias' ) #
+      self._configPT = _PrecisionTracking( signatureType = 'minBias',  nameSuffix = 'MinBias' ) #Final collection is being renamed to just tau apparently...
+      self._doRecord = True
 
-class _Settings_minBias( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_minBias400( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "minBias" #To be appended to alg names
-      self._roi      = "HLT_Roi_MinBias" #FIXME: possibly different!  
+      self._roi      = "HLT_Roi_MinBias" #FIXME: possibly different!
       self._configFT = _FastTracking(      signatureType = 'minBias400',  nameSuffix = 'MinBias' ) #
       self._configPT = _PrecisionTracking( signatureType = 'minBias400',  nameSuffix = 'MinBias' ) #Final collection is being renamed to just tau apparently...
-      self._doRecord = True 
+      self._doRecord = True
 
-class _Settings_beamSpot( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_minBias2( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "minBias" #To be appended to alg names
+      self._roi      = "HLT_Roi_MinBias" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'minBias2',  nameSuffix = 'MinBias' ) #
+      self._configPT = _PrecisionTracking( signatureType = 'minBias2',  nameSuffix = 'MinBias' ) #Final collection is being renamed to just tau apparently...
+      self._doRecord = True
+
+class _Settings_beamSpot( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "beamSpot" #To be appended to alg names
-      self._roi      = "HLT_Roi_FS" #FIXME: possibly different!  
+      self._roi      = "HLT_Roi_FS" #FIXME: possibly different!
       self._configFT = _FastTracking(      signatureType = 'beamSpot',  nameSuffix = 'BeamSpot' ) #
       #PT probably isn't necessary for BS
       #self._configPT =   _PrecisionTracking( signatureType = 'beamSpot',  nameSuffix = 'BeamSpot' ) #Final collection is being renamed to just tau apparently...
-      self._doRecord = False 
+      self._doRecord = False
 
-class _Settings_fullScan( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_fullScan( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "fullScan" #To be appended to alg names
-      self._roi      = "HLT_Roi_FS" #FIXME: possibly different!  
+      self._roi      = "HLT_Roi_FS" #FIXME: possibly different!
       self._configFT = _FastTracking(   signatureType = 'fullScan',  nameSuffix = 'FS' ) #
-      self._doRecord = False 
+      self._doRecord = False
+
+class _Settings_fullScan2( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "fullScan2" #To be appended to alg names
+      self._roi      = "HLT_Roi_FS" #FIXME: possibly different!
+      self._configFT = _FastTracking(   signatureType = 'fullScan2',  nameSuffix = 'FS' ) #
+      self._doRecord = False
+
+class _Settings_fullScan500( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "fullScan500" #To be appended to alg names
+      self._roi      = "HLT_Roi_FS" #FIXME: possibly different!
+      self._configFT = _FastTracking(   signatureType = 'fullScan500',  nameSuffix = 'FS' ) #
+      self._doRecord = False
 
-class _Settings_cosmics( _GlobalSettings ): 
-   def __init__( self ): 
+class _Settings_fullScanLRT( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "fullScanLrt" #To be appended to alg names
+      self._roi      = "HLT_Roi_FS" #FIXME: possibly different!
+      self._configFT = _FastTracking(   signatureType = 'fullScanLRT',  nameSuffix = 'FSLRT' ) #
+      self._doRecord = False
+      self._isLRT    = True
+
+class _Settings_cosmics( _GlobalSettings ):
+   def __init__( self ):
       _GlobalSettings.__init__(self)
       self._name     = "cosmics" #To be appended to alg names
-      self._roi      = "HLT_Roi_Cosmics" #FIXME: possibly different!  
+      self._roi      = "HLT_Roi_Cosmics" #FIXME: possibly different!
       self._configFT = _FastTracking(      signatureType = 'cosmics',  nameSuffix = 'Cosmic' ) #
-      self._doRecord = False 
+      self._doRecord = False
+
+class _Settings_cosmicsN( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "cosmicsN" #To be appended to alg names
+      self._roi      = "HLT_Roi_Cosmics" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'cosmicsN',  nameSuffix = 'Cosmic' ) #
+      self._doRecord = False
+
+class _Settings_bphysics( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "bphysics" #To be appended to alg names
+      self._roi      = "HLT_Roi_Bjet" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'bphysics',   nameSuffix = 'Bjet' ) #TODO: get correct nameSuffix
+      self._configPT = _PrecisionTracking( signatureType = 'bphysics',   nameSuffix = 'Bjet' )
+      self._doRecord = False
+
+class _Settings_bphysicsHighPt( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "bphysicsHighPt" #To be appended to alg names
+      self._roi      = "HLT_Roi_Bjet" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'bphysHighPt',   nameSuffix = 'Bjet' ) #TODO: Get correct nameSuffix
+      self._configPT = _PrecisionTracking( signatureType = 'bphysHighPt',   nameSuffix = 'Bjet' )
+      self._doRecord = False
 
+class _Settings_beamgas( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "beamgas" #To be appended to alg names
+      self._roi      = "HLT_Roi_Beamgas" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'beamgas',   nameSuffix = 'beamgas' ) #TODO: Get correct nameSuffix
+      self._configPT = _PrecisionTracking( signatureType = 'beamgas',   nameSuffix = 'beamgas' )
+      self._doRecord = False
+
+class _Settings_hadCalib( _GlobalSettings ):
+   def __init__( self ):
+      _GlobalSettings.__init__(self)
+      self._name     = "hadcalib" #To be appended to alg names
+      self._roi      = "HLT_Roi_hadCalib" #FIXME: possibly different!
+      self._configFT = _FastTracking(      signatureType = 'hadCalib',   nameSuffix = 'beamgas' ) #TODO: Get correct nameSuffix
+      self._configPT = _PrecisionTracking( signatureType = 'hadCalib',   nameSuffix = 'beamgas' )
+      self._doRecord = False
 
-_ConfigSettings = { 
+_ConfigSettings = {
    "electron"     : _Settings_electron(),
     #Muon signatures
     "muon"        : _Settings_muon(),
@@ -543,23 +930,42 @@ _ConfigSettings = {
     "muonCore"    : _Settings_muonCore(),
     "muonFS"      : _Settings_muonFS(),
     "muonLate"    : _Settings_muonLate(),
-   
+    "muonLRT"     : _Settings_muonLRT(),
+
     #Tau signatures
     "tauTau"      : _Settings_tauTau(),
     "tauCore"     : _Settings_tauCore(),
     "tauIso"      : _Settings_tauIso(),
+    "tauLRT"      : _Settings_tauLRT(),
+    #Might be potentially removed
+    "tauId"       : _Settings_tauId(),
+    "tauTrk"      : _Settings_tauTrk(),
+    "tauTrkTwo"   : _Settings_tauTrkTwo(),
+    "tauEF"       : _Settings_tauEF(),
+    "tauIsoBDT"   : _Settings_tauIsoBDT(),
 
     "bjet"        : _Settings_bjet(),
+    "bjetVtx"        : _Settings_bjetVtx(),
+    "bjetLRT"     : _Settings_bjetLRT(),
     "jet"         : _Settings_jet(),
-   
+
     "fullScan"    : _Settings_fullScan(),
-   
+    "fullScan2"   : _Settings_fullScan2(),
+    "fullScan500" : _Settings_fullScan500(),
+    "fullScanLRT" : _Settings_fullScanLRT(),
+
     "beamSpot"    : _Settings_beamSpot(),
     "cosmics"     : _Settings_cosmics(),
-    "minBias"     : _Settings_minBias(),
-    #"bphysics"    : _Settings_bphysics(), 
+    "minBias"     : _Settings_minBias400(),
+    "minBias2"     : _Settings_minBias2(),
+    "minBias0"     : _Settings_minBias(),
+    "bphysics"    : _Settings_bphysics(),
+    "bphysHighPt" : _Settings_bphysicsHighPt(),
+
+    "beamgas"     : _Settings_beamgas(),
+    "hadCalib"    : _Settings_hadCalib()
                   }
-      
+
 #FTF Remap which eventually will be dropped once naming is aligned with signature settings
 remap  = {
    #"Muon"     : "muon",
@@ -579,13 +985,14 @@ remap  = {
    #"Jet"      : "bjet",
    #"JetFS"    : "fullScan",
    "FS"       : "fullScan",
-   #"bjetVtx"  : "bjetVtx",
    #"FullScan" : "fullScan",
    "BeamSpot" : "beamSpot",
    #"Bphysics" : "bphysics",
    #"Cosmic"   : "cosmics",
    #"MinBias"  : "minBias400",
-   #"minBias"  : "minBias400"
+   #"minBias"  : "minBias400",
+   "minBias400": "minBias",
+   "tau": "tauTau"
 }
 
 def remap_type( signature ):
@@ -600,15 +1007,13 @@ def remap_type( signature ):
 #FIXME: rename to InDetTrigSignatureConfig ?
 def getInDetTrigConfig( name ):
 #Most of the remapping has been removed, should we also replace FS & BeamSpot?
-   rName = remap_type( name ) 
+   rName = remap_type( name )
 
    if rName in _ConfigSettings :
       return _ConfigSettings[rName]
-   else : 
-    #       don't just return None, and do nothing as this 
-    #       will just hide the error until people try to use 
+   else :
+    #       don't just return None, and do nothing as this
+    #       will just hide the error until people try to use
     #       the bad slice configuration
       raise Exception( "getInDetTrigConfig() called with incorrect non existent slice: "+rName )
-      return None         
-
-
+      return None
diff --git a/Trigger/TrigTools/TrigInDetConfig/python/InDetSetup.py b/Trigger/TrigTools/TrigInDetConfig/python/InDetSetup.py
index 80ea72b7108dbf312da5e5862b7666534c2eeffb..c380eefeec3c27b2027276f1d39ca38071da344e 100644
--- a/Trigger/TrigTools/TrigInDetConfig/python/InDetSetup.py
+++ b/Trigger/TrigTools/TrigInDetConfig/python/InDetSetup.py
@@ -25,7 +25,7 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
   #Add suffix to the algorithms
   signature =  '_{}'.format( config.name )
 
-  #Global keys/names for Trigger collections 
+  #Global keys/names for Trigger collections
   from .InDetTrigCollectionKeys import  TrigPixelKeys, TrigSCTKeys
   from InDetRecExample.InDetKeys import InDetKeys
   from TrigInDetConfig.TrigInDetConfig import InDetCacheNames
@@ -48,7 +48,7 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
                                     ( 'IDCInDetBSErrContainer_Cache' , InDetCacheNames.SCTFlaggedCondCacheKey ),
                                     ( 'xAOD::EventInfo' , 'StoreGateSvc+EventInfo' ),
                                     ( 'TagInfo' , 'DetectorStore+ProcessingTags' )]
-    
+
     viewAlgs.append( ViewDataVerifier )
 
     # Load RDOs if we aren't loading bytestream
@@ -103,7 +103,7 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
     InDetPixelRawDataProvider.RDOCacheKey = InDetCacheNames.PixRDOCacheKey
     InDetPixelRawDataProvider.BSErrorsCacheKey = InDetCacheNames.PixBSErrCacheKey
 
-    from RegionSelector.RegSelToolConfig import makeRegSelTool_Pixel 
+    from RegionSelector.RegSelToolConfig import makeRegSelTool_Pixel
 
     InDetPixelRawDataProvider.RegSelTool = makeRegSelTool_Pixel()
 
@@ -150,7 +150,7 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
 
   #Pixel clusterisation
   from InDetTrigRecExample.InDetTrigConfigRecLoadTools import TrigPixelLorentzAngleTool, TrigSCTLorentzAngleTool
-  
+
   from SiClusterizationTool.SiClusterizationToolConf import InDet__ClusterMakerTool
   InDetClusterMakerTool = InDet__ClusterMakerTool(name                 = "InDetClusterMakerTool_" + signature,
                                                   SCTLorentzAngleTool = TrigSCTLorentzAngleTool,
@@ -218,7 +218,7 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
   sct_ByteStreamErrorsToolSetup.setToolName("InDetSCT_BSErrorTool_" + signature)
   sct_ByteStreamErrorsToolSetup.setConfigTool(sct_ConfigurationConditionsToolSetup.getTool())
   sct_ByteStreamErrorsToolSetup.setup()
-  InDetSCT_ConditionsSummaryToolWithoutFlagged.ConditionsTools.append(sct_ByteStreamErrorsToolSetup.getTool().getFullName())     
+  InDetSCT_ConditionsSummaryToolWithoutFlagged.ConditionsTools.append(sct_ByteStreamErrorsToolSetup.getTool().getFullName())
 
   if (InDetTrigFlags.doPrintConfigurables()):
      print (InDetSCT_ConditionsSummaryToolWithoutFlagged)
@@ -272,7 +272,7 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
                                                                     SiSpacePointMakerTool  = InDetSiSpacePointMakerTool,
                                                                     PixelsClustersName     = TrigPixelKeys.Clusters,
                                                                     SpacePointsPixelName   = TrigPixelKeys.SpacePoints,
-                                                                    SCT_ClustersName	    = TrigSCTKeys.Clusters, 
+                                                                    SCT_ClustersName	    = TrigSCTKeys.Clusters,
                                                                     SpacePointsSCTName     = TrigSCTKeys.SpacePoints,
                                                                     SpacePointsOverlapName = InDetKeys.OverlapSpacePoints(),
                                                                     ProcessPixels          = DetFlags.haveRIO.pixel_on(),
@@ -294,7 +294,8 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
       condSeq += InDet__SiElementPropertiesTableCondAlg(name = "InDetSiElementPropertiesTableCondAlg")
 
   #FIXME have a flag for now set for True( as most cases call FTF) but potentially separate
-  if doFTF: 
+  #do not add if the config is LRT
+  if doFTF:
       #Load signature configuration (containing cut values, names of collections, etc)
       #from .InDetTrigConfigSettings import getInDetTrigConfig
       #configSetting = getInDetTrigConfig( whichSignature )
@@ -305,12 +306,12 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
       #TODO: eventually adapt IDTrigConfig also in FTF configuration (pass as additional param)
       theFTF = TrigFastTrackFinderBase("TrigFastTrackFinder_" + signature, config.FT.signatureType )
       theFTF.RoIs           = rois
-      theFTF.TracksName     = config.FT.trkTracksFTF() 
+      theFTF.TracksName     = config.FT.trkTracksFTF()
       theFTF.doCloneRemoval = config.FT.setting.doCloneRemoval
 
       viewAlgs.append(theFTF)
 
-      
+
       from TrigInDetConf.TrigInDetPostTools import  InDetTrigParticleCreatorToolFTF
       from InDetTrigParticleCreation.InDetTrigParticleCreationConf import InDet__TrigTrackingxAODCnvMT
 
@@ -319,8 +320,8 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
       theTrackParticleCreatorAlg = InDet__TrigTrackingxAODCnvMT(name = "InDetTrigTrackParticleCreatorAlg" + signature,
                                                                 TrackName = config.FT.trkTracksFTF(),
                                                                 ParticleCreatorTool = InDetTrigParticleCreatorToolFTF)
-    
-      
+
+
       #In general all FTF trackParticle collections are recordable except beamspot to save space
       theTrackParticleCreatorAlg.TrackParticlesName = config.FT.tracksFTF( doRecord = config.isRecordable )
 
@@ -328,4 +329,3 @@ def makeInDetAlgs( config = None, rois = 'EMViewRoIs', doFTF = True, viewVerifie
 
 
   return viewAlgs, ViewDataVerifier
-
diff --git a/Trigger/TrigTools/TrigInDetConfig/python/TrigTrackingCutFlags.py b/Trigger/TrigTools/TrigInDetConfig/python/TrigTrackingCutFlags.py
index 1c2f5221d90fa31890792c355cc3b92cf0b2cb1d..b77ee2d99db5b2998f3d4bb6a96dd629adfc7f20 100644
--- a/Trigger/TrigTools/TrigInDetConfig/python/TrigTrackingCutFlags.py
+++ b/Trigger/TrigTools/TrigInDetConfig/python/TrigTrackingCutFlags.py
@@ -28,21 +28,45 @@ def __muonFlags():
     flags.doResMon = True
     return flags
 
+def _lrtFlags():
+    flags = __sliceFlags()
+    flags.maxHoles = 2
+    flags.minClusters = 8
+    flags.minSiNotShared = 6
+    flags.maxShared = 1
+    flags.maxPixelHoles = 1
+    flags.maxSctHoles = 1
+    flags.maxDoubleHoles = 0
+    flags.maxPrimaryImpact = 300.0 * Units.mm # highlumi
+    flags.maxZImpact = 500.0 * Units.mm
+    flags.roadWidth = 5.
+    flags.seedFilterLevel = 1
+    flags.nHolesMax = flags.maxHoles #fix them together as in the code being ported from. Should be safer if values are adjusted
+    flags.nHolesGapMax = 1
+    flags.Xi2max = 9.
+    flags.Xi2maxNoAdd =25.0
+    flags.nWeightedClustersMin = 8
+    flags.doZBoundary = True
+    flags.maxdImpactSSSSeeds = 300.0
+
+    return flags
+
 def createTrigTrackingFlags():
-    flags = AthConfigFlags() 
+    flags = AthConfigFlags()
     flags.addFlagsCategory('Trigger.InDetTracking.Electron', __electronFlags, prefix=True)
     flags.addFlagsCategory('Trigger.InDetTracking.Muon', __muonFlags, prefix=True)
+    flags.addFlagsCategory('Trigger.InDetTracking.LRT', _lrtFlags, prefix=True)
     return flags
 
 if __name__ == "__main__":
     from AthenaCommon.Logging import logging
-    _msg = logging.getLogger('AthConfigFlags')    
+    _msg = logging.getLogger('AthConfigFlags')
     _msg.setLevel(2)
     from AthenaConfiguration.AllConfigFlags import ConfigFlags as flags
     flags.Trigger.doID
     flags.dump(".*Trig")
-    
+
     flags.Trigger.InDetTracking.Electron.minPT = 2.0 * Units.GeV
     newflags = flags.cloneAndReplace('InDet.Tracking', 'Trigger.InDetTracking.Electron')
     assert newflags.InDet.Tracking.minPT == 2.0 * Units.GeV
-    flags.dump()
\ No newline at end of file
+    flags.dump()
diff --git a/Trigger/TrigTruthEvent/TrigInDetTruthEvent/src/TrigInDetTrackTruth.cxx b/Trigger/TrigTruthEvent/TrigInDetTruthEvent/src/TrigInDetTrackTruth.cxx
index dc78b42bdb956474331c1c6bbf25da71b59cdc9e..7034bbbd184fa929ae13a44cac0dc5e124220887 100644
--- a/Trigger/TrigTruthEvent/TrigInDetTruthEvent/src/TrigInDetTrackTruth.cxx
+++ b/Trigger/TrigTruthEvent/TrigInDetTruthEvent/src/TrigInDetTrackTruth.cxx
@@ -112,7 +112,7 @@ int TrigInDetTrackTruth::updateFamilyTree()
       // first get GenParticle pointer
       if ( !it1->isValid() ) continue; 
    
-      const HepMC::GenParticle* p_child = (*it1);
+      auto p_child = (*it1);
       log << MSG::DEBUG << "GenParticle " << child << " (" << p_child << "); PDG id=" 
 	  << p_child->pdg_id() << "; status=" << p_child->status() 
 	  << "; pT=" << p_child->momentum().perp() 
@@ -120,8 +120,8 @@ int TrigInDetTrackTruth::updateFamilyTree()
 	  << endmsg;
       
       // then get production vertex (check against null)
-      HepMC::GenVertex* p_child_vtx = p_child->production_vertex();
-      if ( p_child_vtx == NULL ) 
+      auto p_child_vtx = p_child->production_vertex();
+      if ( !p_child_vtx) 
 	{
 	  log << MSG::DEBUG<<"GenVertex pointer null: jump to next particle"<<endmsg;
 	  continue;
@@ -131,6 +131,16 @@ int TrigInDetTrackTruth::updateFamilyTree()
       
       /* find mother: there should be only one for final state particles 
 	 (particles which can leave energy deposits in detectors)        */
+#ifdef HEPMC3
+     // check a mother was found
+      if ( p_child_vtx->particles_in().size()==0)
+	{
+	  log << MSG::DEBUG<< "Mother not found: go to next particle" <<endmsg;
+	  continue;
+	}  
+     auto p_mum = p_child_vtx->particles_in().begin();
+      
+ #else
       HepMC::GenVertex::particles_in_const_iterator p_mum = p_child_vtx->particles_in_const_begin();
       
       // check a mother was found
@@ -139,6 +149,7 @@ int TrigInDetTrackTruth::updateFamilyTree()
 	  log << MSG::DEBUG<< "Mother not found: go to next particle" <<endmsg;
 	  continue;
 	} 
+#endif
       log << MSG::DEBUG<< "Mother GenParticle (" << *p_mum << ") found; PDG id=" 
 	  << (*p_mum)->pdg_id() << "; status=" << (*p_mum)->status()
 	  << "; pT=" << (*p_mum)->momentum().perp() 
@@ -152,7 +163,7 @@ int TrigInDetTrackTruth::updateFamilyTree()
 	{
 	  log << MSG::DEBUG << "* Trying daughter index=" << child 
 	      << " and mother index=" << mum << endmsg;
-          const HepMC::GenParticle* p2 = *it2;
+          auto p2 = *it2;
           if ( *p_mum == p2 )
 	    { // mother also matches track
 	      m_family_tree.push_back( std::pair<unsigned int, unsigned int>(mum,child) );
diff --git a/Trigger/TrigValidation/TrigAnalysisTest/share/ref_RDOtoRDOTrig_v1Dev_build.ref b/Trigger/TrigValidation/TrigAnalysisTest/share/ref_RDOtoRDOTrig_v1Dev_build.ref
index f5062252786ff3f2db8936e5560e5c8cb01844f3..c619572a2202335e4eddb004e8ae2e7cd6017cc4 100644
--- a/Trigger/TrigValidation/TrigAnalysisTest/share/ref_RDOtoRDOTrig_v1Dev_build.ref
+++ b/Trigger/TrigValidation/TrigAnalysisTest/share/ref_RDOtoRDOTrig_v1Dev_build.ref
@@ -69,9 +69,9 @@ HLT_2g10_loose_mu20_L1MU20:
     1: 1
     2: 1
   stepFeatures:
-    0: 2
-    1: 2
-    2: 4
+    0: 3
+    1: 3
+    2: 5
 HLT_2g15_tight_dPhi15_L1DPHI-M70-2EM12I:
   eventCount: 0
 HLT_2g20_tight_L12EM15VH:
@@ -513,15 +513,15 @@ HLT_e17_lhloose_mu14_L1EM15VH_MU10:
     7: 2
     8: 2
   stepFeatures:
-    0: 2
-    1: 3
-    2: 4
-    3: 2
-    4: 2
-    5: 2
-    6: 2
-    7: 2
-    8: 2
+    0: 4
+    1: 5
+    2: 6
+    3: 4
+    4: 4
+    5: 4
+    6: 4
+    7: 4
+    8: 4
 HLT_e17_lhvloose_nod0_L1EM15VH:
   eventCount: 5
   stepCounts:
@@ -661,13 +661,13 @@ HLT_e26_lhmedium_mu8noL1_L1EM22VHI:
     5: 2
     6: 2
   stepFeatures:
-    0: 5
-    1: 6
-    2: 6
-    3: 4
-    4: 4
-    5: 2
-    6: 2
+    0: 10
+    1: 10
+    2: 10
+    3: 8
+    4: 8
+    5: 4
+    6: 4
 HLT_e26_lhtight_L1EM15VH:
   eventCount: 4
   stepCounts:
@@ -789,9 +789,9 @@ HLT_e3_etcut1step_g5_etcut_L12EM3:
     1: 17
     2: 17
   stepFeatures:
-    0: 55
-    1: 55
-    2: 55
+    0: 186
+    1: 186
+    2: 237
 HLT_e3_etcut_L1EM3:
   eventCount: 20
   stepCounts:
@@ -981,15 +981,15 @@ HLT_e7_lhmedium_mu24_L1MU20:
     7: 1
     8: 1
   stepFeatures:
-    0: 9
-    1: 10
-    2: 10
-    3: 7
-    4: 2
-    5: 2
-    6: 1
-    7: 1
-    8: 1
+    0: 18
+    1: 17
+    2: 17
+    3: 14
+    4: 4
+    5: 4
+    6: 2
+    7: 2
+    8: 2
 HLT_eb_low_L1RD2_FILLED:
   eventCount: 20
   stepCounts:
@@ -1236,14 +1236,14 @@ HLT_g25_medium_mu24_ivarmedium_L1MU20:
     6: 1
     7: 1
   stepFeatures:
-    0: 2
-    1: 2
-    2: 4
-    3: 2
-    4: 2
-    5: 1
-    6: 1
-    7: 1
+    0: 4
+    1: 4
+    2: 6
+    3: 4
+    4: 4
+    5: 2
+    6: 2
+    7: 2
 HLT_g25_tight_L1EM20VH:
   eventCount: 5
   stepCounts:
@@ -1270,14 +1270,14 @@ HLT_g35_loose_mu18_L1EM24VHI:
     6: 1
     7: 1
   stepFeatures:
-    0: 2
-    1: 2
-    2: 4
-    3: 2
-    4: 2
-    5: 1
-    6: 1
-    7: 1
+    0: 4
+    1: 4
+    2: 6
+    3: 4
+    4: 4
+    5: 2
+    6: 2
+    7: 2
 HLT_g35_medium_g25_medium_L12EM20VH:
   eventCount: 0
 HLT_g35_tight_icalotight_mu18noL1_L1EM22VHI:
@@ -1287,9 +1287,9 @@ HLT_g35_tight_icalotight_mu18noL1_L1EM22VHI:
     1: 5
     2: 5
   stepFeatures:
-    0: 5
-    1: 5
-    2: 8
+    0: 10
+    1: 10
+    2: 13
 HLT_g3_loose_LArPEB_L1EM3:
   eventCount: 9
   stepCounts:
@@ -1407,7 +1407,7 @@ HLT_j0_vbenfSEP30etSEP34mass35SEP50fbet_L1J20:
   stepCounts:
     0: 15
   stepFeatures:
-    0: 398
+    0: 383
 HLT_j225_subjesgscIS_ftf_bmv2c1040_split_L1J100:
   eventCount: 0
   stepCounts:
@@ -1536,6 +1536,30 @@ HLT_j45_nojcalib_L1J20:
     0: 17
   stepFeatures:
     0: 39
+HLT_j45_pf_ftf_010jvt_L1J20:
+  eventCount: 19
+  stepCounts:
+    0: 19
+    1: 19
+  stepFeatures:
+    0: 19
+    1: 55
+HLT_j45_pf_ftf_020jvt_L1J20:
+  eventCount: 19
+  stepCounts:
+    0: 19
+    1: 19
+  stepFeatures:
+    0: 19
+    1: 54
+HLT_j45_pf_ftf_050jvt_L1J20:
+  eventCount: 19
+  stepCounts:
+    0: 19
+    1: 19
+  stepFeatures:
+    0: 19
+    1: 54
 HLT_j45_pf_ftf_L1J20:
   eventCount: 19
   stepCounts:
@@ -1779,7 +1803,7 @@ HLT_mu10_ivarmedium_mu10_10invm70_L12MU10:
     1: 4
     2: 4
     3: 4
-    4: 2
+    4: 6
 HLT_mu10_lateMu_L1LATE-MU10_XE50:
   eventCount: 0
 HLT_mu11_mu6_bBmumu_L1MU11_2MU6:
@@ -1860,12 +1884,12 @@ HLT_mu20_2mu4noL1_L1MU20:
     4: 1
     5: 1
   stepFeatures:
-    0: 10
-    1: 7
-    2: 7
-    3: 7
-    4: 2
-    5: 2
+    0: 18
+    1: 13
+    2: 13
+    3: 13
+    4: 4
+    5: 4
 HLT_mu20_ivarmedium_mu4noL1_10invm70_L1MU20:
   eventCount: 2
   stepCounts:
@@ -1877,13 +1901,13 @@ HLT_mu20_ivarmedium_mu4noL1_10invm70_L1MU20:
     5: 2
     6: 2
   stepFeatures:
-    0: 10
-    1: 7
-    2: 7
-    3: 7
-    4: 4
-    5: 2
-    6: 2
+    0: 18
+    1: 13
+    2: 13
+    3: 13
+    4: 8
+    5: 7
+    6: 6
 HLT_mu20_ivarmedium_mu8noL1_L1MU20:
   eventCount: 1
   stepCounts:
@@ -1895,13 +1919,13 @@ HLT_mu20_ivarmedium_mu8noL1_L1MU20:
     5: 1
     6: 1
   stepFeatures:
-    0: 10
-    1: 7
-    2: 7
-    3: 7
-    4: 4
-    5: 1
-    6: 1
+    0: 18
+    1: 13
+    2: 13
+    3: 13
+    4: 8
+    5: 3
+    6: 3
 HLT_mu22_2mu4noL1_L1MU20:
   eventCount: 1
   stepCounts:
@@ -1912,12 +1936,12 @@ HLT_mu22_2mu4noL1_L1MU20:
     4: 1
     5: 1
   stepFeatures:
-    0: 10
-    1: 7
-    2: 6
-    3: 6
-    4: 2
-    5: 2
+    0: 18
+    1: 13
+    2: 11
+    3: 11
+    4: 4
+    5: 4
 HLT_mu22_mu10noL1_L1MU20:
   eventCount: 2
   stepCounts:
@@ -1928,12 +1952,12 @@ HLT_mu22_mu10noL1_L1MU20:
     4: 2
     5: 2
   stepFeatures:
-    0: 10
-    1: 7
-    2: 6
-    3: 6
-    4: 3
-    5: 3
+    0: 18
+    1: 13
+    2: 11
+    3: 11
+    4: 7
+    5: 7
 HLT_mu22_mu8noL1_L1MU20:
   eventCount: 2
   stepCounts:
@@ -1944,12 +1968,12 @@ HLT_mu22_mu8noL1_L1MU20:
     4: 2
     5: 2
   stepFeatures:
-    0: 10
-    1: 7
-    2: 6
-    3: 6
-    4: 3
-    5: 3
+    0: 18
+    1: 13
+    2: 11
+    3: 11
+    4: 7
+    5: 7
 HLT_mu24_L1MU20:
   eventCount: 5
   stepCounts:
@@ -1998,12 +2022,12 @@ HLT_mu24_mu10noL1_L1MU20:
     4: 2
     5: 2
   stepFeatures:
-    0: 10
-    1: 7
-    2: 6
-    3: 6
-    4: 3
-    5: 3
+    0: 18
+    1: 13
+    2: 11
+    3: 11
+    4: 7
+    5: 7
 HLT_mu24_mu8noL1_L1MU20:
   eventCount: 2
   stepCounts:
@@ -2014,12 +2038,12 @@ HLT_mu24_mu8noL1_L1MU20:
     4: 2
     5: 2
   stepFeatures:
-    0: 10
-    1: 7
-    2: 6
-    3: 6
-    4: 3
-    5: 3
+    0: 18
+    1: 13
+    2: 11
+    3: 11
+    4: 7
+    5: 7
 HLT_mu26_L1MU20:
   eventCount: 4
   stepCounts:
@@ -2162,10 +2186,10 @@ HLT_mu6_j45_nojcalib_L1J20:
     2: 9
     3: 9
   stepFeatures:
-    0: 11
-    1: 10
-    2: 11
-    3: 11
+    0: 20
+    1: 19
+    2: 20
+    3: 20
 HLT_mu6_msonly_L1MU6:
   eventCount: 10
   stepCounts:
@@ -2196,12 +2220,12 @@ HLT_mu6_mu6noL1_L1MU6:
     4: 6
     5: 3
   stepFeatures:
-    0: 13
-    1: 12
-    2: 13
-    3: 13
-    4: 8
-    5: 5
+    0: 23
+    1: 22
+    2: 23
+    3: 23
+    4: 21
+    5: 11
 HLT_mu6_xe30_mht_L1XE10:
   eventCount: 9
   stepCounts:
@@ -2211,11 +2235,11 @@ HLT_mu6_xe30_mht_L1XE10:
     3: 9
     4: 9
   stepFeatures:
-    0: 12
-    1: 11
-    2: 12
-    3: 12
-    4: 11
+    0: 21
+    1: 20
+    2: 21
+    3: 21
+    4: 20
 HLT_mu80_msonly_3layersEC_L1MU20:
   eventCount: 1
   stepCounts:
@@ -2404,6 +2428,8 @@ HLT_tau0_perf_ptonly_L1TAU60:
     3: 3
 HLT_tau160_idperf_track_L1TAU100:
   eventCount: 0
+HLT_tau160_idperf_tracktwoMVABDT_L1TAU100:
+  eventCount: 0
 HLT_tau160_idperf_tracktwoMVA_L1TAU100:
   eventCount: 0
 HLT_tau160_idperf_tracktwo_L1TAU100:
@@ -2412,8 +2438,12 @@ HLT_tau160_medium1_tracktwoEF_L1TAU100:
   eventCount: 0
 HLT_tau160_medium1_tracktwo_L1TAU100:
   eventCount: 0
+HLT_tau160_mediumRNN_tracktwoMVABDT_L1TAU100:
+  eventCount: 0
 HLT_tau160_mediumRNN_tracktwoMVA_L1TAU100:
   eventCount: 0
+HLT_tau160_perf_tracktwoMVABDT_L1TAU100:
+  eventCount: 0
 HLT_tau160_perf_tracktwoMVA_L1TAU100:
   eventCount: 0
 HLT_tau160_perf_tracktwo_L1TAU100:
@@ -2436,6 +2466,20 @@ HLT_tau25_idperf_track_L1TAU12IM:
     2: 15
     3: 15
     4: 15
+HLT_tau25_idperf_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 12
+  stepCounts:
+    0: 14
+    1: 12
+    2: 12
+    3: 12
+    4: 12
+  stepFeatures:
+    0: 24
+    1: 16
+    2: 15
+    3: 15
+    4: 15
 HLT_tau25_idperf_tracktwoMVA_L1TAU12IM:
   eventCount: 12
   stepCounts:
@@ -2466,6 +2510,20 @@ HLT_tau25_idperf_tracktwo_L1TAU12IM:
     3: 14
     4: 14
     5: 14
+HLT_tau25_looseRNN_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 9
+  stepCounts:
+    0: 12
+    1: 10
+    2: 10
+    3: 10
+    4: 9
+  stepFeatures:
+    0: 22
+    1: 14
+    2: 13
+    3: 13
+    4: 12
 HLT_tau25_looseRNN_tracktwoMVA_L1TAU12IM:
   eventCount: 9
   stepCounts:
@@ -2502,6 +2560,18 @@ HLT_tau25_medium1_tracktwoEF_L1TAU12IM:
     1: 14
     2: 12
     3: 12
+HLT_tau25_medium1_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 0
+  stepCounts:
+    0: 12
+    1: 10
+    2: 10
+    3: 10
+  stepFeatures:
+    0: 22
+    1: 14
+    2: 13
+    3: 13
 HLT_tau25_medium1_tracktwoMVA_L1TAU12IM:
   eventCount: 0
   stepCounts:
@@ -2524,6 +2594,20 @@ HLT_tau25_medium1_tracktwo_L1TAU12IM:
     0: 22
     1: 14
     2: 12
+HLT_tau25_mediumRNN_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 8
+  stepCounts:
+    0: 12
+    1: 10
+    2: 10
+    3: 10
+    4: 8
+  stepFeatures:
+    0: 22
+    1: 14
+    2: 13
+    3: 13
+    4: 9
 HLT_tau25_mediumRNN_tracktwoMVA_L1TAU12IM:
   eventCount: 8
   stepCounts:
@@ -2548,6 +2632,20 @@ HLT_tau25_mediumRNN_tracktwo_L1TAU12IM:
     0: 22
     1: 14
     2: 12
+HLT_tau25_perf_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 12
+  stepCounts:
+    0: 14
+    1: 12
+    2: 12
+    3: 12
+    4: 12
+  stepFeatures:
+    0: 24
+    1: 16
+    2: 15
+    3: 15
+    4: 15
 HLT_tau25_perf_tracktwoMVA_L1TAU12IM:
   eventCount: 12
   stepCounts:
@@ -2578,6 +2676,20 @@ HLT_tau25_perf_tracktwo_L1TAU12IM:
     3: 14
     4: 14
     5: 14
+HLT_tau25_tightRNN_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 7
+  stepCounts:
+    0: 12
+    1: 10
+    2: 10
+    3: 10
+    4: 7
+  stepFeatures:
+    0: 22
+    1: 14
+    2: 13
+    3: 13
+    4: 7
 HLT_tau25_tightRNN_tracktwoMVA_L1TAU12IM:
   eventCount: 7
   stepCounts:
@@ -2602,6 +2714,20 @@ HLT_tau25_tightRNN_tracktwo_L1TAU12IM:
     0: 22
     1: 14
     2: 12
+HLT_tau25_verylooseRNN_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 9
+  stepCounts:
+    0: 12
+    1: 10
+    2: 10
+    3: 10
+    4: 9
+  stepFeatures:
+    0: 22
+    1: 14
+    2: 13
+    3: 13
+    4: 12
 HLT_tau25_verylooseRNN_tracktwoMVA_L1TAU12IM:
   eventCount: 9
   stepCounts:
@@ -2764,8 +2890,8 @@ HLT_xe100_trkmht_xe85_tcpufit_xe65_cell_L1XE50:
     0: 6
     1: 5
   stepFeatures:
-    0: 6
-    1: 5
+    0: 18
+    1: 15
 HLT_xe110_mht_L1XE50:
   eventCount: 6
   stepCounts:
@@ -2819,7 +2945,7 @@ HLT_xe30_cell_xe30_tcpufit_L1XE10:
   stepCounts:
     0: 14
   stepFeatures:
-    0: 14
+    0: 28
 HLT_xe30_cvfpufit_L1XE10:
   eventCount: 14
   stepCounts:
@@ -2907,36 +3033,36 @@ HLT_xe65_cell_xe110_tcpufit_L1XE50:
   stepCounts:
     0: 5
   stepFeatures:
-    0: 5
+    0: 10
 HLT_xe80_tcpufit_unconvtrk120_isohpttrack_iaggrloose_L1XE50:
   eventCount: 3
   stepCounts:
     0: 3
   stepFeatures:
-    0: 3
+    0: 7
 HLT_xe80_tcpufit_unconvtrk120_isohpttrack_iaggrmedium_L1XE50:
   eventCount: 2
   stepCounts:
     0: 2
   stepFeatures:
-    0: 2
+    0: 4
 HLT_xe80_tcpufit_unconvtrk120_isohpttrack_imedium_L1XE50:
   eventCount: 5
   stepCounts:
     0: 5
   stepFeatures:
-    0: 5
+    0: 15
 HLT_xe80_tcpufit_unconvtrk80_isohpttrack_imedium_L1XE50:
   eventCount: 6
   stepCounts:
     0: 6
   stepFeatures:
-    0: 6
+    0: 20
 HLT_xe95_trkmht_xe90_tcpufit_xe75_cell_L1XE50:
   eventCount: 4
   stepCounts:
     0: 4
     1: 4
   stepFeatures:
-    0: 4
-    1: 4
+    0: 12
+    1: 12
diff --git a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v1Dev_build.py b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v1Dev_build.py
index 850fe3fbaf4cff80611e3239d3080956167c6672..bb619b840d5e45d127967c41ed804846949b5b9f 100755
--- a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v1Dev_build.py
+++ b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v1Dev_build.py
@@ -8,7 +8,6 @@
 # If you create a grid version, check art-output in existing grid tests.
 
 from TrigValTools.TrigValSteering import Test, ExecStep, CheckSteps, Input
-from TrigAnalysisTest.TrigAnalysisSteps import add_analysis_steps
 
 hit2rdo = ExecStep.ExecStep('HITtoRDO')
 hit2rdo.type = 'Reco_tf'
@@ -40,7 +39,6 @@ test = Test.Test()
 test.art_type = 'build'
 test.exec_steps = [hit2rdo, rdo2rdotrig]
 test.check_steps = CheckSteps.default_check_steps(test)
-add_analysis_steps(test, input_file='RDO_TRIG.pool.root')
 
 import sys
 sys.exit(test.run())
diff --git a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v1Dev_grid.py b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v1Dev_grid.py
index a9fa06ae53b48ab32a512f2900c2b241afa6f4bf..517fc56c9fad0878fc24f4caa024d5a6e3e49af5 100755
--- a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v1Dev_grid.py
+++ b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v1Dev_grid.py
@@ -21,7 +21,6 @@
 # art-output: *.check*
 
 from TrigValTools.TrigValSteering import Test, ExecStep, CheckSteps, Input
-from TrigAnalysisTest.TrigAnalysisSteps import add_analysis_steps
 
 hit2rdo = ExecStep.ExecStep('HITtoRDO')
 hit2rdo.type = 'Reco_tf'
@@ -55,7 +54,6 @@ test = Test.Test()
 test.art_type = 'grid'
 test.exec_steps = [hit2rdo, rdo2rdotrig]
 test.check_steps = CheckSteps.default_check_steps(test)
-add_analysis_steps(test, input_file='RDO_TRIG.pool.root')
 
 import sys
 sys.exit(test.run())
diff --git a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v7Primaries_build.py b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v7Primaries_build.py
index 0ad0b76563d0e78cde65cf25fb71f9614645eb15..fdba52cfe6bdc7c229238c07e56e5f8c64b8eb24 100755
--- a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v7Primaries_build.py
+++ b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v7Primaries_build.py
@@ -8,7 +8,6 @@
 # If you create a grid version, check art-output in existing grid tests.
 
 from TrigValTools.TrigValSteering import Test, ExecStep, CheckSteps, Input
-from TrigAnalysisTest.TrigAnalysisSteps import add_analysis_steps
 
 hit2rdo = ExecStep.ExecStep('HITtoRDO')
 hit2rdo.type = 'Reco_tf'
@@ -45,7 +44,6 @@ test = Test.Test()
 test.art_type = 'build'
 test.exec_steps = [hit2rdo, rdo2rdotrig]
 test.check_steps = CheckSteps.default_check_steps(test)
-add_analysis_steps(test, input_file='RDO_TRIG.pool.root')
 
 import sys
 sys.exit(test.run())
diff --git a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v7Primaries_grid.py b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v7Primaries_grid.py
index 9ea5c43968ea747e8a356daea1d7d4f1c623dbe7..bdd10b008516123a5e0ea7e33ec0c644ca076b44 100755
--- a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v7Primaries_grid.py
+++ b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_HITtoRDOTrig_v7Primaries_grid.py
@@ -23,7 +23,6 @@
 # art-output: LVL1config*.xml
 
 from TrigValTools.TrigValSteering import Test, ExecStep, CheckSteps, Input
-from TrigAnalysisTest.TrigAnalysisSteps import add_analysis_steps
 
 hit2rdo = ExecStep.ExecStep('HITtoRDO')
 hit2rdo.type = 'Reco_tf'
@@ -61,7 +60,6 @@ test = Test.Test()
 test.art_type = 'grid'
 test.exec_steps = [hit2rdo, rdo2rdotrig]
 test.check_steps = CheckSteps.default_check_steps(test)
-add_analysis_steps(test, input_file='RDO_TRIG.pool.root')
 
 import sys
 sys.exit(test.run())
diff --git a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_mt1_build.py b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_mt1_build.py
deleted file mode 100755
index f01adecf1a3a33f49c7da8b971933d28d0202c37..0000000000000000000000000000000000000000
--- a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_mt1_build.py
+++ /dev/null
@@ -1,8 +0,0 @@
-#!/bin/sh
-# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-#
-# flake8: noqa
-# This is just a hacky link to a renamed test script, which is needed until the test name in CI configuration is updated
-test_trigAna_RDOtoRDOTrig_v1Dev_build.py
-exit_code=$?
-exit ${exit_code}
diff --git a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v1Dev_grid.py b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v1Dev_grid.py
index fe1186b0e791044d9bcc6b9b43c06860af89d6e7..057bdfcb09c9219e7305952758c2b948c9976c67 100755
--- a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v1Dev_grid.py
+++ b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v1Dev_grid.py
@@ -21,7 +21,6 @@
 # art-output: *.check*
 
 from TrigValTools.TrigValSteering import Test, ExecStep, CheckSteps
-from TrigAnalysisTest.TrigAnalysisSteps import add_analysis_steps
 
 preExec = ';'.join([
   'setMenu=\'LS2_v1_TriggerValidation_mc_prescale\'',
@@ -42,7 +41,6 @@ test = Test.Test()
 test.art_type = 'grid'
 test.exec_steps = [ex]
 test.check_steps = CheckSteps.default_check_steps(test)
-add_analysis_steps(test, input_file='RDO_TRIG.pool.root')
 
 import sys
 sys.exit(test.run())
diff --git a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v7Primaries_build.py b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v7Primaries_build.py
index 55d92a222edfc043a56ad68d37bf95e44ba3d388..b968a8d8b4cc7ca3910fde6373e479966ad7ca08 100755
--- a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v7Primaries_build.py
+++ b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v7Primaries_build.py
@@ -8,7 +8,6 @@
 # If you create a grid version, check art-output in existing grid tests.
 
 from TrigValTools.TrigValSteering import Test, ExecStep, CheckSteps
-from TrigAnalysisTest.TrigAnalysisSteps import add_analysis_steps
 
 preExec = ';'.join([
   'from TriggerJobOpts.TriggerFlags import TriggerFlags',
@@ -26,7 +25,6 @@ test = Test.Test()
 test.art_type = 'build'
 test.exec_steps = [ex]
 test.check_steps = CheckSteps.default_check_steps(test)
-add_analysis_steps(test, input_file='RDO_TRIG.pool.root')
 
 import sys
 sys.exit(test.run())
diff --git a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v7Primaries_grid.py b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v7Primaries_grid.py
index 78744e46473dc86a7f5eaa56d1c109d887205653..c6f1f953bc6bd62786f57a74a5e149b91c710c6d 100755
--- a/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v7Primaries_grid.py
+++ b/Trigger/TrigValidation/TrigAnalysisTest/test/test_trigAna_RDOtoRDOTrig_v7Primaries_grid.py
@@ -23,7 +23,6 @@
 # art-output: LVL1config*.xml
 
 from TrigValTools.TrigValSteering import Test, ExecStep, CheckSteps
-from TrigAnalysisTest.TrigAnalysisSteps import add_analysis_steps
 
 preExec = ';'.join([
   'from TriggerJobOpts.TriggerFlags import TriggerFlags',
@@ -42,7 +41,6 @@ test = Test.Test()
 test.art_type = 'grid'
 test.exec_steps = [ex]
 test.check_steps = CheckSteps.default_check_steps(test)
-add_analysis_steps(test, input_file='RDO_TRIG.pool.root')
 
 import sys
 sys.exit(test.run())
diff --git a/Trigger/TrigValidation/TrigInDetValidation/python/TrigInDetNewArtSteps.py b/Trigger/TrigValidation/TrigInDetValidation/python/TrigInDetNewArtSteps.py
index 82d2a11168f63c8386369661669b877b3a5ad83e..f36db2004b19a85072b1e23f66e649aaf443b880 100644
--- a/Trigger/TrigValidation/TrigInDetValidation/python/TrigInDetNewArtSteps.py
+++ b/Trigger/TrigValidation/TrigInDetValidation/python/TrigInDetNewArtSteps.py
@@ -63,7 +63,7 @@ class TrigInDetReco(ExecStep):
         # get the cuttent atlas base release, and the previous base release
         import os
         DVERSION=os.getenv('Athena_VERSION')
-        if ( DVERSION == None ) : 
+        if ( DVERSION is None ) :
             AVERSION = "22.0.20"
         else :
             BASE=DVERSION[:5]
@@ -190,7 +190,7 @@ class TrigInDetCompStep(RefComparisonStep):
     '''
     def __init__( self, name='TrigInDetComp', slice=None, args=None, file=None, reference=None ):
         super(TrigInDetCompStep, self).__init__(name)
-        if reference == None : 
+        if reference is None :
             self.reference  = file # do we need this any more ??? 
             self.args  = args + " " + file + "  " + file + " --noref --oldrms "
         else:
@@ -231,7 +231,7 @@ class TrigInDetCpuCostStep(RefComparisonStep):
     
     def configure(self, test):
         #self.args += self.input_file+' '+self.ref_file+' '+' -o '+self.output_dir
-        if (self.reference == None):
+        if (self.reference is None):
             ## if not reference found, run with "--noref" option
             self.args += ' {} --noref -o {} -p TIME'.format(self.input_file,self.output_dir)
         else:
diff --git a/Trigger/TrigValidation/TrigInDetValidation/test/test_trigID_bjet_nopps_pu40.py b/Trigger/TrigValidation/TrigInDetValidation/test/test_trigID_bjet_nopps_pu40.py
new file mode 100755
index 0000000000000000000000000000000000000000..850c9adf65f4b1f03c11fae83f36d99f618a2074
--- /dev/null
+++ b/Trigger/TrigValidation/TrigInDetValidation/test/test_trigID_bjet_nopps_pu40.py
@@ -0,0 +1,45 @@
+#!/usr/bin/env python
+
+# art-description: art job for bjet_pu40_mt
+# art-type: grid
+# art-include: master/Athena
+# art-input-nfiles: 3
+# art-athena-mt: 4
+# art-memory: 4096
+# art-html: https://idtrigger-val.web.cern.ch/idtrigger-val/TIDAWeb/TIDAart/?jobdir=
+# art-output: *.txt
+# art-output: *.log
+# art-output: log.*
+# art-output: *.out
+# art-output: *.err
+# art-output: *.log.tar.gz
+# art-output: *.new
+# art-output: *.json
+# art-output: *.root
+# art-output: *.check*
+# art-output: HLT*
+# art-output: times*
+# art-output: cost-perCall
+# art-output: cost-perEvent
+# art-output: cost-perCall-chain
+# art-output: cost-perEvent-chain
+# art-output: *.dat 
+
+import os
+os.system("echo 'ftf = findAlgorithm(topSequence, \"TrigFastTrackFinder__jet\")' > dopps.py")
+os.system("echo 'ftf.TripletDoPPS=False' >> dopps.py")
+
+Slices = ['bjet']
+RunEF   = True
+Events  = 4000
+Threads = 8 
+Slots   = 8
+postinclude_file = 'dopps.py'
+Input = 'ttbar_ID'    # defined in TrigValTools/share/TrigValInputs.json  
+
+TrackReference = [ 'Truth', 'Offline' ]
+
+
+from AthenaCommon.Include import include 
+include("TrigInDetValidation/TrigInDetValidation_Base.py")
+
diff --git a/Trigger/TrigValidation/TrigInDetValidation/test/test_trigID_fsjet_nopps_pu40.py b/Trigger/TrigValidation/TrigInDetValidation/test/test_trigID_fsjet_nopps_pu40.py
new file mode 100755
index 0000000000000000000000000000000000000000..bed747938cc0d3335e84282b97744c1c597d7c0c
--- /dev/null
+++ b/Trigger/TrigValidation/TrigInDetValidation/test/test_trigID_fsjet_nopps_pu40.py
@@ -0,0 +1,55 @@
+#!/usr/bin/env python
+
+# art-description: art job for fsjet_pu40_new
+# art-type: grid
+# art-include: master/Athena
+# art-input-nfiles: 3
+# art-athena-mt: 8
+# art-memory: 4096
+# art-html: https://idtrigger-val.web.cern.ch/idtrigger-val/TIDAWeb/TIDAart/?jobdir=
+# art-output: *.txt
+# art-output: *.log
+# art-output: log.*
+# art-output: *.out
+# art-output: *.err
+# art-output: *.log.tar.gz
+# art-output: *.new
+# art-output: *.json
+# art-output: *.root
+# art-output: *.check*
+# art-output: HLT*
+# art-output: times*
+# art-output: cost-perCall
+# art-output: cost-perEvent
+# art-output: cost-perCall-chain
+# art-output: cost-perEvent-chain
+# art-output: *.dat 
+
+import os
+os.system("echo 'ftf = findAlgorithm(topSequence, \"TrigFastTrackFinder__jet\")' > dopps.py")
+os.system("echo 'ftf.TripletDoPPS=False' >> dopps.py")
+
+Slices  = ['fsjet']
+RunEF   = False
+Events  = 2000 
+Threads = 8 
+Slots   = 8
+postinclude_file = 'dopps.py'
+Input   = 'ttbar'    # defined in TrigValTools/share/TrigValInputs.json  
+
+Jobs = [ ( "Truth",       " TIDAdata-run3.dat              -o data-hists.root" ), 
+         ( "Offline",     " TIDAdata-run3-offline.dat      -o data-hists-offline.root" ),
+         ( "OfflineVtx",  " TIDAdata-run3-offline-vtx.dat  -o data-hists-offline-vtx.root" ) ]
+
+
+Comp = [ ( "FSjet",        "L2fsjet",     "data-hists.root",              " -c TIDAhisto-panel.dat      -d HLTL2-plots " ),
+         ( "FSjetoffline", "L2fsjet",     "data-hists-offline.root",      " -c TIDAhisto-panel.dat      -d HLTL2-plots-offline " ),
+         ( "FSvtx",        "L2fsjetvtx",  "data-hists-offline-vtx.root",  " -c TIDAhisto-panel-vtx.dat  -d HLTL2-plots-vtx     --ncols 3" ),
+         ( "FSvtxall",     "L2fsjetvtx",  "data-hists-offline.root",      " -c TIDAhisto-panel-vtx.dat  -d HLTL2-plots-vtxall  --ncols 3" ) ]
+
+
+from AthenaCommon.Include import include 
+include("TrigInDetValidation/TrigInDetValidation_NewBase.py")
+
+
+ 
diff --git a/Trigger/TrigValidation/TriggerTest/share/ref_data_v1Dev_build.ref b/Trigger/TrigValidation/TriggerTest/share/ref_data_v1Dev_build.ref
index 79fe38dd7652cfbe9fb6a6d90590e1819df97251..013b6f31e99e9772d9f4eec334b3557e8b10d932 100644
--- a/Trigger/TrigValidation/TriggerTest/share/ref_data_v1Dev_build.ref
+++ b/Trigger/TrigValidation/TriggerTest/share/ref_data_v1Dev_build.ref
@@ -282,8 +282,8 @@ HLT_e12_lhloose_2mu10_L12MU10:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 4
+    0: 2
+    1: 5
 HLT_e140_lhloose_L1EM22VHI:
   eventCount: 0
 HLT_e140_lhloose_nod0_L1EM22VHI:
@@ -351,9 +351,9 @@ HLT_e3_etcut1step_g5_etcut_L12EM3:
     1: 10
     2: 10
   stepFeatures:
-    0: 23
-    1: 23
-    2: 23
+    0: 57
+    1: 57
+    2: 66
 HLT_e3_etcut_L1EM3:
   eventCount: 13
   stepCounts:
@@ -657,7 +657,7 @@ HLT_j0_vbenfSEP30etSEP34mass35SEP50fbet_L1J20:
   stepCounts:
     0: 2
   stepFeatures:
-    0: 24
+    0: 17
 HLT_j225_subjesgscIS_ftf_bmv2c1040_split_L1J100:
   eventCount: 0
 HLT_j260_320eta490_L1J20:
@@ -734,6 +734,30 @@ HLT_j45_nojcalib_L1J20:
     0: 3
   stepFeatures:
     0: 3
+HLT_j45_pf_ftf_010jvt_L1J20:
+  eventCount: 5
+  stepCounts:
+    0: 5
+    1: 5
+  stepFeatures:
+    0: 5
+    1: 5
+HLT_j45_pf_ftf_020jvt_L1J20:
+  eventCount: 5
+  stepCounts:
+    0: 5
+    1: 5
+  stepFeatures:
+    0: 5
+    1: 5
+HLT_j45_pf_ftf_050jvt_L1J20:
+  eventCount: 5
+  stepCounts:
+    0: 5
+    1: 5
+  stepFeatures:
+    0: 5
+    1: 5
 HLT_j45_pf_ftf_L1J20:
   eventCount: 5
   stepCounts:
@@ -978,48 +1002,48 @@ HLT_mu20_2mu4noL1_L1MU20:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu20_ivarmedium_mu4noL1_10invm70_L1MU20:
   eventCount: 0
   stepCounts:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu20_ivarmedium_mu8noL1_L1MU20:
   eventCount: 0
   stepCounts:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu22_2mu4noL1_L1MU20:
   eventCount: 0
   stepCounts:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu22_mu10noL1_L1MU20:
   eventCount: 0
   stepCounts:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu22_mu8noL1_L1MU20:
   eventCount: 0
   stepCounts:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu24_L1MU20:
   eventCount: 0
   stepCounts:
@@ -1050,16 +1074,16 @@ HLT_mu24_mu10noL1_L1MU20:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu24_mu8noL1_L1MU20:
   eventCount: 0
   stepCounts:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu26_L1MU20:
   eventCount: 0
   stepCounts:
@@ -1160,16 +1184,16 @@ HLT_mu6_mu6noL1_L1MU6:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu6_xe30_mht_L1XE10:
   eventCount: 0
   stepCounts:
     0: 1
     1: 1
   stepFeatures:
-    0: 1
-    1: 1
+    0: 2
+    1: 2
 HLT_mu80_msonly_3layersEC_L1MU20:
   eventCount: 0
   stepCounts:
@@ -1346,6 +1370,8 @@ HLT_tau0_perf_ptonly_L1TAU60:
   eventCount: 0
 HLT_tau160_idperf_track_L1TAU100:
   eventCount: 0
+HLT_tau160_idperf_tracktwoMVABDT_L1TAU100:
+  eventCount: 0
 HLT_tau160_idperf_tracktwoMVA_L1TAU100:
   eventCount: 0
 HLT_tau160_idperf_tracktwo_L1TAU100:
@@ -1354,8 +1380,12 @@ HLT_tau160_medium1_tracktwoEF_L1TAU100:
   eventCount: 0
 HLT_tau160_medium1_tracktwo_L1TAU100:
   eventCount: 0
+HLT_tau160_mediumRNN_tracktwoMVABDT_L1TAU100:
+  eventCount: 0
 HLT_tau160_mediumRNN_tracktwoMVA_L1TAU100:
   eventCount: 0
+HLT_tau160_perf_tracktwoMVABDT_L1TAU100:
+  eventCount: 0
 HLT_tau160_perf_tracktwoMVA_L1TAU100:
   eventCount: 0
 HLT_tau160_perf_tracktwo_L1TAU100:
@@ -1378,6 +1408,20 @@ HLT_tau25_idperf_track_L1TAU12IM:
     2: 3
     3: 3
     4: 3
+HLT_tau25_idperf_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 3
+  stepCounts:
+    0: 3
+    1: 3
+    2: 3
+    3: 3
+    4: 3
+  stepFeatures:
+    0: 4
+    1: 3
+    2: 3
+    3: 3
+    4: 3
 HLT_tau25_idperf_tracktwoMVA_L1TAU12IM:
   eventCount: 3
   stepCounts:
@@ -1408,6 +1452,20 @@ HLT_tau25_idperf_tracktwo_L1TAU12IM:
     3: 3
     4: 3
     5: 3
+HLT_tau25_looseRNN_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 2
+  stepCounts:
+    0: 3
+    1: 3
+    2: 3
+    3: 3
+    4: 2
+  stepFeatures:
+    0: 4
+    1: 3
+    2: 3
+    3: 3
+    4: 2
 HLT_tau25_looseRNN_tracktwoMVA_L1TAU12IM:
   eventCount: 2
   stepCounts:
@@ -1444,6 +1502,18 @@ HLT_tau25_medium1_tracktwoEF_L1TAU12IM:
     1: 3
     2: 3
     3: 3
+HLT_tau25_medium1_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 0
+  stepCounts:
+    0: 3
+    1: 3
+    2: 3
+    3: 3
+  stepFeatures:
+    0: 4
+    1: 3
+    2: 3
+    3: 3
 HLT_tau25_medium1_tracktwoMVA_L1TAU12IM:
   eventCount: 0
   stepCounts:
@@ -1466,6 +1536,20 @@ HLT_tau25_medium1_tracktwo_L1TAU12IM:
     0: 4
     1: 3
     2: 3
+HLT_tau25_mediumRNN_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 1
+  stepCounts:
+    0: 3
+    1: 3
+    2: 3
+    3: 3
+    4: 1
+  stepFeatures:
+    0: 4
+    1: 3
+    2: 3
+    3: 3
+    4: 1
 HLT_tau25_mediumRNN_tracktwoMVA_L1TAU12IM:
   eventCount: 1
   stepCounts:
@@ -1490,6 +1574,20 @@ HLT_tau25_mediumRNN_tracktwo_L1TAU12IM:
     0: 4
     1: 3
     2: 3
+HLT_tau25_perf_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 3
+  stepCounts:
+    0: 3
+    1: 3
+    2: 3
+    3: 3
+    4: 3
+  stepFeatures:
+    0: 4
+    1: 3
+    2: 3
+    3: 3
+    4: 3
 HLT_tau25_perf_tracktwoMVA_L1TAU12IM:
   eventCount: 3
   stepCounts:
@@ -1520,6 +1618,20 @@ HLT_tau25_perf_tracktwo_L1TAU12IM:
     3: 3
     4: 3
     5: 3
+HLT_tau25_tightRNN_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 1
+  stepCounts:
+    0: 3
+    1: 3
+    2: 3
+    3: 3
+    4: 1
+  stepFeatures:
+    0: 4
+    1: 3
+    2: 3
+    3: 3
+    4: 1
 HLT_tau25_tightRNN_tracktwoMVA_L1TAU12IM:
   eventCount: 1
   stepCounts:
@@ -1544,6 +1656,20 @@ HLT_tau25_tightRNN_tracktwo_L1TAU12IM:
     0: 4
     1: 3
     2: 3
+HLT_tau25_verylooseRNN_tracktwoMVABDT_L1TAU12IM:
+  eventCount: 2
+  stepCounts:
+    0: 3
+    1: 3
+    2: 3
+    3: 3
+    4: 2
+  stepFeatures:
+    0: 4
+    1: 3
+    2: 3
+    3: 3
+    4: 2
 HLT_tau25_verylooseRNN_tracktwoMVA_L1TAU12IM:
   eventCount: 2
   stepCounts:
@@ -1699,7 +1825,7 @@ HLT_xe30_cell_xe30_tcpufit_L1XE10:
   stepCounts:
     0: 3
   stepFeatures:
-    0: 3
+    0: 6
 HLT_xe30_cvfpufit_L1XE10:
   eventCount: 6
   stepCounts:
@@ -1791,6 +1917,6 @@ HLT_xe80_tcpufit_unconvtrk80_isohpttrack_imedium_L1XE50:
   stepCounts:
     0: 1
   stepFeatures:
-    0: 1
+    0: 2
 HLT_xe95_trkmht_xe90_tcpufit_xe75_cell_L1XE50:
   eventCount: 0
diff --git a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_grid.py b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_grid.py
index 777044199df5ef2d5a047a39ef0743ff1db59641..4e806448361a610ff5c2fec6b12b939bd094030b 100755
--- a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_grid.py
+++ b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_grid.py
@@ -4,6 +4,7 @@
 # art-description: Trigger RDO->RDO_TRIG athena test of the Dev_pp_run3_v1 menu
 # art-type: grid
 # art-include: master/Athena
+# art-athena-mt: 4
 # art-output: *.txt
 # art-output: *.log
 # art-output: log.*
@@ -24,7 +25,8 @@ ex = ExecStep.ExecStep()
 ex.type = 'athena'
 ex.job_options = 'TriggerJobOpts/runHLT_standalone.py'
 ex.input = 'ttbar'
-ex.threads = 1
+ex.threads = 4
+ex.concurrent_events = 4
 # LS2_v1 soon to be renamed to Dev_pp_run3_v1
 ex.args = '-c "setMenu=\'LS2_v1_TriggerValidation_mc_prescale\';doWriteBS=False;doWriteRDOTrigger=True;"'
 
diff --git a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_pu80_grid.py b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_pu80_grid.py
index 59cae14f1c5fb857e1e3d6c97c3e6028b9c57d6d..b44906f430bf9a6542815ed84b1f8958efc47eb2 100755
--- a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_pu80_grid.py
+++ b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_pu80_grid.py
@@ -4,6 +4,7 @@
 # art-description: Trigger RDO->RDO_TRIG athena test of the Dev_pp_run3_v1 menu with pileup80 ttbar sample
 # art-type: grid
 # art-include: master/Athena
+# art-athena-mt: 4
 # art-output: *.txt
 # art-output: *.log
 # art-output: log.*
@@ -24,7 +25,8 @@ ex = ExecStep.ExecStep()
 ex.type = 'athena'
 ex.job_options = 'TriggerJobOpts/runHLT_standalone.py'
 ex.input = 'ttbar_pu80'
-ex.threads = 1
+ex.threads = 4
+ex.concurrent_events = 4
 # LS2_v1 soon to be renamed to Dev_pp_run3_v1
 ex.args = '-c "setMenu=\'LS2_v1_TriggerValidation_mc_prescale\';doWriteBS=False;doWriteRDOTrigger=True;"'
 
diff --git a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_writeBS_grid.py b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_writeBS_grid.py
index dbea883df517d7009893fe7ae475cade00e7025d..d25b9b9371ef627b4815e650ae2e8a781631f3b2 100755
--- a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_writeBS_grid.py
+++ b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Dev_writeBS_grid.py
@@ -4,6 +4,7 @@
 # art-description: Trigger RDO->BS athena test of the Dev_pp_run3_v1 menu
 # art-type: grid
 # art-include: master/Athena
+# art-athena-mt: 4
 # art-output: *.txt
 # art-output: *.log
 # art-output: log.*
@@ -25,7 +26,8 @@ ex = ExecStep.ExecStep()
 ex.type = 'athena'
 ex.job_options = 'TriggerJobOpts/runHLT_standalone.py'
 ex.input = 'ttbar'
-ex.threads = 1
+ex.threads = 4
+ex.concurrent_events = 4
 # LS2_v1 soon to be renamed to Dev_pp_run3_v1
 ex.args = '-c "setMenu=\'LS2_v1_TriggerValidation_mc_prescale\';doWriteBS=True;doWriteRDOTrigger=False;"'
 
diff --git a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1MC_grid.py b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1MC_grid.py
index 07af8bc468f483cee70105a1f33553f41be3ae03..bbd854cd380249b12b9186ad01d47904c98b66bd 100755
--- a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1MC_grid.py
+++ b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1MC_grid.py
@@ -4,6 +4,7 @@
 # art-description: Trigger RDO->RDO_TRIG athena test of the MC_pp_run3_v1 menu
 # art-type: grid
 # art-include: master/Athena
+# art-athena-mt: 4
 # art-output: *.txt
 # art-output: *.log
 # art-output: log.*
@@ -24,7 +25,8 @@ ex = ExecStep.ExecStep()
 ex.type = 'athena'
 ex.job_options = 'TriggerJobOpts/runHLT_standalone.py'
 ex.input = 'ttbar'
-ex.threads = 1
+ex.threads = 4
+ex.concurrent_events = 4
 ex.args = '-c "setMenu=\'MC_pp_run3_v1\';doWriteBS=False;doWriteRDOTrigger=True;"'
 
 test = Test.Test()
diff --git a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1PhysP1_grid.py b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1PhysP1_grid.py
index a950aa8984a180b93a700136d08bd3333f8db3e1..50c63fa1915875a8e3c0e9b5ffb48fe97adaa419 100755
--- a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1PhysP1_grid.py
+++ b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1PhysP1_grid.py
@@ -4,6 +4,7 @@
 # art-description: Trigger RDO->RDO_TRIG athena test of the PhysicsP1_pp_run3_v1 menu
 # art-type: grid
 # art-include: master/Athena
+# art-athena-mt: 4
 # art-output: *.txt
 # art-output: *.log
 # art-output: log.*
@@ -24,7 +25,8 @@ ex = ExecStep.ExecStep()
 ex.type = 'athena'
 ex.job_options = 'TriggerJobOpts/runHLT_standalone.py'
 ex.input = 'ttbar'
-ex.threads = 1
+ex.threads = 4
+ex.concurrent_events = 4
 ex.args = '-c "setMenu=\'PhysicsP1_pp_run3_v1\';doWriteBS=False;doWriteRDOTrigger=True;"'
 
 test = Test.Test()
diff --git a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Phys_grid.py b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Phys_grid.py
index 732a19a4b137723cf5aad1ba54f0dc3e950a34b2..3be147f9fa51f4ee6ebfc6e5939f65e77b8640ba 100755
--- a/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Phys_grid.py
+++ b/Trigger/TrigValidation/TriggerTest/test/test_trig_mc_v1Phys_grid.py
@@ -4,6 +4,7 @@
 # art-description: Trigger RDO->RDO_TRIG athena test of the Physics_pp_run3_v1 menu
 # art-type: grid
 # art-include: master/Athena
+# art-athena-mt: 4
 # art-output: *.txt
 # art-output: *.log
 # art-output: log.*
@@ -24,7 +25,8 @@ ex = ExecStep.ExecStep()
 ex.type = 'athena'
 ex.job_options = 'TriggerJobOpts/runHLT_standalone.py'
 ex.input = 'ttbar'
-ex.threads = 1
+ex.threads = 4
+ex.concurrent_events = 4
 ex.args = '-c "setMenu=\'Physics_pp_run3_v1\';doWriteBS=False;doWriteRDOTrigger=True;"'
 
 test = Test.Test()
diff --git a/Trigger/TriggerCommon/TrigEDMConfig/python/ContainerRemapping_Run2Run3.py b/Trigger/TriggerCommon/TrigEDMConfig/python/ContainerRemapping_Run2Run3.py
index 4ab7cbc2318c2bc0adb21bb9f2006b164eebc0e3..7ac68c736393783eb9a02b2f00d542f2959c43bd 100644
--- a/Trigger/TriggerCommon/TrigEDMConfig/python/ContainerRemapping_Run2Run3.py
+++ b/Trigger/TriggerCommon/TrigEDMConfig/python/ContainerRemapping_Run2Run3.py
@@ -24,7 +24,7 @@ HLT_Name_Changes = {
         ('HLT_AntiKt10LCTopoJets_subjes',                    'HLT_xAOD__JetContainer_a10tclcwsubjesFS'),
         ('HLT_AntiKt10LCTopoJets_nojcalib',                  'HLT_xAOD__JetContainer_a10tclcwnojcalibFS'),
         # Large-R groomed
-        ('HLT_AntiKt10LCTopoTrimmedPtFrac5SmallR20Jets_jes', 'HLT_xAOD__JetContainer_a10ttclcwjesFS'),
+        ('HLT_AntiKt10LCTopoTrimmedPtFrac4SmallR20Jets_jes', 'HLT_xAOD__JetContainer_a10ttclcwjesFS'),
         ],
     
     'xAOD::CaloClusterContainer':
@@ -42,6 +42,13 @@ def remapHLTContainerNames():
             auxcontainertype = containertype.replace("Container","AuxContainer")
             if containertype=="xAOD::CaloClusterContainer":
                 auxcontainertype = "xAOD::CaloClusterTrigAuxContainer"
+            if containertype=="xAOD::JetContainer" and run3name.startswith("HLT"):
+                isShallow = True
+                for expr in ["RCJets","Trimmed","SoftDrop","nojcalib"]:
+                    if expr in run3name:
+                        isShallow=False
+                if isShallow:
+                    auxcontainertype = "xAOD::ShallowAuxContainer"
 
             #AddressRemappingSvc.addInputRename(containertype,run3name,run2name)
             ars = AddressRemappingSvc.getAddressRemappingSvc()
diff --git a/Trigger/TriggerCommon/TrigEDMConfig/python/TriggerEDMRun3.py b/Trigger/TriggerCommon/TrigEDMConfig/python/TriggerEDMRun3.py
index d866cf3620c313e982111d6931622dca4f89f8d6..9b8c0dcc12d0395f9085132fd7dac23244aba278 100644
--- a/Trigger/TriggerCommon/TrigEDMConfig/python/TriggerEDMRun3.py
+++ b/Trigger/TriggerCommon/TrigEDMConfig/python/TriggerEDMRun3.py
@@ -207,6 +207,7 @@ TriggerHLTListRun3 = [
     ('xAOD::TrackParticleContainer#HLT_IDTrack_MuonLate_FTF',                 'BS ESD AODFULL', 'Muon', 'inViews:MUEFLATEViewRoIs'),
     ('xAOD::TrackParticleAuxContainer#HLT_IDTrack_MuonLate_FTFAux.',          'BS ESD AODFULL', 'Muon'),
 
+
     ('xAOD::TrackParticleContainer#HLT_IDTrack_MuonLate_IDTrig',              'BS ESD AODFULL', 'Muon', 'inViews:MUEFLATEViewRoIs'),
     ('xAOD::TrackParticleAuxContainer#HLT_IDTrack_MuonLate_IDTrigAux.',       'BS ESD AODFULL', 'Muon'),
 
@@ -293,6 +294,7 @@ TriggerHLTListRun3 = [
     ('TrigRoiDescriptorCollection#HLT_Roi_TauCore_MVA',                'BS ESD AODFULL AODSLIM',  'Steer'),
     ('TrigRoiDescriptorCollection#HLT_Roi_TauCore',             'BS ESD AODFULL AODSLIM',  'Steer'),
     ('TrigRoiDescriptorCollection#HLT_Roi_TauIso',             'BS ESD AODFULL AODSLIM',  'Steer'),
+    ('TrigRoiDescriptorCollection#HLT_Roi_TauIsoBDT',             'BS ESD AODFULL AODSLIM',  'Steer'),
     ('TrigRoiDescriptorCollection#HLT_Roi_TauID',           'BS ESD AODFULL AODSLIM',  'Steer'),
 
     ('xAOD::JetContainer#HLT_jet_seed',                         'BS ESD AODFULL AODSLIM AODVERYSLIM', 'Tau', 'inViews:TAUCaloViews,TAUCaloMVAViews'),
@@ -356,8 +358,8 @@ TriggerHLTListRun3 = [
     ('xAOD::JetContainer#HLT_AntiKt10EMPFlowCSSKSoftDropBeta100Zcut10Jets_nojcalib_ftf',                'BS ESD AODFULL', 'Jet'),
     ('xAOD::JetAuxContainer#HLT_AntiKt10EMPFlowCSSKSoftDropBeta100Zcut10Jets_nojcalib_ftfAux.'+JetVars, 'BS ESD AODFULL', 'Jet'),
 
-    ('xAOD::JetContainer#HLT_AntiKt10EMPFlowCSSKSoftDropBeta100Zcut10Jets_jes_ftf',                    'BS ESD AODFULL', 'Jet'),
-    ('xAOD::ShallowAuxContainer#HLT_AntiKt10EMPFlowCSSKSoftDropBeta100Zcut10Jets_jes_ftfAux.'+JetVars, 'BS ESD AODFULL', 'Jet'),
+    ('xAOD::JetContainer#HLT_AntiKt10EMPFlowCSSKSoftDropBeta100Zcut10Jets_jes_ftf',                'BS ESD AODFULL', 'Jet'),
+    ('xAOD::JetAuxContainer#HLT_AntiKt10EMPFlowCSSKSoftDropBeta100Zcut10Jets_jes_ftfAux.'+JetVars, 'BS ESD AODFULL', 'Jet'),
 
     ('xAOD::JetContainer#HLT_AntiKt4EMPFlowJets_subjesIS_ftf',                        'BS ESD AODFULL', 'Jet', 'alias:JetContainerShallowCopy'),
     ('xAOD::ShallowAuxContainer#HLT_AntiKt4EMPFlowJets_subjesIS_ftfAux.'+JetCopyVars, 'BS ESD AODFULL', 'Jet'),
@@ -388,7 +390,7 @@ TriggerHLTListRun3 = [
     ('xAOD::VertexAuxContainer#HLT_IDVertex_FSAux.',          'BS ESD AODFULL', 'Jet'),
 
 
-    # custom BeamSpot tracks - we don't want to write these out in general so this 
+    # custom BeamSpot tracks - we don't want to write these out in general so this
     # is commented, if we want to write them out at some point, then these lines
     # should be uncommented and they should get written out
     #    ('xAOD::TrackParticleContainer#HLT_IDTrack_BeamSpot_FTF',         'BS ESD AODFULL', 'ID', 'inViews:beamspotViewRoIs' ),
@@ -473,6 +475,8 @@ TriggerHLTListRun3 = [
     ('xAOD::TrackParticleContainer#HLT_IDTrack_Bjet_FTF',        'BS ESD AODFULL', 'Bjet', 'inViews:BTagViews'),
     ('xAOD::TrackParticleAuxContainer#HLT_IDTrack_Bjet_FTFAux.', 'BS ESD AODFULL', 'Bjet'),
 
+
+
     # bjet Second Stage Precision tracks
     ('xAOD::TrackParticleContainer#HLT_IDTrack_Bjet_IDTrig',        'BS ESD AODFULL', 'Bjet', 'inViews:BTagViews'),
     ('xAOD::TrackParticleAuxContainer#HLT_IDTrack_Bjet_IDTrigAux.', 'BS ESD AODFULL', 'Bjet'),
@@ -486,12 +490,12 @@ TriggerHLTListRun3 = [
 
     # secvertex for b-jets
     ('xAOD::VertexContainer#HLT_BTaggingSecVtx',                          'BS ESD AODFULL AODSLIM AODVERYSLIM', 'Bjet', 'inViews:BTagViews'),
-    ('xAOD::VertexAuxContainer#HLT_BTaggingSecVtxAux.',                   'BS ESD AODFULL AODSLIM AODVERYSLIM', 'Bjet'),  
+    ('xAOD::VertexAuxContainer#HLT_BTaggingSecVtxAux.',                   'BS ESD AODFULL AODSLIM AODVERYSLIM', 'Bjet'),
 
     # btagvertex for b-jets
     ('xAOD::BTagVertexContainer#HLT_BTaggingJFVtx',                          'BS ESD AODFULL AODSLIM AODVERYSLIM', 'Bjet', 'inViews:BTagViews'),
     ('xAOD::BTagVertexAuxContainer#HLT_BTaggingJFVtxAux.',                   'BS ESD AODFULL AODSLIM AODVERYSLIM', 'Bjet'),
-    
+
     # bjet b-tagging
     ('xAOD::BTaggingContainer#HLT_BTagging',                          'BS ESD AODFULL AODSLIM AODVERYSLIM', 'Bjet', 'inViews:BTagViews'),
     ('xAOD::BTaggingAuxContainer#HLT_BTaggingAux.'+BTagVars,          'BS ESD AODFULL AODSLIM AODVERYSLIM', 'Bjet'),
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/python/HLTTriggerGetter.py b/Trigger/TriggerCommon/TriggerJobOpts/python/HLTTriggerGetter.py
index e8058e8941343ee4eac90c5fa9ba7c07819de071..a5b2806068a0f2f277175cade788e023c61f592c 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/python/HLTTriggerGetter.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/python/HLTTriggerGetter.py
@@ -218,22 +218,6 @@ class HLTSimulationGetter(Configured):
 
 
         if TriggerFlags.writeBS():
-            # declare objects to go to BS (from the lists above)
-            ## if TriggerFlags.doLVL2():                
-            ##     from TrigEDMConfig.TriggerEDM import getL2BSList
-            ##     TrigSteer_L2.Navigation.ClassesToPayload = getL2BSList()
-            ##     TrigSteer_L2.Navigation.ClassesToPreregister = []
-            ## 
-            ## if TriggerFlags.doEF():
-            ##     from TrigEDMConfig.TriggerEDM import getEFBSList
-            ##     TrigSteer_EF.Navigation.ClassesToPayload = getEFBSList()
-            ##     TrigSteer_EF.Navigation.ClassesToPreregister = []
-            ##     try:
-            ##         from TrigEDMConfig.TriggerEDM import getEFDSList
-            ##         TrigSteer_EF.Navigation.ClassesToPayload_DSonly = getEFDSList()
-            ##     except ImportError:
-            ##         log.warning("DataScouting not available in this release")
-
             if TriggerFlags.doHLT():
                 from TrigEDMConfig.TriggerEDM import  getHLTBSList 
                 TrigSteer_HLT.Navigation.ClassesToPayload = getHLTBSList() 
@@ -257,14 +241,6 @@ class HLTSimulationGetter(Configured):
             TrigSerializeConvHelper = TrigSerializeConvHelper(doTP = True)
             ToolSvc += TrigSerializeConvHelper
 
-            #do not activate T/P of EF classes at L2
-            ## if TriggerFlags.doLVL2(): 
-            ##     from TrigEDMConfig.TriggerEDM import getL2BSTypeList
-            ##     TrigSerToolTP.ActiveClasses = getL2BSTypeList()
-            ## if TriggerFlags.doEF():
-            ##     from TrigEDMConfig.TriggerEDM import getL2BSTypeList, getEFBSTypeList
-            ##     TrigSerToolTP.ActiveClasses = getL2BSTypeList() + getEFBSTypeList()
-
             if TriggerFlags.doHLT():
                 from TrigEDMConfig.TriggerEDM import getHLTBSTypeList 
                 TrigSerToolTP.ActiveClasses = getHLTBSTypeList()
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/python/Lvl1SimulationConfig.py b/Trigger/TriggerCommon/TriggerJobOpts/python/Lvl1SimulationConfig.py
index 463e2b07dc49a51b16cc79034d277f38d06a2582..614fc8765886daebb1911338a490094ce956fff1 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/python/Lvl1SimulationConfig.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/python/Lvl1SimulationConfig.py
@@ -187,22 +187,20 @@ def Lvl1SimulationSequence( flags = None ):
     ##################################################
 
     l1TopoSim = None
+    from L1TopoSimulation.L1TopoSimulationConfig import L1TopoSimulation
+    l1TopoSim = L1TopoSimulation()
+    l1TopoSim.MuonInputProvider.ROIBResultLocation = "" #disable input from RoIBResult
     if flags.Trigger.enableL1Phase1:
-        log.info("No phase1 configuration for L1Topo simulation is available")
+        l1TopoSim.MuonInputProvider.MuctpiSimTool = ToolSvc.MUCTPI_AthTool
     else:
-        from L1TopoSimulation.L1TopoSimulationConfig import L1TopoSimulation
-        l1TopoSim = L1TopoSimulation()
-
-        l1TopoSim.MuonInputProvider.ROIBResultLocation = "" #disable input from RoIBResult
         l1TopoSim.MuonInputProvider.MuctpiSimTool = ToolSvc.L1MuctpiTool
-
-        # enable the reduced (coarse) granularity topo simulation
-        # currently only for MC
-        from AthenaCommon.GlobalFlags  import globalflags
-        if globalflags.DataSource()!='data':
-            l1TopoSim.MuonInputProvider.MuonEncoding = 1
-        else:
-            l1TopoSim.MuonInputProvider.MuonEncoding = 0
+    # enable the reduced (coarse) granularity topo simulation
+    # currently only for MC
+    from AthenaCommon.GlobalFlags  import globalflags
+    if globalflags.DataSource()!='data':
+        l1TopoSim.MuonInputProvider.MuonEncoding = 1
+    else:
+        l1TopoSim.MuonInputProvider.MuonEncoding = 0
 
     ##################################################
     # CTP
@@ -213,7 +211,7 @@ def Lvl1SimulationSequence( flags = None ):
     ctp.DoLUCID     = False
     ctp.DoBCM       = False
     ctp.DoL1Topo    = not flags.Trigger.enableL1Phase1
-    ctp.UseCondL1Menu = False
+    ctp.UseNewConfig = True
     ctp.TrigConfigSvc = svcMgr.LVL1ConfigSvc
     ctpSim      = seqAND("ctpSim", [ctp])
 
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/python/Modifiers.py b/Trigger/TriggerCommon/TriggerJobOpts/python/Modifiers.py
index f9a8e1cf22bd40c11e3b57fe737eedea8a1e9307..5727d0bb3bcd639846526fb557579cdfdf1a0148 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/python/Modifiers.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/python/Modifiers.py
@@ -633,10 +633,6 @@ class rerunLVL1(_modifier):
     """
     def preSetup(self):
 
-        # Do nothing for EF only running
-        if not TriggerFlags.doLVL2() and TriggerFlags.doEF():
-            return
-
         from AthenaCommon.Include import include
         from AthenaCommon.AlgSequence import AlgSequence
         topSequence = AlgSequence()
@@ -736,10 +732,6 @@ class rerunDMLVL1(_modifier):
     """
     def preSetup(self):
 
-         # Do nothing for EF only running
-         if not TriggerFlags.doLVL2() and TriggerFlags.doEF():
-             return
-
          from AthenaCommon.Include import include
          from AthenaCommon.AlgSequence import AlgSequence
          topSequence = AlgSequence()
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfig.py b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfig.py
index 2e754db3f0354cf9c53fcfc53e08ebb36abd5e89..019ff970bb32b7c455ee3c51cbaa9ba204a591f9 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfig.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfig.py
@@ -10,6 +10,11 @@ __log = logging.getLogger('TriggerConfig')
 def __isCombo(alg):
     return hasProp( alg, "MultiplicitiesMap" )  # alg.getType() == 'ComboHypo':
 
+def __stepNumber(stepName):
+    """extract step number frmo strings like Step2... -> 2"""
+    return int(stepName.split('_')[0].replace("Step",""))
+
+
 def collectHypos( steps ):
     """
     Method iterating over the CF and picking all the Hypothesis algorithms
@@ -24,7 +29,7 @@ def collectHypos( steps ):
     for stepSeq in getSequenceChildren( steps ):
         if not isSequence( stepSeq ):
             continue
-        
+
         if "filter" in stepSeq.getName():
             __log.debug("Skipping filtering steps %s", stepSeq.getName() )
             continue
@@ -47,13 +52,13 @@ def collectHypos( steps ):
     return OrderedDict(hypos)
 
 def __decisionsFromHypo( hypo ):
-    """ return all chains served by this hypo and the key of produced decision object """
+    """ return all chains served by this hypo and the keys of produced decision object """
     from TrigCompositeUtils.TrigCompositeUtils import isLegId
-    __log.debug("Hypo type %s is combo %r", hypo.getName(), __isCombo(hypo))
-    if __isCombo( hypo ):
-        return [key for key in list(hypo.MultiplicitiesMap.keys()) if not isLegId(key)], str(hypo.HypoOutputDecisions[0])
+    __log.debug("Hypo type %s is combo %r", hypo.getName(), __isCombo(hypo))    
+    if __isCombo(hypo):
+        return [key for key in list(hypo.MultiplicitiesMap.keys()) if not isLegId(key)], hypo.HypoOutputDecisions
     else: # regular hypos
-        return [ t.getName() for t in hypo.HypoTools if not isLegId(t.getName())], str(hypo.HypoOutputDecisions)
+        return [ t.getName() for t in hypo.HypoTools if not isLegId(t.getName())], [str(hypo.HypoOutputDecisions)]
 
 def __getSequenceChildrenIfIsSequence( s ):
     if isSequence( s ):
@@ -168,17 +173,28 @@ def triggerSummaryCfg(flags, hypos):
     DecisionSummaryMakerAlg=CompFactory.DecisionSummaryMakerAlg
     from TrigEDMConfig.TriggerEDMRun3 import recordable
     decisionSummaryAlg = DecisionSummaryMakerAlg()
-    allChains = OrderedDict()
+    allChains = OrderedDict() # keys are chain names, values are lists of collections
 
-    
-    # lambda sort because we have strings Step1 Step2 ... Step10 Step11 and python sorts that
-    # to Step10 Step11 Step1 Step2
-    for stepName, stepHypos in sorted( hypos.items(), key=lambda x : int(x[0].split('_')[0][4:]) ):
-        # order hypos so that ComboHypos are last ones
-        orderedStepHypos = sorted(stepHypos, key=lambda hypo: __isCombo(hypo))  
+
+    # sort steps according to the step number i.e. strings Step1 Step2 ... Step10 Step11 rather than
+    # alphabetic order Step10 Step11 Step1 Step2
+    for stepName, stepHypos in sorted( hypos.items(), key=lambda x : __stepNumber(x[0]) ):
+        # While filling the allChains dict we will replace the content intentionally
+        # i.e. the chain has typically multiple steps and we want the collections from the last one
+        # In a step the chain is handled by hypo or hypo followed by the combo,
+        # in second case we want out of the later.
+        # For that we process first ComboHypo and then regular Hypos 
+        # (TODO, review this whn config is symmetrised by addition of ComboHypos always)
+        orderedStepHypos = sorted(stepHypos, key=lambda hypo: not __isCombo(hypo))
+
+        stepChains = OrderedDict()
         for hypo in orderedStepHypos:
-            hypoChains,hypoOutputKey = __decisionsFromHypo( hypo )
-            allChains.update( OrderedDict.fromkeys( hypoChains, hypoOutputKey ) )
+            hypoChains, hypoOutputKeys = __decisionsFromHypo( hypo )
+            for chain in hypoChains:
+                if chain not in stepChains:
+                    stepChains[chain] = hypoOutputKeys
+        allChains.update( stepChains )
+
     from TriggerMenuMT.HLTMenuConfig.Menu.TriggerConfigHLT import TriggerConfigHLT
     from L1Decoder.L1DecoderConfig import mapThresholdToL1DecisionCollection
     if len(TriggerConfigHLT.dicts()) == 0:
@@ -189,13 +205,18 @@ def triggerSummaryCfg(flags, hypos):
                 __log.debug("The chain %s is not mentioned in any step", chainName)
                 # TODO once sequences available in the menu we need to crosscheck it here
                 assert len(chainDict['chainParts'])  == 1, "Chains w/o the steps can not have mutiple parts in chainDict, it makes no sense: %s"%chainName
-                allChains[chainName] = mapThresholdToL1DecisionCollection( chainDict['chainParts'][0]['L1threshold'] )
-                __log.debug("The chain %s final decisions will be taken from %s", chainName, allChains[chainName] )
-
+                allChains[chainName] = [ mapThresholdToL1DecisionCollection( chainDict['chainParts'][0]['L1threshold'] ) ]
 
     for c, cont in allChains.items():
-        __log.debug("Final decision of chain  %s will be read from %s", c, cont)
-    decisionSummaryAlg.FinalDecisionKeys = list(OrderedDict.fromkeys(allChains.values()))
+        __log.debug("Final decision of chain  %s will be read from %d %s", c, len(cont), str(cont))
+    # Flatten all the collections preserving the order
+    collectionsWithFinalDecisions = []
+    for chain, collections in allChains.items():
+        for c in collections:
+            if c not in collectionsWithFinalDecisions:
+                collectionsWithFinalDecisions.append(c)
+    __log.debug("Final keys %s", collectionsWithFinalDecisions)
+    decisionSummaryAlg.FinalDecisionKeys = collectionsWithFinalDecisions
     decisionSummaryAlg.FinalStepDecisions = dict(allChains)
     decisionSummaryAlg.DecisionsSummaryKey = "HLTNav_Summary" # Output
     decisionSummaryAlg.DoCostMonitoring = flags.Trigger.CostMonitoring.doCostMonitoring
@@ -219,11 +240,11 @@ def triggerMonitoringCfg(flags, hypos, filters, l1Decoder):
 
     # lambda sort because we have strings Step1 Step2 ... Step10 Step11 and python sorts that
     # to Step10 Step11 Step1 Step2
-    for stepName, stepHypos in sorted( hypos.items(), key=lambda x : int(x[0].split('_')[0][4:]) ):
+    for stepName, stepHypos in sorted( hypos.items(), key=lambda x : __stepNumber(x[0])):
         stepDecisionKeys = []
         for hypo in stepHypos:
-            hypoChains, hypoOutputKey  = __decisionsFromHypo( hypo )
-            stepDecisionKeys.append( hypoOutputKey )
+            hypoChains, hypoOutputKeys  = __decisionsFromHypo( hypo )
+            stepDecisionKeys.extend( hypoOutputKeys )
             allChains.update( hypoChains )
 
         dcTool = DecisionCollectorTool( "DecisionCollector" + stepName, Decisions=list(OrderedDict.fromkeys(stepDecisionKeys)))
@@ -560,7 +581,7 @@ def triggerRunCfg( flags, seqName = None, menu=None ):
     acc.merge( L1ConfigSvcCfg(flags) )
 
     acc.addSequence( seqOR( "HLTTop") )
-    
+
     acc.addSequence( parOR("HLTBeginSeq"), parentName="HLTTop" )
     # bit of a hack as for "legacy" type JO a seq name for cache creators has to be given,
     # in newJO realm the seqName will be removed as a comp fragment shoudl be unaware of where it will be attached
@@ -583,7 +604,7 @@ def triggerRunCfg( flags, seqName = None, menu=None ):
     filters = collectFilters( HLTSteps )
     acc.addSequence( parOR("HLTEndSeq"), parentName="HLTTop" )
     acc.addSequence( seqAND("HLTFinalizeSeq"), parentName="HLTEndSeq" )
-    
+
     summaryAcc, summaryAlg = triggerSummaryCfg( flags, hypos )
     acc.merge( summaryAcc, sequenceName="HLTFinalizeSeq" )
     acc.addEventAlgo( summaryAlg, sequenceName="HLTFinalizeSeq" )
@@ -664,13 +685,13 @@ if __name__ == "__main__":
         menuCA.addSequence( seqAND("HLTAllSteps") )
         return menuCA
 
-        
+
     acc = triggerRunCfg( ConfigFlags, seqName = None, menu = testMenu )
     Configurable.configurableRun3Behavior=0
     from AthenaConfiguration.ComponentAccumulator import appendCAtoAthena
     appendCAtoAthena( acc )
 
-    
+
     f=open("TriggerRunConf.pkl","wb")
     acc.store(f)
     f.close()
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfigFlags.py b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfigFlags.py
index db719bd2be261ed9e0e3e4039e7f142b90c24c20..5fccd7a800b5c3db47e10c93c2b09a0669209e37 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfigFlags.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfigFlags.py
@@ -298,7 +298,6 @@ def createTriggerFlags():
         from MuonConfig.MuonConfigFlags import createMuonConfigFlags
         muonflags = createMuonConfigFlags()
         muonflags.Muon.useTGCPriorNextBC=True
-        muonflags.Muon.enableErrorTuning=False
         muonflags.Muon.MuonTrigger=True
         muonflags.Muon.SAMuonTrigger=True
         return muonflags 
@@ -310,21 +309,16 @@ def createTriggerFlags():
 
     return flags
     # for reference, this flags are skipped as never used or never set in fact, or set identical to de default or used in a very old JO:
-    # readLVL1Calo, readLVL1Muon, fakeLVL1, useCaloTTL
+    # fakeLVL1, useCaloTTL
     # doCosmicSim - old JO
-    # disableRandomPrescale - never used
     # doMergedHLTResult - not needed now
     # doAlwaysUnpackDSResult - never set
     # doTrt - fast TRT or trigger - never used
     # doLucid - not sure if ever set to False, identical rec flag exists
     # doZdc - never set to anything different than default
-    # doHLTpersistency - never red
-    # useOfflineSpacePoints - used only to set 
-    # doNtuple - never red
-    # configForStartup                 
+    # configForStartup
     # the flags related to trigger DB are redundant of triggerConfig - need to decide if they are needed in this form
     # also not defined the Prescale sets yet
-    # abortOnConfigurationError - never red
     # in signatures
     # egamma: ringerVersion - not used
     # muon: doMuonCalibrationStream - not used
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfigGetter.py b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfigGetter.py
index 78517fb357d3ee3366efc162e84fddc64b2b38cb..d3f95dbdefcbefa89d9eb3c02466e298193203e4 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfigGetter.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerConfigGetter.py
@@ -141,15 +141,13 @@ class TriggerConfigGetter(Configured):
 
         # first check the input
         if "HIT2RDO" in self._environment:
-            TriggerFlags.doLVL2 = False
-            TriggerFlags.doEF = False
+            TriggerFlags.doHLT = False
             log.info("For simulation jobs the following flags are set:")
             log.info("globalflags.InputFormat             : %s", globalflags.InputFormat())
             log.info("globalflags.DataSource              : %s", globalflags.DataSource())
             log.info("TriggerFlags.configForStartup       : %s", TriggerFlags.configForStartup())
             log.info("TriggerFlags.dataTakingConditions   : %s", TriggerFlags.dataTakingConditions())
-            log.info("TriggerFlags.doLVL2                 : %s", TriggerFlags.doLVL2())
-            log.info("TriggerFlags.doEF                   : %s", TriggerFlags.doEF())
+            log.info("TriggerFlags.doHLT                  : %s", TriggerFlags.doHLT())
         else:
             if not self.checkInput():
                 log.error("Could not determine job input. Can't setup trigger configuration and will return!")
@@ -190,14 +188,14 @@ class TriggerConfigGetter(Configured):
 
         # reading from the TriggerDB can mean different things:
 
-        # a) TriggerFlags doLVL2() and doEF() are both False:
+        # a) TriggerFlags doHLT() is False:
         #    - create a tmp sqlite file with the conditions (menu)
         #    - use DSConfigSvc
 
 
-        # b) TriggerFlags doLVL2() or doEF() is True:
+        # b) TriggerFlags doHLT() is True:
         #    - use HLTConfigSvc
-        if self.readTriggerDB and (TriggerFlags.doLVL2() or TriggerFlags.doEF() or TriggerFlags.doHLT()):
+        if self.readTriggerDB and TriggerFlags.doHLT():
 
             self.ConfigSrcList = ['xml'] # to use L1/HLTConfigSvc and not DSConfigSvc, but only if we are running the HLT
 
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerFlags.py b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerFlags.py
index e7ea511f414c689c0e4b065ff876a010175f727e..20ce5bdbdab30e69c25ee7e58817b89166078b73 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerFlags.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerFlags.py
@@ -41,34 +41,24 @@ default_true_flags = [
     "doZdc",  # if False, disable ZDC algorithms at LVL2 & EF """"
     "doLucid", # if False, disable Lucid algorithms at LVL2 & EF
     "doMuon", # if FAlse, disable Muons, note: muons need input file containing digits"""
-    "doHLTpersistency",  # serialise L2result """
     "doNavigationSlimming",  # Enable the trigger navigation slimming"""
 ]
 
 default_false_flags = [
     "readLVL1FromJSON", # the authoritative L1 menu (xml or json) - this flag will be removed after the transition to json has been completed
-    "readLVL1Calo", # read LVL1 Calo info from pool or BS """
-    "readLVL1Muon", # read LVL1 Muon in from Pool or BS """
     "fakeLVL1", # create fake RoI from KINE info  """
     "useL1CaloCalibration", # Should be false for early data, true for later """
     "useRun1CaloEnergyScale",
     "doCosmicSim", # run the LVL1 simulation with special setup for cosmic simulation (set to FALSE by default, to do collisions simulation) """
-    "disableRandomPrescale",  # if True, disable Random Prescales
-    "doLVL2",  # if False, disable LVL2 selection
-    "doEF",  # if False, disable EF selection
     "doTruth",
     "doFTK",  # if False, disable FTK result reader """
     "doTriggerConfigOnly",  # if True only the configuration services should be set, no algorithm """
-    "useOfflineSpacePoints", # use online convertors for Si SpacePoints
     "doTransientByteStream",  # Write transient ByteStream before executing HLT algorithms.
                               # To be used for running on MC RDO with clients which require BS inputs.
-    "doNtuple",
     "writeBS",  # Write ByteStream output file """
     "readBS",
     "readMenuFromTriggerDb", # define the TriggerDb to be the source of the LVL1 and HLT trigger menu
     "generateMenuDiagnostics",  # Generate additional files heling in menu diagnostics """
-    "abortOnConfigurationError", # Should the job be stoped if there is an error in configuration
-
 ]
 
 for name in default_true_flags:
@@ -87,24 +77,6 @@ class doHLT(JobProperty):
     allowedType=['bool']
     StoredValue=True
     
-    def _do_action(self):
-        """ setup flag level consistency """
-        if self.get_Value() is True:
-            if TriggerFlags.doEF.is_locked():
-                TriggerFlags.doEF.unlock()
-                TriggerFlags.doEF.set_Off()
-                TriggerFlags.doEF.lock()
-            else:
-                TriggerFlags.doEF.set_Off()
-            if TriggerFlags.doEF.is_locked():
-                TriggerFlags.doLVL2.unlock()
-                TriggerFlags.doLVL2.set_Off()
-                TriggerFlags.doLVL2.lock()
-            else:
-                TriggerFlags.doLVL2.set_Off()
-            log = logging.getLogger( 'TriggerFlags.doHLT' )
-            log.info("doHLT is True: force doLVL2=False and doEF=False"  )
-
 _flags.append(doHLT)
 
 class doMT(JobProperty):
@@ -964,8 +936,7 @@ def sync_Trigger2Reco():
     if globalflags.InputFormat() == 'bytestream':
         TriggerFlags.readBS = True
         TriggerFlags.doLVL1 = False
-        TriggerFlags.doLVL2 = False
-        TriggerFlags.doEF   = False
+        TriggerFlags.doHLT   = False
 
     if rec.doWriteBS():
         TriggerFlags.writeBS = True
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerGetter.py b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerGetter.py
index d1fd8603a31e15ec9888f305b941ce9611f2e10d..a33ba3f35c0c1413202255d19b54520a15d7435c 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerGetter.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/python/TriggerGetter.py
@@ -1,4 +1,4 @@
-# Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 from AthenaCommon.GlobalFlags import jobproperties
 from AthenaCommon.Logging import logging
@@ -44,17 +44,17 @@ class TriggerGetter(Configured):
 
         # start with print some information what this will do
         log.info("Basic configuration flags RecAlgsFlag.doTrigger: %d   RecFlags.doTrigger: %d TriggerFlags.doTriggerConfigOnly %d", recAlgs.doTrigger(), rec.doTrigger(), TF.doTriggerConfigOnly() )
-        log.info("TriggerFlags: doL1Topo: %s, doLVL1: %s, doLVL2: %s, doEF: %s, doHLT: %s, doMT: %s", TF.doL1Topo(), TF.doLVL1(), TF.doLVL2(), TF.doEF(), TF.doHLT(), TF.doMT() )
+        log.info("TriggerFlags: doL1Topo: %s, doLVL1: %s, doHLT: %s, doMT: %s", TF.doL1Topo(), TF.doLVL1(), TF.doHLT(), TF.doMT() )
 
         # RDOtoRDOTrigger MT temporarily coded in the transform skeleton, so skip here
         if TF.doMT() and rec.readRDO() and rec.doWriteRDO():
             log.info("Nothing happens in TriggerGetter for RDOtoRDOTrigger MT")
             return True
         
-        willGenerateMenu = recAlgs.doTrigger() and (TF.doLVL1() or TF.doLVL2() or TF.doEF() or TF.doHLT()) and not TF.doTriggerConfigOnly()
+        willGenerateMenu = recAlgs.doTrigger() and (TF.doLVL1() or TF.doHLT()) and not TF.doTriggerConfigOnly()
         willRunTriggerConfigGetter = recAlgs.doTrigger() or rec.doTrigger() or TF.doTriggerConfigOnly()
         willRunLVL1SimulationGetter = recAlgs.doTrigger() and not TF.doTriggerConfigOnly()
-        willRunHLTSimulationGetter = willRunLVL1SimulationGetter and (TF.doLVL2() or TF.doEF() or TF.doHLT())
+        willRunHLTSimulationGetter = willRunLVL1SimulationGetter and TF.doHLT()
 
         log.info("Will run: %s%s%s%s", "GenerateMenu " if willGenerateMenu else "",
                                        "TriggerConfigGetter " if willRunTriggerConfigGetter else "",
@@ -68,7 +68,7 @@ class TriggerGetter(Configured):
         if recAlgs.doTrigger():
             from TriggerMenu.menu.GenerateMenu import GenerateMenu
 
-            if ((TF.doLVL1() or TF.doLVL2() or TF.doEF() or TF.doHLT()) and not TF.doTriggerConfigOnly()):
+            if ((TF.doLVL1() or TF.doHLT()) and not TF.doTriggerConfigOnly()):
                 log.info("generating menu")
                 # trigger menu files generation
                 g = GenerateMenu()
@@ -120,7 +120,7 @@ class TriggerGetter(Configured):
             lvl1 = Lvl1SimulationGetter()  # noqa: F841
             
 
-            if TF.doTransientByteStream() or (jobproperties.Global.InputFormat() != 'bytestream' and (TF.doLVL2() or TF.doEF() or TF.doHLT())):
+            if TF.doTransientByteStream() or (jobproperties.Global.InputFormat() != 'bytestream' and TF.doHLT()):
                 # Transient BS construction and intialization
                 from ByteStreamCnvSvc import WriteByteStream
                 StreamBS = WriteByteStream.getStream("Transient","StreamBS")
@@ -147,10 +147,8 @@ class TriggerGetter(Configured):
 
             # setup HLT
             # initialize HLT config svc
-            log.info("TriggerFlags: doLVL2 %r", TF.doLVL2())
-            log.info("TriggerFlags: doEF   %r", TF.doEF())
             log.info("TriggerFlags: doHLT  %r", TF.doHLT())
-            if TF.doLVL2() or TF.doEF() or TF.doHLT():
+            if TF.doHLT():
                 log.info("configuring hlt")
                 from TriggerJobOpts.HLTTriggerGetter import HLTSimulationGetter
                 hlt = HLTSimulationGetter(g)  # noqa: F841
@@ -166,7 +164,7 @@ class TriggerGetter(Configured):
         hltouput = Lvl1ResultBuilderGetter()
 
         # prepare result making of HLT
-        if TF.doLVL2() or TF.doEF() or TF.doHLT() or (recAlgs.doTrigger() and TF.readBS()):
+        if TF.doHLT() or (recAlgs.doTrigger() and TF.readBS()):
             from TriggerJobOpts.HLTTriggerResultGetter import HLTTriggerResultGetter
             hltouput = HLTTriggerResultGetter()  # noqa: F841
       
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/share/BStoESD_Tier0_HLTConfig_jobOptions.py b/Trigger/TriggerCommon/TriggerJobOpts/share/BStoESD_Tier0_HLTConfig_jobOptions.py
index 1418276ca6de26138c4402619a037443595a09d2..f7245c3d1b15d6721dc297123a6a3b583aa792e7 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/share/BStoESD_Tier0_HLTConfig_jobOptions.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/share/BStoESD_Tier0_HLTConfig_jobOptions.py
@@ -29,8 +29,7 @@ if rec.doTrigger():
     tf.readBS=True # needed in HLTTriggerGetter - do not understand why it is not
     # true by default when globalflags.InputFormat = 'bytestream'
     tf.doLVL1= False # needed to not rerun the trigger
-    tf.doEF= False # needed to not rerun the trigger
-    tf.doLVL2 = False  # needed to not rerun the trigger
+    tf.doHLT= False # needed to not rerun the trigger
     tf.configurationSourceList = ['ds']
 
     try:
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/share/Trigger_topOptions_standalone.py b/Trigger/TriggerCommon/TriggerJobOpts/share/Trigger_topOptions_standalone.py
index 6889699a20f95c4e20dc5cecea6bdf343695ef5b..268cae97692d734541b98c21c7372a81d692d7c5 100755
--- a/Trigger/TriggerCommon/TriggerJobOpts/share/Trigger_topOptions_standalone.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/share/Trigger_topOptions_standalone.py
@@ -133,7 +133,7 @@ if TriggerFlags.doMuon():
     # load services needed for converters
     import MuonCnvExample.MuonCablingConfig  # noqa: F401 configuration by import, old Run-2 job options
     import MuonRecExample.MuonReadCalib  # noqa: F401 configuration by import, old Run-2 job options
-    if (TriggerFlags.doEF() or TriggerFlags.doHLT()) and 'forceMuonDataPrep' in dir():
+    if TriggerFlags.doHLT() and 'forceMuonDataPrep' in dir():
         if (TriggerFlags.MuonSlice.doEFRoIDrivenAccess()):
             include("MuonRdoToPrepData/CscRdoToCscPrepData_jobOptions.py")
         else:
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/share/runHLT_standalone_newJO.py b/Trigger/TriggerCommon/TriggerJobOpts/share/runHLT_standalone_newJO.py
index 7170f2fc9cdf43a374a8f403706c86ef3be263b5..f824ab4af1ed5377953ddf9f0c5e55eb12c968e2 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/share/runHLT_standalone_newJO.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/share/runHLT_standalone_newJO.py
@@ -42,6 +42,7 @@ flags.Scheduler.CheckDependencies = True
 flags.Scheduler.ShowDataDeps = True
 flags.Scheduler.ShowDataFlow = True
 flags.Scheduler.ShowControlFlow = True
+flags.Scheduler.EnableVerboseViews = True
 
 flags.Exec.MaxEvents=50
 flags.Input.isMC = False
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/share/runHLT_standalone_run2.py b/Trigger/TriggerCommon/TriggerJobOpts/share/runHLT_standalone_run2.py
index 0a92e0bc364cf8c79eb55d234e62b2664b194a1e..9bb40a1bc65fecfcc49d769309a148851ec86d3a 100755
--- a/Trigger/TriggerCommon/TriggerJobOpts/share/runHLT_standalone_run2.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/share/runHLT_standalone_run2.py
@@ -324,10 +324,7 @@ if setModifiers:
 include.block("RecExCond/RecExCommon_flags.py")
 log = logging.getLogger('runHLT_standalone.py')
 
-TriggerFlags.doHLTpersistency=False
 TriggerFlags.writeBS=True
-TriggerFlags.abortOnConfigurationError=True
-
 TriggerFlags.triggerMenuSetup=setMenu
 
 def stripPrescales(menu):
diff --git a/Trigger/TriggerCommon/TriggerJobOpts/share/test_hltConditions.py b/Trigger/TriggerCommon/TriggerJobOpts/share/test_hltConditions.py
index 550b02b03a14a941ea323d41d6a146d9e8010789..ad8a7ca03fb47ae5b29df58b31c41f56f05aae1b 100644
--- a/Trigger/TriggerCommon/TriggerJobOpts/share/test_hltConditions.py
+++ b/Trigger/TriggerCommon/TriggerJobOpts/share/test_hltConditions.py
@@ -6,7 +6,7 @@
 # deployment in the online DB.
 #
 # Usage:
-#  athena.py -c "sqlite='noise.db'" TriggerJobOpts/test_hltConditions.py
+#  athena.py --threads=1 -c "sqlite='noise.db'" TriggerJobOpts/test_hltConditions.py
 #  - Other options can be found below
 #
 # Author: Frank Winklmeier
@@ -22,9 +22,10 @@ if 'folder' not in dir():
    folder = '/CALO/Noise/CellNoise'
 
 # No updates required past this point
-testCurrentMenu=True
-EvtMax=10
-BSRDOInput='/afs/cern.ch/atlas/project/trigger/pesa-sw/validation/atn-test/data16_13TeV.00307126.physics_eb_zmm_egz.merged.RAW.selected._0001.data'
+from AthenaCommon.AppMgr import theApp
+from AthenaCommon.AthenaCommonFlags import athenaCommonFlags
+theApp.EvtMax = 10
+athenaCommonFlags.FilesInput = ['/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data18_13TeV.00360026.physics_EnhancedBias.merge.RAW._lb0151._SFO-1._0001.1']
 
 from AthenaCommon.Include import include
 myfolder = folder  # 'folder' seems to be overwritten somewhere in the include
@@ -32,12 +33,11 @@ include('TriggerJobOpts/runHLT_standalone.py')
 folder = myfolder
 
 from AthenaCommon.AppMgr import ServiceMgr as svcMgr
-from IOVDbSvc.CondDB import conddb  # noqa: F401 configuration by import, old Run-2 job options
-svcMgr.IOVDbSvc.forceRunNumber = 9999999
-
+from IOVDbSvc.CondDB import conddb
 sqlite_tmp = 'cool_tmp.db'
 tag = svcMgr.IOVDbSvc.GlobalTag
 conddb.addMarkup(folder,'<db>sqlite://;schema=%s;dbname=CONDBR2</db>' % sqlite_tmp)
+conddb.addMarkup(folder,'<forceRunNumber>%d</forceRunNumber>' % 9999999 )
 
 import os
 import sys
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/CMakeLists.txt b/Trigger/TriggerCommon/TriggerMenuMT/CMakeLists.txt
index 8a58635cbda9a7c2276e1f1df9674a4451f4c867..7a03fb29a6723ae7381504434209e08b7f79721b 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/CMakeLists.txt
+++ b/Trigger/TriggerCommon/TriggerMenuMT/CMakeLists.txt
@@ -3,11 +3,6 @@
 # Declare the package name:
 atlas_subdir( TriggerMenuMT )
 
-atlas_add_test( flake8
-   SCRIPT flake8 --select=ATL,F,E7,E9,W6,E101 --enable-extension=ATL900,ATL901,ATL902
-   ${CMAKE_CURRENT_SOURCE_DIR}/python ${CMAKE_CURRENT_SOURCE_DIR}/scripts
-   POST_EXEC_SCRIPT nopost.sh )
-
 #----------------------------------
 # Function to build trigger menu:
 function( atlas_build_lvl1_trigger_menu menu )
@@ -99,21 +94,25 @@ atlas_install_python_modules( python/*.py
                               python/LVL1MenuConfig
                               python/L1
                               python/HLTMenuConfig
-			                  POST_BUILD_CMD ${ATLAS_FLAKE8})
+                              POST_BUILD_CMD ${ATLAS_FLAKE8} --extend-extensions=ATL900,ATL901 )
 
-atlas_install_scripts( scripts/generateMenuMT.py
-                       scripts/generateL1MenuMT.sh
-                       scripts/generateLVL1MenuMT.py
+atlas_install_scripts( scripts/generateLVL1MenuMT.py
                        scripts/generateL1TopoMenuMT.py
-                       scripts/test_HLTmenu.sh
                        scripts/generateL1MenuRun3.py
                        scripts/trigCompareOldandNewL1Menus.py
-                       scripts/trigL1MenuMigrationCheck.sh
                        scripts/verify_menu_config.py
                        scripts/test_full_menu_cf.py
-                       scripts/generateBunchGroupSetFromOldKey.py )
+                       scripts/generateBunchGroupSetFromOldKey.py
+                       POST_BUILD_CMD ${ATLAS_FLAKE8} )
+
+# Shell scripts without flake8 checking:
+atlas_install_scripts( scripts/generateL1MenuMT.sh
+                       scripts/trigL1MenuMigrationCheck.sh
+                       scripts/test_HLTmenu.sh )
+
+atlas_install_joboptions( share/*.py
+                          POST_BUILD_CMD ${ATLAS_FLAKE8} --extend-ignore=F821 )
 
-atlas_install_joboptions( share/*.py )
 atlas_install_xmls( data/*.dtd data/*.xml )
 
 #----------------------------------
@@ -122,31 +121,35 @@ file( MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_generateMenuMT_newJ
 atlas_add_test( generateMenuMT_newJO
                 SCRIPT python -m TriggerMenuMT.HLTMenuConfig.Menu.LS2_v1_newJO
                 PROPERTIES WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_generateMenuMT_newJO
-                PROPERTIES TIMEOUT 500 )
+                PROPERTIES TIMEOUT 500
+                POST_EXEC_SCRIPT nopost.sh )
 
 file( MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_ViewCFTest )
 atlas_add_test( ViewCFTest
-		        SCRIPT python -m unittest -v TriggerMenuMT.HLTMenuConfig.Test.ViewCFTest
+                SCRIPT python -m unittest -v TriggerMenuMT.HLTMenuConfig.Test.ViewCFTest
                 PROPERTIES WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_ViewCFTest
-		        POST_EXEC_SCRIPT nopost.sh )
+                POST_EXEC_SCRIPT nopost.sh )
 
 file( MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_generateMenuMT )
 atlas_add_test( generateMenuMT
-		        SCRIPT bash test_HLTmenu.sh
+                SCRIPT test_HLTmenu.sh
                 PROPERTIES WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_generateMenuMT
-                PROPERTIES TIMEOUT 4000 )
+                PROPERTIES TIMEOUT 4000
+                POST_EXEC_SCRIPT nopost.sh )
 
 file( MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_full_menu_cf )
 atlas_add_test( full_menu_cf
-		        SCRIPT scripts/test_full_menu_cf.sh
+                SCRIPT scripts/test_full_menu_cf.sh
                 PROPERTIES WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_full_menu_cf 
-                PROPERTIES TIMEOUT 500)
+                PROPERTIES TIMEOUT 500
+                POST_EXEC_SCRIPT nopost.sh )
                 
 file( MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_LS2_emu_menu_DH )
 atlas_add_test( LS2_emu_menu_DH
-		        SCRIPT test_emu_step_menu_processing.sh
+                SCRIPT test_emu_step_menu_processing.sh
                 PROPERTIES WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/unitTestRun_LS2_emu_menu_DH
-                PROPERTIES TIMEOUT 500)
+                PROPERTIES TIMEOUT 500
+                POST_EXEC_SCRIPT nopost.sh )
 
 #----------------------------------
 # List of menus to be created:
@@ -158,5 +161,3 @@ atlas_build_lvl1_trigger_menu( Cosmic_run3_v1 )
 atlas_build_lvl1_trigger_menu( PhysicsP1_HI_run3_v1 )
 atlas_build_lvl1_trigger_menu( Dev_HI_run3_v1 )
 atlas_build_lvl1_trigger_menu( LS2_v1_TriggerValidation_mc_prescale )
-
-
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Bjet/BjetTrackingConfiguration.py b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Bjet/BjetTrackingConfiguration.py
index a4fc83070d1f8282d56b3984493bc7ec06bf91d3..c9b8d8987cb0532e0ad81e4cb5c5fed5143c1b9a 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Bjet/BjetTrackingConfiguration.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Bjet/BjetTrackingConfiguration.py
@@ -33,11 +33,3 @@ def getSecondStageBjetTracking( inputRoI, dataObjects ):
     algSequence.append( seqAND("PrecisionTrackingSequence",PTAlgs) )
 
     return [ algSequence, PTTrackParticles ]
-
-
-
-
-
-
-
-
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Menu/LS2_v1.py b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Menu/LS2_v1.py
index 0bc89a0e8b8de18609b3b8de89a1215a7f1309fc..06d632fc3ec573f6346eec920d72aa78effff126 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Menu/LS2_v1.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Menu/LS2_v1.py
@@ -237,6 +237,9 @@ def setupMenu():
         ChainProp(name='HLT_j85_ftf_L1J20', groups=SingleJetGroup),
 
         ChainProp(name='HLT_j45_pf_ftf_L1J20', groups=SingleJetGroup),
+        ChainProp(name='HLT_j45_pf_ftf_010jvt_L1J20', groups=SingleJetGroup),
+        ChainProp(name='HLT_j45_pf_ftf_020jvt_L1J20', groups=SingleJetGroup),
+        ChainProp(name='HLT_j45_pf_ftf_050jvt_L1J20', groups=SingleJetGroup),
         ChainProp(name='HLT_j45_pf_ftf_preselj20_L1J20', groups=SingleJetGroup),
         ChainProp(name='HLT_j45_ftf_preselj20_L1J20', groups=SingleJetGroup),
         ChainProp(name='HLT_j45_subjesIS_ftf_preselj20_L1J20', groups=SingleJetGroup),
@@ -357,6 +360,18 @@ def setupMenu():
         ChainProp(name="HLT_tau160_medium1_tracktwoEF_L1TAU100",groups=SingleTauGroup),
         ChainProp(name="HLT_tau200_medium1_tracktwoEF_L1TAU100",groups=SingleTauGroup),
         ChainProp(name="HLT_tau200_mediumRNN_tracktwoMVA_L1TAU100",groups=SingleTauGroup),
+        #ATR-18804
+        ChainProp(name="HLT_tau25_idperf_tracktwoMVABDT_L1TAU12IM",groups=SingleTauGroup),
+        ChainProp(name="HLT_tau25_perf_tracktwoMVABDT_L1TAU12IM",groups=SingleTauGroup),
+        ChainProp(name="HLT_tau25_medium1_tracktwoMVABDT_L1TAU12IM",groups=SingleTauGroup),
+        ChainProp(name="HLT_tau25_verylooseRNN_tracktwoMVABDT_L1TAU12IM",groups=SingleTauGroup),
+        ChainProp(name="HLT_tau25_looseRNN_tracktwoMVABDT_L1TAU12IM",groups=SingleTauGroup),
+        ChainProp(name="HLT_tau25_mediumRNN_tracktwoMVABDT_L1TAU12IM",groups=SingleTauGroup),
+        ChainProp(name="HLT_tau25_tightRNN_tracktwoMVABDT_L1TAU12IM",groups=SingleTauGroup),
+        ChainProp(name="HLT_tau160_perf_tracktwoMVABDT_L1TAU100",groups=SingleTauGroup),
+        ChainProp(name="HLT_tau160_idperf_tracktwoMVABDT_L1TAU100",groups=SingleTauGroup),
+        ChainProp(name="HLT_tau160_mediumRNN_tracktwoMVABDT_L1TAU100",groups=SingleTauGroup),  
+
         # ATR-21797
         # the following 3 chains were in serial mode in Run-2
         ChainProp(name="HLT_tau80_mediumRNN_tracktwoMVA_tau60_mediumRNN_tracktwoMVA_L1TAU60_2TAU40",         l1SeedThresholds=['TAU60','TAU40'],     groups=MultiTauGroup),
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Menu/SignatureDicts.py b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Menu/SignatureDicts.py
index 298f0e9a5055f95aaf456cafbd58ce9ebd0b37f5..473d1ac38e655358e0d4295d7a65bdd986775432 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Menu/SignatureDicts.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Menu/SignatureDicts.py
@@ -97,33 +97,63 @@ TestChainParts_Default = {
 AllowedTopos_jet = []
 # ---- Jet Dictionary of all allowed Values ----
 JetChainParts = {
+    # Information common to all signatures
     'signature'     : ['Jet'],
     'alignmentGroup': ['Jet','JetMET'],
     'L1threshold'   : '',
     'chainPartName' : '',
     'threshold'     : '',
     'multiplicity'  : '',
-    'etaRange'      : ['0eta320', '320eta490', '0eta240', '0eta290'],
-    'jvt'           : ['011jvt', '015jvt', '059jvt'],
-    'momCuts'       : ['050momemfrac100','momhecfrac010','050momemfrac100SEPmomhecfrac010'],
-    # May need to reinstate in the event that preselection is
-    # needed before running tracking
-    #'gscThreshold' : ['gsc'],
     'trigType'     : ['j'],
+    'topo'          : AllowedTopos_jet,
     'extra'        : [],
-    'cleaning'     : ['noCleaning',],
-    'recoAlg'      : ['a4', 'a10', 'a10r', 'a10t', 'a10sd'],
-    'dataType'     : ['tc','pf','sktc','cssktc','csskpf'],
-    'calib'        : ['em', 'lcw'],
-    'jetCalib'     : ['jes', 'subjes', 'subjesIS', 'subjesgscIS', 'subresjesgscIS', 'nojcalib'],
-    'scan'         : ['FS',],
     'addInfo'      : ['perf'],
-
-    'TLA'          : [],
-    'dataScouting' : ['JetDS'],
-
-    'topo'         : AllowedTopos_jet,
-
+    'sigFolder'     : 'Jet',
+    'subSigs'       : ['Jet'],
+
+    # Information unique to the jet slice
+    # Reco information
+    'recoAlg'      : # Jet clustering algorithm
+      ['a4', 'a10', 'a10r', 'a10t', 'a10sd'],
+    'dataType'     : # Jet input type (rename?)
+      ['tc','pf','sktc','cssktc','csskpf'],
+    'calib'        : # Topocluster calibration (change to constit mods?)
+      ['em', 'lcw'],
+    'jetCalib'     : # Jet calibration
+      ['jes', 'subjes', 'subjesIS', 'subjesgscIS', 'subresjesgscIS', 'nojcalib'],
+    'scan'         : # No longer used?
+      ['FS',],
+    'trkopt'       : # Tracking configuration
+      ['notrk','ftf'],
+    'trkpresel'    : # Tracking preselection
+      ['nopresel','preselj20'],
+    # Hypo information
+    #   If hypoScenario is 'simple', then hypo configuration is handled based on the
+    #   other dict contents. If it is not 'simple', then the configuration is 100%
+    #   from the hypoScenario specification, and all other hypo entries are ignored.
+    'hypoScenario' : ['simple', # Independent selections on individual jets, multiplicity+threshold cuts
+                      'vbenf',  # Test VBF-like chain
+                      'vbenfSEP30etSEP34mass35SEP50fbet', # Test VBF-like chain with more info
+                      'dijetSEP80j1etSEP0j1eta240SEP80j2etSEP0j2eta240SEP700djmass', # Test dijet mass sel
+                      # 'agg' category is for single variable computed by aggregation over single jets
+                      'aggSEP1000htSEP30etSEP0eta320', # HT selection with explicit jet et/eta cuts
+                      'aggSEP500htSEP30etSEP0eta320',
+                      'aggSEP100htSEP10etSEP0eta320',],
+    # Simple hypo configuration. Single property cuts defined as MINvarMAX
+    'etaRange'      :
+      ['0eta320', '320eta490', '0eta240', '0eta290'],
+    'jvt'           : # Jet Vertex Tagger pileup discriminant
+      ['010jvt', '011jvt', '015jvt', '020jvt', '050jvt', '059jvt'],
+    'momCuts'       : # Generic moment cut on single jets
+      ['050momemfrac100','momhecfrac010','050momemfrac100SEPmomhecfrac010'],
+    'cleaning'      : # Jet cleaning per jet (currently unused)
+      ['noCleaning',],
+    'smc'           : # "Single mass condition" -- rename?
+      ['30smcINF', '35smcINF', '40smcINF', '50smcINF', '60smcINF', 'nosmc'],
+    # Setup for alternative data stream readout
+    'TLA'          : [],        # Unused
+    'dataScouting' : ['JetDS'], # Triggers TLA jet selection + recording
+    # B-tagging information
     'bTag'         : ['boffperf'  ,
                       'bmv2c2040' , 'bmv2c2050' , 'bmv2c2060' , 'bmv2c2070' , 'bmv2c2077' , 'bmv2c2085' ,
                       'bmv2c1040' , 'bmv2c1050' , 'bmv2c1060' , 'bmv2c1070' , 'bmv2c1077' , 'bmv2c1085' ,
@@ -132,17 +162,6 @@ JetChainParts = {
     'bTracking'    : [],
     'bConfig'      : ['split',],
     'bMatching'    : ['antimatchdr05mu'],
-    'trkopt'       : ['notrk','ftk','ftkrefit','ftf'],
-    'trkpresel'    : ['nopresel','preselj20'],
-    'hypoScenario' : ['simple', 'vbenf',
-                      'vbenfSEP30etSEP34mass35SEP50fbet',
-                      'dijetSEP80j1etSEP0j1eta240SEP80j2etSEP0j2eta240SEP700djmass',
-                      'aggSEP1000htSEP30etSEP0eta320',
-                      'aggSEP500htSEP30etSEP0eta320',
-                      'aggSEP100htSEP10etSEP0eta320',],
-    'smc'          : ['30smcINF', '35smcINF', '40smcINF', '50smcINF', '60smcINF', 'nosmc'],
-    'sigFolder'     : 'Jet',
-    'subSigs'       : ['Jet']
 }
 
 # ---- Jet Dictionary of default Values ----
@@ -152,31 +171,35 @@ JetChainParts_Default = {
     'L1threshold'   : '',
     'threshold'     : '',
     'multiplicity'  : '',
-    'etaRange'      : '0eta320',
-    'jvt'           : '',
-    'momCuts'       : '',
     'trigType'      :'j',
+    'topo'          : [],
     'extra'         : '',
-    'cleaning'      : 'noCleaning',
+    'addInfo'       : [],
+    'sigFolder'     : 'Jet',
+    'subSigs'       : ['Jet'],
+    #
     'recoAlg'       :'a4',
     'dataType'      :'tc',
     'calib'         :'em',
     'jetCalib'      :'default',
     'scan'          :'FS',
-    'addInfo'       : [],
+    'trkopt'        : 'notrk',
+    'trkpresel'     : 'nopresel',
+    #
+    'etaRange'      : '0eta320',
+    'jvt'           : '',
+    'momCuts'       : '',
+    'cleaning'      : 'noCleaning',
+    'hypoScenario'  : 'simple',
+    'smc'           : 'nosmc',
+    #
     'TLA'           : '',
-    'topo'          : [],
+    'dataScouting'  : '',
+    #
     'bTag'          : '',
     'bTracking'     : '',
     'bConfig'       : [],
     'bMatching'     : [],
-    'dataScouting'  : '',
-    'trkopt'        : 'notrk',
-    'trkpresel'     : 'nopresel',
-    'hypoScenario'  : 'simple',
-    'smc'           : 'nosmc',
-    'sigFolder'     : 'Jet',
-    'subSigs'       : ['Jet']
 }
 
 # ---- bJet Dictionary of default Values that are different to the ones for normal jet chains ----
@@ -261,7 +284,7 @@ TauChainParts = {
     'L1threshold'   : '',
     'chainPartName' : '',
     'threshold'     : '',
-    'preselection'  : ['track', 'tracktwo', 'tracktwoEF', 'tracktwoMVA', 'tracktwoEFmvaTES', 'ptonly', ],
+    'preselection'  : ['track', 'tracktwo', 'tracktwoEF', 'tracktwoMVA', 'tracktwoMVABDT' , 'tracktwoEFmvaTES', 'ptonly', ],
     'selection'     : ['medium1', 'verylooseRNN', 'looseRNN', 'mediumRNN', 'tightRNN', 'perf', 'idperf'],
     'multiplicity'  : '',
     'trigType'      : ['tau'],
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauChainConfiguration.py b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauChainConfiguration.py
index 7091e3fe471461c9eb8f0e09b8bbb32fcb594660..3f2d0d2230ca73d3115bd4e80bf07f1456b71d7e 100755
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauChainConfiguration.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauChainConfiguration.py
@@ -11,7 +11,7 @@ log = logging.getLogger("TriggerMenuMT.HLTMenuConfig.Tau.TauChainConfiguration")
 
 from TriggerMenuMT.HLTMenuConfig.Menu.ChainConfigurationBase import ChainConfigurationBase
 
-from TriggerMenuMT.HLTMenuConfig.Tau.TauMenuSequences import tauCaloMenuSeq, tauCaloMVAMenuSeq, tauFTFTauSeq, tauFTFTauCoreSeq, tauFTFTauIsoSeq, tauIDPrecSeq, tauTrackPrecSeq, tauTrackTwoPrecSeq, tauTrackTwoEFSeq, tauTrackTwoMVASeq, tauPreSelSeq, tauPreSelTTSeq, tauPrecTrackSeq, tauPrecTrackIsoSeq
+from TriggerMenuMT.HLTMenuConfig.Tau.TauMenuSequences import tauCaloMenuSeq, tauCaloMVAMenuSeq, tauFTFTauSeq, tauFTFTauCoreSeq, tauFTFTauIsoSeq, tauFTFTauIsoBDTSeq, tauIDPrecSeq, tauTrackPrecSeq, tauTrackTwoPrecSeq, tauTrackTwoEFSeq, tauTrackTwoMVASeq, tauPreSelSeq, tauPreSelTTSeq, tauPrecTrackSeq, tauPrecTrackIsoSeq
 
 #--------------------------------------------------------
 # fragments generating config will be functions in new JO
@@ -31,6 +31,9 @@ def getFTFCoreCfg(flags):
 def getFTFIsoCfg(flags):
     return tauFTFTauIsoSeq()
 
+def getFTFIsoBDTCfg(flags):
+    return tauFTFTauIsoBDTSeq()
+
 def getIDPrecCfg(flags):
     return tauIDPrecSeq()
 
@@ -78,11 +81,12 @@ class TauChainConfiguration(ChainConfigurationBase):
         # define here the names of the steps and obtain the chainStep configuration 
         # --------------------
         stepDictionary = {
-            "ptonly"     :['getCaloSeq'   , 'getFTFTau'  , 'getTrkEmpty' , 'getTauEmpty'  , 'getPrecTrack'    , 'getIDPrec'      ], 
-            "track"      :['getCaloSeq'   , 'getFTFTau'  , 'getTrkEmpty' , 'getPreSel'    , 'getPrecTrack'    , 'getTrackPrec'   ], 
-            "tracktwo"   :['getCaloSeq'   , 'getFTFCore' , 'getFTFIso'   , 'getPreSelTT'  , 'getPrecTrackIso' , 'getTrackTwoPrec'],
-            "tracktwoEF" :['getCaloSeq'   , 'getFTFCore' , 'getFTFIso'   , 'getTauEmpty'  , 'getPrecTrackIso' , 'getTrackTwoEF'  ],
-            "tracktwoMVA":['getCaloMVASeq', 'getFTFCore' , 'getFTFIso'   , 'getTauEmpty'  , 'getPrecTrackIso' , 'getTrackTwoMVA' ],
+            "ptonly"        :['getCaloSeq'   , 'getFTFTau'  , 'getTrkEmpty' , 'getTauEmpty'  , 'getPrecTrack'    , 'getIDPrec'      ], 
+            "track"         :['getCaloSeq'   , 'getFTFTau'  , 'getTrkEmpty' , 'getPreSel'    , 'getPrecTrack'    , 'getTrackPrec'   ], 
+            "tracktwo"      :['getCaloSeq'   , 'getFTFCore' , 'getFTFIso'   , 'getPreSelTT'  , 'getPrecTrackIso' , 'getTrackTwoPrec'],
+            "tracktwoEF"    :['getCaloSeq'   , 'getFTFCore' , 'getFTFIso'   , 'getTauEmpty'  , 'getPrecTrackIso' , 'getTrackTwoEF'  ],
+            "tracktwoMVA"   :['getCaloMVASeq', 'getFTFCore' , 'getFTFIso'   , 'getTauEmpty'  , 'getPrecTrackIso' , 'getTrackTwoMVA' ],
+            "tracktwoMVABDT":['getCaloMVASeq', 'getFTFCore' , 'getFTFIsoBDT', 'getTauEmpty'  , 'getPrecTrackIso' , 'getTrackTwoMVA' ],
         }
 
         # this should be extended by the signature expert to make full use of the dictionary!
@@ -121,6 +125,11 @@ class TauChainConfiguration(ChainConfigurationBase):
         stepName = 'FTFIso_tau'
         return self.getStep(3,stepName, [getFTFIsoCfg])
 
+    # --------------------                                                                                                                                                                         
+    def getFTFIsoBDT(self):
+        stepName = 'FTFIsoBDT_tau'
+        return self.getStep(3,stepName, [getFTFIsoBDTCfg])
+
     # --------------------                                                                                                                                   
     def getTrkEmpty(self):
         stepName = 'TrkEmpty_tau'
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauMenuSequences.py b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauMenuSequences.py
index a9034d9331acf7cd12d9a0a0ac7c79339d616dfa..c53fce12f2418359f0965696dfff15d1ba9541be 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauMenuSequences.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauMenuSequences.py
@@ -7,7 +7,7 @@ from AthenaConfiguration.AllConfigFlags import ConfigFlags
 # menu components   
 from TriggerMenuMT.HLTMenuConfig.Menu.MenuComponents import MenuSequence, RecoFragmentsPool
 
-from TriggerMenuMT.HLTMenuConfig.Tau.TauRecoSequences import tauCaloSequence, tauCaloMVASequence, tauFTFCoreSequence, tauFTFTauSequence, tauFTFIsoSequence, tauIDSequence, tauTrackSequence, tauTrackTwoSequence, tauEFSequence, tauMVASequence, tauPreSelSequence, tauPreSelTTSequence, tauPrecTrackSequence, tauPrecIsoTrackSequence
+from TriggerMenuMT.HLTMenuConfig.Tau.TauRecoSequences import tauCaloSequence, tauCaloMVASequence, tauFTFCoreSequence, tauFTFTauSequence, tauFTFIsoSequence, tauFTFIsoBDTSequence, tauIDSequence, tauTrackSequence, tauTrackTwoSequence, tauEFSequence, tauMVASequence, tauPreSelSequence, tauPreSelTTSequence, tauPrecTrackSequence, tauPrecIsoTrackSequence
 
 # ====================================================================================================  
 #    Get MenuSequences
@@ -120,6 +120,25 @@ def tauFTFTauIsoSeq():
                           Hypo        = fastTrkHypo,
                           HypoToolGen = TrigTauTrackHypoToolFromDict )
 
+# ===============================================================================================                                                                                                  
+#   Fast track finder (iso bdt) + Dummy Hypo step (tracktwoMVABDT)                                                                                                                                 
+# ===============================================================================================                                                                                                  
+
+def tauFTFTauIsoBDTSeq():
+    (sequence, ftfIsoBDTViewsMaker, sequenceOut) = RecoFragmentsPool.retrieve(tauFTFIsoBDTSequence,ConfigFlags )
+
+    from TrigTauHypo.TrigTauHypoConf import  TrigTrackPreSelHypoAlgMT
+    fastTrkHypo                 = TrigTrackPreSelHypoAlgMT("TrackPreSelHypoAlg_PassByIsoBDT")
+    fastTrkHypo.trackcollection = sequenceOut
+    fastTrkHypo.RoIForIDReadHandleKey = "UpdatedTrackBDTRoI"
+
+    from TrigTauHypo.TrigTauHypoTool import TrigTauTrackHypoToolFromDict
+
+    return  MenuSequence( Sequence    = sequence,
+                          Maker       = ftfIsoBDTViewsMaker,
+                          Hypo        = fastTrkHypo,
+                          HypoToolGen = TrigTauTrackHypoToolFromDict )
+
 
 # ===============================================================================================
 #     Precision tracking + Tau Precision Alg + EFMVHypo step   (pTonly)
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauRecoSequences.py b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauRecoSequences.py
index 8593e99dc6892021fc3225ddfa3238caece0dc3b..f69fbc8370abff462a298f9f036ddfeec8f3d644 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauRecoSequences.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/HLTMenuConfig/Tau/TauRecoSequences.py
@@ -23,9 +23,12 @@ def _getTauSignatureShort( name ):
     elif "FTFCore" in name:
       signature = 'tauCore'
       signatureID = 'tauCore'
-    elif "FTFIso" in name:
+    elif "IsoInView" in name:
       signature = 'tauIso'
       signatureID = 'tauIso'
+    elif "IsoBDT" in name:
+      signature = 'tauIsoBDT'
+      signatureID = 'tauIsoBDT'
     elif "TrackInView" in name:
       signature = 'tauTrk'
       signatureID = 'tauTau'
@@ -89,6 +92,17 @@ def _algoTauTrackRoiUpdater(inputRoIs, tracks):
     algo.RoIInputKey                   = inputRoIs
     algo.RoIOutputKey                  = "UpdatedTrackRoI"
     algo.fastTracksKey                 = tracks
+    algo.Key_trigTauJetInputContainer  = ""
+    return algo
+
+def _algoTauTrackBDTRoiUpdater(inputRoIs, tracks):
+    from TrigTauHypo.TrigTauHypoConf import TrigTauTrackRoiUpdaterMT
+    algo                               = TrigTauTrackRoiUpdaterMT("TrackRoiUpdaterBDT")
+    algo.RoIInputKey                   = inputRoIs
+    algo.RoIOutputKey                  = "UpdatedTrackBDTRoI"
+    algo.fastTracksKey                 = tracks
+    algo.useBDT                        = True
+    algo.Key_trigTauJetInputContainer  = "HLT_TrigTauRecMerged_CaloOnly"
     return algo
 
 def _algoTauPreselection(inputRoIs, tracks, step):
@@ -357,6 +371,8 @@ def tauFTFSequence( RoIs, name ):
 
     if 'Core' in signatureName:
       tauTrackRoiUpdaterAlg = _algoTauTrackRoiUpdater(inputRoIs = RoIs, tracks = TrackCollection)
+      tauTrackRoiUpdaterAlgBDT = _algoTauTrackBDTRoiUpdater(inputRoIs = RoIs, tracks = TrackCollection)
+      viewAlgs.append(tauTrackRoiUpdaterAlgBDT)
       viewAlgs.append(tauTrackRoiUpdaterAlg)
 
     tauFTFSequence += viewAlgs
@@ -444,6 +460,32 @@ def tauFTFIsoSequence(ConfigFlags):
     tauFastTrackIsoSequence = seqAND("tauFastTrackIsoSequence", [ftfIsoViewsMaker, tauFTFIsoInViewSequence ])
     return (tauFastTrackIsoSequence, ftfIsoViewsMaker, sequenceOut)
 
+# ===============================================================================================                                                                                                  
+#   Reco sequence for FTFTauIsoBDT (tracktwoMVABDT)                                                                                                                                                
+# ===============================================================================================                                                                                                  
+
+def tauFTFIsoBDTSequence(ConfigFlags):
+
+    RecoSequenceName                   = "tauFTFIsoBDTInViewSequence"
+
+    newRoITool                         = ViewCreatorFetchFromViewROITool()
+    newRoITool.RoisWriteHandleKey      = recordable("HLT_Roi_TauIsoBDT") #RoI collection recorded to EDM                                                                                           
+    newRoITool.InViewRoIs              = "UpdatedTrackBDTRoI" #input RoIs from calo only step                                                                                                      
+
+    ftfIsoViewsMaker                   = EventViewCreatorAlgorithm("IMFTFIsoBDT")
+    ftfIsoViewsMaker.RoIsLink          = "roi"
+    ftfIsoViewsMaker.RoITool           = newRoITool
+    ftfIsoViewsMaker.InViewRoIs        = "RoiForTauIsoBDT"
+    ftfIsoViewsMaker.Views             = "TAUFTFIsoBDTViews"
+    ftfIsoViewsMaker.ViewFallThrough   = True
+    ftfIsoViewsMaker.RequireParentView = True
+    ftfIsoViewsMaker.ViewNodeName      = RecoSequenceName
+
+    (tauFTFIsoBDTInViewSequence, sequenceOut) = tauFTFSequence( ftfIsoViewsMaker.InViewRoIs, RecoSequenceName)
+
+    tauFastTrackIsoBDTSequence = seqAND("tauFastTrackIsoBDTSequence", [ftfIsoViewsMaker, tauFTFIsoBDTInViewSequence ])
+    return (tauFastTrackIsoBDTSequence, ftfIsoViewsMaker, sequenceOut)
+
 
 # ===============================================================================================                                                            
 #   Reco sequence for PreSelection algorithm (track)                                                                                
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/L1/Config/ItemDef.py b/Trigger/TriggerCommon/TriggerMenuMT/python/L1/Config/ItemDef.py
index 8cb186e920ff2b57a94352b2f0d4afa7c1f5e211..404df6fa2ad0396890bc0aa7c69d70b9a58ab620 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/L1/Config/ItemDef.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/L1/Config/ItemDef.py
@@ -1654,12 +1654,8 @@ class ItemDef:
             MenuItem('L1_LFV-MU6').setLogic( d.TOPO_0DR15_2MU6ab & d.MU6.x(2) & physcond)
             MenuItem('L1_LFV-MU').setLogic( d.R2TOPO_0DR10_MU10ab_MU6ab & d.MU10 & d.MU6.x(2) & physcond)
 
-            if isV8 or isHIV5 or isPhaseII:
-                MenuItem('L1_LFV-EM8I').setLogic( d.TOPO_0DETA04_EM8abi_MU10ab & d.TOPO_0DPHI03_EM8abi_MU10ab & d.MU10 & physcond) #ATR-14282
-                MenuItem('L1_LFV-EM15I').setLogic( d.TOPO_0DETA04_EM15abi_MUab & d.TOPO_0DPHI03_EM15abi_MUab & physcond) #ATR-14282
-            else:
-                MenuItem('L1_LFV-EM8I').setLogic( d.TOPO_0DETA04_0DPHI03_EM8abi_MU10ab & physcond)
-                MenuItem('L1_LFV-EM15I').setLogic( d.TOPO_0DETA04_0DPHI03_EM15abi_MUab & physcond)
+            MenuItem('L1_LFV-EM8I').setLogic( d.TOPO_0DETA04_EM8abi_MU10ab & d.TOPO_0DPHI03_EM8abi_MU10ab & d.MU10 & physcond) #ATR-14282
+            MenuItem('L1_LFV-EM15I').setLogic( d.TOPO_0DETA04_EM15abi_MUab & d.TOPO_0DPHI03_EM15abi_MUab & physcond) #ATR-14282
                 
             MenuItem('L1_DPHI-J20s2XE50').setLogic( d.TOPO_10MINDPHI_J20s2_XE50 & physcond)
             MenuItem('L1_DPHI-J20XE50').setLogic( d.R2TOPO_10MINDPHI_J20ab_XE50 & physcond)
@@ -1708,10 +1704,7 @@ class ItemDef:
             MenuItem('L1_DR-TAU20ITAU12I').setLogic( d.TOPO_0DR28_TAU20abi_TAU12abi & physcond)
             MenuItem('L1_BOX-TAU20ITAU12I').setLogic( d.R2TOPO_0DETA20_0DPHI20_TAU20abi_TAU12abi & physcond)
 
-            if isV8:
-                MenuItem('L1_DR-TAU20ITAU12I-J25').setLogic( d.TOPO_2DISAMB_J25ab_0DR28_TAU20abi_TAU12abi & physcond)
-            else:
-                MenuItem('L1_DR-TAU20ITAU12I-J25').setLogic( d.TOPO_1DISAMB_J25ab_0DR28_TAU20abi_TAU12abi & physcond)
+            MenuItem('L1_DR-TAU20ITAU12I-J25').setLogic( d.TOPO_2DISAMB_J25ab_0DR28_TAU20abi_TAU12abi & physcond)
 
             MenuItem('L1_DR25-TAU20ITAU12I-J25').setLogic( d.R2TOPO_1DISAMB_J25ab_0DR25_TAU20abi_TAU12abi & physcond)
             MenuItem('L1_LAR-EM').setLogic( d.R2TOPO_LAR_EM20shi1 & physcond).setTriggerType( TT.lardemo ) # LAr demo (ATR-11897)
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/L1/Menu/MenuMapping.py b/Trigger/TriggerCommon/TriggerMenuMT/python/L1/Menu/MenuMapping.py
index a2a7168ed4754013eca87245e159e6a5aa7e8e88..0b641377b92cc9a4f4009f5775bf6cb4da8df81c 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/L1/Menu/MenuMapping.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/L1/Menu/MenuMapping.py
@@ -8,6 +8,7 @@ The resolved name is also being used in the L1/Config/ItemDef.py and L1/Config/T
 """
 
 menuMap = {
+    "Physics_pp_v7" : "MC_pp_v8",
     "LS2_v1" : "MC_pp_v8",
     "Physics_pp_run3_v1" : "MC_pp_v8",
     "MC_pp_run3_v1" : "MC_pp_v8",
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1/Lvl1Flags.py b/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1/Lvl1Flags.py
index bfb8232e804d70a9ec2f41070c5e623977fd737c..adaed177fdf36b557536f774c06ad467febb914f 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1/Lvl1Flags.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1/Lvl1Flags.py
@@ -1,4 +1,4 @@
-# Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 """
 Lvl1 specific flags
@@ -11,7 +11,7 @@ from .Limits import Limits
 __author__  = 'J.Stelzer'
 __doc__="Level 1 specific flags for Run 2"
 
-log = logging.getLogger('TriggerMenu.L1Flags.py')
+log = logging.getLogger('LVL1.Lvl1Flags.py')
 
 _flags = [] 
 class CTPVersion(JobProperty):
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1/TriggerTypeDefRun1.py b/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1/TriggerTypeDefRun1.py
new file mode 100644
index 0000000000000000000000000000000000000000..ef07604c0ab2e19a3d669b4306db6e355cb85360
--- /dev/null
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1/TriggerTypeDefRun1.py
@@ -0,0 +1,41 @@
+# Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration
+
+
+from TriggerJobOpts.TriggerFlags import TriggerFlags as TF
+
+class TT:
+    """
+    Trigger type logic
+    should also match StreamingDef.py definitions
+    """
+    rand        = 1 << 0
+    zerobs      = 1 << 1  # trigger type for zero bias triggers
+    calo        = 1 << 2        
+    rpcin = tgc = 1 << 3  # Assign TGC to RPCIN to free one bit for new and CALOEM trigger type
+    caloem      = 1 << 4  # to stream separately
+    minb        = 1 << 5
+    rpcout      = 1 << 6
+    phys        = 1 << 7
+
+    # Calibration requests
+    #  From David B - for calibration events TriggerType
+    #  will be reset by CTP - values below are placeholders
+    calreq0 = 0x30
+    calreq1 = 0x32
+    calreq2 = 0x34
+
+    if any([ x in TF.triggerMenuSetup() for x in
+             [ 'InitialBeam_HI',
+               'Cosmic_v3',
+               'L1_pp',
+               'L1_alfa',
+               'MC_pp',
+               'MC_HI',
+               'MC_loose',
+               'MC_tight',
+               'Physics_pp',
+               'Physics_default',
+               'Physics_HI',
+               ]]):
+        caloem = 0
+
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1Menu/ItemDefRun1.py b/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1Menu/ItemDefRun1.py
deleted file mode 100755
index da34993660e8ff35c1ec737d753414fe06f34263..0000000000000000000000000000000000000000
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1Menu/ItemDefRun1.py
+++ /dev/null
@@ -1,870 +0,0 @@
-# Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
-#
-# Disable flake8 checking due to the use of 'exec':
-# flake8: noqa
-#
-from TriggerJobOpts.TriggerFlags import TriggerFlags
-
-# The trigger types
-from TriggerMenu.l1.TriggerTypeDefRun1 import TT
-from TriggerMenu.l1.Limits import Limits
-from TriggerMenu.l1.Logic import Not
-from TriggerMenu.l1.Lvl1MenuItems import LVL1MenuItem
-
-from AthenaCommon.Logging import logging
-log = logging.getLogger('TriggerMenu.Lvl1.py')
-
-
-class ItemDef(object):
-    def __init__(self):
-        """Constructor"""
-        pass
-    
-    #----------------------------------------------------------------------
-    # LVL1- thresholds and items
-    #----------------------------------------------------------------------
-    @staticmethod
-    def registerItems(tm):
-        """Register LVL1 thresholds for further use"""
-
-        # register all thresholds ...
-        from ThresholdDefRun1 import ThresholdDef
-        ThresholdDef.registerThresholds(tm)
-
-        # ... and make them accessible by their name
-        for thr in tm.registeredThresholds.values():
-            thrvarname = thr.name.replace('.','') # we can not have . in the variable name
-            exec("%s = ThrCondition(thr)" % thrvarname)
-
-        # InternalTriggers
-        for i in range( Limits.NumBunchgroups ):
-            exec("BGRP%i = Logic(Lvl1InternalTrigger('BGRP%i'))" % (i,i))
-
-        for i in range( Limits.NumRndmTriggers ):
-            exec("RNDM%i = Logic(Lvl1InternalTrigger('RNDM%i'))" % (i,i))
-
-        for i in range(2):
-            exec("PCLK%i = Logic(Lvl1InternalTrigger('PCLK%i'))" % (i,i))
-
-
-        LVL1MenuItem.l1configForRegistration = tm  # from now on all new LVL1MenuItems are registered to tm
-
-        # Setting up bunch group and BPTX conditions
-        bgrpcond            = BGRP0 & BGRP1
-        physcond            = BGRP0 & BGRP1
-        calibcond           = BGRP0 & BGRP2
-        cosmiccond          = BGRP0 & BGRP3
-        unpaired_isocond    = BGRP0 & BGRP4 # unpaired isolated (satellite bunches)
-        unpaired_nonisocond = BGRP0 & BGRP5 # unpaired non-isolated (parasitic bunches)
-        firstempty          = BGRP0 & BGRP6
-        unpairedRcond       = BGRP0 & BGRP7 # unpaired beams 1 oR beam 2
-        bgrp7cond           = BGRP0 & BGRP7 # No unpaired anymore
-
-
-        LVL1MenuItem.currentPartition = 1
-
-        # /gamma ctpid=[0:0x1f]
-
-        emTT = TT.calo | TT.caloem
-        
-        LVL1MenuItem('L1_EM3',    ctpid=0x1 ).setLogic( EM3.x(1)    & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM4',    ctpid=0x54).setLogic( EM4.x(1)    & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM5',    ctpid=-1  ).setLogic( EM5.x(1)    & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM6',    ctpid=-1  ).setLogic( EM6.x(1)    & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM7',    ctpid=0x1 ).setLogic( EM7.x(1)    & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM7V',   ctpid=-1  ).setLogic( EM7V.x(1)   & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM8VH',  ctpid=-1  ).setLogic( EM8VH.x(1)  & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM10',   ctpid=0x2 ).setLogic( EM10.x(1)   & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM10VH', ctpid=-1  ).setLogic( EM10VH.x(1) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM12',   ctpid=0x2 ).setLogic( EM12.x(1)   & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM14',   ctpid=0x5 ).setLogic( EM14.x(1)   & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM14VH', ctpid=-1  ).setLogic( EM14VH.x(1) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM15V',  ctpid=-1  ).setLogic( EM15V.x(1)  & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM15VH', ctpid=-1  ).setLogic( EM15VH.x(1) & physcond).setTriggerType( emTT ) 
-        LVL1MenuItem('L1_EM16',   ctpid=0x5 ).setLogic( EM16.x(1)   & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM16VH', ctpid=-1  ).setLogic( EM16VH.x(1) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM16V',  ctpid=-1  ).setLogic( EM16V.x(1)  & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM18VH', ctpid=-1  ).setLogic( EM18VH.x(1) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM20V',  ctpid=-1  ).setLogic( EM20V.x(1)  & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM24VHI', ctpid=-1  ).setLogic( EM24VHI.x(1) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM30',   ctpid=0x8 ).setLogic( EM30.x(1)   & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM50',   ctpid=0x8 ).setLogic( EM50.x(1)   & physcond).setTriggerType( emTT )
-
-
-        # special bgrp
-        LVL1MenuItem('L1_EM30_BGRP7',  ctpid=-1).setLogic( EM30.x(1) & bgrp7cond ).setTriggerType( emTT )
-        
-        # 2xEM
-        LVL1MenuItem('L1_2EM3',    ctpid=0xa ).setLogic( EM3.x(2)    & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM5',    ctpid=0xb ).setLogic( EM5.x(2)    & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM6',    ctpid=-1  ).setLogic( EM6.x(2)    & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM8VH',  ctpid=-1  ).setLogic( EM8VH.x(2)  & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM10VH', ctpid=-1  ).setLogic( EM10VH.x(2) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM12',   ctpid=0xf ).setLogic( EM12.x(2)   & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM15V',  ctpid=-1 ).setLogic( EM15V.x(2)  & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM15VH', ctpid=0xf ).setLogic( EM15VH.x(2) & physcond).setTriggerType( emTT )
-
-
-
-        # 3xEM
-        LVL1MenuItem('L1_2EM3_EM6'   ).setLogic( EM3.x(2)& EM6.x(1) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM7V_2EM3'   ).setLogic(EM7V.x(1)& EM3.x(2) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM3_EM12'  ).setLogic( EM3.x(2)& EM12.x(1) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM6_EM16VH').setLogic( EM6.x(2)& EM16VH.x(1) & physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_3EM6',  ctpid=-1  ).setLogic( EM6.x(3)  & physcond).setTriggerType(TT.phys).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM15VH_3EM7V'  ).setLogic( EM15VH.x(1) & EM7V.x(3) & physcond).setTriggerType( emTT )
-
-        # 4xEM
-        LVL1MenuItem('L1_3EM6_EM14VH').setLogic( EM6.x(3) & EM14VH.x(1)& physcond).setTriggerType( emTT )
-        LVL1MenuItem('L1_2EM12_EM16V').setLogic( EM12.x(2)& EM16V.x(1) & physcond).setTriggerType( emTT )
-
-        
-        # MUON ctpid=[0x20;0x2f]
-
-        LVL1MenuItem('L1_MU0',  ctpid=0x20).setLogic( MU0.x(1)  & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU4',  ctpid=-1  ).setLogic( MU4.x(1)  & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU6',  ctpid=0x21).setLogic( MU6.x(1)  & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU10', ctpid=0x22).setLogic( MU10.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU11', ctpid=0x23).setLogic( MU11.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU15', ctpid=-1  ).setLogic( MU15.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU20', ctpid=0x24).setLogic( MU20.x(1) & physcond).setTriggerType(TT.rpcin)
-
-        # 2xMU, 3xMU, 4xMU
-        LVL1MenuItem('L1_2MU0',  ctpid=0x26).setLogic( MU0.x(2)  & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU4',  ctpid=-1  ).setLogic( MU4.x(2)  & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU6',  ctpid=0x27).setLogic( MU6.x(2)  & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU10', ctpid=0x28).setLogic( MU10.x(2) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU11', ctpid=0x28).setLogic( MU11.x(2) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU20', ctpid=0x2a).setLogic( MU20.x(2) & physcond)
-        LVL1MenuItem('L1_3MU4',  ctpid=-1  ).setLogic( MU4.x(3)  & physcond)
-        LVL1MenuItem('L1_3MU6',  ctpid=0x2b).setLogic( MU6.x(3)  & physcond)
-        LVL1MenuItem('L1_2MU4_MU6'         ).setLogic( MU4.x(2) & MU6.x(1)  & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU6_MU10'        ).setLogic( MU6.x(2) & MU10.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_3MU4_MU6'         ).setLogic( MU4.x(3) & MU6.x(1)  & physcond).setTriggerType(TT.rpcin)
-
-        LVL1MenuItem('L1_2MU4_XE40', ctpid=-1  ).setLogic( MU4.x(2) &  XE40.x(1)  & physcond).setTriggerType(TT.calo|TT.rpcin)
-        LVL1MenuItem('L1_2MU4_XE30', ctpid=-1  ).setLogic( MU4.x(2) &  XE30.x(1) & physcond).setTriggerType(TT.calo|TT.rpcin)
-
-        # barrel 
-        LVL1MenuItem('L1_MUB'            ).setLogic( NIM_MUB.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MUE'            ).setLogic( NIM_MUE.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU4_BARRELONLY').setLogic( ( MU4.x(2) & Not(NIM_MUE.x(1)) |  MU4.x(3)) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU4_MU6_BARREL').setLogic( MU4.x(2) & NIM_MUB.x(1) & MU6.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU4_BARREL'    ).setLogic( MU4.x(2) & NIM_MUB.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU6_BARRELONLY').setLogic( (MU6.x(2)&Not(NIM_MUE.x(1))| MU6.x(3)) & physcond).setTriggerType(TT.rpcin)        
-        LVL1MenuItem('L1_2MU6_BARREL'    ).setLogic( MU6.x(2) & NIM_MUB.x(1) & physcond).setTriggerType(TT.rpcin)
-        
-
-
-        # TAU ctpid=[0x40:0x4f]
-
-        # 1xTAU
-        LVL1MenuItem('L1_TAU3',   ctpid=0x40).setLogic( HA3.x(1)   & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU6',   ctpid=-1  ).setLogic( HA6.x(1)   & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU8',   ctpid=0x43).setLogic( HA8.x(1)   & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU11',  ctpid=0x44).setLogic( HA11.x(1)  & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU11I', ctpid=0x44).setLogic( HA11I.x(1) & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU12',  ctpid=-1  ).setLogic( HA12.x(1)  & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU15',  ctpid=-1  ).setLogic( HA15.x(1)  & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU15I'            ).setLogic( HA15I.x(1) & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU20',  ctpid=0x46).setLogic( HA20.x(1)  & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU40',  ctpid=0x49).setLogic( HA40.x(1)  & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU60',  ctpid=-1  ).setLogic( HA60.x(1)  & physcond).setTriggerType( TT.calo )
-
-        # 2xTAU
-        LVL1MenuItem('L1_2TAU11', ctpid=0x4c ).setLogic( HA11.x(2)  & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_2TAU11I'            ).setLogic( HA11I.x(2) & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_2TAU15'             ).setLogic( HA15.x(2)  & physcond).setTriggerType( TT.calo )
-
-        # mixed tau
-        LVL1MenuItem('L1_EM15VH_TAU40_2TAU15'          ).setLogic( EM15VH  & HA40 & HA15.x(2)   & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_EM15VH_2TAU12_J25_2J15_3J12'  ).setLogic( EM15VH  & HA12.x(2)  & J25 & J15.x(2) & J12.x(3) & physcond).setTriggerType( TT.calo )
-
-        LVL1MenuItem('L1_MU10_TAU20'       ).setLogic( MU10  & HA20          & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_MU10_TAU12_J25_2J12' ).setLogic( MU10 & HA12 & J25 & J12.x(2) & physcond).setTriggerType( TT.calo )
-
-        LVL1MenuItem('L1_TAU20_2TAU12_J25_2J20_3J12'   ).setLogic( HA20 & HA12.x(2)     & J25 & J20.x(2) & J12.x(3) & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU20_2J20_XE45'              ).setLogic( HA20    & J20.x(2)   & XE45 & physcond).setTriggerType( TT.calo )
-        LVL1MenuItem('L1_TAU20_2TAU12_XE35'            ).setLogic( HA20    & HA12.x(2)  & XE35 & physcond).setTriggerType( TT.calo )
-
-        # EMPTY
-        LVL1MenuItem('L1_2TAU20'    ).setLogic( HA20.x(2) & physcond).setTriggerType(TT.calo)
-
-
-        # JET ctpid=[0x60:0x7f]
-
-        LVL1MenuItem('L1_J5',      ctpid=0x60).setLogic( J5.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J5_win6', ctpid=0x60).setLogic( J5_win6.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J10',     ctpid=0x61).setLogic( J10.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J15'                ).setLogic( J15.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J18',     ctpid=0x62).setLogic( J18.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J20',     ctpid=-1  ).setLogic( J20.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J30'                ).setLogic( J30.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J40'                ).setLogic( J40.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J50'                ).setLogic( J50.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J75'                ).setLogic( J75.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J100',    ctpid=-1  ).setLogic( J100.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J350',    ctpid=-1  ).setLogic( J350.x(1) & physcond).setTriggerType(TT.calo)
-
-        LVL1MenuItem('L1_J15.ETA24', ctpid=-1).setLogic(J15ETA24.x(1) & physcond).setTriggerType(TT.calo)
-
-        LVL1MenuItem('L1_J15.23ETA49' ).setLogic( (JF1523ETA49  | JB1523ETA49  ) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J20.32ETA49' ).setLogic( (JF2032ETA49  | JB2032ETA49  ) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J25.32ETA49' ).setLogic( (JF2532ETA49  | JB2532ETA49  ) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J100.32ETA49').setLogic( (JF10032ETA49 | JB10032ETA49 ) & physcond).setTriggerType(TT.calo)
-
-        # pPb
-        LVL1MenuItem('L1_J5_TE90',  ctpid=0x60).setLogic( J5.x(1)& TE90.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_2J5_TE90', ctpid=0x60).setLogic( J5.x(2)& TE90.x(1) & physcond).setTriggerType(TT.calo)
-
-        # Multi-jet
-        LVL1MenuItem('L1_2J5', ctpid=0x68 ).setLogic( J5.x(2)  & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_2J10'            ).setLogic( J10.x(2) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_3J10', ctpid=0x7f).setLogic( J10.x(3) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_3J15'            ).setLogic( J15.x(3) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_3J50', ctpid=0x7f).setLogic( J50.x(3) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_3J75', ctpid=-1  ).setLogic( J75.x(3) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_3J20', ctpid=-1  ).setLogic( J20.x(3) & physcond).setTriggerType(TT.calo) # new jet threshold
-        LVL1MenuItem('L1_4J10', ctpid=0x6e).setLogic( J10.x(4) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_4J15'            ).setLogic( J15.x(4) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_4J20', ctpid=-1  ).setLogic( J20.x(4) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_5J10', ctpid=-1  ).setLogic( J10.x(5) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_5J15'            ).setLogic( J15.x(5) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_5J20', ctpid=-1  ).setLogic( J20.x(5) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_6J10', ctpid=-1  ).setLogic( J10.x(6) & physcond).setTriggerType(TT.calo)
-        
-        LVL1MenuItem('L1_3J15.ETA24' ).setLogic( J15ETA24.x(3) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_5J15.ETA24' ).setLogic( J15ETA24.x(5) & physcond).setTriggerType(TT.calo)
-
-
-        #example zero bias seeded by single jet
-        #item_zb_j10  = LVL1MenuItem('L1_ZB_J10',  ctpid=240).setLogic(thr_zb_j10.x(1) & physcond).setTriggerType(TT.calo)
-        #example zero bias seeded by di jet
-        #item_zb_2j10 = LVL1MenuItem('L1_ZB_2J10', ctpid=241).setLogic(thr_zb_2j10.x(1) & physcond).setTriggerType(TT.calo)
-        #zb item for v3 menu, seeded by mbts a
-
-        if ('pp_v4' in TriggerFlags.triggerMenuSetup() or 'LS1_v1' in TriggerFlags.triggerMenuSetup()) :
-            LVL1MenuItem('L1_ZB', ctpid=240).setLogic(ZB_EM12.x(1) & physcond).setTriggerType(TT.zerobs)
-        elif  'DC14' in TriggerFlags.triggerMenuSetup():
-            LVL1MenuItem('L1_ZB', ctpid=240).setLogic(ZB_EM15V.x(1) & physcond).setTriggerType(TT.zerobs)
-        else:
-            LVL1MenuItem('L1_ZB', ctpid=240).setLogic(ZB_EM14.x(1) & physcond).setTriggerType(TT.zerobs)
-
-
-            
-        # - Add/remap new L1 thresholds:
-        #   J20->J15, J40->J30, J70->J55, J100->J75, J130->J95, J150->J115
-        LVL1MenuItem('L1_4J30'    ).setLogic( J30.x(4) & physcond)
-        LVL1MenuItem('L1_3J15_J50').setLogic( J15.x(3) & J50.x(1) & physcond)
-        LVL1MenuItem('L1_J30_FJ30').setLogic( J30.x(1) & ( JF30.x(1) | JB30.x(1) ) & physcond)
-        LVL1MenuItem('L1_J50_FJ50').setLogic( J50.x(1) & ( JF50.x(1) | JB50.x(1) ) & physcond)
-
-
-
-        # FJ
-        #pPb items
-        
-        LVL1MenuItem('L1_FJ0',   ctpid=0x7b).setLogic(( JF0.x(1) | JB0.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ0_A', ctpid=0x7b).setLogic(( JF0.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ0_C', ctpid=0x7b).setLogic(( JB0.x(1)) & physcond).setTriggerType(TT.calo)
-        
-        #pp items
-        LVL1MenuItem('L1_FJ5', ctpid=0x7b).setLogic(( JF5.x(1) |  JB5.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ10').setLogic(( JF10.x(1) |  JB10.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ15').setLogic(( JF15.x(1) |  JB15.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ30').setLogic(( JF30.x(1) |  JB30.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ50').setLogic(( JF50.x(1) |  JB50.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ75').setLogic(( JF75.x(1) |  JB75.x(1)) & physcond).setTriggerType(TT.calo)
-
-        # 2xFJ
-        LVL1MenuItem('L1_2FJ15').setLogic( JF15.x(1) &  JB15.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_2FJ30', ctpid=0x7d).setLogic( JF30.x(1) &  JB30.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_2FJ50', ctpid=0x7b).setLogic( JF50.x(1) &  JB50.x(1) & physcond).setTriggerType(TT.calo)
-
-        
-        # Diffractive
-
-        LVL1MenuItem('L1_MU0_TE50'    ).setLogic( MU0.x(1) & TE50.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU4_TE50'    ).setLogic( MU4.x(1) & TE50.x(1) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_EM3_2J5'     ).setLogic( EM3.x(1) & J5.x(2)   & physcond).setTriggerType(TT.calo)
-
-        LVL1MenuItem('L1_MU0_VTE50'   ).setLogic( MU0.x(1) & Not(TE50.x(1)) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU0_VTE20'   ).setLogic( MU0.x(1) & Not(TE20.x(1)) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU4_VTE50'   ).setLogic( MU4.x(1) & Not(TE50.x(1)) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_EM3_VTE50'   ).setLogic( EM3.x(1) & Not(TE50.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_EM3_VTE20'   ).setLogic( EM3.x(1) & Not(TE20.x(1)) & physcond).setTriggerType(TT.calo)
-
-        LVL1MenuItem('L1_MU0_MV_VTE50').setLogic( MU0.x(1) & Not(MBTS_A.x(1)& MBTS_C.x(1)) & Not(TE50.x(1)) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU4_MV_VTE50').setLogic( MU4.x(1) & Not(MBTS_A.x(1)& MBTS_C.x(1)) & Not(TE50.x(1)) & physcond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_EM3_MV_VTE50').setLogic( EM3.x(1) & Not(MBTS_A.x(1)& MBTS_C.x(1)) & Not(TE50.x(1)) & physcond).setTriggerType(TT.calo)
-
-
-        # Items for EMPTY
-        # EM
-        LVL1MenuItem('L1_EM3_EMPTY',   ctpid=-1).setLogic( EM3.x(1)   & cosmiccond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM5_EMPTY',   ctpid=-1).setLogic( EM5.x(1)   & cosmiccond).setTriggerType( emTT )
-        LVL1MenuItem('L1_EM6_EMPTY',   ctpid=-1).setLogic( EM6.x(1)   & cosmiccond).setTriggerType( emTT )
-        # Muon
-        LVL1MenuItem('L1_MU0_EMPTY'      ).setLogic( MU0.x(1)  & cosmiccond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MU4_EMPTY'      ).setLogic( MU4.x(1)  & cosmiccond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MU10_EMPTY'     ).setLogic( MU10.x(1) & cosmiccond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_2MU6_EMPTY'     ).setLogic( MU6.x(2)  & cosmiccond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_2MU0_EMPTY'     ).setLogic( MU0.x(2)  & cosmiccond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_2MU4_EMPTY'     ).setLogic( MU4.x(2)  & cosmiccond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MU11_EMPTY'     ).setLogic( MU11.x(1) & cosmiccond).setTriggerType(TT.rpcout)
-        # Tau
-        LVL1MenuItem('L1_TAU8_EMPTY').setLogic( HA8.x(1) & cosmiccond).setTriggerType(TT.calo)
-        # Jet
-        LVL1MenuItem('L1_J5_EMPTY' ).setLogic( J5.x(1)  & cosmiccond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J10_EMPTY').setLogic( J10.x(1) & cosmiccond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J30_EMPTY').setLogic( J30.x(1) & cosmiccond).setTriggerType(TT.calo)
-        # Forward Jet
-        LVL1MenuItem('L1_FJ5_EMPTY' ).setLogic( ( JF5.x(1) |  JB5.x(1)) & cosmiccond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ0_EMPTY' ).setLogic( ( JF0.x(1) |  JB0.x(1)) & cosmiccond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ30_EMPTY').setLogic( (JF30.x(1) | JB30.x(1)) & cosmiccond).setTriggerType(TT.calo)
-        # combined
-        LVL1MenuItem('L1_MU4_J15_EMPTY'  ).setLogic( MU4.x(1)  &  J15.x(1) & cosmiccond).setTriggerType(TT.rpcout)        
-
-
-                
-        
-        # Items for EMPTY, UNPAIRED1, UNPAIRED2 and UNPAIRED
-
-        # Jet
-        LVL1MenuItem('L1_J5_UNPAIRED_ISO'     ).setLogic( J5.x(1)  & unpaired_isocond   ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J5_UNPAIRED_NONISO'  ).setLogic( J5.x(1)  & unpaired_nonisocond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J5_FIRSTEMPTY'       ).setLogic( J5.x(1)  & firstempty         ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J10_UNPAIRED_ISO'    ).setLogic( J10.x(1) & unpaired_isocond   ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J10_UNPAIRED_NONISO' ).setLogic( J10.x(1) & unpaired_nonisocond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J10_FIRSTEMPTY'      ).setLogic( J10.x(1) & firstempty         ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J30_UNPAIRED'        ).setLogic( J30.x(1) & unpairedRcond      ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J30_UNPAIRED_ISO'    ).setLogic( J30.x(1) & unpaired_isocond   ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J30_UNPAIRED_NONISO' ).setLogic( J30.x(1) & unpaired_nonisocond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_J30_FIRSTEMPTY'      ).setLogic( J30.x(1) & firstempty         ).setTriggerType(TT.calo)
-        # Forward jet
-        LVL1MenuItem('L1_FJ10_UNPAIRED_NONISO').setLogic( ( JF10.x(1) |  JB10.x(1)) & unpaired_nonisocond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ0_UNPAIRED_ISO'    ).setLogic( ( JF0.x(1)  |  JB0.x(1) ) & unpaired_isocond   ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ5_UNPAIRED_ISO'    ).setLogic( ( JF5.x(1)  |  JB5.x(1) ) & unpaired_isocond   ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ30_UNPAIRED_ISO'   ).setLogic( ( JF30.x(1) |  JB30.x(1)) & unpaired_isocond   ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_FJ30_FIRSTEMPTY'     ).setLogic( ( JF30.x(1) |  JB30.x(1)) & firstempty         ).setTriggerType(TT.calo)
-        # Tau
-        LVL1MenuItem('L1_TAU8_UNPAIRED_ISO'   ).setLogic( HA8.x(1) & unpaired_isocond   ).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TAU8_UNPAIRED_NONISO').setLogic( HA8.x(1) & unpaired_nonisocond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TAU8_FIRSTEMPTY'     ).setLogic( HA8.x(1) & firstempty         ).setTriggerType(TT.calo)
-        # EM
-        LVL1MenuItem('L1_EM3_UNPAIRED_ISO'    ).setLogic( EM3.x(1) & unpaired_isocond   ).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_EM3_UNPAIRED_NONISO' ).setLogic( EM3.x(1) & unpaired_nonisocond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_EM3_FIRSTEMPTY'      ).setLogic( EM3.x(1) & firstempty         ).setTriggerType(TT.calo|TT.caloem)
-        # Muon
-        LVL1MenuItem('L1_MU0_UNPAIRED_ISO'    ).setLogic( MU0.x(1)  & unpaired_isocond   ).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU4_UNPAIRED_ISO'    ).setLogic( MU4.x(1)  & unpaired_isocond   ).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU10_UNPAIRED_ISO'   ).setLogic( MU10.x(1) & unpaired_isocond   ).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU0_UNPAIRED_NONISO' ).setLogic( MU0.x(1)  & unpaired_nonisocond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU4_UNPAIRED_NONISO' ).setLogic( MU4.x(1)  & unpaired_nonisocond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU0_FIRSTEMPTY'      ).setLogic( MU0.x(1)  & firstempty         ).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU4_FIRSTEMPTY'      ).setLogic( MU4.x(1)  & firstempty         ).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU6_FIRSTEMPTY'      ).setLogic( MU6.x(1)  & firstempty         ).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU10_FIRSTEMPTY'     ).setLogic( MU10.x(1) & firstempty         ).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_MU20_FIRSTEMPTY'     ).setLogic( MU20.x(1) & firstempty         ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_2MU6_UNPAIRED_ISO'   ).setLogic( MU6.x(2)  & unpaired_isocond   ).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU6_UNPAIRED_NONISO').setLogic( MU6.x(2)  & unpaired_nonisocond).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU4_FIRSTEMPTY'     ).setLogic( MU4.x(2)  & firstempty         ).setTriggerType(TT.rpcin)
-        LVL1MenuItem('L1_2MU6_FIRSTEMPTY'     ).setLogic( MU6.x(2)  & firstempty         ).setTriggerType(TT.rpcin)        
-        # combined
-        LVL1MenuItem('L1_MU4_J15_UNPAIRED_ISO').setLogic( MU4.x(1) & J15.x(1) & unpaired_isocond).setTriggerType(TT.rpcin)
-
-        #Combined JET+MET
-        LVL1MenuItem('L1_J40_XE50').setLogic( (J40.x(1) & XE50.x(1)) & physcond).setTriggerType(TT.calo)
-        
-        # XE ctpid=[0x80:0x9f]
-        LVL1MenuItem('L1_XE20', ctpid=0x81).setLogic( XE20.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XE25', ctpid=0x82).setLogic( XE25.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XE30', ctpid=0x83).setLogic( XE30.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XE40', ctpid=0x84).setLogic( XE40.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XE50', ctpid=0x85).setLogic( XE50.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XE70', ctpid=0x86).setLogic( XE70.x(1) & physcond).setTriggerType(TT.calo)
-
-        LVL1MenuItem('L1_XE35_BGRP7').setLogic( XE35.x(1)&bgrp7cond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XE40_BGRP7').setLogic( XE40.x(1)&bgrp7cond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XE50_BGRP7').setLogic( XE50.x(1)&bgrp7cond).setTriggerType(TT.calo)
-
-        #pPb items        
-        LVL1MenuItem('L1_TE10').setLogic( TE10.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TE20').setLogic( TE20.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TE30').setLogic( TE30.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TE40').setLogic( TE40.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TE35').setLogic( TE35.x(1) & physcond).setTriggerType(TT.calo)
-
-        # Other TE items for L=10^32 and 10^33
-        LVL1MenuItem('L1_TE800', ctpid=0x8f).setLogic( TE800.x(1) & physcond).setTriggerType(TT.calo)
-
-
-        # items for HI p+Pb (forward TE)
-        if 'HI_v2' in TriggerFlags.triggerMenuSetup():
-            LVL1MenuItem('L1_TE0'  ).setLogic( TE0.x(1)   & physcond).setTriggerType(TT.calo)
-            LVL1MenuItem('L1_TE20' ).setLogic( TE20.x(1)  & physcond).setTriggerType(TT.calo)
-            LVL1MenuItem('L1_TE50' ).setLogic( TE50.x(1)  & physcond).setTriggerType(TT.calo)
-            LVL1MenuItem('L1_TE65' ).setLogic( TE65.x(1)  & physcond).setTriggerType(TT.calo)
-            LVL1MenuItem('L1_TE90' ).setLogic( TE90.x(1)  & physcond).setTriggerType(TT.calo)
-            LVL1MenuItem('L1_TE100').setLogic( TE100.x(1) & physcond).setTriggerType(TT.calo)
-        else:
-            LVL1MenuItem('L1_TE0'  ).setLogic( TE0.x(1)   & physcond).setTriggerType(TT.calo)
-            LVL1MenuItem('L1_TE50' ).setLogic( TE50.x(1)  & physcond).setTriggerType(TT.calo)
-            LVL1MenuItem('L1_TE65' ).setLogic( TE65.x(1)  & physcond).setTriggerType(TT.calo)
-            LVL1MenuItem('L1_TE90' ).setLogic( TE90.x(1)  & physcond).setTriggerType(TT.calo)
-            LVL1MenuItem('L1_TE100').setLogic( TE100.x(1) & physcond).setTriggerType(TT.calo)
-            
-
-        LVL1MenuItem('L1_XS30').setLogic( XS30.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XS45').setLogic( XS45.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XS50').setLogic( XS50.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XS55').setLogic( XS55.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XS60').setLogic( XS60.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XS65').setLogic( XS65.x(1) & physcond).setTriggerType(TT.calo)
-        
-        LVL1MenuItem('L1_JE140'            ).setLogic( JE140.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_JE200', ctpid=0x92).setLogic( JE200.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_JE350', ctpid=0x94).setLogic( JE350.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_JE500', ctpid=0x96).setLogic( JE500.x(1) & physcond).setTriggerType(TT.calo)
-
-        # Transient items
-        LVL1MenuItem('L1_XE35').setLogic( XE35.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_XE60').setLogic( XE60.x(1) & physcond).setTriggerType(TT.calo)
-
-        LVL1MenuItem('L1_TE300').setLogic( TE300.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TE500').setLogic( TE500.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TE700').setLogic( TE700.x(1) & physcond).setTriggerType(TT.calo)
-        
-        # Combined items [0xa0:0xff], [0x30:0x3f],
-
-        # EM + (XE, MU, TAU)
-        LVL1MenuItem('L1_EM10VH_XE20').setLogic( EM10VH.x(1)& XE20.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_EM10VH_XE30').setLogic( EM10VH.x(1)& XE30.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_EM10VH_XE35').setLogic( EM10VH.x(1)& XE35.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)        
-
-
-        LVL1MenuItem('L1_EM3_MU6', ctpid=0xbd).setLogic( MU6.x(1)& EM3.x(1) & physcond).setTriggerType(TT.rpcin|TT.calo|TT.caloem)
-        LVL1MenuItem('L1_EM6_2MU6'   ).setLogic( MU6.x(2)& EM6.x(1) & physcond)
-        LVL1MenuItem('L1_EM10VH_MU6' ).setLogic( EM10VH.x(1)& MU6.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_EM15VH_MU10').setLogic( EM15VH.x(1)& MU10.x(1)& physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_EM16VH_MU4' ).setLogic( EM16VH.x(1)& MU4.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_2EM8VH_MU10' ).setLogic( EM8VH.x(2)& MU10.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_EM8VH_2MU6' ).setLogic( EM8VH.x(1)& MU6.x(2) & physcond).setTriggerType(TT.calo|TT.caloem)
-
-
-        LVL1MenuItem('L1_2EM6_MU6'   ).setLogic( EM6.x(2)& MU6.x(1) & physcond)
-        LVL1MenuItem('L1_EM6_MU6'    ).setLogic( EM6.x(1)& MU6.x(1) & physcond)
-        LVL1MenuItem('L1_EM6_MU10'   ).setLogic( EM6.x(1)& MU10.x(1) & physcond)
-        LVL1MenuItem('L1_EM12_XE20'  ).setLogic( EM12.x(1)& XE20.x(1) & physcond)
-        LVL1MenuItem('L1_EM16V_XE20' ).setLogic( EM16V.x(1)& XE20.x(1) & physcond)
-        LVL1MenuItem('L1_EM6_XS45'   ).setLogic( EM6.x(1)& XS45.x(1) & physcond)
-        LVL1MenuItem('L1_EM6_XS50'   ).setLogic( EM6.x(1)& XS50.x(1) & physcond)
-        LVL1MenuItem('L1_EM6_XS55'   ).setLogic( EM6.x(1)& XS55.x(1) & physcond)
-        LVL1MenuItem('L1_EM6_XS60'   ).setLogic( EM6.x(1)& XS60.x(1) & physcond)
-        LVL1MenuItem('L1_EM16V_XS45' ).setLogic( EM16V.x(1)& XS45.x(1) & physcond)
-        LVL1MenuItem('L1_EM12_XS45'  ).setLogic( EM12.x(1)& XS45.x(1) & physcond)
-        LVL1MenuItem('L1_EM12_XS30'  ).setLogic( EM12.x(1)& XS30.x(1) & physcond)
-        LVL1MenuItem('L1_EM12_4J10'  ).setLogic( EM12.x(1)& J10.x(4) & physcond)
-        LVL1MenuItem('L1_EM15VH_J15.23ETA49' ).setLogic( EM15VH&  (JF1523ETA49.x(1)  | JB1523ETA49.x(1)  ) & physcond).setTriggerType(TT.calo)
-
-
-        # TAU + EM
-        LVL1MenuItem('L1_2TAU11I_EM14VH').setLogic( HA11I.x(2)& EM14VH.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_2TAU11_TAU20_EM14VH').setLogic( HA11.x(2)& HA20.x(1)& EM14VH.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_2TAU11_TAU20_EM10VH').setLogic( HA11.x(2)& HA20.x(1)& EM10VH.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_2TAU11_TAU15', ctpid=0x0).setLogic( HA11.x(2)& HA15.x(1) & physcond).setTriggerType(TT.calo)          
-        LVL1MenuItem('L1_2TAU11I_TAU15', ctpid=0x0).setLogic( HA11I.x(2)& HA15.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_2TAU11_EM10VH').setLogic( HA11.x(2)& EM10VH.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-
-        
-        LVL1MenuItem('L1_MU4_J50').setLogic( MU4.x(1)& J50.x(1) & physcond).setTriggerType(TT.rpcin|TT.calo)
-        LVL1MenuItem('L1_MU4_J10').setLogic( MU4.x(1)& J10.x(1) & physcond).setTriggerType(TT.rpcin|TT.calo)
- 
-        # - Add/remap new L1 thresholds:
-        #   J20->J15, J40->J30, J70->J55, J100->J75, J130->J95, J150->J115
-        LVL1MenuItem('L1_MU4_J15').setLogic( MU4.x(1)& J15.x(1) & physcond).setTriggerType(TT.rpcin|TT.calo)
-        LVL1MenuItem('L1_MU4_J30').setLogic( MU4.x(1)& J30.x(1) & physcond)
-        LVL1MenuItem('L1_MU4_J75').setLogic( MU4.x(1)& J75.x(1) & physcond) 
-
-        LVL1MenuItem('L1_MU4_J20_XE20').setLogic( MU4.x(1)& J20.x(1)& XE20.x(1) & physcond)
-        LVL1MenuItem('L1_MU4_J20_XE35').setLogic( MU4.x(1)& J20.x(1)& XE35.x(1) & physcond)
-
-        LVL1MenuItem('L1_MU6_J15').setLogic( MU6.x(1)& J15.x(1) & physcond).setTriggerType(TT.rpcin|TT.calo)
-        LVL1MenuItem('L1_MU6_2J20').setLogic( MU6.x(1)& J20.x(2) & physcond).setTriggerType(TT.rpcin|TT.calo)
-        LVL1MenuItem('L1_2MU4_EM3', ctpid=0xbd).setLogic( MU4.x(2)& EM3.x(1) & physcond).setTriggerType(TT.rpcin|TT.calo|TT.caloem)
-        LVL1MenuItem('L1_2MU4_2EM3', ctpid=0xbd).setLogic( MU4.x(2)& EM3.x(2) & physcond).setTriggerType(TT.rpcin|TT.calo|TT.caloem)
-
-        LVL1MenuItem('L1_MU10_XE20').setLogic( MU10.x(1)& XE20.x(1) & physcond)
-        LVL1MenuItem('L1_MU10_XE25').setLogic( MU10.x(1)& XE25.x(1) & physcond)
-        LVL1MenuItem('L1_MU10_J20').setLogic( MU10.x(1) & J20.x(1) & physcond) # new jet threshold
-
-        # TAU + MU
-        LVL1MenuItem('L1_TAU8_MU10'             ).setLogic( HA8.x(1)  & MU10.x(1) & physcond)
-        LVL1MenuItem('L1_TAU11_MU10', ctpid=0xc7).setLogic( HA11.x(1) & MU10.x(1) & physcond)
-        LVL1MenuItem('L1_2J30_XE20'             ).setLogic( J30.x(2)  & XE20.x(1) & physcond) # new jet threshold
-
-        # TAU + XE
-        LVL1MenuItem('L1_TAU15_XE35'     ).setLogic( HA15.x(1)  & XE35.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TAU15_XE40'     ).setLogic( HA15.x(1)  & XE40.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TAU15I_XE35'    ).setLogic( HA15I.x(1) & XE35.x(1) & physcond)
-        LVL1MenuItem('L1_TAU15I_XE40'    ).setLogic( HA15I.x(1) & XE40.x(1) & physcond)
-        LVL1MenuItem('L1_TAU20_XE40'     ).setLogic( HA20.x(1)  & XE40.x(1) & physcond)
-        LVL1MenuItem('L1_TAU20_XE35'     ).setLogic( HA20.x(1)  & XE35.x(1) & physcond)
-        LVL1MenuItem('L1_TAU15_XS35'     ).setLogic( HA15.x(1)  & XS35.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_TAU15_XE25_3J15').setLogic( HA15.x(1)  & XE25.x(1) & J15.x(3) & physcond).setTriggerType(TT.calo)
-
-        # VBF request
-        
-        LVL1MenuItem('L1_2TAU8_TAU15_FJ15'         ).setLogic( HA8.x(2) & HA15.x(1)  & ( JF15.x(1) | JB15.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_2TAU8_TAU15_J15CF'        ).setLogic( HA8.x(2) & HA15.x(1)  & J15CF.x(1) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_2TAU8_TAU11I_EM10VH_FJ15' ).setLogic( HA8.x(2) & HA11I.x(1) & EM10VH.x(1)&( JF15.x(1)| JB15.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_2TAU8_TAU11I_EM10VH_J15CF').setLogic( HA8.x(2) & HA11I.x(1) & EM10VH.x(1)& J15CF.x(1) & physcond).setTriggerType(TT.calo)
-
-               
-        LVL1MenuItem('L1_EM14VH_FJ15' ).setLogic( EM14VH.x(1)&( JF15.x(1)| JB15.x(1)) & physcond).setTriggerType(TT.calo|TT.caloem)
-        LVL1MenuItem('L1_EM14VH_J15CF').setLogic( EM14VH.x(1)& J15CF.x(1) & physcond).setTriggerType(TT.calo|TT.caloem)
-
-        LVL1MenuItem('L1_MU10_FJ15').setLogic(  MU10.x(1) & ( JF15.x(1) | JB15.x(1)) & physcond)
-        LVL1MenuItem('L1_MU10_J15CF').setLogic( MU10.x(1)& J15CF.x(1) & physcond)
-
-        LVL1MenuItem('L1_3J15_FJ15').setLogic( J15.x(3)&( JF15.x(1)| JB15.x(1)) & physcond).setTriggerType(TT.calo)
-        LVL1MenuItem('L1_2J15_2FJ15').setLogic( J15.x(2)&( JF15.x(1)& JB15.x(1)) & physcond).setTriggerType(TT.calo)              
-
-        # Transient items
-        # L1_TAU6_2JT4_JT35  (or whatever soft thresholds they have. JT4 must have 
-        # softer cuts than TAU06 and JT35 - please get in touch with us if it is not 
-        # the case - we will need to rethink it then)
-
-        LVL1MenuItem('L1_J50_XE30').setLogic( J50.x(1)&  XE30.x(1) & physcond)
-        LVL1MenuItem('L1_J50_XE35').setLogic( J50.x(1)&  XE35.x(1) & physcond)
-        LVL1MenuItem('L1_J50_XE40').setLogic( J50.x(1)&  XE40.x(1) & physcond)
-        LVL1MenuItem('L1_J30_XE35').setLogic( J30.x(1)& XE35.x(1) & physcond)
-        LVL1MenuItem('L1_J30_XE40').setLogic( J30.x(1)& XE40.x(1) & physcond)
-        LVL1MenuItem('L1_J30_XE50').setLogic( J30.x(1)& XE50.x(1) & physcond)
-        LVL1MenuItem('L1_2J20_XE20').setLogic( J20.x(2)&  XE20.x(1) & physcond)
-        
-
-        # MBTS
-        MBTS_1   = MBTS_A.x(1) | MBTS_C.x(1)
-        MBTS_2   = (MBTS_A.x(2) | MBTS_C.x(2) | MBTS_A.x(1)) & (MBTS_A.x(2) | MBTS_C.x(2) | MBTS_C.x(1))
-        MBTS_1_1 = MBTS_A.x(1) & MBTS_C.x(1)
-        MBTS_2_2 = MBTS_A.x(2) & MBTS_C.x(2)
-        MBTS_3_3 = MBTS_A.x(3) & MBTS_C.x(3)
-        MBTS_4_4 = MBTS_A.x(4) & MBTS_C.x(4)
-
-        LVL1MenuItem('L1_MBTS_1',           ctpid=0xe2).setLogic( MBTS_1   & physcond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_2',           ctpid=0xe3).setLogic( MBTS_2   & physcond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_1_1_OVERLAY', ctpid=0xe4).setLogic( MBTS_1_1 & physcond ).setTriggerType(TT.zerobs)
-        LVL1MenuItem('L1_MBTS_1_1',         ctpid=0xe4).setLogic( MBTS_1_1 & physcond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_2_2'                    ).setLogic( MBTS_2_2 & physcond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_3_3'                    ).setLogic( MBTS_3_3 & physcond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_4_4',         ctpid=0xe1).setLogic( MBTS_4_4 & physcond ).setTriggerType(TT.minb)
-
-        LVL1MenuItem('L1_MBTS_1_EMPTY'  ).setLogic( MBTS_1   & cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_2_EMPTY'  ).setLogic( MBTS_2   & cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_1_1_EMPTY').setLogic( MBTS_1_1 & cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_2_2_EMPTY').setLogic( MBTS_2_2 & cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_3_3_EMPTY').setLogic( MBTS_3_3 & cosmiccond).setTriggerType(TT.minb)
-
-        LVL1MenuItem('L1_MBTS_1_UNPAIRED_ISO'   ).setLogic( MBTS_1 & unpaired_isocond    ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_1_UNPAIRED_NONISO').setLogic( MBTS_1 & unpaired_nonisocond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_2_UNPAIRED_ISO'   ).setLogic( MBTS_2 & unpaired_isocond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_2_UNPAIRED_NONISO').setLogic( MBTS_2 & unpaired_nonisocond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_2_BGRP7'          ).setLogic( MBTS_2 & bgrp7cond           ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_1_1_UNPAIRED_ISO' ).setLogic( MBTS_1_1 & unpaired_isocond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_2_2_UNPAIRED_ISO' ).setLogic( MBTS_2_2 & unpaired_isocond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_3_3_UNPAIRED_ISO' ).setLogic( MBTS_3_3 & unpaired_isocond ).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTS_4_4_UNPAIRED_ISO' ).setLogic( MBTS_4_4 & unpaired_isocond ).setTriggerType(TT.minb)
-
-        LVL1MenuItem('L1_MBTSA0' ).setLogic( MBTS_A0.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA1' ).setLogic( MBTS_A1.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA2' ).setLogic( MBTS_A2.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA3' ).setLogic( MBTS_A3.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA4' ).setLogic( MBTS_A4.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA5' ).setLogic( MBTS_A5.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA6' ).setLogic( MBTS_A6.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA7' ).setLogic( MBTS_A7.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA8' ).setLogic( MBTS_A8.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA9' ).setLogic( MBTS_A9.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA10').setLogic( MBTS_A10.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA11').setLogic( MBTS_A11.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA12').setLogic( MBTS_A12.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA13').setLogic( MBTS_A13.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA14').setLogic( MBTS_A14.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSA15').setLogic( MBTS_A15.x(1) & physcond).setTriggerType(TT.minb)
-
-        LVL1MenuItem('L1_MBTSC0' ).setLogic( MBTS_C0.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC1' ).setLogic( MBTS_C1.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC2' ).setLogic( MBTS_C2.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC3' ).setLogic( MBTS_C3.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC4' ).setLogic( MBTS_C4.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC5' ).setLogic( MBTS_C5.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC6' ).setLogic( MBTS_C6.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC7' ).setLogic( MBTS_C7.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC8' ).setLogic( MBTS_C8.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC9' ).setLogic( MBTS_C9.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC10').setLogic( MBTS_C10.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC11').setLogic( MBTS_C11.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC12').setLogic( MBTS_C12.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC13').setLogic( MBTS_C13.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC14').setLogic( MBTS_C14.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_MBTSC15').setLogic( MBTS_C15.x(1) & physcond).setTriggerType(TT.minb)
-        
-
-        # ZDC
-        
-        LVL1MenuItem('L1_ZDC'                     ).setLogic((ZDC_A.x(1)|ZDC_C.x(1)) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_EMPTY'               ).setLogic((ZDC_A.x(1)|ZDC_C.x(1))&cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_UNPAIRED_ISO'        ).setLogic((ZDC_A.x(1)|ZDC_C.x(1))&unpaired_isocond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_UNPAIRED_NONISO'     ).setLogic((ZDC_A.x(1)|ZDC_C.x(1))&unpaired_nonisocond).setTriggerType(TT.minb)                
-        LVL1MenuItem('L1_ZDC_A_C'                 ).setLogic(ZDC_A.x(1)&ZDC_C.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_A_C_EMPTY'           ).setLogic(ZDC_A.x(1)&ZDC_C.x(1)&cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_A_C_UNPAIRED_ISO'    ).setLogic(ZDC_A.x(1)&ZDC_C.x(1)&unpaired_isocond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_A_C_UNPAIRED_NONISO' ).setLogic(ZDC_A.x(1)&ZDC_C.x(1)&unpaired_nonisocond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_A'                   ).setLogic(ZDC_A.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_C'                   ).setLogic(ZDC_C.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_AND'                 ).setLogic(ZDC_AND.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_A_VTE20'             ).setLogic(ZDC_A.x(1)&Not( TE20.x(1)) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_C_VTE20'             ).setLogic(ZDC_C.x(1)&Not( TE20.x(1)) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_A_BGRP7'             ).setLogic(ZDC_A.x(1)&bgrp7cond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_C_BGRP7'             ).setLogic(ZDC_C.x(1)&bgrp7cond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_MBTS_1'              ).setLogic((ZDC_A.x(1)|ZDC_C.x(1))&( MBTS_A.x(1)| MBTS_C.x(1)) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_MBTS_2'              ).setLogic((ZDC_A.x(1)|ZDC_C.x(1))&\
-                                                             ( MBTS_A.x(2)| MBTS_C.x(2)| MBTS_A.x(1))\
-                                                             &( MBTS_A.x(2)| MBTS_C.x(2)| MBTS_C.x(1)) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_MBTS_1_1'            ).setLogic((ZDC_A.x(1)|ZDC_C.x(1))&( MBTS_A.x(1)& MBTS_C.x(1)) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_ZDC_MBTS_2_2'            ).setLogic((ZDC_A.x(1)|ZDC_C.x(1))&( MBTS_A.x(2)& MBTS_C.x(2)) & physcond).setTriggerType(TT.minb)
-
-
-        # BCM
-
-        LVL1MenuItem('L1_BCM_AC_CA_BGRP0',ctpid=0xe6 ).setLogic((BCM_AtoC.x(1)|BCM_CtoA.x(1))&BGRP0).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_BCM_AC_CA_UNPAIRED_ISO'     ).setLogic((BCM_AtoC.x(1)|BCM_CtoA.x(1))&unpaired_isocond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_BCM_AC_CA_UNPAIRED_NONISO'  ).setLogic((BCM_AtoC.x(1)|BCM_CtoA.x(1))&unpaired_nonisocond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_BCM_HT_BGRP0',   ctpid=0xf8 ).setLogic( BCM_Comb.x(7)&BGRP0).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_BCM_Wide_BGRP0', ctpid=0xe8 ).setLogic( BCM_Wide.x(1)&BGRP0).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_BCM_Wide_EMPTY'             ).setLogic( BCM_Wide.x(1)&cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_BCM_Wide_UNPAIRED_ISO'      ).setLogic( BCM_Wide.x(1)&unpaired_isocond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_BCM_Wide_UNPAIRED_NONISO'   ).setLogic( BCM_Wide.x(1)&unpaired_nonisocond).setTriggerType(TT.minb)
-
-
-        # LUCID
-        
-        LVL1MenuItem('L1_LUCID_C',     ctpid=0xed  ).setLogic( LUCID_C.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_A',     ctpid=0xec  ).setLogic( LUCID_A.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_A_C',   ctpid=0xee  ).setLogic( LUCID_A.x(1)&LUCID_C.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID',       ctpid=0xf5  ).setLogic( (LUCID_A.x(1)|LUCID_C.x(1)) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_BGRP7'              ).setLogic( (LUCID_A.x(1)|LUCID_C.x(1))&bgrp7cond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_COMM'               ).setLogic( NIMDIR5.x(1) & physcond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_A_C_EMPTY'          ).setLogic( LUCID_A.x(1)&LUCID_C.x(1)&cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_EMPTY'              ).setLogic( (LUCID_A.x(1)|LUCID_C.x(1))&cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_UNPAIRED_ISO'       ).setLogic( (LUCID_A.x(1)|LUCID_C.x(1))&unpaired_isocond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_UNPAIRED_NONISO'    ).setLogic( (LUCID_A.x(1)|LUCID_C.x(1))&unpaired_nonisocond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_COMM_EMPTY'         ).setLogic( NIMDIR5.x(1)&cosmiccond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_COMM_UNPAIRED_ISO'  ).setLogic( NIMDIR5.x(1)&unpaired_isocond).setTriggerType(TT.minb)        
-        LVL1MenuItem('L1_LUCID_A_C_UNPAIRED_ISO'   ).setLogic( LUCID_A.x(1)&LUCID_C.x(1)&unpaired_isocond).setTriggerType(TT.minb)
-        LVL1MenuItem('L1_LUCID_A_C_UNPAIRED_NONISO').setLogic( LUCID_A.x(1)&LUCID_C.x(1)&unpaired_nonisocond).setTriggerType(TT.minb)
-
-
-        # RANDOM
-
-        LVL1MenuItem('L1_RD0_FILLED'         ).setLogic( RNDM0 & physcond           ).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_RD0_EMPTY'          ).setLogic( RNDM0 & cosmiccond         ).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_RD0_FIRSTEMPTY'     ).setLogic( RNDM0 & firstempty         ).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_RD0_UNPAIRED_ISO'   ).setLogic( RNDM0 & unpaired_isocond   ).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_RD0_UNPAIRED_NONISO').setLogic( RNDM0 & unpaired_nonisocond).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_RD1_FILLED'         ).setLogic( RNDM1 & physcond           ).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_RD1_EMPTY'          ).setLogic( RNDM1 & cosmiccond         ).setTriggerType(TT.zerobs)
-
-        
-        # Bunch groups
-
-        LVL1MenuItem('L1_BGRP1').setLogic(BGRP0 & BGRP1).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_BGRP7').setLogic(BGRP0 & BGRP7).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_BGRP1_ALFA_BGT').setLogic(BGRP0 & BGRP1).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_BGRP4_ALFA_BGT').setLogic(BGRP0 & BGRP4).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_BGRP7_ALFA_BGT').setLogic(BGRP0 & BGRP7).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_BPTX0_BGRP0', ctpid=0xf1).setLogic(BPTX0.x(1)&BGRP0).setTriggerType(TT.rand)
-        LVL1MenuItem('L1_BPTX1_BGRP0', ctpid=0xf2).setLogic(BPTX1.x(1)&BGRP0).setTriggerType(TT.rand)
-        
-
-        # Direct inputs [0x50:0x5f]
-        #LVL1MenuItem('L1_LHCF',  ctpid=-1).setLogic( (NIMDIR36.x(1) & physcond)).setTriggerType(TT.minb)        
-        LVL1MenuItem('L1_LHCF',  ctpid=-1).setLogic( (NIMDIR36.x(1) & physcond))
-
-
-
-        LVL1MenuItem('L1_ALFA_EMPTY').setLogic( NIM_ALFA_LOG.x(1) & cosmiccond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_BGRP7').setLogic( NIM_ALFA_LOG.x(1) & bgrp7cond).setTriggerType(TT.rpcout)
-
-        LVL1MenuItem('L1_ALFA_EMPTY_OD', ctpid=-1).setLogic( NIM_ALFA_LOG_OD.x(1)&cosmiccond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_BGRP7_OD', ctpid=-1).setLogic( NIM_ALFA_LOG_OD.x(1)&bgrp7cond).setTriggerType(TT.rpcout)
-
-
-        LVL1MenuItem('L1_TRT', ctpid=0x4e).setLogic(NIMDIR25.x(1)&BGRP0).setTriggerType(TT.rpcout)
-
-        LVL1MenuItem('L1_L1A_Mon', ctpid=0x4f).setLogic(NIMDIR26.x(1)&BGRP0).setTriggerType(TT.rpcout)
-        
-        LVL1MenuItem('L1_CALREQ0', ctpid=0xfd).setLogic( NIM28.x(1) & calibcond).setTriggerType(TT.calreq0)
-        LVL1MenuItem('L1_CALREQ1', ctpid=0xfe).setLogic( NIM29.x(1) & calibcond).setTriggerType(TT.calreq1)
-        LVL1MenuItem('L1_CALREQ2', ctpid=0xff).setLogic( NIM30.x(1) & calibcond).setTriggerType(TT.calreq2)
-
-
-        LVL1MenuItem('L1_NIM_S8C2B21').setLogic(NIMDIR6.x(1) & bgrpcond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_NIM_S8C2B22').setLogic(NIMDIR7.x(1) & bgrpcond).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_NIM_S8C2B23').setLogic(NIMDIR8.x(1) & bgrpcond).setTriggerType(TT.rpcout)
-
-        
-
-
-        # Alfa items
-        ARL = NIM_A7R1L.x(1)
-        ARU = NIM_A7R1U.x(1)
-        ALL = NIM_A7L1L.x(1)
-        ALU = NIM_A7L1U.x(1)
-        BRL = NIM_B7R1L.x(1)
-        BRU = NIM_B7R1U.x(1)
-        BLL = NIM_B7L1L.x(1)
-        BLU = NIM_B7L1U.x(1)
-
-        # Elastics1 and 2
-        LVL1MenuItem('L1_ALFA_ELAST1').setLogic( BLU & ALU & ARL & BRL & Not( BLL | ALL | ARU | BRU ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ELAST2').setLogic( BLL & ALL & ARU & BRU & Not( BLU | ALU | ARL | BRL ) & physcond ).setTriggerType(TT.rpcout)
-
-        # Elastics 11 - Elastics 18
-        LVL1MenuItem('L1_ALFA_ELAST11').setLogic( BLU & ALU & ARL & BRL & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ELAST12').setLogic( BLL & ALL & ARU & BRU & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ELAST13').setLogic( ( BLU | ALU ) & ( ARL & BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ELAST14').setLogic( ( BLU & ALU ) & ( ARL | BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ELAST15').setLogic( ( BLU | ALU ) & ( ARL | BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ELAST16').setLogic( ( BLL | ALL ) & ( ARU & BRU ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ELAST17').setLogic( ( BLL & ALL ) & ( ARU | BRU ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ELAST18').setLogic( ( BLL | ALL ) & ( ARU | BRU ) & physcond ).setTriggerType(TT.rpcout)
-
-        # Single_Diffraction 1 - 8
-        LVL1MenuItem('L1_ALFA_SDIFF1').setLogic( BLU & ALU & Not( BLL | ALL | ARU | ARL | BRU | BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SDIFF2').setLogic( ARL & BRL & Not( BLU | BLL | ALU | ALL | ARU | BRU ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SDIFF3').setLogic( BLL & ALL & Not( BLU | ALU | ARU | ARL | BRU | BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SDIFF4').setLogic( ARU & BRU & Not( BLU | BLL | ALU | ALL | ARL | BRL ) & physcond ).setTriggerType(TT.rpcout)
-
-        LVL1MenuItem('L1_ALFA_SDIFF5').setLogic( BLU & ALU & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SDIFF6').setLogic( ARL & BRL & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SDIFF7').setLogic( BLL & ALL & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SDIFF8').setLogic( ARU & BRU & physcond ).setTriggerType(TT.rpcout)
-
-        # Big_showers 1 - 4
-        LVL1MenuItem('L1_ALFA_SHOW1').setLogic( BLU & BLL & ALU & ALL & Not( ARU | ARL | BRU | BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SHOW2').setLogic( ARU & ARL & BRU & BRL & Not( BLU | BLL | ALU | ALL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SHOW3').setLogic( BLU & BLL & ALU & ALL & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SHOW4').setLogic( ARU & ARL & BRU & BRL & physcond ).setTriggerType(TT.rpcout)
-
-        # Systematics 1 - 4
-        LVL1MenuItem('L1_ALFA_SYST1').setLogic( BLU & BLL & Not( ALU | ALL | ARU | ARL | BRU | BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SYST2').setLogic( ALU & ALL & Not( BLU | BLL | ARU | ARL | BRU | BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SYST3').setLogic( ARU & ARL & Not( BLU | BLL | ALU | ALL | BRU | BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SYST4').setLogic( BRU & BRL & Not( BLU | BLL | ALU | ALL | ARU | ARL ) & physcond ).setTriggerType(TT.rpcout)
-
-        # Big_showers_Systematics 1 - 5
-        LVL1MenuItem('L1_ALFA_SHOWSYST1').setLogic( BLU & BLL & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SHOWSYST2').setLogic( ALU & ALL & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SHOWSYST3').setLogic( ARU & ARL & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SHOWSYST4').setLogic( BRU & BRL & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SHOWSYST5').setLogic( ( BLU | BLL | ALU | ALL ) & ( ARU | ARL | BRU | BRL ) & physcond ).setTriggerType(TT.rpcout)
-
-        # Systematics 9 - 12, 17, 18
-        LVL1MenuItem('L1_ALFA_SYST9' ).setLogic( BLU & ALU & ARU & BRU & Not( BLL | ALL | ARL | BRL ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SYST10').setLogic( BLL & ALL & ARL & BRL & Not( BLU | ALU | ARU | BRU ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SYST11').setLogic( BLU & ALU & ARU & BRU & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SYST12').setLogic( BLL & ALL & ARL & BRL & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SYST17').setLogic( ( BLU | ALU ) & ( ARU | BRU ) & physcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_SYST18').setLogic( ( BLL | ALL ) & ( ARL | BRL ) & physcond ).setTriggerType(TT.rpcout)
-
-        # ANY_ALFA = Minimum_Bias : B7L1U or B7L1L or A7L1U or A7L1L or A7R1U or A7R1L or B7R1U or B7R1L
-        ANY_ALFA = BLU | BLL | ALU | ALL | ARU | ARL | BRU | BRL
-        LVL1MenuItem('L1_ALFA_ANY'                ).setLogic( ANY_ALFA & physcond            ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ANY_EMPTY'          ).setLogic( ANY_ALFA & cosmiccond          ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ANY_FIRSTEMPTY'     ).setLogic( ANY_ALFA & firstempty          ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ANY_UNPAIRED_ISO'   ).setLogic( ANY_ALFA & unpaired_isocond    ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_ANY_UNPAIRED_NONISO').setLogic( ANY_ALFA & unpaired_nonisocond ).setTriggerType(TT.rpcout)
-
-        #---------------------------------
-        # new ALFA items for 2012 running:
-        #---------------------------------
-        ARL_OD = NIM_A7R1L_OD.x(1)
-        ARU_OD = NIM_A7R1U_OD.x(1)
-        ALL_OD = NIM_A7L1L_OD.x(1)
-        ALU_OD = NIM_A7L1U_OD.x(1)
-        BRL_OD = NIM_B7R1L_OD.x(1)
-        BRU_OD = NIM_B7R1U_OD.x(1)
-        BLL_OD = NIM_B7L1L_OD.x(1)
-        BLU_OD = NIM_B7L1U_OD.x(1)
-
-        LVL1MenuItem('L1_ALFA_A7L1U').setLogic( ALU & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_A7L1L').setLogic( ALL & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_A7R1U').setLogic( ARU & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_A7R1L').setLogic( ARL & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B7L1U').setLogic( BLU & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B7L1L').setLogic( BLL & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B7R1U').setLogic( BRU & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B7R1L').setLogic( BRL & BGRP0 ).setTriggerType(TT.rpcout)
-
-        LVL1MenuItem('L1_ALFA_A7L1U_OD').setLogic( ALU_OD & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_A7L1L_OD').setLogic( ALL_OD & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B7L1U_OD').setLogic( BLU_OD & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B7L1L_OD').setLogic( BLL_OD & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_A7R1U_OD').setLogic( ARU_OD & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_A7R1L_OD').setLogic( ARL_OD & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B7R1U_OD').setLogic( BRU_OD & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B7R1L_OD').setLogic( BRL_OD & BGRP0 ).setTriggerType(TT.rpcout)
-
-        LVL1MenuItem('L1_ALFA_B7L1_OD').setLogic( ( BLU_OD & BLL_OD ) & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_A7L1_OD').setLogic( ( ALU_OD & ALL_OD ) & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_A7R1_OD').setLogic( ( ARU_OD & ARL_OD ) & BGRP0 ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B7R1_OD').setLogic( ( BRU_OD & BRL_OD ) & BGRP0 ).setTriggerType(TT.rpcout)
-        
-        LVL1MenuItem('L1_ALFA_B1_EMPTY').setLogic( ( BLU | BLL | ALU | ALL ) & cosmiccond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ALFA_B2_EMPTY').setLogic( ( ARU | ARL | BRU | BRL ) & cosmiccond ).setTriggerType(TT.rpcout)
-
-        # ALFA and MBTS 
-        LVL1MenuItem('L1_MBTS_2_A_ALFA_C').setLogic( MBTS_A.x(2) & (( ARU & BRU ) | ( ARL & BRL )) & bgrpcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MBTS_2_C_ALFA_A').setLogic( MBTS_C.x(2) & (( ALU & BLU ) | ( ALL & BLL )) & bgrpcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MBTS_2_ALFA').setLogic( MBTS_2 & ANY_ALFA & bgrpcond ).setTriggerType(TT.rpcout)
-
-        LVL1MenuItem('L1_MBTS_2_A_ALFA_C_UNPAIRED_ISO').setLogic( MBTS_A.x(2) & ((ARU & BRU) | (ARL & BRL)) & unpaired_isocond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MBTS_2_C_ALFA_A_UNPAIRED_ISO').setLogic( MBTS_C.x(2) & ((ALU & BLU) | (ALL & BLL)) & unpaired_isocond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MBTS_2_ALFA_UNPAIRED_ISO'    ).setLogic( MBTS_2 & ANY_ALFA & unpaired_isocond ).setTriggerType(TT.rpcout)
-
-        LVL1MenuItem('L1_MBTS_1_A_ALFA_C').setLogic( MBTS_A.x(1) & ((ARU & BRU) | (ARL & BRL)) & bgrpcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MBTS_1_C_ALFA_A').setLogic( MBTS_C.x(1) & ((ALU & BLU) | (ALL & BLL)) & bgrpcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MBTS_1_A_ALFA_C_UNPAIRED_ISO').setLogic( MBTS_A.x(1) & ((ARU & BRU) | (ARL & BRL)) & unpaired_isocond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_MBTS_1_C_ALFA_A_UNPAIRED_ISO').setLogic( MBTS_C.x(1) & ((ALU & BLU) | (ALL & BLL)) & unpaired_isocond ).setTriggerType(TT.rpcout)
-            
-        # ALFA and LUCID 
-        LVL1MenuItem('L1_LUCID_A_ALFA_C').setLogic( LUCID_A.x(1) & ((ARU & BRU) | (ARL & BRL)) & bgrpcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_LUCID_C_ALFA_A').setLogic( LUCID_C.x(1) & ((ALU & BLU) | (ALL & BLL)) & bgrpcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_LUCID_A_ALFA_C_UNPAIRED_ISO').setLogic( LUCID_A.x(1) & ((ARU & BRU) | (ARL & BRL)) & unpaired_isocond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_LUCID_C_ALFA_A_UNPAIRED_ISO').setLogic( LUCID_C.x(1) & ((ALU & BLU) | (ALL & BLL)) & unpaired_isocond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_LUCID_ALFA').setLogic( (LUCID_A.x(1) | LUCID_C.x(1)) & ANY_ALFA & bgrpcond ).setTriggerType(TT.rpcout)
-
-        # ALFA and ZDC
-        LVL1MenuItem('L1_ZDC_A_ALFA_C').setLogic( ZDC_A.x(1) & ((ARU & BRU) | (ARL & BRL)) & bgrpcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ZDC_C_ALFA_A').setLogic( ZDC_C.x(1) & ((ALU & BLU) | (ALL & BLL)) & bgrpcond ).setTriggerType(TT.rpcout)
-        LVL1MenuItem('L1_ZDC_ALFA').setLogic( (ZDC_A.x(1) | ZDC_C.x(1)) & ANY_ALFA & bgrpcond ).setTriggerType(TT.rpcout)
-
-        # new combined ALFA items for 2012 running
-        LVL1MenuItem('L1_EM3_ALFA_ANY'   ).setLogic( EM3.x(1) & ANY_ALFA & physcond ).setTriggerType( TT.calo | TT.caloem | TT.rpcout)
-        LVL1MenuItem('L1_EM3_ALFA_MBTS_A').setLogic( EM3.x(1) & MBTS_A.x(1) & ((BRU & ARU) | (BRL & ARL)) & physcond).setTriggerType( TT.calo | TT.caloem | TT.minb | TT.rpcout)
-        LVL1MenuItem('L1_EM3_ALFA_MBTS_C').setLogic( EM3.x(1) & MBTS_C.x(1) & ((BLU & ALU) | (BLL & ALL)) & physcond).setTriggerType( TT.calo | TT.caloem | TT.minb | TT.rpcout)
-        
-        LVL1MenuItem('L1_EM3_ALFA_ANY_UNPAIRED_ISO'   ).setLogic( EM3.x(1) & ANY_ALFA & unpaired_isocond).setTriggerType( TT.calo | TT.caloem | TT.rpcout)
-        LVL1MenuItem('L1_EM3_ALFA_MBTS_C_UNPAIRED_ISO').setLogic( EM3.x(1) & MBTS_C.x(1) & ((BLU & ALU) | (BLL & ALL)) & unpaired_isocond).setTriggerType( TT.calo | TT.caloem | TT.minb | TT.rpcout)
-        LVL1MenuItem('L1_EM3_ALFA_MBTS_A_UNPAIRED_ISO').setLogic( EM3.x(1) & MBTS_A.x(1) & ((BRU & ARU) | (BRL & ARL)) & unpaired_isocond).setTriggerType( TT.calo | TT.caloem | TT.minb | TT.rpcout)
-
-
-        LVL1MenuItem('L1_TOPO_DPHI', ctpid=300).setLogic( TOPO_DPHI.x(1) & physcond).setTriggerType( TT.calo )
-
-
-        # =======================================================
-
-        LVL1MenuItem.currentPartition = 1
-        LVL1MenuItem.l1configForRegistration = None
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1Menu/L1Seeds.py b/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1Menu/L1Seeds.py
index af77952935900dd4caae9fe05274e3843c819336..cee0b67842ad89ecb2324c757af06ce40a3dcb49 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1Menu/L1Seeds.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/python/LVL1MenuConfig/LVL1Menu/L1Seeds.py
@@ -1,4 +1,4 @@
-# Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration
+# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
 
 from AthenaCommon.Logging import logging
 log = logging.getLogger("TriggerMenuMT.LVL1MenuConfig.L1Seeds")
@@ -12,7 +12,7 @@ from TriggerMenuMT.LVL1MenuConfig.LVL1.Lvl1Flags import Lvl1Flags
 run1 = Lvl1Flags.CTPVersion()<=3
 
 if run1:
-    from TriggerMenu.l1.TriggerTypeDefRun1 import TT
+    from TriggerMenuMT.LVL1MenuConfig.LVL1.TriggerTypeDefRun1 import TT
     rpcout_type = TT.rpcout | TT.phys
     rpcin_type  = TT.rpcin  | TT.phys             
 else:
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/scripts/generateMenuMT.py b/Trigger/TriggerCommon/TriggerMenuMT/scripts/generateMenuMT.py
deleted file mode 100644
index c98b0ae0c8cec78fb52f3ff326cd241d834dabbe..0000000000000000000000000000000000000000
--- a/Trigger/TriggerCommon/TriggerMenuMT/scripts/generateMenuMT.py
+++ /dev/null
@@ -1,42 +0,0 @@
-# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-
-# import flags
-doWriteRDOTrigger = False
-doWriteBS = False
-include("TriggerJobOpts/runHLT_standalone.py")  # noqa: F821
-
-#################################
-# Configure L1Decoder
-#################################
-
-# provide a minimal menu information
-from AthenaCommon.GlobalFlags import globalflags
-from AthenaCommon.AlgSequence import AlgSequence
-topSequence = AlgSequence()
-if globalflags.InputFormat.is_bytestream():
-   from AthenaCommon.Constants import DEBUG
-   topSequence.L1Decoder.ctpUnpacker.OutputLevel=DEBUG  # noqa: ATL900
-
-
-
-# this is a temporary hack to include new test chains
-# very hacky indeed, the L1 part should be in in the GenerateMenuMT part
-
-from TriggerJobOpts.TriggerFlags import TriggerFlags
-TriggerFlags.triggerMenuSetup = "LS2_v1"
-
-from TriggerMenuMT.HLTMenuConfig.Menu.GenerateMenuMT import GenerateMenuMT
-g = GenerateMenuMT()
-
-
-
-
-
-##########################################
-# Menu and CF construction
-##########################################
-g.generateMT()
-
-
-
-
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/scripts/testMenuMT.sh b/Trigger/TriggerCommon/TriggerMenuMT/scripts/testMenuMT.sh
deleted file mode 100755
index c26ea2bbdf29e7c550167f8ee7616260378954c6..0000000000000000000000000000000000000000
--- a/Trigger/TriggerCommon/TriggerMenuMT/scripts/testMenuMT.sh
+++ /dev/null
@@ -1,82 +0,0 @@
-#!/usr/bin/env sh
-
-help() {
-    echo "Syntax: testMenuMT.sh [-r VERSION] MENU [DEST]"
-}
-
-if [ $# -lt 1 ]; then
-    help
-    exit 0
-fi
-
-while true; do
-    case "$1" in
-        -r)
-            release=$2
-            shift 2
-            ;;
-        -h)
-            help
-            exit 0
-            ;;
-        -*)
-            echo "Invalid parameter"
-            exit 1
-            ;;
-        *)
-            break
-    esac
-done
-
-menu=$1
-dest=$2
-if [ -z "$dest" ]; then
-    dest=$PWD
-fi
-
-# Get absolute path name
-dest=`cd $dest; pwd`
-
-if [ -z "$release" ]; then
-    release=${AtlasVersion}    # for interactive use
-fi
-
-# Temporary run directroy and cleanup traps in case of termination
-rundir=`mktemp -t -d tmxml.${menu}.XXXXXXXXXX`
-TRAPINT() {
-    rm -rf $rundir
-    return 130 # 128+SIGINT
-}
-TRAPTERM() {
-    rm -rf $rundir
-    return 143 # 128+SIGTERM
-}
-
-
-## menu generation starts here
-echo "generateHLTMenuMT: Building menu: ${menu} for ${release}"
-logfiletopo=topo${menu}.log
-logfilelvl1=lvl1${menu}.log
-logfilehlt=hlt${menu}.log
-cd $rundir
-
-generateLVL1MenuMT.py $menu &> $logfiletopo 
-generateL1TopoMenuMT.py $menu &> $logfilelvl1 
-generateMenuMT.py $menu &> $logfilehlt
-
-cp L1Topoconfig_*.xml ${dest}
-cp LVL1config_*.xml ${dest}
-#cp $logfilelvl1 $logfiletopo ${dest}
-
-if [[ -e outputLVL1config.xml ]]; then
-    cp outputLVL1config.xml ${dest}/LVL1config_${menu}_${release}.xml
-fi
-
-#this gives some more sensitivity to hidden problems
-grep --colour ERROR ${dest}/$logfile
-grep --colour -A 100 "Shortened traceback" ${dest}/$logfile
-
-rm -rf $rundir
-
-# Do not return real athena exit code as we want to pretend everything was fine
-#unset PYTHONDONTWRITEBYTECODE
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/scripts/test_HLTmenu.sh b/Trigger/TriggerCommon/TriggerMenuMT/scripts/test_HLTmenu.sh
index bce1f232c39ffb24e91e73423ebffe21e662e314..1dd24c210961f334a335cf5d872a8e5934a4f7b2 100755
--- a/Trigger/TriggerCommon/TriggerMenuMT/scripts/test_HLTmenu.sh
+++ b/Trigger/TriggerCommon/TriggerMenuMT/scripts/test_HLTmenu.sh
@@ -2,6 +2,6 @@
 
 set -e
 
-athena --config-only=config.pkl -l DEBUG --threads=1 --skipEvents=10 --evtMax=20 --filesInput="/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1" TriggerMenuMT/generateMT.py;
+athena --config-only=config.pkl --threads=1 --filesInput="/cvmfs/atlas-nightlies.cern.ch/repo/data/data-art/TrigP1Test/data17_13TeV.00327265.physics_EnhancedBias.merge.RAW._lb0100._SFO-1._0001.1" -c "setMenu='LS2_v1'" TriggerJobOpts/runHLT_standalone.py
 
 verify_menu_config.py -f $PWD || { echo "ERROR: Menu verification failed" ; exit 1; }
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/share/full_menu_cf.py b/Trigger/TriggerCommon/TriggerMenuMT/share/full_menu_cf.py
index 67529e23aa56629f39f4fdabcfb3347b42778615..b76dd9b1d0616fa0fe3f9bc2bea072f9deaa9b20 100644
--- a/Trigger/TriggerCommon/TriggerMenuMT/share/full_menu_cf.py
+++ b/Trigger/TriggerCommon/TriggerMenuMT/share/full_menu_cf.py
@@ -13,14 +13,14 @@
 ##########################################
 
 def generateChains():
-    from TriggerMenuMT.HLTMenuConfig.Menu.MenuComponents import Chain, ChainStep, RecoFragmentsPool
+    from TriggerMenuMT.HLTMenuConfig.Menu.MenuComponents import RecoFragmentsPool
     from DecisionHandling.TestUtils import makeChain, makeChainStep
     
     testChains = []
     ##################################################################
     # egamma chains
     ##################################################################
-    if opt.doEgammaSlice == True:
+    if opt.doEgammaSlice is True:
         from TriggerMenuMT.HLTMenuConfig.Egamma.ElectronDef import electronFastCaloCfg, fastElectronSequenceCfg, precisionCaloSequenceCfg
         fastCaloSeq = RecoFragmentsPool.retrieve( electronFastCaloCfg, None )
         electronSeq = RecoFragmentsPool.retrieve( fastElectronSequenceCfg, None )
@@ -56,7 +56,7 @@ def generateChains():
     ##################################################################
     # muon chains
     ##################################################################
-    if opt.doMuonSlice == True:
+    if opt.doMuonSlice is True:
         from TriggerMenuMT.HLTMenuConfig.Muon.MuonSequenceSetup import muFastSequence, muCombSequence, muEFSASequence, muEFCBSequence, muEFSAFSSequence, muEFCBFSSequence
 
         MuonChains  = []
@@ -87,19 +87,12 @@ def generateChains():
         step1_2mufast_sym= makeChainStep("Step1_2muFast_sym", [ mufastS], multiplicity=[2])
         step2_2muComb_sym= makeChainStep("Step2_2muComb_sym", [ mucombS], multiplicity=[2])
     
-        step3_2muEFSA_sym= makeChainStep("Step3_2muEFSA_sym", [ muEFSAS], multiplicity=[2])
-        step4_2muEFCB_sym= makeChainStep("Step4_2muEFCB_sym", [ muEFCBS], multiplicity=[2])
- 
         MuonChains += [ makeChain(name='HLT_2mu6Comb_L12MU6',  L1Thresholds=["MU6"], ChainSteps=[ step1_2mufast_sym, step2_2muComb_sym ])]
 
         # 2muons asymmetric (this will change): 2 sequences, 2 seeds
         step1_2mufast_asym= makeChainStep("Step1_2muFast_asym", [ mufastS, mufastS], multiplicity=[1,1])
         step2_2muComb_asym= makeChainStep("Step1_2muComb_asym", [ mucombS, mucombS], multiplicity=[1,1])
     
-        step3_2muEFSA_asym= makeChainStep("Step3_2muEFSA_asym", [ muEFSAS, muEFSAS], multiplicity=[1,1])
-        step4_2muEFCB_asym= makeChainStep("Step4_2muEFCB_asym", [ muEFCBS, muEFCBS], multiplicity=[1,1])
-        
-    
         MuonChains += [ makeChain(name='HLT_mu6_mu4_L12MU4',
                                 L1Thresholds=["MU4", "MU6"],
                                 ChainSteps=[ step1_2mufast_asym, step2_2muComb_asym ])]        
@@ -135,7 +128,7 @@ def generateChains():
         from TriggerMenuMT.HLTMenuConfig.Jet.JetMenuSequences import jetTrackingHypoMenuSequence
         return jetTrackingHypoMenuSequence(ConfigFlags, clustersKey=clustersKey, **jetRecoDict)
 
-    if opt.doJetSlice == True:
+    if opt.doJetSlice is True:
 
         # small-R jets
         jetSeq_a4_tc_em = jetCaloHypoMenuSequenceFromString("a4_tc_em_subjesIS")
@@ -177,7 +170,7 @@ def generateChains():
     ##################################################################
     # bjet chains
     ##################################################################
-    if opt.doBjetSlice == True:
+    if opt.doBjetSlice is True:
         from TriggerMenuMT.HLTMenuConfig.Bjet.BjetSequenceSetup import getBJetSequence
 
         jetSeq_a4_tc_em_presel, emclusters = jetCaloPreselMenuSequenceFromString("a4_tc_em_subjesIS")
@@ -198,7 +191,7 @@ def generateChains():
         ##################################################################
     # tau chains
     ##################################################################
-    if opt.doTauSlice == True and False:
+    if opt.doTauSlice is True and False:  # not working at the moment
         from TriggerMenuMT.HLTMenuConfig.Tau.TauMenuSequences import getTauSequence
 
         step1=makeChainStep("Step1_tau", [getTauSequence('calo')])
@@ -221,8 +214,7 @@ def generateChains():
     ##################################################################
     # MET chains
     ##################################################################
-    if opt.doMETSlice == True:
-        from TriggerMenuMT.HLTMenuConfig.MET.METMenuSequences import metMenuSequence
+    if opt.doMETSlice is True:
         from TriggerMenuMT.HLTMenuConfig.MET.METChainConfiguration import extractMETRecoDict
         from TriggerMenuMT.HLTMenuConfig.MET.ConfigHelpers import AlgConfig
 
@@ -250,7 +242,7 @@ def generateChains():
     ##################################################################
     # B-physics and light states chains
     ##################################################################
-    if opt.doBphysicsSlice == True:
+    if opt.doBphysicsSlice is True:
         from TriggerMenuMT.HLTMenuConfig.Muon.MuonSequenceSetup import muFastSequence, muCombSequence, muEFSASequence, muEFCBSequence
         from TrigBphysHypo.TrigMultiTrkComboHypoConfig import DimuL2ComboHypoCfg, DimuEFComboHypoCfg
         
@@ -273,14 +265,14 @@ def generateChains():
     ##################################################################
     # combined chains
     ##################################################################
-    if opt.doCombinedSlice == True:
+    if opt.doCombinedSlice is True:
         from TriggerMenuMT.HLTMenuConfig.Egamma.ElectronDef import electronFastCaloCfg
         fastCaloSeq = RecoFragmentsPool.retrieve( electronFastCaloCfg, None )
         
         from TriggerMenuMT.HLTMenuConfig.Muon.MuonSequenceSetup import muFastSequence
         
         comboStep_et_mufast           = makeChainStep("Step1_et_mufast", [fastCaloSeq, muFastSequence()], multiplicity=[1,1])
-        comboStep_mufast_etcut1_step1 = makeChainStep("Step1_mufast_etcut1", [muFastSequence(), fastCaloSeq], multiplicity=[1,1])
+    #   comboStep_mufast_etcut1_step1 = makeChainStep("Step1_mufast_etcut1", [muFastSequence(), fastCaloSeq], multiplicity=[1,1])
         
         comboChains =  [ makeChain(name='HLT_e3_etcut_mu6_L1EM8I_MU10', L1Thresholds=["EM8I", "MU10"],  ChainSteps=[comboStep_et_mufast ])]
     #   comboChains += [Chain(name='HLT_mu8fast_e8_etcut1step',   ChainSteps=[ comboStep_mufast_etcut1_step1 ])]
@@ -315,7 +307,5 @@ generateJSON()
 from TriggerMenuMT.HLTMenuConfig.Menu.HLTPrescaleJSON import generateJSON as generatePrescaleJSON
 generatePrescaleJSON()
    
-from AthenaCommon.AlgSequence import dumpSequence, AthSequencer
+from AthenaCommon.AlgSequence import dumpSequence
 dumpSequence(topSequence)
-    
-    
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/share/generateMT.py b/Trigger/TriggerCommon/TriggerMenuMT/share/generateMT.py
deleted file mode 100755
index 9f5039fe5a8d35d0942a26ec1af5698299978df6..0000000000000000000000000000000000000000
--- a/Trigger/TriggerCommon/TriggerMenuMT/share/generateMT.py
+++ /dev/null
@@ -1,10 +0,0 @@
-# Copyright (C) 2002-2020 CERN for the benefit of the ATLAS collaboration
-
-setMenu             = "LS2_v1"
-doWriteRDOTrigger   = False
-doWriteBS           = False
-endJobAfterGenerate = False
-from TriggerJobOpts.TriggerFlags import TriggerFlags
-TriggerFlags.generateMenuDiagnostics = True
-include("TriggerJobOpts/runHLT_standalone.py")
-
diff --git a/Trigger/TriggerCommon/TriggerMenuMT/share/trigermenuMT_test.py b/Trigger/TriggerCommon/TriggerMenuMT/share/trigermenuMT_test.py
deleted file mode 100644
index 9f64d82acfc6014771f18b52d797af877cf8cbff..0000000000000000000000000000000000000000
--- a/Trigger/TriggerCommon/TriggerMenuMT/share/trigermenuMT_test.py
+++ /dev/null
@@ -1,55 +0,0 @@
-#
-# Minimal example to build a trigger menu
-#
-from TriggerMenuMT.LVL1MenuConfig.TriggerConfigLVL1 import TriggerConfigLVL1            
-from TriggerMenuMT.LVL1MenuConfig.LVL1.Lvl1Flags import Lvl1Flags
-from TriggerMenuMT.LVL1MenuConfig.LVL1.Lvl1MenuItems import LVL1MenuItem
-from TriggerMenuMT.L1.Config.TriggerTypeDef import TT
-from TriggerMenuMT.LVL1MenuConfig.LVL1.Lvl1Condition import ThrCondition, Lvl1InternalTrigger
-from TriggerMenuMT.L1.Base.Logic import Logic
-
-# Define L1 menu thresholds and items
-Lvl1Flags.RemapThresholdsAsListed = True
-Lvl1Flags.thresholds = ['EM3','MU4']
-Lvl1Flags.items = ['L1_EM3','L1_MU4']
-
-l1menu = TriggerConfigLVL1( outputFile = 'l1menu.xml', 
-                            menuName = 'menutest',
-                            topoMenu = None )
-
-LVL1MenuItem.l1configForRegistration = l1menu
-
-# Register L1 menu
-bgrp = Logic(Lvl1InternalTrigger('BGRP0')) & Logic(Lvl1InternalTrigger('BGRP1'))
-
-EM3 = l1menu.registerThr('EM3','EM').addThrValue(3)
-LVL1MenuItem('L1_EM3'       ).setLogic( ThrCondition(EM3) & bgrp ).setTriggerType( TT.calo )
-
-MU4 = l1menu.registerThr('MU4','MUON').addThrValue(4)
-LVL1MenuItem('L1_MU4'       ).setLogic( ThrCondition(MU4) & bgrp ).setTriggerType( TT.muon )
-
-# Generate and write L1 menu
-l1menu.generateMenu()        
-l1menu.writeXML()
-
-
-from TriggerMenu.menu.TriggerPythonConfig import TriggerPythonConfig
-from TriggerMenu.menu.HLTObjects import HLTChain
-hltmenu = TriggerPythonConfig('hltmenu.xml')
-
-from TrigSteeringTest.TrigSteeringTestConf import PESA__dummyAlgo
-defalgo = PESA__dummyAlgo('Em3')
-hltmenu.addSequence("EM3" , defalgo, "em3" )
-
-chain = HLTChain( chain_name="HLT_e3", chain_counter="1", lower_chain_name="EM3", level = "HLT", prescale="1", pass_through="1")
-chain.addHLTSignature( "em3" ).addHLTSignature( "em3" )
-chain.addTriggerTypeBit('4')
-chain.addStreamTag('electrons', prescale='1', obeyLB="yes")
-chain.addStreamTag('IDCalibration', prescale='1', obeyLB="no", type="calibration")
-chain.addGroup("electrons")
-hltmenu.addHLTChain(chain)
-
-hltmenu.writeConfigFiles();
-
-import sys
-sys.exit(0)
diff --git a/Trigger/TriggerSimulation/TrigSimTransforms/share/athena_RDOtoBS.py b/Trigger/TriggerSimulation/TrigSimTransforms/share/athena_RDOtoBS.py
index 61caf0feea3fa0fe7c6e96fc12f3a5974a375588..3214c045ed41a1c0bdd1731e354380ecc1059bdf 100644
--- a/Trigger/TriggerSimulation/TrigSimTransforms/share/athena_RDOtoBS.py
+++ b/Trigger/TriggerSimulation/TrigSimTransforms/share/athena_RDOtoBS.py
@@ -76,8 +76,7 @@ recAlgs.doTrigger.set_Value_and_Lock(True)
 
 # Config trigger
 TriggerFlags.doLVL1.set_Value_and_Lock(True)   # this should be disabled in the future
-TriggerFlags.doLVL2.set_Value_and_Lock(False)
-TriggerFlags.doEF.set_Value_and_Lock(False)
+TriggerFlags.doHLT.set_Value_and_Lock(False)
 #-------------------------------------------------------------------------------
 TriggerFlags.configurationSourceList.set_Value_and_Lock(["xml"])
 
diff --git a/Trigger/TriggerSimulation/TrigSimTransforms/share/skeleton.BStoTRIGBS.fails.py b/Trigger/TriggerSimulation/TrigSimTransforms/share/skeleton.BStoTRIGBS.fails.py
index 5057d3d6c75af0363c4307547ce0b24b1d57892a..d99521e334846e1c0da4de3416eb0fcd6bec9edb 100644
--- a/Trigger/TriggerSimulation/TrigSimTransforms/share/skeleton.BStoTRIGBS.fails.py
+++ b/Trigger/TriggerSimulation/TrigSimTransforms/share/skeleton.BStoTRIGBS.fails.py
@@ -68,14 +68,11 @@ topSequence = AlgSequence()
 
 # Trying manual setup of L1 instead of automatic (throgh L1ConfigGetter).
 TriggerFlags.doLVL1 = False
-TriggerFlags.doLVL2 = True
-TriggerFlags.doEF = True
+TriggerFlags.doHLT = True
 
 TriggerFlags.doTruth.set_Value_and_Lock(False)
 
-TriggerFlags.doHLTpersistency = True
 TriggerFlags.writeBS = True
-TriggerFlags.abortOnConfigurationError = True
 
 TriggerFlags.enableMonitoring = []
 
@@ -337,8 +334,6 @@ hlt = HLTSimulationGetter()
 
 rng = getattr(ToolSvc,'HLT::RandomScaler')
 rng.useEventSeed = True
-#EF gets an extra seed "hash-offset" of 1 to make it independent of L2
-rng.config(seed=int(TriggerFlags.doEF()), luxury=2)
 
 ### End of the mess.....
 ###############################
diff --git a/graphics/VP1/VP1Systems/VP1TrackSystems/VP1TrackSystems/TrackHandle_TruthTrack.h b/graphics/VP1/VP1Systems/VP1TrackSystems/VP1TrackSystems/TrackHandle_TruthTrack.h
index 7a9108728c65f001e2ddf07437186678ab2b6427..6eeb20eb31a1219d487b714a933556e3a356a093 100644
--- a/graphics/VP1/VP1Systems/VP1TrackSystems/VP1TrackSystems/TrackHandle_TruthTrack.h
+++ b/graphics/VP1/VP1Systems/VP1TrackSystems/VP1TrackSystems/TrackHandle_TruthTrack.h
@@ -31,7 +31,7 @@ public:
   TrackHandle_TruthTrack( TrackCollHandleBase*,
 			  const SimBarCode&,
 			  const SimHitList&,
-			  const HepMC::GenParticle* genPart = 0 );
+			  HepMC::ConstGenParticlePtr genPart = nullptr );
 
   virtual ~TrackHandle_TruthTrack();
 
diff --git a/graphics/VP1/VP1Systems/VP1TrackSystems/src/TrackCollHandle_TruthTracks.cxx b/graphics/VP1/VP1Systems/VP1TrackSystems/src/TrackCollHandle_TruthTracks.cxx
index da876623a4f351bf0387c13c7381c73b604f397f..b35dbbb6a3744369b0fa0cea6d957ab7a6f5ba1e 100644
--- a/graphics/VP1/VP1Systems/VP1TrackSystems/src/TrackCollHandle_TruthTracks.cxx
+++ b/graphics/VP1/VP1Systems/VP1TrackSystems/src/TrackCollHandle_TruthTracks.cxx
@@ -58,9 +58,9 @@ public:
 
   TrackCollHandle_TruthTracks * theclass;
   bool loadHitLists(std::map<SimBarCode,SimHitList> & hitLists);
-  void loadGenParticles( std::map<SimBarCode,const HepMC::GenParticle*> & genParticles,
-			 const HepMC::GenVertex* vtx );
-  bool loadGenParticles( std::map<SimBarCode,const HepMC::GenParticle*> & genParticles,
+  void loadGenParticles( std::map<SimBarCode,HepMC::ConstGenParticlePtr> & genParticles,
+			 HepMC::ConstGenVertexPtr vtx );
+  bool loadGenParticles( std::map<SimBarCode,HepMC::ConstGenParticlePtr> & genParticles,
 			 const QString& hepMcCollKey );
 
   template <class collT>
@@ -99,7 +99,7 @@ public:
   bool displayAscObjs;
   void updateVisibleAssociatedObjects();
 
-  bool fixMomentumInfoInSimHits(const HepMC::GenParticle* p,SimHitList& hitlist);
+  bool fixMomentumInfoInSimHits(HepMC::ConstGenParticlePtr p,SimHitList& hitlist);
 
   static const int maxPdgCode = 1000000000;
 
@@ -316,23 +316,27 @@ void TrackCollHandle_TruthTracks::fixPDGCode(SimHitHandleBase* handle) const
 }
 
 //____________________________________________________________________
-void TrackCollHandle_TruthTracks::Imp::loadGenParticles( std::map<SimBarCode,const HepMC::GenParticle*> & genParticles,
-							 const HepMC::GenVertex* vtx )
+void TrackCollHandle_TruthTracks::Imp::loadGenParticles( std::map<SimBarCode,HepMC::ConstGenParticlePtr> & genParticles,
+							 HepMC::ConstGenVertexPtr vtx )
 {
   if (!vtx)
     return;
+#ifdef HEPMC3
+  for (auto p: vtx->particles_out()){
+#else    
   HepMC::GenVertex::particles_out_const_iterator itPart(vtx->particles_out_const_begin());
   HepMC::GenVertex::particles_out_const_iterator itPartEnd(vtx->particles_out_const_end());
 
   for (;itPart!=itPartEnd;++itPart) {
     const HepMC::GenParticle* p = *itPart;
+#endif
     if (!p)//fixme: message.
       continue;
     const HepMC::GenEvent* evt = p->parent_event();
     if (!evt)
       continue;//fixme: message.
     //Fixme: If verbose: check barcode does not already exists!
-    SimBarCode simBarCode(p->barcode(),0/*evt->event_number()...fixme: correct??*/,p->pdg_id());
+    SimBarCode simBarCode(HepMC::barcode(p),0/*evt->event_number()...fixme: correct??*/,p->pdg_id());
     genParticles[simBarCode] = p;
     if (!simBarCode.isNonUniqueSecondary())
       extBarCode2pdg[simBarCode.extBarCode()] = p->pdg_id();
@@ -342,7 +346,7 @@ void TrackCollHandle_TruthTracks::Imp::loadGenParticles( std::map<SimBarCode,con
 }
 
 //____________________________________________________________________
-bool TrackCollHandle_TruthTracks::Imp::loadGenParticles( std::map<SimBarCode,const HepMC::GenParticle*> & genParticles,
+bool TrackCollHandle_TruthTracks::Imp::loadGenParticles( std::map<SimBarCode,HepMC::ConstGenParticlePtr> & genParticles,
 							 const QString& hepMcCollKey )
 {
   possiblyUpdateGUI();
@@ -361,10 +365,14 @@ bool TrackCollHandle_TruthTracks::Imp::loadGenParticles( std::map<SimBarCode,con
     const HepMC::GenEvent * evt = *itEvt;
     if (!evt)
       continue;
+#ifdef HEPMC3
+   for(auto itVtx: evt->vertices()) loadGenParticles(genParticles,itVtx);
+#else
     HepMC::GenEvent::vertex_const_iterator itVtx(evt->vertices_begin()), itVtxEnd(evt->vertices_end());
     for(;itVtx!=itVtxEnd;++itVtx) {
       loadGenParticles(genParticles,*itVtx);
     }
+#endif
   }
 
   return true;
@@ -384,7 +392,7 @@ bool TrackCollHandle_TruthTracks::load()
   }
 
   //get genparticles (should be done BEFORE we load sim. hits., so the barCode2pdg map gets filled):
-  std::map<SimBarCode,const HepMC::GenParticle*> genParticles;
+  std::map<SimBarCode,HepMC::ConstGenParticlePtr> genParticles;
   if (!hepmckey.isEmpty())
     if (!m_d->loadGenParticles(genParticles,hepmckey))
       return false;
@@ -408,7 +416,7 @@ bool TrackCollHandle_TruthTracks::load()
   //handles for the remaining genparticle (unless they have production
   //and decay vertices ultra-close to each other):
 
-  std::map<SimBarCode,const HepMC::GenParticle*>::iterator itGenPart, itGenPartEnd(genParticles.end());
+  std::map<SimBarCode,HepMC::ConstGenParticlePtr>::iterator itGenPart, itGenPartEnd(genParticles.end());
   std::map<SimBarCode,SimHitList>::iterator itHitList, itHitListEnd(hitLists.end()), itHitListTemp;
 
   //First we attempt to sort secondaries with barcode=0 into new lists
@@ -439,7 +447,7 @@ bool TrackCollHandle_TruthTracks::load()
       continue;
     }
     itGenPart = genParticles.find(itHitList->first);
-    const HepMC::GenParticle * p(0);
+    HepMC::ConstGenParticlePtr p{nullptr};
     if (itGenPart!=itGenPartEnd) {
       p = itGenPart->second;
       itGenPart->second = 0;
@@ -454,7 +462,7 @@ bool TrackCollHandle_TruthTracks::load()
   const double minSpacialSeparation = 1.0e-3*CLHEP::mm;
   const double minSepSq = minSpacialSeparation*minSpacialSeparation;
   for (itGenPart=genParticles.begin();itGenPart!=itGenPartEnd;++itGenPart) {
-    const HepMC::GenParticle * p = itGenPart->second;
+    auto p = itGenPart->second;
     if (!p)
       continue;
      if (abs(p->pdg_id())>=Imp::maxPdgCode)//Internal particle... (fixme: find proper limit!!)
@@ -746,7 +754,7 @@ std::list<SimHitHandleBase*>::iterator TrackCollHandle_TruthTracks::Imp::closest
 
 
 //____________________________________________________________________
-bool TrackCollHandle_TruthTracks::Imp::fixMomentumInfoInSimHits(const HepMC::GenParticle* p,SimHitList& hitlist) {
+bool TrackCollHandle_TruthTracks::Imp::fixMomentumInfoInSimHits(HepMC::ConstGenParticlePtr p,SimHitList& hitlist) {
   //Returns false only if we prune down to zero information!
 
   if (hitlist.empty())
@@ -756,7 +764,7 @@ bool TrackCollHandle_TruthTracks::Imp::fixMomentumInfoInSimHits(const HepMC::Gen
   static double unknown = -1.0e99;
   double mom(unknown), time(unknown);
   if (p) {
-    const HepMC::GenVertex * v = p->production_vertex();
+    auto v = p->production_vertex();
     if (v) {
       mom = mag(p->momentum());
       time = v->position().t()/CLHEP::c_light;
diff --git a/graphics/VP1/VP1Systems/VP1VertexSystems/src/VP1TruthVertexCollection.cxx b/graphics/VP1/VP1Systems/VP1VertexSystems/src/VP1TruthVertexCollection.cxx
index bb6a0e5d696038099008e110b35905928f536cf2..d091a94b7dc3b395cb37adcffef34c256f2e75cb 100644
--- a/graphics/VP1/VP1Systems/VP1VertexSystems/src/VP1TruthVertexCollection.cxx
+++ b/graphics/VP1/VP1Systems/VP1VertexSystems/src/VP1TruthVertexCollection.cxx
@@ -109,18 +109,23 @@ public:
       vertices->vertex.set1Value ( 4, x, y,z-extent );
       vertices->vertex.set1Value ( 5, x, y,z+extent );
     }
-    const HepMC::GenVertex * vertex() const { return m_vertex; }
+    HepMC::ConstGenVertexPtr vertex() const { return m_vertex; }
     SoLineSet * line() const { return m_line; }
 
     double quantityVal(const VertexCommonFlags::QUANTITY& q) {
       //Find total 4-momentum of incoming particles
       double px(0), py(0), pz(0), e(0);//HepMC::FourVector does NOT support operators + or += !!!!!!
+#ifdef HEPMC3
+      for (auto PartIn:  m_vertex->particles_in()){
+#else
       HepMC::GenVertex::particles_in_const_iterator itPartIn,itPartInE(m_vertex->particles_in_const_end());
       for ( itPartIn = m_vertex->particles_in_const_begin();itPartIn!=itPartInE;++itPartIn) {
-	px += (*itPartIn)->momentum().px();
-	py += (*itPartIn)->momentum().py();
-	pz += (*itPartIn)->momentum().pz();
-	e += (*itPartIn)->momentum().e();
+      auto PartIn=*itPartIn;
+#endif
+	px +=PartIn->momentum().px();
+	py +=PartIn->momentum().py();
+	pz +=PartIn->momentum().pz();
+	e += PartIn->momentum().e();
       }
       const HepMC::FourVector mom(px,py,pz,e);
       switch(q) {
@@ -172,7 +177,7 @@ public:
       return false;
     }
     bool m_attached;
-    const HepMC::GenVertex * m_vertex;
+    HepMC::ConstGenVertexPtr  m_vertex;
     SoLineSet * m_line;
     VP1TruthVertexCollection::Imp * m_d;
   };
@@ -250,9 +255,13 @@ bool VP1TruthVertexCollection::load()
     if (!genEvent)
       continue;
 
+#ifdef HEPMC3
+     for (auto vtx:  genEvent->vertices()) {
+#else
     HepMC::GenEvent::vertex_const_iterator itVertex, itVertexEnd(genEvent->vertices_end());
     for (itVertex = genEvent->vertices_begin(); itVertex != itVertexEnd; itVertex++ ) {
-      const HepMC::GenVertex * vtx(*itVertex);
+      auto  vtx=*itVertex;
+#endif
       if (!vtx)
 	continue;
       m_d->vertices << new Imp::VertexHandle(vtx,m_d);
@@ -279,31 +288,40 @@ QStringList VP1TruthVertexCollection::infoOnClicked(SoPath* pickedPath)
   }
   if (!vertexHandle)
     return QStringList() << "ERROR: Could not get truth vertex information for picked Node";
-  const HepMC::GenVertex * vtx = vertexHandle->vertex();
+  HepMC::ConstGenVertexPtr vtx = vertexHandle->vertex();
 
   QStringList l;
   if (m_d->controller->printInfoOnClick()) {
 
     //Make output:
     l <<"Truth vertex from collection "+text()+":" ;
-
+#ifdef HEPMC3
+     for ( auto PartIn: vtx->particles_in()) {
+#else
     HepMC::GenVertex::particles_in_const_iterator itPartIn,itPartInE(vtx->particles_in_const_end());
     for ( itPartIn = vtx->particles_in_const_begin();itPartIn!=itPartInE;++itPartIn) {
-      const int pdg = (*itPartIn)->pdg_id();
+      auto PartIn=*itPartIn;
+#endif
+      const int pdg = PartIn->pdg_id();
       bool ok;
       QString name = VP1ParticleData::particleName(pdg,ok);
       if (!ok)
 	name = "<unknown>";
-      l << "--> In: "+name+" ("+str(pdg)+")  [ P = "+str(m_d->mag((*itPartIn)->momentum())/Gaudi::Units::GeV)+" GeV ]";
+      l << "--> In: "+name+" ("+str(pdg)+")  [ P = "+str(m_d->mag(PartIn->momentum())/Gaudi::Units::GeV)+" GeV ]";
     }
+#ifdef HEPMC3
+     for ( auto PartOut: vtx->particles_out()) {
+#else
     HepMC::GenVertex::particles_out_const_iterator itPartOut,itPartOutE(vtx->particles_out_const_end());
     for ( itPartOut = vtx->particles_out_const_begin();itPartOut!=itPartOutE;++itPartOut) {
-      const int pdg = (*itPartOut)->pdg_id();
+      auto PartOut=*itPartOut;
+#endif
+      const int pdg = PartOut->pdg_id();
       bool ok;
       QString name = VP1ParticleData::particleName(pdg,ok);
       if (!ok)
 	name = "<unknown>";
-      l << "--> Out: "+name+" ("+str(pdg)+")  [ P = "+str(m_d->mag((*itPartOut)->momentum())/Gaudi::Units::GeV)+" GeV ]";
+      l << "--> Out: "+name+" ("+str(pdg)+")  [ P = "+str(m_d->mag(PartOut->momentum())/Gaudi::Units::GeV)+" GeV ]";
     }
 
     if (m_d->controller->printVerboseInfoOnClick()) {