diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/AthenaPoolTestWrite.py b/AtlasTest/DatabaseTest/AthenaPoolTest/share/AthenaPoolTestWrite.py index 6c2472465406e4b2f49461b9e8a6adce66d420c3..5fc8b48b3395a2facecf65c497c31ae23a4c8dfd 100755 --- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/AthenaPoolTestWrite.py +++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/AthenaPoolTestWrite.py @@ -13,10 +13,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -gbl.AthenaServices.SetFatalHandler(438) - - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() @@ -27,6 +23,9 @@ from AthenaCommon.AppMgr import ServiceMgr as svcMgr ## get a handle to the ApplicationManager from AthenaCommon.AppMgr import theApp +# Set handler for traceback +svcMgr.CoreDumpSvc.FatalHandler = 438 + #-------------------------------------------------------------- # Load POOL support #-------------------------------------------------------------- diff --git a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.py b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.py index af7bd07c828aaf2211d6c15cfcd5dd915a84847a..4efa3fc4e2a70824c9503337e8f554ed81a1c789 100755 --- a/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.py +++ b/AtlasTest/DatabaseTest/AthenaPoolTest/share/EventInfoWrite.py @@ -13,10 +13,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllReadCool.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllReadCool.py index acf11bd900242def1836fd56f562eb4b164df466..978e94b7686524b5af6ecab6023c52b5326f6249 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllReadCool.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllReadCool.py @@ -7,9 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - #import password for devdb10 from devdb10pwd.py from devdb10_pwd import devdb10pwd diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllWriteCool.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllWriteCool.py index 282f4cd98d04689f1d7da46effb96b4b130881ab..4a38dbff0a526af4914183dd3753998e12e1ff8a 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllWriteCool.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/AllWriteCool.py @@ -1,5 +1,4 @@ import AthenaCommon.AtlasUnixGeneratorJob -gbl.AthenaServices.SetFatalHandler(438) from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() from AthenaCommon.AppMgr import ServiceMgr as svcMgr @@ -10,6 +9,8 @@ from devdb10_pwd import devdb10pwd import IOVDbSvc.IOVDb +svcMgr.CoreDumpSvc.FatalHandler = 438 + from IOVDbTestAlg.IOVDbTestAlgConf import IOVDbTestAlg topSequence += IOVDbTestAlg( "IOVDbTestAlg" ) diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCool.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCool.py index 0f988a2ba809b81fadbe78d918c397fef5d90400..cc9e6a4da2603e212990391c421a64915843a39c 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCool.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCool.py @@ -7,9 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAfterTwoStep.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAfterTwoStep.py index 5e65fb0af50f7bfd24e815ee1ef6faba6c41c3fe..91f6f2725338c5db45d718b301c36e3c4e34eb7c 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAfterTwoStep.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAfterTwoStep.py @@ -6,9 +6,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAndReg.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAndReg.py index d0d1372a0c840ead36160d20be2b518300ed302a..512575927b3559dca9f4a45e5ca32fbb92821e54 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAndReg.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolAndReg.py @@ -7,9 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolFromMetaData.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolFromMetaData.py index 51194796060552be9ae40720346b1174cc19d08b..f1328760141e9ba628447b3e8c8cb30d5bfbf5bf 100644 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolFromMetaData.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolFromMetaData.py @@ -6,9 +6,6 @@ ## basic job configuration import AthenaCommon.AtlasUnixStandardJob -# Set handler for traceback -gbl.AthenaServices.SetFatalHandler(438) - ## get a handle on the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() @@ -31,6 +28,9 @@ from AthenaCommon.AppMgr import ServiceMgr as svcMgr ## get a handle on the ToolSvc from AthenaCommon.AppMgr import ToolSvc +# Set handler for traceback +svcMgr.CoreDumpSvc.FatalHandler = 438 + #svcMgr.EventSelector.InputCollections = [ "SimplePoolFile1.root" ] svcMgr.EventSelector.InputCollections = [ "SimpleEventPoolFile.root" ] diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNewTag.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNewTag.py index 8e88b4f9e965038174620c28a71805f193740b14..c42d7927035149eb0ae9dca198792ba599a5f2df 100644 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNewTag.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNewTag.py @@ -7,9 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNoReg.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNoReg.py index a13ba7d6fcc026ab78e763d94b18fb7e25dfefad..cc5d7d3a317aefd01d0b56f94b78f1cc13afcb5c 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNoReg.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolNoReg.py @@ -7,10 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolWriteMD.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolWriteMD.py index c60f585d421c8fd2c991f6089c02fc0683757a34..bec0bb629a3c8b085d54ace3f9ef084226342097 100644 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolWriteMD.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgReadCoolWriteMD.py @@ -7,9 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCool.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCool.py index fa7b4746d407d131110e5ccc4c937ab13f18e89e..5a2911b776f2ebcd6f52da5f55afeca616ac42d3 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCool.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCool.py @@ -7,9 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNewTag.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNewTag.py index 18e6b225a31108ae336ed8125d336c3876dadf9a..cd6fdbdd2746174893e8cf6d0de841c6f96ce88e 100644 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNewTag.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNewTag.py @@ -7,9 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNoReg.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNoReg.py index 0329d150b13f0e41aefe652af4e21c307bb1bc67..06ad40ade26d6f89b3f1df847e002c8a36a92033 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNoReg.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolNoReg.py @@ -7,10 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep2.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep2.py index 42b834a9f0cc36c3f340ab0416f424a750ae078e..8d3508f7defc2524ddb28ffca8da20abf3d6e520 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep2.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep2.py @@ -7,9 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep3.py b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep3.py index 872b368e51ce1771f126d58c10943493acd40ad6..f2baa7693604dca4d4a44b3e6e4fed97d897cced 100755 --- a/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep3.py +++ b/AtlasTest/DatabaseTest/IOVDbTestAlg/share/IOVDbTestAlgWriteCoolStep3.py @@ -7,9 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/AtlasTest/TestTools/share/post.sh b/AtlasTest/TestTools/share/post.sh index 1cae95b38bce46ec6167d2283752be28059d56b3..aa1e079d26a3a4c7f6361a8fbb7d76ee724a8c88 100755 --- a/AtlasTest/TestTools/share/post.sh +++ b/AtlasTest/TestTools/share/post.sh @@ -213,6 +213,9 @@ PP="$PP"'|Warning in <TInterpreter::ReadRootmapFile>: enum' # Ignore sourceID message from EventSelector. PP="$PP"'|Disconnecting input sourceID' +# Printouts from new-style job configuration. +PP="$PP"'|Py:ComponentAccumulator +INFO ' +PP="$PP"'|^[a-zA-Z0-9.]+ +: [^ ]' if [ "$extrapatterns" != "" ]; then PP="$PP""|$extrapatterns" diff --git a/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h b/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h index d4859d19c71fbb59c0fdaf9aea666fc030962c0b..3bc7a103484cc5beab572ce3b6a98bf0c7da437d 100644 --- a/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h +++ b/Calorimeter/CaloExample/CaloTests/CaloTests/AnalysisCal.h @@ -42,7 +42,7 @@ namespace MyAnalysisCal { /** standard Athena-Algorithm method */ virtual StatusCode initialize() override; /** standard Athena-Algorithm method */ - virtual StatusCode execute_r(const EventContext& ctx) const override; + virtual StatusCode execute(const EventContext& ctx) const override; /** standard Athena-Algorithm method */ virtual StatusCode finalize() override; private: diff --git a/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx b/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx index 4e2bc56114e690e124ae5daf5922b6c0b018fdec..67ada897510eb13c89f673d6ccd0032acc73f7f1 100644 --- a/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx +++ b/Calorimeter/CaloExample/CaloTests/src/MyAnalysisCal.cxx @@ -51,7 +51,7 @@ namespace MyAnalysisCal { } //__________________________________________________________________________ - StatusCode AnalysisCal::execute_r (const EventContext& ctx) const + StatusCode AnalysisCal::execute (const EventContext& ctx) const { //............................................. diff --git a/Calorimeter/CaloRec/CaloRec/ToolWithConstantsMixin.icc b/Calorimeter/CaloRec/CaloRec/ToolWithConstantsMixin.icc index d16e950c9d8dd98c284c76b0d855403fdf5f1fb9..89ff976865d123415a87f8ca7a2bfc7e99409e1b 100644 --- a/Calorimeter/CaloRec/CaloRec/ToolWithConstantsMixin.icc +++ b/Calorimeter/CaloRec/CaloRec/ToolWithConstantsMixin.icc @@ -43,7 +43,7 @@ StatusCode do_declare (ToolWithConstantsMixin* self, if (AlgTool* x = dynamic_cast<AlgTool*> (self)) { x->declareProperty (name, c); return StatusCode::SUCCESS; - } else if (Algorithm* x = dynamic_cast<Algorithm*> (self)) { + } else if (Gaudi::Algorithm* x = dynamic_cast<Gaudi::Algorithm*> (self)) { x->declareProperty (name, c); return StatusCode::SUCCESS; } else if (Service* x = dynamic_cast<Service*> (self)) { diff --git a/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.cxx b/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.cxx index a0f324f807e5dbca47dda582943a190be08831b6..eb23fe09a2cbfc55733b2fb9af804082b05b4735 100644 --- a/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.cxx +++ b/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.cxx @@ -46,7 +46,7 @@ StatusCode CaloBCIDAvgAlg::finalize() { //---------------------------------------------------------------------------------------- -StatusCode CaloBCIDAvgAlg::execute_r(const EventContext& ctx) const { +StatusCode CaloBCIDAvgAlg::execute(const EventContext& ctx) const { SG::ReadHandle<xAOD::EventInfo> ei(m_eventInfoKey,ctx); diff --git a/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.h b/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.h index c53fa6597c6ac67f86548cad93dfc456cbf8fe64..72f5c9879664d8cfd513a2589a2daa739b0c5baa 100644 --- a/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.h +++ b/Calorimeter/CaloRec/src/CaloBCIDAvgAlg.h @@ -28,7 +28,7 @@ public: // Algorithm virtual methods StatusCode initialize(); - StatusCode execute_r(const EventContext& ctx) const; + StatusCode execute(const EventContext& ctx) const; StatusCode finalize(); private: diff --git a/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.cxx b/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.cxx index 40e8eb77cc63b690f5c1622edec6f5c09c21b234..fe06a71efa812817e3e571ecda1e18c4a1349f25 100644 --- a/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.cxx +++ b/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.cxx @@ -80,7 +80,7 @@ StatusCode CaloCell2ClusterMapper::finalize() //############################################################################### -StatusCode CaloCell2ClusterMapper::execute_r(const EventContext& ctx) const { +StatusCode CaloCell2ClusterMapper::execute(const EventContext& ctx) const { // make a DataVector of Navigable CaloClusterContainer ATH_MSG_DEBUG(" Recording Cell2Cluster Map " << m_mapOutputKey.key()); diff --git a/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.h b/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.h index 6f497d6d699c066fb0c94f6e7adc9a2188e7850f..db39d8be16d68757fb2afba4fa814b8a5344ac93 100644 --- a/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.h +++ b/Calorimeter/CaloRec/src/CaloCell2ClusterMapper.h @@ -35,7 +35,7 @@ class CaloCell2ClusterMapper : public AthReentrantAlgorithm CaloCell2ClusterMapper(const std::string& name, ISvcLocator* pSvcLocator); virtual ~CaloCell2ClusterMapper(); virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; protected: diff --git a/Calorimeter/CaloRec/src/CaloClusterMaker.cxx b/Calorimeter/CaloRec/src/CaloClusterMaker.cxx index 20b364f66b7c34e5bf5d8a4783e02bdbe674fba9..8819e2a15f6d96f56cab73e70adeb77e6f72c11f 100644 --- a/Calorimeter/CaloRec/src/CaloClusterMaker.cxx +++ b/Calorimeter/CaloRec/src/CaloClusterMaker.cxx @@ -132,7 +132,7 @@ StatusCode CaloClusterMaker::finalize() { //############################################################################### -StatusCode CaloClusterMaker::execute_r (const EventContext& ctx) const +StatusCode CaloClusterMaker::execute (const EventContext& ctx) const { // make a Cluster Container diff --git a/Calorimeter/CaloRec/src/CaloClusterMaker.h b/Calorimeter/CaloRec/src/CaloClusterMaker.h index b490c417a485bd706d42645a3ec90f36687524d9..05c8fd631d244b2f14e05df08f634fa3c183b99c 100644 --- a/Calorimeter/CaloRec/src/CaloClusterMaker.h +++ b/Calorimeter/CaloRec/src/CaloClusterMaker.h @@ -40,7 +40,7 @@ class CaloClusterMaker : public AthReentrantAlgorithm CaloClusterMaker(const std::string& name, ISvcLocator* pSvcLocator); virtual ~CaloClusterMaker() override; virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& ctx) const override; + virtual StatusCode execute(const EventContext& ctx) const override; virtual StatusCode finalize() override; const std::string& getOutputContainerName() const; diff --git a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx index e68e0b1e2e90972ca75e17592da2b4055e338983..55afed800e3f0aa001438dafcbf846ce34bd6061 100644 --- a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx +++ b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.cxx @@ -152,7 +152,7 @@ StatusCode CaloTopoTowerAlg::initialize() ///============================================== /// EXECUTE ///============================================== -StatusCode CaloTopoTowerAlg::execute_r (const EventContext& ctx) const +StatusCode CaloTopoTowerAlg::execute (const EventContext& ctx) const { /// Say hello ATH_MSG_DEBUG( "In CaloTopoTowerAlg::execute()" ); diff --git a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.h b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.h index 0aaac831cef67c923888796e55e31cafac5c7c64..fb65ce621da926b93d8ef05d3c634aa6a2807041 100644 --- a/Calorimeter/CaloRec/src/CaloTopoTowerAlg.h +++ b/Calorimeter/CaloRec/src/CaloTopoTowerAlg.h @@ -61,7 +61,7 @@ class CaloTopoTowerAlg : public AthReentrantAlgorithm virtual StatusCode finalize() override; /// Execute - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: // Container name strings diff --git a/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.cxx b/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.cxx index e652ebfc2526aa98608272474c54a26a39614fb2..6581b2a8cb6bcc573c8e61bfc07339ee62708d9a 100644 --- a/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.cxx +++ b/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.cxx @@ -206,7 +206,7 @@ StatusCode CaloTopoTowerAlgorithm::initialize() // Execute // ///////////// -StatusCode CaloTopoTowerAlgorithm::execute_r (const EventContext& ctx) const +StatusCode CaloTopoTowerAlgorithm::execute (const EventContext& ctx) const { ////////////////////////// diff --git a/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.h b/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.h index bd46bd5fe1627bffffb11289fc115ed7f3067009..24c6f06327fc461fdd21fdaa3367144a876c6215 100644 --- a/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.h +++ b/Calorimeter/CaloRec/src/CaloTopoTowerAlgorithm.h @@ -50,7 +50,7 @@ class CaloTopoTowerAlgorithm : public AthReentrantAlgorithm /// inherited from Algorithm virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; protected: diff --git a/Calorimeter/CaloRec/src/CaloTowerAlgorithm.cxx b/Calorimeter/CaloRec/src/CaloTowerAlgorithm.cxx index 0f477e0c074b125e4ba04304466a191db3ca73ee..0ba432ed5354fe4d4b6425f7e1fd8b6cb070103f 100644 --- a/Calorimeter/CaloRec/src/CaloTowerAlgorithm.cxx +++ b/Calorimeter/CaloRec/src/CaloTowerAlgorithm.cxx @@ -114,7 +114,7 @@ StatusCode CaloTowerAlgorithm::initialize() // Execute // ///////////// -StatusCode CaloTowerAlgorithm::execute_r (const EventContext& ctx) const +StatusCode CaloTowerAlgorithm::execute (const EventContext& ctx) const { ////////////////////////// diff --git a/Calorimeter/CaloRec/src/CaloTowerAlgorithm.h b/Calorimeter/CaloRec/src/CaloTowerAlgorithm.h index a3142cbd5e4ab55a0c4711166c87a6500fb57dd3..a642742773cdc07b9c5adae5991baa3c6a119653 100644 --- a/Calorimeter/CaloRec/src/CaloTowerAlgorithm.h +++ b/Calorimeter/CaloRec/src/CaloTowerAlgorithm.h @@ -46,7 +46,7 @@ class CaloTowerAlgorithm: public AthReentrantAlgorithm { /// inherited from Algorithm virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; protected: diff --git a/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.cxx b/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.cxx index c57a41e3c2dbd94eaa265a0ef2bd100c67115a3e..260a909d009f7d6a8cb60d8a63b0eb222355ea75 100644 --- a/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.cxx +++ b/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.cxx @@ -45,7 +45,7 @@ StatusCode CaloTowerxAODFromCells::initialize() { return initBase(); } -StatusCode CaloTowerxAODFromCells::execute_r(const EventContext& ctx) const +StatusCode CaloTowerxAODFromCells::execute(const EventContext& ctx) const { SG::ReadHandle<CaloCellContainer> inputCellContainer(m_inputCellContainerKey, ctx); if (!inputCellContainer.isValid()) { diff --git a/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.h b/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.h index 4810f17ab2fe1130b46d7397bc7191f09b169f0f..d2bf214acad8ca0fecf8aac9d0b12bf994d26d0c 100644 --- a/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.h +++ b/Calorimeter/CaloRec/src/CaloTowerxAODFromCells.h @@ -33,7 +33,7 @@ public: /// @name @c AthAlgorithm interface implementation /// @{ virtual StatusCode initialize() override; ///< @brief Initialize algorithm - virtual StatusCode execute_r(const EventContext& ctx) const override; ///< @brief Execute algorithm + virtual StatusCode execute(const EventContext& ctx) const override; ///< @brief Execute algorithm virtual StatusCode finalize() override; ///< @brief Finalize algorithm /// @} diff --git a/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.cxx b/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.cxx index 7236142f1827ded242119e816eab444728db4aa4..358b544b3c5f2d6842d1ef4144aa67e50676176f 100644 --- a/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.cxx +++ b/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.cxx @@ -30,7 +30,7 @@ StatusCode CaloTowerxAODFromClusters::initialize() { return StatusCode::SUCCESS; } -StatusCode CaloTowerxAODFromClusters::execute_r(const EventContext& ctx) const +StatusCode CaloTowerxAODFromClusters::execute(const EventContext& ctx) const { SG::ReadHandle<xAOD::CaloClusterContainer> inputClusterContainer(m_inputClusterContainerKey, ctx); diff --git a/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.h b/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.h index 6b4b24b3a19c98385f0eae4bcf5d47bd4b0b7c08..63ae13ce993d41ce8f221a8b2f20184ec70441f4 100644 --- a/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.h +++ b/Calorimeter/CaloRec/src/CaloTowerxAODFromClusters.h @@ -27,7 +27,7 @@ public: /// @name @c AthAlgorithm interface implementation /// @{ virtual StatusCode initialize() override; ///< @brief Initialize algorithm - virtual StatusCode execute_r(const EventContext&) const override; ///< @brief Execute algorithm + virtual StatusCode execute(const EventContext&) const override; ///< @brief Execute algorithm virtual StatusCode finalize() override; ///< @brief Finalize algorithm /// @} diff --git a/Calorimeter/CaloRec/src/ToolWithConstantsMixin.cxx b/Calorimeter/CaloRec/src/ToolWithConstantsMixin.cxx index d093358143300860f9002bf387aae23c4eb3458b..17e9fae866938a25ff165c2002677269538ec983 100755 --- a/Calorimeter/CaloRec/src/ToolWithConstantsMixin.cxx +++ b/Calorimeter/CaloRec/src/ToolWithConstantsMixin.cxx @@ -75,7 +75,7 @@ ToolWithConstantsMixin::finish_ctor (const std::string& toolcls /*= ""*/) if (m_toolcls.empty()) m_toolcls = thistool->type(); } - else if (Algorithm* thisalg = dynamic_cast<Algorithm*> (this)) { + else if (Gaudi::Algorithm* thisalg = dynamic_cast<Gaudi::Algorithm*> (this)) { thisalg->declareProperty ("detStoreKey", m_detStoreKey); thisalg->declareProperty ("prefix", m_prefix); thisalg->declareProperty ("useCallback", m_use_callback); diff --git a/Control/AthAnalysisBaseComps/AthAnalysisBaseComps/AthAnalysisHelper.h b/Control/AthAnalysisBaseComps/AthAnalysisBaseComps/AthAnalysisHelper.h index d05f7fc57052c8fcf1d3e1effb0044adb0b22b07..128ed9f575b6bd78d1bc1ef544f63f5aec918a1f 100644 --- a/Control/AthAnalysisBaseComps/AthAnalysisBaseComps/AthAnalysisHelper.h +++ b/Control/AthAnalysisBaseComps/AthAnalysisBaseComps/AthAnalysisHelper.h @@ -119,7 +119,7 @@ public: ///setProperty on an alg, even when initialized template<typename W> static StatusCode setProperty(IAlgorithm* alg, const std::string& property, const W& value) { - Algorithm* theAlg = dynamic_cast<Algorithm*>(alg); + Gaudi::Algorithm* theAlg = dynamic_cast<Gaudi::Algorithm*>(alg); if(!theAlg) { std::cout << "ERROR: alg is not an Algorithm. Cannot AthAnalysisHelper::setProperty on it" << std::endl; return StatusCode::FAILURE; diff --git a/Control/AthenaBaseComps/AthenaBaseComps/AthLegacySequence.h b/Control/AthenaBaseComps/AthenaBaseComps/AthLegacySequence.h new file mode 100644 index 0000000000000000000000000000000000000000..4745fe0a44a6d5e8a7a3d21e2e99f5cb2f982945 --- /dev/null +++ b/Control/AthenaBaseComps/AthenaBaseComps/AthLegacySequence.h @@ -0,0 +1,69 @@ +/* + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration +*/ + +// AthLegacySequence.h +// Header file for class AthLegacySequence +/////////////////////////////////////////////////////////////////// +#ifndef ATHENABASECOMPS_ATHLEGACYEQUENCE_H +#define ATHENABASECOMPS_ATHLEGACYEQUENCE_H 1 + +#pragma once + + +// Framework includes +#include "AthenaBaseComps/AthCommonDataStore.h" +#include "AthenaBaseComps/AthCommonMsg.h" +#include "Gaudi/Sequence.h" +#include "GaudiKernel/ThreadLocalContext.h" + +namespace Athena { + namespace details { +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Woverloaded-virtual" + class AthLegacySequenceAdapter + : public AthCommonDataStore<AthCommonMsg< Gaudi::Sequence >> + { + public: + + /// Constructor with parameters: + AthLegacySequenceAdapter(const std::string& name, + ISvcLocator* pSvcLocator); + + virtual StatusCode execute() = 0; + + const EventContext& getContext() const { return Gaudi::Hive::currentContext(); } + + virtual const DataObjIDColl& extraOutputDeps() const override; + + protected: + bool isReEntrant() const override final { return false; } + + private: + StatusCode execute( const EventContext& ) const override final + { + return const_cast<AthLegacySequenceAdapter*>( this )->execute(); + } + + DataObjIDColl m_extendedExtraObjects; + + }; +#pragma GCC diagnostic pop + } +} + + +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Woverloaded-virtual" +/// Alias for backward compatibility +class AthLegacySequence : public Athena::details::AthLegacySequenceAdapter +{ +public: + using Athena::details::AthLegacySequenceAdapter::AthLegacySequenceAdapter; + // this is to explicitly hide the other signature of `execute` + StatusCode execute() override = 0; +}; +#pragma GCC diagnostic pop + + +#endif //> !ATHENABASECOMPS_ATHLEGACYSEQUENCE_H diff --git a/Control/AthenaBaseComps/AthenaBaseComps/AthReentrantAlgorithm.h b/Control/AthenaBaseComps/AthenaBaseComps/AthReentrantAlgorithm.h index 4472d43ea233388abae444a7f4ea4a5ce24141a4..65b21b18b6a7d4eb6ddb76f20bda70d31b0bda25 100644 --- a/Control/AthenaBaseComps/AthenaBaseComps/AthReentrantAlgorithm.h +++ b/Control/AthenaBaseComps/AthenaBaseComps/AthReentrantAlgorithm.h @@ -22,13 +22,7 @@ #include "AthenaBaseComps/AthMemMacros.h" -// Framework includes -#ifndef REENTRANT_GAUDI - #define ReEntAlgorithm Algorithm - #include "GaudiKernel/Algorithm.h" -#else - #include "GaudiKernel/ReEntAlgorithm.h" -#endif +#include "Gaudi/Algorithm.h" /** @@ -40,19 +34,19 @@ * derives from @c AthReentrantAlgorithm, then the same algorithm object may * be used in multiple threads without cloning. * - * Rather than @c execute, a reentrant algorithm will call @c execute_r, - * which has two differences. First, @c execute_r is @c const. If the + * Rather than @c execute, a reentrant algorithm will call @c execute, + * which has two differences. First, @c execute is @c const. If the * same object is being used in multiple threads, it should not have any * state which is being changed. Any attempt to get around this with * @c mutable or @c const_cast should be viewed with great suspicion: * that may not be thread-safe. * - * Second, the @c execute_r method takes an explicit event context argument. + * Second, the @c execute method takes an explicit event context argument. * This may be used to find the proper store for the event being processed * by the current thread. * * The typical usage will be to declare a key object as a property of the - * algorithm and then construct a transient handle instance during @c execute_r + * algorithm and then construct a transient handle instance during @c execute * from the key and the event context. For example: * *@code @@ -74,7 +68,7 @@ * return StatusCode::SUCCESS; * } * - * StatusCode MyAlg::execute_r (const EventContext& ctx) const + * StatusCode MyAlg::execute (const EventContext& ctx) const * { * SG::ReadHandle<MyObj> myobj (m_rhandle, ctx); * const MyObj& p = *myobj; @@ -85,7 +79,7 @@ class AthReentrantAlgorithm - : public AthCommonDataStore<AthCommonMsg<ReEntAlgorithm>> + : public AthCommonDataStore<AthCommonMsg<Gaudi::Algorithm>> { /////////////////////////////////////////////////////////////////// // Public methods: @@ -102,27 +96,6 @@ class AthReentrantAlgorithm /// Destructor: virtual ~AthReentrantAlgorithm() override; - -#ifndef REENTRANT_GAUDI - /** - * @brief Standard Gaudi execute method. - * - * This cannot be overridden; you should override the reentrant method - * @c execute_r instead. - */ - virtual StatusCode execute() override final; - - - /** - * @brief Reentrant execute method. - * @param ctx The current event context. - * - * Override this for your algorithm. - */ - virtual StatusCode execute_r (const EventContext& ctx) const = 0; -#endif - - /** Specify if the algorithm is clonable * * Reentrant algorithms are clonable. @@ -137,16 +110,6 @@ class AthReentrantAlgorithm virtual unsigned int cardinality() const override; - /** - * @brief Return the current event context. - * - * Override this because the base class version won't work correctly - * for reentrant algorithms. (We shouldn't really be using this - * for reentrant algorithms, but just in case.). - */ - virtual const EventContext& getContext() const override; - - /** * @brief Execute an algorithm. * @@ -156,7 +119,6 @@ class AthReentrantAlgorithm */ virtual StatusCode sysExecute (const EventContext& ctx) override; - /** * @brief Return the list of extra output dependencies. diff --git a/Control/AthenaBaseComps/src/AthLegacySequence.cxx b/Control/AthenaBaseComps/src/AthLegacySequence.cxx new file mode 100644 index 0000000000000000000000000000000000000000..eaea8b72b8bb90f7dba8d67a0a03e512e672f542 --- /dev/null +++ b/Control/AthenaBaseComps/src/AthLegacySequence.cxx @@ -0,0 +1,32 @@ +/* + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration +*/ +// AthenaBaseComps includes +#include "AthenaBaseComps/AthLegacySequence.h" +#include "AthAlgorithmDHUpdate.h" + + +namespace Athena { + namespace details { + AthLegacySequenceAdapter::AthLegacySequenceAdapter(const std::string& name, + ISvcLocator* pSvcLocator): + ::AthCommonDataStore<AthCommonMsg<Gaudi::Sequence>> ( name, pSvcLocator) + { + setProperty("Cardinality", 1); + m_updateDataHandles = + std::make_unique<AthenaBaseComps::AthAlgorithmDHUpdate> + (m_extendedExtraObjects, + std::move (m_updateDataHandles)); + } + + + const DataObjIDColl& + AthLegacySequenceAdapter::extraOutputDeps() const { + if (!m_extendedExtraObjects.empty()) { + return m_extendedExtraObjects; + } + return Gaudi::Sequence::extraOutputDeps(); + } + } + +} diff --git a/Control/AthenaBaseComps/src/AthReentrantAlgorithm.cxx b/Control/AthenaBaseComps/src/AthReentrantAlgorithm.cxx index f60c8cd210d2b3b173ad7d6e60632e70ec7c5963..d958beeb8caf6008f0b5e31b8e9853724becbd87 100644 --- a/Control/AthenaBaseComps/src/AthReentrantAlgorithm.cxx +++ b/Control/AthenaBaseComps/src/AthReentrantAlgorithm.cxx @@ -19,7 +19,7 @@ AthReentrantAlgorithm::AthReentrantAlgorithm( const std::string& name, ISvcLocator* pSvcLocator, const std::string& version ) : - ::AthCommonDataStore<AthCommonMsg<ReEntAlgorithm>> ( name, pSvcLocator, version ) + ::AthCommonDataStore<AthCommonMsg<Gaudi::Algorithm>> ( name, pSvcLocator, version ) { // Set up to run AthAlgorithmDHUpdate in sysInitialize before @@ -38,19 +38,6 @@ AthReentrantAlgorithm::~AthReentrantAlgorithm() ATH_MSG_DEBUG ("Calling destructor"); } -#ifndef REENTRANT_GAUDI -/** - * @brief Standard Gaudi execute method. - * - * Find the event context and call @c execute_r. - */ -StatusCode AthReentrantAlgorithm::execute() -{ - return execute_r (Gaudi::Hive::currentContext()); -} -#endif - - /** Specify if the algorithm is clonable */ bool AthReentrantAlgorithm::isClonable() const @@ -69,18 +56,6 @@ unsigned int AthReentrantAlgorithm::cardinality() const return 0; } -/** - * @brief Return the current event context. - * - * Override this because the base class version won't work correctly - * for reentrant algorithms. (We shouldn't really be using this - * for reentrant algorithms, but just in case.). - */ -const EventContext& AthReentrantAlgorithm::getContext() const -{ - return Gaudi::Hive::currentContext(); -} - /** * @brief Execute an algorithm. * @@ -90,23 +65,7 @@ const EventContext& AthReentrantAlgorithm::getContext() const */ StatusCode AthReentrantAlgorithm::sysExecute (const EventContext& ctx) { - EventContext ctx2 = ctx; - // sysExecute will assign the context we pass in to a member variable of - // the algorithm. If the context is referencing any dynamic memory, - // then we can end up with a double-delete. So clear out any extension --- - // we won't actually use the context we pass to here for anything anyway. - - if (ctx.hasExtension<Atlas::ExtendedEventContext>()) { - ctx2.setExtension( Atlas::ExtendedEventContext() ); - } else if (ctx.hasExtension()) { - ATH_MSG_ERROR("EventContext " << ctx - << " has an extended context of an unknown type: \"" - << System::typeinfoName( ctx.getExtensionType() ) - << "\". Can't progress."); - return StatusCode::FAILURE; - } - - return ::ReEntAlgorithm::sysExecute (ctx2); + return Gaudi::Algorithm::sysExecute (ctx); } diff --git a/Control/AthenaBaseComps/test/AthReentrantAlgorithm_test.cxx b/Control/AthenaBaseComps/test/AthReentrantAlgorithm_test.cxx index 31df7275dcf8acebb57a183cea503c3e2d85348a..93babbcf671b78f7d0ea8b541224f9cea647540b 100644 --- a/Control/AthenaBaseComps/test/AthReentrantAlgorithm_test.cxx +++ b/Control/AthenaBaseComps/test/AthReentrantAlgorithm_test.cxx @@ -45,7 +45,7 @@ public: MyAlg (const std::string& name, ISvcLocator* svcLoc); virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual void declare(Gaudi::DataHandle& hnd) override; virtual void addDependency (const DataObjID& obj, const Gaudi::DataHandle::Mode& mode) override; @@ -83,7 +83,7 @@ StatusCode MyAlg::initialize() } -StatusCode MyAlg::execute_r (const EventContext& ctx) const +StatusCode MyAlg::execute (const EventContext& ctx) const { pdict = ctx.getExtension<Atlas::ExtendedEventContext>().proxy(); return StatusCode::SUCCESS; @@ -171,7 +171,7 @@ void test1 (ISvcLocator* svcLoc) Gaudi::Hive::setCurrentContext (ctx); - assert (alg.execute().isSuccess()); + assert (alg.execute( ctx ).isSuccess()); assert (pdict == xdict); DataObjIDColl exp = { @@ -193,7 +193,7 @@ class MyArrAlg : public AthReentrantAlgorithm public: MyArrAlg (const std::string& name, ISvcLocator* svcLoc); - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; SG::ReadHandleKey<MyObj> rkey; SG::WriteHandleKey<MyObj> wkey; @@ -215,7 +215,7 @@ MyArrAlg::MyArrAlg (const std::string& name, ISvcLocator* svcLoc) } -StatusCode MyArrAlg::execute_r (const EventContext& /*ctx*/) const +StatusCode MyArrAlg::execute (const EventContext& /*ctx*/) const { return StatusCode::SUCCESS; } diff --git a/Control/AthenaCommon/share/Preparation.py b/Control/AthenaCommon/share/Preparation.py index 480815d784da0e0047089418b5d38d81bdb36451..0a4786ea1ed3a2eb12ccc082bb48c0f8127a8c19 100644 --- a/Control/AthenaCommon/share/Preparation.py +++ b/Control/AthenaCommon/share/Preparation.py @@ -81,22 +81,6 @@ if min_cppyy_vmem_growth: del vmem_before_cppyy del min_cppyy_vmem_growth, grow_vmem, vmem_mb -from cppyy import gbl -## backward compat... -class _AthenaServicesDictBwd: - @staticmethod - def SetFatalHandler(flags=-1): - import AthenaCommon.Logging as L - info = L.log.info - info("'gbl.AthenaServices.SetFatalHandler(flag)' is DEPRECATED") - info("instead, please consider using:") - info(" svcMgr.CoreDumpSvc.FatalHandler = flag") - - from AthenaCommon.AppMgr import ServiceMgr as svcMgr - svcMgr.CoreDumpSvc.FatalHandler = flags -setattr(gbl, 'AthenaServices', _AthenaServicesDictBwd) -del _AthenaServicesDictBwd -## end -- if not (not opts.run_batch and theApp.EventLoop == "PyAthenaEventLoopMgr"): # make SIG_INT fatal svcMgr.CoreDumpSvc.FatalHandler = -1 diff --git a/Control/AthenaConfiguration/python/ComponentAccumulator.py b/Control/AthenaConfiguration/python/ComponentAccumulator.py index d100edbfac63e9c88f16d2c3e2626862530ec70e..4f67c0f2542119a47b6985bd3cf0c020f1c77e47 100644 --- a/Control/AthenaConfiguration/python/ComponentAccumulator.py +++ b/Control/AthenaConfiguration/python/ComponentAccumulator.py @@ -548,7 +548,7 @@ class ComponentAccumulator(object): # if local bootstrap is missing, use one from the release bsfilename=find_datafile("bootstrap.pkl") else: - bsfilename = localbs[0] + bsfilename = "./"+localbs[0] bsfile=open(bsfilename) self._jocat=pickle.load(bsfile) @@ -565,8 +565,11 @@ class ComponentAccumulator(object): evtalgseq.append( alg.getFullName() ) - for seqName, algoList in flatSequencers( self._sequence ).iteritems(): - self._jocat[seqName]["Members"]=str( [alg.getFullName() for alg in algoList] ) + for seqName, algoList in flatSequencers( self._sequence ).iteritems(): + # part of the sequence may come from the bootstrap, we need to retain the content, that is done here + mergedSequence = ast.literal_eval(self._jocat[seqName]["Members"]) + [alg.getFullName() for alg in algoList] + self._jocat[seqName]["Members"] = str( mergedSequence ) + #Conditions Algorithms: condalgseq=[] diff --git a/Control/AthenaConfiguration/python/iconfTool/__init__.py b/Control/AthenaConfiguration/python/iconfTool/__init__.py old mode 100755 new mode 100644 diff --git a/Control/AthenaConfiguration/python/iconfTool/utils/__init__.py b/Control/AthenaConfiguration/python/iconfTool/utils/__init__.py old mode 100644 new mode 100755 diff --git a/Control/AthenaExamples/AthAsgExUnittest/test/gt_AthExUnittest.cxx b/Control/AthenaExamples/AthAsgExUnittest/test/gt_AthExUnittest.cxx index 07cd88c2a673c0e00a4bf2823b4404fcd5c28c17..c7db4954c3321d2564286a211f56d860ca5d84b3 100644 --- a/Control/AthenaExamples/AthAsgExUnittest/test/gt_AthExUnittest.cxx +++ b/Control/AthenaExamples/AthAsgExUnittest/test/gt_AthExUnittest.cxx @@ -46,7 +46,7 @@ namespace Athena_test { IAlgorithm* ialg= Algorithm::Factory::create( "MyPackageAlg", "MyPackageAlg", Gaudi::svcLocator() ).release(); - myAlg= dynamic_cast<Algorithm*>( ialg ); + myAlg= dynamic_cast<Gaudi::Algorithm*>( ialg ); } @@ -64,7 +64,7 @@ namespace Athena_test { return std::stoi( prop ); } - Algorithm* myAlg; + Gaudi::Algorithm* myAlg; }; diff --git a/Control/AthenaExamples/AthExHive/src/HiveAlgR.cxx b/Control/AthenaExamples/AthExHive/src/HiveAlgR.cxx index e433a9bce04ca2b71b5b957d2dfbf538f623e71b..5d87ca857cb520474ae949c97cbdc073e0908e48 100644 --- a/Control/AthenaExamples/AthExHive/src/HiveAlgR.cxx +++ b/Control/AthenaExamples/AthExHive/src/HiveAlgR.cxx @@ -38,7 +38,7 @@ StatusCode HiveAlgR::finalize() { return StatusCode::SUCCESS; } -StatusCode HiveAlgR::execute_r(const EventContext& ctx) const { +StatusCode HiveAlgR::execute(const EventContext& ctx) const { info() << "execute_R: " << index() << " on " << ctx << endmsg; diff --git a/Control/AthenaExamples/AthExHive/src/HiveAlgR.h b/Control/AthenaExamples/AthExHive/src/HiveAlgR.h index a7bcfbd16b6c8f32bbb8ff4235f8d495e9619b40..7be555e7b9ec98bf1e21a7a93691035d3e11ccd9 100644 --- a/Control/AthenaExamples/AthExHive/src/HiveAlgR.h +++ b/Control/AthenaExamples/AthExHive/src/HiveAlgR.h @@ -24,7 +24,7 @@ public: // Define the initialize, execute and finalize methods: StatusCode initialize(); - StatusCode execute_r(const EventContext&) const; + StatusCode execute(const EventContext&) const; StatusCode finalize(); private: diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.cxx b/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.cxx index 9d63867debb7b093ab8d40d745fea1a9db07d035..ddc3bc4496cfa4603664856f8f093a929ab9a1a4 100644 --- a/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.cxx +++ b/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.cxx @@ -33,7 +33,7 @@ StatusCode ExampleAlg::initialize() } -StatusCode ExampleAlg::execute_r (const EventContext& ctx) const +StatusCode ExampleAlg::execute (const EventContext& ctx) const { // Construct handles from the keys. // Since this is a reentrant algorithm, we have an explicit event context, diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.h b/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.h index de06b3e3853c1f9deffbae58deca58eb0fd1e87b..22d6b4708c971347bc84b958d14ca1e057d1dc56 100644 --- a/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.h +++ b/Control/AthenaExamples/AthExStoreGateExample/src/ExampleAlg.h @@ -29,7 +29,7 @@ class ExampleAlg public: ExampleAlg (const std::string& name, ISvcLocator* svcLocator); virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: // Declare the keys used to access the data: one for reading and one diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.cxx b/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.cxx index fcfe02f317d15ddc2d5a3d3b597aa90783b31c7a..ba8920403c5b0f9b27f671b88abd259b5f2962a5 100644 --- a/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.cxx +++ b/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.cxx @@ -69,7 +69,7 @@ StatusCode ReadDataReentrant::initialize() // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * -StatusCode ReadDataReentrant::execute_r (const EventContext& ctx) const +StatusCode ReadDataReentrant::execute (const EventContext& ctx) const { // An algorithm, like this one, retrieving an object from the StoreGate(SG) diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.h b/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.h index d2f0fd136ecea6c64597813841d440962ddaaef7..93c54318dd3b2b153822bbf834e05b30a1e9d0db 100644 --- a/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.h +++ b/Control/AthenaExamples/AthExStoreGateExample/src/ReadDataReentrant.h @@ -31,7 +31,7 @@ class ReadDataReentrant public: ReadDataReentrant (const std::string& name, ISvcLocator* pSvcLocator); virtual StatusCode initialize() override final; - virtual StatusCode execute_r (const EventContext& ctx) const override final; + virtual StatusCode execute (const EventContext& ctx) const override final; virtual StatusCode finalize() override final; private: diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.cxx b/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.cxx index 842a29da1d4772d80a3d4609178f62fd91bb4079..8ad1cc179eb586babe8f9a1107495fabaabd080a 100644 --- a/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.cxx +++ b/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.cxx @@ -78,7 +78,7 @@ StatusCode WriteDataReentrant::initialize() // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * -StatusCode WriteDataReentrant::execute_r (const EventContext& ctx) const +StatusCode WriteDataReentrant::execute (const EventContext& ctx) const { //this example illustrates how to record objects into the StoreGate(SG) //with and without providing a key diff --git a/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.h b/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.h index 67221fa97b4c668f2ab13384e331931e8506ab09..7db055a45b86a90b2424f8040fd43be873962c04 100644 --- a/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.h +++ b/Control/AthenaExamples/AthExStoreGateExample/src/WriteDataReentrant.h @@ -32,7 +32,7 @@ public: WriteDataReentrant (const std::string& name, ISvcLocator* pSvcLocator); virtual StatusCode initialize() override final; virtual StatusCode finalize() override final; - virtual StatusCode execute_r (const EventContext& ctx) const override final; + virtual StatusCode execute (const EventContext& ctx) const override final; private: SG::WriteHandleKey<MyDataObj> m_dobjKey; diff --git a/Control/AthenaExamples/AthExUnittest/test/gt_AthExUnittest.cxx b/Control/AthenaExamples/AthExUnittest/test/gt_AthExUnittest.cxx index 5c656b82bf448beb78b46c75f4e40f09c47f32d0..e890dcb1be6886bc2e332005ede7337e92203419 100644 --- a/Control/AthenaExamples/AthExUnittest/test/gt_AthExUnittest.cxx +++ b/Control/AthenaExamples/AthExUnittest/test/gt_AthExUnittest.cxx @@ -46,7 +46,7 @@ namespace Athena_test { IAlgorithm* ialg= Algorithm::Factory::create( "AthExUnittestAlg", "AthExUnittestAlg", Gaudi::svcLocator() ).release(); - myAlg= dynamic_cast<Algorithm*>( ialg ); + myAlg= dynamic_cast<Gaudi::Algorithm*>( ialg ); } @@ -64,7 +64,7 @@ namespace Athena_test { return std::stoi( prop ); } - Algorithm* myAlg = nullptr; + Gaudi::Algorithm* myAlg = nullptr; }; diff --git a/Control/AthenaMonitoring/src/AthMonBench.h b/Control/AthenaMonitoring/src/AthMonBench.h index 307a12a2c36ef2192a78b2da3fb70870eb4a1a19..a934ce38b891473d33e8ec460fffb59b2f9f0d71 100644 --- a/Control/AthenaMonitoring/src/AthMonBench.h +++ b/Control/AthenaMonitoring/src/AthMonBench.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ @@ -30,7 +30,7 @@ public: static const MSG::Level s_resourceMonThreshold = MSG::DEBUG; AthMonBench(); - ~AthMonBench(){} + ~AthMonBench() = default; //Modify: void reset(); diff --git a/Control/AthenaPython/AthenaPython/PyAthenaAlg.h b/Control/AthenaPython/AthenaPython/PyAthenaAlg.h index 0d1ddeec4ff0a6910acaedb91d8a003a7800db57..b69045c2872eac16536fcea38fa3303ef9d72e77 100644 --- a/Control/AthenaPython/AthenaPython/PyAthenaAlg.h +++ b/Control/AthenaPython/AthenaPython/PyAthenaAlg.h @@ -51,8 +51,6 @@ class Alg : virtual public ::IPyComponent, virtual StatusCode sysInitialize() override; - virtual void resetExecuted() override; - /////////////////////////////////////////////////////////////////// // Const methods: /////////////////////////////////////////////////////////////////// diff --git a/Control/AthenaPython/src/PyAthenaAlg.cxx b/Control/AthenaPython/src/PyAthenaAlg.cxx index dd0bc8c06550b2d3b880a99e7d3b5bf06e5e8121..687b3b15abfd12eda565405c272b8e784e9aa11a 100644 --- a/Control/AthenaPython/src/PyAthenaAlg.cxx +++ b/Control/AthenaPython/src/PyAthenaAlg.cxx @@ -99,12 +99,6 @@ Alg::execute() return sc; } -void -Alg::resetExecuted() -{ - PyAthena::callPyMethod( m_self, "resetExecuted" ).ignore(); -} - StatusCode Alg::sysInitialize() { diff --git a/Control/AthenaServices/python/PyAthenaEventLoopMgr.py b/Control/AthenaServices/python/PyAthenaEventLoopMgr.py index ec08cccd8c0ace2425005d2a5d5b5926fcf3f904..4de2415d8f3538374800291f21eac6eff4eb6703 100644 --- a/Control/AthenaServices/python/PyAthenaEventLoopMgr.py +++ b/Control/AthenaServices/python/PyAthenaEventLoopMgr.py @@ -130,7 +130,7 @@ class PyAthenaEventLoopMgr( PyGaudi.iService ): if not alg._ialg: alg.retrieveInterface() ialg = alg._ialg - ialg.resetExecuted() + ialg.execState(ctx).reset() result = ialg.sysExecute(ctx) if result.isFailure(): from AthenaCommon.Logging import log as msg diff --git a/Control/AthenaServices/src/AthIncFirerAlg.cxx b/Control/AthenaServices/src/AthIncFirerAlg.cxx index 07fcc114f63cb1e893554d39fd0d047d2d9d3f83..8d126b4688234545cc0ddd086da5b72ef4f233cb 100644 --- a/Control/AthenaServices/src/AthIncFirerAlg.cxx +++ b/Control/AthenaServices/src/AthIncFirerAlg.cxx @@ -5,14 +5,12 @@ #include "EventInfo/EventIncident.h" #include "AthenaKernel/errorcheck.h" -AthIncFirerAlg::AthIncFirerAlg( const std::string& name, ISvcLocator* pSvcLocator ):AthAlgorithm(name,pSvcLocator),m_Serial(false){ +AthIncFirerAlg::AthIncFirerAlg( const std::string& name, ISvcLocator* pSvcLocator ):AthReentrantAlgorithm(name,pSvcLocator),m_Serial(false){ declareProperty("Incidents",m_incLists,"Incidents to fire"); declareProperty("FireSerial",m_Serial,"Whether to fire serial incidents"); } StatusCode AthIncFirerAlg::initialize(){ - auto sc=AthAlgorithm::initialize(); - if (sc.isFailure()) return sc; m_incSvc = service("IncidentSvc",true); //Copied from CPUCruncher.cpp if (m_incLists.value().size()==0){ @@ -22,30 +20,14 @@ StatusCode AthIncFirerAlg::initialize(){ return StatusCode::SUCCESS; } -StatusCode AthIncFirerAlg::execute() { - for(auto & i:m_incLists.value()){ - ATH_MSG_VERBOSE("Firing incident "<<i); - if((i=="BeginEvent")||(i=="EndEvent")){ - const EventInfo* event(0); - CHECK( evtStore()->retrieve(event) ); - m_incSvc->fireIncident(std::make_unique<EventIncident>(*event, name(),i)); - if(m_Serial.value())m_incSvc->fireIncident(EventIncident(*event, name(),i)); - }else{ - m_incSvc->fireIncident(std::make_unique<Incident>(name(),i)); - if(m_Serial.value())m_incSvc->fireIncident(Incident( name(),i)); - } - } - return StatusCode::SUCCESS; -} - -StatusCode AthIncFirerAlg::execute_r(const EventContext& ctx)const { +StatusCode AthIncFirerAlg::execute(const EventContext& ctx)const { auto ctxcp=ctx; for(auto & i:m_incLists.value()){ ATH_MSG_VERBOSE("Firing incident "<<i); if((i=="BeginEvent")||(i=="EndEvent")){ const EventInfo* event(0); - evtStore()->retrieve(event); + evtStore()->retrieve(event).ignore(); m_incSvc->fireIncident(std::make_unique<EventIncident>(*event, name(),i,ctxcp)); if(m_Serial.value())m_incSvc->fireIncident(EventIncident(*event, name(),i,ctxcp)); }else{ diff --git a/Control/AthenaServices/src/AthIncFirerAlg.h b/Control/AthenaServices/src/AthIncFirerAlg.h index 96485337142802ed5610c3a8f9cfbdef60ef4aa0..017da68379ea14456e6059fea77feb30610699f7 100644 --- a/Control/AthenaServices/src/AthIncFirerAlg.h +++ b/Control/AthenaServices/src/AthIncFirerAlg.h @@ -4,18 +4,17 @@ #include <vector> #include <string> -#include "AthenaBaseComps/AthAlgorithm.h" +#include "AthenaBaseComps/AthReentrantAlgorithm.h" #include "GaudiKernel/Property.h" #include "GaudiKernel/ServiceHandle.h" class IIncidentSvc; -class AthIncFirerAlg : public AthAlgorithm{ +class AthIncFirerAlg : public AthReentrantAlgorithm{ public: AthIncFirerAlg( const std::string& name, ISvcLocator* pSvcLocator ); StatusCode initialize() override; - StatusCode execute() override; - StatusCode execute_r(const EventContext& ctx) const ; + StatusCode execute(const EventContext& ctx) const ; StatusCode finalize() override; private: // Gaudi::Property<std::vector<std::string>> m_incLists{this, "Incidents", {},"List of incidents to fire"}; diff --git a/Control/AthenaServices/src/AthenaOutputStream.cxx b/Control/AthenaServices/src/AthenaOutputStream.cxx index ace89895181e59281ff402ef08a4140f8b270a55..51d84cba12d00a0263c54a954e14efe2798d5e76 100644 --- a/Control/AthenaServices/src/AthenaOutputStream.cxx +++ b/Control/AthenaServices/src/AthenaOutputStream.cxx @@ -317,7 +317,7 @@ StatusCode AthenaOutputStream::initialize() { StatusCode AthenaOutputStream::stop() { - ATH_MSG_INFO("AthenaOutputStream " << this->name() << " ::stop()"); + ATH_MSG_DEBUG("AthenaOutputStream " << this->name() << " ::stop()"); for (std::vector<ToolHandle<IAthenaOutputTool> >::iterator iter = m_helperTools.begin(); iter != m_helperTools.end(); iter++) { if (!(*iter)->preFinalize().isSuccess()) { diff --git a/Control/CxxUtils/CxxUtils/ConcurrentBitset.h b/Control/CxxUtils/CxxUtils/ConcurrentBitset.h index cdab7e0163309bb217deee9bc26ea6b70a1a3755..add96c3fbf61116cf7cd7355a1558f95bd475591 100644 --- a/Control/CxxUtils/CxxUtils/ConcurrentBitset.h +++ b/Control/CxxUtils/CxxUtils/ConcurrentBitset.h @@ -1,6 +1,6 @@ // This file's extension implies that it's C, but it's really -*- C++ -*-. /* - * Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration. + * Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration. */ // $Id$ /** @@ -209,6 +209,16 @@ public: ConcurrentBitset (std::initializer_list<bit_t> l, bit_t nbits = 0); + /** + * @brief Move constructor. + * @param other Container to move. + * + * No concurrent access may be in progress on @c other. + * After this returns, @c other can only be deleted. + */ + ConcurrentBitset (ConcurrentBitset&& other); + + /** * @brief Destructor. */ @@ -225,6 +235,16 @@ public: ConcurrentBitset& operator= (const ConcurrentBitset& other); + /** + * @brief Move. + * @param other Bitset from which to move. + * + * No concurrent access may be in progress on @c other. + * After this returns, @c other can only be deleted. + */ + ConcurrentBitset& operator= (ConcurrentBitset&& other); + + /** * @brief Clean up old versions of the set. * diff --git a/Control/CxxUtils/Root/ConcurrentBitset.cxx b/Control/CxxUtils/Root/ConcurrentBitset.cxx index 25a368dacb9d59775afc20ba4885d4d8f4c3cc6a..0cc542f94b1bc6071023df7f32d3a3a48b76678c 100644 --- a/Control/CxxUtils/Root/ConcurrentBitset.cxx +++ b/Control/CxxUtils/Root/ConcurrentBitset.cxx @@ -70,6 +70,22 @@ ConcurrentBitset::ConcurrentBitset (std::initializer_list<bit_t> l, } +/** + * @brief Move constructor. + * @param other Container to move. + * + * No concurrent access may be in progress on @c other. + * After this returns, @c other can only be deleted. + */ +ConcurrentBitset::ConcurrentBitset (ConcurrentBitset&& other) +{ + other.emptyGarbage(); + Impl* impl = other.m_impl; + other.m_impl = nullptr; + m_impl = impl; +} + + /** * @brief Destructor. */ @@ -98,6 +114,27 @@ ConcurrentBitset& ConcurrentBitset::operator= (const ConcurrentBitset& other) } +/** + * @brief Move. + * @param other Bitset from which to move. + * + * No concurrent access may be in progress on @c other. + * After this returns, @c other can only be deleted. + */ +ConcurrentBitset& ConcurrentBitset::operator= (ConcurrentBitset&& other) +{ + if (this != &other) { + emptyGarbage(); + other.emptyGarbage(); + delete m_impl; + Impl* impl = other.m_impl; + other.m_impl = nullptr; + m_impl = impl; + } + return *this; +} + + /** * @brief Clean up old versions of the set. * diff --git a/Control/CxxUtils/test/ConcurrentBitset_test.cxx b/Control/CxxUtils/test/ConcurrentBitset_test.cxx index c305ee051234ef8c3054502872f48e52784ed3fb..2efd1811d246877b3e007093f599cfa493c75b86 100644 --- a/Control/CxxUtils/test/ConcurrentBitset_test.cxx +++ b/Control/CxxUtils/test/ConcurrentBitset_test.cxx @@ -1,5 +1,5 @@ /* - * Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration. + * Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration. */ // $Id$ @@ -320,7 +320,7 @@ void test_insert() } -// Copy/assign +// Copy/assign/move void test_copy() { std::cout << "test_copy\n"; @@ -365,6 +365,15 @@ void test_copy() bs3 = bs1; std::vector<size_t> v3 (bs3.begin(), bs3.end()); assert (v3 == (std::vector<size_t> {5, 45, 87, 501})); + + CxxUtils::ConcurrentBitset bs4 = std::move(bs1); + std::vector<size_t> v4 (bs4.begin(), bs4.end()); + assert (v4 == (std::vector<size_t> {5, 45, 87, 501})); + + CxxUtils::ConcurrentBitset bs5; + bs5 = std::move(bs4); + std::vector<size_t> v5 (bs5.begin(), bs5.end()); + assert (v5 == (std::vector<size_t> {5, 45, 87, 501})); } diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.cxx index 1c4d514f58ea9c908facd3eecad35206e68e28f8..0d7f4caf263d2b535fc27b85d06a6110728d6436 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.cxx +++ b/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.cxx @@ -45,7 +45,7 @@ StatusCode CondAlg1::initialize() /** * @brief Algorithm event processing. */ -StatusCode CondAlg1::execute_r (const EventContext& ctx) const +StatusCode CondAlg1::execute (const EventContext& ctx) const { SG::ReadCondHandle<AthenaAttributeList> attrList (m_attrListKey, ctx); int xint = (**attrList)["xint"].data<int>(); diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.h b/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.h index 5a8afa2372448ee07b596ae04a98e402605febec..37fda17d17c240507c53d81c4ad5309b93bff68c 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.h +++ b/Control/DataModelTest/DataModelTestDataCommon/src/CondAlg1.h @@ -46,7 +46,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.cxx index f91246d40b37ba5c1561ab81dc7499f6816a595c..079279a66ec19a874daf485338064ea50f50c5be 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.cxx +++ b/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.cxx @@ -61,7 +61,7 @@ StatusCode CondReaderAlg::initialize() /** * @brief Algorithm event processing. */ -StatusCode CondReaderAlg::execute_r (const EventContext& ctx) const +StatusCode CondReaderAlg::execute (const EventContext& ctx) const { SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx); diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.h b/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.h index 237d77c15482477e368cfc81a92b7eb2610088a1..06781d9024b326bb3353a2f8d1a6c5b381eb0eeb 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.h +++ b/Control/DataModelTest/DataModelTestDataCommon/src/CondReaderAlg.h @@ -49,7 +49,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.cxx index 61347ae0e6afda2bdc9d3de0cb6ddc8e1cc575e8..88fd2d9700d2ab778197bd95c1cd2153eadff27b 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.cxx +++ b/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.cxx @@ -45,7 +45,7 @@ StatusCode MetaReaderAlg::initialize() * @brief Algorithm execute method. * @param ctx Event context. */ -StatusCode MetaReaderAlg::execute_r (const EventContext& ctx) const +StatusCode MetaReaderAlg::execute (const EventContext& ctx) const { // Get proper dbkey. const DataHeader* thisDH = nullptr; diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.h b/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.h index c1f2bd4749b848892cb74df5dbc6312c46c362cd..149fced29774f5d5c4f80d679b75b3207307a93a 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.h +++ b/Control/DataModelTest/DataModelTestDataCommon/src/MetaReaderAlg.h @@ -47,7 +47,7 @@ public: * @brief Algorithm execute method. * @param ctx Event context. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.cxx index 2f07dafba3e86c432ffd73c39fbb49de7b73c89b..b79938bd03e53addb73a8515d714c044309149bc 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.cxx +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.cxx @@ -44,7 +44,7 @@ StatusCode xAODTestAlg::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestAlg::execute_r (const EventContext& ctx) const +StatusCode xAODTestAlg::execute (const EventContext& ctx) const { for (const auto& t : m_tools) ATH_CHECK( t->doit (ctx) ); diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.h index 44f39f83de0de5d4f9ac71123c055e8c37309e48..cd2e5824a6e939cf36ce5a6513a192bdbbbdc9da 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.h +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestAlg.h @@ -45,7 +45,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.cxx index 551b35e9add8d0a62ebb67aee44adf5c99d0a2ba..e56022f27ccddd7535dd71ffa165cdebb438b6a1 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.cxx +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.cxx @@ -69,7 +69,7 @@ StatusCode xAODTestDecor::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestDecor::execute_r (const EventContext& ctx) const +StatusCode xAODTestDecor::execute (const EventContext& ctx) const { SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx); unsigned int count = eventInfo->event_ID()->event_number() + 1; diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.h index cf0b32004c96f22165a89502d50d1b2d06d1570f..1251a2c6a1f588a8734752032124ac4ee8d2dc90 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.h +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestDecor.h @@ -52,7 +52,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx index 489b62499d2f95f433c49f8b9668618638e89a1b..b3b0b48fc2f64dad1f88118d9dbc0de42893192b 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.cxx @@ -62,7 +62,7 @@ StatusCode xAODTestReadDecor::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestReadDecor::execute_r (const EventContext& ctx) const +StatusCode xAODTestReadDecor::execute (const EventContext& ctx) const { { std::ostringstream ss; diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.h index 113f994046d77a3bcb11504a732edc7ea129f9a8..62d92088f1b8a46348601b781a2355f4ed17a298 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.h +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadDecor.h @@ -48,7 +48,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.cxx index 31e3a94d7d757c774c35263d1d63081d42974145..0a5056e239a4eab7c47afb1ee127cb7740c20c26 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.cxx +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.cxx @@ -38,7 +38,7 @@ StatusCode xAODTestReadSymlink::initialize() } -StatusCode xAODTestReadSymlink::execute_r (const EventContext& ctx) const +StatusCode xAODTestReadSymlink::execute (const EventContext& ctx) const { SG::ReadHandle<SG::AuxElement> c (m_objKey, ctx); SG::ReadHandle<DMTest::S1> s1 (m_s1Key, ctx); diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.h index 55561d6328b62edd0d79c8deb53a0fca83414545..a8db4bc9dbb055a0f4c4310181e300e31cfeb153 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.h +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestReadSymlink.h @@ -48,7 +48,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.cxx b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.cxx index 6eaeef6adf044f5d683441ef75b808598041b6b7..46c6935b81ef4b5e11ee79352e782fc551a1b066 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.cxx +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.cxx @@ -55,7 +55,7 @@ StatusCode xAODTestWriteCInfo::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestWriteCInfo::execute_r (const EventContext& ctx) const +StatusCode xAODTestWriteCInfo::execute (const EventContext& ctx) const { //SG::ReadHandle<xAOD::EventInfo> eventInfo (m_eventInfoKey, ctx); //unsigned int count = eventInfo->eventNumber() + 1; diff --git a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.h b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.h index ad3d2de6bf4cacc546113f33e265fc29afcfed2a..0e4ee559826bb227c8b5e04fffc00e08285e0f57 100644 --- a/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.h +++ b/Control/DataModelTest/DataModelTestDataCommon/src/xAODTestWriteCInfo.h @@ -53,7 +53,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.cxx index 640f302d671f68fd766b4f5c0dec31bd1f1ba211..7e97df33bc6ca1e02970baffd7edaf28085a630f 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.cxx +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.cxx @@ -54,7 +54,7 @@ StatusCode xAODTestFilterCVec::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestFilterCVec::execute_r (const EventContext& ctx) const +StatusCode xAODTestFilterCVec::execute (const EventContext& ctx) const { SG::ReadHandle<DMTest::CVec> cvec (m_cvecKey, ctx); const static C::Accessor<ElementLink<DMTest::CVec> > cEL ("cEL"); diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.h index f6220c7e8af24eb4ec498aad701ecb6302c4539b..7e1dbdc16c07f2913e6a639e0fc18b2c7dd595b5 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.h +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestFilterCVec.h @@ -50,7 +50,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.cxx index 507990d44627d2bbb4c3774641b365623c63b78f..e01a0f3b89ac0f6fc82bb3df656a8871a53896fc 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.cxx +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.cxx @@ -51,7 +51,7 @@ StatusCode xAODTestReadCInfo::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestReadCInfo::execute_r (const EventContext& ctx) const +StatusCode xAODTestReadCInfo::execute (const EventContext& ctx) const { static const C::Accessor<int> anInt2 ("anInt2"); static const C::Accessor<int> anInt10 ("anInt10"); diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.h index 22ddd89b1ac265ea551a2004d33c1544f202a64d..77fb515eb62dab4eaf9456d8df937d64963fc8b7 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.h +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCInfo.h @@ -47,7 +47,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const; + virtual StatusCode execute (const EventContext& ctx) const; private: diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.cxx index a9468898e3d05b801c2f49c78d9973c676aa5878..54224900a2e33d251b97146af57d028d41ec7926 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.cxx +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.cxx @@ -65,7 +65,7 @@ StatusCode xAODTestReadCVec::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestReadCVec::execute_r (const EventContext& ctx) const +StatusCode xAODTestReadCVec::execute (const EventContext& ctx) const { SG::ReadHandle<DMTest::CVec> cvec (m_cvecKey, ctx); diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.h index d45f552feebeef3f51063a8f917fa2f59fad4b4f..4b2a74c25e5dbf09afda872ab0b45ec8a9c0c13b 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.h +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCVec.h @@ -50,7 +50,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.cxx index a0a95e62e9f5c5c71d321cdaebd78786828c62e6..2c7fd98ac5e580ba64f523c10c2bd867ea7af31a 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.cxx +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.cxx @@ -54,7 +54,7 @@ StatusCode xAODTestReadCView::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestReadCView::execute_r (const EventContext& ctx) const +StatusCode xAODTestReadCView::execute (const EventContext& ctx) const { SG::ReadHandle<DMTest::CView> cview (m_cviewKey, ctx); diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.h index 9a722b5977adce46078e03e5918d2af502c6b344..eeb513f850779548d484a52e0e1619b4b6150dbe 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.h +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadCView.h @@ -50,7 +50,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.cxx b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.cxx index ea93300e21a698ca66dd25049fa4a223eabaf788..ec6526dd0e9eb7e217dbff165271998b5e7eb4d2 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.cxx +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.cxx @@ -64,7 +64,7 @@ StatusCode xAODTestReadHVec::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestReadHVec::execute_r (const EventContext& ctx) const +StatusCode xAODTestReadHVec::execute (const EventContext& ctx) const { const DMTest::HVec* hvec = SG::get (m_hvecKey, ctx); std::cout << m_hvecKey.key() << ":"; diff --git a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.h b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.h index c749ab28f13e23a0770b09d5ae4d559533a8e29f..e6dc370b7bb732d757a8cad2dd0fa58a2e052b20 100644 --- a/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.h +++ b/Control/DataModelTest/DataModelTestDataRead/src/xAODTestReadHVec.h @@ -51,7 +51,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.cxx index 164615717c98bc6cc45d7d79c86b3c0ec7e56585..9e1fc6a73b10bba0c2dfcafb46eb4fa25e808bb4 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.cxx +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.cxx @@ -77,7 +77,7 @@ StatusCode xAODTestWrite::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestWrite::execute_r (const EventContext& ctx) const +StatusCode xAODTestWrite::execute (const EventContext& ctx) const { SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx); unsigned int count = eventInfo->event_ID()->event_number() + 1; diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.h index bf5af6cbee38f633d0361eb33727f08445dae998..b85a3695688f14a3afab41f56088613aa67c373b 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.h +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWrite.h @@ -53,7 +53,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.cxx index 05bd50affc78fa15b6a0434460d451d7055fb9c0..50bfe4227a120ccc7c3ca88b0cecf8c5d3981de7 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.cxx +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.cxx @@ -71,7 +71,7 @@ StatusCode xAODTestWriteCVec::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestWriteCVec::execute_r (const EventContext& ctx) const +StatusCode xAODTestWriteCVec::execute (const EventContext& ctx) const { //SG::ReadHandle<xAOD::EventInfo> eventInfo (m_eventInfoKey, ctx); //unsigned int count = eventInfo->eventNumber() + 1; diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.h index e7da4af15ade979137f4f5677884b5ab70d8903b..151956d790d0f606f334a23dd545bfb49377d613 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.h +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVec.h @@ -53,7 +53,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.cxx index 3f54d8c62cfe14972b9e3e2084ee3620d804a55c..ce978de84878a08a76bfb39ba7de24977c879c8e 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.cxx +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.cxx @@ -50,7 +50,7 @@ StatusCode xAODTestWriteCVecConst::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestWriteCVecConst::execute_r (const EventContext& ctx) const +StatusCode xAODTestWriteCVecConst::execute (const EventContext& ctx) const { auto coll = CxxUtils::make_unique<DMTest::CVec>(); auto store = CxxUtils::make_unique<DMTest::CAuxContainer>(); diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.h index 5802915bdc886a3df0c6682a21be9e3c1e169566..fd8d71abf2bfe9fadeac7b6927eb9978e7e50803 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.h +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCVecConst.h @@ -49,7 +49,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.cxx index b9a3417d759cab6df01285e82c0aaa7370d23d95..96a4bf7e3a2359e78f81c1ce9d89af31694a332c 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.cxx +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.cxx @@ -52,7 +52,7 @@ StatusCode xAODTestWriteCView::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestWriteCView::execute_r (const EventContext& ctx) const +StatusCode xAODTestWriteCView::execute (const EventContext& ctx) const { SG::ReadHandle<DMTest::CVec> cvec (m_cvecKey, ctx); auto cview = std::make_unique<ConstDataVector<DMTest::CView> >(SG::VIEW_ELEMENTS); diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.h index 89cf85142768914a2ef9b645609aa8a2fd4e7a37..46bc298d25765b7b49f273f005927fca0e23a5b5 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.h +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteCView.h @@ -52,7 +52,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.cxx index d091fc269321e02683e20048078887b5e2420d5f..b9598e4146528481a8da39c3d9efca6d38681d05 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.cxx +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.cxx @@ -56,7 +56,7 @@ StatusCode xAODTestWriteHVec::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestWriteHVec::execute_r (const EventContext& ctx) const +StatusCode xAODTestWriteHVec::execute (const EventContext& ctx) const { SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx); unsigned int count = eventInfo->event_ID()->event_number() + 1; diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.h index a932ea9f9ec657531496b9282c59c350d3fb644e..389b258bfa212294ed8338d42d2c01a9e41d3205 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.h +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteHVec.h @@ -53,7 +53,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /** diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.cxx b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.cxx index 549dfef439f0e48f169b5f751e559d0424a34613..efac81f2886fdf6363f32117d82684cef0a93f2a 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.cxx +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.cxx @@ -53,7 +53,7 @@ StatusCode xAODTestWriteSymlinks::initialize() /** * @brief Algorithm event processing. */ -StatusCode xAODTestWriteSymlinks::execute_r (const EventContext& ctx) const +StatusCode xAODTestWriteSymlinks::execute (const EventContext& ctx) const { SG::ReadHandle<EventInfo> eventInfo (m_eventInfoKey, ctx); SG::WriteHandle<DMTest::S2> s2 (m_s2Key, ctx); diff --git a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.h b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.h index e58707d95c4ca54cfe18ce1c4d5e94e4f4d0de3a..a5eab365e414381b4b9cd978973f58c4c393b82c 100644 --- a/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.h +++ b/Control/DataModelTest/DataModelTestDataWrite/src/xAODTestWriteSymlinks.h @@ -50,7 +50,7 @@ public: /** * @brief Algorithm event processing. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/Control/GaudiSequencer/src/AthRetrySequencer.cxx b/Control/GaudiSequencer/src/AthRetrySequencer.cxx index 39d9b9296457695728ad717a33b911725762c4c6..c7a9b0f6d4c353288c75e177171bc33e4a583224 100644 --- a/Control/GaudiSequencer/src/AthRetrySequencer.cxx +++ b/Control/GaudiSequencer/src/AthRetrySequencer.cxx @@ -44,16 +44,16 @@ AthRetrySequencer::AthRetrySequencer( const std::string& name, AthRetrySequencer::~AthRetrySequencer() {} -StatusCode AthRetrySequencer::execute() +StatusCode AthRetrySequencer::execute( const EventContext& ctx ) const { ATH_MSG_DEBUG ("Executing " << name() << "..."); int iloop = 0; while (iloop < m_maxRetries || m_maxRetries == -1) { iloop += 1; - this->AthSequencer::resetExecuted(); - if (this->AthSequencer::execute().isSuccess() && - filterPassed()) { + this->AthSequencer::resetExecuted( ctx ); + if (this->AthSequencer::execute( ctx ).isSuccess() && + this->execState(ctx).filterPassed()) { return StatusCode::SUCCESS; } } diff --git a/Control/GaudiSequencer/src/AthRetrySequencer.h b/Control/GaudiSequencer/src/AthRetrySequencer.h index be505503398360a6784c6a101051f8e66d54ebf4..0654858d380103ec57c649755b95dea630a87ee3 100644 --- a/Control/GaudiSequencer/src/AthRetrySequencer.h +++ b/Control/GaudiSequencer/src/AthRetrySequencer.h @@ -47,7 +47,7 @@ class AthRetrySequencer //AthRetrySequencer &operator=(const AthRetrySequencer &alg); // Athena algorithm's Hooks - virtual StatusCode execute(); + virtual StatusCode execute( const EventContext& ) const override; /////////////////////////////////////////////////////////////////// // Const methods: diff --git a/Control/GaudiSequencer/src/AthSequencer.cxx b/Control/GaudiSequencer/src/AthSequencer.cxx index 393fc3dc992d1137cd5e38f8306dfd7ee44f2dbf..5bee1662a514b5d35e602a5a3fe5cdb8791ee523 100644 --- a/Control/GaudiSequencer/src/AthSequencer.cxx +++ b/Control/GaudiSequencer/src/AthSequencer.cxx @@ -31,6 +31,10 @@ #include <execinfo.h> #endif +/// timer will abort job once timeout for any algorithm or sequence is reached +thread_local Athena::AlgorithmTimer s_abortTimer{ 0, NULL, Athena::AlgorithmTimer::DEFAULT }; + + #include "valgrind/valgrind.h" /** @@ -49,7 +53,7 @@ bool AthSequencer::m_installedSignalHandler; **/ AthSequencer::AthSequencer( const std::string& name, ISvcLocator* pSvcLocator ): - AthAlgorithm (name, pSvcLocator), + ::AthCommonDataStore<AthCommonMsg<Gaudi::Sequence>> ( name, pSvcLocator ), m_timeoutMilliseconds(0), m_abortTimer(0, NULL, Athena::AlgorithmTimer::DEFAULT ), m_continueEventloopOnFPE(false) @@ -89,13 +93,6 @@ AthSequencer::AthSequencer( const std::string& name, AthSequencer::~AthSequencer() {} -/// Mark as a sequencer. -bool AthSequencer::isSequence() const -{ - return true; -} - - StatusCode AthSequencer::initialize() { @@ -107,52 +104,60 @@ AthSequencer::initialize() m_timeoutMilliseconds = 0; } - std::vector<Algorithm*>* theAlgs; - std::vector<Algorithm*>::iterator it; - std::vector<Algorithm*>::iterator itend; + std::vector<Gaudi::Algorithm*>* theAlgs; + std::vector<Gaudi::Algorithm*>::iterator it; + std::vector<Gaudi::Algorithm*>::iterator itend; if (!decodeMemberNames().isSuccess()) { ATH_MSG_ERROR ("Unable to configure one or more sequencer members "); return StatusCode::FAILURE; } + StatusCode sc(StatusCode::SUCCESS); // Loop over all sub-algorithms theAlgs = subAlgorithms( ); itend = theAlgs->end( ); for (it = theAlgs->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); + Gaudi::Algorithm* theAlgorithm = (*it); if (!theAlgorithm->sysInitialize( ).isSuccess()) { - ATH_MSG_ERROR ("Unable to initialize Algorithm " << theAlgorithm->name()); - return StatusCode::FAILURE; + ATH_MSG_ERROR ("Unable to initialize Algorithm " + << theAlgorithm->type() << "/" << theAlgorithm->name()); + sc= StatusCode::FAILURE; } } - return StatusCode::SUCCESS; + return sc; } StatusCode AthSequencer::reinitialize() { + StatusCode sc(StatusCode::SUCCESS); // Bypass the loop if this sequencer is disabled if ( isEnabled( ) ) { // Loop over all members calling their reinitialize functions // if they are not disabled. - std::vector<Algorithm*>* theAlgms = subAlgorithms( ); - std::vector<Algorithm*>::iterator it; - std::vector<Algorithm*>::iterator itend = theAlgms->end( ); + std::vector<Gaudi::Algorithm*>* theAlgms = subAlgorithms( ); + std::vector<Gaudi::Algorithm*>::iterator it; + std::vector<Gaudi::Algorithm*>::iterator itend = theAlgms->end( ); for (it = theAlgms->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); - if ( ! theAlgorithm->isEnabled( ) ) { - theAlgorithm->reinitialize( ).ignore(); + Gaudi::Algorithm* theAlgorithm = (*it); + if ( theAlgorithm->isEnabled( ) ) { + if (theAlgorithm->sysReinitialize( ).isFailure()) { + ATH_MSG_ERROR ("Unable to reinitialize Algorithm " + << theAlgorithm->type () << "/" + << theAlgorithm->name()); + sc = StatusCode::FAILURE; + } } } } - return StatusCode::SUCCESS; + return sc; } StatusCode -AthSequencer::execute() +AthSequencer::execute( const EventContext& ctx ) const { volatile bool all_good = true; volatile bool caughtfpe= false; @@ -160,34 +165,32 @@ AthSequencer::execute() bool seqPass = !m_modeOR; ATH_MSG_DEBUG ("Executing " << name() << "..."); + + auto& state = execState( ctx ); // Bypass the loop if this sequencer is disabled or has already been executed - if ( isEnabled( ) && ! isExecuted( ) ) { + if ( isEnabled( ) && state.state() != AlgExecState::State::Done ) { // Prevent multiple executions of this sequencer for the current event - setExecuted( true ); + state.setState( AlgExecState::State::Executing ); // Loop over all algorithms calling their execute functions if they // are (a) not disabled, and (b) aren't already executed. Note that // in the latter case the filter state is still examined. Terminate // the loop if an algorithm indicates that it's filter didn't pass. - std::vector<Algorithm*>* subAlgms = subAlgorithms( ); - //volatile std::vector<Algorithm*>::iterator it; - //std::vector<Algorithm*>::iterator itend = subAlgms->end( ); - //for (it = subAlgms->begin(); it != itend; it++) { - //volatile Algorithm* theAlgorithm = (*it); - for (Algorithm* theAlgorithm : *subAlgms) { + const std::vector<Gaudi::Algorithm*>* subAlgms = subAlgorithms( ); + for (auto theAlgorithm : *subAlgms) { if ( theAlgorithm->isEnabled( ) ) { - if ( ! theAlgorithm->isExecuted( ) ) { - sc = executeAlgorithm (theAlgorithm, all_good, caughtfpe); + if ( theAlgorithm->execState(ctx).state() == AlgExecState::State::None ) { + sc = executeAlgorithm (theAlgorithm, ctx, all_good, caughtfpe); } if ( all_good ) { if ( !m_ignoreFilter ) { // Take the filter passed status of this algorithm as my own status - bool passed = theAlgorithm->filterPassed( ); - setFilterPassed( passed ); + bool passed = theAlgorithm->execState( ctx ).filterPassed(); + state.setFilterPassed( passed ); // The behaviour when the filter fails depends on the // StopOverride property. @@ -206,16 +209,18 @@ AthSequencer::execute() } } - if ( !m_ignoreFilter && !m_names.empty() ) setFilterPassed( seqPass ); + if ( !m_ignoreFilter && !m_names.empty() ) state.setFilterPassed( seqPass ); + state.setState( AlgExecState::State::Done ); return caughtfpe ? StatusCode::RECOVERABLE : sc; } -StatusCode AthSequencer::executeAlgorithm (Algorithm* theAlgorithm, +StatusCode AthSequencer::executeAlgorithm (Gaudi::Algorithm* theAlgorithm, + const EventContext& ctx, volatile bool& all_good, - volatile bool& caughtfpe) + volatile bool& caughtfpe) const { StatusCode sc = StatusCode::SUCCESS; @@ -226,13 +231,11 @@ StatusCode AthSequencer::executeAlgorithm (Algorithm* theAlgorithm, !sigsetjmp(s_fpe_landing_zone, 1) ) { // Call the sysExecute() of the method the algorithm - m_abortTimer.start(m_timeoutMilliseconds); - sc = theAlgorithm->sysExecute( getContext() ); + s_abortTimer.start(m_timeoutMilliseconds); + sc = theAlgorithm->sysExecute( ctx ); all_good = sc.isSuccess(); - // I think this should be done by the algorithm itself, - // but just in case... - theAlgorithm->setExecuted( true ); - int tmp=m_abortTimer.stop(); + + int tmp=s_abortTimer.stop(); // but printout only if non-zero timeout was used if (m_timeoutMilliseconds) { ATH_MSG_DEBUG ("Time left before interrupting <" @@ -253,92 +256,98 @@ StatusCode AthSequencer::executeAlgorithm (Algorithm* theAlgorithm, return sc; } -StatusCode -AthSequencer::finalize() -{ - ATH_MSG_DEBUG ("Finalizing " << name() << "..."); - return StatusCode::SUCCESS; -} - StatusCode AthSequencer::start() { + StatusCode sc(StatusCode::SUCCESS); #ifdef GAUDIKERNEL_STATEMACHINE_H_ - std::vector<Algorithm*>* theAlgs; - std::vector<Algorithm*>::iterator it; - std::vector<Algorithm*>::iterator itend; + std::vector<Gaudi::Algorithm*>* theAlgs; + std::vector<Gaudi::Algorithm*>::iterator it; + std::vector<Gaudi::Algorithm*>::iterator itend; // Loop over all sub-algorithms theAlgs = subAlgorithms( ); itend = theAlgs->end( ); for (it = theAlgs->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); + Gaudi::Algorithm* theAlgorithm = (*it); if (!theAlgorithm->sysStart( ).isSuccess()) { - ATH_MSG_ERROR ("Unable to start Algorithm " << theAlgorithm->name()); - return StatusCode::FAILURE; + ATH_MSG_ERROR ("Unable to start Algorithm " + << theAlgorithm->type () << "/" + << theAlgorithm->name()); + sc = StatusCode::FAILURE; } } #endif // !GAUDIKERNEL_STATEMACHINE_H_ - - return StatusCode::SUCCESS; + return sc; } StatusCode AthSequencer::stop() { + StatusCode sc(StatusCode::SUCCESS); #ifdef GAUDIKERNEL_STATEMACHINE_H_ // Loop over all sub-algorithms if they are not disabled. - std::vector<Algorithm*>* theAlgs; - std::vector<Algorithm*>::iterator it; - std::vector<Algorithm*>::iterator itend; + std::vector<Gaudi::Algorithm*>* theAlgs; + std::vector<Gaudi::Algorithm*>::iterator it; + std::vector<Gaudi::Algorithm*>::iterator itend; theAlgs = subAlgorithms( ); itend = theAlgs->end( ); for (it = theAlgs->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); + Gaudi::Algorithm* theAlgorithm = (*it); if (theAlgorithm->sysStop( ).isFailure()) { - ATH_MSG_ERROR ("Unable to stop Algorithm " << theAlgorithm->name()); + ATH_MSG_ERROR ("Unable to stop Algorithm " + << theAlgorithm->type () << "/" + << theAlgorithm->name()); + sc = StatusCode::FAILURE; } } #endif // !GAUDIKERNEL_STATEMACHINE_H_ - return StatusCode::SUCCESS; + return sc; } StatusCode AthSequencer::beginRun() { // Bypass the loop if this sequencer is disabled + StatusCode sc(StatusCode::SUCCESS); if ( isEnabled( ) ) { // Loop over all members calling their sysInitialize functions // if they are not disabled. Note that the Algoriithm::sysInitialize // function protects this from affecting Algorithms that have already // been initialized. - std::vector<Algorithm*>* theAlgs = subAlgorithms( ); - std::vector<Algorithm*>::iterator it; - std::vector<Algorithm*>::iterator itend = theAlgs->end( ); + std::vector<Gaudi::Algorithm*>* theAlgs = subAlgorithms( ); + std::vector<Gaudi::Algorithm*>::iterator it; + std::vector<Gaudi::Algorithm*>::iterator itend = theAlgs->end( ); for (it = theAlgs->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); + Gaudi::Algorithm* theAlgorithm = (*it); if (!theAlgorithm->sysInitialize( ).isSuccess()) { ATH_MSG_ERROR ("Unable to initialize Algorithm " << theAlgorithm->name()); - return StatusCode::FAILURE; + sc = StatusCode::FAILURE; + return sc; } } // Loop over all members calling their beginRun functions // if they are not disabled. for (it = theAlgs->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); - if ( ! theAlgorithm->isEnabled( ) ) { + Gaudi::Algorithm* theAlgorithm = (*it); + if ( theAlgorithm->isEnabled( ) ) { #ifdef __GNUC__ #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wdeprecated-declarations" #endif - theAlgorithm->beginRun( ).ignore(); + if (theAlgorithm->sysBeginRun( ).isFailure()) { + ATH_MSG_ERROR("Unable to BeginRun Algorithm " + << theAlgorithm->type() << "/" + << theAlgorithm->name()); + sc = StatusCode::FAILURE; + } #ifdef __GNUC__ #pragma GCC diagnostic pop #endif @@ -347,50 +356,56 @@ AthSequencer::beginRun() } - return StatusCode::SUCCESS; + return sc; } StatusCode AthSequencer::endRun() { + StatusCode sc(StatusCode::SUCCESS); // Bypass the loop if this sequencer is disabled if ( isEnabled( ) ) { // Loop over all members calling their endRun functions // if they are not disabled. - std::vector<Algorithm*>* theAlgms = subAlgorithms( ); - std::vector<Algorithm*>::iterator it; - std::vector<Algorithm*>::iterator itend = theAlgms->end( ); + std::vector<Gaudi::Algorithm*>* theAlgms = subAlgorithms( ); + std::vector<Gaudi::Algorithm*>::iterator it; + std::vector<Gaudi::Algorithm*>::iterator itend = theAlgms->end( ); for (it = theAlgms->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); - if ( ! theAlgorithm->isEnabled( ) ) { + Gaudi::Algorithm* theAlgorithm = (*it); + if ( theAlgorithm->isEnabled( ) ) { #ifdef __GNUC__ #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wdeprecated-declarations" #endif - theAlgorithm->endRun( ).ignore(); + if ( theAlgorithm->sysEndRun( ).isFailure() ) { + ATH_MSG_ERROR("Unable to EndRun Algorithm " + << theAlgorithm->type() << "/" + << theAlgorithm->name()); + sc = StatusCode::FAILURE; + } #ifdef __GNUC__ #pragma GCC diagnostic pop #endif } } } - return StatusCode::SUCCESS; + return sc; } void -AthSequencer::resetExecuted( ) +AthSequencer::resetExecuted( const EventContext& ctx ) const { - Algorithm::resetExecuted( ); + execState(ctx).reset(); // Loop over all members calling their resetExecuted functions // if they are not disabled. - std::vector<Algorithm*>* subAlgms = subAlgorithms( ); - std::vector<Algorithm*>::iterator it; - std::vector<Algorithm*>::iterator itend = subAlgms->end( ); + const std::vector<Gaudi::Algorithm*>* subAlgms = subAlgorithms( ); + std::vector<Gaudi::Algorithm*>::const_iterator it; + std::vector<Gaudi::Algorithm*>::const_iterator itend = subAlgms->end( ); for (it = subAlgms->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); - theAlgorithm->resetExecuted( ); + Gaudi::Algorithm* theAlgorithm = (*it); + theAlgorithm->execState(ctx).reset(); } } @@ -401,7 +416,7 @@ AthSequencer::isStopOverride( ) const } StatusCode -AthSequencer::append( Algorithm* pAlgorithm ) +AthSequencer::append( Gaudi::Algorithm* pAlgorithm ) { return append( pAlgorithm, subAlgorithms( ) ); } @@ -409,13 +424,13 @@ AthSequencer::append( Algorithm* pAlgorithm ) StatusCode AthSequencer::createAndAppend( const std::string& type, const std::string& name, - Algorithm*& pAlgorithm ) + Gaudi::Algorithm*& pAlgorithm ) { return createAndAppend( type, name, pAlgorithm, subAlgorithms( ) ); } StatusCode -AthSequencer::remove( Algorithm* pAlgorithm ) +AthSequencer::remove( Gaudi::Algorithm* pAlgorithm ) { return remove (pAlgorithm->name()); } @@ -444,16 +459,16 @@ AthSequencer::membershipHandler( Property& /* theProp */ ) **/ StatusCode -AthSequencer::append( Algorithm* pAlgorithm, - std::vector<Algorithm*>* theAlgs ) +AthSequencer::append( Gaudi::Algorithm* pAlgorithm, + std::vector<Gaudi::Algorithm*>* theAlgs ) { bool all_good = true; // Check that the specified algorithm doesn't already exist // in the membership list - std::vector<Algorithm*>::iterator it; - std::vector<Algorithm*>::iterator itend = theAlgs->end( ); + std::vector<Gaudi::Algorithm*>::iterator it; + std::vector<Gaudi::Algorithm*>::iterator itend = theAlgs->end( ); for (it = theAlgs->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); + Gaudi::Algorithm* theAlgorithm = (*it); if ( theAlgorithm == pAlgorithm ) { all_good = false; break; @@ -469,8 +484,8 @@ AthSequencer::append( Algorithm* pAlgorithm, StatusCode AthSequencer::createAndAppend( const std::string& type, const std::string& algName, - Algorithm*& pAlgorithm, - std::vector<Algorithm*>* theAlgs ) + Gaudi::Algorithm*& pAlgorithm, + std::vector<Gaudi::Algorithm*>* theAlgs ) { StatusCode result = StatusCode::FAILURE; IAlgManager* theAlgMgr; @@ -484,7 +499,7 @@ AthSequencer::createAndAppend( const std::string& type, result = theAlgMgr->createAlgorithm( type, algName, tmp ); if ( result.isSuccess( ) ) { try{ - pAlgorithm = dynamic_cast<Algorithm*>(tmp); + pAlgorithm = dynamic_cast<Gaudi::Algorithm*>(tmp); theAlgs->push_back( pAlgorithm ); } catch(...){ ATH_MSG_ERROR ("Unable to create Algorithm " << algName); @@ -498,7 +513,7 @@ AthSequencer::createAndAppend( const std::string& type, StatusCode AthSequencer::decodeNames( Gaudi::Property<std::vector<std::string>>& theNames, - std::vector<Algorithm*>* theAlgs ) + std::vector<Gaudi::Algorithm*>* theAlgs ) { StatusCode result; IAlgManager* theAlgMgr; @@ -536,10 +551,10 @@ AthSequencer::decodeNames( Gaudi::Property<std::vector<std::string>>& theNames, // Check whether the suppied name corresponds to an existing // Algorithm object. IAlgorithm* theIAlg; - Algorithm* theAlgorithm; + Gaudi::Algorithm* theAlgorithm; StatusCode status = theAlgMgr->getAlgorithm( theName, theIAlg ); if ( status.isSuccess( ) ) { - theAlgorithm = dynamic_cast<Algorithm*>(theIAlg); + theAlgorithm = dynamic_cast<Gaudi::Algorithm*>(theIAlg); if (!theAlgorithm) { ATH_MSG_WARNING (theName << " is not an Algorithm - Failed dynamic cast"); @@ -581,7 +596,7 @@ AthSequencer::decodeNames( Gaudi::Property<std::vector<std::string>>& theNames, if ( result.isSuccess() && !theAlgs->empty() ) { msg(MSG::DEBUG) << "Member list: "; bool first = true; - for (Algorithm* alg : *theAlgs) { + for (Gaudi::Algorithm* alg : *theAlgs) { if (first) first = false; else @@ -599,15 +614,15 @@ AthSequencer::decodeNames( Gaudi::Property<std::vector<std::string>>& theNames, StatusCode AthSequencer::remove( const std::string& algname, - std::vector<Algorithm*>* theAlgs ) + std::vector<Gaudi::Algorithm*>* theAlgs ) { StatusCode result = StatusCode::FAILURE; // Test that the algorithm exists in the member list - std::vector<Algorithm*>::iterator it; - std::vector<Algorithm*>::iterator itend = theAlgs->end( ); + std::vector<Gaudi::Algorithm*>::iterator it; + std::vector<Gaudi::Algorithm*>::iterator itend = theAlgs->end( ); for (it = theAlgs->begin(); it != itend; it++) { - Algorithm* theAlgorithm = (*it); + Gaudi::Algorithm* theAlgorithm = (*it); if ( theAlgorithm->name( ) == algname ) { // Algorithm with specified name exists in the algorithm list - remove it @@ -671,7 +686,7 @@ void AthSequencer::fpe_callback( int /* sig_number */, siginfo_t *info, void* /* } void -AthSequencer::cleanupAfterFPE(siginfo_t *info) +AthSequencer::cleanupAfterFPE(siginfo_t *info) const { if (info->si_signo != SIGFPE) /* should never happen */ { @@ -696,6 +711,7 @@ AthSequencer::cleanupAfterFPE(siginfo_t *info) // now have to unwind gaudi stack // Check if the AlgContextSvc is running IAlgContextSvc* algContextSvc(0); + EventContext ctx = Gaudi::Hive::currentContext(); if (service("AlgContextSvc", algContextSvc, /*createIf=*/ false).isSuccess() && algContextSvc) { IAlgorithm* alg = algContextSvc->currentAlg(); @@ -718,7 +734,7 @@ AthSequencer::cleanupAfterFPE(siginfo_t *info) } } while ( algContextSvc->algorithms().size() && algContextSvc->currentAlg()->name() != this->name() ) - if ( algContextSvc->unSetCurrentAlg(algContextSvc->currentAlg()).isFailure() ) + if ( algContextSvc->unSetCurrentAlg(algContextSvc->currentAlg(),ctx).isFailure() ) this->msg() << "cannot unwind: " << algContextSvc->currentAlg(); this->msg() << endmsg; } diff --git a/Control/GaudiSequencer/src/AthSequencer.h b/Control/GaudiSequencer/src/AthSequencer.h index 516d33275e0ceb77d85a589b730077f212b6c5f4..13fa4d45e993cda130dedb64f10abec4752964b6 100644 --- a/Control/GaudiSequencer/src/AthSequencer.h +++ b/Control/GaudiSequencer/src/AthSequencer.h @@ -13,8 +13,11 @@ #define GAUDISEQUENCER_ATHSEQUENCER_H // Include files -#include "AthenaBaseComps/AthAlgorithm.h" +#include "AthenaBaseComps/AthCommonDataStore.h" +#include "AthenaBaseComps/AthCommonMsg.h" + #include "GaudiKernel/Property.h" +#include "Gaudi/Sequence.h" #include "AthenaKernel/AlgorithmTimer.h" @@ -34,7 +37,8 @@ ** terminated and the AthSequencer assumes the same filtered state as the ** last member. **/ -class AthSequencer : public AthAlgorithm +class AthSequencer + : public AthCommonDataStore<AthCommonMsg<Gaudi::Sequence>> { public: @@ -54,8 +58,6 @@ public: ** Public Function Members ** *****************************/ - /// Mark as a sequencer. - virtual bool isSequence() const override final; /** ** Initialization of a sequencer. Typically things like histogram creation, @@ -74,13 +76,8 @@ public: ** The actions to be performed by the sequencer on an event. This method ** is invoked once per event. **/ - virtual StatusCode execute( ) override; - - /** - ** AthSequencer finalization. - **/ - virtual StatusCode finalize( ) override; - + virtual StatusCode execute( const EventContext& ctx ) const override; + /** ** AthSequencer beginRun. **/ @@ -102,7 +99,7 @@ public: /** ** Reset the AthSequencer executed state for the current event. **/ - virtual void resetExecuted( ) override; + virtual void resetExecuted( const EventContext& ctx ) const; /** ** Has the StopOverride mode been set? @@ -112,7 +109,7 @@ public: /** ** Append an algorithm to the sequencer. **/ - StatusCode append( Algorithm* pAlgorithm ); + StatusCode append( Gaudi::Algorithm* pAlgorithm ); /** ** Create a algorithm and append it to the sequencer. A call to this method @@ -126,13 +123,13 @@ public: StatusCode createAndAppend( const std::string& type, // The concrete algorithm class of the algorithm const std::string& name, // The name to be given to the algorithm - Algorithm*& pAlgorithm // Set to point to the newly created algorithm object + Gaudi::Algorithm*& pAlgorithm // Set to point to the newly created algorithm object ); /** ** Remove the specified algorithm from the sequencer **/ - StatusCode remove( Algorithm* pAlgorithm ); + StatusCode remove( Gaudi::Algorithm* pAlgorithm ); StatusCode remove( const std::string& name ); /// Decode Member Name list @@ -152,8 +149,8 @@ protected: /** ** Append an algorithm to the sequencer. **/ - StatusCode append( Algorithm* pAlgorithm, - std::vector<Algorithm*>* theAlgs ); + StatusCode append( Gaudi::Algorithm* pAlgorithm, + std::vector<Gaudi::Algorithm*>* theAlgs ); /** ** Create a algorithm and append it to the sequencer. A call to this method @@ -167,21 +164,21 @@ protected: StatusCode createAndAppend( const std::string& type, // The concrete algorithm class of the algorithm const std::string& name, // The name to be given to the algorithm - Algorithm*& pAlgorithm, // Set to point to the newly created algorithm object - std::vector<Algorithm*>* theAlgs + Gaudi::Algorithm*& pAlgorithm, // Set to point to the newly created algorithm object + std::vector<Gaudi::Algorithm*>* theAlgs ); /** ** Decode algorithm names, creating or appending algorithms as appropriate **/ StatusCode decodeNames( Gaudi::Property<std::vector<std::string>>& theNames, - std::vector<Algorithm*>* theAlgs ); + std::vector<Gaudi::Algorithm*>* theAlgs ); /** ** Remove the specified algorithm from the sequencer **/ - StatusCode remove( const std::string& algname, std::vector<Algorithm*>* theAlgs ); + StatusCode remove( const std::string& algname, std::vector<Gaudi::Algorithm*>* theAlgs ); private: @@ -201,9 +198,10 @@ private: /// Run one algorithm. /// Broken out to avoid warnings related to longjmp. - StatusCode executeAlgorithm (Algorithm* theAlgorithm, + StatusCode executeAlgorithm (Gaudi::Algorithm* theAlgorithm, + const EventContext& ctx, volatile bool& all_good, - volatile bool& caughtfpe); + volatile bool& caughtfpe) const; /************************** ** Private Data Members ** @@ -247,7 +245,7 @@ private: static void fpe_trap_enable(); static void fpe_callback(int, siginfo_t*, void*); static bool prepareCatchAndEnableFPE(); - void cleanupAfterFPE(siginfo_t*); + void cleanupAfterFPE(siginfo_t*) const; static void uninstallFPESignalHandler(); static const size_t s_maxArraySize = 50; diff --git a/Control/SGComps/src/AddressRemappingSvc.cxx b/Control/SGComps/src/AddressRemappingSvc.cxx index e976546742877a517b66d3a6c8d6902946c0d48a..8efdb0af1a2d89c2b1553bcd1ddb8d805176d175 100644 --- a/Control/SGComps/src/AddressRemappingSvc.cxx +++ b/Control/SGComps/src/AddressRemappingSvc.cxx @@ -465,7 +465,7 @@ void AddressRemappingSvc::initDeletes() m_haveDeletes = true; for (IAlgorithm* ialg : m_algResourcePool->getFlatAlgList()) { - if (Algorithm* alg = dynamic_cast<Algorithm*> (ialg)) { + if (Gaudi::Algorithm* alg = dynamic_cast<Gaudi::Algorithm*> (ialg)) { // Need to ignore SGInputLoader; it'll have output deps // on everything being read. if (alg->name() == "SGInputLoader") continue; @@ -488,7 +488,10 @@ void AddressRemappingSvc::initDeletes() } } } + } else { + ATH_MSG_WARNING(ialg->name() << " doesn't seem to be an Algorithm" ); } + } } //______________________________________________________________________________ diff --git a/Control/StoreGate/StoreGate/MetaHandleKey.icc b/Control/StoreGate/StoreGate/MetaHandleKey.icc index 1bfa1f608995964a729539da78bf99f9502b3c90..7cfbf252105773801b49a4ee6fb9d5dfaa3daa8e 100644 --- a/Control/StoreGate/StoreGate/MetaHandleKey.icc +++ b/Control/StoreGate/StoreGate/MetaHandleKey.icc @@ -49,7 +49,7 @@ namespace SG { return StatusCode::FAILURE; } else { - msg << MSG::INFO << "MetaCont found with key= " + msg << MSG::DEBUG << "MetaCont found with key= " << SG::VarHandleKey::key() << endmsg; } } else { diff --git a/Control/StoreGate/StoreGate/ReadDecorHandle.h b/Control/StoreGate/StoreGate/ReadDecorHandle.h index 025ca9964e6efa70da33b04a2b69a48c53245032..83884e546853952c1f402a9af0d909275bdddd03 100644 --- a/Control/StoreGate/StoreGate/ReadDecorHandle.h +++ b/Control/StoreGate/StoreGate/ReadDecorHandle.h @@ -73,7 +73,7 @@ namespace SG { * ... * } * - * StatusCode MyAlgorithm::execute_r (const EventContext& ctx) const + * StatusCode MyAlgorithm::execute (const EventContext& ctx) const * { * SG::ReadDecorHandle<MyCont, float> h (m_key, ctx); * for (const MyObj& o : *h) { // Access the container. diff --git a/Control/StoreGate/StoreGate/ReadDecorHandleKey.h b/Control/StoreGate/StoreGate/ReadDecorHandleKey.h index 1e4f643519d5f38d575286ca87a8cac3a2171cf0..d05be29b4aa3c3f98fdf1cfd30b25b4745018405 100644 --- a/Control/StoreGate/StoreGate/ReadDecorHandleKey.h +++ b/Control/StoreGate/StoreGate/ReadDecorHandleKey.h @@ -55,7 +55,7 @@ namespace SG { * ... * } * - * StatusCode MyAlgorithm::execute_r (const EventContext& ctx) const + * StatusCode MyAlgorithm::execute (const EventContext& ctx) const * { * SG::ReadDecorHandle<MyCont, float> h (m_key, ctx); * for (const MyObj& o : *h) { // Access the container. diff --git a/Control/StoreGate/StoreGate/WriteDecorHandle.h b/Control/StoreGate/StoreGate/WriteDecorHandle.h index ced61555169efd9d5d63ab9a27268396efeaf188..c50b96f81bd72d3f39cd68c02ad3c5e018d27352 100644 --- a/Control/StoreGate/StoreGate/WriteDecorHandle.h +++ b/Control/StoreGate/StoreGate/WriteDecorHandle.h @@ -75,7 +75,7 @@ namespace SG { * ... * } * - * StatusCode MyAlgorithm::execute_r (const EventContext& ctx) const + * StatusCode MyAlgorithm::execute (const EventContext& ctx) const * { * SG::WriteDecorHandle<MyCont, float> h (m_key, ctx); * for (const MyObj& o : *h) { // Access the container. diff --git a/Control/StoreGate/StoreGate/WriteDecorHandleKey.h b/Control/StoreGate/StoreGate/WriteDecorHandleKey.h index 8576bc78b070ae0257ba5b582f6141ccf82a8326..e8820fb81ebe9b85fe76272686e2695dd0deeeb8 100644 --- a/Control/StoreGate/StoreGate/WriteDecorHandleKey.h +++ b/Control/StoreGate/StoreGate/WriteDecorHandleKey.h @@ -60,7 +60,7 @@ namespace SG { * ... * } * - * StatusCode MyAlgorithm::execute_r (const EventContext& ctx) const + * StatusCode MyAlgorithm::execute (const EventContext& ctx) const * { * SG::WriteDecorHandle<MyCont, float> h (m_key, ctx); * for (const MyObj& o : *h) { // Access the container. diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.cxx index cdd88c845a488efac3c90f95c0c695e4e6861db0..4c45d79ceff27dc4834fcb85e19ddf8d59be9e96 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.cxx +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.cxx @@ -41,7 +41,7 @@ StatusCode ReWriteData::initialize() { return StatusCode::SUCCESS; } //___________________________________________________________________________ -StatusCode ReWriteData::execute_r (const EventContext& ctx) const { +StatusCode ReWriteData::execute (const EventContext& ctx) const { ATH_MSG_DEBUG("in execute()"); if (!m_exampleHitKey.key().empty()) { diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.h index 2d98b4f84f0216d2992955f56181ebca67db96ee..5a564c8162feb0e4b523584386f419eeff3f2482 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.h +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReWriteData.h @@ -32,7 +32,7 @@ public: // Constructor and Destructor public: /// Gaudi Service Interface method implementations: virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; private: diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.cxx index 446a26a5f3b3057c1ef8dceb1225844e6e2f96b4..0cff7e2dc641f1fc306d3768a5027acd596a344d 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.cxx +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.cxx @@ -54,7 +54,7 @@ StatusCode ReadData::initialize() { return StatusCode::SUCCESS; } //___________________________________________________________________________ -StatusCode ReadData::execute_r (const EventContext& ctx) const { +StatusCode ReadData::execute (const EventContext& ctx) const { ATH_MSG_DEBUG("in execute()"); SG::ConstIterator<EventStreamInfo> esi1, esi2; diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.h index 62bad7121f9091488bdbb94f21ce37c1b5a440c1..4c209285fa8571586ee6645253f59cab982aa5ef 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.h +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/ReadData.h @@ -34,7 +34,7 @@ public: // Constructor and Destructor public: /// Gaudi Service Interface method implementations: virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; private: diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.cxx index 85e08478ebc86dfaf6323947ad94b781744a264e..a28b1e16e362d1d6a67cbef012837e3cf09e1ecb 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.cxx +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.cxx @@ -45,7 +45,7 @@ StatusCode WriteCond::initialize() { return StatusCode::SUCCESS; } //___________________________________________________________________________ -StatusCode WriteCond::execute_r (const EventContext& ctx) const { +StatusCode WriteCond::execute (const EventContext& ctx) const { ATH_MSG_DEBUG("in execute()"); SG::ReadHandle<ExampleHitContainer> hits (m_exampleHitKey, ctx); diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.h index 813489ff99dac9069ce4121175c4de80b337e3b2..330b4fa343a8e6a7918e8d12d0f5b06f55d91e59 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.h +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteCond.h @@ -30,7 +30,7 @@ public: // Constructor and Destructor public: /// Gaudi Service Interface method implementations: virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode stop() override; private: diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.cxx index 014e904dd27b8084afdffa592c0fa1974e57dcfc..e06c58555536ef68aa7ae9a8f38d4cae2e50398a 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.cxx +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.cxx @@ -32,7 +32,7 @@ StatusCode WriteData::initialize() { return StatusCode::SUCCESS; } //___________________________________________________________________________ -StatusCode WriteData::execute_r (const EventContext& ctx) const { +StatusCode WriteData::execute (const EventContext& ctx) const { ATH_MSG_DEBUG("in execute()"); int eventNumber = ctx.eventID().event_number(); diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.h index 03ccdcd069173bfad313ef50a38513571547d90e..0eedbdc1d1fa2f34e361a4598caa60c32c2e8afe 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.h +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteData.h @@ -30,7 +30,7 @@ public: // Constructor and Destructor public: /// Gaudi Service Interface method implementations: virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; SG::WriteHandleKey<ExampleHitContainer> m_exampleHitKey { this, "ExampleHitKey", "MyHits" }; diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.cxx b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.cxx index 4d55425c6c6f33b7d491a96b0daa49ee1ca87083..d51e4620a5f2b5dfec5be20316d8df506ce5e89a 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.cxx +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.cxx @@ -50,7 +50,7 @@ StatusCode WriteTag::initialize() { return StatusCode::SUCCESS; } //___________________________________________________________________________ -StatusCode WriteTag::execute_r (const EventContext& ctx) const { +StatusCode WriteTag::execute (const EventContext& ctx) const { ATH_MSG_DEBUG("in execute()"); unsigned int eventNumber = ctx.eventID().event_number(); diff --git a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.h b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.h index 7d7d1006a8f36aefc5b48678f3ea1932dc138c19..874f3f5124fbc1b5aeb54ed7ef9b883116eeb0c6 100755 --- a/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.h +++ b/Database/AthenaPOOL/AthenaPoolExample/AthenaPoolExampleAlgorithms/src/WriteTag.h @@ -33,7 +33,7 @@ public: // Constructor and Destructor public: /// Gaudi Service Interface method implementations: virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; private: diff --git a/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.cxx b/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.cxx index a34750fb2167a47b6a75bda65eeef0c86afbe9ea..1f20118e7e8e236b0276d06be094eabddf09ca97 100644 --- a/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.cxx +++ b/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.cxx @@ -34,7 +34,7 @@ StatusCode MakeInputDataHeader::initialize() { return(StatusCode::SUCCESS); } //___________________________________________________________________________ -StatusCode MakeInputDataHeader::execute_r (const EventContext& ctx) const +StatusCode MakeInputDataHeader::execute (const EventContext& ctx) const { SG::ReadHandle<DataHeader> dh (m_streamName, ctx); ATH_CHECK( dh.alias (m_aliasName) ); diff --git a/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.h b/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.h index a99cf8fc9bdb3677ae688ec3881b7cf9d3993a12..4fc503d7ac30eb890553599cced7c78d6d4fafe0 100644 --- a/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.h +++ b/Database/AthenaPOOL/OutputStreamAthenaPool/src/MakeInputDataHeader.h @@ -38,7 +38,7 @@ public: virtual ~MakeInputDataHeader(); /// AthAlgorithm Interface method implementations: virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& ctx) const override; + virtual StatusCode execute(const EventContext& ctx) const override; virtual StatusCode finalize() override; private: diff --git a/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.cxx b/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.cxx index 1085be4378ff911894aa09b54255cedf6d892a7f..81783c7e1cb8dcdbf6411ae32eaa732f495547fa 100644 --- a/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.cxx +++ b/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.cxx @@ -34,7 +34,7 @@ OnlineLumiCalibrationCondAlg::initialize() StatusCode -OnlineLumiCalibrationCondAlg::execute_r (const EventContext& ctx) const +OnlineLumiCalibrationCondAlg::execute (const EventContext& ctx) const { SG::ReadCondHandle<CondAttrListCollection> calibrationFolder (m_calibrationFolderName, ctx); diff --git a/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.h b/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.h index 4b3966d57342125e7b1db26e07a50893cb48b1f2..d267e68b5e2e56b7586026fdb7ce3c5faf87d86f 100644 --- a/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.h +++ b/Database/CoolLumiUtilities/src/OnlineLumiCalibrationCondAlg.h @@ -29,7 +29,7 @@ public: virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/Database/CoolLumiUtilities/test/OnlineLumiCalibrationCondAlg_test.cxx b/Database/CoolLumiUtilities/test/OnlineLumiCalibrationCondAlg_test.cxx index d0ad5af704a72576fe9b83ac75adc83e03f6bb6d..3eaea94dc88902d47e7489eab7181d84c52a85f2 100644 --- a/Database/CoolLumiUtilities/test/OnlineLumiCalibrationCondAlg_test.cxx +++ b/Database/CoolLumiUtilities/test/OnlineLumiCalibrationCondAlg_test.cxx @@ -104,7 +104,7 @@ void test1 (ISvcLocator* svcloc) ServiceHandle<StoreGateSvc> conditionStore ("ConditionStore", "test"); assert( conditionStore->record (std::move (cc1), "testcalib") ); - assert( alg.execute_r (ctx).isSuccess() ); + assert( alg.execute (ctx).isSuccess() ); CondCont<OnlineLumiCalibrationCondData>* cc2 = nullptr; assert( conditionStore->retrieve (cc2, "OnlineLumiCalibrationCondData").isSuccess() ); diff --git a/DetectorDescription/IdDictParser/test/tid.cxx b/DetectorDescription/IdDictParser/test/tid.cxx index 71a75efb57fad78d4d1fc7ebe71ceb33e22083b0..c810e16c3beac39e692b66e19f2e7852f2ef4458 100755 --- a/DetectorDescription/IdDictParser/test/tid.cxx +++ b/DetectorDescription/IdDictParser/test/tid.cxx @@ -97,7 +97,10 @@ int main (int argc, char* argv[]) // IdDictDictionary::bits32 b = dictionary->pack32 (id, 0, 6); Identifier packedB((Identifier::value_type)0); - dictionary->pack32 (id, 0, 6, packedB); + if (dictionary->pack32 (id, 0, 6, packedB) != 0) { + std::cout << "error from pack32\n"; + return 1; + } std::cout << "b=[" << packedB << "]" << std::endl; diff --git a/DetectorDescription/RegSelSvcTest/CMakeLists.txt b/DetectorDescription/RegSelSvcTest/CMakeLists.txt index d71d783ae86c3623a61e2062451aef14b6716c78..8928aa2dea0b440aaa55f621a63db1cb5f1d7c7a 100644 --- a/DetectorDescription/RegSelSvcTest/CMakeLists.txt +++ b/DetectorDescription/RegSelSvcTest/CMakeLists.txt @@ -7,8 +7,6 @@ atlas_subdir( RegSelSvcTest ) # Declare the package's dependencies: atlas_depends_on_subdirs( PUBLIC - Control/CLIDSvc - Control/SGTools DetectorDescription/IRegionSelector DetectorDescription/Identifier GaudiKernel @@ -27,11 +25,11 @@ atlas_depends_on_subdirs( PUBLIC atlas_add_library( RegSelSvcTestLib NO_PUBLIC_HEADERS src/*.cxx - PRIVATE_LINK_LIBRARIES SGTools IRegionSelector Identifier GaudiKernel StoreGateLib SGtests AthenaBaseComps AthenaPoolUtilities RegSelLUT PathResolver TrigSteeringEvent ) + PRIVATE_LINK_LIBRARIES IRegionSelector Identifier GaudiKernel StoreGateLib SGtests AthenaBaseComps AthenaPoolUtilities RegSelLUT PathResolver TrigSteeringEvent ) atlas_add_component( RegSelSvcTest src/components/*.cxx - LINK_LIBRARIES SGTools IRegionSelector Identifier GaudiKernel AthenaBaseComps StoreGateLib SGtests AthenaPoolUtilities RegSelLUT PathResolver TrigSteeringEvent RegionSelectorLib RegSelSvcTestLib ) + LINK_LIBRARIES IRegionSelector Identifier GaudiKernel AthenaBaseComps StoreGateLib SGtests AthenaPoolUtilities RegSelLUT PathResolver TrigSteeringEvent RegionSelectorLib RegSelSvcTestLib ) atlas_add_test( RegSel_dump SCRIPT test/test_RegSel_dump.sh PROPERTIES TIMEOUT 1200 diff --git a/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.cxx b/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.cxx index 78301af97fd7a3f347591f4fb4065dc56a497312..c483744ceddba0dc00f690bbac7ec0346650e4e2 100644 --- a/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.cxx +++ b/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.cxx @@ -29,7 +29,7 @@ StatusCode RegSelTestAlg::finalize() { return StatusCode::SUCCESS; } -StatusCode RegSelTestAlg::execute_r(const EventContext& /*context*/) const { +StatusCode RegSelTestAlg::execute(const EventContext& /*context*/) const { ATH_MSG_DEBUG ("Executing " << name() << "..."); if ( m_mt ) CHECK( mt() ); diff --git a/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.h b/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.h index 724b2a25731444ef1d822e195a0244d790370505..6ff141f9dffad3bc9318cd6ac97888b8241655ce 100644 --- a/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.h +++ b/DetectorDescription/RegSelSvcTest/src/RegSelTestAlg.h @@ -25,7 +25,7 @@ class RegSelTestAlg virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; virtual StatusCode finalize() override; StatusCode dump() const; StatusCode mt() const; diff --git a/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.cxx b/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.cxx index 4d712dc83cca66a254b9f511afed70444d0cb885..1f796ef516ac30fa6936615ceac208ad61e2b99c 100644 --- a/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.cxx +++ b/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.cxx @@ -57,7 +57,7 @@ private: -StatusCode ROBDataProviderMTTest::execute_r( const EventContext& context ) const +StatusCode ROBDataProviderMTTest::execute( const EventContext& context ) const { // will be asking for many ROBs from the list and check if all of them come from the same physical event const RawEvent* ev = m_robDataProvider->getEvent( context ); diff --git a/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.h b/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.h index 12468b2d71dd1c04423f6261608c32fb9008d202..853641e4c39c333abc16fc3f9690174bf30c944f 100644 --- a/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.h +++ b/Event/ByteStreamCnvSvcBase/src/ROBDataProviderMTTest.h @@ -28,7 +28,7 @@ class ROBDataProviderMTTest //ROBDataProviderMTTest &operator=(const ROBDataProviderMTTest &alg); StatusCode initialize() override; - StatusCode execute_r(const EventContext& context) const override; + StatusCode execute(const EventContext& context) const override; StatusCode finalize() override; private: diff --git a/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.cxx b/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.cxx index cdc4b67c9f961d0a824233e0ff42ba0484e4f5bf..9ad9029219a1501730a4441811651b1387c45c52 100644 --- a/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.cxx +++ b/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.cxx @@ -59,7 +59,7 @@ namespace xAODMaker { return StatusCode::SUCCESS; } - StatusCode EventInfoCnvAlg::execute_r (const EventContext& ctx) const { + StatusCode EventInfoCnvAlg::execute (const EventContext& ctx) const { // Check if anything needs to be done: // FIXME: Job configuration should be fixed so we don't need this test. @@ -158,7 +158,7 @@ namespace xAODMaker { ATH_MSG_DEBUG( "Preparing xAOD::EventInfo object in beginRun()" ); // Run the conversion using the execute function: - CHECK( execute_r (Gaudi::Hive::currentContext()) ); + CHECK( execute (Gaudi::Hive::currentContext()) ); } // Return gracefully: diff --git a/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.h b/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.h index ba1887428768786d846e3f0bfde690e63c455289..40781a4634a511151bf2557a5a337d7cc5d731be 100644 --- a/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.h +++ b/Event/xAOD/xAODEventInfoCnv/src/EventInfoCnvAlg.h @@ -43,7 +43,7 @@ namespace xAODMaker { /// Function initialising the algorithm virtual StatusCode initialize() override; /// Function executing the algorithm - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; /// Function executed at the beginning of the job, once the first event /// from the input file is already open diff --git a/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/CompositeParticleAuxContainer_v1.h b/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/CompositeParticleAuxContainer_v1.h index 96362abdfa144f5838a0e691cbc93cf0090d3926..3f5ecae3d5abed6f15cd028ccd253738b05601e1 100644 --- a/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/CompositeParticleAuxContainer_v1.h +++ b/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/CompositeParticleAuxContainer_v1.h @@ -1,7 +1,7 @@ // Dear emacs, this is -*- c++ -*- /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ // $Id: CompositeParticleAuxContainer_v1.h 677235 2015-06-22 16:08:20Z kkoeneke $ @@ -35,7 +35,7 @@ namespace xAOD { /// Default constructor CompositeParticleAuxContainer_v1(); /// Destructor - ~CompositeParticleAuxContainer_v1() {} + ~CompositeParticleAuxContainer_v1() = default; diff --git a/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/ParticleAuxContainer_v1.h b/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/ParticleAuxContainer_v1.h index b6b50707a626767e2615fee3035f8fb402ebe523..23c0f44b06a2fca7a4a0711d565143dbdb2a534b 100644 --- a/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/ParticleAuxContainer_v1.h +++ b/Event/xAOD/xAODParticleEvent/xAODParticleEvent/versions/ParticleAuxContainer_v1.h @@ -1,7 +1,7 @@ // Dear emacs, this is -*- c++ -*- /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ // $Id: ParticleAuxContainer_v1.h 637086 2014-12-19 16:02:19Z kkoeneke $ @@ -34,7 +34,7 @@ namespace xAOD { /// Default constructor ParticleAuxContainer_v1(); /// Destructor - ~ParticleAuxContainer_v1() {} + ~ParticleAuxContainer_v1() = default; diff --git a/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.cxx b/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.cxx index 6fe5bd6b21169b0baa103a21deff5812dcf32f39..1e8ed9c0126c5ca8ba9eb48530f1911142305358 100644 --- a/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.cxx +++ b/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.cxx @@ -85,7 +85,7 @@ namespace xAODMaker { } - StatusCode xAODTruthCnvAlg::execute_r (const EventContext& ctx) const { + StatusCode xAODTruthCnvAlg::execute (const EventContext& ctx) const { SG::WriteHandle<xAODTruthParticleLinkVector> truthLinkVec(m_truthLinkContainerKey, ctx); ATH_CHECK(truthLinkVec.record(std::make_unique<xAODTruthParticleLinkVector>())); diff --git a/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.h b/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.h index 10b3fb5c02b7864a1c93fcc6db47e6a5d3f66bad..dcdccf5d2bb25e00a7f3cb33ad4e401a8750d4ac 100644 --- a/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.h +++ b/Event/xAOD/xAODTruthCnv/src/xAODTruthCnvAlg.h @@ -53,7 +53,7 @@ namespace xAODMaker { /// Function initialising the algorithm virtual StatusCode initialize() override; /// Function executing the algorithm - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/ForwardDetectors/LUCID/LUCID_DigiTools/LUCID_DigiTools/LUCID_DigiSettings.h b/ForwardDetectors/LUCID/LUCID_DigiTools/LUCID_DigiTools/LUCID_DigiSettings.h index b217134a125279b3aaff0f83b84b27e7bac407a7..fcc929838aa5ed7044fbcb7e23c04700718028a3 100644 --- a/ForwardDetectors/LUCID/LUCID_DigiTools/LUCID_DigiTools/LUCID_DigiSettings.h +++ b/ForwardDetectors/LUCID/LUCID_DigiTools/LUCID_DigiTools/LUCID_DigiSettings.h @@ -27,7 +27,7 @@ class LUCID_DigiSettings { double GetDigiParDouble(std::string); int GetDigiParInt (std::string); - void OverwriteDigiParProperties(Algorithm*); + void OverwriteDigiParProperties(Gaudi::Algorithm*); void OverwriteDigiParValues(); void Print() const; diff --git a/ForwardDetectors/LUCID/LUCID_DigiTools/src/LUCID_DigiSettings.cxx b/ForwardDetectors/LUCID/LUCID_DigiTools/src/LUCID_DigiSettings.cxx index 7085cc2676a40b3e4429650ae8ac9a2cb4ab63ee..37fe7480ba4c028eb40998f8bb1229448115eca9 100644 --- a/ForwardDetectors/LUCID/LUCID_DigiTools/src/LUCID_DigiSettings.cxx +++ b/ForwardDetectors/LUCID/LUCID_DigiTools/src/LUCID_DigiSettings.cxx @@ -45,7 +45,7 @@ void LUCID_DigiSettings::SetDefaultValues() { m_tdcFedNoiseFactor = 0.8; } -void LUCID_DigiSettings::OverwriteDigiParProperties(Algorithm* alg) { +void LUCID_DigiSettings::OverwriteDigiParProperties(Gaudi::Algorithm* alg) { std::map <std::string, parDouble>::iterator doubleMapIt = m_doubleMap.begin(); std::map <std::string, parInt>::iterator intMapIt = m_intMap.begin(); diff --git a/Generators/GenAnalysisTools/TruthHelper/TruthHelper/GenIMCselector.h b/Generators/GenAnalysisTools/TruthHelper/TruthHelper/GenIMCselector.h index 50b81a3bd47856ece3fdcb270bf80c85739b4722..cd2e7f1edad5bd43356ee1434956cbb9b137a3e2 100644 --- a/Generators/GenAnalysisTools/TruthHelper/TruthHelper/GenIMCselector.h +++ b/Generators/GenAnalysisTools/TruthHelper/TruthHelper/GenIMCselector.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ #ifndef TRUTHHELPER_GENIMCSELECTOR_H @@ -17,7 +17,7 @@ namespace TruthHelper { public: // Virtual destructor to allow inheritance - virtual ~GenIMCselector() { } + virtual ~GenIMCselector() = default; // Allow selector objects to be copied (to be implemented). virtual GenIMCselector* create() const = 0; diff --git a/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.cxx b/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.cxx index 9d8a72ff20bed2c2c18768c200f7a797f2b52c16..45ff6f53daab16eaf0f3abfa675fbe2ca6908249 100644 --- a/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.cxx +++ b/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.cxx @@ -42,9 +42,9 @@ StatusCode MTCalibPebHypoAlg::finalize() { } // ============================================================================= -// Implementation of AthReentrantAlgorithm::execute_r +// Implementation of AthReentrantAlgorithm::execute // ============================================================================= -StatusCode MTCalibPebHypoAlg::execute_r(const EventContext& eventContext) const { +StatusCode MTCalibPebHypoAlg::execute(const EventContext& eventContext) const { ATH_MSG_DEBUG("Executing " << name()); // New output diff --git a/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.h b/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.h index 81cf142d5455628ba172654025826b90d53c0a17..af8791804762b6eb53d15aa5c92729cfc8a0c0e8 100644 --- a/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.h +++ b/HLT/Trigger/TrigControl/TrigExamples/TrigExPartialEB/src/MTCalibPebHypoAlg.h @@ -22,7 +22,7 @@ public: // ------------------------- AthReentrantAlgorithm methods ------------------- virtual StatusCode initialize() override; virtual StatusCode finalize() override; - virtual StatusCode execute_r(const EventContext& eventContext) const override; + virtual StatusCode execute(const EventContext& eventContext) const override; private: ToolHandleArray<MTCalibPebHypoTool> m_hypoTools {this, "HypoTools", {}, "Tools to perform selection"}; }; diff --git a/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.cxx b/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.cxx index a7cee61fc80e18f282a8d26c518e300796cd89b7..bdd0ef2c8497342d9ede62875f5e1d63a102f025 100644 --- a/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.cxx +++ b/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.cxx @@ -27,7 +27,7 @@ StatusCode InDet::InDetBeamSpotReader::initialize() { return StatusCode::SUCCESS; } -StatusCode InDet::InDetBeamSpotReader::execute_r(const EventContext& ctx) const { +StatusCode InDet::InDetBeamSpotReader::execute(const EventContext& ctx) const { ATH_MSG_DEBUG( "in execute()"); //get the set of diff --git a/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.h b/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.h index 3be3e5f167a2051514311fca8c3499e139e79326..8533e0c824744c74b09df77476c8d93de6858144 100644 --- a/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.h +++ b/InnerDetector/InDetCalibAlgs/InDetBeamSpotFinder/src/InDetBeamSpotReader.h @@ -27,7 +27,7 @@ namespace InDet { //Standard constructor and methods InDetBeamSpotReader (const std::string& name, ISvcLocator* pSvcLocator); StatusCode initialize() override; - StatusCode execute_r(const EventContext& ctx) const override; + StatusCode execute(const EventContext& ctx) const override; StatusCode finalize() override; diff --git a/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.cxx b/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.cxx index 69ed0bb97d540c1dbd12942b354c4b4029874c26..16ca558d36b213bfaaebda72b2b5fb4a5a2d3ac1 100644 --- a/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.cxx +++ b/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.cxx @@ -151,7 +151,7 @@ StatusCode SpecialPixelMapCondAlg::initialize() return StatusCode::SUCCESS; } -StatusCode SpecialPixelMapCondAlg::execute_r (const EventContext& ctx) const +StatusCode SpecialPixelMapCondAlg::execute (const EventContext& ctx) const { ATH_MSG_DEBUG("Entering SpecialPixelMapCondAlg"); const std::array<const SG::ReadCondHandleKey<CondAttrListCollection>*, s_max> condarray{{ &m_ConAttrList1, &m_ConAttrList2, &m_ConAttrList3, &m_ConAttrList4 }}; diff --git a/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.h b/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.h index 57b77ee1dfd9da0780a99ddd3cb63b7bfcda78b8..02be8f33b188ae5768873de8540226be2fd140a2 100644 --- a/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.h +++ b/InnerDetector/InDetConditions/PixelConditionsAlgorithms/src/SpecialPixelMapCondAlg.h @@ -23,7 +23,7 @@ class SpecialPixelMapCondAlg: public AthReentrantAlgorithm { ~SpecialPixelMapCondAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext&) const override; + virtual StatusCode execute (const EventContext&) const override; private: diff --git a/InnerDetector/InDetDetDescr/PixelCabling/run/dumpCabling_jobOptions.py b/InnerDetector/InDetDetDescr/PixelCabling/run/dumpCabling_jobOptions.py index 9dbdab7fea11985258aee5ebe892225cf92d524f..99a94377c32969407c9408309f4750d21b0f5748 100644 --- a/InnerDetector/InDetDetDescr/PixelCabling/run/dumpCabling_jobOptions.py +++ b/InnerDetector/InDetDetDescr/PixelCabling/run/dumpCabling_jobOptions.py @@ -4,8 +4,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) from AthenaCommon.GlobalFlags import globalflags globalflags.DataSource = 'data' diff --git a/InnerDetector/InDetDetDescr/PixelCabling/run/readCabling_jobOptions.py b/InnerDetector/InDetDetDescr/PixelCabling/run/readCabling_jobOptions.py index 3c256dfb85bc8db7c34227beac475ce1f94f88f5..51280c9fe8f4f4c4747d2b32ac07737958658d18 100644 --- a/InnerDetector/InDetDetDescr/PixelCabling/run/readCabling_jobOptions.py +++ b/InnerDetector/InDetDetDescr/PixelCabling/run/readCabling_jobOptions.py @@ -4,8 +4,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) from AthenaCommon.GlobalFlags import globalflags globalflags.DataSource = 'data' diff --git a/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.cxx b/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.cxx index ef471a0cd7787c66c92e092bf53ba05d4428af6a..fd9401c1492c9f7be504e265ccbb1bd3c5e72da9 100644 --- a/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.cxx +++ b/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.cxx @@ -327,7 +327,7 @@ const std::vector<float>* SCT_DistortionsTool::readDistortions(int RegionID, int } -bool SCT_DistortionsTool::loadData() const +bool SCT_DistortionsTool::loadData() { int temp(0); @@ -528,7 +528,7 @@ int SCT_DistortionsTool::identifyRegion(IdentifierHash id) const ATH_MSG_DEBUG( "Identifying module common profile region: " ); //int REGION=0;//1=J1,2=J2,3=UK,4=USA,5=Scand //Identifier::value_type ID = id.get_compact(); - std::map<int,int>::iterator it; + std::map<int,int>::const_iterator it; int ID = id; it = m_moduleSites.find(ID); diff --git a/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.h b/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.h index 4817b5b5959a4b2e12f86b9de955c4d3e78c0b3e..00fbde4aefef2e4a9c686fa42e997d9f12bcbd0f 100644 --- a/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.h +++ b/InnerDetector/InDetDetDescr/SCT_ModuleDistortions/src/SCT_DistortionsTool.h @@ -60,7 +60,7 @@ class SCT_DistortionsTool : public AthAlgTool, virtual public ISCT_ModuleDistort float m_distortionsScale; - mutable std::map<int,int> m_moduleSites; + std::map<int,int> m_moduleSites; std::vector<float>* m_dataJap1_S0; std::vector<float>* m_dataJap2_S0; @@ -74,7 +74,7 @@ class SCT_DistortionsTool : public AthAlgTool, virtual public ISCT_ModuleDistort std::vector<float>* m_dataUSA_S1; std::vector<float>* m_dataScand_S1; - bool loadData() const; + bool loadData(); }; diff --git a/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.cxx b/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.cxx index 33ea2736b868acbefd84211b6e98e008af722788..6b21e1775d2a432306931dce59b8efdf4e3b0cc5 100644 --- a/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.cxx +++ b/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.cxx @@ -98,49 +98,49 @@ mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_0_20V.root")); - fluence_layers.push_back(1e-10); + m_fluence_layers.push_back(1e-10); } else if (m_fluence == 2) { mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_1e14_20V.root")); - fluence_layers.push_back(1e14); + m_fluence_layers.push_back(1e14); } else if (m_fluence == 3) { mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_2e14_30V.root")); - fluence_layers.push_back(2e14); + m_fluence_layers.push_back(2e14); } else if (m_fluence == 4) { mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_5e14_40V.root")); - fluence_layers.push_back(5e14); + m_fluence_layers.push_back(5e14); } else if (m_fluence == 5) { mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_1e15_50V.root")); - fluence_layers.push_back(1e15); + m_fluence_layers.push_back(1e15); } else if (m_fluence == 6) { mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_5e15_160V.root")); - fluence_layers.push_back(5e15); + m_fluence_layers.push_back(5e15); } else if (m_fluence == 7) { mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_6e15_190V_new.root")); - fluence_layers.push_back(6e15); + m_fluence_layers.push_back(6e15); } else if (m_fluence == 8) { mapsPath_list.push_back(PathResolverFindCalibFile("/afs/cern.ch/user/v/vewallan/public/TCADmaps/outputfiles/phi_1e16_260V_new.root")); - fluence_layers.push_back(1e16); + m_fluence_layers.push_back(1e16); } // ***************************** @@ -172,9 +172,9 @@ } //ramoPotentialMap.push_back(ramoPotentialMap_hold); ramoPotentialMap[Layer] = ramoPotentialMap_hold; - fluence_layersMaps[Layer] = fluence_layers.at(i); + m_fluence_layersMaps[Layer] = m_fluence_layers.at(i); - ATH_MSG_INFO("Using fluence " << fluence_layers.at(i)); + ATH_MSG_INFO("Using fluence " << m_fluence_layers.at(i)); //Now setup the E-field. TH2F * eFieldMap_hold; @@ -270,7 +270,7 @@ StatusCode SensorSim3DTool::induceCharge(const TimedHitPtr < SiHit > & phit, SiC //Calculate trapping times based on fluence (already includes check for fluence=0) if (m_doRadDamage) { - std::pair < double, double > trappingTimes = m_radDamageUtil->getTrappingTimes(fluence_layers.at(0)); //0 = IBL + std::pair < double, double > trappingTimes = m_radDamageUtil->getTrappingTimes(m_fluence_layers.at(0)); //0 = IBL m_trappingTimeElectrons = trappingTimes.first; m_trappingTimeHoles = trappingTimes.second; } @@ -286,7 +286,7 @@ StatusCode SensorSim3DTool::induceCharge(const TimedHitPtr < SiHit > & phit, SiC double ncharges = initialConditions[6]; double iTotalLength = initialConditions[7]; ncharges = 50; - temperature = 300; // K + m_temperature = 300; // K ATH_MSG_VERBOSE("Applying 3D sensor simulation."); double sensorThickness = Module.design().thickness(); @@ -401,7 +401,7 @@ StatusCode SensorSim3DTool::induceCharge(const TimedHitPtr < SiHit > & phit, SiC double phiRand = CLHEP::RandGaussZiggurat::shoot(m_rndmEngine); //Apply diffusion. rdif is teh max. diffusion - double Dt = getMobility(efield, isHole) * (0.024) * std::min(driftTime, timeToElectrode) * temperature / 273.; + double Dt = getMobility(efield, isHole) * (0.024) * std::min(driftTime, timeToElectrode) * m_temperature / 273.; double rdif = sqrt(Dt) / 1000; //in mm double xposDiff = x_pix + rdif * phiRand; double etaRand = CLHEP::RandGaussZiggurat::shoot(m_rndmEngine); @@ -639,14 +639,14 @@ double SensorSim3DTool::getMobility(double electricField, bool isHoleBit) { //These parameterizations come from C. Jacoboni et al., Solidâ€State Electronics 20 (1977) 77â€89. (see also https://cds.cern.ch/record/684187/files/indet-2001-004.pdf). if (!isHoleBit) { - vsat = 15.3 * pow(temperature, -0.87); // mm/ns - ecrit = 1.01E-7 * pow(temperature, 1.55); // MV/mm - beta = 2.57E-2 * pow(temperature, 0.66); + vsat = 15.3 * pow(m_temperature, -0.87); // mm/ns + ecrit = 1.01E-7 * pow(m_temperature, 1.55); // MV/mm + beta = 2.57E-2 * pow(m_temperature, 0.66); } if (isHoleBit) { - vsat = 1.62 * pow(temperature, -0.52); // mm/ns - ecrit = 1.24E-7 * pow(temperature, 1.68); // MV/mm - beta = 0.46 * pow(temperature, 0.17); + vsat = 1.62 * pow(m_temperature, -0.52); // mm/ns + ecrit = 1.24E-7 * pow(m_temperature, 1.68); // MV/mm + beta = 0.46 * pow(m_temperature, 0.17); } double mobility = (vsat / ecrit) / pow(1 + pow((electricField / ecrit), beta), (1 / beta)); diff --git a/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.h b/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.h index 890e1f94b2a3d640f820121e1c4ea2f5dd079093..ae0a260dcbbfe6bf6ac6988bcc64481eabaab868 100644 --- a/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.h +++ b/InnerDetector/InDetDigitization/PixelRadDamDigitization/src/SensorSim3DTool.h @@ -70,14 +70,14 @@ class SensorSim3DTool : public SensorSimTool { int m_numberOfCharges; double m_diffusionConstant; - double temperature; + double m_temperature; bool m_doRadDamage; bool m_doChunkCorrection; double m_fluence; //eventually, this should be pulled from the conditions. - std::vector<double> fluence_layers; - std::map<std::pair<int, int>, double> fluence_layersMaps; + std::vector<double> m_fluence_layers; + std::map<std::pair<int, int>, double> m_fluence_layersMaps; double m_trappingTimeElectrons; double m_trappingTimeHoles; ServiceHandle<IChargeCollProbSvc> m_chargeCollSvc; diff --git a/InnerDetector/InDetEventCnv/PixelRawDataByteStreamCnv/share/Pixel_main.py b/InnerDetector/InDetEventCnv/PixelRawDataByteStreamCnv/share/Pixel_main.py index 0d8ee8434c38d50b862672c1c63a1ad1406af9ee..3fd5d4d3c62da6f999ec1f06b393dbc373b4ad5c 100644 --- a/InnerDetector/InDetEventCnv/PixelRawDataByteStreamCnv/share/Pixel_main.py +++ b/InnerDetector/InDetEventCnv/PixelRawDataByteStreamCnv/share/Pixel_main.py @@ -115,8 +115,7 @@ ServiceMgr.StoreGateSvc.Dump = False # get stack dump # ------------------------------------------------------------ -gbl.AthenaServices.SetFatalHandler(438) - +ServiceMgr.CoreDumpSvc.FatalHandler = 438 # ------------------------------------------------------------ # Use auditors diff --git a/InnerDetector/InDetExample/InDetRecExample/share/InDetRec_all.py b/InnerDetector/InDetExample/InDetRecExample/share/InDetRec_all.py index 43fa4afd36414a6ae03adbb6d42d88393b2772dc..95ab8547b5811fef0084ddf4e2824e31b67283e9 100755 --- a/InnerDetector/InDetExample/InDetRecExample/share/InDetRec_all.py +++ b/InnerDetector/InDetExample/InDetRecExample/share/InDetRec_all.py @@ -138,7 +138,7 @@ ServiceMgr.StoreGateSvc.Dump = False # get stack dump # ------------------------------------------------------------ -gbl.AthenaServices.SetFatalHandler(438) +ServiceMgr.CoreDumpSvc.FatalHandler = 438 #-------------------------------------------------------------- # run JiveXML for Atlantis event display diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptionsNewSteering.py b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptionsNewSteering.py index 33de8b9bc158c4e0decb40c03788aac2d2f5dfca..def20c510f7028515432f22f919da5886fcb09d2 100755 --- a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptionsNewSteering.py +++ b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptionsNewSteering.py @@ -364,8 +364,8 @@ ServiceMgr.StoreGateSvc.Dump = False # get stack dump # ------------------------------------------------------------ -gbl.AthenaServices.SetFatalHandler(438) - +ServiceMgr.CoreDumpSvc.FatalHandler = 438 + if doAuditors: # load AuditorSvc theAuditorSvc = AuditorSvc() diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample.py b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample.py index 844fce15c950a380d22fb200fa95896a39fc5b7e..370a1ac7b899c97c769f0bea851507161dbe66da 100755 --- a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample.py +++ b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample.py @@ -363,7 +363,7 @@ ServiceMgr.StoreGateSvc.Dump = False # get stack dump # ------------------------------------------------------------ -gbl.AthenaServices.SetFatalHandler(438) +ServiceMgr.CoreDumpSvc.FatalHandler = 438 if doAuditors: # load AuditorSvc diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_backTracking.py b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_backTracking.py index 95ec2cb520f2bdd57bc8e13b33618d2085ba97ca..44aa7c83f0d16b75e2f99fda6dde2d555d6af07f 100755 --- a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_backTracking.py +++ b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_backTracking.py @@ -316,8 +316,8 @@ ServiceMgr.StoreGateSvc.Dump = False # get stack dump # ------------------------------------------------------------ -gbl.AthenaServices.SetFatalHandler(438) - +ServiceMgr.CoreDumpSvc.FatalHandler = 438 + if doAuditors: # load AuditorSvc theAuditorSvc = AuditorSvc() diff --git a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_doReadBS.py b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_doReadBS.py index 0ec9c1afe9f7d0369e9ee739ebd9d6b96eab4582..b44c7b1593a5b0255a5b25e732aa49ca1aef6fee 100755 --- a/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_doReadBS.py +++ b/InnerDetector/InDetExample/InDetTrigRecExample/share/jobOptions_RTT_InDetTrigRecExample_doReadBS.py @@ -366,8 +366,8 @@ ServiceMgr.StoreGateSvc.Dump = False # get stack dump # ------------------------------------------------------------ -gbl.AthenaServices.SetFatalHandler(438) - +ServiceMgr.CoreDumpSvc.FatalHandler = 438 + if doAuditors: # load AuditorSvc theAuditorSvc = AuditorSvc() diff --git a/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/InDetCaloClusterROISelector/CaloClusterROI_Selector.h b/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/InDetCaloClusterROISelector/CaloClusterROI_Selector.h index 312c5d863fbf39e78769860dcd9f35abcd79a0fa..d737c2760af0179732daa09c46bdf59b65ae4828 100755 --- a/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/InDetCaloClusterROISelector/CaloClusterROI_Selector.h +++ b/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/InDetCaloClusterROISelector/CaloClusterROI_Selector.h @@ -44,7 +44,7 @@ class CaloClusterROI_Selector : public AthReentrantAlgorithm /** @brief finalize method*/ StatusCode finalize(); /** @brief execute method*/ - StatusCode execute_r(const EventContext& ctx) const; + StatusCode execute(const EventContext& ctx) const; private: diff --git a/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/src/CaloClusterROI_Selector.cxx b/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/src/CaloClusterROI_Selector.cxx index ded679b271a645e321085a7296cca11673bbedcb..6f77152ac95dfb5412e4aaa28ddd33d0a16ff06e 100755 --- a/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/src/CaloClusterROI_Selector.cxx +++ b/InnerDetector/InDetRecAlgs/InDetCaloClusterROISelector/src/CaloClusterROI_Selector.cxx @@ -77,7 +77,7 @@ StatusCode InDet::CaloClusterROI_Selector::finalize() } // ====================================================================== -StatusCode InDet::CaloClusterROI_Selector::execute_r(const EventContext& ctx) const +StatusCode InDet::CaloClusterROI_Selector::execute(const EventContext& ctx) const { // // athena execute method diff --git a/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/InDetExtensionProcessor/InDetExtensionProcessor.h b/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/InDetExtensionProcessor/InDetExtensionProcessor.h index 3e525a67b8e51768a617a7b55d86e3822304cf23..9a08f71ead06998ae915d824be9a47ccb0ac1fde 100755 --- a/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/InDetExtensionProcessor/InDetExtensionProcessor.h +++ b/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/InDetExtensionProcessor/InDetExtensionProcessor.h @@ -40,7 +40,7 @@ public: InDetExtensionProcessor(const std::string &name,ISvcLocator *pSvcLocator); virtual StatusCode initialize(); - virtual StatusCode execute_r(const EventContext& ctx) const; + virtual StatusCode execute(const EventContext& ctx) const; virtual StatusCode finalize(); private: diff --git a/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/src/InDetExtensionProcessor.cxx b/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/src/InDetExtensionProcessor.cxx index ad32cae93dd9c4ffc83695af36c5614c81472c68..97414860ef42ca725d2eb0ac45745d7f8c472971 100755 --- a/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/src/InDetExtensionProcessor.cxx +++ b/InnerDetector/InDetRecAlgs/InDetExtensionProcessor/src/InDetExtensionProcessor.cxx @@ -115,7 +115,7 @@ StatusCode InDet::InDetExtensionProcessor::initialize() //================================================================================================== // Execute method: -StatusCode InDet::InDetExtensionProcessor::execute_r(const EventContext& ctx) const +StatusCode InDet::InDetExtensionProcessor::execute(const EventContext& ctx) const { // process the extensions SG::ReadHandle<TrackCollection> tracks(m_trackName, ctx); diff --git a/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.cxx b/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.cxx index 2e5411fead0b0209498487467b6e13d404a4bf2f..ed8be743ba739bcfc13116e33a498b7161250dcc 100644 --- a/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.cxx +++ b/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.cxx @@ -55,7 +55,7 @@ namespace InDet{ CacheCreator::~CacheCreator() {} - StatusCode CacheCreator::execute_r (const EventContext& ctx) const + StatusCode CacheCreator::execute (const EventContext& ctx) const { if(!m_disableTRT) ATH_CHECK(CreateContainer(m_rioContainerCacheKey, m_pTRTHelper->straw_layer_hash_max(), ctx)); diff --git a/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.h b/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.h index 1ed4085d859a984cd51ccdcdf0244426f477442f..2f47911654d8f0ead15322f5088edfac5afaaa18 100644 --- a/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.h +++ b/InnerDetector/InDetRecAlgs/InDetPrepRawDataFormation/src/CacheCreator.h @@ -37,7 +37,7 @@ namespace InDet{ CacheCreator(const std::string &name,ISvcLocator *pSvcLocator); virtual ~CacheCreator() ; virtual StatusCode initialize () override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; //No need for finalize protected: const TRT_ID* m_pTRTHelper; diff --git a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/SiSpacePointFormation/SiTrackerSpacePointFinder.h b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/SiSpacePointFormation/SiTrackerSpacePointFinder.h index 1ebf0e96642bd386d3bf18d9b84bcd0857e2ed9a..0f89649a0022dcf02c921fac7ea0902b4d6b0080 100755 --- a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/SiSpacePointFormation/SiTrackerSpacePointFinder.h +++ b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/SiSpacePointFormation/SiTrackerSpacePointFinder.h @@ -95,7 +95,7 @@ namespace InDet { StatusCode initialize() override; - StatusCode execute_r (const EventContext& ctx) const override; + StatusCode execute (const EventContext& ctx) const override; StatusCode finalize() override; diff --git a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx index 0230f094c480aa21039e853ac7b84b08cb49d6ad..6cd6c38df275455c2bfd73ecbfeb00671d283cfe 100755 --- a/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx +++ b/InnerDetector/InDetRecAlgs/SiSpacePointFormation/src/SiTrackerSpacePointFinder.cxx @@ -164,7 +164,7 @@ StatusCode SiTrackerSpacePointFinder::initialize() //------------------------------------------------------------------------- -StatusCode SiTrackerSpacePointFinder::execute_r (const EventContext& ctx) const +StatusCode SiTrackerSpacePointFinder::execute (const EventContext& ctx) const { diff --git a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/CMakeLists.txt b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/CMakeLists.txt index 2a7e9db21e70ab80991e718a2f7452f08210c182..59e9895cbc2d335b0305d06f9b4cb6b7ceb86af3 100644 --- a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/CMakeLists.txt +++ b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/CMakeLists.txt @@ -9,7 +9,7 @@ atlas_subdir( TRT_SeededTrackFinder ) atlas_depends_on_subdirs( PUBLIC Control/AthenaBaseComps GaudiKernel - InnerDetector/InDetConditions/InDetBeamSpotService + InnerDetector/InDetConditions/BeamSpotConditionsData InnerDetector/InDetRecTools/InDetRecToolInterfaces Tracking/TrkEvent/TrkSegment Tracking/TrkEvent/TrkTrack diff --git a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/TRT_SeededTrackFinder/TRT_SeededTrackFinder.h b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/TRT_SeededTrackFinder/TRT_SeededTrackFinder.h index 1452ffd95f62eea5e146717e5bf8f72e53c32a42..fb156428679ce8f99fc94f01d00834680e9d81a5 100755 --- a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/TRT_SeededTrackFinder/TRT_SeededTrackFinder.h +++ b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/TRT_SeededTrackFinder/TRT_SeededTrackFinder.h @@ -32,7 +32,7 @@ #include "InDetRecToolInterfaces/ITRT_TrackExtensionTool.h" #include "TrkExInterfaces/IExtrapolator.h" -#include "InDetBeamSpotService/IBeamCondSvc.h" +#include "BeamSpotConditionsData/BeamSpotData.h" #include "InDetRecToolInterfaces/ITRT_SeededTrackFinder.h" @@ -100,7 +100,7 @@ namespace InDet { ToolHandle<Trk::IExtrapolator> m_extrapolator; //!< the extrapoator - ServiceHandle<IBeamCondSvc> m_iBeamCondSvc; //!< pointer to the beam condition service + SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" }; bool m_SiExtensionCuts; //!< enable cuts after Si segment finding double m_minPt; //!< minimal Pt cut double m_maxEta; //!< maximal Eta cut diff --git a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/src/TRT_SeededTrackFinder.cxx b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/src/TRT_SeededTrackFinder.cxx index 46501530b62cc3a2321a2c8f1867eacc0a98071b..3137f7924d832529266d902fbb90b288304fc72b 100755 --- a/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/src/TRT_SeededTrackFinder.cxx +++ b/InnerDetector/InDetRecAlgs/TRT_SeededTrackFinder/src/TRT_SeededTrackFinder.cxx @@ -39,8 +39,7 @@ InDet::TRT_SeededTrackFinder::TRT_SeededTrackFinder m_fitterTool("Trk::KalmanFitter/InDetTrackFitter"), m_trtExtension("InDet::TRT_TrackExtensionTool_xk"), m_Segments("TRTSegments"), - m_outTracks("TRTSeededTracks"), - m_iBeamCondSvc("BeamCondSvc",name) + m_outTracks("TRTSeededTracks") { m_doRefit = false ; //Do a final careful refit of tracks m_doExtension = false ; //Find the track TRT extension @@ -69,7 +68,6 @@ InDet::TRT_SeededTrackFinder::TRT_SeededTrackFinder declareProperty("maxRPhiImp", m_maxRPhiImp = 10.); declareProperty("maxZImp", m_maxZImp = 250.); declareProperty("Extrapolator", m_extrapolator); - declareProperty("BeamPositionSvc", m_iBeamCondSvc ); } /////////////////////////////////////////////////////////////////// @@ -98,9 +96,10 @@ StatusCode InDet::TRT_SeededTrackFinder::initialize() // get extrapolator ATH_CHECK( m_extrapolator.retrieve()); // get beam spot service - ATH_CHECK( m_iBeamCondSvc.retrieve()); + ATH_CHECK( m_beamSpotKey.initialize() ); } else { m_extrapolator.disable(); + //disable m_beamSpotKey when able to } // Get tool for track extension to TRT @@ -298,7 +297,10 @@ StatusCode InDet::TRT_SeededTrackFinder::execute() // --- beam spot position Amg::Vector3D beamSpotPosition(0,0,0); - if (m_iBeamCondSvc) beamSpotPosition = m_iBeamCondSvc->beamVtx().position(); + if (m_SiExtensionCuts){ + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + beamSpotPosition = beamSpotHandle->beamVtx().position(); + } // --- create surface Trk::PerigeeSurface perigeeSurface(beamSpotPosition); diff --git a/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/InDetCompetingRIOsOnTrack/CompetingSCT_ClustersOnTrack.h b/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/InDetCompetingRIOsOnTrack/CompetingSCT_ClustersOnTrack.h index 324108680d21b2e9db0d408343614a6fd039a85f..6364b47fb98f5590a6f301e7fe339bbc9e36c239 100755 --- a/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/InDetCompetingRIOsOnTrack/CompetingSCT_ClustersOnTrack.h +++ b/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/InDetCompetingRIOsOnTrack/CompetingSCT_ClustersOnTrack.h @@ -11,13 +11,11 @@ // Trk #include "TrkCompetingRIOsOnTrack/CompetingRIOsOnTrack.h" -//#include "TrkEventPrimitives/GlobalPosition.h" -//#include "TrkEventPrimitives/ErrorMatrix.h" -// #include "TrkParameters/TrackParameters.h" #include "InDetRIO_OnTrack/SCT_ClusterOnTrack.h" // cannot fwd-declare because of covariant method + #include <iosfwd> +#include <mutex> -//#include <iostream.h> class MsgStream; namespace Trk {class Surface;} @@ -107,8 +105,10 @@ private: void clearChildRotVector(); - /** The global Position */ + /** The global position */ mutable const Amg::Vector3D* m_globalPosition; + /** Mutex to protect the global position */ + mutable std::mutex m_mutex; /** The vector of contained InDet::SCT_ClusterOnTrack objects */ std::vector<const InDet::SCT_ClusterOnTrack*>* m_containedChildRots; @@ -139,10 +139,11 @@ inline const InDet::SCT_ClusterOnTrack& CompetingSCT_ClustersOnTrack::rioOnTrack return * m_containedChildRots->operator[](indx); } - inline const Amg::Vector3D& CompetingSCT_ClustersOnTrack::globalPosition() const { - if (m_globalPosition) - return (*m_globalPosition); - m_globalPosition = associatedSurface().localToGlobal(localParameters()); +inline const Amg::Vector3D& CompetingSCT_ClustersOnTrack::globalPosition() const { + if (m_globalPosition==nullptr) { + std::lock_guard<std::mutex> lock{m_mutex}; + m_globalPosition = associatedSurface().localToGlobal(localParameters()); + } return (*m_globalPosition); } diff --git a/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/src/CompetingSCT_ClustersOnTrack.cxx b/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/src/CompetingSCT_ClustersOnTrack.cxx index e3fba303f1f2a2b535d0a830ecbc3c0afadb6a1f..8c4eec43588220d45b2b2a1707034af18766eee8 100755 --- a/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/src/CompetingSCT_ClustersOnTrack.cxx +++ b/InnerDetector/InDetRecEvent/InDetCompetingRIOsOnTrack/src/CompetingSCT_ClustersOnTrack.cxx @@ -18,7 +18,8 @@ // default constructor InDet::CompetingSCT_ClustersOnTrack::CompetingSCT_ClustersOnTrack(): Trk::CompetingRIOsOnTrack(), - m_globalPosition(0), + m_globalPosition(nullptr), + m_mutex(), m_containedChildRots(0) // {} @@ -26,7 +27,8 @@ InDet::CompetingSCT_ClustersOnTrack::CompetingSCT_ClustersOnTrack(): // copy constructor InDet::CompetingSCT_ClustersOnTrack::CompetingSCT_ClustersOnTrack(const InDet::CompetingSCT_ClustersOnTrack& compROT) : Trk::CompetingRIOsOnTrack(compROT), - m_globalPosition(compROT.m_globalPosition ? new Amg::Vector3D(*compROT.m_globalPosition) : 0), + m_globalPosition(compROT.m_globalPosition ? new Amg::Vector3D(*compROT.m_globalPosition) : nullptr), + m_mutex(), m_containedChildRots(0) { m_containedChildRots = new std::vector< const InDet::SCT_ClusterOnTrack* >; std::vector< const InDet::SCT_ClusterOnTrack* >::const_iterator rotIter = compROT.m_containedChildRots->begin(); @@ -43,7 +45,8 @@ InDet::CompetingSCT_ClustersOnTrack::CompetingSCT_ClustersOnTrack( ): Trk::CompetingRIOsOnTrack(assgnProb), -m_globalPosition(0), +m_globalPosition(nullptr), +m_mutex(), m_containedChildRots(childrots) { // initialize local position and error matrix @@ -61,10 +64,12 @@ InDet::CompetingSCT_ClustersOnTrack& InDet::CompetingSCT_ClustersOnTrack::operat delete m_globalPosition; m_containedChildRots = new std::vector<const InDet::SCT_ClusterOnTrack*>; - m_globalPosition = compROT.m_globalPosition ? new Amg::Vector3D(*compROT.m_globalPosition) : 0; std::vector<const InDet::SCT_ClusterOnTrack*>::const_iterator rotIter = compROT.m_containedChildRots->begin(); for (; rotIter!=compROT.m_containedChildRots->end(); ++rotIter) m_containedChildRots->push_back((*rotIter)->clone()); + + std::lock_guard<std::mutex> lock{m_mutex}; + m_globalPosition = compROT.m_globalPosition ? new Amg::Vector3D(*compROT.m_globalPosition) : nullptr; } return (*this); } @@ -90,7 +95,7 @@ MsgStream& InDet::CompetingSCT_ClustersOnTrack::dump( MsgStream& out ) const { "over different surfaces") << " (given prob>cut)" << std::endl; Trk::CompetingRIOsOnTrack::dump(out); out << " - GlobalPosition : "; - if (m_globalPosition==NULL) out << "null pointer"<<endmsg; + if (m_globalPosition==nullptr) out << "null pointer"<<endmsg; else out << *m_globalPosition<<endmsg; return out; } @@ -103,7 +108,7 @@ std::ostream& InDet::CompetingSCT_ClustersOnTrack::dump( std::ostream& out ) con "over different surfaces") << " (given prob>cut)" << std::endl; Trk::CompetingRIOsOnTrack::dump(out); out << " - GlobalPosition : "; - if (m_globalPosition==NULL) out << "null pointer"<<std::endl; + if (m_globalPosition==nullptr) out << "null pointer"<<std::endl; else out << *m_globalPosition<<std::endl; return out; } diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/CMakeLists.txt b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/CMakeLists.txt index 79c04d47459e3070f3c6f1158b3d261721cf6f15..bc34afcd990044150623271912af7d261e68523c 100644 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/CMakeLists.txt +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/CMakeLists.txt @@ -17,7 +17,6 @@ atlas_depends_on_subdirs( PUBLIC Tracking/TrkEvent/TrkParticleBase Tracking/TrkEvent/TrkTrack InnerDetector/InDetConditions/BeamSpotConditionsData - InnerDetector/InDetConditions/InDetBeamSpotService PRIVATE Control/AthContainers DetectorDescription/GeoPrimitives diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptiveMultiPriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptiveMultiPriVxFinderTool.h index 38cee93cdec7353cf5b2c2a29ebbb58a8007cfc7..793fa3d7f91ecde033ece1a7e89dc9207626c5bb 100755 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptiveMultiPriVxFinderTool.h +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptiveMultiPriVxFinderTool.h @@ -97,10 +97,10 @@ #include "xAODTracking/TrackParticleFwd.h" #include "xAODTracking/VertexContainerFwd.h" #include "xAODTracking/TrackParticleContainerFwd.h" - +#include "BeamSpotConditionsData/BeamSpotData.h" class TrackToVtxLinkContainer; class NN; -class IBeamCondSvc; + namespace Trk { @@ -155,7 +155,7 @@ namespace InDet ToolHandle< Trk::IVertexSeedFinder > m_SeedFinder; ToolHandle< InDet::IInDetTrackSelectionTool > m_trkFilter; - ServiceHandle<IBeamCondSvc> m_iBeamCondSvc; //!< pointer to the beam condition service + SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" }; /** Define a beam constraint for the fit */ bool m_useBeamConstraint; //!< Use a vertex/beam constraint diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptivePriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptivePriVxFinderTool.h index bd0f6fcbca6366f8696d618021804e4af6ff511d..f1974942d5639051c0698faee5fd605f7eb35579 100755 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptivePriVxFinderTool.h +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetAdaptivePriVxFinderTool.h @@ -56,7 +56,7 @@ * Forward declarations */ -class IBeamCondSvc; +#include "BeamSpotConditionsData/BeamSpotData.h" #include "xAODTracking/VertexFwd.h" #include "xAODTracking/TrackParticleFwd.h" #include "xAODTracking/VertexContainerFwd.h" @@ -113,7 +113,7 @@ public: ToolHandle< Trk::IVertexFitter > m_iVertexFitter; ToolHandle< InDet::IInDetTrackSelectionTool > m_trkFilter; - ServiceHandle<IBeamCondSvc> m_iBeamCondSvc; //!< pointer to the beam condition service + SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" }; void SGError(std::string errService); diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetIterativePriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetIterativePriVxFinderTool.h index f0aa49bd286133992e6b8b84b2c7f48c7fa3a58a..8c9b8898e9a70f5b73273651bafcee5856378fda 100755 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetIterativePriVxFinderTool.h +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetIterativePriVxFinderTool.h @@ -47,7 +47,6 @@ * Forward declarations */ -class IBeamCondSvc; #include "xAODTracking/VertexFwd.h" #include "xAODTracking/TrackParticleFwd.h" #include "xAODTracking/VertexContainerFwd.h" diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetMultiPriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetMultiPriVxFinderTool.h index 3f0673ef2da4987d4380e47795d1aca9000b0702..b8b1028521149311678a13757f1dd06bf304963c 100644 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetMultiPriVxFinderTool.h +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetMultiPriVxFinderTool.h @@ -38,8 +38,7 @@ /** * Forward declarations */ - -class IBeamCondSvc; +#include "BeamSpotConditionsData/BeamSpotData.h" #include "xAODTracking/VertexFwd.h" #include "xAODTracking/TrackParticleFwd.h" #include "xAODTracking/VertexContainerFwd.h" @@ -119,7 +118,7 @@ public: ToolHandle< Trk::IVertexSeedFinder > m_SeedFinder; ToolHandle< Trk::IImpactPoint3dEstimator > m_ImpactPoint3dEstimator; - ServiceHandle<IBeamCondSvc> m_iBeamCondSvc; //!< pointer to the beam condition service + SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" }; bool m_useBeamConstraint; double m_significanceCutSeeding; diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetPriVxFinderTool.h b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetPriVxFinderTool.h index a8c8ed804832c63249abf46b22bc0ae248a1c388..befc34946fa3330872c984d79f26620207832194 100755 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetPriVxFinderTool.h +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/InDetPriVxFinderTool/InDetPriVxFinderTool.h @@ -86,12 +86,12 @@ */ /* Forward declarations */ -class IBeamCondSvc; + #include "xAODTracking/Vertex.h" #include "xAODTracking/TrackParticle.h" #include "xAODTracking/VertexContainer.h" #include "xAODTracking/TrackParticleContainer.h" - +#include "BeamSpotConditionsData/BeamSpotData.h" namespace Trk { class IVertexFitter; @@ -120,7 +120,7 @@ private: ToolHandle < Trk::IVertexFitter > m_iVertexFitter; ToolHandle< InDet::IInDetTrackSelectionTool > m_trkFilter; - ServiceHandle<IBeamCondSvc> m_iBeamCondSvc; //!< pointer to the beam condition service + SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" }; //!< pointer to the beam condition service /** Define a beam constraint for the fit */ bool m_useBeamConstraint; //!< Use a vertex/beam constraint diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptiveMultiPriVxFinderTool.cxx b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptiveMultiPriVxFinderTool.cxx index a020683f493037b5f151cb95eb35ca8f481db094..d493845fbbe81626e33df964420780da0c7db796 100755 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptiveMultiPriVxFinderTool.cxx +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptiveMultiPriVxFinderTool.cxx @@ -34,7 +34,7 @@ #include "NN.h" #include "InDetTrackSelectionTool/IInDetTrackSelectionTool.h" -#include "InDetBeamSpotService/IBeamCondSvc.h" + #include "VxMultiVertex/MvfFitInfo.h" #include "VxMultiVertex/MVFVxTrackAtVertex.h" @@ -67,7 +67,6 @@ namespace InDet m_MultiVertexFitter("Trk::AdaptiveMultiVertexFitter"), m_SeedFinder("Trk::ZScanSeedFinder"), m_trkFilter("InDet::InDetTrackSelection"), - m_iBeamCondSvc("BeamCondSvc", n), m_useBeamConstraint(true), m_TracksMaxZinterval(1.), m_maxVertexChi2(18.42), @@ -98,7 +97,6 @@ namespace InDet declareProperty("realMultiVertex", m_realMultiVertex); declareProperty("useFastCompatibility", m_useFastCompatibility); declareProperty("useBeamConstraint", m_useBeamConstraint); - declareProperty("BeamPositionSvc", m_iBeamCondSvc); declareProperty("addSingleTrackVertices", m_addSingleTrackVertices); //********* signal vertex selection (for pile up) **** declareProperty("selectiontype", m_selectiontype); @@ -121,7 +119,7 @@ namespace InDet ATH_CHECK(m_SeedFinder.retrieve()); - ATH_CHECK(m_iBeamCondSvc.retrieve()); + ATH_CHECK(m_beamSpotKey.initialize()); ATH_CHECK(m_trkFilter.retrieve()); @@ -152,11 +150,12 @@ namespace InDet /* xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); */ - Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx()); + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx()); std::vector<const Trk::ITrackLink*> selectedTracks; @@ -205,11 +204,12 @@ namespace InDet /* xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); */ - Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx()); + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx()); typedef DataVector<Trk::TrackParticleBase>::const_iterator TrackParticleDataVecIter; @@ -252,11 +252,11 @@ namespace InDet std::pair<xAOD::VertexContainer*, xAOD::VertexAuxContainer*> InDetAdaptiveMultiPriVxFinderTool::findVertex(const xAOD::TrackParticleContainer* trackParticles) { std::vector<const Trk::ITrackLink*> selectedTracks; - + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); typedef DataVector<xAOD::TrackParticle>::const_iterator TrackParticleDataVecIter; @@ -354,7 +354,7 @@ namespace InDet //prepare iterators for tracks only necessary for seeding std::vector<const Trk::ITrackLink*>::iterator seedtrkbegin = seedTracks.begin(); std::vector<const Trk::ITrackLink*>::iterator seedtrkend = seedTracks.end(); - + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; int iteration = 0; unsigned int seedtracknumber = seedTracks.size(); do { @@ -381,10 +381,10 @@ namespace InDet if (m_useBeamConstraint) { constraintVertex = new xAOD::Vertex(); constraintVertex->makePrivateStore(); - constraintVertex->setPosition(m_iBeamCondSvc->beamVtx().position()); - constraintVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); - constraintVertex->setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), - m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF()); + constraintVertex->setPosition(beamSpotHandle->beamVtx().position()); + constraintVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); + constraintVertex->setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), + beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF()); actualVertex = m_SeedFinder->findSeed(perigeeList, constraintVertex); } else { actualVertex = m_SeedFinder->findSeed(perigeeList); @@ -801,8 +801,8 @@ namespace InDet ATH_MSG_WARNING("No vertices found: returning a place-holder at the beam spot center."); xAOD::Vertex* beamspotCandidate = new xAOD::Vertex; beamspotCandidate->makePrivateStore(); - beamspotCandidate->setPosition(m_iBeamCondSvc->beamVtx().position()); - beamspotCandidate->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamspotCandidate->setPosition(beamSpotHandle->beamVtx().position()); + beamspotCandidate->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); beamspotCandidate->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>(); // TODO: I don't need to set fitQuality too do I? myxAODVertices.push_back(xAODVertex_pair(0, beamspotCandidate)); @@ -889,8 +889,8 @@ namespace InDet xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex; theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its // aux store - dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position()); - dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position()); + dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>(); dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx); } diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptivePriVxFinderTool.cxx b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptivePriVxFinderTool.cxx index 58ca183dee14d5f8c727b3cdd225b9e1d41322c3..e213911d5bed64420e551fd3940d14c1b39eb1ce 100755 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptivePriVxFinderTool.cxx +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetAdaptivePriVxFinderTool.cxx @@ -34,7 +34,6 @@ #include "EventPrimitives/EventPrimitivesHelpers.h" #include "GeoPrimitives/GeoPrimitives.h" -#include "InDetBeamSpotService/IBeamCondSvc.h" #include "InDetTrackSelectionTool/IInDetTrackSelectionTool.h" //#include "VxVertex/VxContainer.h" @@ -75,13 +74,12 @@ namespace InDet const IInterface* p) : AthAlgTool(t, n, p), m_iVertexFitter("Trk::AdaptiveVertexFitter"), - m_trkFilter("InDet::InDetTrackSelection"), - m_iBeamCondSvc("BeamCondSvc", n) { + m_trkFilter("InDet::InDetTrackSelection") + { declareInterface<IVertexFinder>(this);//by GP: changed from InDetAdaptivePriVxFinderTool to IPriVxFinderTool /* Retrieve StoreGate container and tool names from job options */ declareProperty("VertexFitterTool", m_iVertexFitter); declareProperty("TrackSelector", m_trkFilter); - declareProperty("BeamPositionSvc", m_iBeamCondSvc); /* Cuts for track preselection */ } @@ -98,11 +96,7 @@ namespace InDet return StatusCode::FAILURE; } - sc = m_iBeamCondSvc.retrieve(); - if (sc.isFailure()) { - msg(MSG::ERROR) << "Could not find BeamCondSvc." << endmsg; - return sc; - } + ATH_CHECK(m_beamSpotKey.initialize()); if (m_trkFilter.retrieve().isFailure()) { msg(MSG::ERROR) << " Unable to retrieve " << m_trkFilter << endmsg; @@ -123,11 +117,11 @@ namespace InDet /* xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); */ - - Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx()); + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx()); //---- Start of preselection of tracks ---------------// std::vector<const Trk::TrackParameters*> origParameters; @@ -179,11 +173,12 @@ namespace InDet /* xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); */ - Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx()); + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx()); //---- Start of preselection of tracks ---------------// std::vector<const Trk::TrackParameters*> origParameters; @@ -242,11 +237,13 @@ namespace InDet std::pair<xAOD::VertexContainer*, xAOD::VertexAuxContainer*> InDetAdaptivePriVxFinderTool::findVertex(const xAOD::TrackParticleContainer* trackParticles) { ATH_MSG_DEBUG(" Number of input tracks before track selection: " << trackParticles->size()); + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); //---- Start of preselection of tracks ---------------// std::vector<const Trk::TrackParameters*> origParameters; @@ -328,11 +325,12 @@ namespace InDet //---- Start of fitting section ------------------------------------------------------// if (origParameters.size() >= 1) { + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); - beamposition.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); + beamposition.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF()); myxAODVertex = m_iVertexFitter->fit(origParameters, beamposition); /* @TODO? The fit tool does not return tracks chi2 ordered anymore We have to do it */ @@ -392,11 +390,12 @@ namespace InDet } //---- if no vertex is there let dummy be at beam spot else if (theVertexContainer->size() == 0) { + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex; theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its // aux store - dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position()); - dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position()); + dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>(); dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx); } diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetMultiPriVxFinderTool.cxx b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetMultiPriVxFinderTool.cxx index 62d549095d204a1ee232c33de067ea1950e49bc3..9b21e38ba10dcafcda7fd36d5646862bb329e9f1 100755 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetMultiPriVxFinderTool.cxx +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetMultiPriVxFinderTool.cxx @@ -34,7 +34,6 @@ #include "GeoPrimitives/GeoPrimitives.h" #include "TrkVertexFitterInterfaces/IImpactPoint3dEstimator.h" -#include "InDetBeamSpotService/IBeamCondSvc.h" #include "InDetTrackSelectionTool/IInDetTrackSelectionTool.h" #include "TrkVertexFitterInterfaces/IVertexSeedFinder.h" @@ -68,7 +67,6 @@ namespace InDet m_trkFilter("InDet::InDetTrackSelection"), m_SeedFinder("Trk::ImagingSeedFinder"), m_ImpactPoint3dEstimator("Trk::ImpactPoint3dEstimator"), - m_iBeamCondSvc("BeamCondSvc", n), m_useBeamConstraint(false), m_significanceCutSeeding(10), m_maximumChi2cutForSeeding(6. * 6.), @@ -80,7 +78,6 @@ namespace InDet declareProperty("VertexFitterTool", m_iVertexFitter); declareProperty("TrackSelector", m_trkFilter); - declareProperty("BeamPositionSvc", m_iBeamCondSvc); declareProperty("SeedFinder", m_SeedFinder); declareProperty("ImpactPoint3dEstimator", m_ImpactPoint3dEstimator); @@ -99,9 +96,7 @@ namespace InDet StatusCode InDetMultiPriVxFinderTool::initialize() { - StatusCode sc; - - + if (m_createSplitVertices == true && m_useBeamConstraint == true) { msg(MSG::FATAL) << " Split vertices cannot be obtained if beam spot constraint is true! Change settings..." << endmsg; @@ -124,11 +119,7 @@ namespace InDet return StatusCode::FAILURE; } - sc = m_iBeamCondSvc.retrieve(); - if (sc.isFailure()) { - msg(MSG::ERROR) << "Could not find BeamCondSvc." << endmsg; - return sc; - } + ATH_CHECK(m_beamSpotKey.initialize()); if (m_trkFilter.retrieve().isFailure()) { msg(MSG::ERROR) << " Unable to retrieve " << m_trkFilter << endmsg; @@ -154,16 +145,20 @@ namespace InDet typedef DataVector<Trk::Track>::const_iterator TrackDataVecIter; bool selectionPassed{false}; + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + const InDet::BeamSpotData* beamdata = nullptr; + if(m_useBeamConstraint && beamSpotHandle.isValid()) beamdata = beamSpotHandle.retrieve(); + for (TrackDataVecIter itr = (*trackTES).begin(); itr != (*trackTES).end(); itr++) { if (m_useBeamConstraint) { // TODO: change trkFilter to allow for this replacement /* xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamdata->beamVtx().position()); + beamposition.setCovariancePosition(beamdata->beamVtx().covariancePosition()); */ - Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx()); + Trk::RecVertex beamposition(beamdata->beamVtx()); selectionPassed = static_cast<bool>(m_trkFilter->accept(**itr, &beamposition)); } else { Trk::Vertex null(Amg::Vector3D(0, 0, 0)); @@ -195,16 +190,20 @@ namespace InDet typedef DataVector<Trk::TrackParticleBase>::const_iterator TrackParticleDataVecIter; bool selectionPassed{false}; + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + const InDet::BeamSpotData* beamdata = nullptr; + if(m_useBeamConstraint && beamSpotHandle.isValid()) beamdata = beamSpotHandle.retrieve(); + for (TrackParticleDataVecIter itr = (*trackTES).begin(); itr != (*trackTES).end(); itr++) { if (m_useBeamConstraint) { // TODO: change trkFilter to allow for this replacement /* xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamdata->beamVtx().position()); + beamposition.setCovariancePosition(beamdata->beamVtx().covariancePosition()); */ - Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx()); + Trk::RecVertex beamposition(beamdata->beamVtx()); selectionPassed = static_cast<bool>(m_trkFilter->accept(*((*itr)->originalTrack()), &beamposition)); } else { Trk::Vertex null(Amg::Vector3D(0, 0, 0)); @@ -233,7 +232,10 @@ namespace InDet ATH_MSG_DEBUG(" Number of input tracks before track selection: " << trackParticles->size()); std::vector<Trk::ITrackLink*> selectedTracks; - + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + const InDet::BeamSpotData* beamdata = nullptr; + if(m_useBeamConstraint && beamSpotHandle.isValid()) beamdata = beamSpotHandle.retrieve(); + typedef DataVector<xAOD::TrackParticle>::const_iterator TrackParticleDataVecIter; bool selectionPassed{false}; @@ -241,8 +243,8 @@ namespace InDet if (m_useBeamConstraint) { xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamdata->beamVtx().position()); + beamposition.setCovariancePosition(beamdata->beamVtx().covariancePosition()); selectionPassed = static_cast<bool> (m_trkFilter->accept(**itr, &beamposition)); } else { xAOD::Vertex null; @@ -302,10 +304,11 @@ namespace InDet xAOD::Vertex theconstraint; theconstraint.makePrivateStore(); if (m_useBeamConstraint) { - theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position()); - theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); - theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), - m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF()); + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + theconstraint.setPosition(beamSpotHandle->beamVtx().position()); + theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); + theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), + beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF()); seedVertices = m_SeedFinder->findMultiSeeds(perigeeList, &theconstraint); } else { seedVertices = m_SeedFinder->findMultiSeeds(perigeeList); @@ -520,8 +523,9 @@ namespace InDet xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex; theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its // aux store - dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position()); - dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position()); + dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>(); dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx); } diff --git a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetPriVxFinderTool.cxx b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetPriVxFinderTool.cxx index 0f2347fb4662c3aa6f23bd10979739376d7bf2f0..85f31d6c3c2bd6e7dc554f0b94e5275448c0c548 100755 --- a/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetPriVxFinderTool.cxx +++ b/InnerDetector/InDetRecTools/InDetPriVxFinderTool/src/InDetPriVxFinderTool.cxx @@ -36,7 +36,6 @@ #include "VxVertex/VxCandidate.h" #include "VxVertex/VxTrackAtVertex.h" -#include "InDetBeamSpotService/IBeamCondSvc.h" #include "InDetTrackSelectionTool/IInDetTrackSelectionTool.h" #include "TrkVertexFitterInterfaces/IVertexFitter.h" #include "InDetRecToolInterfaces/IMultiPVSeedFinder.h" @@ -73,7 +72,6 @@ namespace InDet m_iPriVxSeedFinder("InDet::SlidingWindowMultiSeedFinder"), m_iVertexFitter("Trk::FastVertexFitter"), m_trkFilter("InDet::InDetTrackSelection"), - m_iBeamCondSvc("BeamCondSvc", n), m_useBeamConstraint(false), m_chi2CutMethod(1), m_enableMultipleVertices(true), @@ -90,7 +88,6 @@ namespace InDet declareProperty("maxChi2PerTrack", m_maxChi2PerTrack); declareProperty("enableMultipleVertices", m_enableMultipleVertices); declareProperty("clusterLength", m_clusterLength); - declareProperty("BeamPositionSvc", m_iBeamCondSvc); declareProperty("createSplitVertices", m_createSplitVertices); declareProperty("splitVerticesTrkInvFraction", m_splitVerticesTrkInvFraction, "inverse fraction to split tracks (1:N)"); @@ -136,10 +133,7 @@ namespace InDet msg(MSG::INFO) << "Retrieved tool " << m_iVertexFitter << endmsg; } - if (m_iBeamCondSvc.retrieve().isFailure()) { - msg(MSG::ERROR) << "Could not find BeamCondSvc." << endmsg; - return StatusCode::FAILURE; - } + ATH_CHECK(m_beamSpotKey.initialize()); msg(MSG::INFO) << "Initialization successful" << endmsg; return StatusCode::SUCCESS; @@ -153,11 +147,12 @@ namespace InDet /* xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); */ - - Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx()); + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + + const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx()); //---- create a vector of track particle base objects ---------------// std::vector<const Trk::Track*> origTracks; @@ -269,11 +264,11 @@ namespace InDet /* xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); */ - - Trk::RecVertex beamposition(m_iBeamCondSvc->beamVtx()); + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + const Trk::RecVertex &beamposition(beamSpotHandle->beamVtx()); //---- create a vector of track particle base objects ---------------// std::vector<const Trk::TrackParticleBase*> origTrackParticles; @@ -387,11 +382,12 @@ namespace InDet std::pair<xAOD::VertexContainer*, xAOD::VertexAuxContainer*> InDetPriVxFinderTool::findVertex(const xAOD::TrackParticleContainer* trackParticles) { ATH_MSG_DEBUG(" Number of input tracks before track selection: " << trackParticles->size()); - + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + xAOD::Vertex beamposition; beamposition.makePrivateStore(); - beamposition.setPosition(m_iBeamCondSvc->beamVtx().position()); - beamposition.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + beamposition.setPosition(beamSpotHandle->beamVtx().position()); + beamposition.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); std::vector<const xAOD::TrackParticle*> origTPs; origTPs.clear(); @@ -510,6 +506,7 @@ namespace InDet std::vector<xAOD::Vertex*> splitVtxVector; double vertexPt; xAOD::Vertex* myxAODVertex = 0; + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; for (unsigned int i = 0; i < zTrackColl.size(); i++) { // std::cout<<"Inside the loop"<<std::endl; if (msgLvl(MSG::DEBUG)) msg() << "Fitting vertex of Z-Cluster " << i << " with " << zTrackColl[i].size() << " Tracks" << endmsg; @@ -521,26 +518,26 @@ namespace InDet if (origParameters.size() == 1 && m_useBeamConstraint) { xAOD::Vertex theconstraint; theconstraint.makePrivateStore(); - theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position()); - theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); - theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF()); + theconstraint.setPosition(beamSpotHandle->beamVtx().position()); + theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); + theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF()); myxAODVertex = m_iVertexFitter->fit(origParameters, theconstraint); } else if (origParameters.size() < 2 && m_createSplitVertices) { // in the case this is a split vertex and it has only one track // we make a dummy vertex and push it back to the container myxAODVertex = new xAOD::Vertex; myxAODVertex->makePrivateStore(); - myxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position()); - myxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + myxAODVertex->setPosition(beamSpotHandle->beamVtx().position()); + myxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); myxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>(); myxAODVertex->setVertexType(xAOD::VxType::NoVtx); } else if (origParameters.size() > 1) { if (m_useBeamConstraint) { xAOD::Vertex theconstraint; theconstraint.makePrivateStore(); - theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position()); - theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); - theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF()); + theconstraint.setPosition(beamSpotHandle->beamVtx().position()); + theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); + theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF()); myxAODVertex = m_iVertexFitter->fit(origParameters, theconstraint); } else { myxAODVertex = m_iVertexFitter->fit(origParameters, vertex); @@ -584,9 +581,9 @@ namespace InDet if (m_useBeamConstraint) { xAOD::Vertex theconstraint; theconstraint.makePrivateStore(); - theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position()); - theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); - theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF()); + theconstraint.setPosition(beamSpotHandle->beamVtx().position()); + theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); + theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF()); myxAODVertex = m_iVertexFitter->fit(origParameters, theconstraint); } else { myxAODVertex = m_iVertexFitter->fit(origParameters, vertex); @@ -619,9 +616,9 @@ namespace InDet if (m_useBeamConstraint) { xAOD::Vertex theconstraint; theconstraint.makePrivateStore(); - theconstraint.setPosition(m_iBeamCondSvc->beamVtx().position()); - theconstraint.setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); - theconstraint.setFitQuality(m_iBeamCondSvc->beamVtx().fitQuality().chiSquared(), m_iBeamCondSvc->beamVtx().fitQuality().doubleNumberDoF()); + theconstraint.setPosition(beamSpotHandle->beamVtx().position()); + theconstraint.setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); + theconstraint.setFitQuality(beamSpotHandle->beamVtx().fitQuality().chiSquared(), beamSpotHandle->beamVtx().fitQuality().doubleNumberDoF()); myxAODVertex = m_iVertexFitter->fit(origParameters, theconstraint); } else { myxAODVertex = m_iVertexFitter->fit(origParameters, vertex); @@ -661,8 +658,8 @@ namespace InDet } else { xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex; dummyxAODVertex->makePrivateStore(); - dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position()); - dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position()); + dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>(); dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx); splitVtxVector.push_back(dummyxAODVertex); @@ -708,8 +705,8 @@ namespace InDet xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex; theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its // aux store - dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position()); - dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position()); + dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>(); dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx); } @@ -719,8 +716,8 @@ namespace InDet xAOD::Vertex* dummyxAODVertex = new xAOD::Vertex; theVertexContainer->push_back(dummyxAODVertex); // have to add vertex to container here first so it can use its // aux store - dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position()); - dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position()); + dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>(); dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx); if (m_createSplitVertices) { @@ -728,8 +725,8 @@ namespace InDet xAOD::Vertex* new_dummyxAODVertex = new xAOD::Vertex; theVertexContainer->push_back(new_dummyxAODVertex); // have to add vertex to container here first so it can use // its aux store - new_dummyxAODVertex->setPosition(m_iBeamCondSvc->beamVtx().position()); - new_dummyxAODVertex->setCovariancePosition(m_iBeamCondSvc->beamVtx().covariancePosition()); + new_dummyxAODVertex->setPosition(beamSpotHandle->beamVtx().position()); + new_dummyxAODVertex->setCovariancePosition(beamSpotHandle->beamVtx().covariancePosition()); new_dummyxAODVertex->vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>(); new_dummyxAODVertex->setVertexType(xAOD::VxType::NoVtx); } diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.cxx b/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.cxx index 47abf1be458a458f7d348e886830c8bb592e28e0..27acecaf8ef6f914dc5741bd03efa59eb0eadd97 100644 --- a/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.cxx +++ b/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.cxx @@ -44,7 +44,7 @@ StatusCode InDet::ToolTester::initialize() { return StatusCode::SUCCESS; } -StatusCode InDet::ToolTester::execute_r(const EventContext &ctx) const { +StatusCode InDet::ToolTester::execute(const EventContext &ctx) const { // Retrieve the tracks: SG::ReadHandle<xAOD::TrackParticleContainer> tracks(m_sgKey,ctx); diff --git a/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.h b/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.h index 08bc2a208ce1ca2c4647b9cc679427562273d204..445d5290a1de7f4fbb6ed0d4a6c119a1b326484f 100644 --- a/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.h +++ b/InnerDetector/InDetRecTools/InDetTrackSelectionTool/src/ToolTester.h @@ -34,7 +34,7 @@ namespace InDet { /// Function initialising the algorithm virtual StatusCode initialize(); /// Function executing the algorithm - virtual StatusCode execute_r(const EventContext &ctx) const; + virtual StatusCode execute(const EventContext &ctx) const; private: /// StoreGate key for the track container to investigate diff --git a/InnerDetector/InDetRecTools/PixelToTPIDTool/share/PixeldEdxWriteCool.py b/InnerDetector/InDetRecTools/PixelToTPIDTool/share/PixeldEdxWriteCool.py index d8f6a3b29ab1d86e51734b3564247a69172b8ac0..49a6f70bb9d383dec3645e136ff0306cd5a5d74b 100755 --- a/InnerDetector/InDetRecTools/PixelToTPIDTool/share/PixeldEdxWriteCool.py +++ b/InnerDetector/InDetRecTools/PixelToTPIDTool/share/PixeldEdxWriteCool.py @@ -7,10 +7,6 @@ ## basic job configuration (for generator) import AthenaCommon.AtlasUnixGeneratorJob -# Set handler for traceback -#gbl.AthenaServices.SetFatalHandler(438) - - ## get a handle to the default top-level algorithm sequence from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() diff --git a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/CMakeLists.txt b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/CMakeLists.txt index 9c80a92d68e73378131221eb5982a0393965c841..8ae2bd4893699fc9ed15d384847a0dc1f1225919 100644 --- a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/CMakeLists.txt +++ b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/CMakeLists.txt @@ -9,7 +9,7 @@ atlas_subdir( SiTrackMakerTool_xk ) atlas_depends_on_subdirs( PUBLIC Control/AthenaBaseComps GaudiKernel - InnerDetector/InDetConditions/InDetBeamSpotService + InnerDetector/InDetConditions/BeamSpotConditionsData InnerDetector/InDetRecTools/InDetRecToolInterfaces MagneticField/MagFieldInterfaces Tracking/TrkDetDescr/TrkGeometry diff --git a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/SiTrackMakerTool_xk/SiTrackMaker_xk.h b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/SiTrackMakerTool_xk/SiTrackMaker_xk.h index bd3e460d3bddc1e6915ca6797fb3a8a533d3e32a..af35b2e65e7dcf224a589ff8f6eac89390bf2474 100755 --- a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/SiTrackMakerTool_xk/SiTrackMaker_xk.h +++ b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/SiTrackMakerTool_xk/SiTrackMaker_xk.h @@ -26,13 +26,12 @@ #include "InDetRecToolInterfaces/ISeedToTrackConversionTool.h" #include "TrkGeometry/MagneticFieldProperties.h" #include "TrkCaloClusterROI/CaloClusterROI_Collection.h" +#include "BeamSpotConditionsData/BeamSpotData.h" #include <list> -#include <map> #include <iosfwd> class MsgStream; -class IBeamCondSvc; namespace InDet{ @@ -102,7 +101,7 @@ namespace InDet{ ToolHandle<InDet::ISiDetElementsRoadMaker> m_roadmaker ; ToolHandle<InDet::ISiCombinatorialTrackFinder> m_tracksfinder; ToolHandle<InDet::ISeedToTrackConversionTool> m_seedtrack ; - IBeamCondSvc* m_beam {} ; + SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" }; int m_nprint{} ; // Kind output information int m_inputseeds{} ; // Number input seeds @@ -116,7 +115,6 @@ namespace InDet{ // std::string m_inputHadClusterContainerName; SG::ReadHandleKey<CaloClusterROI_Collection> m_caloCluster; SG::ReadHandleKey<CaloClusterROI_Collection> m_caloHad; - std::string m_beamconditions; Trk::TrackInfo m_trackinfo ; bool m_pix{} ; bool m_sct{} ; diff --git a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/src/SiTrackMaker_xk.cxx b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/src/SiTrackMaker_xk.cxx index 8e2ef308bc6a0ad25bcc6f29c410c45ac7c16e8d..e69a0725677f46e6fd0f39f974a68121be10dc45 100755 --- a/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/src/SiTrackMaker_xk.cxx +++ b/InnerDetector/InDetRecTools/SiTrackMakerTool_xk/src/SiTrackMaker_xk.cxx @@ -20,7 +20,6 @@ #include "SiTrackMakerTool_xk/SiTrackMaker_xk.h" #include "TrkCaloClusterROI/CaloClusterROI.h" -#include "InDetBeamSpotService/IBeamCondSvc.h" /////////////////////////////////////////////////////////////////// @@ -75,7 +74,6 @@ InDet::SiTrackMaker_xk::SiTrackMaker_xk m_seedsegmentsWrite = false; // m_inputClusterContainerName = "InDetCaloClusterROIs" ; // m_inputHadClusterContainerName = "InDetHadCaloClusterROIs"; - m_beamconditions = "BeamCondSvc" ; declareInterface<ISiTrackMaker>(this); @@ -130,14 +128,9 @@ InDet::SiTrackMaker_xk::~SiTrackMaker_xk() StatusCode InDet::SiTrackMaker_xk::initialize() { - StatusCode sc = AlgTool::initialize(); - // Get beam geometry // - m_beam = 0; - if(m_beamconditions!="") { - sc = service(m_beamconditions,m_beam); - } + ATH_CHECK( m_beamSpotKey.initialize() ); // Get magnetic field service // @@ -375,8 +368,9 @@ std::ostream& InDet::operator << void InDet::SiTrackMaker_xk::newEvent(bool PIX,bool SCT) { - if(m_beam) {Amg::Vector3D cb = m_beam->beamPos(); m_xybeam[0] = cb[0]; m_xybeam[1] = cb[1];} - else { m_xybeam[0] = 0.; m_xybeam[1] = 0.;} + SG::ReadCondHandle<InDet::BeamSpotData> beamSpotHandle { m_beamSpotKey }; + if(beamSpotHandle.isValid()) { m_xybeam[0] = beamSpotHandle->beamPos()[0]; m_xybeam[1] = beamSpotHandle->beamPos()[1];} + else { m_xybeam[0] = 0.; m_xybeam[1] = 0.;} m_pix = PIX && m_usePix; m_sct = SCT && m_useSct; diff --git a/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/InDetDetailedTrackTruthMaker.h b/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/InDetDetailedTrackTruthMaker.h index 264c084ed3b022b2b4b8ca00687a116d7278827d..fd60e199cdcf7f016a0431deb265cebdcf3644dd 100755 --- a/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/InDetDetailedTrackTruthMaker.h +++ b/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/InDetDetailedTrackTruthMaker.h @@ -34,7 +34,7 @@ public: InDetDetailedTrackTruthMaker(const std::string &name,ISvcLocator *pSvcLocator); virtual StatusCode initialize(); - virtual StatusCode execute_r(const EventContext &ctx) const; + virtual StatusCode execute(const EventContext &ctx) const; virtual StatusCode finalize(); private: diff --git a/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/PRD_MultiTruthMaker.h b/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/PRD_MultiTruthMaker.h index 84f3abd67dcda39c44d5dbf72e1e1adc18a6676d..83a06f5e02a16352a6b9e7cba3c71891a073b0d6 100755 --- a/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/PRD_MultiTruthMaker.h +++ b/InnerDetector/InDetTruth/InDetTruthAlgs/InDetTruthAlgs/PRD_MultiTruthMaker.h @@ -32,7 +32,7 @@ public: PRD_MultiTruthMaker(const std::string &name,ISvcLocator *pSvcLocator); virtual StatusCode initialize(); - virtual StatusCode execute_r(const EventContext &ctx) const; + virtual StatusCode execute(const EventContext &ctx) const; virtual StatusCode finalize(); private: diff --git a/InnerDetector/InDetTruth/InDetTruthAlgs/src/InDetDetailedTrackTruthMaker.cxx b/InnerDetector/InDetTruth/InDetTruthAlgs/src/InDetDetailedTrackTruthMaker.cxx index 9262a1c5cb52275a53ac2702d45ea2b29fc22723..eccdd3a9556a9e679e05c03a751acdbe95258b6e 100755 --- a/InnerDetector/InDetTruth/InDetTruthAlgs/src/InDetDetailedTrackTruthMaker.cxx +++ b/InnerDetector/InDetTruth/InDetTruthAlgs/src/InDetDetailedTrackTruthMaker.cxx @@ -64,9 +64,9 @@ StatusCode InDetDetailedTrackTruthMaker::finalize() } // ----------------------------------------------------------------------------------------------------- -StatusCode InDetDetailedTrackTruthMaker::execute_r(const EventContext &ctx) const +StatusCode InDetDetailedTrackTruthMaker::execute(const EventContext &ctx) const { - ATH_MSG_DEBUG ("InDetDetailedTrackTruthMaker::execute_r(...)"); + ATH_MSG_DEBUG ("InDetDetailedTrackTruthMaker::execute(...)"); //---------------------------------------------------------------- // Retrieve track collection diff --git a/InnerDetector/InDetTruth/InDetTruthAlgs/src/PRD_MultiTruthMaker.cxx b/InnerDetector/InDetTruth/InDetTruthAlgs/src/PRD_MultiTruthMaker.cxx index 060e76998f8784d9dd3ba236e0488521fb4b0de8..5fd65d0558e30ef7cda172a6aea4c687afd86851 100755 --- a/InnerDetector/InDetTruth/InDetTruthAlgs/src/PRD_MultiTruthMaker.cxx +++ b/InnerDetector/InDetTruth/InDetTruthAlgs/src/PRD_MultiTruthMaker.cxx @@ -81,7 +81,7 @@ StatusCode PRD_MultiTruthMaker::finalize() } // ----------------------------------------------------------------------------------------------------- -StatusCode PRD_MultiTruthMaker::execute_r(const EventContext &ctx) const { +StatusCode PRD_MultiTruthMaker::execute(const EventContext &ctx) const { ATH_MSG_DEBUG ("PRD_MultiTruthMaker::execute()"); diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.cxx b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.cxx index 5aa001129a2d33d01169ebe8d8da1536455585a2..c986a0642bb8ce92abed5e2182001155641257f0 100644 --- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.cxx +++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.cxx @@ -32,7 +32,7 @@ InDetPhysHitDecoratorAlg::InDetPhysHitDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator) : - AthAlgorithm(name,pSvcLocator), + AthReentrantAlgorithm(name,pSvcLocator), m_holeSearchTool("InDet::InDetTrackHoleSearchTool"), m_updatorHandle("Trk::KalmanUpdator/TrkKalmanUpdator"), m_residualPullCalculator("Trk::ResidualPullCalculator/ResidualPullCalculator"), @@ -109,15 +109,9 @@ InDetPhysHitDecoratorAlg::finalize() { return StatusCode::SUCCESS; } -StatusCode -InDetPhysHitDecoratorAlg::execute() { - const EventContext context{ Gaudi::Hive::currentContext() }; - return execute_r(context); -} - // to migrate to AthReentrantAlgorithm later StatusCode -InDetPhysHitDecoratorAlg::execute_r(const EventContext &ctx) const { +InDetPhysHitDecoratorAlg::execute(const EventContext &ctx) const { SG::ReadHandle<xAOD::TrackParticleContainer> ptracks(m_trkParticleName); if ((not ptracks.isValid())) { return StatusCode::FAILURE; diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.h b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.h index b1f08b4df07edcb7d79915fc43577bf96ae55a9e..8a95ee1049720f29c80cfb4ced9fc9e8985509ed 100644 --- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.h +++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysHitDecoratorAlg.h @@ -12,7 +12,7 @@ **/ // STL includes #include <string> -#include "AthenaBaseComps/AthAlgorithm.h" +#include "AthenaBaseComps/AthReentrantAlgorithm.h" #include "GaudiKernel/ToolHandle.h" #include "xAODTracking/TrackParticleContainer.h" #include "StoreGate/WriteDecorHandle.h" @@ -33,7 +33,7 @@ namespace Trk { // class to decorate xAOD::TruthParticles with additional information required by validation -class InDetPhysHitDecoratorAlg: public AthAlgorithm { +class InDetPhysHitDecoratorAlg: public AthReentrantAlgorithm { public: // L0PIXBARR : layer0 of pixel barrel (IBL in Run2) // PIXEL : in barrel all layers appart from layer0. In end-caps all disks/rings. @@ -48,8 +48,7 @@ public: ~InDetPhysHitDecoratorAlg (); virtual StatusCode initialize() override; virtual StatusCode finalize() override; - virtual StatusCode execute() override; - virtual StatusCode execute_r(const EventContext &ctx) const; + virtual StatusCode execute(const EventContext &ctx) const; private: bool diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.cxx b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.cxx index b6f1a3e804214b6704607123ed3d0ba739e50834..454606b041994f9c6709dd90ce0fa308a16386ab 100644 --- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.cxx +++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.cxx @@ -27,7 +27,7 @@ InDetPhysValTruthDecoratorAlg::InDetPhysValTruthDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator) : - AthAlgorithm(name, pSvcLocator), + AthReentrantAlgorithm(name, pSvcLocator), m_beamSpotSvc("BeamCondSvc", name) { } @@ -71,14 +71,7 @@ InDetPhysValTruthDecoratorAlg::finalize() { } StatusCode -InDetPhysValTruthDecoratorAlg::execute() { - const EventContext context{ Gaudi::Hive::currentContext() }; - return execute_r(context); -} - -// to migrate to AthReentrantAlgorithm later -StatusCode -InDetPhysValTruthDecoratorAlg::execute_r(const EventContext &ctx) const { +InDetPhysValTruthDecoratorAlg::execute(const EventContext &ctx) const { SG::ReadHandle<xAOD::TruthParticleContainer> ptruth(m_truthParticleName); if ((not ptruth.isValid())) { return StatusCode::FAILURE; diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.h b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.h index 6a9ad9d4475c0cfa3324fa9d7629daad8ebfc2c5..11202a332889309cb371295bb057c9979ad01088 100644 --- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.h +++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/InDetPhysValTruthDecoratorAlg.h @@ -13,7 +13,7 @@ // STL includes #include <string> #include "xAODTruth/TruthParticleContainer.h" -#include "AthenaBaseComps/AthAlgorithm.h" +#include "AthenaBaseComps/AthReentrantAlgorithm.h" #include "GaudiKernel/ToolHandle.h" #include "GaudiKernel/ServiceHandle.h" #include "TrkExInterfaces/IExtrapolator.h" @@ -29,17 +29,14 @@ class IBeamCondSvc; // class to decorate xAOD::TruthParticles with additional information required by validation -class InDetPhysValTruthDecoratorAlg: public AthAlgorithm { +class InDetPhysValTruthDecoratorAlg: public AthReentrantAlgorithm { public: InDetPhysValTruthDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator); virtual ~InDetPhysValTruthDecoratorAlg (); virtual StatusCode initialize(); virtual StatusCode finalize(); - virtual StatusCode execute() override; - - // to migrate to AthReentrantAlgorithm later - virtual StatusCode execute_r(const EventContext &ctx) const; + virtual StatusCode execute(const EventContext &ctx) const; private: bool decorateTruth(const xAOD::TruthParticle& particle, diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.cxx b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.cxx index f8d5d429ee12d5756a2c00d11e345fb62695048f..0f7ebce677ff7f983860e9bde493d00e0d943e19 100644 --- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.cxx +++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.cxx @@ -44,7 +44,7 @@ ParameterErrDecoratorAlg::finalize() { } StatusCode -ParameterErrDecoratorAlg::execute_r(const EventContext &ctx) const { +ParameterErrDecoratorAlg::execute(const EventContext &ctx) const { SG::ReadHandle<xAOD::TrackParticleContainer> ptracks(m_trkParticleName); if ((not ptracks.isValid())) { return StatusCode::FAILURE; diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.h b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.h index a9850f563f07cb90e003758f3ef4ee3429fa19b3..02ad809325d407a51bcac8acb3cd10e668d9d6aa 100644 --- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.h +++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/ParameterErrDecoratorAlg.h @@ -28,7 +28,7 @@ public: ~ParameterErrDecoratorAlg(); virtual StatusCode initialize(); virtual StatusCode finalize(); - virtual StatusCode execute_r(const EventContext &ctx) const; + virtual StatusCode execute(const EventContext &ctx) const; private: virtual bool decorateTrack(const xAOD::TrackParticle& particle, std::vector< SG::WriteDecorHandle<xAOD::TrackParticleContainer,float> > &float_decor) const; diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.cxx b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.cxx index 5a83ab72e827e7e751cec6ba65496e905aac0b36..dcc8674da31f1f9ba0bf34efca0f358843f59b7a 100644 --- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.cxx +++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.cxx @@ -13,7 +13,7 @@ TruthClassDecoratorAlg::TruthClassDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator) : - AthAlgorithm(name,pSvcLocator) + AthReentrantAlgorithm(name,pSvcLocator) { } @@ -37,15 +37,9 @@ TruthClassDecoratorAlg::finalize() { } -StatusCode -TruthClassDecoratorAlg::execute() { - const EventContext context{ Gaudi::Hive::currentContext() }; - return execute_r(context); -} - // to migrate to AthReentrantAlgorithm later StatusCode -TruthClassDecoratorAlg::execute_r(const EventContext &ctx) const { +TruthClassDecoratorAlg::execute(const EventContext &ctx) const { SG::ReadHandle<xAOD::TruthParticleContainer> ptruth(m_truthParticleName); if ((not ptruth.isValid())) { return StatusCode::FAILURE; diff --git a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.h b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.h index 8284785db4e209099c4b96de0f0488b6d3e028a8..2cb5b6b9d0c73968da18d1947bd651cf578bbd34 100644 --- a/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.h +++ b/InnerDetector/InDetValidation/InDetPhysValMonitoring/src/TruthClassDecoratorAlg.h @@ -13,7 +13,7 @@ // STL includes #include <string> #include "xAODTruth/TruthParticleContainer.h" -#include "AthenaBaseComps/AthAlgorithm.h" +#include "AthenaBaseComps/AthReentrantAlgorithm.h" #include "GaudiKernel/ToolHandle.h" #include "GaudiKernel/EventContext.h" #include "StoreGate/WriteDecorHandleKey.h" @@ -24,7 +24,7 @@ #include "InDetPhysValMonitoring/IAthSelectionTool.h" // class to decorate xAOD::TruthParticles with type and origin, required by validation -class TruthClassDecoratorAlg: public AthAlgorithm { +class TruthClassDecoratorAlg: public AthReentrantAlgorithm { public: TruthClassDecoratorAlg(const std::string& name, ISvcLocator* pSvcLocator); virtual ~TruthClassDecoratorAlg () {/*nop*/ @@ -32,10 +32,7 @@ public: virtual StatusCode initialize() override; virtual StatusCode finalize() override; - virtual StatusCode execute() override; - - // to migrate to AthReentrantAlgorithm later - virtual StatusCode execute_r(const EventContext &ctx) const; + virtual StatusCode execute(const EventContext &ctx) const; private: bool decorateTruth(const xAOD::TruthParticle& particle, diff --git a/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/InDetTrackClusterAssValidation/TrackClusterAssValidation.h b/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/InDetTrackClusterAssValidation/TrackClusterAssValidation.h index 2c5e0093f483da0bc5efda104b76cba2514c7b63..a90bdc2c0dd158fcb1fe14f46978fecbfbbf1290 100755 --- a/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/InDetTrackClusterAssValidation/TrackClusterAssValidation.h +++ b/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/InDetTrackClusterAssValidation/TrackClusterAssValidation.h @@ -85,7 +85,7 @@ namespace InDet { TrackClusterAssValidation(const std::string &name, ISvcLocator *pSvcLocator); virtual ~TrackClusterAssValidation() {} StatusCode initialize(); - StatusCode execute_r(const EventContext& ctx) const; + StatusCode execute(const EventContext& ctx) const; StatusCode finalize(); protected: diff --git a/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/src/TrackClusterAssValidation.cxx b/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/src/TrackClusterAssValidation.cxx index 8e4affef115d6f289d91aa5941f38d9c867a3732..17649691cbed6963ac4f4751aa9b942f21b75aba 100755 --- a/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/src/TrackClusterAssValidation.cxx +++ b/InnerDetector/InDetValidation/InDetTrackClusterAssValidation/src/TrackClusterAssValidation.cxx @@ -144,7 +144,7 @@ StatusCode InDet::TrackClusterAssValidation::initialize() // Execute /////////////////////////////////////////////////////////////////// -StatusCode InDet::TrackClusterAssValidation::execute_r(const EventContext& ctx) const +StatusCode InDet::TrackClusterAssValidation::execute(const EventContext& ctx) const { if(!m_usePIX && !m_useSCT) return StatusCode::SUCCESS; diff --git a/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/HoleSearchValidation.h b/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/HoleSearchValidation.h index f896325e29e459a686c63266d47a8f4652b0e03b..770427d5a4a667ba9ef0227f44d4e16d0a7879ab 100755 --- a/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/HoleSearchValidation.h +++ b/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/HoleSearchValidation.h @@ -58,7 +58,7 @@ namespace InDet { /** standard Athena-Algorithm method */ StatusCode initialize(); /** standard Athena-Algorithm method */ - StatusCode execute_r(const EventContext& ctx) const; + StatusCode execute(const EventContext& ctx) const; /** standard Athena-Algorithm method */ StatusCode finalize(); diff --git a/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/InDetSplittedTracksCreator.h b/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/InDetSplittedTracksCreator.h index 1e40a80f9123325f7ea57d963a947027a6224ecf..6fd969ce5e6185c299862832f5be9380196da921 100644 --- a/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/InDetSplittedTracksCreator.h +++ b/InnerDetector/InDetValidation/InDetTrackValidation/InDetTrackValidation/InDetSplittedTracksCreator.h @@ -35,7 +35,7 @@ public: /** standard Athena-Algorithm method */ StatusCode initialize(); /** standard Athena-Algorithm method */ - StatusCode execute_r(const EventContext& ctx) const; + StatusCode execute(const EventContext& ctx) const; /** standard Athena-Algorithm method */ StatusCode finalize(); diff --git a/InnerDetector/InDetValidation/InDetTrackValidation/src/HoleSearchValidation.cxx b/InnerDetector/InDetValidation/InDetTrackValidation/src/HoleSearchValidation.cxx index 6186436a7cbcd0ff6f02874f34d13e63b9eeabe8..6322b581f67aaae23f2caf45a316f14f4823bb91 100755 --- a/InnerDetector/InDetValidation/InDetTrackValidation/src/HoleSearchValidation.cxx +++ b/InnerDetector/InDetValidation/InDetTrackValidation/src/HoleSearchValidation.cxx @@ -154,7 +154,7 @@ StatusCode HoleSearchValidation::initialize() { return StatusCode::SUCCESS; } -StatusCode HoleSearchValidation::execute_r(const EventContext& ctx) const { +StatusCode HoleSearchValidation::execute(const EventContext& ctx) const { std::array<bool,Parts::kNParts> remove_parts; for (unsigned int part_i=0; part_i<Parts::kNParts; ++part_i) { diff --git a/InnerDetector/InDetValidation/InDetTrackValidation/src/InDetSplittedTracksCreator.cxx b/InnerDetector/InDetValidation/InDetTrackValidation/src/InDetSplittedTracksCreator.cxx index 4376a4523bb9197cd3f4bf269e6160bbb8ac9fe5..cd5604f465281c1614aaa478b67e5a36df682d64 100644 --- a/InnerDetector/InDetValidation/InDetTrackValidation/src/InDetSplittedTracksCreator.cxx +++ b/InnerDetector/InDetValidation/InDetTrackValidation/src/InDetSplittedTracksCreator.cxx @@ -47,7 +47,7 @@ StatusCode InDet::InDetSplittedTracksCreator::initialize(){ return StatusCode::SUCCESS; } // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * -StatusCode InDet::InDetSplittedTracksCreator::execute_r(const EventContext& ctx) const { +StatusCode InDet::InDetSplittedTracksCreator::execute(const EventContext& ctx) const { ATH_MSG_DEBUG("InDetSplittedTracksCreator execute()"); ATH_MSG_DEBUG("Input Track Collection: " << m_TrackCol); diff --git a/LArCalorimeter/LArCellRec/share/LArCellBuilderFromLArHitTool_test.ref b/LArCalorimeter/LArCellRec/share/LArCellBuilderFromLArHitTool_test.ref index a5f028aaf96c29f0d4c3c06f8b35900d94e2572b..051220ee50516696ec0782547ddeb99384b577d2 100644 --- a/LArCalorimeter/LArCellRec/share/LArCellBuilderFromLArHitTool_test.ref +++ b/LArCalorimeter/LArCellRec/share/LArCellBuilderFromLArHitTool_test.ref @@ -1,14 +1,14 @@ -Sat Nov 10 05:32:00 CET 2018 +Thu Dec 6 05:01:02 CET 2018 Preloading tcmalloc_minimal.so Py:Athena INFO including file "AthenaCommon/Preparation.py" -Py:Athena INFO using release [AthenaWorkDir-22.0.1] [x86_64-slc6-gcc62-dbg] [atlas-work3/6f2b6978e1b] -- built on [2018-11-10T0506] +Py:Athena INFO using release [AthenaWorkDir-22.0.1] [x86_64-slc6-gcc62-opt] [atlas-work3/fa0fd6d0989] -- built on [2018-12-06T0405] Py:Athena INFO including file "AthenaCommon/Atlas.UnixStandardJob.py" Py:Athena INFO executing ROOT6Setup Py:Athena INFO including file "AthenaCommon/Execution.py" Py:Athena INFO including file "LArCellRec/LArCellBuilderFromLArHitTool_test.py" [?1034hSetGeometryVersion.py obtained major release version 22 Py:Athena INFO including file "IdDictDetDescrCnv/IdDictDetDescrCnv_joboptions.py" -Py:ConfigurableDb INFO Read module info for 5558 configurables from 52 genConfDb files +Py:ConfigurableDb INFO Read module info for 5473 configurables from 52 genConfDb files Py:ConfigurableDb INFO No duplicates have been found: that's good ! EventInfoMgtInit: Got release version Athena-22.0.1 Py:IOVDbSvc.CondDB INFO Setting up conditions DB access to instance OFLP200 @@ -42,8 +42,8 @@ ApplicationMgr INFO Updating Gaudi::PluginService::SetDebug(level) to leve ApplicationMgr INFO Updating Gaudi::PluginService::SetDebug(level) to level= 'PluginDebugLevel':0 ApplicationMgr SUCCESS ==================================================================================================================================== - Welcome to ApplicationMgr (GaudiCoreSvc v30r4) - running on lxplus051.cern.ch on Sat Nov 10 05:32:19 2018 + Welcome to ApplicationMgr (GaudiCoreSvc v30r5) + running on lxplus077.cern.ch on Thu Dec 6 05:01:24 2018 ==================================================================================================================================== ApplicationMgr INFO Successfully loaded modules : AthenaServices ApplicationMgr INFO Application Manager Configured successfully @@ -60,8 +60,8 @@ PoolSvc INFO io_register[PoolSvc](xmlcatalog_file:PoolFileCatalog.x PoolSvc INFO Set connectionsvc retry/timeout/IDLE timeout to 'ConnectionRetrialPeriod':300/ 'ConnectionRetrialTimeOut':3600/ 'ConnectionTimeOut':5 seconds with connection cleanup disabled PoolSvc INFO Frontier compression level set to 5 DBReplicaSvc INFO Frontier server at (serverurl=http://atlasfrontier-local.cern.ch:8000/atlr)(serverurl=http://atlasfrontier-ai.cern.ch:8000/atlr)(serverurl=http://lcgft-atlas.gridpp.rl.ac.uk:3128/frontierATLAS)(serverurl=http://ccfrontier.in2p3.fr:23128/ccin2p3-AtlasFrontier)(proxyurl=http://ca-proxy.cern.ch:3128)(proxyurl=http://ca-proxy-meyrin.cern.ch:3128)(proxyurl=http://ca-proxy-wigner.cern.ch:3128)(proxyurl=http://atlasbpfrontier.cern.ch:3127)(proxyurl=http://atlasbpfrontier.fnal.gov:3127) will be considered for COOL data -DBReplicaSvc INFO Read replica configuration from /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/dbreplica.config -DBReplicaSvc INFO Total of 10 servers found for host lxplus051.cern.ch [ATLF ATLAS_COOLPROD atlas_dd ATLAS_CONFIG INT8R INTR ATONR_COOL ATONR_CONF DEVDB11 ATLF ] +DBReplicaSvc INFO Read replica configuration from /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/dbreplica.config +DBReplicaSvc INFO Total of 10 servers found for host lxplus077.cern.ch [ATLF ATLAS_COOLPROD atlas_dd ATLAS_CONFIG INT8R INTR ATONR_COOL ATONR_CONF DEVDB11 ATLF ] PoolSvc INFO Successfully setup replica sorting algorithm PoolSvc INFO Setting up APR FileCatalog and Streams PoolSvc WARNING Unable to locate catalog for prfile:poolcond/PoolCat_oflcond.xml check your ATLAS_POOLCOND_PATH and DATAPATH variables @@ -77,14 +77,14 @@ IOVDbSvc INFO Global tag: OFLCOND-RUN12-SDR-35 set from joboptions IOVDbSvc INFO Folder /LAR/Identifier/OnOffIdMap, adding new key tag with value LARIdentifierOnOffIdMap-012 IOVDbSvc INFO Folder /LAR/Identifier/CalibIdMap, adding new key tag with value LARIdentifierCalibIdMap-012 IOVDbSvc INFO Folder /LAR/Identifier/FebRodMap, adding new key tag with value LARIdentifierFebRodMap-005 -IOVDbSvc INFO Read from meta data only for folder /TagInfo +IOVDbFolder INFO Read from meta data only for folder /TagInfo IOVDbSvc INFO Initialised with 3 connections and 24 folders IOVDbSvc INFO Service IOVDbSvc initialised successfully IOVDbSvc INFO preLoadAddresses: Removing folder /TagInfo. It should only be in the file meta data and was not found. IOVDbSvc INFO Opening COOL connection for COOLOFL_LAR/OFLP200 IOVSvc INFO No IOVSvcTool associated with store "StoreGateSvc" IOVSvcTool INFO IOVRanges will be checked at every Event -ClassIDSvc INFO getRegistryEntries: read 2132 CLIDRegistry entries for module ALL +ClassIDSvc INFO getRegistryEntries: read 2134 CLIDRegistry entries for module ALL IOVDbSvc INFO Opening COOL connection for COOLOFL_CALO/OFLP200 IOVDbSvc INFO Disconnecting from COOLOFL_LAR/OFLP200 IOVDbSvc INFO Disconnecting from COOLOFL_CALO/OFLP200 @@ -112,7 +112,7 @@ IOVDbSvc INFO Added taginfo remove for /LAR/Identifier/LArTTCellMapA IOVDbSvc INFO Added taginfo remove for /LAR/ElecCalibMC/fSampl IOVDbSvc INFO Added taginfo remove for /LAR/ElecCalibMC/uA2MeV ClassIDSvc INFO getRegistryEntries: read 17 CLIDRegistry entries for module ALL -ClassIDSvc INFO getRegistryEntries: read 5227 CLIDRegistry entries for module ALL +ClassIDSvc INFO getRegistryEntries: read 2879 CLIDRegistry entries for module ALL ClassIDSvc INFO getRegistryEntries: read 18 CLIDRegistry entries for module ALL DetDescrCnvSvc INFO initializing DetDescrCnvSvc INFO Found DetectorStore service @@ -201,12 +201,12 @@ EndcapDMConstru... INFO Start building EC electronics geometry multi-layered version of absorbers activated, mlabs == 1 ================================================ EndcapDMConstru... INFO Start building EC electronics geometry -GeoModelSvc INFO GeoModelSvc.LArDetectorToolNV SZ= 28072Kb Time = 1.51S +GeoModelSvc INFO GeoModelSvc.LArDetectorToolNV SZ= 21904Kb Time = 0.75S ClassIDSvc INFO getRegistryEntries: read 213 CLIDRegistry entries for module ALL ClassIDSvc INFO getRegistryEntries: read 65 CLIDRegistry entries for module ALL AthenaEventLoopMgr INFO Initializing AthenaEventLoopMgr - package version AthenaServices-00-00-00 -ClassIDSvc INFO getRegistryEntries: read 6828 CLIDRegistry entries for module ALL -ClassIDSvc INFO getRegistryEntries: read 670 CLIDRegistry entries for module ALL +ClassIDSvc INFO getRegistryEntries: read 6826 CLIDRegistry entries for module ALL +ClassIDSvc INFO getRegistryEntries: read 605 CLIDRegistry entries for module ALL CondInputLoader INFO Initializing CondInputLoader... CondInputLoader INFO Adding base classes: + ( 'AthenaAttributeList' , 'ConditionStore+/LAR/BadChannels/MissingFEBs' ) -> @@ -276,15 +276,15 @@ CaloIDHelper_ID... INFO in createObj: creating a LArHEC_ID helper object in th AtlasDetectorID INFO initialize_from_dictionary - OK CaloIDHelper_ID... INFO in createObj: creating a LArFCAL_ID helper object in the detector store AtlasDetectorID INFO initialize_from_dictionary - OK -LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCal2DNeighbors-April2011.txt -LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCal3DNeighborsNext-April2011.txt -LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCal3DNeighborsPrev-April2011.txt +LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCal2DNeighbors-April2011.txt +LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCal3DNeighborsNext-April2011.txt +LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCal3DNeighborsPrev-April2011.txt CaloIDHelper_ID... INFO in createObj: creating a LArMiniFCAL_ID helper object in the detector store AtlasDetectorID INFO initialize_from_dictionary - OK LArMiniFCAL_ID INFO initialize_from_dict - LArCalorimeter dictionary does NOT contain miniFCAL description. Unable to initialize LArMiniFCAL_ID. CaloIDHelper_ID... INFO in createObj: creating a TileID helper object in the detector store AtlasDetectorID INFO initialize_from_dictionary - OK -TileNeighbour INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/TileNeighbour_reduced.txt +TileNeighbour INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/TileNeighbour_reduced.txt AtlasDetectorID INFO initialize_from_dictionary - OK CaloIdMgrDetDes... INFO in createObj: creating a CaloDescrManager object in the detector store CaloIDHelper_ID... INFO in createObj: creating a CaloDM_ID helper object in the detector store @@ -303,28 +303,28 @@ CaloIDHelper_ID... INFO in createObj: creating a LArHEC_SuperCell_ID helper ob AtlasDetectorID INFO initialize_from_dictionary - OK CaloIDHelper_ID... INFO in createObj: creating a LArFCAL_SuperCell_ID helper object in the detector store AtlasDetectorID INFO initialize_from_dictionary - OK -LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCalSuperCells2DNeighborsNew-April2014.txt -LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCalSuperCells3DNeighborsNextNew-April2014.txt -LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/FCalSuperCells3DNeighborsPrevNew-April2014.txt +LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCalSuperCells2DNeighborsNew-April2014.txt +LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCalSuperCells3DNeighborsNextNew-April2014.txt +LArFCAL_Base_ID INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/FCalSuperCells3DNeighborsPrevNew-April2014.txt CaloIDHelper_ID... INFO in createObj: creating a Tile_SuperCell_ID helper object in the detector store AtlasDetectorID INFO initialize_from_dictionary - OK -TileNeighbour INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-11-08T2259/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-dbg/share/TileSuperCellNeighbour.txt +TileNeighbour INFO Reading file /cvmfs/atlas-nightlies.cern.ch/repo/sw/master/2018-12-04T2300/Athena/22.0.1/InstallArea/x86_64-slc6-gcc62-opt/share/TileSuperCellNeighbour.txt AtlasDetectorID INFO initialize_from_dictionary - OK CaloIdMgrDetDes... INFO Finished CaloIdMgrDetDes... INFO Initializing CaloIdMgr from values in CaloIdMgrDetDescrCnv DetectorStore WARNING retrieve(default): No valid proxy for default object of type TileDetDescrManager(CLID 2941) CaloMgrDetDescrCnvWARNING Could not get the TileDetectorManager. No Calo Elements will be built for Tile - <ROOT.CaloDetDescrManager object at 0x16d1ba40> -ClassIDSvc INFO getRegistryEntries: read 4258 CLIDRegistry entries for module ALL + <ROOT.CaloDetDescrManager object at 0x1679d480> +ClassIDSvc INFO getRegistryEntries: read 4203 CLIDRegistry entries for module ALL ToolSvc.tool1em INFO No threshold on hit energy ToolSvc.tool1em INFO THRESHOLD CHOICE : No Threshold ! ToolSvc.CaloNoi... INFO CaloNoiseTool called ToolSvc.CaloNoiseToolDefault initialize() begin LArOnlineIDDetD... INFO in createObj: creating a LArOnlineID helper object in the detector store LArOnlineID INFO initialize_from_dictionary AtlasDetectorID INFO initialize_from_dictionary - OK -ClassIDSvc INFO getRegistryEntries: read 2826 CLIDRegistry entries for module ALL -IOVSvcTool INFO Still in initialize phase, not tiggering callback for LArCablingService[0x29631e00]+7f1ebdd81054 bound to AthenaAttributeList[/LAR/Identifier/OnOffIdMap] +ClassIDSvc INFO getRegistryEntries: read 2605 CLIDRegistry entries for module ALL +IOVSvcTool INFO Still in initialize phase, not tiggering callback for LArCablingService[0x1cd28a00]+7f3320d16630 bound to AthenaAttributeList[/LAR/Identifier/OnOffIdMap] ToolSvc.LArCabl... INFO Successfully installed callback on folder/LAR/Identifier/OnOffIdMap ToolSvc.LArCabl... INFO Successfully installed callback on folder/LAR/Identifier/CalibIdMap ToolSvc.LArCabl... INFO Successfully installed callback on folder/LAR/Identifier/FebRodMap @@ -334,7 +334,7 @@ ToolSvc.LArADC2... INFO Registered callback for key: LArDAC2uA ToolSvc.LArADC2... INFO Registered callback for key: LAruA2MeV ToolSvc.LArADC2... INFO Registered callback for key: LArMphysOverMcal ToolSvc.LArADC2... INFO Registered callback for key: LArHVScaleCorr -IOVSvcTool INFO Still in initialize phase, not tiggering callback for LArMCSymTool[0x29633200]+189 bound to /LAR/Identifier/FebRodMap +IOVSvcTool INFO Still in initialize phase, not tiggering callback for LArMCSymTool[0x1cd29e00]+189 bound to /LAR/Identifier/CalibIdMap ClassIDSvc INFO getRegistryEntries: read 53 CLIDRegistry entries for module ALL ToolSvc.LArAuto... INFO Registered callback for key: LArShape ToolSvc.LArAuto... INFO Registered callback for key: LArAutoCorr @@ -342,19 +342,19 @@ ToolSvc.LArOFCT... INFO Registered callback for key: LArShape ToolSvc.LArOFCT... INFO Registered callback for key: LArNoise ToolSvc.LArOFCT... INFO Registered callback for LArOFCTool/LArAutoCorrTotalTool ToolSvc.CaloNoi... INFO Will cache electronic noise -IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArNoiseMC[LArNoise] +IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArNoiseMC[LArNoise] ToolSvc.CaloNoi... INFO Registered callback for key: LArNoise -IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArAutoCorrMC[LArAutoCorr] +IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArAutoCorrMC[LArAutoCorr] ToolSvc.CaloNoi... INFO Registered callback for key: LArAutoCorr -IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArShape32MC[LArShape] +IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArShape32MC[LArShape] ToolSvc.CaloNoi... INFO Registered callback for key: LArShape -IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArfSamplMC[LArfSampl] +IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArfSamplMC[LArfSampl] ToolSvc.CaloNoi... INFO Registered callback for key: LArfSampl -IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArMinBiasMC[LArMinBias] +IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArMinBiasMC[LArMinBias] ToolSvc.CaloNoi... INFO Registered callback for key: LArMinBias -IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArRamp +IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArDAC2uA ToolSvc.CaloNoi... INFO Registered callbacks for LArADC2MeVTool -> CaloNoiseTool -IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x29938398]+191 bound to LArShape +IOVSvcTool INFO Still in initialize phase, not tiggering callback for CaloNoiseTool[0x2907a398]+191 bound to LArAutoCorr ToolSvc.CaloNoi... INFO Registered callbacks for LArOFCTool -> CaloNoiseTool ToolSvc.CaloNoi... INFO CaloNoiseTool initialize() end ToolSvc.tool1em INFO no noise selected @@ -433,26 +433,24 @@ EventPersistenc... INFO Added successfully Conversion service:AthenaPoolCnvSvc EventPersistenc... INFO Added successfully Conversion service:TagInfoMgr ClassIDSvc INFO getRegistryEntries: read 109 CLIDRegistry entries for module ALL IOVDbSvc INFO Opening COOL connection for COOLOFL_LAR/OFLP200 -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARAlign-IOVDEP-00 for folder /LAR/Align -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArBadChannelsBadChannels-IOVDEP-06 for folder /LAR/BadChannels/BadChannels -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArBadChannelsMissingFEBs-IOVDEP-04 for folder /LAR/BadChannels/MissingFEBs -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCAutoCorr-Apr2010 for folder /LAR/ElecCalibMC/AutoCorr -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArCellPositionShift-ideal for folder /LAR/LArCellPositionShift -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCDAC2uA-CSC02-J for folder /LAR/ElecCalibMC/DAC2uA -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCHVScaleCorr-IOVDEP-00 for folder /LAR/ElecCalibMC/HVScaleCorr -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMinBias-IOVDEP-01 for folder /LAR/ElecCalibMC/MinBias -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMinBiasAverage-IOVDEP-01 for folder /LAR/ElecCalibMC/MinBiasAverage -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMphysOverMcal-CSC02-I for folder /LAR/ElecCalibMC/MphysOverMcal -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCNoise-Apr2010 for folder /LAR/ElecCalibMC/Noise -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCPedestal-DC3-B-IdFix7 for folder /LAR/ElecCalibMC/Pedestal -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCRamp-CSC02-K for folder /LAR/ElecCalibMC/Ramp -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCShape-Apr2010 for folder /LAR/ElecCalibMC/Shape -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARIdentifierLArTTCellMapAtlas-HadFcalFix2 for folder /LAR/Identifier/LArTTCellMapAtlas -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCfSampl-G496-19213-FTFP_BERT_BIRK for folder /LAR/ElecCalibMC/fSampl -IOVDbSvc INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARuA2MeV-Feb2011 for folder /LAR/ElecCalibMC/uA2MeV +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARAlign-IOVDEP-00 for folder /LAR/Align +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArBadChannelsBadChannels-IOVDEP-06 for folder /LAR/BadChannels/BadChannels +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArBadChannelsMissingFEBs-IOVDEP-04 for folder /LAR/BadChannels/MissingFEBs +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCAutoCorr-Apr2010 for folder /LAR/ElecCalibMC/AutoCorr +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LArCellPositionShift-ideal for folder /LAR/LArCellPositionShift +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCDAC2uA-CSC02-J for folder /LAR/ElecCalibMC/DAC2uA +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCHVScaleCorr-IOVDEP-00 for folder /LAR/ElecCalibMC/HVScaleCorr +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMinBias-IOVDEP-01 for folder /LAR/ElecCalibMC/MinBias +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMinBiasAverage-IOVDEP-01 for folder /LAR/ElecCalibMC/MinBiasAverage +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCMphysOverMcal-CSC02-I for folder /LAR/ElecCalibMC/MphysOverMcal +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCNoise-Apr2010 for folder /LAR/ElecCalibMC/Noise +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCPedestal-DC3-B-IdFix7 for folder /LAR/ElecCalibMC/Pedestal +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCRamp-CSC02-K for folder /LAR/ElecCalibMC/Ramp +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCShape-Apr2010 for folder /LAR/ElecCalibMC/Shape +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARIdentifierLArTTCellMapAtlas-HadFcalFix2 for folder /LAR/Identifier/LArTTCellMapAtlas +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARElecCalibMCfSampl-G496-19213-FTFP_BERT_BIRK for folder /LAR/ElecCalibMC/fSampl +IOVDbFolder INFO HVS tag OFLCOND-RUN12-SDR-35 resolved to LARuA2MeV-Feb2011 for folder /LAR/ElecCalibMC/uA2MeV IOVDbSvc INFO Disconnecting from COOLOFL_LAR/OFLP200 -DbSession INFO Open DbSession -Domain[ROOT_All] INFO > Access DbDomain READ [ROOT_All] Domain[ROOT_All] INFO -> Access DbDatabase READ [ROOT_All] EACFEBD4-9BD2-E211-848A-02163E006B20 Domain[ROOT_All] INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000057.gen.COND/cond09_mc.000057.gen.COND._0001.pool.root RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000057.gen.COND/cond09_mc.000057.gen.COND._0001.pool.root File version:52200 @@ -476,9 +474,13 @@ RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond08/cond Domain[ROOT_All] INFO -> Access DbDatabase READ [ROOT_All] D27D07D4-C135-E011-84A9-003048F0E01E Domain[ROOT_All] INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000027.gen.COND/cond09_mc.000027.gen.COND._0001.pool.root RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000027.gen.COND/cond09_mc.000027.gen.COND._0001.pool.root File version:52600 +/cvmfs/atlas-co... INFO Database being retired... +Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] EACFEBD4-9BD2-E211-848A-02163E006B20 Domain[ROOT_All] INFO -> Access DbDatabase READ [ROOT_All] 7C42BC12-BD96-E011-B8EC-003048F0E01C Domain[ROOT_All] INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000032.gen.COND/cond09_mc.000032.gen.COND._0001.pool.root RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000032.gen.COND/cond09_mc.000032.gen.COND._0001.pool.root File version:52600 +/cvmfs/atlas-co... INFO Database being retired... +Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A Domain[ROOT_All] INFO -> Access DbDatabase READ [ROOT_All] 303FCBD8-653E-DD11-ABBD-000423D99862 Domain[ROOT_All] INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/oflcond/oflcond.000003.conditions.simul.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0061.pool.root RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/oflcond/oflcond.000003.conditions.simul.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0061.pool.root File version:51800 @@ -584,17 +586,19 @@ Domain[ROOT_All] INFO /cvmfs/atlas-condb.cern.ch/r Warning in <TClass::Init>: no dictionary for class DataHeader_p1 is available Warning in <TClass::Init>: no dictionary for class DataHeaderElement_p1 is available RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cmccond/cmccond.000001.conditions.simul.pool.v0000/oflcond.000002.conditions.simul.pool.v0000._0053.pool.root__DQ2-1250193473 File version:51000 -RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/oflcond/oflcond.000003.conditions.simul.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0061.pool.root File version:51800 /cvmfs/atlas-co... INFO Database being retired... Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] FE8535CE-AD50-DC11-952F-000423D67862 -RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000009.gen.COND/cond09_mc.000009.gen.COND._0013.pool.root File version:52200 +RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/oflcond/oflcond.000003.conditions.simul.pool.v0000/oflcond.000003.conditions.simul.pool.v0000._0061.pool.root File version:51800 /cvmfs/atlas-co... INFO Database being retired... Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 3CE29BA7-A6DC-DC11-BF61-000423D65662 +RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000009.gen.COND/cond09_mc.000009.gen.COND._0013.pool.root File version:52200 +/cvmfs/atlas-co... INFO Database being retired... +Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 9229AE70-AC4C-DF11-A934-003048D2BC4A Domain[ROOT_All] INFO -> Access DbDatabase READ [ROOT_All] 445FAD9A-5DB3-E14A-81DB-BA6244602734 Domain[ROOT_All] INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000084.gen.COND/cond09_mc.000084.gen.COND._0001.pool.root RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000084.gen.COND/cond09_mc.000084.gen.COND._0001.pool.root File version:53413 /cvmfs/atlas-co... INFO Database being retired... -Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 9229AE70-AC4C-DF11-A934-003048D2BC4A +Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 180A4AF2-F47E-DB11-9E8F-000E0C4DEA2D RootDatabase.open INFO /cvmfs/atlas-condb.cern.ch/repo/conditions/cond09/cond09_mc.000027.gen.COND/cond09_mc.000027.gen.COND._0001.pool.root File version:52600 /cvmfs/atlas-co... INFO Database being retired... Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 303FCBD8-653E-DD11-ABBD-000423D99862 @@ -619,15 +623,8 @@ LArSymCondition... INFO recorded new LArMinBiasAverageSym with range {[0,l:0] LArSymCondition... INFO recorded new LArShapeSym with range {[0,l:0] - [INVALID]} into Conditions Store LArSymCondition... INFO recorded new LArMphysOverMcalSym with range {[0,l:0] - [INVALID]} into Conditions Store xAODMaker::Even...WARNING xAOD::EventInfo with key "EventInfo" is already in StoreGate; EventInfoCnvAlg should not be scheduled. -ClassIDSvc INFO getRegistryEntries: read 2254 CLIDRegistry entries for module ALL +ClassIDSvc INFO getRegistryEntries: read 1223 CLIDRegistry entries for module ALL AthenaEventLoopMgr INFO ===>>> done processing event #1, run #1 1 events processed so far <<<=== -/cvmfs/atlas-co... INFO Database being retired... -Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] EACFEBD4-9BD2-E211-848A-02163E006B20 -/cvmfs/atlas-co... INFO Database being retired... -Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 8667C6F2-1559-DE11-A611-000423D9A21A -/cvmfs/atlas-co... INFO Database being retired... -Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 180A4AF2-F47E-DB11-9E8F-000E0C4DEA2D -Domain[ROOT_All] INFO > Deaccess DbDomain READ [ROOT_All] AthenaEventLoopMgr INFO ===>>> start processing event #2, run #1 1 events processed so far <<<=== ClassIDSvc INFO getRegistryEntries: read 708 CLIDRegistry entries for module ALL AthenaEventLoopMgr INFO ===>>> done processing event #2, run #1 2 events processed so far <<<=== @@ -652,16 +649,19 @@ ToolSvc.tool5fcal WARNING windows not reimplemented yet AthenaEventLoopMgr INFO ===>>> done processing event #5, run #1 5 events processed so far <<<=== /cvmfs/atlas-co... INFO Database being retired... /cvmfs/atlas-co... INFO Database being retired... -Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] D27D07D4-C135-E011-84A9-003048F0E01E -/cvmfs/atlas-co... INFO Database being retired... /cvmfs/atlas-co... INFO Database being retired... /cvmfs/atlas-co... INFO Database being retired... /cvmfs/atlas-co... INFO Database being retired... /cvmfs/atlas-co... INFO Database being retired... Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] F4885664-6C4D-DF11-A94A-00304867340C /cvmfs/atlas-co... INFO Database being retired... -Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 445FAD9A-5DB3-E14A-81DB-BA6244602734 /cvmfs/atlas-co... INFO Database being retired... +Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] D27D07D4-C135-E011-84A9-003048F0E01E +/cvmfs/atlas-co... INFO Database being retired... +/cvmfs/atlas-co... INFO Database being retired... +/cvmfs/atlas-co... INFO Database being retired... +/cvmfs/atlas-co... INFO Database being retired... +Domain[ROOT_All] INFO -> Deaccess DbDatabase READ [ROOT_All] 445FAD9A-5DB3-E14A-81DB-BA6244602734 /cvmfs/atlas-co... INFO Database being retired... Domain[ROOT_All] INFO > Deaccess DbDomain READ [ROOT_All] ApplicationMgr INFO Application Manager Stopped successfully @@ -671,42 +671,42 @@ testalg1 INFO Finalizing testalg1... IncidentProcAlg2 INFO Finalize PyComponentMgr INFO Finalizing PyComponentMgr... IdDictDetDescrCnv INFO in finalize -IOVDbSvc INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 (( 0.24 ))s -IOVDbSvc INFO Folder /LAR/BadChannels/BadChannels (AttrListColl) db-read 1/1 objs/chan/bytes 0/8/0 (( 0.05 ))s -IOVDbSvc INFO Folder /LAR/BadChannels/MissingFEBs (AttrList) db-read 1/1 objs/chan/bytes 1/1/16 (( 0.05 ))s -IOVDbSvc INFO Folder /LAR/Identifier/CalibIdMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/1520148 (( 0.07 ))s -IOVDbSvc INFO Folder /LAR/Identifier/FebRodMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/6100 (( 0.19 ))s -IOVDbSvc INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/780292 (( 0.33 ))s -IOVDbSvc INFO Folder /CALO/Ofl/Identifier/CaloTTOnAttrIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 (( 0.00 ))s -IOVDbSvc INFO Folder /CALO/Ofl/Identifier/CaloTTOnOffIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 (( 0.00 ))s -IOVDbSvc INFO Folder /CALO/Ofl/Identifier/CaloTTPpmRxIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 (( 0.00 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/AutoCorr (PoolColl) db-read 1/2 objs/chan/bytes 3/3/486 (( 0.05 ))s -IOVDbSvc INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 (( 0.03 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/DAC2uA (PoolColl) db-read 1/2 objs/chan/bytes 1/1/170 (( 0.04 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/HVScaleCorr (PoolColl) db-read 1/2 objs/chan/bytes 12/12/1980 (( 0.18 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/MinBias (PoolColl) db-read 1/2 objs/chan/bytes 1/1/174 (( 0.08 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/MinBiasAverage (PoolColl) db-read 1/1 objs/chan/bytes 1/1/181 (( 0.04 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/MphysOverMcal (PoolColl) db-read 1/2 objs/chan/bytes 3/3/516 (( 0.04 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/Noise (PoolColl) db-read 1/2 objs/chan/bytes 3/3/516 (( 0.05 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/Pedestal (PoolRef) db-read 1/1 objs/chan/bytes 1/1/167 (( 0.04 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/Ramp (PoolColl) db-read 1/2 objs/chan/bytes 3/3/489 (( 0.05 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/Shape (PoolColl) db-read 1/2 objs/chan/bytes 3/3/477 (( 0.04 ))s -IOVDbSvc INFO Folder /LAR/Identifier/LArTTCellMapAtlas (PoolRef) db-read 1/0 objs/chan/bytes 1/1/173 (( 0.04 ))s -IOVDbSvc WARNING Folder /LAR/Identifier/LArTTCellMapAtlas is requested but no data retrieved -IOVDbSvc INFO Folder /LAR/ElecCalibMC/fSampl (PoolColl) db-read 1/2 objs/chan/bytes 1/1/194 (( 0.06 ))s -IOVDbSvc INFO Folder /LAR/ElecCalibMC/uA2MeV (PoolColl) db-read 1/2 objs/chan/bytes 1/1/165 (( 0.11 ))s -IOVDbSvc INFO Total payload read from COOL: 2312609 bytes in (( 1.78 ))s +IOVDbFolder INFO Folder /LAR/Align (PoolRef) db-read 1/1 objs/chan/bytes 1/1/170 (( 0.84 ))s +IOVDbFolder INFO Folder /LAR/BadChannels/BadChannels (AttrListColl) db-read 1/1 objs/chan/bytes 0/8/0 (( 0.99 ))s +IOVDbFolder INFO Folder /LAR/BadChannels/MissingFEBs (AttrList) db-read 1/1 objs/chan/bytes 1/1/16 (( 0.55 ))s +IOVDbFolder INFO Folder /LAR/Identifier/CalibIdMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/1520148 (( 0.52 ))s +IOVDbFolder INFO Folder /LAR/Identifier/FebRodMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/6100 (( 0.01 ))s +IOVDbFolder INFO Folder /LAR/Identifier/OnOffIdMap (AttrList) db-read 1/2 objs/chan/bytes 1/1/780292 (( 0.07 ))s +IOVDbFolder INFO Folder /CALO/Ofl/Identifier/CaloTTOnAttrIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 (( 0.00 ))s +IOVDbFolder INFO Folder /CALO/Ofl/Identifier/CaloTTOnOffIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 (( 0.00 ))s +IOVDbFolder INFO Folder /CALO/Ofl/Identifier/CaloTTPpmRxIdMapAtlas (PoolRef) db-read 0/0 objs/chan/bytes 0/1/0 (( 0.00 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/AutoCorr (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/486 (( 0.59 ))s +IOVDbFolder INFO Folder /LAR/LArCellPositionShift (PoolRef) db-read 1/1 objs/chan/bytes 1/1/195 (( 0.43 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/DAC2uA (PoolRefColl) db-read 1/2 objs/chan/bytes 1/1/170 (( 0.48 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/HVScaleCorr (PoolRefColl) db-read 1/2 objs/chan/bytes 12/12/1980 (( 0.49 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/MinBias (PoolRefColl) db-read 1/2 objs/chan/bytes 1/1/174 (( 0.49 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/MinBiasAverage (PoolRefColl) db-read 1/1 objs/chan/bytes 1/1/181 (( 0.50 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/MphysOverMcal (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/516 (( 0.41 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/Noise (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/516 (( 0.49 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/Pedestal (PoolRef) db-read 1/1 objs/chan/bytes 1/1/167 (( 2.22 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/Ramp (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/489 (( 0.49 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/Shape (PoolRefColl) db-read 1/2 objs/chan/bytes 3/3/477 (( 0.49 ))s +IOVDbFolder INFO Folder /LAR/Identifier/LArTTCellMapAtlas (PoolRef) db-read 1/0 objs/chan/bytes 1/1/173 (( 0.44 ))s +IOVDbFolder WARNING Folder /LAR/Identifier/LArTTCellMapAtlas is requested but no data retrieved +IOVDbFolder INFO Folder /LAR/ElecCalibMC/fSampl (PoolRefColl) db-read 1/2 objs/chan/bytes 1/1/194 (( 0.50 ))s +IOVDbFolder INFO Folder /LAR/ElecCalibMC/uA2MeV (PoolRefColl) db-read 1/2 objs/chan/bytes 1/1/165 (( 0.52 ))s +IOVDbSvc INFO bytes in (( 11.52 ))s IOVDbSvc INFO Connection sqlite://;schema=mycool.db;dbname=OFLP200 : nConnect: 0 nFolders: 0 ReadTime: (( 0.00 ))s -IOVDbSvc INFO Connection COOLOFL_LAR/OFLP200 : nConnect: 2 nFolders: 20 ReadTime: (( 1.78 ))s +IOVDbSvc INFO Connection COOLOFL_LAR/OFLP200 : nConnect: 2 nFolders: 20 ReadTime: (( 11.52 ))s IOVDbSvc INFO Connection COOLOFL_CALO/OFLP200 : nConnect: 1 nFolders: 3 ReadTime: (( 0.00 ))s AthDictLoaderSvc INFO in finalize... ToolSvc INFO Removing all tools created by ToolSvc *****Chrono***** INFO **************************************************************************************************** *****Chrono***** INFO The Final CPU consumption ( Chrono ) Table (ordered) *****Chrono***** INFO **************************************************************************************************** -cObjR_ALL INFO Time User : Tot= 1.12 [s] Ave/Min/Max=0.0172(+-0.077)/ 0/ 0.58 [s] #= 65 -cObj_ALL INFO Time User : Tot= 2.11 [s] Ave/Min/Max=0.0728(+-0.159)/ 0/ 0.68 [s] #= 29 -ChronoStatSvc INFO Time User : Tot= 101 [s] #= 1 +cObjR_ALL INFO Time User : Tot= 0.92 [s] Ave/Min/Max=0.0142(+-0.0755)/ 0/ 0.57 [s] #= 65 +cObj_ALL INFO Time User : Tot= 1.28 [s] Ave/Min/Max=0.0441(+-0.126)/ 0/ 0.62 [s] #= 29 +ChronoStatSvc INFO Time User : Tot= 52 [s] #= 1 *****Chrono***** INFO **************************************************************************************************** ChronoStatSvc.f... INFO Service finalized successfully ApplicationMgr INFO Application Manager Finalized successfully diff --git a/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.cxx b/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.cxx index 751ba1962a14331bc79fe374595c96373eb57af3..af1babc4fc48dac2246b0ca79dd8d7a261f0f8b0 100644 --- a/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.cxx +++ b/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.cxx @@ -34,7 +34,7 @@ StatusCode LArNoisyROAlg::initialize() { return StatusCode::SUCCESS; } -StatusCode LArNoisyROAlg::execute_r (const EventContext& ctx) const +StatusCode LArNoisyROAlg::execute (const EventContext& ctx) const { SG::ReadHandle<CaloCellContainer> cellContainer(m_CaloCellContainerName, ctx); if (!cellContainer.isValid()) { diff --git a/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.h b/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.h index 9ada3ebafcd6e3014e1647dd470d7d974d7d10f5..1f706dcdffa919ec7670471d19d9398f21fd3c84 100644 --- a/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.h +++ b/LArCalorimeter/LArCellRec/src/LArNoisyROAlg.h @@ -35,7 +35,7 @@ class LArNoisyROAlg : public AthReentrantAlgorithm LArNoisyROAlg(const std::string &name,ISvcLocator *pSvcLocator); virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; diff --git a/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.cxx b/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.cxx index 822c0f0568076b238eaa9d6f5ff3467029e2a2c8..d03908a402acd8c1977b96f79a2b50d0588560b3 100644 --- a/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.cxx +++ b/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.cxx @@ -45,7 +45,7 @@ StatusCode LArTimeVetoAlg::finalize() } //__________________________________________________________________________ -StatusCode LArTimeVetoAlg::execute_r( const EventContext& ctx ) const +StatusCode LArTimeVetoAlg::execute( const EventContext& ctx ) const { ATH_MSG_DEBUG("LArTimeVetoAlg execute()"); diff --git a/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.h b/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.h index e4e5478e324382fc3ae877f39e14acee61d79901..87a34c39a99ed3e9de19eeacb6ed58dfa625dea7 100644 --- a/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.h +++ b/LArCalorimeter/LArCellRec/src/LArTimeVetoAlg.h @@ -24,7 +24,7 @@ class LArTimeVetoAlg : public AthReentrantAlgorithm { ~LArTimeVetoAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; private: diff --git a/LArCalorimeter/LArClusterRec/LArClusterRec/LArDigitThinnerFromEMClust.h b/LArCalorimeter/LArClusterRec/LArClusterRec/LArDigitThinnerFromEMClust.h index aaf8ce4129d8fedf0eca5f807a75bfd96c36b592..31759dd1c341bde17cd202c0541794f8a36fd77f 100755 --- a/LArCalorimeter/LArClusterRec/LArClusterRec/LArDigitThinnerFromEMClust.h +++ b/LArCalorimeter/LArClusterRec/LArClusterRec/LArDigitThinnerFromEMClust.h @@ -43,7 +43,7 @@ class LArDigitThinnerFromEMClust : public AthReentrantAlgorithm ~LArDigitThinnerFromEMClust(); StatusCode initialize() override; - StatusCode execute_r(const EventContext& ctx) const override; + StatusCode execute(const EventContext& ctx) const override; StatusCode finalize() override; private: diff --git a/LArCalorimeter/LArClusterRec/src/LArDigitThinnerFromEMClust.cxx b/LArCalorimeter/LArClusterRec/src/LArDigitThinnerFromEMClust.cxx index 0f9a71a8ded823ac7117d449efa33543b30e62aa..0c7bf3cceadb55bdf43f84ba20fee87d3414a8f7 100755 --- a/LArCalorimeter/LArClusterRec/src/LArDigitThinnerFromEMClust.cxx +++ b/LArCalorimeter/LArClusterRec/src/LArDigitThinnerFromEMClust.cxx @@ -47,7 +47,7 @@ StatusCode LArDigitThinnerFromEMClust::finalize() { } -StatusCode LArDigitThinnerFromEMClust::execute_r(const EventContext& ctx) const { +StatusCode LArDigitThinnerFromEMClust::execute(const EventContext& ctx) const { //Get inputs from read handles: SG::ReadHandle<LArDigitContainer> inputContainer(m_inputContainerKey,ctx); diff --git a/LArCalorimeter/LArExample/LArConditionsCommon/share/LArMinimalSetup.py b/LArCalorimeter/LArExample/LArConditionsCommon/share/LArMinimalSetup.py index 1a07d2878d85230598ca91dd5c145226d32858c2..b3ef2adc4b3379251872657bfa9d3ee3e88a71ef 100644 --- a/LArCalorimeter/LArExample/LArConditionsCommon/share/LArMinimalSetup.py +++ b/LArCalorimeter/LArExample/LArConditionsCommon/share/LArMinimalSetup.py @@ -14,7 +14,7 @@ globalflags.InputFormat.set_Value_and_Lock('bytestream') globalflags.DatabaseInstance.set_Value_and_Lock('CONDBR2') from AthenaCommon.JobProperties import jobproperties -jobproperties.Global.DetDescrVersion = "ATLAS-GEO-20-00-00" +jobproperties.Global.DetDescrVersion = "ATLAS-R2-2016-01-00-01" from AthenaCommon.DetFlags import DetFlags DetFlags.Calo_setOff() #Switched off to avoid geometry diff --git a/LArCalorimeter/LArMonTools/python/LArMonFlags.py b/LArCalorimeter/LArMonTools/python/LArMonFlags.py index 9b6b81e31a5f6db8b5f7f972b2e875ba0cec3f64..aff95ffeb0c4a70a5dbc7131013b921c1046f2b2 100644 --- a/LArCalorimeter/LArMonTools/python/LArMonFlags.py +++ b/LArCalorimeter/LArMonTools/python/LArMonFlags.py @@ -136,6 +136,13 @@ class doLArRODMonTool(JobProperty): StoredValue=True list+=[doLArRODMonTool] +class doLArNoiseCorrelationMon(JobProperty): + """ Global switch for doLArNoiseCorrelationMon """ + statusOn=True + allowedTypes=['bool'] + StoredValue=True +list+=[doLArNoiseCorrelationMon] + ##----------------------------------------------------------------------------- ## 2nd step ## Definition of the LArMon flag container diff --git a/LArCalorimeter/LArMonTools/share/LArAllMonitoring_jobOptions.py b/LArCalorimeter/LArMonTools/share/LArAllMonitoring_jobOptions.py index 26b4057b64c8f8ad279a7f4536b253666dda2c5f..b00be98b100223e084c1a9903b8356b852618a57 100755 --- a/LArCalorimeter/LArMonTools/share/LArAllMonitoring_jobOptions.py +++ b/LArCalorimeter/LArMonTools/share/LArAllMonitoring_jobOptions.py @@ -51,6 +51,8 @@ else: if 'LArDigitKey' in dir() : LArMonFlags.LArDigitKey=LArDigitKey + + # This is the main block choosing what monitoring to run. # There is some repetition, but I think maintenance is easier (Rob). @@ -74,6 +76,8 @@ if jobproperties.Beam.beamType() == 'cosmics': include ("LArMonTools/LArCoverage_jobOptions.py") if LArMonFlags.doLArDigitMon(): include ("LArMonTools/LArDigitMon_jobOptions.py") + if LArMonFlags.doLArNoiseCorrelationMon(): + include ("LArMonTools/LArNoiseCorrelationMon_jobOptions.py") if LArMonFlags.doLArNoisyROMon(): include ("LArMonTools/LArNoisyROMon_jobOptions.py") if LArMonFlags.doLArRawChannelMon(): @@ -81,6 +85,7 @@ if jobproperties.Beam.beamType() == 'cosmics': if LArMonFlags.doLArCollisionTimeMon(): include("LArMonTools/LArCollisionTimeMonTool_jobOptions.py") + elif jobproperties.Beam.beamType() == 'singlebeam': if larESDMon and not athenaCommonFlags.isOnline(): if LArMonFlags.doLArAffectedRegions(): @@ -99,6 +104,8 @@ elif jobproperties.Beam.beamType() == 'singlebeam': include ("LArMonTools/LArCoverage_jobOptions.py") if LArMonFlags.doLArDigitMon(): include ("LArMonTools/LArDigitMon_jobOptions.py") + if LArMonFlags.doLArNoiseCorrelationMon(): + include ("LArMonTools/LArNoiseCorrelationMon_jobOptions.py") if LArMonFlags.doLArNoisyROMon(): include ("LArMonTools/LArNoisyROMon_jobOptions.py") if LArMonFlags.doLArRawChannelMon(): @@ -123,6 +130,8 @@ else: # should be jobproperties.Beam.beamType() =='collisions' include ("LArMonTools/LArCoverage_jobOptions.py") if LArMonFlags.doLArDigitMon(): include ("LArMonTools/LArDigitMon_jobOptions.py") + if LArMonFlags.doLArNoiseCorrelationMon(): + include ("LArMonTools/LArNoiseCorrelationMon_jobOptions.py") if LArMonFlags.doLArNoisyROMon(): include ("LArMonTools/LArNoisyROMon_jobOptions.py") if LArMonFlags.doLArRawChannelMon(): diff --git a/LArCalorimeter/LArMonTools/share/LArCalibRunMonitoringOffline.py b/LArCalorimeter/LArMonTools/share/LArCalibRunMonitoringOffline.py new file mode 100644 index 0000000000000000000000000000000000000000..a71d27273054ba4fb0e786e6514349795807b3ed --- /dev/null +++ b/LArCalorimeter/LArMonTools/share/LArCalibRunMonitoringOffline.py @@ -0,0 +1,34 @@ +# Calibration runs + +#### to be run like this (from run/ directory): +# athena.py -s -c 'RunNumber='$rn';InputDir="'$folderIn'";OutputDir="'$outDataFolder'";OutName="'$aname'_'$gain'";Gain="'$gain'";Partition="ALL";EvtNo='$evts';FEBSforStatTest=["endcapAft04slot02","barrelCft01slot03"]' ../build/x86_64-slc6-gcc62-opt/jobOptions/LArMonTools/LArCalibRunMonitoringOffline.py +# +# OutName - if you want to modify the output name +# Gain=HIGH/MEDIUM/LOW +# EvtNo set if you want to run on a limited number of events, do not set otherwise +# FEBSforStatTest tellse the coherent noise what to run on, if not set there's a default +### + +from AthenaCommon.ConcurrencyFlags import jobproperties as jps + +online = False + +# +# Common header to all LArMon jobs +# + +coherent_noise_febs = FEBSforStatTest #list of FEBs to be monitored, if empty, runs on them all +print coherent_noise_febs +#coherent_noise_PublishPartialSums = True #if true, publish the partial sums histograms, can be useful for debugging. False by default +coherent_noise_calibration_run = True + + +from LArMonTools.LArMonFlags import LArMonFlags +include("LArMonTools/LArMonJobOptionsOffline.py") # contains the setting up of athena for the monitoring + rootfile naming + LArBuilders +svcMgr.IOVDbSvc.GlobalTag="CONDBR2-ES1PA-2018-03" +# needed at P1 +#Service("PoolSvc").SortReplicas = False + +svcMgr.MessageSvc.OutputLevel = 4 #2 to set DEBUG mode, 4 to remove debug + + diff --git a/LArCalorimeter/LArMonTools/share/LArMonByteStream.py b/LArCalorimeter/LArMonTools/share/LArMonByteStream.py index 66d82f9fa851111a370479e76c8610f0d797b3f7..843471ffe9d54b4bcb2d15d7addb38cd69bdfb7a 100755 --- a/LArCalorimeter/LArMonTools/share/LArMonByteStream.py +++ b/LArCalorimeter/LArMonTools/share/LArMonByteStream.py @@ -4,14 +4,7 @@ # if not online: theByteStreamInputSvc = svcMgr.ByteStreamInputSvc - if not 'FullFileName' in dir(): - theByteStreamInputSvc.InputDirectory = [ InputDir ] - theByteStreamInputSvc.FilePrefix = [ FilePrefix ] - theByteStreamInputSvc.RunNumber = [ RunNumber ] - else: - for i in range(len(FullFileNameTab)): - theByteStreamInputSvc.NumFile += [ 10000 ] - theByteStreamInputSvc.FullFileName = FullFileNameTab + theByteStreamInputSvc.FullFileName = FullFileName theByteStreamInputSvc.MaxBadEvents=0 else: theApp.CreateSvc += ["ByteStreamCnvSvc"] diff --git a/LArCalorimeter/LArMonTools/share/LArMonCommonTrailer_jobOptions.py b/LArCalorimeter/LArMonTools/share/LArMonCommonTrailer_jobOptions.py index d3aad2014c7d76bf1eaa0c77b12b83cee022e52f..143b18a7b1754c76afe7e5d6b1af515a6cf3b3a8 100755 --- a/LArCalorimeter/LArMonTools/share/LArMonCommonTrailer_jobOptions.py +++ b/LArCalorimeter/LArMonTools/share/LArMonCommonTrailer_jobOptions.py @@ -4,7 +4,7 @@ if not online: if os.path.exists(RootHistOutputFileName): os.remove(RootHistOutputFileName) svcMgr += THistSvc() - svcMgr.THistSvc.Output = ["AllMon DATAFILE='"+RootHistOutputFileName+"' OPT='New'"] + svcMgr.THistSvc.Output = ["AllMon DATAFILE='"+RootHistOutputFileName+"' OPT='APPEND'"] if Type == 'Delay' and DelayNtuple: theApp.Dlls += [ "RootHistCnv" ] theApp.HistogramPersistency = "ROOT" diff --git a/LArCalorimeter/LArMonTools/share/LArMonTools.py b/LArCalorimeter/LArMonTools/share/LArMonTools.py index e84c8f140b49ab9adaa0379f74b320bf4bfa7f19..e1e08735b8ef6dd1b4874ba4011efaf948dfd34e 100755 --- a/LArCalorimeter/LArMonTools/share/LArMonTools.py +++ b/LArCalorimeter/LArMonTools/share/LArMonTools.py @@ -8,14 +8,14 @@ theLArBadChannelsMasker.ProblemsToMask=[ ] ToolSvc+=theLArBadChannelsMasker +include("LArConditionsCommon/LArConditionsCommon_comm_jobOptions.py") + include("LArMonTools/LArFEBMon_jobOptions.py") # Data integrity checks - Includes LArFEBMon tool and LArEventInfo if Type == 'Pedestal': - include("LArMonTools/LArDigitNoiseMonTool_jobOptions.py") # Monitoring of digits (noise, pedestal, correlation...) - include("LArMonTools/LArOddCellsMonTool_jobOptions.py") # Monitoring of digits compared with DB pedestal / noise -# include("LArMonTools/LArRawChannelNoiseMonTool_jobOptions.py") # Monitoring of raw channels (noise, pedestal, correlation...) -# include("LArMonTools/LArScaNoiseMonTool_jobOptions.py") # Monitoring of fixed pattern noise -# include("LArMonTools/LArFebNoiseMonTool_jobOptions.py") # Monitoring of noise shape (using FEB as a scope) -# include("LArMonTools/LArFebNoiseMonToolAlt_jobOptions.py") # Monitoring of noise shape (using FEB as a scope) + coherent_noise_calibration_run=True + include("LArMonTools/LArNoiseCorrelationMon_jobOptions.py") # Coherent noise plots + + elif Type == 'Delay': include("LArMonTools/LArDelayMon_jobOptions.py") # includes LArWaveMon tool and LArJitterMon # include("LArMonTools/LArXtalk_jobOptions.py") # includes LArWaveXtalk tool diff --git a/LArCalorimeter/LArMonTools/share/LArMonVariables.py b/LArCalorimeter/LArMonTools/share/LArMonVariables.py index edbad925f8ffe16e8eb3c496d1075afbb323291f..6f04ae10880fa9c50ca1929ddf52426ec1298efb 100755 --- a/LArCalorimeter/LArMonTools/share/LArMonVariables.py +++ b/LArCalorimeter/LArMonTools/share/LArMonVariables.py @@ -10,20 +10,36 @@ if 'SubDet' not in dir(): if 'InputDir' not in dir(): InputDir = "/castor/cern.ch/grid/atlas/DAQ/lar/ElecCalib/2009/00102562" +if 'FullFileName' in dir(): + if 'RunNumber' not in dir(): + RunNumber = int(FullFileName.strip().split('.')[1]) + + if 'Type' not in dir(): + Type = str(FullFileName.strip().split('.')[2].strip().split('-')[1]) + print Type + + if 'Partition' not in dir(): + Partition = str(FullFileName.strip().split('.')[6].split('-')[1]) + print Partition + + if not 'FullFileNameTab' in dir(): + FullFileNameTab = [ InputDir+"/"+FullFileName ] + + pass + if 'FullFileName' not in dir(): - FullFileName = "data09_calib.00102562.calibration_LArElec-Pedestal-7s-Low-HecFcal.daq.RAW._lb0000._EB-FCAL._0001.data" + include("LArCalibProcessing/GetInputFiles.py") + if 'FilePrefix' not in dir(): + FilePrefix="data18" + FullFileName =[] + FullFileName+=GetInputFilesFromTokens(InputDir,int(RunNumber),FilePrefix,".*") + if len(FullFileName) == 0: + print "No input files !!!" + sys.exit(-1) + word = FullFileName[0].split('-') + Type = word[1] -if 'RunNumber' not in dir(): - RunNumber = int(FullFileName.strip().split('.')[1]) -if 'Type' not in dir(): - Type = str(FullFileName.strip().split('.')[2].strip().split('-')[1]) - print Type - -if 'Partition' not in dir(): - Partition = str(FullFileName.strip().split('.')[6].split('-')[1]) - print Partition - if not 'online' in dir(): online = False @@ -45,8 +61,6 @@ if not 'LArDigitKey' in dir(): if not 'LArRawChannelKey' in dir(): LArRawChannelKey="LArRawChannels" -if not 'FullFileNameTab' in dir(): - FullFileNameTab = [ InputDir+"/"+FullFileName ] if not 'DelayNtuple' in dir(): DelayNtuple = False diff --git a/LArCalorimeter/LArMonTools/share/LArNoiseCorrelationMon_jobOptions.py b/LArCalorimeter/LArMonTools/share/LArNoiseCorrelationMon_jobOptions.py new file mode 100644 index 0000000000000000000000000000000000000000..265bb1e05f264c939b3da60629aaecaf18cbb4de --- /dev/null +++ b/LArCalorimeter/LArMonTools/share/LArNoiseCorrelationMon_jobOptions.py @@ -0,0 +1,57 @@ +#from LArCellRec.LArNoisyROFlags import larNoisyROFlags + +# --- for athena online running --- +if 'EventBlockSize' not in dir(): + EventBlockSize=0 + + +#Run is Online or Offline: +from AthenaCommon.AthenaCommonFlags import athenaCommonFlags +OnlineMode=athenaCommonFlags.isOnline() + + +#some FEBs to be monitored (updated 04 may 2018) +MiniNoiseBurstFlagging_FEBs = ["barrelAft09slot02","barrelAft09slot14","barrelAft10slot10","barrelAft10slot14","barrelAft31slot14","barrelCft08slot14","barrelCft22slot07","barrelCft27slot05","barrelCft27slot14"] +NewlyNoisy_FEBs = ["barrelCft02slot14","barrelCft01slot14","barrelCft07slot09","barrelCft07slot11","barrelCft06slot14"] +NoisyRegionsInOuterWheel_FEBs = ["endcapCft21slot04","endcapCft21slot02","endcapCft02slot04","endcapCft02slot02","endcapCft09slot02","endcapCft09slot03","endcapAft21slot04","endcapAft21slot02","endcapAft21slot03"] +NotNoisyRegionForComparison_FEBs = ["endcapAft02slot04"] +FEBs_from_DQ_run_350440 = ["endcapAft19slot12","endcapAft19slot09","endcapAft20slot09"] + +defaultFEBs=NotNoisyRegionForComparison_FEBs+NoisyRegionsInOuterWheel_FEBs+NewlyNoisy_FEBs+MiniNoiseBurstFlagging_FEBs+FEBs_from_DQ_run_350440 +if 'coherent_noise_febs' in dir(): + defaultFEBs=coherent_noise_febs + pass + +###### LArNoiseCorrelationMon Configuration ############### +from LArMonTools.LArMonToolsConf import LArNoiseCorrelationMon +theLArNoiseCorrelationMon = LArNoiseCorrelationMon(name="LArNoiseCorrelationMon", + LArDigitContainerKey = LArMonFlags.LArDigitKey(), + IsOnline = OnlineMode, + IgnoreBadChannels = True, + LArBadChannelMask = theLArBadChannelsMasker, + ProcessNEvents = EventBlockSize, + TriggerChain = "HLT_noalg_zb_L1ZB, HLT_noalg_cosmiccalo_L1RD1_EMPTY", + FEBsToMonitor = defaultFEBs, + IsCalibrationRun = False, + ) + + + + +if 'coherent_noise_calibration_run' in dir(): + if coherent_noise_calibration_run: + theLArNoiseCorrelationMon.IsCalibrationRun=True + theLArNoiseCorrelationMon.LArDigitContainerKey=Gain + theLArNoiseCorrelationMon.TriggerChain="" + theLArNoiseCorrelationMon.TrigDecisionTool="" + pass + pass + +if 'coherent_noise_PublishPartialSums' in dir(): + theLArNoiseCorrelationMon.PublishPartialSums = coherent_noise_PublishPartialSums + pass + +#ToolSvc += theLArNoiseCorrelationMon +LArMon.AthenaMonTools+=[ theLArNoiseCorrelationMon ] + + diff --git a/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.cxx b/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.cxx new file mode 100755 index 0000000000000000000000000000000000000000..0059ea6aba28974319bf61db7a40876ff321648f --- /dev/null +++ b/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.cxx @@ -0,0 +1,692 @@ +/* + Copyright (C) 2002-2019 CERN for the benefit of the ATLAS collaboration +*/ + + +// ******************************************************************** +// NAME: LArNoiseCorrelationMon.cxx +// PACKAGE: LArMonTools +// +// AUTHOR: Margherita Spalla (margherita.spalla@cern.ch) +// Based on structure of LArDigitMon by Helary Louis (helary@lapp.in2p3.fr) +// +// Computes and plots the correlation between single channels to monitor coherent noise. +// The correlation is computed as: +// corr(i,j) = Cov(i,j)/sqrt(Var(i)*Var(j)) where 'Cov(i,j)' is the sample covariance of channels i and j and 'Var(i)' is the sample variance of channel i. +// Variance and covariance are computed summing over all samples and all events for each channel: Cov(i,j)=[sum(x_i*x_j)-N*mean_i*mean_j]/(N-1) , where x_i is the single sample minus the pedestal. +// +// Correlation histograms are computed per FEB. The FEBs to be monitored are set in the JO. +// +// Available parameters in the jo file: +// 1) List of FEBs to be monitored: should be passed as a list of strings of the form 'BarrelCFT00Slot02', case insensitive (corresponding to type LARONLINEID defined in the package atlas/LArCalorimeter/LArMonTools/LArMonTools/LArOnlineIDStrHelper.h). If the list is empty, all FEBs are monitored. +// 2) control PublishAllFebsOnline: if it is set to true, switched off the monitoring in case the FEB list (1) is empty and the algorithm is running online. +// 3) list of triggers to be used ('TriggerChain'): to be passed as a single string "trigger_chain_1, trigger_chain_2". The default is "HLT_noalg_zb_L1ZB, HLT_noalg_cosmiccalo_L1RD1_EMPTY", for the latter, only events in the abort gap are used, selection done by hand. +// 4) control IsCalibrationRun: to be set to true when running on calibration, it switches off the trigger selection. +// 5) control PublishPartialSums: tells the algorithm to also publish the partial sum histograms. default is false. + +// +// ******************************************************************** + +//Histograms +#include "GaudiKernel/ITHistSvc.h" +#include "LWHists/TProfile_LW.h" +#include "LWHists/TH2F_LW.h" + +//STL: +#include <sstream> +#include <iomanip> +#include <cmath> +#include <vector> +#include <algorithm> + +//ROOT +#include "TPRegexp.h" +#include "TF1.h" + +//LAr infos: +#include "Identifier/HWIdentifier.h" +#include "LArOnlineIDStrHelper.h" +#include "LArIdentifier/LArOnlineID.h" +#include "LArRawEvent/LArDigit.h" +#include "LArRawEvent/LArDigitContainer.h" +#include "LArRecEvent/LArNoisyROSummary.h" +#include "TrigDecisionTool/TrigDecisionTool.h" + +//Events infos: +#include "xAODEventInfo/EventInfo.h" + +//for looping on FEBs +#include "LArRawEvent/LArFebHeaderContainer.h" + +//Header: +#include "LArNoiseCorrelationMon.h" + + +// BCIDs of the abort gap +const int ABORT_GAP_START = 3446; +const int ABORT_GAP_END = 3563; + + + + +/*---------------------------------------------------------*/ +LArNoiseCorrelationMon::LArNoiseCorrelationMon(const std::string& type, + const std::string& name, + const IInterface* parent) + : ManagedMonitorToolBase(type, name, parent), + m_strHelper(nullptr), + m_LArOnlineIDHelper(nullptr), + m_badChannelMask("BadLArRawChannelMask"), + m_LArCablingService("LArCablingService") +{ + /** FEBs to be monitored. If empty, all FEBs will be monitored*/ + std::vector<std::string> empty_vector(0); + declareProperty("FEBsToMonitor",m_FEBsToMonitor=empty_vector); + + /** If false, blocks the histogram booking in case it's running online and the 'm_FEBsToMonitor' list is empty. i.e. prevents the algorithm from publishing one histogram per FEB for all FEBs in online environnement */ + declareProperty("PublishAllFebsOnline",m_publishAllFebsOnline=true); + declareProperty("PublishPartialSums",m_publishPartialSums=false); + + /** To be set to true when running on calibration run. It swithces off trigger selection*/ + declareProperty("IsCalibrationRun",m_isCalibrationRun=false); + + /**bool use to mask the bad channels*/ + declareProperty("IgnoreBadChannels", m_ignoreKnownBadChannels=false); + declareProperty("LArBadChannelMask",m_badChannelMask); + declareProperty("LArDigitContainerKey", m_LArDigitContainerKey = "FREE"); + declareProperty("IsOnline", m_IsOnline=false); + + /**bool enable summary plot */ + declareProperty("DoSummary", m_DoSummary=true); +} + +/*---------------------------------------------------------*/ +LArNoiseCorrelationMon::~LArNoiseCorrelationMon() +{ +} + +StatusCode +LArNoiseCorrelationMon::finalize() +{ + ATH_MSG_INFO( "finalHists LArNoiseCorrelationMon" ); + + /** delete local histograms. */ + if(m_IsOnline) + { + for (auto const& feb_entry : m_FEBhistograms) + { + m_histos=feb_entry.second; + if(m_histos.second.first) + { + LWHist::safeDelete(m_histos.second.first); + m_histos.second.first=nullptr; + } + if(m_histos.second.second) + { + LWHist::safeDelete(m_histos.second.second); + m_histos.second.second=nullptr; + } + } + } + return StatusCode::SUCCESS; + +} + +/*---------------------------------------------------------*/ +StatusCode +LArNoiseCorrelationMon::initialize() +{ + + ATH_MSG_INFO( "Initialize LArNoiseCorrelationMon" ); + + m_evtCounter=0; + + /** Get LAr Online Id Helper*/ + ATH_CHECK(detStore()->retrieve( m_LArOnlineIDHelper, "LArOnlineID" )); + + + /** Get LAr Calbling Service*/ + ATH_CHECK(m_LArCablingService.retrieve()); + + + /** Get bad-channel mask (only if jO IgnoreBadChannels is true)*/ + if (m_ignoreKnownBadChannels) { + ATH_CHECK(m_badChannelMask.retrieve()); + } + + /** Retrieve pedestals container*/ + ATH_CHECK(m_keyPedestal.initialize()); + + /** get the trigger list from the 'm_triggerChainProp'*/ + m_triggers.clear(); + if(m_isCalibrationRun) { + ATH_MSG_INFO( "Running as 'calibration run'. No trigger selection will be applied."); + } + else { + ATH_MSG_DEBUG( "Parsing trigger chain list" ); + StatusCode sc=ManagedMonitorToolBase::parseList(m_triggerChainProp, m_triggers); + if(sc.isFailure()) { + ATH_MSG_ERROR( "Error parsing the trigger chain list, exiting." ); + return StatusCode::FAILURE; + } + } + + return ManagedMonitorToolBase::initialize(); +} + +/*---------------------------------------------------------*/ +StatusCode +LArNoiseCorrelationMon::bookHistograms() +{ + /** lar noise correlation */ + m_Nchan=128; + m_chan_low=-0.5; + m_chan_up=127.5; + + MonGroup GroupEMBA( this, "/LAr/NoiseCorrelation/EMBA", run, ATTRIB_MANAGED ); + MonGroup GroupEMBC( this, "/LAr/NoiseCorrelation/EMBC", run, ATTRIB_MANAGED ); + MonGroup GroupEMECA( this, "/LAr/NoiseCorrelation/EMECA", run, ATTRIB_MANAGED ); + MonGroup GroupEMECC( this, "/LAr/NoiseCorrelation/EMECC", run, ATTRIB_MANAGED ); + MonGroup GroupHECA( this, "/LAr/NoiseCorrelation/HECA", run, ATTRIB_MANAGED ); + MonGroup GroupHECC( this, "/LAr/NoiseCorrelation/HECC", run, ATTRIB_MANAGED ); + MonGroup GroupFCALA( this, "/LAr/NoiseCorrelation/FCALA", run, ATTRIB_MANAGED ); + MonGroup GroupFCALC( this, "/LAr/NoiseCorrelation/FCALC", run, ATTRIB_MANAGED ); + + /**declare strings for histograms title*/ + m_hist_name = "NoiseCorr_"; + m_hist_summary_name1 = "SummaryPlot_maximumCorr"; + m_hist_summary_name2 = "SummaryPlot_maximumCorr_sigma"; + m_hist_title = "LAr Noise Correlation"; + m_strHelper = new LArOnlineIDStrHelper(m_LArOnlineIDHelper); + m_strHelper->setDefaultNameType(LArOnlineIDStrHelper::LARONLINEID); + + /** Check which (if any) FEBs we want to monitor*/ + if(m_FEBsToMonitor.size()==0) { + if(!m_publishAllFebsOnline && m_IsOnline) { + ATH_MSG_INFO("'m_publishAllFebsOnline' set to false: cannot publish all FEBs in online run. Do nothing."); + return StatusCode::SUCCESS; + } + bookAllFEBs(GroupEMBA,GroupEMBC,GroupEMECA,GroupEMECC,GroupHECA,GroupHECC,GroupFCALA,GroupFCALC); + } + else bookSelectedFEBs(GroupEMBA,GroupEMBC,GroupEMECA,GroupEMECC,GroupHECA,GroupHECC,GroupFCALA,GroupFCALC); + + return StatusCode::SUCCESS; +} + + +/*---------------------------------------------------------*/ +StatusCode +LArNoiseCorrelationMon::fillHistograms() +{ + /** if publishing all FEBs has been forbidden and m_FEBsToMonitor is empty, then no histogram will be published anyway: no need to loop over channels */ + if(!m_publishAllFebsOnline && m_IsOnline && m_FEBsToMonitor.size()==0) { + ATH_MSG_DEBUG("'m_publishAllFebsOnline' set to false and empty FEB list in online run. No FEB will be monitored."); + return StatusCode::SUCCESS; + } + + ATH_MSG_DEBUG("in fillHists()" ); + + /**increase internal event counter, for calibration run only */ + m_evtCounter++; + + /** check trigger */ + bool passTrig = m_isCalibrationRun; + if(!m_isCalibrationRun) { + /**EventID is a part of EventInfo, search event informations:*/ + const xAOD::EventInfo* thisEvent; + ATH_CHECK(evtStore()->retrieve(thisEvent)); + + m_evtId = thisEvent->eventNumber(); + ATH_MSG_DEBUG("Event nb " << m_evtId ); + + bool passBCID; + if(!m_trigDecTool.empty()) { + for(auto trig_chain : m_triggers) { + passBCID = ((trig_chain == "HLT_noalg_cosmiccalo_L1RD1_EMPTY")?(thisEvent->bcid() >= ABORT_GAP_START && thisEvent->bcid() <= ABORT_GAP_END):true); + passTrig=(passTrig || (passBCID && m_trigDecTool->isPassed(trig_chain))); + } + } + } + + if (!passTrig) { + ATH_MSG_DEBUG ( " Failed trigger selection " ); + if(m_IsOnline && (endOfLumiBlockFlag() || endOfEventsBlockFlag())) fillInCorrelations(); //seems not to work offline, so done for online only + return StatusCode::SUCCESS; + } else { + ATH_MSG_DEBUG ( " Pass trigger selection " ); + } + + + /*retrieve pedestal*/ + SG::ReadCondHandle<ILArPedestal> pedestalHdl{m_keyPedestal}; + const ILArPedestal* pedestals=*pedestalHdl; + + /** retrieve LArDigitContainer*/ + const LArDigitContainer* pLArDigitContainer=nullptr; + ATH_CHECK(evtStore()->retrieve(pLArDigitContainer, m_LArDigitContainerKey)); + + + ATH_MSG_DEBUG ( " LArDigitContainer size "<<pLArDigitContainer->size()<<" for key "<<m_LArDigitContainerKey); + /** Define iterators to loop over Digits containers*/ + LArDigitContainer::const_iterator itDig = pLArDigitContainer->begin(); + LArDigitContainer::const_iterator itDig_2; + LArDigitContainer::const_iterator itDig_e= pLArDigitContainer->end(); + + /** Loop over digits*/ + for ( ; itDig!=itDig_e;++itDig) { + const LArDigit* pLArDigit = *itDig; + + /** Retrieve pedestals */ + HWIdentifier id = pLArDigit->hardwareID(); + CaloGain::CaloGain gain = pLArDigit->gain(); + float pedestal = pedestals->pedestal(id,gain); + + if(!isGoodChannel(id,pedestal)) + continue; + + /** Retrieve samples*/ + const std::vector<short>* digito = &pLArDigit->samples(); + + /** Retrieve once, all the cell info:*/ + m_febID = m_LArOnlineIDHelper->feb_Id(id); + m_ch1 = m_LArOnlineIDHelper->channel(id); + + try { + m_histos=m_FEBhistograms.at(m_febID); + } + catch (const std::out_of_range& oor) { + continue; + } + + /** Second loop over digit */ + bool av_set=false; + for(itDig_2 = itDig; itDig_2!=itDig_e;++itDig_2) + { + const LArDigit* pLArDigit2 = *itDig_2; + HWIdentifier id2 = pLArDigit2->hardwareID(); + if(m_LArOnlineIDHelper->feb_Id(id2)!=m_febID) continue; + + /** get the pedestal */ + CaloGain::CaloGain gain2 = pLArDigit2->gain(); + float pedestal2 = pedestals->pedestal(id2,gain2); + + if(!isGoodChannel(id2,pedestal2)) continue; + + /** get the channel number */ + m_ch2 = m_LArOnlineIDHelper->channel(id2); + + /** get the samples */ + const std::vector<short>* digito2 = &pLArDigit2->samples(); + std::vector<short>::const_iterator iterSam2= digito2->begin(); + std::vector<short>::const_iterator iterSam= digito->begin(); + + double part_sum=0; + int Nsam=pLArDigit->nsamples(); + if(pLArDigit2->nsamples()!=Nsam) + { + ATH_MSG_WARNING( Form("Different number of samples between channels %d vs %d: skipping these two",Nsam,pLArDigit2->nsamples()) ); + continue; + } + + /** Loop over the samples and compute average and sum of squares*/ + for(int i=0;i<Nsam;i++,iterSam++,iterSam2++) + { + if(!av_set) { /** fill the mean only once per ch1. This code is here to avoid one additional loop over samples before the second loop. */ + m_histos.second.second->Fill(m_ch1,(*iterSam-pedestal)); + } + /** now compute sum of squares */ + part_sum+=((*iterSam-pedestal)*(*iterSam2-pedestal2)); + } + av_set=true; /** now the average is set and I won't do this again in next ch2 loop*/ + m_histos.second.first->Fill(m_ch1,m_ch2,part_sum); + m_histos.second.first->Fill(m_ch2,m_ch1,part_sum); + }/** End of second loop on LArDigit*/ + }/** End of loop on LArDigit*/ + + + /** compute correlation and update the published plot once per LB (seems not to work offline, so done for online only)*/ + if(m_IsOnline && (endOfLumiBlockFlag() || endOfEventsBlockFlag())) fillInCorrelations(); + + return StatusCode::SUCCESS; +} + +/*---------------------------------------------------------*/ +StatusCode LArNoiseCorrelationMon::procHistograms() +{ + if(endOfRunFlag()) + { + fillInCorrelations(); + if(m_IsOnline) + { + for (auto const& feb_entry : m_FEBhistograms) + { + m_histos=feb_entry.second; + if(m_histos.second.first) m_histos.second.first->Reset(); + if(m_histos.second.second) m_histos.second.second->Reset(); + } + } + } + return StatusCode::SUCCESS; +} + + +/*---------------------------------------------------------*/ +/** check if channel is ok for monitoring */ + bool LArNoiseCorrelationMon::isGoodChannel(const HWIdentifier ID,const float ped) const + { + /** Remove problematic channels*/ + if (m_ignoreKnownBadChannels && m_badChannelMask->cellShouldBeMasked(ID)) + return false; + + /**skip cells with no pedestals reference in db.*/ + if(ped <= (1.0+LArElecCalib::ERRORCODE)) + return false; + + /**skip disconnected channels:*/ + if(!m_LArCablingService->isOnlineConnected(ID)) + return false; + + return true; + } + + +/*---------------------------------------------------------*/ +/**Compute correlations and fill in the plots*/ +void LArNoiseCorrelationMon::fillInCorrelations() +{ + double mean1,mean2; + double sumVar1,sumVar2; + double N; + double cor; + for (auto const& feb_entry : m_FEBhistograms) + { + double tmp_maxcorr = 0.0; + TH1F *hist_tmp_correlation; + hist_tmp_correlation = new TH1F("Tmp_correlation_value", "TMP correlation value", 40, -1.0, 1.0 ); + double tmp_RMS = 0.0; + m_histos=feb_entry.second; + for(int i=1;i<=m_Nchan;i++) + { + mean1=m_histos.second.second->GetBinContent(i); + sumVar1=m_histos.second.first->GetBinContent(i,i); + N=m_histos.second.second->GetBinEntries(i); + if(N==0) + { + ATH_MSG_DEBUG( "Bin " << i << " has 0 entries" ); + continue; + } + for(int j=i+1;j<=m_Nchan;j++) + { + mean2=m_histos.second.second->GetBinContent(j); + sumVar2=m_histos.second.first->GetBinContent(j,j); + if((sumVar1-N*mean1*mean1)*(sumVar2-N*mean2*mean2)==0) { + ATH_MSG_DEBUG( "sigma_i*sigma_j is zero for bin (" << i << "," << j << "). Correlation cannot be computed." ); + continue; + } + cor=(m_histos.second.first->GetBinContent(i,j)-N*mean1*mean2)/TMath::Sqrt((sumVar1-N*mean1*mean1)*(sumVar2-N*mean2*mean2)); + m_histos.first->SetBinContent(i,j,cor); + m_histos.first->SetBinContent(j,i,cor); + /** calculate maximum correlation */ + /** First variable: maximum correlation in the FEB */ + if ( tmp_maxcorr < std::abs(cor) ) + tmp_maxcorr = std::abs(cor); + /** Second valiable: RMS value in correlation distribution */ + hist_tmp_correlation->Fill(cor); + } + } + + tmp_RMS = hist_tmp_correlation->GetRMS(); + + // Fill in summary histogram + TPMERegexp tmp('_'); + int nsplit = tmp.Split( m_histos.first->GetTitle() ); + if(m_DoSummary){ + if(nsplit > 1){ + // EMB + if(m_LArOnlineIDHelper->isEMBchannel( feb_entry.first )){ + if(m_LArOnlineIDHelper->pos_neg(feb_entry.first) ){ + m_h_summary_plot1_EMBA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr); + m_h_summary_plot2_EMBA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS); + } + else{ + m_h_summary_plot1_EMBC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr); + m_h_summary_plot2_EMBC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS); + } + } + // EMEC + else if(m_LArOnlineIDHelper->isEMECchannel( feb_entry.first )){ + if(m_LArOnlineIDHelper->pos_neg(feb_entry.first)){ + m_h_summary_plot1_EMECA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr); + m_h_summary_plot2_EMECA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS); + } + else{ + m_h_summary_plot1_EMECC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr); + m_h_summary_plot2_EMECC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS); + } + } + // HEC + else if(m_LArOnlineIDHelper->isHECchannel( feb_entry.first )){ + if(m_LArOnlineIDHelper->pos_neg(feb_entry.first)){ + m_h_summary_plot1_HECA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr ); + m_h_summary_plot2_HECA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS ); + } + else{ + m_h_summary_plot1_HECC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr ); + m_h_summary_plot2_HECC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS ); + } + } + // FCAL + else if(m_LArOnlineIDHelper->isFCALchannel( feb_entry.first )){ + if(m_LArOnlineIDHelper->pos_neg(feb_entry.first)){ + m_h_summary_plot1_FCALA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr ); + m_h_summary_plot2_FCALA->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS ); + } + else{ + m_h_summary_plot1_FCALC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_maxcorr ); + m_h_summary_plot2_FCALC->SetBinContent( atoi(tmp[0])+1, atoi(tmp[1])+1, tmp_RMS ); + } + } + } + } + // Delete them in order to save the memory + delete hist_tmp_correlation; + + } +} + + + + + +/*---------------------------------------------------------*/ +/**Loops on selected FEBS to book and define histograms.*/ +void LArNoiseCorrelationMon::bookSelectedFEBs(MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC) +{ + ATH_MSG_INFO( "Booking selected FEBs: " << m_FEBsToMonitor.size() << " provided." ); + std::string aFEB; /**aFEB is the feb to monitor*/ + HWIdentifier febid; + for(uint feb_i=0;feb_i<m_FEBsToMonitor.size();feb_i++) { + aFEB=m_FEBsToMonitor[feb_i]; + febid=m_strHelper->feb_id(aFEB); + if(!febid.is_valid()) { + ATH_MSG_WARNING( "FEB id " << aFEB << " not valid. It will not be monitored." ); + continue; + } + bookThisFEB(febid,grEMBA,grEMBC,grEMECA,grEMECC,grHECA,grHECC,grFCALA,grFCALC); + } + // summary plot + if(m_DoSummary){ + m_h_summary_plot1_EMBA = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMBA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_EMBC = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMBC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_EMECA = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMECA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_EMECC = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMECC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_HECA = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot HECA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_HECC = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot HECC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_FCALA = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot FCALA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_FCALC = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot FCALC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_EMBA = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMBA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_EMBC = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMBC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_EMECA = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMECA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_EMECC = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMECC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_HECA = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot HECA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_HECC = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot HECC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_FCALA = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot FCALA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_FCALC = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot FCALC" ,16, 0, 16, 34, 0, 34); + grEMBA.regHist(m_h_summary_plot1_EMBA).ignore(); + grEMBC.regHist(m_h_summary_plot1_EMBC).ignore(); + grEMECA.regHist(m_h_summary_plot1_EMECA).ignore(); + grEMECC.regHist(m_h_summary_plot1_EMECC).ignore(); + grHECA.regHist(m_h_summary_plot1_HECA).ignore(); + grHECC.regHist(m_h_summary_plot1_HECC).ignore(); + grFCALA.regHist(m_h_summary_plot1_FCALA).ignore(); + grFCALC.regHist(m_h_summary_plot1_FCALC).ignore(); + grEMBA.regHist(m_h_summary_plot2_EMBA).ignore(); + grEMBC.regHist(m_h_summary_plot2_EMBC).ignore(); + grEMECA.regHist(m_h_summary_plot2_EMECA).ignore(); + grEMECC.regHist(m_h_summary_plot2_EMECC).ignore(); + grHECA.regHist(m_h_summary_plot2_HECA).ignore(); + grHECC.regHist(m_h_summary_plot2_HECC).ignore(); + grFCALA.regHist(m_h_summary_plot2_FCALA).ignore(); + grFCALC.regHist(m_h_summary_plot2_FCALC).ignore(); + } +} + + +/*---------------------------------------------------------*/ +/**Loops on all FEBS to book and define histograms.*/ +void LArNoiseCorrelationMon::bookAllFEBs(MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC) +{ + ATH_MSG_INFO( "No selected FEBs provided: booking all FEBs."); + + /** loop on FEBs to init histograms */ + std::vector<HWIdentifier>::const_iterator feb_it = m_LArOnlineIDHelper->feb_begin(); + std::vector<HWIdentifier>::const_iterator feb_it_e = m_LArOnlineIDHelper->feb_end(); + for ( ; feb_it!=feb_it_e;++feb_it) { + bookThisFEB((*feb_it),grEMBA,grEMBC,grEMECA,grEMECC,grHECA,grHECC,grFCALA,grFCALC); + } + // summary plot + if(m_DoSummary){ + m_h_summary_plot1_EMBA = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMBA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_EMBC = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMBC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_EMECA = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMECA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_EMECC = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot EMECC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_HECA = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot HECA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_HECC = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot HECC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_FCALA = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot FCALA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot1_FCALC = TH2F_LW::create(m_hist_summary_name1.c_str(), "Summary1 plot FCALC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_EMBA = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMBA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_EMBC = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMBC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_EMECA = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMECA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_EMECC = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot EMECC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_HECA = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot HECA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_HECC = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot HECC" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_FCALA = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot FCALA" ,16, 0, 16, 34, 0, 34); + m_h_summary_plot2_FCALC = TH2F_LW::create(m_hist_summary_name2.c_str(), "Summary2 plot FCALC" ,16, 0, 16, 34, 0, 34); + + grEMBA.regHist(m_h_summary_plot1_EMBA).ignore(); + grEMBC.regHist(m_h_summary_plot1_EMBC).ignore(); + grEMECA.regHist(m_h_summary_plot1_EMECA).ignore(); + grEMECC.regHist(m_h_summary_plot1_EMECC).ignore(); + grHECA.regHist(m_h_summary_plot1_HECA).ignore(); + grHECC.regHist(m_h_summary_plot1_HECC).ignore(); + grFCALA.regHist(m_h_summary_plot1_FCALA).ignore(); + grFCALC.regHist(m_h_summary_plot1_FCALC).ignore(); + + grEMBA.regHist(m_h_summary_plot2_EMBA).ignore(); + grEMBC.regHist(m_h_summary_plot2_EMBC).ignore(); + grEMECA.regHist(m_h_summary_plot2_EMECA).ignore(); + grEMECC.regHist(m_h_summary_plot2_EMECC).ignore(); + grHECA.regHist(m_h_summary_plot2_HECA).ignore(); + grHECC.regHist(m_h_summary_plot2_HECC).ignore(); + grFCALA.regHist(m_h_summary_plot2_FCALA).ignore(); + grFCALC.regHist(m_h_summary_plot2_FCALC).ignore(); + + } +} + +/*---------------------------------------------------------*/ +/**Book and defines histogramms for a given FEB.*/ +void LArNoiseCorrelationMon::bookThisFEB(HWIdentifier id,MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC) +{ + std::string this_name=m_strHelper->feb_str(id); + int num_slot = m_LArOnlineIDHelper->slot(id); + int num_feedthrough = m_LArOnlineIDHelper->feedthrough(id); + std::string slot_feed_title = std::to_string(num_slot) + "_" + std::to_string(num_feedthrough); + + TH2F_LW* h_corr = TH2F_LW::create((m_hist_name+this_name).c_str(), slot_feed_title.c_str(), m_Nchan,m_chan_low,m_chan_up,m_Nchan,m_chan_low,m_chan_up); + TH2F_LW* h_TMP_sums = TH2F_LW::create((m_hist_name+this_name+"_TMP_sum").c_str(),(m_hist_title+" TMP sum").c_str(),m_Nchan,m_chan_low,m_chan_up,m_Nchan,m_chan_low,m_chan_up); + TProfile_LW* h_av = TProfile_LW::create((m_hist_name+this_name+"_TMP_av").c_str(),(m_hist_title+" TMP av").c_str(),m_Nchan,m_chan_low,m_chan_up,"s"); + m_FEBhistograms[id]=std::make_pair(h_corr,std::make_pair(h_TMP_sums,h_av)); + + if(m_LArOnlineIDHelper->isEMBchannel(id)) { + if(m_LArOnlineIDHelper->pos_neg(id)==1) { + grEMBA.regHist(h_corr).ignore(); + if(m_publishPartialSums && !m_IsOnline) { + grEMBA.regHist(h_av).ignore(); + grEMBA.regHist(h_TMP_sums).ignore(); + } + } + else { + grEMBC.regHist(h_corr).ignore(); + if(m_publishPartialSums && !m_IsOnline) { + grEMBC.regHist(h_av).ignore(); + grEMBC.regHist(h_TMP_sums).ignore(); + } + } + } + else + if(m_LArOnlineIDHelper->isEMECchannel(id)) { + if(m_LArOnlineIDHelper->pos_neg(id)==1) { + grEMECA.regHist(h_corr).ignore(); + if(m_publishPartialSums && !m_IsOnline) { + grEMECA.regHist(h_av).ignore(); + grEMECA.regHist(h_TMP_sums).ignore(); + } + } + else { + grEMECC.regHist(h_corr).ignore(); + if(m_publishPartialSums && !m_IsOnline) { + grEMECC.regHist(h_av).ignore(); + grEMECC.regHist(h_TMP_sums).ignore(); + } + } + } + else + if(m_LArOnlineIDHelper->isHECchannel(id)) { + if(m_LArOnlineIDHelper->pos_neg(id)==1) { + grHECA.regHist(h_corr).ignore(); + if(m_publishPartialSums && !m_IsOnline) { + grHECA.regHist(h_av).ignore(); + grHECA.regHist(h_TMP_sums).ignore(); + } + } + else { + grHECC.regHist(h_corr).ignore(); + if(m_publishPartialSums && !m_IsOnline) { + grHECC.regHist(h_av).ignore(); + grHECC.regHist(h_TMP_sums).ignore(); + } + } + } + else + if(m_LArOnlineIDHelper->isFCALchannel(id)) { + if(m_LArOnlineIDHelper->pos_neg(id)==1) { + grFCALA.regHist(h_corr).ignore(); + if(m_publishPartialSums && !m_IsOnline) { + grFCALA.regHist(h_av).ignore(); + grFCALA.regHist(h_TMP_sums).ignore(); + } + } + else { + grFCALC.regHist(h_corr).ignore(); + if(m_publishPartialSums && !m_IsOnline) { + grFCALC.regHist(h_av).ignore(); + grFCALC.regHist(h_TMP_sums).ignore(); + } + } + } +} + + + + diff --git a/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.h b/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.h new file mode 100755 index 0000000000000000000000000000000000000000..df0befd0f313ba9d1d14b5e4400b38c6fe90fe5d --- /dev/null +++ b/LArCalorimeter/LArMonTools/src/LArNoiseCorrelationMon.h @@ -0,0 +1,144 @@ +/* + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration +*/ + +/** + * @class LArNoiseCorrelationMon + * @author Margherita Spalla + * + */ + +#ifndef LARCORRMON_H +#define LARCORRMON_H + +//inheritance: +#include "AthenaMonitoring/ManagedMonitorToolBase.h" + + +//LAr services: +#include "LArElecCalib/ILArPedestal.h" +#include "LArRecConditions/ILArBadChannelMasker.h" +#include "LArCabling/LArCablingService.h" + + +//STL: +#include <string> + + + +class LArOnlineID; +class HWIdentifier; +class LArOnlineIDStrHelper; +class TProfile2D_LW; +class TProfile_LW; +class TH2F_LW; + +class LArNoiseCorrelationMon: public ManagedMonitorToolBase +{ + + +public: + LArNoiseCorrelationMon(const std::string& type, + const std::string& name, + const IInterface* parent); + + /** @brief Default destructor */ + virtual ~LArNoiseCorrelationMon(); + + + + virtual StatusCode initialize() override; + virtual StatusCode finalize() override; + virtual StatusCode bookHistograms() override; + virtual StatusCode fillHistograms() override; + virtual StatusCode procHistograms() override; + +protected: + + + /** services */ + LArOnlineIDStrHelper* m_strHelper; + const LArOnlineID* m_LArOnlineIDHelper; + + /** Handle to bad-channel mask */ + ToolHandle<ILArBadChannelMasker> m_badChannelMask; + + /** Handle to LArCablingService */ + ToolHandle<LArCablingService> m_LArCablingService; + + + /** Handle to pedestal */ + SG::ReadCondHandleKey<ILArPedestal> m_keyPedestal{this,"LArPedestalKey","LArPedestal","SG key of LArPedestal CDO"}; + +private: + + /**correlation histograms*/ + int m_Nchan; + double m_chan_low,m_chan_up; + std::string m_hist_name; + std::string m_hist_summary_name1; + std::string m_hist_summary_name2; + std::string m_hist_title; + + /** The FEB map*/ + std::map<HWIdentifier,std::pair<TH2F_LW*,std::pair<TH2F_LW*,TProfile_LW*> > > m_FEBhistograms; + std::pair<TH2F_LW*,std::pair<TH2F_LW*,TProfile_LW*> > m_histos; //for handling histograms + + /** Summary plot*/ + TH2F_LW * m_h_summary_plot1_EMBA; + TH2F_LW * m_h_summary_plot1_EMBC; + TH2F_LW * m_h_summary_plot1_EMECA; + TH2F_LW * m_h_summary_plot1_EMECC; + TH2F_LW * m_h_summary_plot1_HECA; + TH2F_LW * m_h_summary_plot1_HECC; + TH2F_LW * m_h_summary_plot1_FCALA; + TH2F_LW * m_h_summary_plot1_FCALC; + + TH2F_LW * m_h_summary_plot2_EMBA; + TH2F_LW * m_h_summary_plot2_EMBC; + TH2F_LW * m_h_summary_plot2_EMECA; + TH2F_LW * m_h_summary_plot2_EMECC; + TH2F_LW * m_h_summary_plot2_HECA; + TH2F_LW * m_h_summary_plot2_HECC; + TH2F_LW * m_h_summary_plot2_FCALA; + TH2F_LW * m_h_summary_plot2_FCALC; + + + /** list of FEBs to monitor. FEB names are expected to be of the type LARONLINEID defined in the package atlas/LArCalorimeter/LArMonTools/LArMonTools/LArOnlineIDStrHelper.h e.g. 'BarrelCFT00Slot02' */ + std::vector<std::string> m_FEBsToMonitor; + + /** to publish partial sums (offline only) if needed*/ + bool m_publishPartialSums; + + /** to avoid publishing tons of histograms online, in case it's a problem*/ + bool m_publishAllFebsOnline; + + /** to avoid asking for triggers in case of a calibration run*/ + bool m_isCalibrationRun; + + /**declare identifier*/ + HWIdentifier m_febID; + int m_ch1,m_ch2; + + /**other variables used in joboptions*/ + bool m_IsOnline; + bool m_ignoreKnownBadChannels; + bool m_DoSummary; + + std::string m_LArDigitContainerKey; + + /** Private members*/ + int m_evtId; + std::vector<std::string> m_triggers; + int m_evtCounter; + + /** Declare methods used*/ + bool isGoodChannel(const HWIdentifier id,const float ped) const; + void fillInCorrelations(); + void bookSelectedFEBs(MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC); + void bookAllFEBs(MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC); + void bookThisFEB(HWIdentifier id,MonGroup& grEMBA,MonGroup& grEMBC,MonGroup& grEMECA,MonGroup& grEMECC,MonGroup& grHECA,MonGroup& grHECC,MonGroup& grFCALA,MonGroup& grFCALC); + +}; + +#endif diff --git a/LArCalorimeter/LArMonTools/src/components/LArMonTools_entries.cxx b/LArCalorimeter/LArMonTools/src/components/LArMonTools_entries.cxx index 63b710decd52a56b67f076230f8c23d28148c017..8f9afe207c760b37692d11097b825c287871ede6 100644 --- a/LArCalorimeter/LArMonTools/src/components/LArMonTools_entries.cxx +++ b/LArCalorimeter/LArMonTools/src/components/LArMonTools_entries.cxx @@ -8,6 +8,7 @@ #include "../LArAffectedRegions.h" #include "../LArHVCorrectionMonTool.h" #include "../LArNoisyROMon.h" +#include "../LArNoiseCorrelationMon.h" DECLARE_COMPONENT( LArFEBMon ) @@ -20,4 +21,5 @@ DECLARE_COMPONENT( LArRODMonTool ) DECLARE_COMPONENT( LArAffectedRegions ) DECLARE_COMPONENT( LArHVCorrectionMonTool ) DECLARE_COMPONENT( LArNoisyROMon ) +DECLARE_COMPONENT( LArNoiseCorrelationMon ) diff --git a/LArCalorimeter/LArROD/LArROD/LArDigitThinner.h b/LArCalorimeter/LArROD/LArROD/LArDigitThinner.h index 069d42705444edc197f3b66c909cda20f371ddbc..e8b4b4081cc787e6bd8095af25f708088865d00c 100755 --- a/LArCalorimeter/LArROD/LArROD/LArDigitThinner.h +++ b/LArCalorimeter/LArROD/LArROD/LArDigitThinner.h @@ -43,7 +43,7 @@ class LArDigitThinner : public AthReentrantAlgorithm ~LArDigitThinner(); StatusCode initialize() override; - StatusCode execute_r(const EventContext& ctx) const override; + StatusCode execute(const EventContext& ctx) const override; StatusCode finalize() override; private: diff --git a/LArCalorimeter/LArROD/LArROD/LArRawChannelBuilderAlg.h b/LArCalorimeter/LArROD/LArROD/LArRawChannelBuilderAlg.h index cc4921c3d9d6d675aa9d0c985d79e46abdd95c80..f393c21811a28243d2c75a829b83a5ffac2a5a9f 100644 --- a/LArCalorimeter/LArROD/LArROD/LArRawChannelBuilderAlg.h +++ b/LArCalorimeter/LArROD/LArROD/LArRawChannelBuilderAlg.h @@ -30,7 +30,7 @@ class LArRawChannelBuilderAlg : public AthReentrantAlgorithm { LArRawChannelBuilderAlg(const std::string& name, ISvcLocator* pSvcLocator); StatusCode initialize() override; - StatusCode execute_r(const EventContext& ctx) const override; + StatusCode execute(const EventContext& ctx) const override; StatusCode finalize() override; diff --git a/LArCalorimeter/LArROD/src/LArDigitThinner.cxx b/LArCalorimeter/LArROD/src/LArDigitThinner.cxx index 578b6eb4aad197a3fa3787f0a796133b27bbb2cb..48f23506b33132bcf7f47c0e6d8295596f4bcb59 100755 --- a/LArCalorimeter/LArROD/src/LArDigitThinner.cxx +++ b/LArCalorimeter/LArROD/src/LArDigitThinner.cxx @@ -136,7 +136,7 @@ StatusCode LArDigitThinner::finalize() } -StatusCode LArDigitThinner::execute_r(const EventContext& ctx) const { +StatusCode LArDigitThinner::execute(const EventContext& ctx) const { initCutValues(ctx); //Should return right away if the cut values are already initialized diff --git a/LArCalorimeter/LArROD/src/LArRawChannelBuilderAlg.cxx b/LArCalorimeter/LArROD/src/LArRawChannelBuilderAlg.cxx index fe5bf88b8e83cc027a8669ae8b885403a68bcdc3..06a86f4a7eebeb9bdd187376638db4543b278234 100644 --- a/LArCalorimeter/LArROD/src/LArRawChannelBuilderAlg.cxx +++ b/LArCalorimeter/LArROD/src/LArRawChannelBuilderAlg.cxx @@ -30,7 +30,7 @@ StatusCode LArRawChannelBuilderAlg::finalize() { return StatusCode::SUCCESS; } -StatusCode LArRawChannelBuilderAlg::execute_r(const EventContext& ctx) const { +StatusCode LArRawChannelBuilderAlg::execute(const EventContext& ctx) const { //Get event inputs from read handles: SG::ReadHandle<LArDigitContainer> inputContainer(m_digitKey,ctx); diff --git a/LArCalorimeter/LArRawEvent/LArRawEvent/LArOFIterResults.h b/LArCalorimeter/LArRawEvent/LArRawEvent/LArOFIterResults.h index 66bf8a6d80742b92799f43183e6eabc5a1d18eb9..b4d22ef8bf56ba692227ec9f89e1e3a9e320f74a 100644 --- a/LArCalorimeter/LArRawEvent/LArRawEvent/LArOFIterResults.h +++ b/LArCalorimeter/LArRawEvent/LArRawEvent/LArOFIterResults.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ //Dear emacs, this is -*-c++-*- @@ -34,7 +34,7 @@ class LArOFIterResults { ); // Destructor - virtual ~LArOFIterResults() {}; + ~LArOFIterResults() = default; // Return Functions given below inline HWIdentifier getChannelID() const; diff --git a/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.cxx b/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.cxx index 646e08e20c7c4903f1d7cdea3e0df3a6f5ec290d..56284850ad2ed0465d156d7ab188e647de8c7566 100755 --- a/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.cxx +++ b/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.cxx @@ -127,7 +127,7 @@ StatusCode LArHVCondAlg::initialize(){ } -StatusCode LArHVCondAlg::execute_r(const EventContext& ctx) const { +StatusCode LArHVCondAlg::execute(const EventContext& ctx) const { ATH_MSG_DEBUG("executing"); bool doHVData=false; diff --git a/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.h b/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.h index b715569aa23a2e498668697666303d7ad6b65c52..b69427da2f8386b3d278b4c1a96c1d3aaeb7eb0b 100755 --- a/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.h +++ b/LArCalorimeter/LArRecUtils/src/LArHVCondAlg.h @@ -55,7 +55,7 @@ class LArHVCondAlg: public AthReentrantAlgorithm virtual StatusCode initialize() override; virtual StatusCode finalize() override; - StatusCode execute_r(const EventContext& ctx) const override; + StatusCode execute(const EventContext& ctx) const override; private: diff --git a/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.cxx b/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.cxx index 4312ee307aa59877751bbc559f517e19196a03da..6c20c20337a8b89f3bc012e163b2671f3fdf9a2c 100755 --- a/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.cxx +++ b/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.cxx @@ -109,7 +109,7 @@ AthenaAttributeList* LArHVPathologyDbCondAlg::hvPathology2AttrList(const LArHVPa } */ -StatusCode LArHVPathologyDbCondAlg::execute_r(const EventContext& ctx) const { +StatusCode LArHVPathologyDbCondAlg::execute(const EventContext& ctx) const { SG::WriteCondHandle<LArHVPathology > writeHandle{m_hvPAthologyKey, ctx}; diff --git a/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.h b/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.h index 5006fd67d1bab0a64d5e5057f88360723417e878..95c034f44fff15a33dc3e4113eeb82cbb67b4f40 100755 --- a/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.h +++ b/LArCalorimeter/LArRecUtils/src/LArHVPathologyDbCondAlg.h @@ -31,7 +31,7 @@ class LArHVPathologyDbCondAlg: public AthReentrantAlgorithm virtual StatusCode initialize() override; virtual StatusCode finalize() override; - virtual StatusCode execute_r(const EventContext& ctx) const override; + virtual StatusCode execute(const EventContext& ctx) const override; private: diff --git a/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/MSVertexRecoAlg/MSVertexRecoAlg.h b/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/MSVertexRecoAlg/MSVertexRecoAlg.h index fbbb7eda3ec48a56e424f1307f7effd6510bd9bb..00741af01daf2d686afaabaeab4bf1baf37dd76e 100644 --- a/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/MSVertexRecoAlg/MSVertexRecoAlg.h +++ b/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/MSVertexRecoAlg/MSVertexRecoAlg.h @@ -20,7 +20,7 @@ class MSVertexRecoAlg : public AthReentrantAlgorithm ~MSVertexRecoAlg(); StatusCode initialize() override; - StatusCode execute_r (const EventContext& ctx) const override; + StatusCode execute (const EventContext& ctx) const override; StatusCode finalize() override; diff --git a/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/src/MSVertexRecoAlg.cxx b/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/src/MSVertexRecoAlg.cxx index b0b5a2c344ad561b4095b9ffb32684153ad18110..3d9b0d6be1eb104b2c329125a0fbb6291123a653 100644 --- a/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/src/MSVertexRecoAlg.cxx +++ b/MuonSpectrometer/MSVertexReconstruction/MSVertexRecoAlg/src/MSVertexRecoAlg.cxx @@ -48,7 +48,7 @@ StatusCode MSVertexRecoAlg::initialize(){ //** ----------------------------------------------------------------------------------------------------------------- **// -StatusCode MSVertexRecoAlg::execute_r (const EventContext& ctx) const { +StatusCode MSVertexRecoAlg::execute (const EventContext& ctx) const { std::vector<Tracklet> tracklets; std::vector<MSVertex*> vertices; diff --git a/MuonSpectrometer/MuonCnv/MuonMM_CnvTools/CMakeLists.txt b/MuonSpectrometer/MuonCnv/MuonMM_CnvTools/CMakeLists.txt index e9f2ac5f984c550ddade2aee5420874700aed676..902c799d062b9fc9c07ddec165d6fc5047acedf8 100644 --- a/MuonSpectrometer/MuonCnv/MuonMM_CnvTools/CMakeLists.txt +++ b/MuonSpectrometer/MuonCnv/MuonMM_CnvTools/CMakeLists.txt @@ -11,8 +11,6 @@ atlas_depends_on_subdirs( PUBLIC GaudiKernel PRIVATE Control/AthenaBaseComps - Control/CLIDSvc - Control/SGTools Control/StoreGate DetectorDescription/AtlasDetDescr DetectorDescription/Identifier @@ -33,7 +31,7 @@ atlas_add_component( MuonMM_CnvTools src/*.cxx src/components/*.cxx INCLUDE_DIRS ${TDAQ-COMMON_INCLUDE_DIRS} - LINK_LIBRARIES ${TDAQ-COMMON_LIBRARIES} ByteStreamData ByteStreamData_test GaudiKernel AthenaBaseComps SGTools StoreGateLib SGtests AtlasDetDescr Identifier ByteStreamCnvSvcBaseLib MuonContainerManager MuonReadoutGeometry MuonDigitContainer MuonIdHelpersLib MuonRDO MuonPrepRawData ) + LINK_LIBRARIES ${TDAQ-COMMON_LIBRARIES} ByteStreamData ByteStreamData_test GaudiKernel AthenaBaseComps StoreGateLib SGtests AtlasDetDescr Identifier ByteStreamCnvSvcBaseLib MuonContainerManager MuonReadoutGeometry MuonDigitContainer MuonIdHelpersLib MuonRDO MuonPrepRawData ) # Install files from the package: atlas_install_headers( MuonMM_CnvTools ) diff --git a/PhysicsAnalysis/AnalysisCommon/AnalysisTools/AnalysisTools/AANTupleStream.h b/PhysicsAnalysis/AnalysisCommon/AnalysisTools/AnalysisTools/AANTupleStream.h index 5476ffa4470b7ad931b3421b6fa8b342262b3e95..acbf504a1a370bdbebf9ee6cf50bef21088b95f8 100644 --- a/PhysicsAnalysis/AnalysisCommon/AnalysisTools/AnalysisTools/AANTupleStream.h +++ b/PhysicsAnalysis/AnalysisCommon/AnalysisTools/AnalysisTools/AANTupleStream.h @@ -10,7 +10,7 @@ #include "GaudiKernel/IAddressCreator.h" #include "GaudiKernel/ServiceHandle.h" #include "GaudiKernel/IIoComponent.h" -#include "AthenaBaseComps/AthAlgorithm.h" +#include "AthenaBaseComps/AthLegacySequence.h" #include <map> #include <vector> @@ -30,7 +30,7 @@ class TTree; class TBranch; class AANTupleStream : virtual public IIoComponent, - public AthAlgorithm + public AthLegacySequence { public: diff --git a/PhysicsAnalysis/AnalysisCommon/AnalysisTools/src/AANTupleStream.cxx b/PhysicsAnalysis/AnalysisCommon/AnalysisTools/src/AANTupleStream.cxx index c6199a7623b72a180a5888ca14963e64d85f8589..4375cdd5c952e2d297109d42bcdb0e003b83641a 100644 --- a/PhysicsAnalysis/AnalysisCommon/AnalysisTools/src/AANTupleStream.cxx +++ b/PhysicsAnalysis/AnalysisCommon/AnalysisTools/src/AANTupleStream.cxx @@ -47,7 +47,7 @@ using namespace AANTupleParams; // Standard Constructor AANTupleStream::AANTupleStream(const std::string& name, ISvcLocator* pSvcLocator) - : AthAlgorithm(name, pSvcLocator), + : AthLegacySequence(name, pSvcLocator), m_persSvc ("EventPersistencySvc", name), m_attribSpec(0), m_schemaDone(false), @@ -153,8 +153,8 @@ StatusCode AANTupleStream::initialize() } ATH_MSG_DEBUG ("End initialize "); - - return StatusCode::SUCCESS; + + return AthLegacySequence::initialize(); } @@ -195,7 +195,7 @@ StatusCode AANTupleStream::finalize() gDirectory->cd(curDir.c_str()); } - return StatusCode::SUCCESS; + return AthLegacySequence::finalize(); } @@ -606,6 +606,8 @@ StatusCode AANTupleStream::execute_subAlgos() ATH_MSG_DEBUG ("in execute_subAlgos() ..."); + const EventContext& ctx = Gaudi::Hive::currentContext(); + // -- run subalgorithms for ( unsigned int i=0; i < m_membersNames.size(); ++i ) { @@ -613,7 +615,7 @@ StatusCode AANTupleStream::execute_subAlgos() // skip disabled algo if (! (*(this->subAlgorithms()))[i]->isEnabled()) continue ; - sc = (*(this->subAlgorithms()))[i]->execute(); + sc = (*(this->subAlgorithms()))[i]->execute(ctx); if ( sc.isFailure()) { ATH_MSG_ERROR @@ -695,14 +697,17 @@ bool AANTupleStream::isEventAccepted() const // no filter if (m_acceptAlgs.empty()) return true; - + + const EventContext& ctx = Gaudi::Hive::currentContext(); + // loop over all algs std::vector<Algorithm*>::const_iterator it; std::vector<Algorithm*>::const_iterator itend = m_acceptAlgs.end(); for (it = m_acceptAlgs.begin(); it != itend; ++it) { const Algorithm* theAlgorithm = (*it); - if ( theAlgorithm->isExecuted() && (! theAlgorithm->filterPassed())) + if ( theAlgorithm->execState(ctx).state() == AlgExecState::State::Done && + ( ! theAlgorithm->execState(ctx).filterPassed() ) ) return false; } diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/CMakeLists.txt b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/CMakeLists.txt index d4cf699d1b57eccfe32724d66537a7b3693f4ef3..c7e5fd910502b1a5d47062e170b74efeed676261 100644 --- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/CMakeLists.txt +++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/CMakeLists.txt @@ -11,8 +11,7 @@ atlas_depends_on_subdirs( PUBLIC Event/xAOD/xAODBase GaudiKernel PhysicsAnalysis/AnalysisCommon/PATCore - PhysicsAnalysis/Interfaces/AsgAnalysisInterfaces - PhysicsAnalysis/DerivationFramework/DerivationFrameworkInterfaces + PhysicsAnalysis/DerivationFramework/DerivationFrameworkInterfaces Trigger/TrigAnalysis/TrigDecisionTool PRIVATE Control/AthenaKernel @@ -26,12 +25,11 @@ atlas_add_library( DerivationFrameworkToolsLib src/*.cxx PUBLIC_HEADERS DerivationFrameworkTools PRIVATE_INCLUDE_DIRS ${ROOT_INCLUDE_DIRS} - LINK_LIBRARIES AthenaBaseComps xAODBase GaudiKernel PATCoreLib AsgAnalysisInterfaces TrigDecisionToolLib ExpressionEvaluationLib + LINK_LIBRARIES AthenaBaseComps xAODBase GaudiKernel PATCoreLib TrigDecisionToolLib ExpressionEvaluationLib PRIVATE_LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaKernel ) atlas_add_component( DerivationFrameworkTools src/components/*.cxx INCLUDE_DIRS ${ROOT_INCLUDE_DIRS} - LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaBaseComps xAODBase GaudiKernel AsgAnalysisInterfaces PATCoreLib TrigDecisionToolLib AthenaKernel - ExpressionEvaluationLib DerivationFrameworkToolsLib ) + LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaBaseComps xAODBase GaudiKernel PATCoreLib TrigDecisionToolLib AthenaKernel ExpressionEvaluationLib DerivationFrameworkToolsLib ) diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/DerivationFrameworkTools/AsgSelectionToolWrapper.h b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/DerivationFrameworkTools/AsgSelectionToolWrapper.h index cdf765f1cea2382c2c7e2cc292def9e048a3300c..b02c3360caeed81d5d1dd62ebf5e4d034d0beddd 100644 --- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/DerivationFrameworkTools/AsgSelectionToolWrapper.h +++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/DerivationFrameworkTools/AsgSelectionToolWrapper.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration */ /////////////////////////////////////////////////////////////////// @@ -13,7 +13,7 @@ #include "AthenaBaseComps/AthAlgTool.h" #include "DerivationFrameworkInterfaces/IAugmentationTool.h" -#include "AsgAnalysisInterfaces/ISelectionTool.h" +#include "PATCore/IAsgSelectionTool.h" #include "GaudiKernel/ToolHandle.h" namespace DerivationFramework { @@ -27,7 +27,7 @@ namespace DerivationFramework { virtual StatusCode addBranches() const; private: - ToolHandle<CP::ISelectionTool> m_tool; + ToolHandle<IAsgSelectionTool> m_tool; std::string m_cut; std::string m_sgName; std::string m_containerName; diff --git a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/src/AsgSelectionToolWrapper.cxx b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/src/AsgSelectionToolWrapper.cxx index a358cceba1d3be428887a55dc7118372f5eab056..16644e5e113b72c78db9e4ba7dd226d8cf54cf5e 100644 --- a/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/src/AsgSelectionToolWrapper.cxx +++ b/PhysicsAnalysis/DerivationFramework/DerivationFrameworkTools/src/AsgSelectionToolWrapper.cxx @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration */ /////////////////////////////////////////////////////////////////// @@ -10,7 +10,7 @@ #include "DerivationFrameworkTools/AsgSelectionToolWrapper.h" #include "xAODBase/IParticleContainer.h" -#include "PATCore/AcceptData.h" +#include "PATCore/TAccept.h" #include <vector> #include <string> @@ -59,18 +59,18 @@ namespace DerivationFramework { // Write mask for each element and record to SG for subsequent selection for (xAOD::IParticleContainer::const_iterator pItr = particles->begin(); pItr!=particles->end(); ++pItr) { - asg::AcceptData theAccept=m_tool->accept(*pItr); + Root::TAccept theAccept(m_tool->accept(*pItr)); if(m_cut==""){ - bool pass_selection = static_cast<bool>(theAccept); - if(pass_selection) decorator(**pItr) = 1; - else decorator(**pItr) = 0; + bool pass_selection = (bool) theAccept; + if(pass_selection) decorator(**pItr) = 1; + else decorator(**pItr) = 0; } else{ - if (theAccept.getCutResult(m_cut)) { - decorator(**pItr) = 1; - } else { - decorator(**pItr) = 0; - } + if (theAccept.getCutResult(m_cut)) { + decorator(**pItr) = 1; + } else { + decorator(**pItr) = 0; + } } } diff --git a/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.cxx b/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.cxx index f103251e46e3902be4f6a653ca395526d1e01c13..6c7ce63a88aa924f5666a36580209f55250089f1 100644 --- a/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.cxx +++ b/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.cxx @@ -74,13 +74,13 @@ StatusCode PrimaryDPDPrescaler::initialize() //Print summary info and declare all child filters to CutFlwSvc ATH_MSG_DEBUG( "Accept Algs, Size: " << m_theAcceptAlgs.size() << " Empty: " << m_theAcceptAlgs.empty() ); - for(std::vector<Algorithm*>::iterator i=m_theAcceptAlgs.begin(),end=m_theAcceptAlgs.end(); i != end; ++i) { + for(std::vector<Gaudi::Algorithm*>::iterator i=m_theAcceptAlgs.begin(),end=m_theAcceptAlgs.end(); i != end; ++i) { ATH_MSG_DEBUG( (*i)->name() ); cutFlowSvc()->registerCut((*i)->name(), "", cutID()); } ATH_MSG_DEBUG( "Require Algs, Size: " << m_theRequireAlgs.size() << " Empty: " << m_theRequireAlgs.empty() ); - for(std::vector<Algorithm*>::iterator i=m_theRequireAlgs.begin(),end=m_theRequireAlgs.end(); i != end; ++i) { + for(std::vector<Gaudi::Algorithm*>::iterator i=m_theRequireAlgs.begin(),end=m_theRequireAlgs.end(); i != end; ++i) { ATH_MSG_DEBUG( (*i)->name() ); cutFlowSvc()->registerCut((*i)->name(), "", cutID()); } @@ -270,7 +270,7 @@ void PrimaryDPDPrescaler::handle(const Incident& inc) { //__________________________________________________________________________ -StatusCode PrimaryDPDPrescaler::decodeAlgorithms(StringArrayProperty *theAlgNames, std::vector<Algorithm*> *theAlgs) +StatusCode PrimaryDPDPrescaler::decodeAlgorithms(StringArrayProperty *theAlgNames, std::vector<Gaudi::Algorithm*> *theAlgs) { // Reset the list of Algorithms theAlgs->clear( ); @@ -291,21 +291,21 @@ StatusCode PrimaryDPDPrescaler::decodeAlgorithms(StringArrayProperty *theAlgName // Algorithm object. const std::string& theName = (*it); IAlgorithm* theIAlg; - Algorithm* theAlgorithm; + Gaudi::Algorithm* theAlgorithm; result = theAlgMgr->getAlgorithm( theName, theIAlg ); if ( result.isSuccess( ) ) { try{ - theAlgorithm = dynamic_cast<Algorithm*>(theIAlg); + theAlgorithm = dynamic_cast<Gaudi::Algorithm*>(theIAlg); } catch(...){ result = StatusCode::FAILURE; } } if ( result.isSuccess( ) ) { // Check that the specified algorithm doesn't already exist in the list - std::vector<Algorithm*>::iterator ita; - std::vector<Algorithm*>::iterator itaend = theAlgs->end( ); + std::vector<Gaudi::Algorithm*>::iterator ita; + std::vector<Gaudi::Algorithm*>::iterator itaend = theAlgs->end( ); for (ita = theAlgs->begin(); ita != itaend; ita++) { - Algorithm* existAlgorithm = (*ita); + Gaudi::Algorithm* existAlgorithm = (*ita); if ( theAlgorithm == existAlgorithm ) { result = StatusCode::FAILURE; break; @@ -332,7 +332,7 @@ StatusCode PrimaryDPDPrescaler::decodeAlgorithms(StringArrayProperty *theAlgName //__________________________________________________________________________ bool PrimaryDPDPrescaler::isEventAccepted() { - typedef std::vector<Algorithm*>::iterator AlgIter; + typedef std::vector<Gaudi::Algorithm*>::iterator AlgIter; bool result = true; // Loop over all Algorithms in the accept list to see @@ -352,6 +352,8 @@ bool PrimaryDPDPrescaler::isEventAccepted() bool passRequireAlgs(true); + const EventContext& ctx = Gaudi::Hive::currentContext(); + // Accept Algs (OR) bool isPassed(false); if ( m_theAcceptAlgs.empty() ) @@ -360,7 +362,8 @@ bool PrimaryDPDPrescaler::isEventAccepted() } for(AlgIter i=m_theAcceptAlgs.begin(),end=m_theAcceptAlgs.end(); i != end; ++i) { - if ( (*i)->isExecuted() && (*i)->filterPassed() ) + if ( (*i)->execState(ctx).state() == AlgExecState::State::Done && + (*i)->execState(ctx).filterPassed() ) { isPassed = true; break; @@ -373,7 +376,8 @@ bool PrimaryDPDPrescaler::isEventAccepted() bool isFailed(false); for(AlgIter i=m_theRequireAlgs.begin(),end=m_theRequireAlgs.end(); i != end; ++i) { - if ( (*i)->isExecuted() && !(*i)->filterPassed() ) + if ( (*i)->execState(ctx).state() == AlgExecState::State::Done && + ! (*i)->execState(ctx).filterPassed() ) { isFailed = true; break; diff --git a/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.h b/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.h index 90b76e6e7f61aba8510c341a48bc6f5079a4ef1a..759de6ede7e7bd1b6435e780f730340f806caee4 100644 --- a/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.h +++ b/PhysicsAnalysis/PrimaryDPDMaker/src/PrimaryDPDPrescaler.h @@ -46,7 +46,7 @@ public: // Private methods private: - StatusCode decodeAlgorithms(StringArrayProperty *theAlgNames, std::vector<Algorithm*> *theAlgs); + StatusCode decodeAlgorithms(StringArrayProperty *theAlgNames, std::vector<Gaudi::Algorithm*> *theAlgs); bool isEventAccepted(); void ResetSelfDescription(); @@ -78,10 +78,10 @@ private: double m_prescale; /// List of algorithms to combine with logical OR - std::vector<Algorithm*> m_theAcceptAlgs; + std::vector<Gaudi::Algorithm*> m_theAcceptAlgs; /// List of algorithms to combine with logical AND - std::vector<Algorithm*> m_theRequireAlgs; + std::vector<Gaudi::Algorithm*> m_theRequireAlgs; /// List of algorithms names to combine with logical OR diff --git a/Projects/AthSimulation/externals.txt b/Projects/AthSimulation/externals.txt index 8e6da56d3719325b70e94448557f1fe64750a4bd..6ef7f9b82ab2bfc02891e25f8d25aa252727cdc4 100644 --- a/Projects/AthSimulation/externals.txt +++ b/Projects/AthSimulation/externals.txt @@ -9,4 +9,4 @@ AthSimulationExternalsVersion = 2.0.15 # The version of atlas/Gaudi to use: -GaudiVersion = v30r5.003 +GaudiVersion = v31r0.000 diff --git a/Projects/Athena/externals.txt b/Projects/Athena/externals.txt index 3d7575d135ab79d071cf57f3c2418c25acd361f3..9527c8037d384bb5a54beb38cb7d466c0b0c4ce9 100644 --- a/Projects/Athena/externals.txt +++ b/Projects/Athena/externals.txt @@ -9,4 +9,4 @@ AthenaExternalsVersion = 2.0.15 # The version of atlas/Gaudi to use: -GaudiVersion = v30r5.003 +GaudiVersion = v31r0.000 diff --git a/Projects/Athena/package_filters.txt b/Projects/Athena/package_filters.txt index 0bc39015a1adde3d90f5ac8d0bdf4bed8d6f96ee..2c431ffaabe675392dcbe21e3af287dd3cff3724 100644 --- a/Projects/Athena/package_filters.txt +++ b/Projects/Athena/package_filters.txt @@ -64,3 +64,7 @@ # Don't build PerfMonVTune which has external Intel tool dependency - Control/PerformanceMonitoring/PerfMonVTune + +# Old packages that don't work with AthenaMT +- LArCalorimeter/LArSim +- PhysicsAnalysis/HiggsPhys/HSG5/HSG5DPDUtils diff --git a/Reconstruction/MET/METReconstruction/src/METReaderAlg.cxx b/Reconstruction/MET/METReconstruction/src/METReaderAlg.cxx index 8578113b765cb44ea6632dadba503f478862e142..347e5f2fc3d7f60867188c3e3f8ab86874b11a22 100644 --- a/Reconstruction/MET/METReconstruction/src/METReaderAlg.cxx +++ b/Reconstruction/MET/METReconstruction/src/METReaderAlg.cxx @@ -62,7 +62,7 @@ namespace met { //********************************************************************** - StatusCode METReaderAlg::execute_r (const EventContext& ctx) const{ + StatusCode METReaderAlg::execute (const EventContext& ctx) const{ ATH_MSG_VERBOSE("Executing " << name() << "..."); // Loop over tools. diff --git a/Reconstruction/MET/METReconstruction/src/METReaderAlg.h b/Reconstruction/MET/METReconstruction/src/METReaderAlg.h index 932ccc688b4f6427dac08d5d9d619df1a8f8ddbe..befc14ef5d587aea94cbd9ac96fd6c73ec343fd2 100644 --- a/Reconstruction/MET/METReconstruction/src/METReaderAlg.h +++ b/Reconstruction/MET/METReconstruction/src/METReaderAlg.h @@ -26,7 +26,7 @@ namespace met { /// Athena algorithm's Hooks virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; private: diff --git a/Reconstruction/RecExample/RecExCommon/share/AnalysisCommon_topOptions.py b/Reconstruction/RecExample/RecExCommon/share/AnalysisCommon_topOptions.py index abba4bb4e4cec195731fa09785e68df07f0bd5f9..9aac79c1a85bb60d5e04941928f51654a1518448 100644 --- a/Reconstruction/RecExample/RecExCommon/share/AnalysisCommon_topOptions.py +++ b/Reconstruction/RecExample/RecExCommon/share/AnalysisCommon_topOptions.py @@ -4,7 +4,6 @@ include.block ("RecExCommon/AnalysisCommon_topOptions.py") ## Common job preparation ## ############################ -# gbl.AthenaServices.SetFatalHandler(438) svcMgr.CoreDumpSvc.FatalHandler = 438 import traceback diff --git a/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py b/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py index 0cf0bb1102499b540dcb8d7985179c1d160a0e40..c187b44259ff514e346d9d0799ec604168607f96 100644 --- a/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py +++ b/Reconstruction/RecExample/RecExCommon/share/RecExCommon_topOptions.py @@ -4,7 +4,6 @@ include.block ("RecExCommon/RecExCommon_topOptions.py") ## Common job preparation ## ############################ -# gbl.AthenaServices.SetFatalHandler(438) svcMgr.CoreDumpSvc.FatalHandler = 438 import traceback diff --git a/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.cxx b/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.cxx index 125240dd1a231878fd79e62b7b7b225c37a99b00..fb4b6e926cd776650912d5c45ee13f428f7d108f 100644 --- a/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.cxx +++ b/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.cxx @@ -73,7 +73,7 @@ namespace ClusterMatching { return StatusCode::SUCCESS; } - StatusCode CaloClusterMatchLinkAlg::execute_r(const EventContext& ctx) const + StatusCode CaloClusterMatchLinkAlg::execute(const EventContext& ctx) const { ATH_MSG_DEBUG ("Executing " << name() << "..."); diff --git a/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.h b/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.h index b0db9fb7dfd46eea58cc5852f9a5c341f5bf0954..2cc19713aa61d1a96a7bc47f865503f79f8632d6 100644 --- a/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.h +++ b/Reconstruction/RecoTools/CaloClusterMatching/src/CaloClusterMatchLinkAlg.h @@ -44,7 +44,7 @@ namespace ClusterMatching { // Athena algorithm's Hooks virtual StatusCode initialize(); - virtual StatusCode execute_r(const EventContext& ctx) const; + virtual StatusCode execute(const EventContext& ctx) const; virtual StatusCode finalize(); /////////////////////////////////////////////////////////////////// diff --git a/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.cxx b/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.cxx index a021c920ee85a9108c96a9fdf5f6db74e2a15902..d50a56161fcf3712a8e599ac8f58c702fa209205 100644 --- a/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.cxx +++ b/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.cxx @@ -91,7 +91,7 @@ StatusCode egammaForwardBuilder::finalize() } // ====================================================================== -StatusCode egammaForwardBuilder::execute_r(const EventContext& ctx) const +StatusCode egammaForwardBuilder::execute(const EventContext& ctx) const { ATH_MSG_DEBUG("Executing egammaForwardBuilder "); diff --git a/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.h b/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.h index babf2d4e0b3b32f950fd8d70614162be314e9f56..9af4efff34b8ecca4fca849e374789b11d099dae 100644 --- a/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.h +++ b/Reconstruction/egamma/egammaAlgs/src/egammaForwardBuilder.h @@ -60,7 +60,7 @@ class egammaForwardBuilder : public AthReentrantAlgorithm /** @brief finalize method*/ virtual StatusCode finalize() override final; /** @brief execute method*/ - virtual StatusCode execute_r(const EventContext& ctx) const override final; + virtual StatusCode execute(const EventContext& ctx) const override final; private: diff --git a/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.cxx b/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.cxx index 95fdb681f65f87b81e0181d422e5a00cf62c4196..e571a700fb7366b0f672b7a108a6238b714a3ccc 100644 --- a/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.cxx +++ b/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.cxx @@ -62,7 +62,7 @@ StatusCode egammaTopoClusterCopier::finalize() { } // ========================================================================= -StatusCode egammaTopoClusterCopier::execute_r(const EventContext& ctx) const { +StatusCode egammaTopoClusterCopier::execute(const EventContext& ctx) const { SG::ReadHandle<xAOD::CaloClusterContainer> inputTopoclusters(m_inputTopoCollection, ctx); SG::WriteHandle<xAOD::CaloClusterContainer> outputTopoclustersShallow(m_outputTopoCollectionShallow, ctx); diff --git a/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.h b/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.h index 4966225d026880cc97147e03ae4d8bfe3bf86c95..3daa1124432952d0a3f4485eca83d38a7b348649 100644 --- a/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.h +++ b/Reconstruction/egamma/egammaAlgs/src/egammaTopoClusterCopier.h @@ -23,7 +23,7 @@ class egammaTopoClusterCopier : public AthReentrantAlgorithm { /** @brief initialize method */ virtual StatusCode initialize() override final; /** @brief execute on container */ - virtual StatusCode execute_r(const EventContext& ctx) const override final; + virtual StatusCode execute(const EventContext& ctx) const override final; /** @brief finalize method */ virtual StatusCode finalize() override final; diff --git a/Simulation/G4Utilities/MCTruthAlgs/MCTruthAlgs/TrackRecordFilter.h b/Simulation/G4Utilities/MCTruthAlgs/MCTruthAlgs/TrackRecordFilter.h index c84ebd79f358fc9e44ce09212fd75c844ed25d0a..efda43314d69d54dd6cb37ecb1053403727048f0 100755 --- a/Simulation/G4Utilities/MCTruthAlgs/MCTruthAlgs/TrackRecordFilter.h +++ b/Simulation/G4Utilities/MCTruthAlgs/MCTruthAlgs/TrackRecordFilter.h @@ -26,7 +26,7 @@ public: StatusCode initialize() override; StatusCode finalize() override; - StatusCode execute_r(const EventContext& ctx) const override; + StatusCode execute(const EventContext& ctx) const override; private: SG::ReadHandleKey<TrackRecordCollection> m_inputKey; diff --git a/Simulation/G4Utilities/MCTruthAlgs/src/TrackRecordFilter.cxx b/Simulation/G4Utilities/MCTruthAlgs/src/TrackRecordFilter.cxx index d0002f3986f571114e37a2d1e0be59757ea2b432..7dbd73b229c10bb23cefb19c51c1a76c186375c8 100755 --- a/Simulation/G4Utilities/MCTruthAlgs/src/TrackRecordFilter.cxx +++ b/Simulation/G4Utilities/MCTruthAlgs/src/TrackRecordFilter.cxx @@ -43,7 +43,7 @@ StatusCode TrackRecordFilter::initialize() { return StatusCode::SUCCESS; } -StatusCode TrackRecordFilter::execute_r(const EventContext& ctx) const { +StatusCode TrackRecordFilter::execute(const EventContext& ctx) const { // Get message service ATH_MSG_DEBUG ( "TrackRecordFilter::execute()" ); diff --git a/Simulation/ISF/ISF_Core/ISF_Services/test/TruthSvc_test.cxx b/Simulation/ISF/ISF_Core/ISF_Services/test/TruthSvc_test.cxx index 9cfd4baa78e729a98ebfa13993122083bc309057..3b701f284acf3759a9a1f5e5a1a555804632e79d 100644 --- a/Simulation/ISF/ISF_Core/ISF_Services/test/TruthSvc_test.cxx +++ b/Simulation/ISF/ISF_Core/ISF_Services/test/TruthSvc_test.cxx @@ -623,7 +623,7 @@ namespace ISFTesting { int main(int argc, char *argv[]) { ::testing::InitGoogleTest( &argc, argv ); - // gets stuck forever while trying to finalize boost crap inside SGTools: + // gets stuck forever while trying to finalize boost stuff inside SGTools: //return RUN_ALL_TESTS(); // skips proper finalization: std::quick_exit( RUN_ALL_TESTS() ); diff --git a/Simulation/RunDependentSim/RunDependentSimComps/python/RunDMCFlags.py b/Simulation/RunDependentSim/RunDependentSimComps/python/RunDMCFlags.py index 9080a3e3a77a15b7aec400269b869a93d0562d8a..7205a0394d65c8c10cd7167a23608a16cf10c3ac 100644 --- a/Simulation/RunDependentSim/RunDependentSimComps/python/RunDMCFlags.py +++ b/Simulation/RunDependentSim/RunDependentSimComps/python/RunDMCFlags.py @@ -140,7 +140,12 @@ class RunToTimestampDict(JobProperty): 300000:1500000000, ##MC16 pp (25 ns bunch spacing, nominal mu, 2017) 305000:1525000000, ##MC16 pp (5 TeV 2017) 309000:1540000000, ##MC16 XeXe (2017) - 310000:1550000000 ##MC16 pp (25 ns bunch spacing, nominal mu, 2018) + 310000:1550000000, ##MC16 pp (25 ns bunch spacing, nominal mu, 2018) + 311000:1551000000, ##MC16 pp (25 ns bunch spacing, low mu, 2018) + 312000:1552000000, ##MC16 pp (900 GeV high-beta ALFA, 2018) + 313000:1553000000 ##MC16 PbPb (2018) + + } def addEntry( self, run, timestamp, force=False): if not type(run) == int: diff --git a/TestBeam/TBRec/src/TBAlgoSequencer.cxx b/TestBeam/TBRec/src/TBAlgoSequencer.cxx index f10becf0d506dece97304217cb0f12bff0fa2c8e..2ebd155c0aef66271b2a518a12a53203f556d47d 100644 --- a/TestBeam/TBRec/src/TBAlgoSequencer.cxx +++ b/TestBeam/TBRec/src/TBAlgoSequencer.cxx @@ -16,7 +16,7 @@ TBAlgoSequencer::TBAlgoSequencer(const std::string& name, ISvcLocator* pSvcLocator) : - AthAlgorithm(name,pSvcLocator) + ::AthLegacySequence ( name, pSvcLocator ) , m_timingOn(true) , m_eventPrintFreq(100) , m_eventCounter(0) @@ -56,7 +56,7 @@ TBAlgoSequencer::initialize() ! registerAlgs.isFailure() ) { ListItem theAlgItem(*subAlgos); - Algorithm* theAlgo; + Gaudi::Algorithm* theAlgo; registerAlgs = createSubAlgorithm(theAlgItem.type(),theAlgItem.name(), theAlgo); if ( ! registerAlgs.isFailure() && theAlgo != 0 ) @@ -93,9 +93,14 @@ TBAlgoSequencer::initialize() m_rejectPattern.clear(); - return numberOfAlgorithms > 0 - ? StatusCode::SUCCESS - : StatusCode::FAILURE; + // return numberOfAlgorithms > 0 + // ? StatusCode::SUCCESS + // : StatusCode::FAILURE; + + if (numberOfAlgorithms == 0) return StatusCode::FAILURE; + + return AthLegacySequence::initialize(); + } ///////////// @@ -137,12 +142,14 @@ TBAlgoSequencer::execute() AlgoIterator algoCounter = m_subAlgos.begin(); StatusCode executeAlgs; + const EventContext& ctx = getContext(); + unsigned int algoIndex = 0; while ( ! executeAlgs.isFailure() && algoCounter != m_subAlgos.end() ) { // execute the algorithm if ( m_timingOn ) theTicker->chronoStart(m_algoNameStore[algoIndex]); - executeAlgs = (*algoCounter)->execute(); + executeAlgs = (*algoCounter)->execute(ctx); if ( m_timingOn ) theTicker->chronoStop(m_algoNameStore[algoIndex]); // failure/reject if ( executeAlgs.isFailure() ) @@ -264,6 +271,7 @@ TBAlgoSequencer::finalize() ATH_MSG_INFO ( "======================================================== " ); - return StatusCode::SUCCESS; + + return AthLegacySequence::finalize(); } diff --git a/TestBeam/TBRec/src/TBAlgoSequencer.h b/TestBeam/TBRec/src/TBAlgoSequencer.h index d21fcdf5dd80e486297b4d152639775d7351839e..1566142c148018f0f3078b3efaa3f46cf879aa65 100755 --- a/TestBeam/TBRec/src/TBAlgoSequencer.h +++ b/TestBeam/TBRec/src/TBAlgoSequencer.h @@ -11,7 +11,8 @@ // // /////////////////////////////////////////////////////////////////////////////// -#include "AthenaBaseComps/AthAlgorithm.h" +#include "AthenaBaseComps/AthLegacySequence.h" + #include <string> #include <vector> @@ -19,11 +20,11 @@ class StoreGateSvc; -class TBAlgoSequencer : public AthAlgorithm +class TBAlgoSequencer : public AthLegacySequence { typedef std::string KeyType; - typedef std::vector<Algorithm*> AlgoStore; + typedef std::vector<Gaudi::Algorithm*> AlgoStore; typedef AlgoStore::iterator AlgoIterator; public: diff --git a/TileCalorimeter/TileCalib/TileCalibAlgs/TileCalibAlgs/TileLaserDefaultCalibTool.h b/TileCalorimeter/TileCalib/TileCalibAlgs/TileCalibAlgs/TileLaserDefaultCalibTool.h index df52a945e1fd61cd02444e5cb975461f5769933a..a65829244a79afe6223894d2f1d1bf00e6909c0d 100644 --- a/TileCalorimeter/TileCalib/TileCalibAlgs/TileCalibAlgs/TileLaserDefaultCalibTool.h +++ b/TileCalorimeter/TileCalib/TileCalibAlgs/TileCalibAlgs/TileLaserDefaultCalibTool.h @@ -5,19 +5,22 @@ #ifndef TILECALIBALG_TILELASERDEFAULTCALIBTOOL_H #define TILECALIBALG_TILELASERDEFAULTCALIBTOOL_H -#include "AthenaBaseComps/AthAlgTool.h" +// Tile includes #include "TileCalibAlgs/ITileCalibTool.h" #include "TileEvent/TileDQstatus.h" -#include "StoreGate/ReadHandleKey.h" -#include <string> -#include <map> -#include <cmath> - #include "TileConditions/TileCablingService.h" #include "TileConditions/TileCondToolEmscale.h" #include "TileConditions/ITileBadChanTool.h" +#include "TileConditions/ITileDCSTool.h" +// Athena includes +#include "AthenaBaseComps/AthAlgTool.h" +#include "StoreGate/ReadHandleKey.h" + +#include <string> +#include <map> +#include <cmath> #define NDIODES 10 @@ -39,7 +42,6 @@ class TileLaserObject; class TileHWID; class TFile; class RunningStat; -class TileDCSSvc; class ITileStuckBitsProbsTool; class TileLaserDefaultCalibTool : public AthAlgTool, virtual public ITileCalibTool @@ -74,8 +76,7 @@ class TileLaserDefaultCalibTool : public AthAlgTool, virtual public ITileCalibTo ToolHandle<ITileStuckBitsProbsTool> m_stuckBitsProbs; SG::ReadHandleKey<TileDQstatus> m_dqStatusKey; - ServiceHandle<TileDCSSvc> m_tileDCSSvc; //!< Pointer to TileDCSSvc - + ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"}; // Parameter which will end up in the ROOTuple // diff --git a/TileCalorimeter/TileCalib/TileCalibAlgs/src/TileLaserDefaultCalibTool.cxx b/TileCalorimeter/TileCalib/TileCalibAlgs/src/TileLaserDefaultCalibTool.cxx index 614effeabff42477a1502002899f6b447b833c4e..650d7f9bf165d24394c456e2f6f8866d57e0023a 100644 --- a/TileCalorimeter/TileCalib/TileCalibAlgs/src/TileLaserDefaultCalibTool.cxx +++ b/TileCalorimeter/TileCalib/TileCalibAlgs/src/TileLaserDefaultCalibTool.cxx @@ -2,7 +2,15 @@ Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ +// Tile includes #include "TileCalibAlgs/TileLaserDefaultCalibTool.h" +#include "TileEvent/TileRawChannelContainer.h" +#include "TileEvent/TileLaserObject.h" +#include "TileConditions/TileCablingService.h" +#include "TileCalibBlobObjs/TileCalibUtils.h" +#include "TileConditions/ITileBadChanTool.h" +#include "TileMonitoring/ITileStuckBitsProbsTool.h" + #include "GaudiKernel/MsgStream.h" #include "GaudiKernel/Service.h" @@ -13,14 +21,6 @@ #include "Identifier/HWIdentifier.h" #include "StoreGate/ReadHandle.h" -#include "TileEvent/TileRawChannelContainer.h" -#include "TileEvent/TileLaserObject.h" -#include "TileConditions/TileCablingService.h" -#include "TileCalibBlobObjs/TileCalibUtils.h" -#include "TileConditions/ITileBadChanTool.h" -#include "TileConditions/TileDCSSvc.h" - -#include "TileMonitoring/ITileStuckBitsProbsTool.h" #include "TFile.h" #include "TTree.h" @@ -46,7 +46,6 @@ TileLaserDefaultCalibTool::TileLaserDefaultCalibTool(const std::string& type, co m_tileToolEmscale("TileCondToolEmscale"), m_tileBadChanTool("TileBadChanTool"), m_stuckBitsProbs(""), - m_tileDCSSvc("TileDCSSvc",name), m_toolRunNo(0), m_ADC_problem(0), m_las_filter(0), @@ -123,7 +122,6 @@ TileLaserDefaultCalibTool::TileLaserDefaultCalibTool(const std::string& type, co declareProperty("rawChannelContainer", m_rawChannelContainerName=""); declareProperty("laserObjContainer", m_laserContainerName=""); declareProperty("pisaMethod2", m_pisaMethod2=true); - declareProperty("TileDCSSvc",m_tileDCSSvc); declareProperty("StuckBitsProbsTool", m_stuckBitsProbs); declareProperty("TileDQstatus", m_dqStatusKey = "TileDQstatus"); } // TileLaserDefaultCalibTool::TileLaserDefaultCalibTool @@ -273,9 +271,9 @@ StatusCode TileLaserDefaultCalibTool::initialize(){ ATH_CHECK( m_tileBadChanTool.retrieve() ); - ATH_CHECK( m_tileDCSSvc.retrieve() ); + ATH_CHECK( m_tileDCS.retrieve() ); - CHECK( m_dqStatusKey.initialize() ); + ATH_CHECK( m_dqStatusKey.initialize() ); return StatusCode::SUCCESS; } @@ -895,11 +893,9 @@ StatusCode TileLaserDefaultCalibTool::finalizeCalculations(){ for(int part=0; part<NPARTITIONS; ++part){ int ros = part+1; for(int drawer=0; drawer<NDRAWERS; ++drawer){ - int module = drawer+1; for(int channel=0; channel<NCHANNELS; ++channel){ - int pmt = abs(m_cabling->channel2hole(ros,channel)); - m_HV[part][drawer][channel] = m_tileDCSSvc->getDCSHV(ros, module, pmt); - m_HVSet[part][drawer][channel] = m_tileDCSSvc->getDCSHVSET(ros, module, pmt); + m_HV[part][drawer][channel] = m_tileDCS->getChannelHV(ros, drawer, channel); + m_HVSet[part][drawer][channel] = m_tileDCS->getChannelHVSet(ros, drawer, channel); } // channel } // drawers } // partitions diff --git a/TileCalorimeter/TileConditions/TileConditions/TileConditionsDict.h b/TileCalorimeter/TileConditions/TileConditions/TileConditionsDict.h index 454b91d3dbc179243791d17f702d42e64b3b469a..d5ba3b83097023593be0e311ea9af6585e07d307 100644 --- a/TileCalorimeter/TileConditions/TileConditions/TileConditionsDict.h +++ b/TileCalorimeter/TileConditions/TileConditions/TileConditionsDict.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ @@ -9,6 +9,5 @@ #include "TileConditions/TileBadChanTool.h" #include "TileConditions/TileCablingService.h" #include "TileConditions/TileCablingSvc.h" -#include "TileConditions/TileDCSSvc.h" -#endif +#endif // TILECONDITIONS_TILECONDITIONSDICT_H diff --git a/TileCalorimeter/TileConditions/TileConditions/TileDCSSvc.h b/TileCalorimeter/TileConditions/TileConditions/TileDCSSvc.h deleted file mode 100644 index e1376a8d04e15a0bfd56f4948bae3d78b001f386..0000000000000000000000000000000000000000 --- a/TileCalorimeter/TileConditions/TileConditions/TileDCSSvc.h +++ /dev/null @@ -1,77 +0,0 @@ -/* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration -*/ - -#ifndef TILECONDITIONS_TILECONDDCS_H -#define TILECONDITIONS_TILECONDDCS_H - -// Tile includes -#include "TileConditions/ITileDCSTool.h" -#include "TileConditions/TileCablingSvc.h" - -// Athena includes -#include "AthenaBaseComps/AthService.h" - -// Gaudi includes -#include "GaudiKernel/ToolHandle.h" - -// Forward declaration -class TileCablingService; - - -template <class TYPE> class SvcFactory; - - -//Class to provide DCS information about modules from the COOL database -class TileDCSSvc: virtual public AthService { - friend class SvcFactory<TileDCSSvc>; - - public: - static const InterfaceID& interfaceID(); /*as in TileCablingSvc.h*/ - TileDCSSvc( const std::string& name, ISvcLocator* pSvcLocator ); - virtual ~TileDCSSvc(){ /*do nothing*/} - virtual StatusCode initialize(); - virtual StatusCode finalize(); - StatusCode queryInterface(const InterfaceID& riid, void** ppvInterface); - - enum TileDCSStatus {NON_EXISTING=0, UNKNOWN=1, - OK_DRAWER=10, OK_KNOWNBADPMT, OK, - WARNING_DRAWER=20, WARNING_KNOWNBADPMT, WARNING, - ALERT_DRAWER=30, ALERT_KNOWNBADPMT, ALERT}; - - // these 3 methods return values found in COOL - // and they use ros=1,2,3,4, module and pmt as parameter, all three starts from "1", like in DCS - float getDCSHV (int ros, int module, int pmt) const; - float getDCSHVSET (int ros, int module, int pmt) const; - int getDCSSTATES (int ros, int module) const; - - // these 3 methods return status values which can be used to detect bad PMTs - // ros=1,2,3,4 as usual, while drawer and channel starts from "0" - TileDCSStatus getDCSHVSTATUS (int ros, int drawer, int channel) const; // status for HV deviation - TileDCSStatus getDCSSTATUS (int ros, int drawer) const; // status of drawer voltages - TileDCSStatus getDCSSTATUS (int ros, int drawer, int channel) const; - - bool statusHVIsBad (int ros, int drawer, int channel) const; - bool statusIsBad (int ros, int drawer) const; - bool statusIsBad (int ros, int drawer, int channel) const; - - int getNcalls() const { return m_ncalls; } // how many times callBack was triggered - - std::string partitionName(int ros) {return m_partName[ros];} - - private: - - ToolHandle<ITileDCSTool> m_dcsTool{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"}; - - int m_ncalls; - - const TileCablingService* m_cabling; - - int m_pmt2channel[2][68]; - - std::vector<std::string> m_partName; - - int m_version; -}; - -#endif diff --git a/TileCalorimeter/TileConditions/TileConditions/selection.xml b/TileCalorimeter/TileConditions/TileConditions/selection.xml index f73dffa515be83249e464ad07b86a9b8938498ff..046fd44f3b72c48cff4710b423365f86889d2647 100644 --- a/TileCalorimeter/TileConditions/TileConditions/selection.xml +++ b/TileCalorimeter/TileConditions/TileConditions/selection.xml @@ -4,6 +4,5 @@ <class name="ITileBadChanTool" /> <class name="TileCablingService" /> <class name="TileCablingSvc" /> -<class name="TileDCSSvc" /> </lcgdict> diff --git a/TileCalorimeter/TileConditions/python/TileInfoConfigurator.py b/TileCalorimeter/TileConditions/python/TileInfoConfigurator.py index 499fb26ba9e9955e5250a5d87bdac11d8374503b..e47d47a876116faa8f93e99dac6adb8979fc644f 100644 --- a/TileCalorimeter/TileConditions/python/TileInfoConfigurator.py +++ b/TileCalorimeter/TileConditions/python/TileInfoConfigurator.py @@ -387,7 +387,7 @@ class _TileInfoConfigurator( TileInfoLoader ): return self._coolDCSIsConfigured = True - ## #=== ensure the availability of TileDCSSvc + ## #=== ensure the availability of TileDCS information from AthenaCommon.GlobalFlags import globalflags from AthenaCommon.AthenaCommonFlags import athenaCommonFlags TileUseDCS = (not athenaCommonFlags.isOnline()) and globalflags.DataSource()=='data' @@ -410,20 +410,6 @@ class _TileInfoConfigurator( TileInfoLoader ): ReadSTATES = useSTATUS, TileDCS = dcs) - from AthenaCommon.AppMgr import ServiceMgr as svcMgr - if TileUseDCS and not hasattr(svcMgr, "TileDCSSvc"): - - self._msg.info("Adding TileDCSSvc to ServiceMgr") - svcMgr += CfgMgr.TileDCSSvc() - - from IOVDbSvc.CondDB import conddb - if (conddb.GetInstance() == 'CONDBR2'): - self._msg.info("setting up TileDCSSvc for RUN2") - svcMgr.TileDCSSvc.Version=2 - else: - self._msg.info("setting up TileDCSSvc for RUN1") - svcMgr.TileDCSSvc.Version=1 - #_______________________________________________________________ def setupCOOLDspThreshold(self, defTag = "", dbConnection = ""): diff --git a/TileCalorimeter/TileConditions/src/TileDCSSvc.cxx b/TileCalorimeter/TileConditions/src/TileDCSSvc.cxx deleted file mode 100644 index 1f9a3b14657f492fb136a01402a40abbf6b5fc02..0000000000000000000000000000000000000000 --- a/TileCalorimeter/TileConditions/src/TileDCSSvc.cxx +++ /dev/null @@ -1,132 +0,0 @@ -/* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration -*/ - -// Tile includes -//#include "TileCalibBlobObjs/TileCalibUtils.h" -#include "TileConditions/TileDCSSvc.h" -//#include "src/TileDCSTool.h" -#include "TileConditions/TileCablingService.h" - -// Athena includes -#include "AthenaKernel/errorcheck.h" - -// Gaudi includes -#include "GaudiKernel/ServiceHandle.h" - - -static const InterfaceID IID_TileDCSSvc("TileDCSSvc", 1, 0); -const InterfaceID& TileDCSSvc::interfaceID() { - return IID_TileDCSSvc; -} - -TileDCSSvc::TileDCSSvc(const std::string& name, ISvcLocator* pSvcLocator) - : AthService(name, pSvcLocator) - , m_cabling(nullptr) - , m_version(2) -{ - - declareProperty("Version", m_version); // 1 - RUN1 conditions DB, 2 - RUN2 conditions - - m_partName.push_back("AUX"); - m_partName.push_back("LBA"); - m_partName.push_back("LBC"); - m_partName.push_back("EBA"); - m_partName.push_back("EBC"); - - m_ncalls = 0; - -} - -//_____________________________________________________________________________ -StatusCode TileDCSSvc::queryInterface(const InterfaceID& riid, void** ppvInterface) { - if (TileDCSSvc::interfaceID().versionMatch(riid)) { - *ppvInterface = dynamic_cast<TileDCSSvc*>(this); - } else { - return AthService::queryInterface(riid, ppvInterface); - } - addRef(); - return StatusCode::SUCCESS; -} - -//_____________________________________________________________________________ -StatusCode TileDCSSvc::initialize() { - - //=== get TileDCSTool - ATH_CHECK( m_dcsTool.retrieve()); - - //=== get TileCablingSvc - ServiceHandle<TileCablingSvc> cablingSvc("TileCablingSvc", name()); - ATH_CHECK( cablingSvc.retrieve()); - - //=== cache pointers to cabling helpers - m_cabling = cablingSvc->cablingService(); - if (!m_cabling) { - ATH_MSG_ERROR( "Pointer to TileCablingService is zero: " << m_cabling); - return StatusCode::FAILURE; - } - - for (int i = 0; i < 2; ++i) { - int ros = i + 2; - int channel = 0; - for (; channel < 48; ++channel) { - int pmt = std::abs(m_cabling->channel2hole(ros, channel)); - m_pmt2channel[i][pmt - 1] = channel; // note - pmt-1 is used as index - } - for (; channel < 68; ++channel) { - m_pmt2channel[i][channel] = channel; - } - } - - - return StatusCode::SUCCESS; -} - -//_____________________________________________________________________________ -StatusCode TileDCSSvc::finalize() { - return StatusCode::SUCCESS; -} - -float TileDCSSvc::getDCSHV(int ros, int module, int pmt) const { - int lb_eb = (ros > 2) ? 1 : 0; - int channel = m_pmt2channel[lb_eb][pmt - 1]; - return m_dcsTool->getChannelHV(ros, module - 1, channel); -} - -float TileDCSSvc::getDCSHVSET(int ros, int module, int pmt) const { - int lb_eb = (ros > 2) ? 1 : 0; - int channel = m_pmt2channel[lb_eb][pmt - 1]; - return m_dcsTool->getChannelHVSet(ros, module - 1, channel); -} - -int TileDCSSvc::getDCSSTATES (int ros, int module) const { - return m_dcsTool->getDrawerStates(ros, module - 1); -} - - -//_____________________________________________________________________________ -TileDCSSvc::TileDCSStatus TileDCSSvc::getDCSHVSTATUS(int ros, int drawer, int channel) const { - return static_cast<TileDCSSvc::TileDCSStatus>(m_dcsTool->getDCSHVStatus(ros, drawer, channel)); -} - -//_____________________________________________________________________________ -TileDCSSvc::TileDCSStatus TileDCSSvc::getDCSSTATUS(int ros, int drawer) const { - return static_cast<TileDCSSvc::TileDCSStatus>(m_dcsTool->getDCSStatus(ros, drawer)); -} - - -TileDCSSvc::TileDCSStatus TileDCSSvc::getDCSSTATUS(int ros, int drawer, int channel) const { - return static_cast<TileDCSSvc::TileDCSStatus>(m_dcsTool->getDCSStatus(ros, drawer, channel)); -} - -bool TileDCSSvc::statusHVIsBad (int ros, int drawer, int channel) const { - return m_dcsTool->isStatusHVBad(ros, drawer, channel); -} - -bool TileDCSSvc::statusIsBad (int ros, int drawer) const { - return m_dcsTool->isStatusBad(ros, drawer); -} - -bool TileDCSSvc::statusIsBad (int ros, int drawer, int channel) const { - return m_dcsTool->isStatusBad(ros, drawer, channel); -} diff --git a/TileCalorimeter/TileConditions/src/components/TileConditions_entries.cxx b/TileCalorimeter/TileConditions/src/components/TileConditions_entries.cxx index 8b3393f48f8d509a5aac9917aef642ec9a0dacf0..bf1df2fe6d7de8505011f7bb72f3006783b0baa9 100644 --- a/TileCalorimeter/TileConditions/src/components/TileConditions_entries.cxx +++ b/TileCalorimeter/TileConditions/src/components/TileConditions_entries.cxx @@ -18,7 +18,6 @@ #include "TileConditions/TileCondToolNoiseSample.h" #include "TileConditions/TileCondToolNoiseRawChn.h" #include "TileConditions/TileCondProxyWrapper.h" -#include "TileConditions/TileDCSSvc.h" #include "TileConditions/TileCondDCS_Data.h" #include "TileConditions/TileCondToolAutoCr.h" #include "TileConditions/TileCondToolTMDB.h" @@ -31,7 +30,6 @@ DECLARE_COMPONENT( TileInfoLoader ) DECLARE_COMPONENT( TileCablingSvc ) -DECLARE_COMPONENT( TileDCSSvc ) DECLARE_COMPONENT( TileCondIdTransforms ) DECLARE_COMPONENT( TileBadChanTool ) DECLARE_COMPONENT( TileCondToolOfc ) diff --git a/TileCalorimeter/TileCoolDcs/python/TileDCSDataGrabber.py b/TileCalorimeter/TileCoolDcs/python/TileDCSDataGrabber.py index 94a7acc6332a4ea6e9bdbcd40825dfb32e012c46..31e2b8f3baa2fbba732c4eca81b2e28c7c19a43c 100755 --- a/TileCalorimeter/TileCoolDcs/python/TileDCSDataGrabber.py +++ b/TileCalorimeter/TileCoolDcs/python/TileDCSDataGrabber.py @@ -658,7 +658,7 @@ class TileDCSDataGrabber: while stmt.NextResultRow(): if varType==self.info.type_int: value = stmt.GetInt( 1) elif varType==self.info.type_float: value = stmt.GetDouble(1) - #=== catch crap in oracle + #=== catch in oracle if value < -10000: nCrap += 1 continue @@ -683,7 +683,7 @@ class TileDCSDataGrabber: if not isDebug: bar.done() folderVarSetList.append(folderVarSet) if nCrap > 0: - logging.warning("Found %i \"crap\" entries for %s, ignored those!"%(nCrap,var)) + logging.warning("Found %i \"bad\" entries for %s, ignored those!"%(nCrap,var)) return folderVarSetList diff --git a/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileCalibRec.py b/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileCalibRec.py index 1420c85fbf025b912cc63af48aac948267bd3577..0ecbc992195ea2c8911e839985264f48d3491652 100644 --- a/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileCalibRec.py +++ b/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileCalibRec.py @@ -637,6 +637,9 @@ from AthenaCommon.BeamFlags import jobproperties #jobproperties.Beam.beamType.set_Value_and_Lock('cosmics') jobproperties.Beam.beamType.set_Value_and_Lock('collisions') +from AthenaCommon.AthenaCommonFlags import athenaCommonFlags +athenaCommonFlags.FilesInput.set_Value_and_Lock(FileNameVec) + from AthenaCommon.DetFlags import DetFlags DetFlags.Calo_setOff() #Switched off to avoid geometry DetFlags.ID_setOff() @@ -651,8 +654,6 @@ DetFlags.detdescr.LAr_setOn() DetFlags.detdescr.Tile_setOn() if TileL1CaloRun: DetFlags.detdescr.LVL1_setOn() - from AthenaCommon.AthenaCommonFlags import athenaCommonFlags - athenaCommonFlags.FilesInput.set_Value_and_Lock(FileNameVec) if ReadPool: DetFlags.readRDOPool.Tile_setOn() if TileL1CaloRun: @@ -827,8 +828,20 @@ if not OfcFromCOOL and (doTileOpt2 or doTileOptATLAS or doTileOF1): from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() -from xAODEventInfoCnv.xAODEventInfoCreator import xAODMaker__EventInfoCnvAlg -topSequence+=xAODMaker__EventInfoCnvAlg() +if not 'newRDO' in dir() or newRDO is None: + if 'ReadRDO' in dir() and ReadRDO: + from RecExConfig.InputFilePeeker import inputFileSummary + from RecExConfig.ObjKeyStore import objKeyStore + objKeyStore.addManyTypesInputFile(inputFileSummary['eventdata_itemsList']) + newRDO = objKeyStore.isInInput( "xAOD::EventInfo" ) + else: + newRDO = True + +if ReadPool and newRDO: + topSequence += CfgMgr.xAODMaker__EventInfoNonConstCnvAlg() +else: + from xAODEventInfoCnv.xAODEventInfoCreator import xAODMaker__EventInfoCnvAlg + topSequence+=xAODMaker__EventInfoCnvAlg() #============================================================= #=== read ByteStream and reconstruct data @@ -1190,20 +1203,6 @@ if doTileNtuple: dqStatus.TileDigitsContainer = getattr (TileNtuple, 'TileDigitsContainer', '') dqStatus.TileRawChannelContainer = getattr (TileNtuple, 'TileRawChannelContainer', '') - # FIXME: TileAANtuple does a back-door set of properties - # in TileBeamInfoProvider. That doesn't really work with - # handles and MT. To compensate, also set the properties here. - def moveprop (pname): - pval = TileNtuple.properties()[pname] - if pval == TileNtuple.propertyNoValue: - pval = TileNtuple.getDefaultProperty(pname) - if pval: - setattr (ToolSvc.TileBeamInfoProvider, pname, pval) - - moveprop ('TileBeamElemContainer') - moveprop ('TileDigitsContainer') - moveprop ('TileRawChannelContainer') - if doTileMon: # Monitoring historgrams if not hasattr(svcMgr,"THistSvc"): diff --git a/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileTBStat.py b/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileTBStat.py index 53a19d34363384975b5c2cf3a66760cbb46b3f46..620d705a0970ed6cf4b10fda257a63c4444b4a18 100644 --- a/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileTBStat.py +++ b/TileCalorimeter/TileExample/TileRecEx/share/jobOptions_TileTBStat.py @@ -339,6 +339,11 @@ topSequence += theTileTBDump theTileTBDump.dumpOnce = True theTileTBDump.dumpUnknown = False +from TileRecUtils.TileDQstatusAlgDefault import TileDQstatusAlgDefault +TileDQstatusAlgDefault (TileBeamElemContainer = 'TileBeamElemCnt', + TileDigitsContainer = 'TileDigitsCnt', + TileRawChannelContainer = 'TileRawChannelCnt') + from TileTBRec.TileTBRecConf import TileTBStat theTileTBStat = TileTBStat() topSequence += theTileTBStat diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragLWMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragLWMonTool.h index 8bb51de01a19c9071e3dfae7b086507d0f596132..038073f4f1343aec6cb4f58397efebba5e219d3d 100644 --- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragLWMonTool.h +++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragLWMonTool.h @@ -16,12 +16,12 @@ #include "TileMonitoring/TileFatherMonTool.h" #include "TileEvent/TileDQstatus.h" +#include "TileConditions/ITileDCSTool.h" #include "StoreGate/ReadHandleKey.h" #include <array> class ITileBadChanTool; -class TileDCSSvc; class TileDQstatus; class TileRawChannel; class TileRawChannelCollection; @@ -67,7 +67,7 @@ class TileDQFragLWMonTool: public TileFatherMonTool { void fillBadDrawer(void); ToolHandle<ITileBadChanTool> m_tileBadChanTool; //!< Tile Bad Channel tool - ServiceHandle<TileDCSSvc> m_tileDCSSvc; //!< Pointer to TileDCSSvc + ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"}; /*---------------------------------------------------------*/ /* properties*/ @@ -84,7 +84,7 @@ class TileDQFragLWMonTool: public TileFatherMonTool { bool m_skipMasked; bool m_skipGapCells; bool m_doOnline; - bool m_checkDCS; //!< if false, do not use TileDCSSvc at all + bool m_checkDCS; //!< if false, do not use TileDCS at all /* njunior@cern.ch */ const TileDQstatus* m_dqStatus; diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragMonTool.h index 9b92b57ae14cbade8f25fc3bc540f96334a88754..a826333dffa4718b3c14b2b8d53669083dde888d 100644 --- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragMonTool.h +++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDQFragMonTool.h @@ -16,12 +16,12 @@ #include "TileMonitoring/TileFatherMonTool.h" #include "TileEvent/TileDQstatus.h" +#include "TileConditions/ITileDCSTool.h" #include "StoreGate/ReadHandleKey.h" #include <array> class ITileBadChanTool; -class TileDCSSvc; class TileDQstatus; class TileRawChannel; class TileRawChannelCollection; @@ -72,7 +72,7 @@ class TileDQFragMonTool: public TileFatherMonTool { void fillBadDrawer(void); ToolHandle<ITileBadChanTool> m_tileBadChanTool; //!< Tile Bad Channel tool - ServiceHandle<TileDCSSvc> m_tileDCSSvc; //!< Pointer to TileDCSSvc + ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"}; /*---------------------------------------------------------*/ /* properties*/ @@ -90,7 +90,7 @@ class TileDQFragMonTool: public TileFatherMonTool { bool m_skipGapCells; bool m_doPlots; bool m_doOnline; - bool m_checkDCS; //!< if false, do not use TileDCSSvc at all + bool m_checkDCS; //!< if false, do not use TileDCSTool at all /* njunior@cern.ch */ const TileDQstatus* m_dqStatus; diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDigiNoiseMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDigiNoiseMonTool.h index e3fe1ff4268376c7831bc9e43c63d713cf9f1be1..731b13ee799b4d3d53c8e64e6bff2ec094137282 100644 --- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileDigiNoiseMonTool.h +++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileDigiNoiseMonTool.h @@ -75,7 +75,7 @@ class TileDigiNoiseMonTool : public TileFatherMonTool { bool m_fillPedestalDifference; std::vector<uint32_t> m_triggerTypes; SG::ReadHandleKey<TileDQstatus> m_DQstatusKey; - ToolHandle<ITileDCSTool> m_tileDCS; + ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"}; bool m_checkDCS; bool m_histogramsNotBooked; }; diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelNoiseMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelNoiseMonTool.h index ec1803fab2f1c30462ae57ae0e7f6b52f5e48d46..b23cbff23c92e2053e767df4d8980d7ae4ec8939 100644 --- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelNoiseMonTool.h +++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelNoiseMonTool.h @@ -19,12 +19,13 @@ // To perform the double gaussian fit use the option: m_do2gfit=true // ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -#ifndef TILERAWCHANNELMONTOOL_H -#define TILERAWCHANNELMONTOOL_H +#ifndef TILEMONITORING_TILERAWCHANNELNOISEMONTOOL_H +#define TILEMONITORING_TILERAWCHANNELNOISEMONTOOL_H #include "TileMonitoring/TileFatherMonTool.h" #include "TileEvent/TileDQstatus.h" #include "TileConditions/ITileDCSTool.h" + #include "StoreGate/ReadHandleKey.h" class ITileBadChanTool; @@ -100,8 +101,8 @@ class TileRawChannelNoiseMonTool: public TileFatherMonTool { int m_nbins; unsigned int m_minimumEventsNumberToFit; SG::ReadHandleKey<TileDQstatus> m_DQstatusKey; - ToolHandle<ITileDCSTool> m_tileDCS; + ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"}; bool m_checkDCS; }; -#endif +#endif // TILEMONITORING_TILERAWCHANNELNOISEMONTOOL_H diff --git a/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelTimeMonTool.h b/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelTimeMonTool.h index f37d570d9c37a13e87d7ec6f29ad8b2fd6c8fe96..e47e02e75b58d725882cb31995bed0d566e8ce14 100644 --- a/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelTimeMonTool.h +++ b/TileCalorimeter/TileMonitoring/TileMonitoring/TileRawChannelTimeMonTool.h @@ -98,7 +98,7 @@ class TileRawChannelTimeMonTool: public TileFatherMonTool { std::vector<std::pair<int, int> > m_timeDifferenceBetweenROS; int m_nLumiblocks; SG::ReadHandleKey<TileDQstatus> m_DQstatusKey; - ToolHandle<ITileDCSTool> m_tileDCS; + ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"}; bool m_checkDCS; }; diff --git a/TileCalorimeter/TileMonitoring/share/TileMon_jobOptions.py b/TileCalorimeter/TileMonitoring/share/TileMon_jobOptions.py index e92bb48ca012c7a18e2c8f4644a885c525fe5e29..d05a9904271eab82d72a7dbdcfc90a29e1e5e49e 100644 --- a/TileCalorimeter/TileMonitoring/share/TileMon_jobOptions.py +++ b/TileCalorimeter/TileMonitoring/share/TileMon_jobOptions.py @@ -11,6 +11,10 @@ from AthenaCommon.BeamFlags import jobproperties from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() +from AthenaCommon.AlgSequence import AthSequencer +condSequence = AthSequencer("AthCondSeq") +tileCheckDCS = hasattr(condSequence, 'TileDCSCondAlg') + from AthenaMonitoring.DQMonFlags import DQMonFlags if not 'rec' in dir(): @@ -204,7 +208,7 @@ if tileRawMon: , TriggerChain = "HLT_noalg_cosmiccalo_L1RD1_EMPTY" , TrigDecisionTool = getattr(ToolSvc, DQMonFlags.nameTrigDecTool()) if DQMonFlags.useTrigger() else "" , TriggerTypes = [ 0x82 ] - , CheckDCS = hasattr(ServiceMgr, "TileDCSSvc")) + , CheckDCS = tileCheckDCS) if globalflags.InputFormat() == 'pool': TileDigiNoiseMon.TileDigitsContainer = 'TileDigitsFlt' @@ -221,7 +225,7 @@ if tileRawMon: , SkipMasked = True , SkipGapCells = True , doOnline = athenaCommonFlags.isOnline() - , CheckDCS = hasattr(ServiceMgr, "TileDCSSvc") + , CheckDCS = tileCheckDCS , histoPathBase = "/Tile/DMUErrors") diff --git a/TileCalorimeter/TileMonitoring/share/TileMon_standalone_jobOptions.py b/TileCalorimeter/TileMonitoring/share/TileMon_standalone_jobOptions.py index daf82eae4d0f7e80feda5eaf7e3899d49ffd504e..ea8339d1d63886abaeaa926a1d667d9c2183650c 100644 --- a/TileCalorimeter/TileMonitoring/share/TileMon_standalone_jobOptions.py +++ b/TileCalorimeter/TileMonitoring/share/TileMon_standalone_jobOptions.py @@ -4,11 +4,13 @@ # #============================================================== - - from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() +from AthenaCommon.AlgSequence import AthSequencer +condSequence = AthSequencer("AthCondSeq") +tileCheckDCS = hasattr(condSequence, 'TileDCSCondAlg') + from AthenaCommon.AppMgr import ServiceMgr as svcMgr from AthenaCommon import CfgMgr @@ -40,7 +42,7 @@ toolSvc += CfgMgr.TileDQFragMonTool(name = 'TileDQFragM , SkipGapCells = True , doOnline = athenaCommonFlags.isOnline() , doPlots = False - , CheckDCS = hasattr(svcMgr, "TileDCSSvc") + , CheckDCS = tileCheckDCS , histoPathBase = "Tile/DMUErrors") ManagedAthenaTileMon.AthenaMonTools += [ toolSvc.TileDQFragMon ] diff --git a/TileCalorimeter/TileMonitoring/src/TileDQFragLWMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileDQFragLWMonTool.cxx index 2dcafa1660892b875cca94c27ab57a5435e8165e..8ba59e80e914d0caddcda2ac753b0cb426f59e5a 100644 --- a/TileCalorimeter/TileMonitoring/src/TileDQFragLWMonTool.cxx +++ b/TileCalorimeter/TileMonitoring/src/TileDQFragLWMonTool.cxx @@ -16,7 +16,6 @@ #include "TileCalibBlobObjs/TileCalibUtils.h" #include "TileConditions/ITileBadChanTool.h" -#include "TileConditions/TileDCSSvc.h" #include "TileEvent/TileDigitsContainer.h" #include "TileEvent/TileRawChannelContainer.h" #include "TileRecUtils/TileRawChannelBuilder.h" @@ -35,7 +34,6 @@ TileDQFragLWMonTool::TileDQFragLWMonTool(const std::string & type, const std::string & name, const IInterface* parent) : TileFatherMonTool(type, name, parent) , m_tileBadChanTool("TileBadChanTool") - , m_tileDCSSvc("TileDCSSvc",name) , m_dqStatus(0) , m_globalErrCount{} , m_global{} @@ -151,14 +149,16 @@ StatusCode TileDQFragLWMonTool:: initialize() { ATH_MSG_INFO( "in initialize()" ); - CHECK( m_tileBadChanTool.retrieve() ); + ATH_CHECK( m_tileBadChanTool.retrieve() ); - CHECK( TileFatherMonTool::initialize() ); + ATH_CHECK( TileFatherMonTool::initialize() ); - CHECK( m_DQstatusKey.initialize() ); + ATH_CHECK( m_DQstatusKey.initialize() ); if (m_checkDCS) { - CHECK( m_tileDCSSvc.retrieve() ); + ATH_CHECK( m_tileDCS.retrieve() ); + } else { + m_tileDCS.disable(); } return StatusCode::SUCCESS; @@ -460,7 +460,7 @@ void TileDQFragLWMonTool::fillBadDrawer() { if ((pedestal > 80000. || quality > m_qualityCut) && !(m_tileBadChanTool->getAdcStatus(adcId).isBad() - || (m_checkDCS && m_tileDCSSvc->statusIsBad(ROS, drawer, channel)))) { + || (m_checkDCS && m_tileDCS->isStatusBad(ROS, drawer, channel)))) { m_badPulseQuality[partition]->Fill(module, channel); @@ -660,13 +660,13 @@ void TileDQFragLWMonTool::fillErrorsHistograms(unsigned int ros, unsigned int dr unsigned int drawerIdx = TileCalibUtils::getDrawerIdx(ros + 1, drawer); if (m_checkDCS - && ((m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn) + && ((m_tileDCS->isStatusBad(ros + 1, drawer, ichn) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn).contains(TileBchPrbs::NoHV) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn).contains(TileBchPrbs::WrongHV)) - || (m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn + 1) + || (m_tileDCS->isStatusBad(ros + 1, drawer, ichn + 1) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 1).contains(TileBchPrbs::NoHV) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 1).contains(TileBchPrbs::WrongHV)) - || (m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn + 2) + || (m_tileDCS->isStatusBad(ros + 1, drawer, ichn + 2) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 2).contains(TileBchPrbs::NoHV) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 2).contains(TileBchPrbs::WrongHV)))) { @@ -830,8 +830,8 @@ bool TileDQFragLWMonTool::isModuleDCSgood(unsigned int partition, unsigned int d /*---------------------------------------------------------*/ if (m_checkDCS) { - TileDCSSvc::TileDCSStatus Status = m_tileDCSSvc->getDCSSTATUS(partition, drawer); - if (Status > TileDCSSvc::WARNING) { + TileDCSState::TileDCSStatus status = m_tileDCS->getDCSStatus(partition, drawer); + if (status > TileDCSState::WARNING) { return false; } else { return true; diff --git a/TileCalorimeter/TileMonitoring/src/TileDQFragMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileDQFragMonTool.cxx index 735278be199e3ed6a509c05c6dfa9ab85eddc318..92213e54e9d688c69f42c76561de2e16ab92a180 100644 --- a/TileCalorimeter/TileMonitoring/src/TileDQFragMonTool.cxx +++ b/TileCalorimeter/TileMonitoring/src/TileDQFragMonTool.cxx @@ -16,7 +16,6 @@ #include "TileCalibBlobObjs/TileCalibUtils.h" #include "TileConditions/ITileBadChanTool.h" -#include "TileConditions/TileDCSSvc.h" #include "TileEvent/TileDigitsContainer.h" #include "TileEvent/TileRawChannelContainer.h" #include "TileRecUtils/TileRawChannelBuilder.h" @@ -40,7 +39,6 @@ TileDQFragMonTool::TileDQFragMonTool(const std::string & type, const std::string & name, const IInterface* parent) : TileFatherMonTool(type, name, parent) , m_tileBadChanTool("TileBadChanTool") - , m_tileDCSSvc("TileDCSSvc",name) , m_dqStatus(0) , m_last_lb(0) , m_globalErrCount{} @@ -214,15 +212,18 @@ StatusCode TileDQFragMonTool:: initialize() { ATH_MSG_INFO( "in initialize()" ); - CHECK( m_tileBadChanTool.retrieve() ); + ATH_CHECK( m_tileBadChanTool.retrieve() ); - CHECK( TileFatherMonTool::initialize() ); + ATH_CHECK( TileFatherMonTool::initialize() ); if (m_checkDCS) { - CHECK( m_tileDCSSvc.retrieve() ); + ATH_CHECK( m_tileDCS.retrieve() ); + } else { + m_tileDCS.disable(); } - CHECK( m_DQstatusKey.initialize() ); + + ATH_CHECK( m_DQstatusKey.initialize() ); return StatusCode::SUCCESS; @@ -523,7 +524,7 @@ void TileDQFragMonTool::fillBadDrawer() { int drawer = fragId & 0x3F; // range 0-63 int ROS = fragId >> 8; // range 1-4 bool drbad = true; - if (m_checkDCS) drbad = m_tileDCSSvc->statusIsBad(ROS, drawer); + if (m_checkDCS) drbad = m_tileDCS->isStatusBad(ROS, drawer); if (!drbad) ++nBadDrNM; } @@ -585,7 +586,7 @@ void TileDQFragMonTool::fillBadDrawer() { if ((pedestal > 80000. || quality > m_qualityCut) && !(m_tileBadChanTool->getAdcStatus(adcId).isBad() - || (m_checkDCS && m_tileDCSSvc->statusIsBad(ROS, drawer, channel)))) { + || (m_checkDCS && m_tileDCS->isStatusBad(ROS, drawer, channel)))) { m_badPulseQuality[partition]->Fill(module, channel); @@ -804,13 +805,13 @@ void TileDQFragMonTool::fillErrHist(int ros, int drawer) { unsigned int drawerIdx = TileCalibUtils::getDrawerIdx(ros + 1, drawer); if (m_checkDCS - && ((m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn) + && ((m_tileDCS->isStatusBad(ros + 1, drawer, ichn) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn).contains(TileBchPrbs::NoHV) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn).contains(TileBchPrbs::WrongHV)) - || (m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn + 1) + || (m_tileDCS->isStatusBad(ros + 1, drawer, ichn + 1) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 1).contains(TileBchPrbs::NoHV) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 1).contains(TileBchPrbs::WrongHV)) - || (m_tileDCSSvc->statusIsBad(ros + 1, drawer, ichn + 2) + || (m_tileDCS->isStatusBad(ros + 1, drawer, ichn + 2) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 2).contains(TileBchPrbs::NoHV) && !m_tileBadChanTool->getChannelStatus(drawerIdx, ichn + 2).contains(TileBchPrbs::WrongHV)))) { @@ -1101,8 +1102,8 @@ bool TileDQFragMonTool::isModuleDCSgood(int partition, int drawer) const { /*---------------------------------------------------------*/ if (m_checkDCS) { - TileDCSSvc::TileDCSStatus Status = m_tileDCSSvc->getDCSSTATUS(partition, drawer); - if (Status > TileDCSSvc::WARNING) { + TileDCSState::TileDCSStatus status = m_tileDCS->getDCSStatus(partition, drawer); + if (status > TileDCSState::WARNING) { return false; } else { return true; diff --git a/TileCalorimeter/TileMonitoring/src/TileDigiNoiseMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileDigiNoiseMonTool.cxx index 3601d6b9fce3ec33c63e2111e393ea36fa72e823..cc1d8031a20b0a7028f0d94a7628d8549809d8bc 100644 --- a/TileCalorimeter/TileMonitoring/src/TileDigiNoiseMonTool.cxx +++ b/TileCalorimeter/TileMonitoring/src/TileDigiNoiseMonTool.cxx @@ -18,15 +18,16 @@ // // ******************************************************************** -#include "xAODEventInfo/EventInfo.h" - +// Tile includes #include "TileMonitoring/TileDigiNoiseMonTool.h" - #include "TileEvent/TileDigitsContainer.h" #include "TileEvent/TileRawChannelContainer.h" #include "TileCalibBlobObjs/TileCalibUtils.h" #include "TileConditions/TileBadChanTool.h" #include "TileConditions/TileCondToolNoiseSample.h" + +// Athena includes +#include "xAODEventInfo/EventInfo.h" #include "StoreGate/ReadHandle.h" #include <iostream> @@ -42,7 +43,6 @@ TileDigiNoiseMonTool::TileDigiNoiseMonTool(const std::string & type, const std:: , m_tileToolNoiseSample("TileCondToolNoiseSample") , m_DQstatus(0) , m_nEventsProcessed(0) - , m_tileDCS("TileDCSTool") , m_histogramsNotBooked(true) /*---------------------------------------------------------*/ { @@ -58,7 +58,6 @@ TileDigiNoiseMonTool::TileDigiNoiseMonTool(const std::string & type, const std:: declareProperty("FillPedestalDifference", m_fillPedestalDifference = true); declareProperty("TriggerTypes", m_triggerTypes); declareProperty("TileDQstatus", m_DQstatusKey = "TileDQstatus"); - declareProperty("TileDCSTool", m_tileDCS); declareProperty("CheckDCS", m_checkDCS = false); m_path = "/Tile/DigiNoise"; //ROOT File relative directory @@ -77,8 +76,8 @@ StatusCode TileDigiNoiseMonTool:: initialize() { ATH_MSG_INFO( "in initialize()" ); - CHECK(m_tileBadChanTool.retrieve()); - if (m_fillEmtyFromDB || m_fillPedestalDifference) CHECK(m_tileToolNoiseSample.retrieve()); + ATH_CHECK(m_tileBadChanTool.retrieve()); + if (m_fillEmtyFromDB || m_fillPedestalDifference) ATH_CHECK(m_tileToolNoiseSample.retrieve()); memset(m_sumPed1, 0, sizeof(m_sumPed1)); memset(m_sumPed2, 0, sizeof(m_sumPed2)); @@ -98,12 +97,11 @@ StatusCode TileDigiNoiseMonTool:: initialize() { msg(MSG::INFO) << endmsg; } - CHECK( m_DQstatusKey.initialize() ); + ATH_CHECK( m_DQstatusKey.initialize() ); if (m_checkDCS) { - CHECK( m_tileDCS.retrieve() ); - } - else { + ATH_CHECK( m_tileDCS.retrieve() ); + } else { m_tileDCS.disable(); } @@ -217,12 +215,12 @@ StatusCode TileDigiNoiseMonTool::fillHistograms() { if (m_triggerTypes.empty() || std::find( m_triggerTypes.begin(), m_triggerTypes.end(), m_lvl1info) != m_triggerTypes.end()) { - if (m_histogramsNotBooked) CHECK( bookNoiseHistograms() ); + if (m_histogramsNotBooked) ATH_CHECK( bookNoiseHistograms() ); m_DQstatus = SG::makeHandle (m_DQstatusKey).get(); const TileDigitsContainer* digitsContainer; - CHECK( evtStore()->retrieve(digitsContainer, m_digitsContainerName) ); + ATH_CHECK( evtStore()->retrieve(digitsContainer, m_digitsContainerName) ); for (const TileDigitsCollection* digitsCollection : *digitsContainer) { diff --git a/TileCalorimeter/TileMonitoring/src/TileRawChannelNoiseMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileRawChannelNoiseMonTool.cxx index 0c37fde070f51b81c6dc7be66873e3b224363150..9b38986f2b90650bf467e79edd39a422baea3166 100644 --- a/TileCalorimeter/TileMonitoring/src/TileRawChannelNoiseMonTool.cxx +++ b/TileCalorimeter/TileMonitoring/src/TileRawChannelNoiseMonTool.cxx @@ -18,12 +18,11 @@ // // ******************************************************************** -#include "xAODEventInfo/EventInfo.h" +// Tile includes #include "TileMonitoring/TileRawChannelNoiseMonTool.h" #include "TileMonitoring/PairBuilder.h" - #include "TileCalibBlobObjs/TileCalibUtils.h" #include "TileIdentifier/TileHWID.h" #include "TileIdentifier/TileRawChannelUnit.h" @@ -33,8 +32,12 @@ #include "TileEvent/TileCell.h" #include "TileEvent/TileRawChannelContainer.h" + +// Athena includes +#include "xAODEventInfo/EventInfo.h" #include "StoreGate/ReadHandle.h" + #include "TH1F.h" #include "TH2F.h" #include "TF1.h" @@ -65,7 +68,6 @@ TileRawChannelNoiseMonTool::TileRawChannelNoiseMonTool(const std::string & type, , m_gain(1) , m_nEventsProcessed(0) , m_minimumEventsNumberToFit(100) - , m_tileDCS("TileDCSTool") /*---------------------------------------------------------*/ { declareInterface<IMonitorToolBase>(this); @@ -87,7 +89,6 @@ TileRawChannelNoiseMonTool::TileRawChannelNoiseMonTool(const std::string & type, declareProperty("TriggerTypes", m_triggerTypes); declareProperty("MinimumEventsNumberToFit", m_minimumEventsNumberToFit); declareProperty("TileDQstatus", m_DQstatusKey = "TileDQstatus"); - declareProperty("TileDCSTool", m_tileDCS); declareProperty("CheckDCS", m_checkDCS = false); m_path = "/Tile/RawChannelNoise"; @@ -106,7 +107,7 @@ StatusCode TileRawChannelNoiseMonTool::initialize() { ATH_MSG_INFO("in initialize() - m_path = " << m_path); //=== get TileBadChanTool - CHECK(m_tileBadChanTool.retrieve()); + ATH_CHECK(m_tileBadChanTool.retrieve()); if (m_gainName == "HG"){ m_gain = 1; @@ -129,12 +130,11 @@ StatusCode TileRawChannelNoiseMonTool::initialize() { msg(MSG::INFO) << endmsg; } - CHECK( m_DQstatusKey.initialize() ); + ATH_CHECK( m_DQstatusKey.initialize() ); if (m_checkDCS) { - CHECK( m_tileDCS.retrieve() ); - } - else { + ATH_CHECK( m_tileDCS.retrieve() ); + } else { m_tileDCS.disable(); } @@ -502,7 +502,7 @@ StatusCode TileRawChannelNoiseMonTool::fillHistoPerRawChannel() { m_DQstatus = SG::makeHandle (m_DQstatusKey).get(); const TileRawChannelContainer* rawChannelContainer; - CHECK(evtStore()->retrieve(rawChannelContainer, m_rawChannelContainerName)); + ATH_CHECK(evtStore()->retrieve(rawChannelContainer, m_rawChannelContainerName)); // What is the unit used to store info in the RawChannelContainer ? TileRawChannelUnit::UNIT RChUnit = rawChannelContainer->get_unit(); @@ -515,7 +515,7 @@ StatusCode TileRawChannelNoiseMonTool::fillHistoPerRawChannel() { std::string module_name; const TileRawChannelContainer* rawChannelContainerDSP(nullptr); - CHECK(evtStore()->retrieve(rawChannelContainerDSP, m_rawChannelContainerDspName)); + ATH_CHECK(evtStore()->retrieve(rawChannelContainerDSP, m_rawChannelContainerDspName)); // Loop over the containers @@ -620,7 +620,7 @@ StatusCode TileRawChannelNoiseMonTool::fillHistograms() { if (m_triggerTypes.empty() || std::find( m_triggerTypes.begin(), m_triggerTypes.end(), m_lvl1info) != m_triggerTypes.end()) { - CHECK(fillHistoPerRawChannel()); + ATH_CHECK(fillHistoPerRawChannel()); } if ((m_summaryUpdateFrequency > 0) diff --git a/TileCalorimeter/TileMonitoring/src/TileRawChannelTimeMonTool.cxx b/TileCalorimeter/TileMonitoring/src/TileRawChannelTimeMonTool.cxx index b8f1d1878ac64c58f4fb42ec812593178ba02675..e2c0d12cff42d1b5f805a0e2282626b756d7fedd 100644 --- a/TileCalorimeter/TileMonitoring/src/TileRawChannelTimeMonTool.cxx +++ b/TileCalorimeter/TileMonitoring/src/TileRawChannelTimeMonTool.cxx @@ -12,11 +12,14 @@ // // ******************************************************************** +// Tile includes #include "TileMonitoring/TileRawChannelTimeMonTool.h" #include "TileCalibBlobObjs/TileCalibUtils.h" #include "TileConditions/ITileBadChanTool.h" #include "TileEvent/TileRawChannelContainer.h" + +// Athena includes #include "StoreGate/ReadHandle.h" #include "TProfile.h" @@ -51,7 +54,6 @@ TileRawChannelTimeMonTool::TileRawChannelTimeMonTool(const std::string & type, c , m_partitionTimeCorrection{{0}} , m_timeDifferenceBetweenROS{{1, 2}, {1, 3}, {1, 4}, {2, 3}, {2, 4}, {3, 4}} , m_nLumiblocks(3000) - , m_tileDCS("TileDCSTool") /*---------------------------------------------------------*/ { declareInterface<IMonitorToolBase>(this); @@ -70,7 +72,6 @@ TileRawChannelTimeMonTool::TileRawChannelTimeMonTool(const std::string & type, c declareProperty("TimeCorrectionEBC", m_timeCorrectionEBC); declareProperty("NumberOfLumiblocks", m_nLumiblocks = 3000); declareProperty("TileDQstatus", m_DQstatusKey = "TileDQstatus"); - declareProperty("TileDCSTool", m_tileDCS); declareProperty("CheckDCS", m_checkDCS = false); m_path = "/Tile/RawChannelTime"; @@ -89,7 +90,7 @@ StatusCode TileRawChannelTimeMonTool::initialize() ATH_MSG_INFO("in initialize()"); - CHECK(m_tileBadChanTool.retrieve()); + ATH_CHECK(m_tileBadChanTool.retrieve()); m_nEvents = 0; m_thresholds[0] = m_lowGainThreshold; @@ -101,14 +102,13 @@ StatusCode TileRawChannelTimeMonTool::initialize() m_timeCorrectionEBA, m_timeCorrectionEBC}}; - CHECK(TileFatherMonTool::initialize()); + ATH_CHECK(TileFatherMonTool::initialize()); - CHECK( m_DQstatusKey.initialize() ); + ATH_CHECK( m_DQstatusKey.initialize() ); if (m_checkDCS) { - CHECK( m_tileDCS.retrieve() ); - } - else { + ATH_CHECK( m_tileDCS.retrieve() ); + } else { m_tileDCS.disable(); } @@ -246,7 +246,7 @@ StatusCode TileRawChannelTimeMonTool::fillHists() int32_t current_lumiblock = getLumiBlock(); const TileRawChannelContainer* RawChannelCnt; - CHECK(evtStore()->retrieve(RawChannelCnt, m_contName)); + ATH_CHECK(evtStore()->retrieve(RawChannelCnt, m_contName)); std::vector<double> avgTimePerPart(TileCalibUtils::MAX_ROS, 0.0); std::vector<double> sumTimeCh(TileCalibUtils::MAX_ROS, 0.0); diff --git a/TileCalorimeter/TileMuId/TileMuId/TileLookForMuAlg.h b/TileCalorimeter/TileMuId/TileMuId/TileLookForMuAlg.h index 7ad48b8a60f1292784f97e54112cb81c8b41a6ee..af6181678c78a3bb4e52f04a2649e090891f8273 100755 --- a/TileCalorimeter/TileMuId/TileMuId/TileLookForMuAlg.h +++ b/TileCalorimeter/TileMuId/TileMuId/TileLookForMuAlg.h @@ -48,7 +48,7 @@ class TileLookForMuAlg: public AthReentrantAlgorithm { virtual ~TileLookForMuAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; diff --git a/TileCalorimeter/TileMuId/src/TileLookForMuAlg.cxx b/TileCalorimeter/TileMuId/src/TileLookForMuAlg.cxx index 89571a11404d25e2c8ea327d5b245ef6a04e1b0f..01e677edb703ec279ea516d61efd56bb0cfaf9c9 100755 --- a/TileCalorimeter/TileMuId/src/TileLookForMuAlg.cxx +++ b/TileCalorimeter/TileMuId/src/TileLookForMuAlg.cxx @@ -100,7 +100,7 @@ StatusCode TileLookForMuAlg::initialize() { ///////////////////////////////////////////////////////////////////////////////// //Execution / ///////////////////////////////////////////////////////////////////////////////// -StatusCode TileLookForMuAlg::execute_r (const EventContext& ctx) const { +StatusCode TileLookForMuAlg::execute (const EventContext& ctx) const { ATH_MSG_DEBUG("TileLookForMuAlg execution started"); diff --git a/TileCalorimeter/TileRec/TileRec/TileAANtuple.h b/TileCalorimeter/TileRec/TileRec/TileAANtuple.h index e7e9b1e636763a1282e80418934d46847cc0daa0..69e6722f896f0e1f5cf2e736b2edf362c0189779 100755 --- a/TileCalorimeter/TileRec/TileRec/TileAANtuple.h +++ b/TileCalorimeter/TileRec/TileRec/TileAANtuple.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ //**************************************************************************** @@ -39,21 +39,22 @@ /// /// //**************************************************************************** -#ifndef TileAANtuple_H -#define TileAANtuple_H +#ifndef TILEREC_TILEAANTUPLE_H +#define TILEREC_TILEAANTUPLE_H -// Gauid includes -#include "GaudiKernel/ToolHandle.h" -#include "GaudiKernel/ServiceHandle.h" +// Tile includes +#include "TileConditions/TileCablingService.h" +#include "TileIdentifier/TileRawChannelUnit.h" +#include "TileEvent/TileLaserObject.h" +#include "TileConditions/ITileDCSTool.h" // Athena includes #include "AthenaKernel/IOVSvcDefs.h" #include "AthenaBaseComps/AthAlgorithm.h" -// Tile includes -#include "TileConditions/TileCablingService.h" -#include "TileIdentifier/TileRawChannelUnit.h" -#include "TileEvent/TileLaserObject.h" +// Gauid includes +#include "GaudiKernel/ToolHandle.h" +#include "GaudiKernel/ServiceHandle.h" #include <string> #include <stdint.h> @@ -82,7 +83,6 @@ class TileBeamInfoProvider; class TileBeamElemContByteStreamCnv; class ITileBadChanTool; class TileCondToolEmscale; -class TileDCSSvc; class TileL2Builder; class ITHistSvc; @@ -348,7 +348,7 @@ class TileAANtuple : public AthAlgorithm { int m_finalUnit; //!< calibrate everything to this level bool m_calibMode; //!< If data should be put in calib mode bool m_compareMode; //!< If two sets of data should be compared (e.g. frag4 and frag5) - bool m_checkDCS; //!< if false, do not use TileDCSSvc at all + bool m_checkDCS; //!< if false, do not use TileDCS at all int m_DCSBranches; //!< mask like 110101 - which DCS branches to fill // energy units @@ -363,7 +363,6 @@ class TileAANtuple : public AthAlgorithm { // The ntuple TTree* m_ntuplePtr; TTree* m_DCSntuplePtr; - int m_DCScounter; // handle to THistSvc ServiceHandle<ITHistSvc> m_thistSvc; @@ -384,7 +383,7 @@ class TileAANtuple : public AthAlgorithm { TileBeamElemContByteStreamCnv* m_beamCnv; - ServiceHandle<TileDCSSvc> m_tileDCSSvc; //!< Pointer to TileDCSSvc + ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"}; // variables to check SumEt in frag5 ToolHandle<TileL2Builder> m_l2Builder; //<! Pointer to TileL2Builder @@ -402,4 +401,4 @@ class TileAANtuple : public AthAlgorithm { int m_skipEvents; }; -#endif +#endif // TILEREC_TILEAANTUPLE_H diff --git a/TileCalorimeter/TileRec/src/TileAANtuple.cxx b/TileCalorimeter/TileRec/src/TileAANtuple.cxx index 069b40c5057d7f86b280688eb1b87f94d4cfa6ca..0fcc904c00e78a8001e3536f2bd8d3508d9d3403 100755 --- a/TileCalorimeter/TileRec/src/TileAANtuple.cxx +++ b/TileCalorimeter/TileRec/src/TileAANtuple.cxx @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ ///***************************************************************************** @@ -17,26 +17,12 @@ // //***************************************************************************** -// Gaudi includes -#include "GaudiKernel/ITHistSvc.h" - -//Atlas include -#include "AthenaKernel/errorcheck.h" -#include "xAODEventInfo/EventInfo.h" - -// Calo includes -#include "CaloDetDescr/CaloDetDescrElement.h" -#include "CaloDetDescr/MbtsDetDescrManager.h" -#include "Identifier/IdentifierHash.h" -#include "CaloIdentifier/TileID.h" - //Tile includes #include "TileRec/TileAANtuple.h" #include "TileIdentifier/TileHWID.h" #include "TileCalibBlobObjs/TileCalibUtils.h" #include "TileConditions/TileCablingService.h" #include "TileConditions/ITileBadChanTool.h" -#include "TileConditions/TileDCSSvc.h" #include "TileDetDescr/TileDetDescrManager.h" #include "TileConditions/TileCondToolEmscale.h" #include "TileEvent/TileDigitsContainer.h" @@ -49,6 +35,19 @@ #include "TileByteStream/TileBeamElemContByteStreamCnv.h" #include "TileL2Algs/TileL2Builder.h" +// Calo includes +#include "CaloDetDescr/CaloDetDescrElement.h" +#include "CaloDetDescr/MbtsDetDescrManager.h" +#include "Identifier/IdentifierHash.h" +#include "CaloIdentifier/TileID.h" + +//Atlas include +#include "AthenaKernel/errorcheck.h" +#include "xAODEventInfo/EventInfo.h" + +// Gaudi includes +#include "GaudiKernel/ITHistSvc.h" + #include "TTree.h" #include <iomanip> #include "boost/date_time/local_time/local_time.hpp" @@ -191,7 +190,6 @@ TileAANtuple::TileAANtuple(std::string name, ISvcLocator* pSvcLocator) , m_tileToolEmscale("TileCondToolEmscale") , m_beamInfo("TileBeamInfoProvider/TileBeamInfoProvider") , m_beamCnv(0) -, m_tileDCSSvc("TileDCSSvc",name) , m_l2Builder() , m_sumEt_xx() , m_sumEz_xx() @@ -205,7 +203,6 @@ TileAANtuple::TileAANtuple(std::string name, ISvcLocator* pSvcLocator) , m_bad() { declareProperty("TileCondToolEmscale", m_tileToolEmscale); - declareProperty("TileDCSSvc", m_tileDCSSvc); declareProperty("TileDigitsContainer", m_digitsContainer = "TileDigitsCnt"); declareProperty("TileDigitsContainerFlt", m_fltDigitsContainer = "" /* "TileDigitsFlt" */); declareProperty("TileBeamElemContainer", m_beamElemContainer = "TileBeamElemCnt"); @@ -239,7 +236,6 @@ TileAANtuple::TileAANtuple(std::string name, ISvcLocator* pSvcLocator) declareProperty("SkipEvents", m_skipEvents = 0); m_evtNr = -1; - m_DCScounter = 0; // LASERII memset(m_chan, 0, sizeof(m_chan)); @@ -283,42 +279,44 @@ StatusCode TileAANtuple::initialize() { m_cabling = TileCablingService::getInstance(); // retrieve TileDetDescr Manager det store - CHECK( detStore()->retrieve(m_tileMgr) ); + ATH_CHECK( detStore()->retrieve(m_tileMgr) ); // retrieve TileID helper from det store - CHECK( detStore()->retrieve(m_tileID) ); - CHECK( detStore()->retrieve(m_tileHWID) ); + ATH_CHECK( detStore()->retrieve(m_tileID) ); + ATH_CHECK( detStore()->retrieve(m_tileHWID) ); - //=== get TileDCSSvc + //=== get TileDCSTool if (m_checkDCS) { - CHECK( m_tileDCSSvc.retrieve() ); + ATH_CHECK( m_tileDCS.retrieve() ); + } else { + m_tileDCS.disable(); } //=== get TileBadChanTool - CHECK( m_tileBadChanTool.retrieve() ); + ATH_CHECK( m_tileBadChanTool.retrieve() ); //=== get TileCondToolEmscale - CHECK( m_tileToolEmscale.retrieve() ); + ATH_CHECK( m_tileToolEmscale.retrieve() ); //=== get TileBeamInfo - CHECK( m_beamInfo.retrieve() ); + ATH_CHECK( m_beamInfo.retrieve() ); //=== get TileL2Builder if (m_compareMode) { - CHECK( m_l2Builder.retrieve() ); + ATH_CHECK( m_l2Builder.retrieve() ); } //=== change properties of TileBeamInfo - to make sure that all parameters are consistent if (m_beamElemContainer.size() > 0) { - CHECK( m_beamInfo->setProperty("TileBeamElemContainer",m_beamElemContainer) ); + ATH_CHECK( m_beamInfo->setProperty("TileBeamElemContainer",m_beamElemContainer) ); } if (m_digitsContainer.size() > 0) { - CHECK( m_beamInfo->setProperty("TileDigitsContainer",m_digitsContainer) ); + ATH_CHECK( m_beamInfo->setProperty("TileDigitsContainer",m_digitsContainer) ); } if (m_dspRawChannelContainer.size() > 0) { - CHECK( m_beamInfo->setProperty("TileRawChannelContainer",m_dspRawChannelContainer) ); + ATH_CHECK( m_beamInfo->setProperty("TileRawChannelContainer",m_dspRawChannelContainer) ); } ATH_MSG_INFO( "initialization completed" ) ; @@ -379,7 +377,7 @@ StatusCode TileAANtuple::ntuple_initialize() { // set event number to 0 before first event m_evtNr = 0; - CHECK( m_thistSvc.retrieve() ); + ATH_CHECK( m_thistSvc.retrieve() ); if(initNTuple().isFailure()) { ATH_MSG_ERROR( " Error during ntuple initialization" ); @@ -546,7 +544,7 @@ StatusCode TileAANtuple::storeLaser() { ATH_MSG_DEBUG("TileAANtuple::storeLaser()"); const TileLaserObject* laserObj; - CHECK( evtStore()->retrieve(laserObj, m_laserObject) ); + ATH_CHECK( evtStore()->retrieve(laserObj, m_laserObject) ); m_las_BCID = laserObj->getBCID(); @@ -721,7 +719,7 @@ TileAANtuple::storeRawChannels(std::string containerId // get named container const TileRawChannelContainer* rcCnt; - CHECK( evtStore()->retrieve(rcCnt, containerId) ); + ATH_CHECK( evtStore()->retrieve(rcCnt, containerId) ); ATH_MSG_VERBOSE( "Conteiner ID " << containerId ); TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit(); @@ -890,7 +888,7 @@ TileAANtuple::storeRawChannels(std::string containerId if (m_compareMode && dspCont) { const TileL2Container* l2Cnt; - CHECK( evtStore()->retrieve(l2Cnt, "TileL2Cnt") ); + ATH_CHECK( evtStore()->retrieve(l2Cnt, "TileL2Cnt") ); TileL2Container::const_iterator it = l2Cnt->begin(); TileL2Container::const_iterator end= l2Cnt->end(); @@ -923,7 +921,7 @@ TileAANtuple::storeMFRawChannels(std::string containerId // get named container const TileRawChannelContainer* rcCnt; - CHECK( evtStore()->retrieve(rcCnt, containerId) ); + ATH_CHECK( evtStore()->retrieve(rcCnt, containerId) ); TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit(); ATH_MSG_VERBOSE( "RawChannel unit is " << rChUnit ); @@ -1094,7 +1092,7 @@ TileAANtuple::storeMFRawChannels(std::string containerId if (m_compareMode && dspCont) { const TileL2Container* l2Cnt; - CHECK( evtStore()->retrieve(l2Cnt, "TileL2Cnt") ); + ATH_CHECK( evtStore()->retrieve(l2Cnt, "TileL2Cnt") ); TileL2Container::const_iterator it = l2Cnt->begin(); TileL2Container::const_iterator end= l2Cnt->end(); @@ -1125,7 +1123,7 @@ TileAANtuple::storeDigits(std::string containerId // Read Digits from TES const TileDigitsContainer* digitsCnt; - CHECK( evtStore()->retrieve(digitsCnt, containerId) ); + ATH_CHECK( evtStore()->retrieve(digitsCnt, containerId) ); bool emptyColl = true; @@ -1304,7 +1302,7 @@ StatusCode TileAANtuple::storeTMDBDecision() { ATH_MSG_VERBOSE( "reading TMDB decision from " << m_tileMuRcvContainer ); const TileMuonReceiverContainer *decisionCnt; - CHECK( evtStore()->retrieve(decisionCnt, m_tileMuRcvContainer) ); + ATH_CHECK( evtStore()->retrieve(decisionCnt, m_tileMuRcvContainer) ); TileMuonReceiverContainer::const_iterator it = decisionCnt->begin(); TileMuonReceiverContainer::const_iterator itLast = decisionCnt->end(); @@ -1360,7 +1358,7 @@ StatusCode TileAANtuple::storeTMDBDigits() { ATH_MSG_VERBOSE( "reading TMDB digits from " << m_tileMuRcvDigitsContainer ); const TileDigitsContainer* digitsCnt; - CHECK( evtStore()->retrieve(digitsCnt, m_tileMuRcvDigitsContainer) ); + ATH_CHECK( evtStore()->retrieve(digitsCnt, m_tileMuRcvDigitsContainer) ); TileDigitsContainer::const_iterator itColl1 = (*digitsCnt).begin(); TileDigitsContainer::const_iterator itCollEnd1 = (*digitsCnt).end(); @@ -1432,7 +1430,7 @@ StatusCode TileAANtuple::storeTMDBRawChannel() { ATH_MSG_VERBOSE( "reading TMDB energies from " << m_tileMuRcvRawChannelContainer ); const TileRawChannelContainer* rcCnt; - CHECK( evtStore()->retrieve(rcCnt, m_tileMuRcvRawChannelContainer) ); + ATH_CHECK( evtStore()->retrieve(rcCnt, m_tileMuRcvRawChannelContainer) ); TileRawChannelContainer::const_iterator itColl2 = (*rcCnt).begin(); TileRawChannelContainer::const_iterator itCollEnd2 = (*rcCnt).end(); @@ -1520,7 +1518,7 @@ TileAANtuple::initNTuple(void) { CISPAR_addBranch(); if (m_laserObject.size() > 0) { const TileLaserObject* laserObj; - CHECK( evtStore()->retrieve(laserObj, m_laserObject) ); + ATH_CHECK( evtStore()->retrieve(laserObj, m_laserObject) ); m_las_version = laserObj->getVersion(); LASER_addBranch(); } @@ -2425,102 +2423,94 @@ void TileAANtuple::DCS_addBranch() { } } -StatusCode TileAANtuple::storeDCS() -{ - if (m_DCScounter != m_tileDCSSvc->getNcalls()) { - - ATH_MSG_DEBUG( "Filling DCS ntuple: cnt=" << m_DCScounter - <<" evtCnt=" << m_evtNr - << " evt=" << m_evt - << " lumi=" << m_lumiBlock << " " << m_dateTime ); - - m_DCScounter = m_tileDCSSvc->getNcalls(); - - CLEAR(m_TEMP); - CLEAR(m_HV); - CLEAR(m_HVSET); - CLEAR(m_DRSTATES); - CLEAR(m_HVSTATUS); - CLEAR(m_DRSTATUS); - CLEAR(m_CHSTATUS); - - m_nBadDr = 0; - m_nBadHV = 0; - m_nBadDCS = 0; - m_nBadDB = 0; - m_nBadTotal = 0; - for (int ROS = 1; ROS < 5; ++ROS) { - int rosI = ROS - 1; +StatusCode TileAANtuple::storeDCS() { + + ATH_MSG_DEBUG( "Filling DCS ntuple:" + <<" evtCnt=" << m_evtNr + << " evt=" << m_evt + << " lumi=" << m_lumiBlock << " " << m_dateTime ); + + CLEAR(m_TEMP); + CLEAR(m_HV); + CLEAR(m_HVSET); + CLEAR(m_DRSTATES); + CLEAR(m_HVSTATUS); + CLEAR(m_DRSTATUS); + CLEAR(m_CHSTATUS); + + m_nBadDr = 0; + m_nBadHV = 0; + m_nBadDCS = 0; + m_nBadDB = 0; + m_nBadTotal = 0; + for (int ROS = 1; ROS < 5; ++ROS) { + int rosI = ROS - 1; - for (int drawer = 0; drawer < 64; ++drawer) { - int module = drawer + 1; - m_DRSTATES[rosI][drawer] = m_tileDCSSvc->getDCSSTATES(ROS, module); - m_DRSTATUS[rosI][drawer] = m_tileDCSSvc->getDCSSTATUS(ROS, drawer); - bool drbad = m_tileDCSSvc->statusIsBad(ROS, drawer); + for (int drawer = 0; drawer < 64; ++drawer) { + m_DRSTATES[rosI][drawer] = m_tileDCS->getDrawerStates(ROS, drawer); + m_DRSTATUS[rosI][drawer] = m_tileDCS->getDCSStatus(ROS, drawer); + bool drbad = m_tileDCS->isStatusBad(ROS, drawer); - if (drbad) { - ++m_nBadDr; - } + if (drbad) { + ++m_nBadDr; + } - if (msgLvl(MSG::VERBOSE) || m_DRSTATUS[rosI][drawer] != TileDCSSvc::OK_DRAWER) { - ATH_MSG_VERBOSE( "Module=" << m_tileDCSSvc->partitionName(ROS) - << std::setw(2) << std::setfill('0') << module - << " DRSTATES=" << m_DRSTATES[rosI][drawer] - << " DRSTATUS=" << m_DRSTATUS[rosI][drawer] - << " => " << ((drbad) ? "bad" : "good") ); - } + if (msgLvl(MSG::VERBOSE) || m_DRSTATUS[rosI][drawer] != TileDCSState::OK_DRAWER) { + ATH_MSG_VERBOSE( "Module=" << TileCalibUtils::getDrawerString(ROS, drawer) + << " DRSTATES=" << m_DRSTATES[rosI][drawer] + << " DRSTATUS=" << m_DRSTATUS[rosI][drawer] + << " => " << ((drbad) ? "bad" : "good") ); + } - unsigned int drawerIdx = TileCalibUtils::getDrawerIdx(ROS,drawer); - for (int channel=0; channel<48; ++channel){ - TileBchStatus chStat = m_tileBadChanTool->getChannelStatus(drawerIdx,channel); - int pmt=abs(m_cabling->channel2hole(ROS,channel)); - m_HV[rosI][drawer][channel] = m_tileDCSSvc->getDCSHV(ROS, module, pmt); - m_HVSET[rosI][drawer][channel] = m_tileDCSSvc->getDCSHVSET(ROS, module, pmt); - m_HVSTATUS[rosI][drawer][channel] = m_tileDCSSvc->getDCSHVSTATUS(ROS, drawer, channel); - m_CHSTATUS[rosI][drawer][channel] = m_tileDCSSvc->getDCSSTATUS(ROS, drawer, channel) + unsigned int drawerIdx = TileCalibUtils::getDrawerIdx(ROS,drawer); + for (int channel=0; channel<48; ++channel){ + TileBchStatus chStat = m_tileBadChanTool->getChannelStatus(drawerIdx,channel); + int pmt=abs(m_cabling->channel2hole(ROS,channel)); + m_HV[rosI][drawer][channel] = m_tileDCS->getChannelHV(ROS, drawer, channel); + m_HVSET[rosI][drawer][channel] = m_tileDCS->getChannelHVSet(ROS, drawer, channel); + m_HVSTATUS[rosI][drawer][channel] = m_tileDCS->getDCSHVStatus(ROS, drawer, channel); + m_CHSTATUS[rosI][drawer][channel] = m_tileDCS->getDCSStatus(ROS, drawer, channel) + 100 * m_tileBadChanTool->encodeStatus(chStat); - bool chbad=m_tileDCSSvc->statusIsBad(ROS,drawer,channel); + bool chbad = m_tileDCS->isStatusBad(ROS, drawer, channel); - if (chbad || chStat.isBad()) { - ++m_nBadTotal; - if (chbad) ++m_nBadDCS; - if (chStat.isBad()) ++m_nBadDB; - } + if (chbad || chStat.isBad()) { + ++m_nBadTotal; + if (chbad) ++m_nBadDCS; + if (chStat.isBad()) ++m_nBadDB; + } - if (m_tileDCSSvc->statusHVIsBad(ROS,drawer,channel)) { - ++m_nBadHV; - } + if (m_tileDCS->isStatusHVBad(ROS, drawer, channel)) { + ++m_nBadHV; + } - if (msgLvl(MSG::VERBOSE) || (chbad && !drbad)) { - ATH_MSG_VERBOSE( "Module=" << m_tileDCSSvc->partitionName(ROS) - << std::setw(2) << std::setfill('0') << module - << " channel=" << channel << " pmt=" << pmt - << " HV=" << m_HV[rosI][drawer][channel] - << " HVSET=" << m_HVSET[rosI][drawer][channel] - << " HVSTATUS=" << m_HVSTATUS[rosI][drawer][channel] - << " CHSTATUS=" << m_CHSTATUS[rosI][drawer][channel] - << " => " << ((chbad) ? "bad" : "good") ); - } + if (msgLvl(MSG::VERBOSE) || (chbad && !drbad)) { + ATH_MSG_VERBOSE( "Module=" << TileCalibUtils::getDrawerString(ROS, drawer) + << " channel=" << channel << " pmt=" << pmt + << " HV=" << m_HV[rosI][drawer][channel] + << " HVSET=" << m_HVSET[rosI][drawer][channel] + << " HVSTATUS=" << m_HVSTATUS[rosI][drawer][channel] + << " CHSTATUS=" << m_CHSTATUS[rosI][drawer][channel] + << " => " << ((chbad) ? "bad" : "good") ); } + } - for (int ind=0; ind<7; ++ind){ - m_TEMP[rosI][drawer][ind] = m_tileDCSSvc->getDCSHV(ROS, module, ind+49); - ATH_MSG_VERBOSE( "Module=" << m_tileDCSSvc->partitionName(ROS) - << std::setw(2) << std::setfill('0') << module - << " TEMP" << ind+1 << "=" << m_TEMP[rosI][drawer][ind] ); + for (int ind=0; ind<7; ++ind){ + m_TEMP[rosI][drawer][ind] = m_tileDCS->getChannelHV(ROS, drawer, ind+49); + ATH_MSG_VERBOSE( "Module=" << TileCalibUtils::getDrawerString(ROS, drawer) + << " TEMP" << ind+1 << "=" << m_TEMP[rosI][drawer][ind] ); - } } } + } - ATH_MSG_DEBUG( "BAD status in DCS: nBadDr=" << m_nBadDr - << " nBadHV=" << m_nBadHV - << " nBadDCS=" << m_nBadDCS - << " nBadDB=" << m_nBadDB - << " nBadTotal=" << m_nBadTotal ); + ATH_MSG_DEBUG( "BAD status in DCS: nBadDr=" << m_nBadDr + << " nBadHV=" << m_nBadHV + << " nBadDCS=" << m_nBadDCS + << " nBadDB=" << m_nBadDB + << " nBadTotal=" << m_nBadTotal ); - m_DCSntuplePtr->Fill(); - } + m_DCSntuplePtr->Fill(); + return StatusCode::SUCCESS; } diff --git a/TileCalorimeter/TileRecAlgs/src/TileCellSelector.cxx b/TileCalorimeter/TileRecAlgs/src/TileCellSelector.cxx index b72e98da9b4f59e6ff47507c1c55080ad289d816..aeb8e3781025145b5648a38ee67feaa22576c0c9 100644 --- a/TileCalorimeter/TileRecAlgs/src/TileCellSelector.cxx +++ b/TileCalorimeter/TileRecAlgs/src/TileCellSelector.cxx @@ -11,7 +11,6 @@ #include "TileCalibBlobObjs/TileCalibUtils.h" #include "TileConditions/TileCablingService.h" #include "TileConditions/ITileBadChanTool.h" -#include "TileConditions/TileDCSSvc.h" // Calo includes #include "CaloIdentifier/TileID.h" @@ -53,7 +52,6 @@ TileCellSelector::TileCellSelector(const std::string& name, ISvcLocator* pSvcLoc , m_tileHWID(0) , m_cabling(0) , m_tileBadChanTool("TileBadChanTool") - , m_tileDCSSvc("TileDCSSvc",name) , m_runNum(0) , m_lumiBlock(0) , m_evtNum(0) @@ -142,15 +140,17 @@ StatusCode TileCellSelector::initialize() { ATH_CHECK( m_eventInfoKey.initialize() ); - CHECK(detStore()->retrieve(m_tileID, "TileID")); - CHECK(detStore()->retrieve(m_tileHWID, "TileHWID")); + ATH_CHECK(detStore()->retrieve(m_tileID, "TileID")); + ATH_CHECK(detStore()->retrieve(m_tileHWID, "TileHWID")); m_cabling = TileCablingService::getInstance(); - CHECK(m_tileBadChanTool.retrieve()); + ATH_CHECK(m_tileBadChanTool.retrieve()); if (m_checkDCS) { - CHECK(m_tileDCSSvc.retrieve()); + ATH_CHECK(m_tileDCS.retrieve()); + } else { + m_tileDCS.disable(); } ATH_MSG_INFO( "Cell container " @@ -320,7 +320,7 @@ StatusCode TileCellSelector::initialize() { m_drawerToSkip.resize(1+TileCalibUtils::getDrawerIdx(4,63),false); } - CHECK( m_dqStatusKey.initialize() ); + ATH_CHECK( m_dqStatusKey.initialize() ); return StatusCode::SUCCESS; } @@ -449,7 +449,7 @@ StatusCode TileCellSelector::execute() { int drmax = 65; for (int dr = 0; dr < drmax; ++dr) { int drawer = dr % 64; - if (m_tileDCSSvc->getDCSSTATUS(ros, drawer) == TileDCSSvc::ALERT_DRAWER) { + if (m_tileDCS->getDCSStatus(ros, drawer) == TileDCSState::ALERT_DRAWER) { if (m1 < 0) m1 = dr; m2 = dr; if (dr < 64) allmod.push_back((ros << 8) + dr); @@ -1194,7 +1194,7 @@ StatusCode TileCellSelector::execute() { int adc = m_tileHWID->adc(adcId); m_chanBad[hash] = m_tileBadChanTool->getAdcStatus(drawerIdx,channel,adc).isBad() || (DQstatus && !DQstatus->isAdcDQgood(ros,drawer,channel,adc)) || - (m_checkDCS && m_tileDCSSvc->getDCSSTATUS(ros,drawer,channel) > TileDCSSvc::WARNING); + (m_checkDCS && m_tileDCS->getDCSStatus(ros, drawer, channel) > TileDCSState::WARNING); } if (allowAmpCheck) { @@ -1426,7 +1426,7 @@ StatusCode TileCellSelector::execute() { ++nChBad; ++nChBadDmu[dmu]; } - } else if (m_checkDCS && m_tileDCSSvc->getDCSSTATUS(ros,drawer,channel) > TileDCSSvc::WARNING) { + } else if (m_checkDCS && m_tileDCS->getDCSStatus(ros, drawer, channel) > TileDCSState::WARNING) { badname = " BADDCS"; } else if (m_tileBadChanTool->getAdcStatus(drawerIdx,channel,adc).isBad()) { badname = " BADDB"; @@ -1788,7 +1788,7 @@ StatusCode TileCellSelector::execute() { badname = " BADDB"; } else if (DQstatus && !DQstatus->isAdcDQgood(ros, drawer, channel, adc)) { badname = " BADDQ"; - } else if (m_checkDCS && m_tileDCSSvc->getDCSSTATUS(ros, drawer, channel) > TileDCSSvc::WARNING) { + } else if (m_checkDCS && m_tileDCS->getDCSStatus(ros, drawer, channel) > TileDCSState::WARNING) { badname = " BADDCS"; } else if (m_chanBad[hash]) { if (badFromCell) { diff --git a/TileCalorimeter/TileRecAlgs/src/TileCellSelector.h b/TileCalorimeter/TileRecAlgs/src/TileCellSelector.h index 12cac4a132bfc976bb19e616cec092b7d432c2bc..c4356cddcec21a64415a9bd57000fba5a5949c7a 100644 --- a/TileCalorimeter/TileRecAlgs/src/TileCellSelector.h +++ b/TileCalorimeter/TileRecAlgs/src/TileCellSelector.h @@ -11,6 +11,7 @@ #include "TileEvent/TileDigitsContainer.h" #include "TileEvent/TileRawChannelContainer.h" #include "TileEvent/TileDQstatus.h" +#include "TileConditions/ITileDCSTool.h" // Calo includes #include "CaloEvent/CaloCellContainer.h" @@ -31,7 +32,6 @@ class TileHWID; class TileCell; class TileCablingService; class ITileBadChanTool; -class TileDCSSvc; ///////////////////////////////////////////////////////////////////////////// @@ -69,7 +69,7 @@ class TileCellSelector: public AthAlgorithm { const TileCablingService* m_cabling; ToolHandle<ITileBadChanTool> m_tileBadChanTool; //!< Tile Bad Channel tool SG::ReadHandleKey<TileDQstatus> m_dqStatusKey; - ServiceHandle<TileDCSSvc> m_tileDCSSvc; //!< Pointer to TileDCSSvc + ToolHandle<ITileDCSTool> m_tileDCS{this, "TileDCSTool", "TileDCSTool", "Tile DCS tool"}; unsigned int m_runNum; unsigned int m_lumiBlock; diff --git a/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter.py b/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter.py index dd28988cdc05e0d4083d528ad1a41450ed1d6578..0b58c45b3921778b6a8f54155e64bde872f052cd 100644 --- a/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter.py +++ b/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter.py @@ -56,7 +56,10 @@ class TileRawChannelGetter ( Configured) : from TileRecUtils.TileRecFlags import jobproperties from TileRecUtils.TileRecUtilsConf import TileBeamInfoProvider theTileBeamInfoProvider = TileBeamInfoProvider() - if hasattr( ServiceMgr, "TileDCSSvc" ): + + from AthenaCommon.AlgSequence import AthSequencer + condSequence = AthSequencer("AthCondSeq") + if hasattr(condSequence, 'TileDCSCondAlg'): theTileBeamInfoProvider.CheckDCS = True # true for real data, false for MC - GlobalFlags.DataSource.is_data() diff --git a/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter_DigiHSTruth.py b/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter_DigiHSTruth.py index 136d6fa045b2527620313982a72e9f507bbe6683..2bf19b5c5a2e5ba0592e5930c85c67e15206d568 100644 --- a/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter_DigiHSTruth.py +++ b/TileCalorimeter/TileRecUtils/python/TileRawChannelGetter_DigiHSTruth.py @@ -52,7 +52,10 @@ class TileRawChannelGetter_DigiHSTruth ( Configured) : from TileRecUtils.TileRecFlags import jobproperties from TileRecUtils.TileRecUtilsConf import TileBeamInfoProvider theTileBeamInfoProvider = TileBeamInfoProvider() - if hasattr( ServiceMgr, "TileDCSSvc" ): + + from AthenaCommon.AlgSequence import AthSequencer + condSequence = AthSequencer("AthCondSeq") + if hasattr(condSequence, 'TileDCSCondAlg'): theTileBeamInfoProvider.CheckDCS = True # true for nominal ATLAS configuration - GlobalFlags.DetGeo.is_atlas() diff --git a/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.cxx index 977e4f640ddd936bb5b2c2713ac56978e3a523bd..f65eabf31d87a8a4c44d68571590897a6b565c4c 100644 --- a/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.cxx +++ b/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.cxx @@ -40,7 +40,7 @@ StatusCode TileBeamElemDumper::initialize() * @brief Algorithm event processing. * @param ctx Event Context. */ -StatusCode TileBeamElemDumper::execute_r (const EventContext& ctx) const +StatusCode TileBeamElemDumper::execute (const EventContext& ctx) const { std::string fname = CxxUtils::strformat ("%s%s_%08u_%08lu.dump", m_prefix.value().c_str(), diff --git a/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.h b/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.h index 9dcf3b0b64d15b83279a9a0d945ea8b60b0a362f..2cc0c353cd1d524a107b9d848d0057e880040ec9 100644 --- a/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.h +++ b/TileCalorimeter/TileRecUtils/src/TileBeamElemDumper.h @@ -47,7 +47,7 @@ public: * @brief Algorithm event processing. * @param ctx Event Context. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/TileCalorimeter/TileRecUtils/src/TileBeamInfoProvider.cxx b/TileCalorimeter/TileRecUtils/src/TileBeamInfoProvider.cxx index 6d47670062537afc708c97eba837f083afd69979..2fc73007887c0e37a0d8ca0f24d66eaecdc0173b 100644 --- a/TileCalorimeter/TileRecUtils/src/TileBeamInfoProvider.cxx +++ b/TileCalorimeter/TileRecUtils/src/TileBeamInfoProvider.cxx @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ // TileCal includes @@ -234,6 +234,8 @@ void TileBeamInfoProvider::handle(const Incident& inc) { // retrive all containers from detector store and cache pointers for future use if (m_checkBeam) { + // Needed due to back-door setting of the property. + m_beamElemContainerKey.initialize().ignore(); SG::ReadHandle<TileBeamElemContainer> beamElemContainer(m_beamElemContainerKey); if (beamElemContainer.isValid()) { m_beamElemCnt = beamElemContainer.cptr(); diff --git a/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.cxx b/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.cxx index 562eececf444d418f1752ec1895bbe7924bca9f3..3b259a007585ccbdedd00360e534629feb267c0d 100644 --- a/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.cxx +++ b/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.cxx @@ -55,7 +55,7 @@ StatusCode TileDQstatusAlg::initialize() * @brief Gaudi execute method. * @param ctx Event context. */ -StatusCode TileDQstatusAlg::execute_r (const EventContext& ctx) const +StatusCode TileDQstatusAlg::execute (const EventContext& ctx) const { auto dqstatus = std::make_unique<TileDQstatus>(); diff --git a/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.h b/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.h index 29385046411b961ada01aa7e493b3451101eaa80..59d669ff21a49ec0ea5773f263bcbf13dabb2299 100644 --- a/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.h +++ b/TileCalorimeter/TileRecUtils/src/TileDQstatusAlg.h @@ -56,7 +56,7 @@ public: * @brief Gaudi execute method. * @param ctx Event context. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.cxx index 4584e32a62284f821dfb3437164195da32e98b7b..6c5e1cb20238e4f01c0606a79776f11f3a152661 100644 --- a/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.cxx +++ b/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.cxx @@ -43,7 +43,7 @@ StatusCode TileDigitsDumper::initialize() * @brief Algorithm event processing. * @param ctx Event Context. */ -StatusCode TileDigitsDumper::execute_r (const EventContext& ctx) const +StatusCode TileDigitsDumper::execute (const EventContext& ctx) const { if (!m_altContKey.key().empty()) { SG::ReadHandle<TileDigitsContainer> altCont (m_altContKey, ctx); diff --git a/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.h b/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.h index 501efd757fafbb9bca604cd30571c6c1d84a4a57..6a21a149ae025319b0adb2863a530459f1b89b20 100644 --- a/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.h +++ b/TileCalorimeter/TileRecUtils/src/TileDigitsDumper.h @@ -47,7 +47,7 @@ public: * @brief Algorithm event processing. * @param ctx Event Context. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/TileCalorimeter/TileRecUtils/src/TileL2Dumper.cxx b/TileCalorimeter/TileRecUtils/src/TileL2Dumper.cxx index 8a731996b690668dc72f9b8f4b1166c3d808f33d..e3f84153fd5cd46297ef3a9cab3f13178e1c56ae 100644 --- a/TileCalorimeter/TileRecUtils/src/TileL2Dumper.cxx +++ b/TileCalorimeter/TileRecUtils/src/TileL2Dumper.cxx @@ -40,7 +40,7 @@ StatusCode TileL2Dumper::initialize() * @brief Algorithm event processing. * @param ctx Event Context. */ -StatusCode TileL2Dumper::execute_r (const EventContext& ctx) const +StatusCode TileL2Dumper::execute (const EventContext& ctx) const { std::string fname = CxxUtils::strformat ("%s%s_%08u_%08lu.dump", m_prefix.value().c_str(), diff --git a/TileCalorimeter/TileRecUtils/src/TileL2Dumper.h b/TileCalorimeter/TileRecUtils/src/TileL2Dumper.h index 368379badfd1c636a38180bcfcfcd7ad7c085a61..d5c5a310a528b64aafe2b01d84b15c1d01b02e1c 100644 --- a/TileCalorimeter/TileRecUtils/src/TileL2Dumper.h +++ b/TileCalorimeter/TileRecUtils/src/TileL2Dumper.h @@ -47,7 +47,7 @@ public: * @brief Algorithm event processing. * @param ctx Event Context. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.cxx index c969c075ea18423f236276109e5a921ef759a8d5..da2754dc514eab0dd8ecacfe5bff018ea21dcc8b 100644 --- a/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.cxx +++ b/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.cxx @@ -41,7 +41,7 @@ StatusCode TileLaserObjectDumper::initialize() * @brief Algorithm event processing. * @param ctx Event Context. */ -StatusCode TileLaserObjectDumper::execute_r (const EventContext& ctx) const +StatusCode TileLaserObjectDumper::execute (const EventContext& ctx) const { std::string fname = CxxUtils::strformat ("%s%s_%08u_%08lu.dump", m_prefix.value().c_str(), diff --git a/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.h b/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.h index c953c0a2308182bd907a456dd9f60de0c689e683..ad458a8eda303683f856d85fac7d34258b5335ad 100644 --- a/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.h +++ b/TileCalorimeter/TileRecUtils/src/TileLaserObjectDumper.h @@ -47,7 +47,7 @@ public: * @brief Algorithm event processing. * @param ctx Event Context. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.cxx index d676d51ba1241f1e94b82e7c16e202b0cff8ded6..faf244c0cb9c1c5ab7c79cae06657cec3ec1fe03 100644 --- a/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.cxx +++ b/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.cxx @@ -41,7 +41,7 @@ StatusCode TileMuonReceiverDumper::initialize() * @brief Algorithm event processing. * @param ctx Event Context. */ -StatusCode TileMuonReceiverDumper::execute_r (const EventContext& ctx) const +StatusCode TileMuonReceiverDumper::execute (const EventContext& ctx) const { std::string fname = CxxUtils::strformat ("%s%s_%08u_%08lu.dump", m_prefix.value().c_str(), diff --git a/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.h b/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.h index 9af75e8b83cae941d92f6c45cd02d85d087bbb95..ad56a6e270a16dd67a9866d3cddd4c4ec58a0610 100644 --- a/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.h +++ b/TileCalorimeter/TileRecUtils/src/TileMuonReceiverDumper.h @@ -47,7 +47,7 @@ public: * @brief Algorithm event processing. * @param ctx Event Context. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.cxx b/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.cxx index 4879ff2be1024880ef18d6796803b6adb4ca47b0..0995c768dde11a3fcc4db3b7a2f94f3277ffc2b4 100644 --- a/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.cxx +++ b/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.cxx @@ -43,7 +43,7 @@ StatusCode TileRawChannelDumper::initialize() * @brief Algorithm event processing. * @param ctx Event Context. */ -StatusCode TileRawChannelDumper::execute_r (const EventContext& ctx) const +StatusCode TileRawChannelDumper::execute (const EventContext& ctx) const { if (!m_altContKey.key().empty()) { SG::ReadHandle<TileRawChannelContainer> altCont (m_altContKey, ctx); diff --git a/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.h b/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.h index 2e6e0fa0b5907752d563a05d03a53e4c4eac4065..0d27cd0b598d923bb887c0f904bce77f015851ba 100644 --- a/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.h +++ b/TileCalorimeter/TileRecUtils/src/TileRawChannelDumper.h @@ -47,7 +47,7 @@ public: * @brief Algorithm event processing. * @param ctx Event Context. */ - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; private: diff --git a/TileCalorimeter/TileSimUtils/CMakeLists.txt b/TileCalorimeter/TileSimUtils/CMakeLists.txt index 9a34e0affc3a41bccb2cd8b620dc7f5232d2d21f..340fa45d60796a87b6140536740d5aeb07887ac9 100644 --- a/TileCalorimeter/TileSimUtils/CMakeLists.txt +++ b/TileCalorimeter/TileSimUtils/CMakeLists.txt @@ -10,8 +10,6 @@ atlas_depends_on_subdirs( PUBLIC Calorimeter/CaloIdentifier Calorimeter/CaloSimEvent Control/AthenaBaseComps - Control/CLIDSvc - Control/SGTools GaudiKernel PRIVATE Control/AthenaKernel @@ -28,7 +26,7 @@ atlas_add_library( TileSimUtilsLib src/*.cxx PUBLIC_HEADERS TileSimUtils PRIVATE_INCLUDE_DIRS ${ROOT_INCLUDE_DIRS} - LINK_LIBRARIES CaloIdentifier CaloSimEvent AthenaBaseComps SGTools GaudiKernel StoreGateLib SGtests + LINK_LIBRARIES CaloIdentifier CaloSimEvent AthenaBaseComps GaudiKernel StoreGateLib SGtests PRIVATE_LINK_LIBRARIES ${ROOT_LIBRARIES} AthenaKernel ) atlas_add_component( TileSimUtils diff --git a/TileCalorimeter/TileSvc/TileByteStream/TileByteStream/TileROD_Decoder.h b/TileCalorimeter/TileSvc/TileByteStream/TileByteStream/TileROD_Decoder.h index 87150e0c552cf97a02eefa15ff912eeaa433ff3f..91d82bc2fc97e07e11e66318354ab2591d17902b 100644 --- a/TileCalorimeter/TileSvc/TileByteStream/TileByteStream/TileROD_Decoder.h +++ b/TileCalorimeter/TileSvc/TileByteStream/TileByteStream/TileROD_Decoder.h @@ -10,6 +10,7 @@ #include <string> #include <iostream> #include <cassert> +#include <atomic> #include <stdint.h> // Gaudi includes @@ -53,6 +54,35 @@ class TileCellBuilder; class TileL2Builder; class TileHid2RESrcID; +namespace TileROD_Helper { + + +// Helper to find the Tile container type corresponding to a container. +template <class COLLECTION> +struct ContainerForCollection {}; + +template <> +struct ContainerForCollection<TileBeamElemCollection> +{ + typedef TileBeamElemContainer type; +}; + +template <> +struct ContainerForCollection<TileDigitsCollection> +{ + typedef TileDigitsContainer type; +}; + +template <> +struct ContainerForCollection<TileRawChannelCollection> +{ + typedef TileRawChannelContainer type; +}; + + +} // namespace TileROD_Helper + + /** * * @class TileROD_Decoder @@ -113,7 +143,9 @@ class TileROD_Decoder: public AthAlgTool { /** This method calls the unpacking methods to decode the ROD data and fills the TileDigitsContainer and/or the TileRawChannelContainer */ - void fillCollection(const ROBData * rob, COLLECTION& v); + void fillCollection(const ROBData * rob, + COLLECTION& v, + typename TileROD_Helper::ContainerForCollection<COLLECTION>::type* container = nullptr); uint32_t fillCollectionHLT(const ROBData * rob, TileCellCollection & v, D0CellsHLT& d0cells); void fillCollectionL2(const ROBData * rob, TileL2Container & v); @@ -140,8 +172,6 @@ class TileROD_Decoder: public AthAlgTool { void mergeD0cellsHLT (const D0CellsHLT& d0cells, TileCellCollection&); - // Set Pointer to container with raw channels - inline void PtrRChContainer(TileRawChannelContainer * container) { m_container = container; } void loadRw2Pmt(const int section, const std::vector<int>& vec) { for (unsigned int i = 0; i < vec.size(); ++i) { // std::cout << vec[i] << std::endl; @@ -149,6 +179,7 @@ class TileROD_Decoder: public AthAlgTool { } } + // Error reporting void printErrorCounter(bool printIfNoError); int getErrorCounter(); @@ -417,24 +448,28 @@ class TileROD_Decoder: public AthAlgTool { DigitsMetaData_t& digitsMetaData, RawChannelMetaData_t& rawchannelMetaData, const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel, - TileBeamElemCollection& v) const; + TileBeamElemCollection& v, + TileBeamElemContainer* container) const; inline void make_copy(uint32_t bsflags, TileFragHash::TYPE rChType, TileRawChannelUnit::UNIT rChUnit, DigitsMetaData_t& digitsMetaData, RawChannelMetaData_t& rawchannelMetaData, const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel, - TileDigitsCollection& v) const; + TileDigitsCollection& v, + TileDigitsContainer* container) const; inline void make_copy(uint32_t bsflags, TileFragHash::TYPE rChType, TileRawChannelUnit::UNIT rChUnit, DigitsMetaData_t& digitsMetaData, RawChannelMetaData_t& rawchannelMetaData, const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel, - TileRawChannelCollection& v) const; + TileRawChannelCollection& v, + TileRawChannelContainer* container) const; uint32_t make_copyHLT(bool of2, TileRawChannelUnit::UNIT rChUnit, + bool correctAmplitude, pFRwChVec & pChannel, TileCellCollection& v, const uint16_t DQuality, D0CellsHLT& d0cells); @@ -520,9 +555,6 @@ class TileROD_Decoder: public AthAlgTool { bool m_of2Default; - // TileRawChannelContainer - TileRawChannelContainer * m_container; - bool m_maskBadDigits; // Pointer to a MBTS cell collection TileCellCollection* m_MBTS; @@ -538,9 +570,8 @@ class TileROD_Decoder: public AthAlgTool { TileL2Builder* m_L2Builder; std::string m_TileDefaultL2Builder; - int m_WarningCounter; - int m_ErrorCounter; - bool m_correctAmplitude; + mutable std::atomic<int> m_WarningCounter; + mutable std::atomic<int> m_ErrorCounter; TileHid2RESrcID * m_hid2re; TileHid2RESrcID * m_hid2reHLT; @@ -574,7 +605,7 @@ class TileROD_Decoder: public AthAlgTool { max_allowed_size = 0; if (size < 3 && size > 0) { if (rob->rod_source_id() > 0x50ffff) error |= 0x10000; // indicate error in frag size, but ignore error in laser ROD - if (m_WarningCounter < (m_maxWarningPrint--)) { + if (m_WarningCounter++ < m_maxWarningPrint) { ATH_MSG_WARNING("ROB " << MSG::hex << rob->source_id() << " ROD " << rob->rod_source_id() << MSG::dec << " has unexpected data size: " << size << " - assuming zero size " ); @@ -582,7 +613,7 @@ class TileROD_Decoder: public AthAlgTool { return 0; } else if (rob->rod_header_size_word() >= rob->rod_fragment_size_word()) { if (rob->rod_source_id() > 0x50ffff) error |= 0x10000; // indicate error in frag size, but ignore error in laser ROD - if (m_WarningCounter < (m_maxWarningPrint--)) { + if (m_WarningCounter++ < m_maxWarningPrint) { ATH_MSG_WARNING("ROB " << MSG::hex << rob->source_id() << " ROD " << rob->rod_source_id() << MSG::dec << " has unexpected header size: " << rob->rod_header_size_word() @@ -655,7 +686,9 @@ void TileROD_Decoder::make_copy(uint32_t /*bsflags*/, DigitsMetaData_t& digitsMetaData, RawChannelMetaData_t& /*rawchannelMetaData*/, const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel, - TileDigitsCollection & v) const { + TileDigitsCollection & v, + TileDigitsContainer* /*container*/) const +{ copy_vec(pDigits, v); // Digits stored if (pChannel.size() > 0) { // RawChannels deleted @@ -705,15 +738,16 @@ void TileROD_Decoder::make_copy(uint32_t bsflags, DigitsMetaData_t& /*digitsMetaData*/, RawChannelMetaData_t& rawchannelMetaData, const ROBData * rob, pDigiVec & pDigits, pRwChVec & pChannel, - TileRawChannelCollection & v) const { + TileRawChannelCollection & v, + TileRawChannelContainer* container) const { if (pChannel.size() > 0) { // take available raw channels // and store in collection - if (m_container) { + if (container) { ATH_MSG_VERBOSE( "RawChannel unit is " << rChUnit << " - setting unit in TileRawChannelContainer " ); - m_container->set_unit(rChUnit); - m_container->set_type(rChType); - m_container->set_bsflags(bsflags); + container->set_unit(rChUnit); + container->set_type(rChType); + container->set_bsflags(bsflags); } else { ATH_MSG_ERROR( "Can't set unit=" << rChUnit << " in TileRawChannelContainer" ); } @@ -788,8 +822,10 @@ void TileROD_Decoder::make_copy(uint32_t /*bsflags*/, TileRawChannelUnit::UNIT /*rChUnit*/, DigitsMetaData_t& /*digitsMetaData*/, RawChannelMetaData_t& /*rawchannelMetaData*/, - const ROBData * /* rob */, pDigiVec & pDigits - , pRwChVec & pChannel, TileBeamElemCollection &) const { + const ROBData * /* rob */, pDigiVec & pDigits, + pRwChVec & pChannel, TileBeamElemCollection &, + TileBeamElemContainer* /*container*/) const +{ // do nothing delete_vec(pDigits); delete_vec(pChannel); @@ -835,7 +871,10 @@ void TileROD_Decoder::make_copy(const ROBData * /* rob */, pBeamVec & pBeam, from a BLOCK of integers */ template<class COLLECTION> -void TileROD_Decoder::fillCollection(const ROBData * rob, COLLECTION & v) { +void TileROD_Decoder::fillCollection(const ROBData * rob, + COLLECTION & v, + typename TileROD_Helper::ContainerForCollection<COLLECTION>::type* container /*= nullptr*/) +{ // // get info from ROD header // @@ -1098,7 +1137,7 @@ void TileROD_Decoder::fillCollection(const ROBData * rob, COLLECTION & v) { } // end of all frags make_copy(bsflags, rChType, rChUnit, digitsMetaData, rawchannelMetaData, - rob, pDigits, pChannel, v); + rob, pDigits, pChannel, v, container); } return; diff --git a/TileCalorimeter/TileSvc/TileByteStream/src/TileROD_Decoder.cxx b/TileCalorimeter/TileSvc/TileByteStream/src/TileROD_Decoder.cxx index b53400efa7625766b225dd605ba52318215b0379..549197768eeb1922eaa21090094784c1ed257558 100644 --- a/TileCalorimeter/TileSvc/TileByteStream/src/TileROD_Decoder.cxx +++ b/TileCalorimeter/TileSvc/TileByteStream/src/TileROD_Decoder.cxx @@ -67,13 +67,11 @@ TileROD_Decoder::TileROD_Decoder(const std::string& type, const std::string& nam declareProperty("AllowedTimeMax", m_allowedTimeMax = 50.); // set amp to zero if time is above allowed time max declareProperty("fullTileMode", m_fullTileRODs); // run from which to take the cabling (for the moment, either 320000 - full 2017 mode - or 0 - 2016 mode) - m_correctAmplitude = false; updateAmpThreshold(15.); m_timeMinThresh = -25; m_timeMaxThresh = 25; - + m_of2Default = true; - m_container = 0; m_MBTS = NULL; m_cell2Double.reserve(23); // Maximum number of cells in a drawer m_WarningCounter = 0; @@ -3288,6 +3286,7 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect } } bool of2 = m_of2Default; + bool correctAmplitude = false; TileRawChannelUnit::UNIT rChUnit = TileRawChannelUnit::ADCcounts; uint16_t DQuality = 0x0; bool fragFound = false; @@ -3332,13 +3331,13 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect case 2: fragFound = true; DQfragMissing = false; - m_correctAmplitude = false; + correctAmplitude = false; unpack_frag2HLT(version, sizeOverhead, p, m_pRwChVec); break; case 3: fragFound = true; DQfragMissing = false; - m_correctAmplitude = false; + correctAmplitude = false; unpack_frag3HLT(version, sizeOverhead, p, m_pRwChVec); break; case 4: @@ -3352,13 +3351,13 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect of2 = ((idAndType & 0x4000000) != 0); int nIter = (idAndType & 0x3000000) >> 24; - m_correctAmplitude = (!nIter); // automatic detection of nIter + correctAmplitude = (!nIter); // automatic detection of nIter rChUnit = (TileRawChannelUnit::UNIT) (unit + TileRawChannelUnit::OnlineOffset); // Online units in real data } else { // simulated data DQfragMissing = false; - m_correctAmplitude = false; + correctAmplitude = false; rChUnit = (TileRawChannelUnit::UNIT) (unit); // Offline units in simulated data } @@ -3372,7 +3371,7 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect int unit = (idAndType & 0xC0000000) >> 30; of2 = ((idAndType & 0x4000000) != 0); - m_correctAmplitude = true; // fragment 5 will appear only if there is no iterations, so correction required + correctAmplitude = true; // fragment 5 will appear only if there is no iterations, so correction required rChUnit = (TileRawChannelUnit::UNIT) (unit + TileRawChannelUnit::OnlineOffset); unpack_frag5HLT(version, sizeOverhead, unit, p, m_pRwChVec); @@ -3399,7 +3398,8 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect if (fragFound) { if (masked_drawer) DQuality = 0x0; - error |= make_copyHLT(of2, rChUnit, m_pRwChVec, v, DQuality, d0cells); + error |= make_copyHLT(of2, rChUnit, correctAmplitude, + m_pRwChVec, v, DQuality, d0cells); } else if (!masked_drawer) error |= 0x20000; return error; @@ -3407,6 +3407,7 @@ uint32_t TileROD_Decoder::fillCollectionHLT(const ROBData * rob, TileCellCollect uint32_t TileROD_Decoder::make_copyHLT(bool of2, TileRawChannelUnit::UNIT rChUnit, + bool correctAmplitude, pFRwChVec & pChannel, TileCellCollection & v, const uint16_t DQuality, D0CellsHLT& d0cells) { @@ -3476,7 +3477,7 @@ uint32_t TileROD_Decoder::make_copyHLT(bool of2, TileRawChannelUnit::MegaElectronVolts); } // parabolic correction for good but slightly out-of-time signals - if (m_correctAmplitude) { + if (correctAmplitude) { if (time<m_allowedTimeMin || time>m_allowedTimeMax) { ener = 0.0F; time = 0.0F; @@ -3533,7 +3534,7 @@ uint32_t TileROD_Decoder::make_copyHLT(bool of2, TileRawChannelUnit::MegaElectronVolts); } // parabolic correction for good but slightly out-of-time signals - if (m_correctAmplitude) { + if (correctAmplitude) { if (time<m_allowedTimeMin || time>m_allowedTimeMax) { ener = 0.0F; time = 0.0F; @@ -3590,7 +3591,7 @@ uint32_t TileROD_Decoder::make_copyHLT(bool of2, rChUnit, TileRawChannelUnit::PicoCoulombs); } // parabolic correction for good but slightly out-of-time signals - if (m_correctAmplitude) { + if (correctAmplitude) { if (time<m_allowedTimeMin || time>m_allowedTimeMax) { ener = 0.0F; time = 0.0F; diff --git a/TileCalorimeter/TileSvc/TileByteStream/src/TileRawChannelContByteStreamCnv.cxx b/TileCalorimeter/TileSvc/TileByteStream/src/TileRawChannelContByteStreamCnv.cxx index 9606fec1e4d97cf879198d4785d53f9d6e9ed83f..9b22d6beb86e4a80b203b66fa0b1e84cc015ace1 100644 --- a/TileCalorimeter/TileSvc/TileByteStream/src/TileRawChannelContByteStreamCnv.cxx +++ b/TileCalorimeter/TileSvc/TileByteStream/src/TileRawChannelContByteStreamCnv.cxx @@ -80,7 +80,6 @@ StatusCode TileRawChannelContByteStreamCnv::initialize() { unit = TileRawChannelUnit::ADCcounts; m_containers[0] = new TileRawChannelContainer(true, type, unit); m_containers[0]->addRef(); // make sure it's not deleted at the end of event - m_decoder->PtrRChContainer( m_containers[0] ); type = TileFragHash::MF; unit = TileRawChannelUnit::ADCcounts; @@ -147,7 +146,7 @@ StatusCode TileRawChannelContByteStreamCnv::createObj(IOpaqueAddress* pAddr, Dat if (isTMDB) {// reid for TMDB 0x5x010x m_decoder->fillCollection_TileMuRcv_RawChannel(robf[0], *rawChannelCollection); } else { - m_decoder->fillCollection(robf[0], *rawChannelCollection); + m_decoder->fillCollection(robf[0], *rawChannelCollection, m_containers[icnt]); } } else { rawChannelCollection->setFragGlobalCRC(TileROD_Decoder::NO_ROB); diff --git a/TileCalorimeter/TileSvc/TileByteStream/test/TileROD_Decoder_test.cxx b/TileCalorimeter/TileSvc/TileByteStream/test/TileROD_Decoder_test.cxx index 276a313e66160d9bb5034f65a1b3ef28a5c8e9e6..3f928b283108b30861e25632d2140d60d39a9907 100644 --- a/TileCalorimeter/TileSvc/TileByteStream/test/TileROD_Decoder_test.cxx +++ b/TileCalorimeter/TileSvc/TileByteStream/test/TileROD_Decoder_test.cxx @@ -148,8 +148,7 @@ void test1 (TileROD_Decoder* decoder) { TileRawChannelContainer cont; TileRawChannelCollection coll (256); - decoder->PtrRChContainer (&cont); - decoder->fillCollection (&data01.rob(), coll); + decoder->fillCollection (&data01.rob(), coll, &cont); std::cout << "TileRawChannelCollection: " << coll.size() << " " << cont.get_unit() << " " << cont.get_type() << " " diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBAANtuple.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBAANtuple.h index c621ee26dbb61df9c211ab6f183c3dc807e1fe09..387c789acec95ba9d6d50f9495ec8a4cb07d2deb 100755 --- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBAANtuple.h +++ b/TileCalorimeter/TileTBRec/TileTBRec/TileTBAANtuple.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ //**************************************************************************** @@ -68,7 +68,6 @@ class TileHWID; class TileInfo; //class TileCablingSvc; class TileRawChannelBuilderFlatFilter; -class TileBeamInfoProvider; class TileBeamElemContByteStreamCnv; class TileLaserObject; class TileCondToolEmscale; @@ -534,8 +533,6 @@ class TileTBAANtuple: public AthAlgorithm { ToolHandle<TileCondToolEmscale> m_tileToolEmscale; //!< main Tile Calibration tool - ToolHandle<TileBeamInfoProvider> m_beamInfo; - TileBeamElemContByteStreamCnv* m_beamCnv; std::string m_currentNtupleLoc; diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBNtuple.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBNtuple.h deleted file mode 100755 index fa2e30a76f2e3dea230906e6537fcd27d17747b7..0000000000000000000000000000000000000000 --- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBNtuple.h +++ /dev/null @@ -1,348 +0,0 @@ -/* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration -*/ - -//**************************************************************************** -/// Filename : TileTBNtuple.h -/// Author : Paulo da Silva -/// Created : Oct, 2003 -/// -/// DESCRIPTION -/// -/// To create TB beam Ntuple file from Digits container -/// -/// Properties (JobOption Parameters): -/// -/// TileDigitsContainer string key value of Digits in TDS -/// TileBeamElemContainer string key of BeamElems in TDS -/// TileRawChannelContainerFlat key of flat filtered RawChannels in TDS -/// TileRawChannelContainerFit key of fit filtered RawChannels in TDS -/// CalibrateEnergy bool If calibration should be applied to energy -/// CalibMode bool If data is in calibration mode -/// NtupleLoc string pathname of ntuple file -/// NtupleID int ID of ntuple -/// BC1X1 float TDC Conv param -/// BC1X2 float TDC Conv param -/// BC1Y1 float TDC Conv param -/// BC1Y2 float TDC Conv param -/// BC1Z float TDC Conv param -/// BC2X1 float TDC Conv param -/// BC2X2 float TDC Conv param -/// BC2Y1 float TDC Conv param -/// BC2Y2 float TDC Conv param -/// BC2Z float TDC Conv param -/// -/// BUGS: -/// -/// History: -/// -// -//**************************************************************************** -#ifndef TileTBNtuple_H -#define TileTBNtuple_H - -// Gaudi includes -#include "GaudiKernel/NTuple.h" -#include "GaudiKernel/ToolHandle.h" -#include "GaudiKernel/ServiceHandle.h" - -// Athena includes -#include "AthenaBaseComps/AthAlgorithm.h" - -#include "TileConditions/TileCablingService.h" - -class TileID; -class TileHWID; -class TileInfo; -class TileRawChannelBuilderFlatFilter; -class TileBeamInfoProvider; -class TileBeamElemContByteStreamCnv; -class TileCondToolEmscale; - -#include "TTree.h" -#include <string> -#include <vector> -#include <map> - -/* @class TileTBNtuple - @brief Osolete Class to create Ntuples. Use TileTBAANtuple for rel> 13.0.10 - */ - -class TileTBNtuple: public AthAlgorithm { - public: - //Constructor - TileTBNtuple(std::string name, ISvcLocator* pSvcLocator); - - //Destructor - virtual ~TileTBNtuple(); - - //Gaudi Hooks - StatusCode initialize(); - StatusCode execute(); - StatusCode finalize(); - - private: - - StatusCode storeRawChannels(std::string cntID - , std::vector<NTuple::Array<float>*> * - , std::vector<NTuple::Array<float>*> * - , std::vector<NTuple::Array<float>*> * - , std::vector<NTuple::Array<float>*> *); - - StatusCode storeDigits(); - StatusCode storeBeamElements(); - StatusCode storeCells(); - - StatusCode initList(void); - StatusCode initNTuple(void); - StatusCode connectFile(void); - - void getEta(void); - - inline int digiChannel2PMT(int fragType, int chan) { - return (abs(m_cabling->channel2hole(fragType, chan)) - 1); - } - - // If data should be put in calib mode - bool m_calibMode; - - // The ntuple - NTuple::Tuple* m_ntuplePtr; - bool m_ntupleCreated; - - // event number - int m_evtNr; - - // Triger items - NTuple::Item<int> m_evTime; - NTuple::Item<int> m_run; - NTuple::Item<int> m_evt; - NTuple::Item<int> m_trigType; - - // 0 - Beam, 1 neg eta, 2 pos eta - NTuple::Array<int> m_l1ID; - NTuple::Array<int> m_l1Type; - NTuple::Array<int> m_evBCID; - NTuple::Array<int> m_evType; - - NTuple::Array<int> m_frBCID; - - // Muon items - NTuple::Item<float> m_muBackHit; - NTuple::Item<float> m_muBackSum; - NTuple::Array<float> m_muBack; // MUON/MuBack - NTuple::Array<float> m_muCalib; // MUON/MuCalib - - // Ecal - NTuple::Array<float> m_ecal; - - // laser items - NTuple::Item<int> m_lasFlag; - NTuple::Item<float> m_las0; - NTuple::Item<float> m_las1; - NTuple::Item<float> m_las2; - NTuple::Item<float> m_las3; - NTuple::Array<float> m_lasExtra; - - // pattern Unit in common beam crate - NTuple::Item<int> m_commonPU; - - // Adder items - NTuple::Matrix<int> m_adder; - //NTuple::Array<int> m_addx; - NTuple::Array<float> m_eneAdd; - NTuple::Array<float> m_timeAdd; - - // status - // NTuple::Matrix<float> m_status; - - // Cispar - NTuple::Array<int> m_cispar; - - // TDC/BEAM Items - NTuple::Item<int> m_s1cou; - NTuple::Item<int> m_s2cou; - NTuple::Item<int> m_s3cou; - NTuple::Item<int> m_cher1; - NTuple::Item<int> m_cher2; - NTuple::Item<int> m_muTag; - NTuple::Item<int> m_muHalo; - NTuple::Item<int> m_muVeto; - - NTuple::Item<int> m_s2extra; - NTuple::Item<int> m_s3extra; - - NTuple::Item<int> m_sc1; - NTuple::Item<int> m_sc2; - - NTuple::Array<int> m_tof; - NTuple::Array<int> m_btdc1; - NTuple::Array<int> m_btdc2; - - NTuple::Item<float> m_xChN2; - NTuple::Item<float> m_yChN2; - NTuple::Item<float> m_xChN1; - NTuple::Item<float> m_yChN1; - NTuple::Item<float> m_xCha0; - NTuple::Item<float> m_yCha0; - - NTuple::Item<float> m_xCha1; - NTuple::Item<float> m_yCha1; - NTuple::Item<float> m_xCha2; - NTuple::Item<float> m_yCha2; - NTuple::Item<float> m_xImp; - NTuple::Item<float> m_yImp; - - // Digi/Energy items - std::vector<NTuple::Item<int>*> m_evtVec; - std::vector<NTuple::Array<int>*> m_bcidVec; - std::vector<NTuple::Item<int>*> m_rodBCIDVec; - std::vector<NTuple::Item<int>*> m_sizeVec; - std::vector<NTuple::Array<int>*> m_dmuMaskVec; - std::vector<NTuple::Array<int>*> m_slinkCRCVec; - std::vector<NTuple::Array<int>*> m_gainVec; - std::vector<NTuple::Array<int>*> m_errVec; - std::vector<NTuple::Matrix<int>*> m_sampleVec; - std::vector<NTuple::Array<int>*> m_feCRCVec; //we use shorts, because vector<bool> is bugged - std::vector<NTuple::Array<int>*> m_rodCRCVec; - - std::vector<NTuple::Array<float>*> m_eneVec; - std::vector<NTuple::Array<float>*> m_timeVec; - std::vector<NTuple::Array<float>*> m_efitVec; - std::vector<NTuple::Array<float>*> m_tfitVec; - std::vector<NTuple::Array<float>*> m_pedfitVec; - std::vector<NTuple::Array<float>*> m_chi2Vec; - std::vector<NTuple::Array<float>*> m_eOptVec; - std::vector<NTuple::Array<float>*> m_tOptVec; - std::vector<NTuple::Array<float>*> m_pedOptVec; - std::vector<NTuple::Array<float>*> m_chi2OptVec; - std::vector<NTuple::Array<float>*> m_eDspVec; - std::vector<NTuple::Array<float>*> m_tDspVec; - std::vector<NTuple::Array<float>*> m_chi2DspVec; - - NTuple::Array<float> m_LarEne; - NTuple::Array<float> m_BarEne; - NTuple::Array<float> m_ExtEne; - NTuple::Array<float> m_GapEne; - - NTuple::Array<int> m_coincTrig1; - NTuple::Array<int> m_coincTrig2; - NTuple::Array<int> m_coincTrig3; - NTuple::Array<int> m_coincTrig4; - NTuple::Array<int> m_coincTrig5; - NTuple::Array<int> m_coincTrig6; - NTuple::Array<int> m_coincTrig7; - NTuple::Array<int> m_coincTrig8; - - NTuple::Item<int> m_coincFlag1; - NTuple::Item<int> m_coincFlag2; - NTuple::Item<int> m_coincFlag3; - NTuple::Item<int> m_coincFlag4; - NTuple::Item<int> m_coincFlag5; - NTuple::Item<int> m_coincFlag6; - NTuple::Item<int> m_coincFlag7; - NTuple::Item<int> m_coincFlag8; - - std::vector<std::string> m_rosName; // name of arrays in ntuple for different ROSes - std::vector<std::string> m_drawerList; // list of frag IDs in correct order - std::vector<int> m_drawerType; // type of every drawer 1-4: B+, B-, EB+, EB- - std::map<unsigned int, unsigned int, std::less<unsigned int> > m_drawerMap; // map for frag IDs -> index - - typedef std::map<unsigned int, unsigned int, std::less<unsigned int> >::iterator drawerMap_iterator; - - std::vector<std::string> m_beamFragList; // list of beam frag IDs to store in the ntuple - bool m_beamIdList[32]; // list of beam frag IDs to store in the ntuple - - // Params for Beam TDC - // Beam chambers -1 and -2 - float m_beamBN2X1; - float m_beamBN2X2; - float m_beamBN2Y1; - float m_beamBN2Y2; - float m_beamBN2Z; - - float m_beamBN1X1; - float m_beamBN1X2; - float m_beamBN1Y1; - float m_beamBN1Y2; - float m_beamBN1Z; - - // Beam chamber 0 - float m_beamBC0X1; - float m_beamBC0X2; - float m_beamBC0Y1; - float m_beamBC0Y2; - float m_beamBC0Z; - - // Beam chambers 1 and 2 - float m_beamBC1X1; - float m_beamBC1X2; - float m_beamBC1Y1; - float m_beamBC1Y2; - float m_beamBC1Z; - - float m_beamBC2X1; - float m_beamBC2X2; - float m_beamBC2Y1; - float m_beamBC2Y2; - float m_beamBC2Z; - float m_beamBC2Zperiod1; - float m_beamBC2Zperiod2; - - //run number - int m_runNumber; - float m_eta; - float m_theta; - std::string m_etaFileName; - - //inner radius of calo - float m_radius; - - // Container Parameters - std::string m_digitsContainer; - std::string m_beamElemContainer; - std::string m_flatRawChannelContainer; - std::string m_fitRawChannelContainer; - std::string m_fitcRawChannelContainer; - std::string m_optRawChannelContainer; - std::string m_dspRawChannelContainer; - std::string m_laserObject; - - bool m_calibrateEnergyThisEvent; - bool m_calibrateEnergy; - bool m_useDspUnits; - bool m_unpackAdder; - bool m_completeNtuple; - bool m_commitNtuple; - bool m_bsInput; - int m_finalUnit; - - // NTuple parameters - std::string m_ntupleID; - std::string m_ntupleLoc; - Long64_t m_treeSize; - int m_nSamples; - unsigned int m_nDrawers; - - ToolHandle<TileRawChannelBuilderFlatFilter> m_adderFilterAlgTool; - - // Identifiers - const TileID* m_tileID; - const TileHWID* m_tileHWID; - - const TileCablingService* m_cabling; - - ToolHandle<TileCondToolEmscale> m_tileToolEmscale; //!< main Tile Calibration tool - - ToolHandle<TileBeamInfoProvider> m_beamInfo; - - TileBeamElemContByteStreamCnv* m_beamCnv; - - std::string m_currentNtupleLoc; - int m_currentFileNum; - int m_eventsPerFile; - - std::string m_streamName; -}; - -#endif diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleRead.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleRead.h deleted file mode 100644 index 93b4fa08667bdc4f79c72d48a2ba732350895607..0000000000000000000000000000000000000000 --- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleRead.h +++ /dev/null @@ -1,90 +0,0 @@ -/* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration -*/ - -#ifndef TileTBOldNtupleRead_H -#define TileTBOldNtupleRead_H - -#include "AthenaBaseComps/AthAlgorithm.h" -#include "GaudiKernel/ToolHandle.h" - -// STL includes -#include <string> -#include <vector> - -// ROOT includes -#include "TFile.h" -#include "TTree.h" - -#include "TileConditions/TileCablingService.h" - -class StoreGateSvc; -class TileHWID; -class TileBeamInfoProvider; -class TileTBOldNtupleStruct; - -class TileTBOldNtupleRead : public AthAlgorithm { -public: - TileTBOldNtupleRead(std::string name, ISvcLocator* pSvcLocator); - virtual ~TileTBOldNtupleRead(); - - StatusCode initialize(); - StatusCode execute(); - StatusCode finalize(); - - int RunNumber() {return m_runNumber;} - int EventNumber() {return m_eventNumber;} - int EventShift(int dr) {return m_eventShift[dr];} - int TrigType() {return m_trigType;} - - int NSamp() {return m_nSamp;} - bool BiGain() {return m_bigain;} - - std::string& DigitsContainer() { return m_digitsContainer; } - std::string& BeamInfoContainer() { return m_beamContainer; } - - TTree* getNtuple() {return m_ntuple;} - - static TileTBOldNtupleRead * getInstance(); - -private: - - std::string m_ntupleID; - std::string m_ntupleDir; - std::string m_digitsContainer; - std::string m_beamContainer; - - bool m_bigain; - bool m_pmtOrder; - bool m_barrelOnly; - bool m_adderFit; - std::vector<int> m_eventShift; - - const TileHWID * m_tileHWID; - const TileCablingService * m_cabling; - ToolHandle<TileBeamInfoProvider> m_beamInfo; - - int m_runNumber; - int m_eventNumber; - int m_maxEventNumber; - int m_trigType; - int m_nSamp; - - TFile * m_file; - TTree * m_ntuple; - TileTBOldNtupleStruct * m_ntupleStruct; - - static TileTBOldNtupleRead * s_instance ; - - inline int digiChannel2PMT(int ros, int chan) { - return (abs(m_cabling->channel2hole(ros,chan))-1); - } - - inline int drawer2ros(int ros, int drawer) { - if (m_barrelOnly) return ros; - else return (drawer<2) ? ros : ros+2; - } - -}; - -#endif diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleWrite.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleWrite.h deleted file mode 100644 index c3c5154963f5484fdd87e0fdde52cd64f69363a9..0000000000000000000000000000000000000000 --- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBOldNtupleWrite.h +++ /dev/null @@ -1,77 +0,0 @@ -/* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration -*/ - -#ifndef TileTBOldNtupleWrite_H -#define TileTBOldNtupleWrite_H - -#include "AthenaBaseComps/AthAlgorithm.h" -#include "GaudiKernel/ToolHandle.h" - -// STL includes -#include <string> -#include <vector> - -// ROOT includes -#include "TFile.h" -#include "TTree.h" - -#include "TileConditions/TileCablingService.h" - -class TileTBOldNtupleRead; -class TileHWID; -class TileInfo; -class TileCondToolEmscale; - -class TileTBOldNtupleWrite : public AthAlgorithm { -public: - TileTBOldNtupleWrite(std::string name, ISvcLocator* pSvcLocator); - virtual ~TileTBOldNtupleWrite(); - - StatusCode initialize(); - StatusCode execute(); - StatusCode finalize(); - -private: - - std::string m_ntupleID; - std::string m_ntupleDir; - std::string m_digitsContainer; - std::string m_rawChannelContainerFit; - std::string m_rawChannelContainerFlat; - - bool m_bigain; - bool m_pmtOrder; - bool m_calibrateEnergy; - bool m_calibrateEnergyThisEvent; - - const TileHWID * m_tileHWID; - const TileCablingService * m_cabling; - - ToolHandle<TileCondToolEmscale> m_tileToolEmscale; //!< main Tile Calibration tool - - int m_runNumber; - int m_eventNumber; - int m_trigType; - - TFile * m_file; - TTree * m_ntupleWrite; - TTree * m_ntupleRead; - - TileTBOldNtupleRead * m_readNtupleAlg; - - inline int digiChannel2PMT(int ros, int chan) { - return (abs(m_cabling->channel2hole(ros,chan))-1); - } - - Float_t * BranchWriteNtuple(const std::string name); - - Float_t m_ene[2][6][48]; - Float_t m_time[2][6][48]; - Float_t m_efit[2][6][48]; - Float_t m_tfit[2][6][48]; - Float_t m_pedfit[2][6][48]; - Float_t m_chi2[2][6][48]; -}; - -#endif diff --git a/TileCalorimeter/TileTBRec/TileTBRec/TileTBStat.h b/TileCalorimeter/TileTBRec/TileTBRec/TileTBStat.h index dc409476dcbcc403459798eed52734bbf6a6baac..73fb9cf8f0de79954f42f2ab8ef49b65d17de158 100755 --- a/TileCalorimeter/TileTBRec/TileTBRec/TileTBStat.h +++ b/TileCalorimeter/TileTBRec/TileTBRec/TileTBStat.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ //**************************************************************************** @@ -37,11 +37,13 @@ // Athena incldues #include "AthenaBaseComps/AthAlgorithm.h" +#include "StoreGate/ReadHandleKey.h" + +#include "TileEvent/TileDQstatus.h" class IROBDataProviderSvc; class TileID; class TileHWID; -class TileBeamInfoProvider; class TileBeamElemContByteStreamCnv; #include <string> @@ -78,9 +80,9 @@ class TileTBStat: public AthAlgorithm { virtual ~TileTBStat(); //Gaudi Hooks - StatusCode initialize(); - StatusCode execute(); - StatusCode finalize(); + virtual StatusCode initialize() override; + virtual StatusCode execute() override; + virtual StatusCode finalize() override; private: @@ -90,11 +92,10 @@ class TileTBStat: public AthAlgorithm { bool m_printAllEvents; bool m_detectDummyFragments; + SG::ReadHandleKey<TileDQstatus> m_dqStatusKey; ServiceHandle<IROBDataProviderSvc> m_RobSvc; - ToolHandle<TileBeamInfoProvider> m_beamInfo; - TileBeamElemContByteStreamCnv* m_beamCnv; int m_evtNr; diff --git a/TileCalorimeter/TileTBRec/share/BeamNtuple_jobOptions.py b/TileCalorimeter/TileTBRec/share/BeamNtuple_jobOptions.py deleted file mode 100755 index 33e9a3ef0cf13266a1e72db1132640688cd28a11..0000000000000000000000000000000000000000 --- a/TileCalorimeter/TileTBRec/share/BeamNtuple_jobOptions.py +++ /dev/null @@ -1,51 +0,0 @@ -#------------------------------- -# Add beam elements to combined ntuple -#------------------------------- - -# if not loaded - load these DLLs -theApp.Dlls += [ "TileRecUtils", "TileTBRec" ] - -theApp.TopAlg += ["TileTBNtuple/BeamCrate"] -BeamCrate = Algorithm( "BeamCrate" ) - -BeamCrate.NTupleLoc = "/FILE1/TB" -BeamCrate.NTupleID = "tree" - -BeamCrate.drawerList = [ ] - -BeamCrate.beamFragList = ["0x001","0x002","0x003","0x007", - "0x010","0x011","0x012","0x013","0x014" ] - -BeamCrate.CompleteNtuple = FALSE -BeamCrate.CommitNtuple = FALSE - -BeamCrate.BN2X1 = 0.522 -BeamCrate.BN2X2 = 0.175 -BeamCrate.BN2Y1 = 1.44 -BeamCrate.BN2Y2 = 0.173 -BeamCrate.BN2Z = 1.0 - -BeamCrate.BN1X1 = -0.309 -BeamCrate.BN1X2 = 0.173 -BeamCrate.BN1Y1 = -0.561 -BeamCrate.BN1Y2 = 0.175 -BeamCrate.BN1Z = 1.0 - -BeamCrate.BC0X1 = -0.111 -BeamCrate.BC0X2 = 0.185 -BeamCrate.BC0Y1 = 0.028 -BeamCrate.BC0Y2 = 0.181 -BeamCrate.BC0Z = 1.0 - -BeamCrate.BC1X1 = -5.56 -BeamCrate.BC1X2 = 0.183 -BeamCrate.BC1Y1 = -3.04 -BeamCrate.BC1Y2 = 0.180 -BeamCrate.BC1Z = 15530.65 - -BeamCrate.BC2X1 = -2.22 -BeamCrate.BC2X2 = 0.195 -BeamCrate.BC2Y1 = 1.91 -BeamCrate.BC2Y2 = 0.188 -BeamCrate.BC2Z = 11227.9 - diff --git a/TileCalorimeter/TileTBRec/share/TileTBNtuple_jobOptions.py b/TileCalorimeter/TileTBRec/share/TileTBNtuple_jobOptions.py index a73c3b3f3f914aa323b18651736635850150be0d..43a918efd3e25c9b57ca88f1f10b311e9f61889a 100755 --- a/TileCalorimeter/TileTBRec/share/TileTBNtuple_jobOptions.py +++ b/TileCalorimeter/TileTBRec/share/TileTBNtuple_jobOptions.py @@ -42,6 +42,9 @@ TileTBNtuple.TileRawChannelContainerFit = "" TileTBNtuple.TileRawChannelContainerFitCool = "" TileTBNtuple.TileRawChannelContainerOpt = "" +#xxx TileDQstatusAlg.TileBeamElemContainer = 'TileBeamElemCnt' +#xxx TileDQstatusAlg.TileDigitsContainer = 'TileDigitsCnt' if TBPeriod != 2017 + if doSim: theApp.Dlls += [ "TileRecUtils", "TileByteStream" ] TileTBNtuple.BSInput = FALSE @@ -56,6 +59,8 @@ if doSim: # TileTBNtuple.TileRawChannelContainerFlat = "TileRawChannelCnt" TileTBNtuple.TileDigitsContainer = "" TileTBNtuple.TileBeamElemContainer = "" + #xxx TileDQstatusAlg.TileBeamElemContainer = '' + #xxx TileDQstatusAlg.TileDigitsContainer = '' if TBPeriod != 2017 TileTBNtuple.TileLaserObject = "" if TileBarrelOnly: TileTBNtuple.drawerList = [ "0x200", "0x201", "0x202", "0x100", "0x101", "0x102" ] diff --git a/TileCalorimeter/TileTBRec/share/jobOptions_TileTBNTuple.py b/TileCalorimeter/TileTBRec/share/jobOptions_TileTBNTuple.py index 078c57dfa04b3071438917c09e452ba3bf61aa5a..e3fd82a52121f63a79625932e23bcd4a7b76feda 100644 --- a/TileCalorimeter/TileTBRec/share/jobOptions_TileTBNTuple.py +++ b/TileCalorimeter/TileTBRec/share/jobOptions_TileTBNTuple.py @@ -4,6 +4,8 @@ # """This topOptions is intended to test the monitoring code""" #================================================================= +#xxx configure TileDQstatusAlg + from AthenaCommon.Logging import logging log_tbntuple = logging.getLogger( 'jobOptions_TileTBNtuple.py' ) @@ -116,6 +118,7 @@ if TileCisRun or TileMonoRun: # declare CIS tool(s) and set jobOptions if necessary TileCisTool = TileCisDefaultCalibTool() + # xxx set TileDQstatusAlg.TileRawChannelContainer="TileRawChannelCnt" if hasattr(ToolSvc, 'TileDigitsMon'): TileCisTool.StuckBitsProbsTool = ToolSvc.TileDigitsMon diff --git a/TileCalorimeter/TileTBRec/src/TileTBAANtuple.cxx b/TileCalorimeter/TileTBRec/src/TileTBAANtuple.cxx index 74bc40415bfb3185e67bf6983a8720535a2bcbcf..3c84692749ec936109c7073c14b0ce5bbb25ce60 100755 --- a/TileCalorimeter/TileTBRec/src/TileTBAANtuple.cxx +++ b/TileCalorimeter/TileTBRec/src/TileTBAANtuple.cxx @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ //***************************************************************************** @@ -43,7 +43,6 @@ #include "TileEvent/TileRawChannelContainer.h" #include "TileEvent/TileLaserObject.h" #include "TileRecUtils/TileRawChannelBuilderFlatFilter.h" -#include "TileRecUtils/TileBeamInfoProvider.h" #include "TileByteStream/TileBeamElemContByteStreamCnv.h" #include "TileByteStream/TileLaserObjByteStreamCnv.h" #include "TileEvent/TileHitContainer.h" @@ -228,7 +227,6 @@ TileTBAANtuple::TileTBAANtuple(std::string name, ISvcLocator* pSvcLocator) , m_tileInfo(0) , m_cabling(0) , m_tileToolEmscale("TileCondToolEmscale") - , m_beamInfo("TileBeamInfoProvider/TileBeamInfoProvider") , m_beamCnv(0) , m_currentFileNum(0) , m_eventsPerFile(0) @@ -384,13 +382,7 @@ StatusCode TileTBAANtuple::ntuple_initialize() { //=== get TileCondToolEmscale CHECK( m_tileToolEmscale.retrieve() ); - CHECK( m_beamInfo.retrieve() ); - - CHECK( m_beamInfo->setProperty("TileBeamElemContainer", m_beamElemContainer) ); - if (m_TBperiod != 2017) - CHECK( m_beamInfo->setProperty("TileDigitsContainer", m_digitsContainer) ); - if (m_TBperiod >= 2015) { m_unpackAdder = false; diff --git a/TileCalorimeter/TileTBRec/src/TileTBNtuple.cxx b/TileCalorimeter/TileTBRec/src/TileTBNtuple.cxx deleted file mode 100755 index a48b03963c7b79ab5f76c27dba3204ce6c165015..0000000000000000000000000000000000000000 --- a/TileCalorimeter/TileTBRec/src/TileTBNtuple.cxx +++ /dev/null @@ -1,2070 +0,0 @@ -/* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration -*/ - -//***************************************************************************** -// Filename : TileTBNtuple.cxx -// Author : Paulo da Silva -// Created : Oct, 2003 -// -// DESCRIPTION: -// Implement the algorithm to save TB Beam ROD dataX -// -// HISTORY: -// -// BUGS: -// -//***************************************************************************** - -// Athena includes -# include "AthenaKernel/errorcheck.h" - -//Event info -#include "xAODEventInfo/EventInfo.h" - -#include "PathResolver/PathResolver.h" -#include <cmath> - -//Calo includes -#include "CaloIdentifier/CaloCell_ID.h" -#include "CaloEvent/CaloCellContainer.h" -#include "CaloIdentifier/CaloID.h" - -//TileCalo includes -#include "CaloIdentifier/TileID.h" -#include "TileIdentifier/TileHWID.h" -#include "TileIdentifier/TileTBFrag.h" -#include "TileCalibBlobObjs/TileCalibUtils.h" -#include "TileConditions/TileCablingService.h" -#include "TileConditions/TileCondToolEmscale.h" -#include "TileEvent/TileDigitsContainer.h" -#include "TileEvent/TileBeamElemContainer.h" -#include "TileEvent/TileRawChannelContainer.h" -#include "TileRecUtils/TileRawChannelBuilderFlatFilter.h" -#include "TileRecUtils/TileBeamInfoProvider.h" -#include "TileByteStream/TileBeamElemContByteStreamCnv.h" -#include "TileTBRec/TileTBNtuple.h" - -#include <fstream> - -#define WRONG_SAMPLE(frag,chan,size) \ -msg(MSG::ERROR) << "Wrong no. of samples (" << size \ - << ") for channel " << chan \ - << " in frag 0x" << MSG::hex << frag << MSG::dec \ - << " - " << BeamFragName[frag&0x1F] << endmsg; - -#define WRONG_CHANNEL(frag,chan) \ -msg(MSG::ERROR) << "Wrong channel " << chan \ - << " in frag 0x" << MSG::hex << frag << MSG::dec \ - << " - " << BeamFragName[frag&0x1F] << endmsg; - -#define FRAG_FOUND(frag,chan,size) \ -if (msgLvl(MSG::DEBUG)) \ - msg(MSG::DEBUG) << "Found channel " << chan \ - << " in frag 0x" << MSG::hex << frag << MSG::dec \ - << " - " << BeamFragName[frag&0x1F] \ - << " of size " << size << endmsg; - - -#define SIGNAL_FOUND(frag,chan,amplitude) \ -if (msgLvl(MSG::DEBUG)) \ - msg(MSG::DEBUG) << "Found channel " << chan \ - << " in frag 0x" << MSG::hex << frag << MSG::dec \ - << " - " << BeamFragName[frag&0x1F] \ - << " with amp=" << amplitude << endmsg; - -// Constructor & deconstructor -/// OBSLETE CLASS: Please, use TileTBAANtuple for rel > 13.0.30. -// Constructor & deconstructor -/** @class TileTBNtuple - * @brief Obsolete class to produce commissioning ntuples. use TileTBAANtuple for rel > 13.0.30. - */ -TileTBNtuple::TileTBNtuple(std::string name, ISvcLocator* pSvcLocator) - : AthAlgorithm(name, pSvcLocator) - , m_calibMode(false) - , m_ntuplePtr(0) - , m_ntupleCreated(false) - , m_evtNr(0) - , m_beamBN2X1(0.0F) - , m_beamBN2X2(0.0F) - , m_beamBN2Y1(0.0F) - , m_beamBN2Y2(0.0F) - , m_beamBN2Z(0.0F) - , m_beamBN1X1(0.0F) - , m_beamBN1X2(0.0F) - , m_beamBN1Y1(0.0F) - , m_beamBN1Y2(0.0F) - , m_beamBN1Z(0.0F) - , m_beamBC0X1(0.0F) - , m_beamBC0X2(0.0F) - , m_beamBC0Y1(0.0F) - , m_beamBC0Y2(0.0F) - , m_beamBC0Z(0.0F) - , m_beamBC1X1(0.0F) - , m_beamBC1X2(0.0F) - , m_beamBC1Y1(0.0F) - , m_beamBC1Y2(0.0F) - , m_beamBC1Z(0.0F) - , m_beamBC2X1(0.0F) - , m_beamBC2X2(0.0F) - , m_beamBC2Y1(0.0F) - , m_beamBC2Y2(0.0F) - , m_beamBC2Z(0.0F) - , m_beamBC2Zperiod1(0.0F) - , m_beamBC2Zperiod2(0.0F) - , m_runNumber(0) - , m_eta(0.0F) - , m_theta(0.0F) - , m_radius(0.0F) - , m_calibrateEnergyThisEvent(false) - , m_calibrateEnergy(false) - , m_useDspUnits(false) - , m_unpackAdder(false) - , m_completeNtuple(false) - , m_commitNtuple(false) - , m_bsInput(false) - , m_finalUnit(0) - , m_treeSize(0) - , m_nSamples(0) - , m_nDrawers(0) - , m_adderFilterAlgTool("TileRawChannelBuilderFlatFilter/TileAdderFlatFilter",this) - , m_tileID(0) - , m_tileHWID(0) - , m_cabling(0) - , m_tileToolEmscale("TileCondToolEmscale") - , m_beamInfo("TileBeamInfoProvider/TileBeamInfoProvider") - , m_beamCnv(0) - , m_currentFileNum(0) -{ - declareProperty("TileCondToolEmscale", m_tileToolEmscale); - declareProperty("TileDigitsContainer", m_digitsContainer = "TileDigitsCnt"); - declareProperty("TileBeamElemContainer", m_beamElemContainer = "TileBeamElemCnt"); - declareProperty("TileRawChannelContainerFlat", m_flatRawChannelContainer = "TileRawChannelFlat"); - declareProperty("TileLaserObject", m_laserObject = ""); - declareProperty("TileRawChannelContainerFit", m_fitRawChannelContainer = ""); // don't create - declareProperty("TileRawChannelContainerFitCool", m_fitcRawChannelContainer = ""); // don't create - declareProperty("TileRawChannelContainerOpt", m_optRawChannelContainer = ""); // by default - declareProperty("TileRawChannelContainerDsp", m_dspRawChannelContainer = ""); // - declareProperty("CalibrateEnergy", m_calibrateEnergy = true); - declareProperty("UseDspUnits", m_useDspUnits = false); - declareProperty("OfflineUnits", m_finalUnit = 4); - declareProperty("CalibMode", m_calibMode = false); - declareProperty("UnpackAdder", m_unpackAdder = false); - declareProperty("CompleteNtuple", m_completeNtuple = true); - declareProperty("CommitNtuple", m_commitNtuple = true); - declareProperty("BSInput", m_bsInput = true); - - declareProperty("NTupleLoc", m_ntupleLoc = "/NTUPLES/FILE%d/TileRec"); - declareProperty("NTupleID", m_ntupleID = "h1000"); - declareProperty("TreeSize", m_treeSize = 16000000000LL); // dummy - - declareProperty("NSamples", m_nSamples = 9); - declareProperty("NDrawers", m_nDrawers = 6); - - declareProperty("EventsPerFile", m_eventsPerFile = 200000); - declareProperty("StreamName", m_streamName = ""); // dummy - -// m_drawerList.resize(6); m_drawerType.resize(6); -// m_drawerList[0] = "0x200"; m_drawerType[0] = 2; // barrel neg -// m_drawerList[1] = "0x201"; m_drawerType[1] = 2; // barrel neg -// m_drawerList[2] = "0x202"; m_drawerType[2] = 4; // ext barrel neg -// m_drawerList[3] = "0x100"; m_drawerType[3] = 1; // barrel pos -// m_drawerList[4] = "0x101"; m_drawerType[4] = 1; // barrel pos -// m_drawerList[5] = "0x102"; m_drawerType[5] = 3; // ext barrel pos - - m_drawerList.resize(1); m_drawerList[0] = "-1"; // setup drawer list from data - m_drawerType.clear(); // take drawer type from Frag ID (doesn't work for 2003) - m_drawerMap.clear(); // for 2003 need to use mapping given above - - char frg[6] = "0x000"; - m_beamFragList.clear(); - for (unsigned int i = 0; i < sizeof(m_beamIdList) / sizeof(bool); ++i) { - m_beamIdList[i] = false; - // no coins trig by default (this is the case for 2004) - if (i <= ECAL_ADC_FRAG || i >= COMMON_ADC1_FRAG) { - sprintf(frg, "0x%3.3x", i); - m_beamFragList.push_back((std::string) frg); - } - } - - m_rosName.push_back("B"); // 0 - this is beam rod name - m_rosName.push_back("A"); m_rosName.push_back("C"); - m_rosName.push_back("D"); m_rosName.push_back("E"); - - declareProperty("rosName", m_rosName); - declareProperty("drawerList", m_drawerList); - declareProperty("drawerType", m_drawerType); - declareProperty("beamFragList", m_beamFragList); - - declareProperty("BN2X1",m_beamBN2X1 = 0.0); - declareProperty("BN2X2",m_beamBN2X2 = 0.2); - declareProperty("BN2Y1",m_beamBN2Y1 = 0.0); - declareProperty("BN2Y2",m_beamBN2Y2 = 0.2); - declareProperty("BN2Z", m_beamBN2Z = 1.0); - - declareProperty("BN1X1",m_beamBN1X1 = 0.0); - declareProperty("BN1X2",m_beamBN1X2 = 0.2); - declareProperty("BN1Y1",m_beamBN1Y1 = 0.0); - declareProperty("BN1Y2",m_beamBN1Y2 = 0.2); - declareProperty("BN1Z", m_beamBN1Z = 1.0); - - declareProperty("BC0X1",m_beamBC0X1 = 0.0); - declareProperty("BC0X2",m_beamBC0X2 = 0.2); - declareProperty("BC0Y1",m_beamBC0Y1 = 0.0); - declareProperty("BC0Y2",m_beamBC0Y2 = 0.2); - declareProperty("BC0Z", m_beamBC0Z = 17138.0); - - declareProperty("BC1X1",m_beamBC1X1 =-0.938); - declareProperty("BC1X2",m_beamBC1X2 = 0.1747); - declareProperty("BC1Y1",m_beamBC1Y1 = 0.125); - declareProperty("BC1Y2",m_beamBC1Y2 = 0.1765); - declareProperty("BC1Z", m_beamBC1Z = 13788.0); - - declareProperty("BC2X1",m_beamBC2X1 =-0.9369); - declareProperty("BC2X2",m_beamBC2X2 = 0.191); - declareProperty("BC2Y1",m_beamBC2Y1 =-1.29); - declareProperty("BC2Y2",m_beamBC2Y2 = 0.187); - declareProperty("BC2Z", m_beamBC2Z = 9411.0); - - // for CTB 2004 only - declareProperty("BC2Zperiod1", m_beamBC2Zperiod1 = 9411.0); - declareProperty("BC2Zperiod2", m_beamBC2Zperiod2 = 12188.0); - - declareProperty("Radius", m_radius = 2280.0); - declareProperty("EtaFileName", m_etaFileName = "TileEtaCTB.txt"); - - m_eta=0.0; - m_theta=0.0; - m_runNumber=0; -} - - -TileTBNtuple::~TileTBNtuple() { -} - -// Alg standard interface function -StatusCode TileTBNtuple::initialize() { - - // find TileCablingService - m_cabling = TileCablingService::getInstance(); - - // retrieve TileID helper from det store - - CHECK( detStore()->retrieve(m_tileID) ); - - CHECK( detStore()->retrieve(m_tileHWID) ); - - //=== get TileCondToolEmscale - CHECK( m_tileToolEmscale.retrieve() ); - - CHECK( m_beamInfo.retrieve() ); - - CHECK( m_beamInfo->setProperty("TileBeamElemContainer", m_beamElemContainer) ); - CHECK( m_beamInfo->setProperty("TileDigitsContainer", m_digitsContainer) ); - - if (m_unpackAdder) { - // get TileRawChannelBuilderFlatFilter for adder energy calculation - CHECK( m_adderFilterAlgTool.retrieve() ); - - m_adderFilterAlgTool->setProperty("TileRawChannelContainer", "TileAdderFlat"); - m_adderFilterAlgTool->setProperty("calibrateEnergy", "true"); - - m_adderFilterAlgTool->setProperty("PedStart", "0"); - m_adderFilterAlgTool->setProperty("PedLength", "1"); - m_adderFilterAlgTool->setProperty("PedOffset", "0"); - m_adderFilterAlgTool->setProperty("SignalStart", "1"); - m_adderFilterAlgTool->setProperty("SignalLength", "15"); - m_adderFilterAlgTool->setProperty("FilterLength", "5"); - m_adderFilterAlgTool->setProperty("FrameLength", "16"); - m_adderFilterAlgTool->setProperty("DeltaCutLo", "9.5"); - m_adderFilterAlgTool->setProperty("DeltaCutHi", "9.5"); - m_adderFilterAlgTool->setProperty("RMSCutLo", "1.0"); - m_adderFilterAlgTool->setProperty("RMSCutHi", "1.0"); - - } - - ATH_MSG_INFO( "calibMode " << m_calibMode ); - ATH_MSG_INFO( "calibrateEnergy " << m_calibrateEnergy ); - ATH_MSG_INFO( "number of samples " << m_nSamples ); - - - msg(MSG::INFO) << "drawerList " << MSG::hex; - unsigned int size = m_drawerList.size(); - for (unsigned int dr = 0; dr < size; ++dr) { - int frag = strtol(m_drawerList[dr].data(), NULL, 0); - if (frag >= 0) { - m_drawerMap[frag] = dr; - if (dr == m_drawerType.size()) m_drawerType.push_back(frag >> 8); - msg(MSG::INFO) << " 0x" << frag; - } else { - msg(MSG::INFO) << " " << m_drawerList[dr]; - // put negative number in first element (flag to read frag ID from data) - m_drawerList[0] = m_drawerList[dr]; - m_drawerList.resize(1); - // m_drawerType.clear(); - m_drawerMap.clear(); - size = 0; - break; - } - } - - if (size == 0) { - if (m_drawerList.size() > 0) - msg(MSG::INFO) << " - negative number, will read frag IDs from the data" << MSG::dec << endmsg; - else - msg(MSG::INFO) << "is empty, no drawer fragments in ntuple" << MSG::dec << endmsg; - } else { - msg(MSG::INFO) << MSG::dec << endmsg; - - size = m_drawerType.size(); - if (size < m_nDrawers) { - m_drawerType.resize(m_nDrawers); - for (; size < m_nDrawers; ++size) - m_drawerType[size] = 0; - } - - msg(MSG::INFO) << "drawerType "; - for (unsigned int dr = 0; dr < size; ++dr) - msg(MSG::INFO) << " " << m_drawerType[dr]; - msg(MSG::INFO) << endmsg; - - if (size > m_nDrawers) { - ATH_MSG_INFO( "increasing m_nDrawers from " << m_nDrawers << " to " << size ); - m_nDrawers = size; - } - - } - - msg(MSG::INFO) << "Beam Frag List " << MSG::hex; - size = m_beamFragList.size(); - for (unsigned int dr = 0; dr < size; ++dr) { - int frag = strtol(m_beamFragList[dr].data(), NULL, 0); - if (frag >= 0) { - m_beamIdList[frag & 0x1F] = true; - msg(MSG::INFO) << " 0x" << frag; - } - } - - if (size == 0) { - msg(MSG::INFO) << "is empty, no beam fragments in ntuple" << MSG::dec << endmsg; - } else { - msg(MSG::INFO) << MSG::dec << endmsg; - } - - // set event number to 0 before first event - m_evtNr = 0; - m_currentFileNum = 0; - - m_calibrateEnergyThisEvent = m_calibrateEnergy; - - if (connectFile().isFailure()) { - ATH_MSG_ERROR( " Can't open file for Ntuple " ); - } - - ATH_MSG_INFO( "initialization completed" ); - - return StatusCode::SUCCESS; -} - -StatusCode TileTBNtuple::execute() { - - if (m_evtNr % 1000 == 0) - ATH_MSG_INFO( m_evtNr << " events processed so far" ); - - if (m_eventsPerFile > 0 && m_evtNr % m_eventsPerFile == 0 && m_evtNr > 0) { - ATH_MSG_INFO( "Booking ntuple in new file" ); - - if (connectFile().isFailure()) { - ATH_MSG_ERROR( " Can't open file for Ntuple " ); - } else if (!m_ntupleCreated) { - if (initNTuple().isFailure()) { - ATH_MSG_ERROR( " Error during ntuple initialization" ); - } - } - } - - /// find event and beam ROD header, calib mode for digitizers - - /// if first event: determine mode (normal or calib) - /// by examining the first TileDigitCollection - /// initialize NTuple accordingly - if (m_evtNr == 0) { - - if (m_bsInput) { - ServiceHandle<IConversionSvc> cnvSvc("ByteStreamCnvSvc", ""); - if (cnvSvc.retrieve().isFailure()) { - ATH_MSG_ERROR( " Can't get ByteStreamCnvSvc " ); - m_beamCnv = NULL; - } else { - - m_beamCnv = dynamic_cast<TileBeamElemContByteStreamCnv *>(cnvSvc->converter(ClassID_traits<TileBeamElemContainer>::ID())); - - if (m_beamCnv == NULL) { - ATH_MSG_ERROR( " Can't get TileBeamElemContByteStreamCnv " ); - } - } - } else { - m_beamCnv = NULL; - } - - if (!m_ntupleCreated) { - - bool calibMode = (m_beamInfo->calibMode() == 1); - if (calibMode != m_calibMode) { - ATH_MSG_INFO( "Calib mode from data is " ); - ATH_MSG_INFO( " Overwriting calib mode " ); - m_calibMode = calibMode; - } - - if (initList().isFailure()) { - ATH_MSG_ERROR( " Error during drawer list initialization" ); - } - - if (initNTuple().isFailure()) { - ATH_MSG_ERROR( " Error during ntuple initialization" ); - } - } - - if (m_unpackAdder) // in 2003 event number starts from 1 - ++m_evtNr; - } - - // store BeamElements - bool empty = storeBeamElements().isFailure(); - - if (m_drawerMap.size() > 0) { - - // store TileDigits - if (m_nSamples > 0) { - empty &= (storeDigits().isFailure()); - } - - // store TileRawChannels - empty &= (storeRawChannels(m_fitRawChannelContainer, &m_efitVec, &m_tfitVec, &m_chi2Vec, &m_pedfitVec).isFailure()); - empty &= (storeRawChannels(m_flatRawChannelContainer, &m_eneVec, &m_timeVec, 0, 0).isFailure()); - empty &= (storeRawChannels(m_optRawChannelContainer, &m_eOptVec, &m_tOptVec, &m_chi2OptVec, &m_pedOptVec).isFailure()); - empty &= (storeRawChannels(m_dspRawChannelContainer, &m_eDspVec, &m_tDspVec, &m_chi2DspVec, 0).isFailure()); - } - - if (m_completeNtuple) { - // store energy per sampling from all calorimeters - empty &= (storeCells().isFailure()); - } - - if (m_beamCnv) { - m_evTime = m_beamCnv->eventFragment()->bc_time_seconds(); - m_evt = m_beamCnv->eventFragment()->global_id(); - // m_runNo = m_beamCnv->eventFragment()->run_no(); // run_no is 0 here - if (m_beamCnv->validBeamFrag()) - m_run = m_beamCnv->robFragment()->rod_run_no(); // take it from beam ROD header - else - m_run = 0; - } else { - m_evTime = 0; - m_evt = m_evtNr; - m_run = 0; - } - - if (m_commitNtuple) { - /// Commit ntuple if collections are nonempty - /// or we share ntuple with somebody else and have to commit in any case - if (!empty || m_ntupleCreated) { - ATH_MSG_DEBUG( "Commiting Ntuple" ); - CHECK( ntupleSvc()->writeRecord(m_ntuplePtr) ); - } else - ATH_MSG_DEBUG( "No data stored for event " << m_evtNr << ", collections are empty" ); - } - /// increase event nr - /// this number can be different from real event number if we skip events - ++m_evtNr; - - // Execution completed. - ATH_MSG_DEBUG( "execute() completed successfully" ); - - return StatusCode::SUCCESS; -} - -StatusCode TileTBNtuple::storeBeamElements() { - - - if (m_beamElemContainer.size() == 0) return StatusCode::SUCCESS; - - const TileBeamElemContainer* BeamElemCnt; - CHECK( evtStore()->retrieve(BeamElemCnt, m_beamElemContainer) ); - - TileBeamElemContainer::const_iterator collItr = BeamElemCnt->begin(); - TileBeamElemContainer::const_iterator lastColl = BeamElemCnt->end(); - - if (m_completeNtuple) { - // Store ROD header info from collection (just from first one) - if (collItr != lastColl) { - m_l1ID[m_nDrawers] = (*collItr)->getLvl1Id(); - m_l1Type[m_nDrawers] = (*collItr)->getLvl1Type(); - m_evType[m_nDrawers] = (*collItr)->getDetEvType(); - m_evBCID[m_nDrawers] = (*collItr)->getRODBCID(); - } else { - m_l1ID[m_nDrawers] = 0xFFFFFFFF; - m_l1Type[m_nDrawers] = 0xFFFFFFFF; - m_evType[m_nDrawers] = 0xFFFFFFFF; - m_evBCID[m_nDrawers] = 0xFFFFFFFF; - } - } - - m_trigType = 0; - - for (; collItr != lastColl; ++collItr) { - - TileBeamElemCollection::const_iterator beamItr = (*collItr)->begin(); - TileBeamElemCollection::const_iterator lastBeam = (*collItr)->end(); - - if (msgLvl(MSG::VERBOSE)) { - - for (; beamItr != lastBeam; ++beamItr) { - HWIdentifier id = (*beamItr)->adc_HWID(); - std::vector<uint32_t> digits = (*beamItr)->get_digits(); - msg(MSG::VERBOSE) << " --- TileBeamElem -- Identifier " << m_tileHWID->to_string(id) << " " - << (*beamItr)->get_digits().size() << " " << digits.size() << endmsg; - - msg(MSG::VERBOSE) << MSG::VERBOSE << " --- TileBeamElem -- BeamElem : " << MSG::dec; - for (unsigned int k = 0; k < digits.size(); k++) - msg(MSG::VERBOSE) << digits[k] << " "; - msg(MSG::VERBOSE) << endmsg; - } - - //restore iterator - beamItr = (*collItr)->begin(); - } - - int frag = (*collItr)->identify(); - ATH_MSG_DEBUG( " frag: " << frag ); - ATH_MSG_DEBUG( " trigType " << (*collItr)->getLvl1Type() ); - - if ( m_trigType == 0 && (*collItr)->getLvl1Type() != 0 ) // take it from the ROD header - m_trigType = (*collItr)->getLvl1Type(); - - // unpack only fragments which we want to store in ntuple - if (m_beamIdList[frag & 0x1F]) { - - for (; beamItr != lastBeam; ++beamItr) { - - HWIdentifier id = (*beamItr)->adc_HWID(); - std::vector<uint32_t> digits = (*beamItr)->get_digits(); - int cha = m_tileHWID->channel(id); - int dsize = digits.size(); - - if (dsize <= 0) { - - WRONG_SAMPLE(frag, cha, dsize); - - } else if (dsize != 16 && frag == ADD_FADC_FRAG) { - - WRONG_SAMPLE(frag, cha, dsize); - - } else if (dsize != 1 && frag != ADD_FADC_FRAG - && frag != BEAM_TDC_FRAG && frag != COMMON_TDC1_FRAG - && frag != COMMON_TOF_FRAG && frag != COMMON_TDC2_FRAG) { - - WRONG_SAMPLE(frag, cha, dsize); - - } else { - - int amplitude = digits[0]; - SIGNAL_FOUND(frag, cha, amplitude); - - switch (frag) { - - case BEAM_TDC_FRAG: - - FRAG_FOUND(frag, cha, dsize); - if (cha < 8) m_btdc1[cha] = amplitude; - else if (cha < 16) m_btdc2[cha - 8] = amplitude; - else WRONG_CHANNEL(frag, cha); - break; - - case BEAM_ADC_FRAG: - - if (m_unpackAdder) { - switch (cha) { - // BEAM - case 0: - m_s1cou = amplitude; - break; - case 1: - m_s2cou = amplitude; - break; - case 2: - m_s3cou = amplitude; - break; - case 3: - m_cher1 = amplitude; - break; // swap of Cher1 - case 4: - m_muTag = amplitude; - break; // and S4 in 2003 data - case 5: - m_cher2 = amplitude; - break; - case 6: - m_muHalo = amplitude; - break; - case 7: - m_muVeto = amplitude; - break; - // LASER - case 8: - m_las0 = amplitude; - break; - case 9: - m_las1 = amplitude; - break; - case 10: - m_las2 = amplitude; - break; - case 11: - m_las3 = amplitude; - break; - case 12: - m_lasExtra[0] = amplitude; - break; - case 13: - m_lasExtra[1] = amplitude; - break; - case 14: - m_lasExtra[2] = amplitude; - break; - case 15: - m_lasExtra[3] = amplitude; - break; - default: - WRONG_CHANNEL(frag, cha); - } - } else { // 2004 data - switch (cha) { - // BEAM - case 0: - m_sc1 = amplitude; - break; - case 1: - m_sc2 = amplitude; - break; - case 2: - case 3: - case 4: - case 5: - case 6: - case 7: - break; - default: - WRONG_CHANNEL(frag, cha); - } - } - break; - - case MUON_ADC_FRAG: - - // first 14 are m_muBack - if (cha < 14) m_muBack[cha] = amplitude; - // last 2 are m_muCalib - else if (cha < 16) m_muCalib[cha - 14] = amplitude; - else WRONG_CHANNEL(frag, cha); - break; - - case ADDR_ADC_FRAG: - - // second half of Muon Wall in 2004 - if (cha < 6) m_muBack[cha + 8] = amplitude; - // last 2 are m_muCalib - else if (cha < 8) m_muCalib[cha - 6] = amplitude; - else WRONG_CHANNEL(frag, cha); - break; - - case LASE_PTN_FRAG: - - if (cha == 0) { - // laser pattern unit - m_lasFlag = amplitude; - if (amplitude & 0xFF00) m_trigType = amplitude >> 8; - } else { - WRONG_CHANNEL(frag, cha); - } - break; - - case LASE_ADC_FRAG: - - // laser in 2004 - switch (cha) { - case 0: - m_las0 = amplitude; - break; - case 1: - m_las1 = amplitude; - break; - case 2: - m_las2 = amplitude; - break; - case 3: - m_las3 = amplitude; - break; - case 4: - m_lasExtra[0] = amplitude; - break; - case 5: - m_lasExtra[1] = amplitude; - break; - case 6: - m_lasExtra[2] = amplitude; - break; - case 7: - m_lasExtra[3] = amplitude; - break; - default: - WRONG_CHANNEL(frag, cha); - } - break; - - case ADD_FADC_FRAG: - - if (m_unpackAdder) { - - for (int k = 0; k < dsize; k++) { - //m_addx[k]=k; - m_adder[cha][k] = digits[k]; - } - // FlatFiler adders - double ene, tim; - m_adderFilterAlgTool->flatFilter(digits, 0, ene, tim); - m_eneAdd[cha] = ene; - m_timeAdd[cha] = tim; - } - break; - - case ECAL_ADC_FRAG: - - if (cha < 8) - m_ecal[cha] = amplitude; - else - WRONG_CHANNEL(frag, cha); - break; - - case DIGI_PAR_FRAG: - - if (cha < 16) - m_cispar[cha] = amplitude; - else - WRONG_CHANNEL(frag, cha); - break; - - case COMMON_ADC1_FRAG: - - switch (cha) { - // BEAM - case 0: - m_s1cou = amplitude; - break; - case 1: - m_s2cou = amplitude; - break; - case 2: - m_s3cou = amplitude; - break; - case 3: - m_muTag = amplitude; - break; - case 4: - m_cher1 = amplitude; - break; - case 5: - m_cher2 = amplitude; - break; - case 6: - m_muHalo = amplitude; - break; - case 7: - m_muVeto = amplitude; - break; - default: - WRONG_CHANNEL(frag, cha); - } - break; - - case COMMON_ADC2_FRAG: - - if (!m_unpackAdder) { - switch (cha) { - // BEAM - case 0: - break; - case 1: - m_s2extra = amplitude; - break; - case 2: - m_s3extra = amplitude; - break; - case 3: - case 4: - case 5: - case 6: - case 7: - break; - default: - WRONG_CHANNEL(frag, cha); - } - } - break; - - case COMMON_PTN_FRAG: - - if (cha == 0) - m_commonPU = amplitude; - else - WRONG_CHANNEL(frag, cha); - break; - - case COMMON_TOF_FRAG: - - if (cha < 8) - m_tof[cha] = amplitude; - else - WRONG_CHANNEL(frag, cha); - break; - - case COMMON_TDC1_FRAG: - - FRAG_FOUND(frag, cha, dsize); - if (cha < 16) m_btdc1[cha] = amplitude; - else WRONG_CHANNEL(frag, cha); - break; - - case COMMON_TDC2_FRAG: - - FRAG_FOUND(frag, cha, dsize); - if (cha < 16) m_btdc2[cha] = amplitude; - else WRONG_CHANNEL(frag, cha); - break; - - case COIN_TRIG1_FRAG: - - if (cha < 3) { - int idx = cha * 32; - for (int ibit = 0; ibit < 32; ++ibit) { - m_coincTrig1[idx++] = (amplitude >> ibit) & 1; - } - } else if (cha == 3) { - m_coincFlag1 = amplitude; - } else - WRONG_CHANNEL(frag, cha); - break; - - case COIN_TRIG2_FRAG: - - if (cha < 3) { - int idx = cha * 32; - for (int ibit = 0; ibit < 32; ++ibit) { - m_coincTrig2[idx++] = (amplitude >> ibit) & 1; - } - } else if (cha == 3) { - m_coincFlag2 = amplitude; - } else - WRONG_CHANNEL(frag, cha); - break; - - case COIN_TRIG3_FRAG: - - if (cha < 3) { - int idx = cha * 32; - for (int ibit = 0; ibit < 32; ++ibit) { - m_coincTrig3[idx++] = (amplitude >> ibit) & 1; - } - } else if (cha == 3) { - m_coincFlag3 = amplitude; - } else - WRONG_CHANNEL(frag, cha); - break; - - case COIN_TRIG4_FRAG: - - if (cha < 3) { - int idx = cha * 32; - for (int ibit = 0; ibit < 32; ++ibit) { - m_coincTrig4[idx++] = (amplitude >> ibit) & 1; - } - } else if (cha == 3) { - m_coincFlag4 = amplitude; - } else - WRONG_CHANNEL(frag, cha); - break; - - case COIN_TRIG5_FRAG: - - if (cha < 3) { - int idx = cha * 32; - for (int ibit = 0; ibit < 32; ++ibit) { - m_coincTrig5[idx++] = (amplitude >> ibit) & 1; - } - } else if (cha == 3) { - m_coincFlag5 = amplitude; - } else - WRONG_CHANNEL(frag, cha); - break; - - case COIN_TRIG6_FRAG: - - if (cha < 3) { - int idx = cha * 32; - for (int ibit = 0; ibit < 32; ++ibit) { - m_coincTrig6[idx++] = (amplitude >> ibit) & 1; - } - } else if (cha == 3) { - m_coincFlag6 = amplitude; - } else - WRONG_CHANNEL(frag, cha); - break; - - case COIN_TRIG7_FRAG: - - if (cha < 3) { - int idx = cha * 32; - for (int ibit = 0; ibit < 32; ++ibit) { - m_coincTrig7[idx++] = (amplitude >> ibit) & 1; - } - } else if (cha == 3) { - m_coincFlag7 = amplitude; - } else - WRONG_CHANNEL(frag, cha); - break; - - case COIN_TRIG8_FRAG: - - if (cha < 3) { - int idx = cha * 32; - for (int ibit = 0; ibit < 32; ++ibit) { - m_coincTrig8[idx++] = (amplitude >> ibit) & 1; - } - } else if (cha == 3) { - m_coincFlag8 = amplitude; - } else - WRONG_CHANNEL(frag, cha); - break; - - default: - break; - } - } - } - } - } - - // calculate beam coords in Beam Chambers - if (m_unpackAdder) { // this is 2003 data - - if (m_beamIdList[BEAM_TDC_FRAG]) { - m_xCha1 = m_beamBC1X1 + m_beamBC1X2 * (m_btdc1[6] - m_btdc1[7]); // last two channels of TDC !!! - m_yCha1 = m_beamBC1Y1 + m_beamBC1Y2 * (m_btdc1[2] - m_btdc1[3]); - m_xCha2 = m_beamBC2X1 + m_beamBC2X2 * (m_btdc2[0] - m_btdc2[1]); - m_yCha2 = m_beamBC2Y1 + m_beamBC2Y2 * (m_btdc2[2] - m_btdc2[3]); - - m_xImp = m_xCha2 + (m_xCha2 - m_xCha1) * m_beamBC2Z / (m_beamBC1Z - m_beamBC2Z); - m_yImp = m_yCha2 + (m_yCha2 - m_yCha1) * m_beamBC2Z / (m_beamBC1Z - m_beamBC2Z); - } - - } else { // this is 2004 data - - if (m_beamIdList[COMMON_TDC1_FRAG]) { - m_yChN2 = m_beamBN2Y1 + m_beamBN2Y2 * (m_btdc1[0] - m_btdc1[1]); - m_xChN2 = m_beamBN2X1 + m_beamBN2X2 * (m_btdc1[2] - m_btdc1[3]); - m_yChN1 = m_beamBN1Y1 + m_beamBN1Y2 * (m_btdc1[4] - m_btdc1[5]); - m_xChN1 = m_beamBN1X1 + m_beamBN1X2 * (m_btdc1[6] - m_btdc1[7]); - - m_yCha0 = m_beamBC0Y1 + m_beamBC0Y2 * (m_btdc1[8] - m_btdc1[9]); - m_xCha0 = m_beamBC0X1 + m_beamBC0X2 * (m_btdc1[10] - m_btdc1[11]); - - if (msgLvl(MSG::DEBUG)) { - msg(MSG::DEBUG) << "BC-2x : ( " << m_btdc1[2] << " - " << m_btdc1[3] << " )\t" << static_cast<float>(m_xChN2) << endmsg; - msg(MSG::DEBUG) << "BC-2y : ( " << m_btdc1[0] << " - " << m_btdc1[1] << " )\t" << static_cast<float>(m_yChN2) << endmsg; - msg(MSG::DEBUG) << "BC-1x : ( " << m_btdc1[6] << " - " << m_btdc1[7] << " )\t" << static_cast<float>(m_xChN1) << endmsg; - msg(MSG::DEBUG) << "BC-1y : ( " << m_btdc1[4] << " - " << m_btdc1[5] << " )\t" << static_cast<float>(m_yChN1) << endmsg; - msg(MSG::DEBUG) << "BC0x : ( " << m_btdc1[10] << " - " << m_btdc1[11] << " )\t" << static_cast<float>(m_xCha0) << endmsg; - msg(MSG::DEBUG) << "BC0y : ( " << m_btdc1[8] << " - " << m_btdc1[9] << " )\t" << static_cast<float>(m_yCha0) << endmsg; - } - - } - - if (m_beamIdList[COMMON_TDC2_FRAG]) { - m_yCha1 = m_beamBC1Y1 + m_beamBC1Y2 * (m_btdc2[0] - m_btdc2[1]); - m_xCha1 = m_beamBC1X1 + m_beamBC1X2 * (m_btdc2[2] - m_btdc2[3]); - m_yCha2 = m_beamBC2Y1 + m_beamBC2Y2 * (m_btdc2[4] - m_btdc2[5]); - m_xCha2 = m_beamBC2X1 + m_beamBC2X2 * (m_btdc2[6] - m_btdc2[7]); - - m_xImp = 0.0; - m_yImp = 0.0; - if (msgLvl(MSG::DEBUG)) { - msg(MSG::DEBUG) << "BC1x : ( " << (int) m_btdc2[2] << " - " << (int) m_btdc2[3] << " )\t" << (float) m_xCha1 << endmsg; - msg(MSG::DEBUG) << "BC1y : ( " << (int) m_btdc2[0] << " - " << (int) m_btdc2[1] << " )\t" << (float) m_yCha1 << endmsg; - msg(MSG::DEBUG) << "BC2x : ( " << (int) m_btdc2[6] << " - " << (int) m_btdc2[7] << " )\t" << (float) m_xCha2 << endmsg; - msg(MSG::DEBUG) << "BC2y : ( " << (int) m_btdc2[4] << " - " << (int) m_btdc2[5] << " )\t" << (float) m_yCha2 << endmsg; - } - } - - if ( m_beamIdList[COMMON_TDC1_FRAG] && m_beamIdList[COMMON_TDC2_FRAG] ) { - - //////////////////////////////////////////////// - // Get run number and eta - if ( 0==m_runNumber ){ - const xAOD::EventInfo* eventInfo(0); - if (evtStore()->retrieve(eventInfo).isFailure()){ - ATH_MSG_ERROR( "No EventInfo object found! Can't read run number!" ); - m_runNumber = -1; - } else { - m_runNumber = eventInfo->runNumber(); - getEta(); - } - } - //////////////////////////////////////////////// - - // Computation of X,Y imp on TileCal/LAr front - float tanBx = (m_xCha1 - m_xCha0) / (m_beamBC0Z - m_beamBC1Z); - float tanBy = (m_yCha1 - m_yCha0) / (m_beamBC0Z - m_beamBC1Z); - - float Ximp = m_xCha1 + m_beamBC1Z * tanBx; - float Yimp = m_yCha1 + m_beamBC1Z * tanBy; - - if (0.0 != cos(m_theta) * (1 + tanBx * tan(m_theta))) { - m_xImp = (Ximp + m_radius * (tanBx * (cos(m_theta) - 1) - sin(m_theta))) / (cos(m_theta) * (1 + tanBx * tan(m_theta))); - m_yImp = Yimp + tanBy * (m_radius * (1 - cos(m_theta)) - Ximp * sin(m_theta)) / (cos(m_theta) * (1 + tanBx * tan(m_theta))); - } - } - } - - - // do not apply Cesium and Laser calibration for CIS events - m_calibrateEnergyThisEvent = m_calibrateEnergy && (m_trigType != 8); - - return StatusCode::SUCCESS; -} - -/** - * Fill ntuple with data from TRC. - * Default TRC container contains flat filtered and - * named container fitted/opt filtered - */ -StatusCode TileTBNtuple::storeRawChannels(std::string containerId - , std::vector<NTuple::Array<float>*> *eneVec - , std::vector<NTuple::Array<float>*> *timeVec - , std::vector<NTuple::Array<float>*> *chi2Vec - , std::vector<NTuple::Array<float>*> *pedVec) { - - - if (containerId.size() == 0) // empty name, nothing to do - return StatusCode::FAILURE; - - // get named container - const TileRawChannelContainer* rcCnt; - CHECK( evtStore()->retrieve(rcCnt, containerId) ); - - TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit(); - - // Get iterator for all TRCColl in TRCCont - TileRawChannelContainer::const_iterator itColl = (*rcCnt).begin(); - TileRawChannelContainer::const_iterator itCollEnd = (*rcCnt).end(); - - TileRawChannelCollection::const_iterator it, itEnd; - - // type is 0 - m_nDrawers-1, fragType is 1-4 B+/B-/EB+/EB- - int type, fragType; - - // Go through all TileRawChannelCollections - for (; itColl != itCollEnd; ++itColl) { - // determine type - int fragId = (*itColl)->identify(); - int drawerIdx = TileCalibUtils::getDrawerIdxFromFragId(fragId); - drawerMap_iterator itr = m_drawerMap.find(fragId); - if (itr != m_drawerMap.end()) { - type = (*itr).second; - } else { - type = -1; - } - - if (type < 0) { - if ((*itColl)->begin() != (*itColl)->end()) - ATH_MSG_WARNING( "frag id 0x" << MSG::hex << fragId << MSG::dec << " was not found among valid frag IDs when storing TRC!" ); - - } else { - fragType = m_drawerType[type]; - ATH_MSG_DEBUG( "TRC (" << containerId - << ") Event# " << m_evtNr - << " Frag id 0x" << MSG::hex << fragId << MSG::dec - << " index " << type ); - - // go through all TileRawChannels in collection - it = (*itColl)->begin(); - itEnd = (*itColl)->end(); - - for (; it != itEnd; ++it) { - HWIdentifier hwid = (*it)->adc_HWID(); - int index = type; - - // determine channel and gain - int channel = m_tileHWID->channel(hwid); - int gain = m_tileHWID->adc(hwid); - - if (m_calibMode) { - // gain, if hi add m_nDrawers to index - if (gain == 1) index += m_nDrawers; - } - - /// Cesium and Laser calibration - /// we assume that CIS calibration was done already in Opt. filtering - /// and we have already energy in pCb - /// after cesium calibration we still have the same pCb for A and BC cells - /// what we do is just set the same scale for D-cells - double energy = (*it)->amplitude(); - if (m_calibrateEnergyThisEvent) { // convert to GeV and not MeV ! - energy = m_tileToolEmscale->channelCalib(drawerIdx, channel, gain, energy, rChUnit, TileRawChannelUnit::MegaElectronVolts) / 1000.; - } - - // cabling for testbeam (convert to pmt#-1) - if (fragType > 0) channel = digiChannel2PMT(fragType, channel); - - (*(*eneVec)[index])[channel] = energy; - (*(*timeVec)[index])[channel] = (*it)->time(); - if (chi2Vec != 0) (*(*chi2Vec)[index])[channel] = (*it)->quality(); - if (pedVec != 0) (*(*pedVec)[index])[channel] = (*it)->pedestal(); - - ATH_MSG_DEBUG( "TRC ene=" << energy - << " time=" << (*it)->time() - << " chi2=" << (*it)->quality() - << " ped=" << (*it)->pedestal() - << " pmt-1=" << channel - << " index " << index ); - - } - } - } - - return StatusCode::SUCCESS; -} - -/** - * Fill Ntuple with info from TileDigits - * Return true if the collection is empty, - * which means that there are no RawChanels either. - */ -StatusCode TileTBNtuple::storeDigits() { - - bool emptyColl = true; - - // Read Digits from TDS - const TileDigitsContainer *digitsCnt; - CHECK( evtStore()->retrieve(digitsCnt, m_digitsContainer) ); - - // Get iterator for all TDColl in TDCont - TileDigitsContainer::const_iterator itColl = (*digitsCnt).begin(); - TileDigitsContainer::const_iterator itCollEnd = (*digitsCnt).end(); - - TileDigitsCollection::const_iterator it, itEnd; - - // type is 0 - m_nDrawers-1, fragType is 1-4 B+/B-/EB+/EB- - int n, type, fragType, channel; - - std::vector<float> sampleVec; - std::vector<uint32_t> headerVec; - std::vector<uint32_t> headerVecHi; - uint32_t CRCmask; - uint32_t fe_crc; - uint32_t rod_crc; - - // Go through all TileDigitsCollections - for (; itColl != itCollEnd; itColl++) { - // determine type of frag - int fragId = (*itColl)->identify(); - drawerMap_iterator itr = m_drawerMap.find(fragId); - if (itr != m_drawerMap.end()) { - type = (*itr).second; - } else { - type = -1; - } - - if (type < 0) { - if ((*itColl)->begin() != (*itColl)->end()) - ATH_MSG_WARNING( "frag id 0x" << MSG::hex << fragId << MSG::dec << " was not found among valid frag IDs when storing TRC!" ); - } else { - fragType = m_drawerType[type]; - if (msgLvl(MSG::DEBUG)) { - - msg(MSG::DEBUG) << "Event# " << m_evtNr - << " Frag id 0x"<< MSG::hex << fragId <<MSG::dec - << " index " << type - << " Calib " << m_calibMode << endmsg; - - msg(MSG::DEBUG) << " Size=" << (*itColl)->getFragSize() - << " BCID=" << (*itColl)->getFragBCID() << MSG::hex - << " CRC=0x" << ((*itColl)->getFragCRC() & 0xffff) - << " DMUMask=0x" << ((*itColl)->getFragDMUMask() & 0xffff) << MSG::dec << endmsg; - - msg(MSG::DEBUG) << " Lvl1ID=" << (*itColl)->getLvl1Id() - << " Lvl1Type=" << (*itColl)->getLvl1Type() - << " EvBCID=" << (*itColl)->getRODBCID() - << " EvType=" << (*itColl)->getDetEvType() << endmsg; - - msg(MSG::DEBUG) << " Header=" << (*itColl)->getFragChipHeaderWords() << endmsg; - } - - if (m_completeNtuple) { - /// Store ROD header info from collection - /// (should be just one per ROD, - /// but we don't know how many RODs we have, - /// so store it for every collection) - m_l1ID[type] = (*itColl)->getLvl1Id(); - m_l1Type[type] = (*itColl)->getLvl1Type(); - m_evType[type] = (*itColl)->getDetEvType(); - m_evBCID[type] = (*itColl)->getRODBCID(); - // store FrBCID - m_frBCID[type] = (*itColl)->getFragBCID(); - } - - if(m_calibMode) { - // Digits in calib mode - // check gain for first digits in collection - - it = (*itColl)->begin(); - itEnd = (*itColl)->end(); - - // non empty collection - if(it != itEnd) { - // store evtnr, bcid,crc, size - // Same for lo and hi, because they come from the same fragment - *m_rodBCIDVec[type] = (*itColl)->getRODBCID(); - *m_sizeVec[type] = (*itColl)->getFragSize(); - *m_sizeVec[type+m_nDrawers] = (*itColl)->getFragSize(); - *m_evtVec[type] = m_evtNr; - *m_evtVec[type+m_nDrawers] = m_evtNr; - - headerVec = (*itColl)->getFragChipHeaderWords(); - headerVecHi = (*itColl)->getFragChipHeaderWordsHigh(); - CRCmask = (*itColl)->getFragDMUMask(); //mask of FE+ROD DMU crc check (16bit+16bit) 0xffffffff == All ok - fe_crc = CRCmask & 0xFFFF; - rod_crc = CRCmask >> 16; - - unsigned int headsize = std::min(16U, static_cast<unsigned int>(headerVec.size())); - unsigned int headsizehi = std::min(16U, static_cast<unsigned int>(headerVecHi.size())); - - for (unsigned int ih = 0; ih < headsize; ++ih) { - (*m_bcidVec[type])[ih] = (headerVec[ih] & 0xFFF); - (*m_feCRCVec[type])[ih] = (fe_crc >> ih & 0x1); - (*m_rodCRCVec[type])[ih] = (rod_crc >> ih & 0x1); - } - - for (unsigned int ihhi = 0; ihhi < headsizehi; ++ihhi) { - (*m_bcidVec[type + m_nDrawers])[ihhi] = (headerVecHi[ihhi] & 0xFFF); - } - - (*m_slinkCRCVec[type])[0] = ((*itColl)->getFragCRC() >> 16) & 0xffff; - (*m_dmuMaskVec[type])[0] = ((*itColl)->getFragDMUMask() >> 16) & 0xffff; - (*m_slinkCRCVec[type])[1] = (*itColl)->getFragCRC() & 0xffff; - (*m_dmuMaskVec[type])[1] = (*itColl)->getFragDMUMask() & 0xffff; - - (*m_slinkCRCVec[type + m_nDrawers])[0] = ((*itColl)->getFragCRC() >> 16) & 0xffff; - (*m_dmuMaskVec[type + m_nDrawers])[0] = ((*itColl)->getFragDMUMask() >> 16) & 0xffff; - (*m_slinkCRCVec[type + m_nDrawers])[1] = (*itColl)->getFragCRC() & 0xffff; - (*m_dmuMaskVec[type + m_nDrawers])[1] = (*itColl)->getFragDMUMask() & 0xffff; - - // go through all TileDigits in collection - for (; it != itEnd; it++) { - emptyColl = false; - - HWIdentifier hwid = (*it)->adc_HWID(); - // determine gain - int gain = m_tileHWID->adc(hwid); - // add m_nDrawers to index if hi gain - int index = type; - if (gain == 1) index += m_nDrawers; - - // determine channel - channel = m_tileHWID->channel(hwid); - // cabling for testbeam (convert to pmt#-1) - if (fragType > 0) channel = digiChannel2PMT(fragType, channel); - - // gain determined for all digits in collection - (*m_gainVec[index])[channel] = gain; - ATH_MSG_DEBUG( "Storing TD for channel: " << channel - << " with gain " << m_tileHWID->adc(hwid) - << " index " << index ); - - // get digits - sampleVec = (*it)->samples(); - int siz = sampleVec.size(); - - if (msgLvl(MSG::DEBUG)) { - msg(MSG::DEBUG) << "Digits." << siz << " {"; - for (int i = 0; i < siz; i++) { - msg(MSG::DEBUG) << (int) sampleVec[i] << " "; - } - - if (siz > m_nSamples) { - msg(MSG::DEBUG) << "} ONLY " << m_nSamples << " digits saved to ntuple" << endmsg; - } else { - msg(MSG::DEBUG) << "}" << endmsg; - } - } - - if (siz > m_nSamples) siz = m_nSamples; - for (n = 0; n < siz; n++) { - (*m_sampleVec[index])[channel][n] = (int) sampleVec[n]; - } - } - } - } else { - // Digits in normal mode - - // store evtnr, bcid,crc, size - *m_rodBCIDVec[type] = (*itColl)->getRODBCID(); - *m_sizeVec[type] = (*itColl)->getFragSize(); - *m_evtVec[type] = m_evtNr; - - headerVec = (*itColl)->getFragChipHeaderWords(); - CRCmask = (*itColl)->getFragDMUMask(); //mask of FE+ROD DMU crc check (16bit+16bit) 0xffffffff == All ok - fe_crc = CRCmask & 0xFFFF; - rod_crc = CRCmask >> 16; - - int headsize = headerVec.size(); - - for (int ih = 0; ih < headsize; ih++) { - (*m_bcidVec[type])[ih] = (headerVec[ih] & 0xFFF); - (*m_feCRCVec[type])[ih] = (fe_crc >> ih & 0x1); - (*m_rodCRCVec[type])[ih] = (rod_crc >> ih & 0x1); - } - - (*m_slinkCRCVec[type])[0] = ((*itColl)->getFragCRC()>>16) & 0xffff; - (*m_dmuMaskVec[type])[0] = ((*itColl)->getFragDMUMask()>>16) & 0xffff; - (*m_slinkCRCVec[type])[1] = (*itColl)->getFragCRC() & 0xffff; - (*m_dmuMaskVec[type])[1] = (*itColl)->getFragDMUMask() & 0xffff; - - // go through all TileDigits in collection - it = (*itColl)->begin(); - itEnd = (*itColl)->end(); - - for(;it != itEnd;it++) { - emptyColl = false; - - HWIdentifier hwid=(*it)->adc_HWID(); - // determine channel - channel = m_tileHWID->channel(hwid); - // cabling for testbeam - if (fragType > 0) channel = digiChannel2PMT(fragType,channel); - - // gain - (*m_gainVec[type])[channel] = m_tileHWID->adc(hwid); - ATH_MSG_DEBUG( "Storing TD for channel: " << channel - << " with gain " << m_tileHWID->adc(hwid) ); - - - // get digits - sampleVec = (*it)->samples(); - int siz = sampleVec.size(); - - if (msgLvl(MSG::DEBUG)) { - msg(MSG::DEBUG) << "Digits." << siz << " {"; - for (int i = 0; i < siz; i++) { - msg(MSG::DEBUG) << (int) sampleVec[i] << " "; - } - msg(MSG::DEBUG) << "}" << endmsg; - } - - for (n = 0; n < siz; n++) { - (*m_sampleVec[type])[channel][n] = (int) sampleVec[n]; - } - } - } - } - // next container - } - - if (emptyColl) - return StatusCode::FAILURE; - else - return StatusCode::SUCCESS; -} - -StatusCode TileTBNtuple::finalize() { - - ATH_MSG_INFO( "finalize() successfully" ); - - return StatusCode::SUCCESS; -} - -StatusCode TileTBNtuple::connectFile(void) { - MsgStream log(msgSvc(), name()); - - m_ntupleCreated = false; - char file[100]; - sprintf(file, m_ntupleLoc.c_str(), ++m_currentFileNum); - std::string ntupleLoc = file; - - NTupleDirPtr DirPtr(ntupleSvc(), ntupleLoc); - if (!DirPtr) DirPtr = ntupleSvc()->createDirectory(ntupleLoc); - if (!DirPtr) { - ATH_MSG_ERROR( "Invalid Ntuple Directory: " ); - return StatusCode::FAILURE; - } - - m_ntuplePtr = ntupleSvc()->book(DirPtr.ptr(), m_ntupleID, CLID_ColumnWiseTuple, "TileBEAM-Ntuple"); - if (!m_ntuplePtr) { - - std::string ntupleCompleteID = ntupleLoc + "/" + m_ntupleID; - - NTuplePtr nt(ntupleSvc(), ntupleCompleteID); - if (!nt) { - ATH_MSG_ERROR( "Failed to book or to retreive ntuple " << ntupleCompleteID ); - return StatusCode::FAILURE; - } else { - ATH_MSG_INFO( "Reaccessing ntuple " << ntupleCompleteID ); - - m_ntuplePtr = nt; - // we share ntuple with some other algorithm - // so have to book all columns now, otherwise Athena will crash - m_ntupleCreated = true; - StatusCode sc = initNTuple(); - if (sc.isFailure()) { - ATH_MSG_ERROR( " Error during ntuple initialization" ); - } - } - } - - return StatusCode::SUCCESS; -} - -StatusCode TileTBNtuple::initNTuple(void) { - - m_evtVec.clear(); - m_bcidVec.clear(); - m_rodBCIDVec.clear(); - m_sizeVec.clear(); - m_dmuMaskVec.clear(); - m_slinkCRCVec.clear(); - m_gainVec.clear(); - m_errVec.clear(); - m_sampleVec.clear(); - m_feCRCVec.clear(); - m_rodCRCVec.clear(); - - m_eneVec.clear(); - m_timeVec.clear(); - - m_efitVec.clear(); - m_tfitVec.clear(); - m_pedfitVec.clear(); - m_chi2Vec.clear(); - - m_eOptVec.clear(); - m_tOptVec.clear(); - m_pedOptVec.clear(); - m_chi2OptVec.clear(); - - m_eDspVec.clear(); - m_tDspVec.clear(); - m_chi2DspVec.clear(); - - // *** Create items for TRIGGER *** - - CHECK( m_ntuplePtr->addItem("TRIGGER/EvTime", m_evTime) ); - CHECK( m_ntuplePtr->addItem("TRIGGER/Run", m_run) ); - CHECK( m_ntuplePtr->addItem("TRIGGER/Evt", m_evt) ); - CHECK( m_ntuplePtr->addItem("TRIGGER/Trig", m_trigType, 0, 65535) ); - - - if ( m_completeNtuple ) { - // Info from ROD headers - // m_nDrawers drawers separately (i.e. with duplications) + Beam ROD - CHECK(m_ntuplePtr->addItem("TRIGGER/L1ID", m_nDrawers + 1, m_l1ID, 0, 65535)); - CHECK(m_ntuplePtr->addItem("TRIGGER/L1Type", m_nDrawers + 1, m_l1Type, 0, 65535)); - CHECK(m_ntuplePtr->addItem("TRIGGER/EvType", m_nDrawers + 1, m_evType, 0, 65535)); - CHECK(m_ntuplePtr->addItem("TRIGGER/EvBCID", m_nDrawers + 1, m_evBCID, 0, 65535)); - CHECK(m_ntuplePtr->addItem("TRIGGER/FrBCID", m_nDrawers, m_frBCID, 0, 65535)); - } - - // *** Create items for MUON *** - if ( m_beamIdList[MUON_ADC_FRAG] || - m_beamIdList[ADDR_ADC_FRAG] ) { - - CHECK(m_ntuplePtr->addItem("MUON/MuBackHit", m_muBackHit)); - CHECK(m_ntuplePtr->addItem("MUON/MuBackSum", m_muBackSum)); - CHECK(m_ntuplePtr->addItem("MUON/MuBack", 14, m_muBack)); - CHECK(m_ntuplePtr->addItem("MUON/MuCalib", 2, m_muCalib)); - } - - // *** Create items for ECAL *** - if ( m_beamIdList[ECAL_ADC_FRAG] ) { - CHECK( m_ntuplePtr->addItem("ECAL/Ecal",8,m_ecal) ); - } - - // *** Create items for LASER *** - if ( m_beamIdList[LASE_PTN_FRAG] ) { - CHECK( m_ntuplePtr->addItem("LASER/LasFlag",m_lasFlag,0,65535) ); - } - if ( ( m_unpackAdder && m_beamIdList[BEAM_ADC_FRAG] ) || - ( !m_unpackAdder && m_beamIdList[LASE_ADC_FRAG] ) ) { - - CHECK(m_ntuplePtr->addItem("LASER/Las0", m_las0)); - CHECK(m_ntuplePtr->addItem("LASER/Las1", m_las1)); - CHECK(m_ntuplePtr->addItem("LASER/Las2", m_las2)); - CHECK(m_ntuplePtr->addItem("LASER/Las3", m_las3)); - CHECK(m_ntuplePtr->addItem("LASER/LasExtra", 4, m_lasExtra)); - } - - // *** Create items for ADDER *** - if (m_unpackAdder) { - if ( m_beamIdList[ADD_FADC_FRAG] ) { - CHECK(m_ntuplePtr->addItem("ADDER/Adder", 16, 16, m_adder, 0, 255)); - CHECK(m_ntuplePtr->addItem("ADDER/EneAdd", 16, m_eneAdd)); - CHECK(m_ntuplePtr->addItem("ADDER/TimeAdd", 16, m_timeAdd)); - } - } - - // *** Create items for STATUS *** - // CHECK( m_ntuplePtr->addItem("STATUS/Status",2,3,m_status) ); - - // *** Create items for CISPAR *** - if ( m_beamIdList[DIGI_PAR_FRAG&0x1F] ) { - CHECK( m_ntuplePtr->addItem("CISPAR/Cispar",16,m_cispar) ); - } - - // *** Create items for BEAM *** - if ( ( m_unpackAdder && m_beamIdList[BEAM_ADC_FRAG] ) || - ( !m_unpackAdder && m_beamIdList[COMMON_ADC1_FRAG] ) ) { - - CHECK(m_ntuplePtr->addItem("BEAM/S1cou", m_s1cou, 0, 65535)); - CHECK(m_ntuplePtr->addItem("BEAM/S2cou", m_s2cou, 0, 65535)); - CHECK(m_ntuplePtr->addItem("BEAM/S3cou", m_s3cou, 0, 65535)); - CHECK(m_ntuplePtr->addItem("BEAM/MuTag", m_muTag, 0, 65535)); - CHECK(m_ntuplePtr->addItem("BEAM/Cher1", m_cher1, 0, 65535)); - CHECK(m_ntuplePtr->addItem("BEAM/Cher2", m_cher2, 0, 65535)); - CHECK(m_ntuplePtr->addItem("BEAM/MuHalo", m_muHalo, 0, 65535)); - CHECK(m_ntuplePtr->addItem("BEAM/MuVeto", m_muVeto, 0, 65535)); - } - - if ( ! m_unpackAdder ) { - - if ( m_beamIdList[COMMON_ADC2_FRAG] ) { - CHECK( m_ntuplePtr->addItem("BEAM/S2extra",m_s2extra,0,65535) ); - CHECK( m_ntuplePtr->addItem("BEAM/S3extra",m_s3extra,0,65535) ); - } - - if (m_beamIdList[BEAM_ADC_FRAG]) { - CHECK(m_ntuplePtr->addItem("BEAM/SC1", m_sc1, 0, 65535)); - CHECK(m_ntuplePtr->addItem("BEAM/SC2", m_sc2, 0, 65535)); - } - - if (m_beamIdList[COMMON_PTN_FRAG]) { - CHECK(m_ntuplePtr->addItem("BEAM/pu", m_commonPU, 0, 65535)); - } - - if (m_beamIdList[COMMON_TOF_FRAG]) { - CHECK(m_ntuplePtr->addItem("BEAM/tof", 8, m_tof, 0, 65535)); - } - - if (m_beamIdList[COMMON_TDC1_FRAG]) { - CHECK(m_ntuplePtr->addItem("BEAM/btdc1", 16, m_btdc1, 0, 65535)); - } - - if (m_beamIdList[COMMON_TDC2_FRAG]) { - CHECK(m_ntuplePtr->addItem("BEAM/btdc2", 16, m_btdc2, 0, 65535)); - } - - if (m_beamIdList[COMMON_TDC1_FRAG]) { - CHECK(m_ntuplePtr->addItem("BEAM/XchN2", m_xChN2)); - CHECK(m_ntuplePtr->addItem("BEAM/YchN2", m_yChN2)); - CHECK(m_ntuplePtr->addItem("BEAM/XchN1", m_xChN1)); - CHECK(m_ntuplePtr->addItem("BEAM/YchN1", m_yChN1)); - } - if ( m_beamIdList[COMMON_TDC2_FRAG] ) { - CHECK( m_ntuplePtr->addItem("BEAM/Xcha0",m_xCha0) ); - CHECK( m_ntuplePtr->addItem("BEAM/Ycha0",m_yCha0) ); - } - } else { - if (m_beamIdList[BEAM_TDC_FRAG]) { - CHECK(m_ntuplePtr->addItem("BEAM/btdc1", 8, m_btdc1, 0, 65535)); - CHECK(m_ntuplePtr->addItem("BEAM/btdc2", 8, m_btdc2, 0, 65535)); - } - } - - if ((m_unpackAdder && m_beamIdList[BEAM_TDC_FRAG]) - || (!m_unpackAdder && m_beamIdList[COMMON_TDC2_FRAG])) { - - CHECK(m_ntuplePtr->addItem("BEAM/Xcha1", m_xCha1)); - CHECK(m_ntuplePtr->addItem("BEAM/Ycha1", m_yCha1)); - CHECK(m_ntuplePtr->addItem("BEAM/Xcha2", m_xCha2)); - CHECK(m_ntuplePtr->addItem("BEAM/Ycha2", m_yCha2)); - CHECK(m_ntuplePtr->addItem("BEAM/Ximp", m_xImp)); - CHECK(m_ntuplePtr->addItem("BEAM/Yimp", m_yImp)); - } - - // *** Create items for TileDigits and TileRawChannels *** - - unsigned int listSize = std::min(m_nDrawers, static_cast<unsigned int>(m_drawerMap.size())); - - if (listSize > 0) { - - std::string digit[10] = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9" }; - std::vector<std::string> suffixArr; - unsigned int length; - bool testbeam = TileCablingService::getInstance()->getTestBeam(); - - if (m_calibMode) { - - length = 2 * m_nDrawers; - suffixArr.resize(length); - - for (unsigned int i = 0; i < listSize; ++i) { - unsigned int ros = m_drawerType[i]; - unsigned int drawer = strtol(m_drawerList[i].data(), NULL, 0) & 0x3F; - std::string digits; - if (testbeam) { - digits = digit[drawer & 7]; - } else { - ++drawer; // count modules from 1 - digits = digit[drawer / 10] + digit[drawer % 10]; - } - - if (ros == 0) { - std::string suff = m_drawerList[i]; - suff.replace(suff.find("0x"), 2, ""); - suffixArr[i] = suff + "lo"; - suffixArr[i + m_nDrawers] = suff + "hi"; - } else { - suffixArr[i] = m_rosName[ros] + digits + "lo"; - suffixArr[i + m_nDrawers] = m_rosName[ros] + digits + "hi"; - } - } - } else { - - length = m_nDrawers; - suffixArr.resize(length); - - for (unsigned int i = 0; i < listSize; ++i) { - unsigned int ros = m_drawerType[i]; - unsigned int drawer = strtol(m_drawerList[i].data(), NULL, 0) & 0x3F; - std::string digits; - if (testbeam) { - digits = digit[drawer & 7]; - } else { - ++drawer; // count modules from 1 - digits = digit[drawer / 10] + digit[drawer % 10]; - } - - if (ros == 0) { - std::string suff = m_drawerList[i]; - suff.replace(suff.find("0x"), 2, ""); - suffixArr[i] = suff; - } else { - suffixArr[i] = m_rosName[ros] + digits; - } - } - } - - // create NTuple objs in vectors - for (unsigned int i = 0; i < length; i++) { - - if (i % m_nDrawers < listSize) - ATH_MSG_DEBUG("Adding items for " << suffixArr[i]); - - NTuple::Item<int> *evt = new NTuple::Item<int>; - NTuple::Array<int> *bcid = new NTuple::Array<int>; - NTuple::Item<int> *rodBCID = new NTuple::Item<int>; - NTuple::Item<int> *size = new NTuple::Item<int>; - NTuple::Array<int> *dmu = new NTuple::Array<int>; - NTuple::Array<int> *crc = new NTuple::Array<int>; - NTuple::Array<int> *gain = new NTuple::Array<int>; - NTuple::Array<int> *err = new NTuple::Array<int>; - NTuple::Matrix<int> *sample = new NTuple::Matrix<int>; - NTuple::Array<int> *fe_crc = new NTuple::Array<int>; - NTuple::Array<int> *rod_crc = new NTuple::Array<int>; - - NTuple::Array<float> *ene = new NTuple::Array<float>; - NTuple::Array<float> *time = new NTuple::Array<float>; - - NTuple::Array<float> *efit = new NTuple::Array<float>; - NTuple::Array<float> *tfit = new NTuple::Array<float>; - NTuple::Array<float> *pedfit = new NTuple::Array<float>; - NTuple::Array<float> *chi2 = new NTuple::Array<float>; - - NTuple::Array<float> *eOpt = new NTuple::Array<float>; - NTuple::Array<float> *tOpt = new NTuple::Array<float>; - NTuple::Array<float> *pedOpt = new NTuple::Array<float>; - NTuple::Array<float> *chi2Opt = new NTuple::Array<float>; - - NTuple::Array<float> *eDsp = new NTuple::Array<float>; - NTuple::Array<float> *tDsp = new NTuple::Array<float>; - NTuple::Array<float> *chi2Dsp = new NTuple::Array<float>; - - m_evtVec.push_back(evt); // I - m_bcidVec.push_back(bcid); // U - m_rodBCIDVec.push_back(rodBCID); // U - m_sizeVec.push_back(size); // U - m_dmuMaskVec.push_back(dmu); // U(2) - m_slinkCRCVec.push_back(crc); // U(2) - m_gainVec.push_back(gain); // U(48/96) - m_errVec.push_back(err); // U(48/96) - m_sampleVec.push_back(sample); // U(48/96,9) - m_feCRCVec.push_back(fe_crc); //U - m_rodCRCVec.push_back(rod_crc); //U - - m_eneVec.push_back(ene); - m_timeVec.push_back(time); - - m_efitVec.push_back(efit); - m_tfitVec.push_back(tfit); - m_pedfitVec.push_back(pedfit); - m_chi2Vec.push_back(chi2); - - m_eOptVec.push_back(eOpt); - m_tOptVec.push_back(tOpt); - m_pedOptVec.push_back(pedOpt); - m_chi2OptVec.push_back(chi2Opt); - - m_eDspVec.push_back(eDsp); - m_tDspVec.push_back(tDsp); - m_chi2DspVec.push_back(chi2Dsp); - - - if (i % m_nDrawers < listSize) { - // create ntuple layout - ATH_MSG_DEBUG( "Adding Leaf to Event '" << ("RAW" + suffixArr[i] + "/Evt" + suffixArr[i]) << "' @" << evt); - - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Evt" + suffixArr[i], *evt) ); // uint - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/BCID" + suffixArr[i], 16, *bcid, 0, 65535) ); // uint - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/rodBCID" + suffixArr[i], *rodBCID, 0, 65535) ); //uint - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Size" + suffixArr[i], *size, 0, 65535) ); // uint - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/DMUMask" + suffixArr[i], 2, *dmu, 0, 65535) ); // uint - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/SlinkCRC" + suffixArr[i], 2, *crc, 0, 65535) ); // uint - // XXX: Number of samples taken from JobOptions and number of channels is hard-coded as 48 - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Gain" + suffixArr[i], 48, *gain, 0, 1) ); // uint - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Err" + suffixArr[i], 48, *err, 0, 1023) ); // uint - if (m_nSamples > 0) { - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/Sample" + suffixArr[i], 48, m_nSamples, *sample, 0, 1023) ); // uint - } - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/feCRC" + suffixArr[i], 16, *fe_crc, 0, 1) ); // uint - CHECK( m_ntuplePtr->addItem("RAW" + suffixArr[i] + "/rodCRC" + suffixArr[i], 16, *rod_crc, 0, 1) ); // uint - - if (m_flatRawChannelContainer.size() > 0) { - - CHECK( m_ntuplePtr->addItem("ENE" + suffixArr[i] + "/Ene" + suffixArr[i], 48, *ene) ); // float - CHECK( m_ntuplePtr->addItem("ENE" + suffixArr[i] + "/Time" + suffixArr[i], 48, *time) ); // float - } - - if (m_fitRawChannelContainer.size() > 0) { - - CHECK( m_ntuplePtr->addItem("FIT" + suffixArr[i] + "/Efit" + suffixArr[i], 48, *efit) ); // float - CHECK( m_ntuplePtr->addItem("FIT" + suffixArr[i] + "/Tfit" + suffixArr[i], 48, *tfit) ); // float - CHECK( m_ntuplePtr->addItem("FIT" + suffixArr[i] + "/Pedfit" + suffixArr[i], 48, *pedfit) ); // float - CHECK( m_ntuplePtr->addItem("FIT" + suffixArr[i] + "/Chi2" + suffixArr[i], 48, *chi2) ); // float - } - - if (m_optRawChannelContainer.size() > 0) { - - CHECK( m_ntuplePtr->addItem("OPT" + suffixArr[i] + "/Eopt" + suffixArr[i], 48, *eOpt) ); // float - CHECK( m_ntuplePtr->addItem("OPT" + suffixArr[i] + "/Topt" + suffixArr[i], 48, *tOpt) ); // float - CHECK( m_ntuplePtr->addItem("OPT" + suffixArr[i] + "/Pedopt" + suffixArr[i], 48, *pedOpt) ); // float - CHECK( m_ntuplePtr->addItem("OPT" + suffixArr[i] + "/Chi2opt" + suffixArr[i], 48, *chi2Opt) ); // float - } - - if (m_dspRawChannelContainer.size() > 0) { - - CHECK( m_ntuplePtr->addItem("DSP" + suffixArr[i] + "/Edsp" + suffixArr[i], 48, *eDsp) ); // float - CHECK( m_ntuplePtr->addItem("DSP" + suffixArr[i] + "/Tdsp" + suffixArr[i], 48, *tDsp) ); // float - CHECK( m_ntuplePtr->addItem("DSP" + suffixArr[i] + "/Chi2dsp" + suffixArr[i], 48, *chi2Dsp) ); // float - } - - } - } - } - - if (m_completeNtuple) { - // *** Create items for total energy in samplings *** - CHECK( m_ntuplePtr->addItem("EneTotal/LarSmp", 4, m_LarEne) ); - CHECK( m_ntuplePtr->addItem("EneTotal/BarSmp", 3, m_BarEne) ); - CHECK( m_ntuplePtr->addItem("EneTotal/ExtSmp", 3, m_ExtEne) ); - CHECK( m_ntuplePtr->addItem("EneTotal/GapSmp", 3, m_GapEne) ); - } - - if (m_beamIdList[COIN_TRIG1_FRAG]) { - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig1", 96, m_coincTrig1) ); - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag1", m_coincFlag1) ); - } - - if (m_beamIdList[COIN_TRIG2_FRAG]) { - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig2", 96, m_coincTrig2) ); - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag2", m_coincFlag2) ); - } - - if (m_beamIdList[COIN_TRIG3_FRAG]) { - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig3", 96, m_coincTrig3) ); - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag3", m_coincFlag3) ); - } - - if (m_beamIdList[COIN_TRIG4_FRAG]) { - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig4", 96, m_coincTrig4) ); - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag4", m_coincFlag4) ); - } - - if (m_beamIdList[COIN_TRIG5_FRAG]) { - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig5", 96, m_coincTrig5) ); - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag5", m_coincFlag5) ); - } - - if (m_beamIdList[COIN_TRIG6_FRAG]) { - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig6", 96, m_coincTrig6) ); - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag6", m_coincFlag6) ); - } - if (m_beamIdList[COIN_TRIG7_FRAG]) { - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig7", 96, m_coincTrig7) ); - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag7", m_coincFlag7) ); - } - - if (m_beamIdList[COIN_TRIG8_FRAG]) { - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincTrig8", 96, m_coincTrig8) ); - CHECK( m_ntuplePtr->addItem("CoincBoard/CoincFlag8", m_coincFlag8) ); - } - - return StatusCode::SUCCESS; -} - -StatusCode TileTBNtuple::storeCells() { - - const CaloCellContainer* cellContainer; - //Retrieve Cell collection from SG - - ATH_MSG_DEBUG( "retrieve cellContainer from SG" ); - - CHECK( evtStore()->retrieve(cellContainer, "AllCalo") ); - - //Loop over all cells in container. Sum up the Energy and fill 2DHistograms - - ATH_MSG_DEBUG( "succeeded retrieving cellContainer from SG" ); - - CaloCellContainer::const_iterator ifirst = cellContainer->begin(); - CaloCellContainer::const_iterator ilast = cellContainer->end(); - ATH_MSG_DEBUG( "TileTBNtuple : about to iterate over CaloCells" ); - - m_LarEne[0] = m_LarEne[1] = m_LarEne[2] = m_LarEne[3] = 0.0; - m_BarEne[0] = m_BarEne[1] = m_BarEne[2] = 0.0; - m_ExtEne[0] = m_ExtEne[1] = m_ExtEne[2] = 0.0; - m_GapEne[0] = m_GapEne[1] = m_GapEne[2] = 0.0; - - for (; ifirst != ilast; ++ifirst) { - //Decode cell information - const CaloCell* cell_ptr = *ifirst; // pointer to cell object - const double energy = cell_ptr->energy(); - const CaloDetDescrElement* caloDDE_ptr = cell_ptr->caloDDE(); //pointer to the DetectorDescriptionElement - const CaloCell_ID::CaloSample sampl = caloDDE_ptr->getSampling(); //To which sampling belongs this cell? -// const CaloCell_ID::SUBCALO subcalo= caloDDE_ptr->getSubCalo(); - - if (sampl == CaloCell_ID::PreSamplerB) { - m_LarEne[0] += energy; - } else if (sampl == CaloCell_ID::EMB1) { - m_LarEne[1] += energy; - } else if (sampl == CaloCell_ID::EMB2) { - m_LarEne[2] += energy; - } else if (sampl == CaloCell_ID::EMB3) { - m_LarEne[3] += energy; - } else if (sampl == CaloCell_ID::TileBar0) { - m_BarEne[0] += energy; - } else if (sampl == CaloCell_ID::TileBar1) { - m_BarEne[1] += energy; - } else if (sampl == CaloCell_ID::TileBar2) { - m_BarEne[2] += energy; - } else if (sampl == CaloCell_ID::TileExt0) { - m_ExtEne[0] += energy; - } else if (sampl == CaloCell_ID::TileExt1) { - m_ExtEne[1] += energy; - } else if (sampl == CaloCell_ID::TileExt2) { - m_ExtEne[2] += energy; - } else if (sampl == CaloCell_ID::TileGap1) { - m_GapEne[1] += energy; - } else if (sampl == CaloCell_ID::TileGap2) { - m_GapEne[2] += energy; - } else if (sampl == CaloCell_ID::TileGap3) { - m_GapEne[0] += energy; - } - } - - return StatusCode::SUCCESS; -} - - -StatusCode TileTBNtuple::initList() { - - unsigned int size = m_drawerList.size(); - - if (size > 0) { - - int frag = strtol(m_drawerList[0].data(), NULL, 0); - - if (frag < 0) { // setup frags IDs from the data - - // Read Digits from TDS - const TileDigitsContainer *digitsCnt; - - if (evtStore()->retrieve(digitsCnt, m_digitsContainer).isFailure()) { - ATH_MSG_ERROR( "can't retrieve Digits from TDS" ); - ATH_MSG_ERROR( "can't set up fragment list for ntuple" ); - - if (m_nSamples != 0) { - ATH_MSG_WARNING( "Disable digit samples in ntuple" ); - m_nSamples = 0; - } - - return StatusCode::SUCCESS; - } - - // Get iterator for all TDColl in TDCont - TileDigitsContainer::const_iterator itColl = (*digitsCnt).begin(); - TileDigitsContainer::const_iterator itCollEnd = (*digitsCnt).end(); - - std::vector<unsigned int> frags; - // Go through all TileDigitsCollections - for (; itColl != itCollEnd; itColl++) { - // determine type of frag - if ((*itColl)->begin() != (*itColl)->end()) frags.push_back((*itColl)->identify()); - } - size = frags.size(); - - if (size > 0) { - - unsigned int rosOrder[5] = { 2, 1, 3, 4, 0 }; - unsigned int dr = 0; - char frg[6] = "0x000"; - - m_drawerList.clear(); - // m_drawerType.clear(); - m_drawerMap.clear(); - - msg(MSG::INFO) << "setting drawerList from data " << MSG::hex; - for (unsigned int ir = 0; ir < 5; ++ir) { - for (unsigned int i = 0; i < size; ++i) { - unsigned int frag = frags[i]; - if (frag >> 8 == rosOrder[ir]) { - sprintf(frg, "0x%3.3x", frag); - m_drawerList.push_back((std::string) frg); - if (dr == m_drawerType.size()) m_drawerType.push_back(frag >> 8); - m_drawerMap[frag] = dr; - msg(MSG::INFO) << " 0x" << frag; - ++dr; - } - } - } - msg(MSG::INFO) << MSG::dec << endmsg; - - size = m_drawerType.size(); - if (size < m_nDrawers) { - m_drawerType.resize(m_nDrawers); - for (; size < m_nDrawers; ++size) - m_drawerType[size] = 0; - } - - msg(MSG::INFO) << "drawerType "; - for (unsigned int dr = 0; dr < size; ++dr) - msg(MSG::INFO) << " " << m_drawerType[dr]; - msg(MSG::INFO) << endmsg; - - if (size > m_nDrawers) { - ATH_MSG_INFO( "increasing m_nDrawers from " << m_nDrawers << " to " << size ); - m_nDrawers = size; - } - - if (size < 1) size = 1; - if (m_eventsPerFile == 0) { - m_eventsPerFile = (int) (200 / size) * 1000; - ATH_MSG_INFO( "Number of events per file was 0, set it to 200k/" << size << " = " << m_eventsPerFile ); - } - - } else { - - ATH_MSG_ERROR( "can't find any TileDigits collections" ); - ATH_MSG_ERROR( "can't set up fragment list for ntuple" ); - } - } - - // once again - check number of samples in the data - // but do not print any ERRORs now - - // Read Digits from TDS - const TileDigitsContainer *digitsCnt; - if (evtStore()->retrieve(digitsCnt, m_digitsContainer).isSuccess()) { - - // Get iterator for all TDColl in TDCont - TileDigitsContainer::const_iterator itColl = (*digitsCnt).begin(); - TileDigitsContainer::const_iterator itCollEnd = (*digitsCnt).end(); - - // Go through all TileDigitsCollections - for (; itColl != itCollEnd; itColl++) { - if ((*itColl)->begin() != (*itColl)->end()) { - int siz = (*(*itColl)->begin())->samples().size(); - if (siz > m_nSamples && m_nSamples != 0) { - ATH_MSG_WARNING( "Increasing number of digit samples in ntuple from " - << m_nSamples << " to " << siz ); - m_nSamples = siz; - } - } - } - } else { - if (m_nSamples != 0) { - ATH_MSG_WARNING( "Disable digit samples in ntuple" ); - m_nSamples = 0; - } - } - } - - return StatusCode::SUCCESS; -} - - - -////////////////////////////////////////////////////////////////////////////// -void TileTBNtuple::getEta() { - - // Get eta from an ASCII file with the following structure : - // runnumber eta - - ATH_MSG_INFO( "Get eta for run " << m_runNumber ); - - // Find the full path to filename: - std::string fileName = PathResolver::find_file(m_etaFileName, "DATAPATH"); - ATH_MSG_INFO( "Reading file " << fileName ); - - if (fileName.size() == 0) { - ATH_MSG_WARNING( "Could not find input file " << m_etaFileName ); - ATH_MSG_WARNING( "Skip reading of eta value " ); - - } else { - - std::ifstream etafile; - etafile.open(fileName.c_str()); - - if (etafile.good()) { - - int runNumber = 0; - float eta = 0; - while ((runNumber != m_runNumber) && (!etafile.eof())) { - etafile >> runNumber >> eta; - } - - if (runNumber != m_runNumber) { - ATH_MSG_INFO( "Run " << m_runNumber << " has not been found, keep eta and theta at zero" ); - m_eta = m_theta = 0.0; - } else { - m_eta = eta; - m_theta = (M_PI_2 - 2 * atan(exp(m_eta))); - ATH_MSG_INFO( "Run " << m_runNumber - << " has been found with eta=" << m_eta - << ", theta =" << m_theta ); - } - - } else { - - ATH_MSG_WARNING( "Problem with file " << fileName ); - ATH_MSG_WARNING( "Skip reading of eta value " ); - } - - etafile.close(); - } -} diff --git a/TileCalorimeter/TileTBRec/src/TileTBOldNtupleRead.cxx b/TileCalorimeter/TileTBRec/src/TileTBOldNtupleRead.cxx deleted file mode 100644 index 0302d413bfdf200be09c3869d3917a19839c34d1..0000000000000000000000000000000000000000 --- a/TileCalorimeter/TileTBRec/src/TileTBOldNtupleRead.cxx +++ /dev/null @@ -1,322 +0,0 @@ -/* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration -*/ - -#include "Rtypes.h" -#include "TileTBRec/TileTBOldNtupleRead.h" -#include "TileTBRec/TileTBOldNtupleStruct.h" - -//Gaudi Includes -#include "GaudiKernel/Bootstrap.h" -#include "GaudiKernel/ISvcLocator.h" -#include "GaudiKernel/IMessageSvc.h" -#include "GaudiKernel/IDataProviderSvc.h" -#include "GaudiKernel/IIncidentSvc.h" -#include "GaudiKernel/SmartDataPtr.h" -#include "StoreGate/StoreGateSvc.h" - -//TileCalo includes -#include "CaloIdentifier/TileID.h" -#include "TileIdentifier/TileHWID.h" -#include "TileIdentifier/TileTBFrag.h" -#include "TileConditions/TileCablingService.h" -#include "TileEvent/TileDigitsContainer.h" -#include "TileEvent/TileBeamElemContainer.h" -#include "TileRecUtils/TileBeamInfoProvider.h" - -TileTBOldNtupleRead * TileTBOldNtupleRead::s_instance = 0; - -TileTBOldNtupleRead * TileTBOldNtupleRead::getInstance() -{ - return s_instance; -} - -TileTBOldNtupleRead::TileTBOldNtupleRead(std::string name, ISvcLocator* pSvcLocator) - : AthAlgorithm(name, pSvcLocator) - , m_tileHWID(0) - , m_cabling(0) - , m_beamInfo("TileBeamInfoProvider") - , m_trigType(0) - , m_file(0) - , m_ntuple(0) - , m_ntupleStruct(0) -{ - m_eventShift.resize(6); - declareProperty("NtupleID",m_ntupleID = "h1000"); - declareProperty("NtupleDir",m_ntupleDir = "."); - declareProperty("RunNumber",m_runNumber = 0); - declareProperty("TileDigitsContainer", m_digitsContainer = "TileDigitsCnt"); - declareProperty("TileBeamElemContainer",m_beamContainer = "TileBeamElemCnt"); - declareProperty("BiGain",m_bigain = false); - declareProperty("FrameLength", m_nSamp = 9); - declareProperty("PmtOrder", m_pmtOrder = true); - declareProperty("BarrelOnly", m_barrelOnly = false); - declareProperty("SkipEvents", m_eventNumber = 0); - declareProperty("AdderFit", m_adderFit = true); - declareProperty("EventShift", m_eventShift); - - m_maxEventNumber=0; - - s_instance = this; -} - -TileTBOldNtupleRead::~TileTBOldNtupleRead() -{ -} - -//============================================== -// initialize -//============================================== -StatusCode TileTBOldNtupleRead::initialize() -{ - ATH_MSG_INFO ( "Initialization started" ); - - // find TileCablingService - m_cabling = TileCablingService::getInstance(); - - ATH_CHECK( detStore()->retrieve(m_tileHWID) ); - - ATH_CHECK( m_beamInfo.retrieve() ); - ATH_CHECK( m_beamInfo->setProperty("TileBeamElemContainer",m_beamContainer) ); - ATH_CHECK( m_beamInfo->setProperty("TileDigitsContainer",m_digitsContainer) ); - - m_eventShift.resize(8); - for (int i=0; i<6; ++i) { // find miminum and maximum event shift - if (m_eventShift[i] < m_eventShift[6] ) m_eventShift[6] = m_eventShift[i]; - if (m_eventShift[i] > m_eventShift[7] ) m_eventShift[7] = m_eventShift[i]; - } - - if (m_eventNumber < 0) m_eventNumber = 0; - - if (m_eventNumber+m_eventShift[6]<0) { - ATH_MSG_INFO ( "Adjusting first ntuple entry to read, setting it to " << -m_eventShift[6] ); - m_eventNumber = -m_eventShift[6] - 1; - } else { - ATH_MSG_INFO ( "Reading old ntuple starting from entry " << m_eventNumber ); - m_eventNumber -= 1; - } - - if (m_eventShift[6] != 0 || m_eventShift[7] != 0) { - ATH_MSG_INFO ( "Additional shift for drawers" - << " N0: " << m_eventShift[0] - << " N1: " << m_eventShift[1] - << " N2: " << m_eventShift[2] - << " P0: " << m_eventShift[3] - << " P1: " << m_eventShift[4] - << " P2: " << m_eventShift[5] ); - } - - char fname[100]; - sprintf(fname,"%s/r%7.7d.root",m_ntupleDir.c_str(),m_runNumber); - m_file=new TFile(fname,"OLD"); - if (m_file == NULL) { - ATH_MSG_ERROR ( "File not found: " << fname ); - return StatusCode::FAILURE; - } - - m_ntuple=(TTree*)(m_file->Get(m_ntupleID.c_str())); - if (m_ntuple == NULL) { - ATH_MSG_ERROR ( "Ntuple not found: " << m_ntupleID ); - return StatusCode::FAILURE; - } - - if (m_nSamp != 9) { - ATH_MSG_ERROR ( "Unexpected number of samples: " << m_nSamp ); - return StatusCode::FAILURE; - } - - m_maxEventNumber = m_ntuple->GetEntries() - m_eventShift[7]; - ATH_MSG_INFO ( "Max available entry to read " << m_maxEventNumber ); - - if (m_bigain) { - ATH_MSG_INFO ( "Assuming bi-gain ntuple structure with " << m_nSamp << " samples" ); - } else { - ATH_MSG_INFO ( "Assuming mono-gain ntuple structure with " << m_nSamp << " samples" ); - } - - m_ntupleStruct = new TileTBOldNtupleStruct(m_ntuple,m_bigain,m_adderFit,m_eventShift); - - ATH_MSG_INFO ( "Initialization completed." ); - return StatusCode::SUCCESS; -} - -//============================================== -// execute -//============================================== -StatusCode TileTBOldNtupleRead::execute() -{ - ++m_eventNumber; - if (m_eventNumber >= m_maxEventNumber) { - ATH_MSG_ERROR ( "All " << m_eventNumber << " entries processed. " ); - return StatusCode::FAILURE; - } - - m_ntupleStruct->GetEntry(m_eventNumber); - ATH_MSG_DEBUG ( "Reading entry " << m_eventNumber - << " event number from ntuple is " << m_ntupleStruct->Evt ); - - // Fill beam elements container (PATTERN UNIT and CISPAR only) - TileBeamElemContainer* pBeamContainer = new TileBeamElemContainer(true); - - m_trigType = m_ntupleStruct->Trig; - ATH_MSG_VERBOSE ( "Trig type = " << m_trigType ); - HWIdentifier adc_id = m_tileHWID->adc_id(0,LASE_PTN_FRAG,0,0); - int value = (m_trigType << 8); - TileBeamElem * rc = new TileBeamElem(adc_id,value); - pBeamContainer->push_back(rc); - - if (msgLvl(MSG::VERBOSE)) msg() << MSG::VERBOSE << "Cis par:"; - for(int ch=0; ch<12; ++ch) { - adc_id = m_tileHWID->adc_id(0,DIGI_PAR_FRAG,ch,0); - value = m_ntupleStruct->cispar[ch]; - if (msgLvl(MSG::VERBOSE)) msg() << " " << value; - TileBeamElem * rc = new TileBeamElem(adc_id,value); - pBeamContainer->push_back(rc); - } - if (msgLvl(MSG::VERBOSE)) msg() << endmsg; - StatusCode sc=evtStore()->record(pBeamContainer, m_beamContainer, false); - if(sc.isFailure()) { - ATH_MSG_ERROR( "Failed to register the container: " << m_beamContainer ); - } - - // Fill the TileDigitsContainer - TileDigitsContainer* pDigitsContainer = new TileDigitsContainer(true); - std::vector<double> digitSamples(m_nSamp); - - if (m_bigain) { - - for(int iros=1; iros<=2; ++iros) { // loop over Positive/Negative side - - for(int dr=0; dr<3; ++dr) { // loop over drawers 0,1,2 - - // cabling for testbeam (change ros for ext.barrel) - int ros = drawer2ros(iros,dr); - int drawerInd = (iros%2 == 0) ? dr : dr+3; // positive drawers shifted by 3 - - for(int ch=0; ch<48; ++ch) { // loop over channels - - // cabling for testbeam (convert channel to pmt#-1) - int pmt = (m_pmtOrder) ? digiChannel2PMT(ros,ch) : ch; - - for (int gain=0; gain<2; ++gain) { - - UShort_t * samples = 0; - switch (drawerInd*2+gain) { - case 0: samples = m_ntupleStruct->Samplen0lo[pmt]; break; - case 1: samples = m_ntupleStruct->Samplen0hi[pmt]; break; - case 2: samples = m_ntupleStruct->Samplen1lo[pmt]; break; - case 3: samples = m_ntupleStruct->Samplen1hi[pmt]; break; - case 4: samples = m_ntupleStruct->Samplen2lo[pmt]; break; - case 5: samples = m_ntupleStruct->Samplen2hi[pmt]; break; - case 6: samples = m_ntupleStruct->Samplep0lo[pmt]; break; - case 7: samples = m_ntupleStruct->Samplep0hi[pmt]; break; - case 8: samples = m_ntupleStruct->Samplep1lo[pmt]; break; - case 9: samples = m_ntupleStruct->Samplep1hi[pmt]; break; - case 10: samples = m_ntupleStruct->Samplep2lo[pmt]; break; - case 11: samples = m_ntupleStruct->Samplep2hi[pmt]; break; - default: - ATH_MSG_ERROR ( "Bad drawer ID: IROS=" << iros << ", dr=" << dr ); - } - - HWIdentifier adc_id = m_tileHWID->adc_id(ros,dr,ch,gain); - if (msgLvl(MSG::VERBOSE)) - msg() << MSG::VERBOSE << m_tileHWID->to_string(adc_id) - << " ch=" << ch << " pmt=" << pmt+1 << " gain=" << gain << " samples: "; - - if (samples) { - for(int i=0; i<m_nSamp; ++i) { - digitSamples[i] = samples[i]; - if (msgLvl(MSG::VERBOSE)) msg() << " " << digitSamples[i]; - } - } else { - for(int i=0; i<m_nSamp; ++i) { - digitSamples[i] = 0; - } - } - if (msgLvl(MSG::VERBOSE)) msg() << endmsg; - - TileDigits * digi = new TileDigits(adc_id,digitSamples); - pDigitsContainer->push_back(digi); - //if (verbose) { - //log << MSG::VERBOSE << m_tileHWID->to_string(adc_id) << " " << (std::string)(*digi) << endmsg; - //} - } - } - } - } - - } else { // mono gain - - for(int iros=1; iros<=2; ++iros) { // loop over Positive/Negative side - - for(int dr=0; dr<3; ++dr) { // loop over drawers 0,1,2 - - // cabling for testbeam (change ros for ext.barrel) - int ros = drawer2ros(iros,dr); - int drawerInd = (iros%2 == 0) ? dr : dr+3; // positive drawers shifted by 3 - - for(int ch=0; ch<48; ++ch) { // loop over channels - - // cabling for testbeam (convert channel to pmt#-1) - int pmt = (m_pmtOrder) ? digiChannel2PMT(ros,ch) : ch; - - int gain = 0; - UShort_t * samples = 0; - switch (drawerInd) { - case 0: gain = m_ntupleStruct->Gainn0lo[pmt]; samples = m_ntupleStruct->Samplen0lo[pmt]; break; - case 1: gain = m_ntupleStruct->Gainn1lo[pmt]; samples = m_ntupleStruct->Samplen1lo[pmt]; break; - case 2: gain = m_ntupleStruct->Gainn2lo[pmt]; samples = m_ntupleStruct->Samplen2lo[pmt]; break; - case 3: gain = m_ntupleStruct->Gainp0lo[pmt]; samples = m_ntupleStruct->Samplep0lo[pmt]; break; - case 4: gain = m_ntupleStruct->Gainp1lo[pmt]; samples = m_ntupleStruct->Samplep1lo[pmt]; break; - case 5: gain = m_ntupleStruct->Gainp2lo[pmt]; samples = m_ntupleStruct->Samplep2lo[pmt]; break; - default: - ATH_MSG_ERROR ( "Bad drawer ID: IROS=" << iros << ", dr=" << dr ); - } - - HWIdentifier adc_id = m_tileHWID->adc_id(ros,dr,ch,gain); - if (msgLvl(MSG::VERBOSE)) - msg() << MSG::VERBOSE << m_tileHWID->to_string(adc_id) - << " ch=" << ch << " pmt=" << pmt+1 << " gain=" << gain << " samples: "; - - for(int i=0; i<m_nSamp; ++i) { - digitSamples[i] = samples[i]; - if (msgLvl(MSG::VERBOSE)) msg() << " " << digitSamples[i]; - } - if (msgLvl(MSG::VERBOSE)) msg() << endmsg; - - TileDigits * digi = new TileDigits(adc_id,digitSamples); - pDigitsContainer->push_back(digi); - //if (verbose) { - //log << MSG::VERBOSE << m_tileHWID->to_string(adc_id) << " " << (std::string)(*digi) << endmsg; - //} - } - } - } - } - - sc=evtStore()->record(pDigitsContainer, m_digitsContainer, false); - if(sc.isFailure()) { - ATH_MSG_ERROR( "Failed to register the container: " << m_digitsContainer ); - } - - Incident inc(name(),IncidentType::BeginEvent); - m_beamInfo->handle (inc); - - return StatusCode::SUCCESS; -} - -//============================================== -// finalize -//============================================== -StatusCode TileTBOldNtupleRead::finalize() -{ - ATH_MSG_INFO("finalize()"); - - delete m_ntuple; - m_file->Close(); - delete m_file; - delete m_ntupleStruct; - - ATH_MSG_INFO("finalize() completed successfully"); - return StatusCode::SUCCESS; -} diff --git a/TileCalorimeter/TileTBRec/src/TileTBOldNtupleWrite.cxx b/TileCalorimeter/TileTBRec/src/TileTBOldNtupleWrite.cxx deleted file mode 100644 index fc200e3a332253c03f6dc66839358948a0e39be4..0000000000000000000000000000000000000000 --- a/TileCalorimeter/TileTBRec/src/TileTBOldNtupleWrite.cxx +++ /dev/null @@ -1,376 +0,0 @@ -/* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration -*/ - -#include "TileTBRec/TileTBOldNtupleWrite.h" -#include "TileTBRec/TileTBOldNtupleRead.h" - -//Gaudi Includes -#include "GaudiKernel/Bootstrap.h" -#include "GaudiKernel/ISvcLocator.h" -#include "GaudiKernel/IMessageSvc.h" -#include "StoreGate/StoreGateSvc.h" - -//TileCalo includes -#include "CaloIdentifier/TileID.h" -#include "TileIdentifier/TileHWID.h" -#include "TileIdentifier/TileTBFrag.h" -#include "TileCalibBlobObjs/TileCalibUtils.h" -#include "TileConditions/TileCablingService.h" -#include "TileConditions/TileCondToolEmscale.h" -#include "TileEvent/TileDigitsContainer.h" -#include "TileEvent/TileBeamElemContainer.h" -#include "TileEvent/TileRawChannelContainer.h" - -TileTBOldNtupleWrite::TileTBOldNtupleWrite(std::string name, ISvcLocator* pSvcLocator) - : AthAlgorithm(name, pSvcLocator) - , m_bigain(0) - , m_calibrateEnergyThisEvent(0) - , m_tileHWID(0) - , m_cabling(0) - , m_tileToolEmscale("TileCondToolEmscale") - , m_runNumber(0) - , m_eventNumber(0) - , m_trigType(0) - , m_file(0) - , m_ntupleWrite(0) - , m_ntupleRead(0) - , m_readNtupleAlg(0) -{ - declareProperty("TileCondToolEmscale", m_tileToolEmscale); - declareProperty("NtupleID",m_ntupleID = "h1000"); - declareProperty("NtupleDir",m_ntupleDir = "."); - declareProperty("TileDigitsContainer", m_digitsContainer = "TileDigitsCnt"); - declareProperty("TileRawChannelContainerFit", m_rawChannelContainerFit = "TileRawChannelFit"); - declareProperty("TileRawChannelContainerFlat", m_rawChannelContainerFlat = ""); // do not fill by default - declareProperty("PmtOrder", m_pmtOrder = true); - declareProperty("CalibrateEnergy", m_calibrateEnergy = true); -} - -TileTBOldNtupleWrite::~TileTBOldNtupleWrite() -{ -} - -StatusCode TileTBOldNtupleWrite::initialize() -{ - ATH_MSG_INFO ( "Initialization started" ); - - // find TileCablingService - m_cabling = TileCablingService::getInstance(); - - ATH_CHECK( detStore()->retrieve(m_tileHWID) ); - ATH_CHECK( m_tileToolEmscale.retrieve() ); - - m_readNtupleAlg=TileTBOldNtupleRead::getInstance(); - - m_bigain = m_readNtupleAlg->BiGain(); - m_runNumber = m_readNtupleAlg->RunNumber(); - m_eventNumber = m_readNtupleAlg->EventNumber(); - m_ntupleRead = m_readNtupleAlg->getNtuple(); - - char fname[100]; - sprintf(fname,"%s/r%7.7d.new.root",m_ntupleDir.c_str(),m_runNumber); - m_file= new TFile(fname,"RECREATE"); - m_ntupleWrite=new TTree(m_ntupleID.c_str(),m_ntupleRead->GetTitle()); - if (m_ntupleWrite == NULL) { - ATH_MSG_ERROR ( "Can not create ntuple " << m_ntupleID ); - return StatusCode::FAILURE; - } - - // Initialize all branches in the m->writeNtuple, using the branches and - // addresses from the m->readNtuple. Like that, no assignments should be - // needed. However, need to exclude the branches that are filled in later on - // from StoreGate. - - for(int i=0; i<m_ntupleRead->GetListOfBranches()->GetEntries(); i++) { - TBranch * br=(TBranch*)(m_ntupleRead->GetListOfBranches()->At(i)); - std::string name = br->GetName(); - std::string title = br->GetTitle(); - Float_t * ptr=this->BranchWriteNtuple(name); - if (ptr == NULL) { - m_ntupleWrite->Branch(name.c_str(),(void*)(br->GetAddress()),title.c_str()); - } else { - m_ntupleWrite->Branch(name.c_str(),(void*)ptr,title.c_str()); - } - } - - ATH_MSG_INFO ( "Initialization completed." ); - return StatusCode::SUCCESS; -} - -StatusCode TileTBOldNtupleWrite::execute() -{ - m_eventNumber = m_readNtupleAlg->EventNumber(); - m_trigType = m_readNtupleAlg->TrigType(); - ATH_MSG_DEBUG ( "Writing event " << m_eventNumber << " trig Type is " << m_trigType ); - - // do not apply Cesium and Laser calibration for CIS events - m_calibrateEnergyThisEvent = m_calibrateEnergy && (m_trigType != 8); - - // get named container - const TileRawChannelContainer* rcCnt; - - if (m_rawChannelContainerFit != "" ) { - - ATH_CHECK( evtStore()->retrieve(rcCnt, m_rawChannelContainerFit) ); - - TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit(); - - // Get iterator for all TRCColl in TRCCont - TileRawChannelContainer::const_iterator itColl = (*rcCnt).begin(); - TileRawChannelContainer::const_iterator itCollEnd = (*rcCnt).end(); - - // Go through all TileRawChannelCollections - for(; itColl != itCollEnd; ++itColl) { - - // go through all TileRawChannels in collection - TileRawChannelCollection::const_iterator it = (*itColl)->begin(); - TileRawChannelCollection::const_iterator itEnd = (*itColl)->end(); - - for(; it != itEnd; ++it) { - HWIdentifier hwid=(*it)->adc_HWID(); - - int gain = m_tileHWID->adc(hwid); - int channel = m_tileHWID->channel(hwid); - int drawer = m_tileHWID->drawer(hwid); - int ros = m_tileHWID->ros(hwid); - int drawerIdx = TileCalibUtils::getDrawerIdx(ros,drawer); - - /// Cesium and Laser calibration - /// we assume that CIS calibration was done already in Opt. filtering - /// and we have already energy in pCb - /// after cesium calibration we still have the same pCb for A and BC cells - /// what we do is just set the same scale for D-cells - double energy = (*it)->amplitude(); - if(m_calibrateEnergyThisEvent) { - energy = m_tileToolEmscale->channelCalib(drawerIdx, channel, gain, energy, - rChUnit, TileRawChannelUnit::CesiumPicoCoulombs); - /// probably we want to convert to MeV - use TileRawChannelUnit::MegaElectronVolts ? - } - - // cabling for testbeam (convert channel to pmt#-1) - int pmt = (m_pmtOrder) ? digiChannel2PMT(ros,channel) : channel; - - ATH_MSG_VERBOSE("TRC " << m_tileHWID->to_string(hwid) - << " ene="<<energy<<" time="<<(*it)->time() - <<" chi2="<<(*it)->quality()<<" ped="<<(*it)->pedestal() - <<" pmt-1="<<pmt); - - int gainMode = (m_bigain) ? gain : 0; // 0 - low gain, 1 - high gain - int drawerInd = (ros%2 == 0) ? drawer : drawer+3; // positive drawers shifted by 3 - - m_efit [gainMode][drawerInd][pmt] = energy; - m_tfit [gainMode][drawerInd][pmt] = (*it)->time(); - m_pedfit[gainMode][drawerInd][pmt] = (*it)->pedestal(); - m_chi2 [gainMode][drawerInd][pmt] = (*it)->quality(); - - } // end of loop over channels - } // end of loop over collections - } // end of if for fit method container - - - if (m_rawChannelContainerFlat != "" ) { - - ATH_CHECK( evtStore()->retrieve(rcCnt, m_rawChannelContainerFlat) ); - - TileRawChannelUnit::UNIT rChUnit = rcCnt->get_unit(); - - // Get iterator for all TRCColl in TRCCont - TileRawChannelContainer::const_iterator itColl = (*rcCnt).begin(); - TileRawChannelContainer::const_iterator itCollEnd = (*rcCnt).end(); - - // Go through all TileRawChannelCollections - for(; itColl != itCollEnd; ++itColl) { - - // go through all TileRawChannels in collection - TileRawChannelCollection::const_iterator it = (*itColl)->begin(); - TileRawChannelCollection::const_iterator itEnd = (*itColl)->end(); - - for(; it != itEnd; ++it) { - HWIdentifier hwid=(*it)->adc_HWID(); - - int gain = m_tileHWID->adc(hwid); - int channel = m_tileHWID->channel(hwid); - int drawer = m_tileHWID->drawer(hwid); - int ros = m_tileHWID->ros(hwid); - int drawerIdx = TileCalibUtils::getDrawerIdx(ros,drawer); - - /// Cesium and Laser calibration - /// we assume that CIS calibration was done already in Opt. filtering - /// and we have already energy in pCb - /// after cesium calibration we still have the same pCb for A and BC cells - /// what we do is just set the same scale for D-cells - double energy = (*it)->amplitude(); - if(m_calibrateEnergyThisEvent) { - energy = m_tileToolEmscale->channelCalib(drawerIdx, channel, gain, energy, - rChUnit, TileRawChannelUnit::CesiumPicoCoulombs); - /// probably we want to convert to MeV - use TileRawChannelUnit::MegaElectronVolts ? - } - - // cabling for testbeam (convert channel to pmt#-1) - int pmt = (m_pmtOrder) ? digiChannel2PMT(ros,channel) : channel; - - ATH_MSG_VERBOSE("TRC " << m_tileHWID->to_string(hwid) - << " flat ene="<<energy<<" time="<<(*it)->time() - <<" pmt-1="<<pmt); - - int gainMode = (m_bigain) ? gain : 0; // 0 - low gain, 1 - high gain - int drawerInd = (ros%2 == 0) ? drawer : drawer+3; // positive drawers shifted by 3 - - m_ene [gainMode][drawerInd][pmt] = energy; - m_time[gainMode][drawerInd][pmt] = (*it)->time(); - - } // end of loop over channels - } // end of loop over collections - } // end of if for flat filter method container - - m_ntupleWrite->Fill(); - - return StatusCode::SUCCESS; -} - -StatusCode TileTBOldNtupleWrite::finalize() -{ - m_file->cd(); - m_ntupleWrite->Write(); - delete m_ntupleWrite; - m_file->Close(); - delete m_file; - - return StatusCode::SUCCESS; -} - -Float_t * TileTBOldNtupleWrite::BranchWriteNtuple(const std::string name) -{ - // copy everything except of EfitXX, TfitXX, PedfitXX, Chi2XX, EneXX, TimeXX - // for these variables return the pointer to new private arrays - - if (m_bigain) { - // first low-gain fit variables - if (name == "Efitn0lo") { return &m_efit[0][0][0]; - } else if (name == "Efitn1lo") { return &m_efit[0][1][0]; - } else if (name == "Efitn2lo") { return &m_efit[0][2][0]; - } else if (name == "Efitp0lo") { return &m_efit[0][3][0]; - } else if (name == "Efitp1lo") { return &m_efit[0][4][0]; - } else if (name == "Efitp2lo") { return &m_efit[0][5][0]; - } else if (name == "Tfitn0lo") { return &m_tfit[0][0][0]; - } else if (name == "Tfitn1lo") { return &m_tfit[0][1][0]; - } else if (name == "Tfitn2lo") { return &m_tfit[0][2][0]; - } else if (name == "Tfitp0lo") { return &m_tfit[0][3][0]; - } else if (name == "Tfitp1lo") { return &m_tfit[0][4][0]; - } else if (name == "Tfitp2lo") { return &m_tfit[0][5][0]; - } else if (name == "Pedfitn0lo") { return &m_pedfit[0][0][0]; - } else if (name == "Pedfitn1lo") { return &m_pedfit[0][1][0]; - } else if (name == "Pedfitn2lo") { return &m_pedfit[0][2][0]; - } else if (name == "Pedfitp0lo") { return &m_pedfit[0][3][0]; - } else if (name == "Pedfitp1lo") { return &m_pedfit[0][4][0]; - } else if (name == "Pedfitp2lo") { return &m_pedfit[0][5][0]; - } else if (name == "Chi2n0lo") { return &m_chi2[0][0][0]; - } else if (name == "Chi2n1lo") { return &m_chi2[0][1][0]; - } else if (name == "Chi2n2lo") { return &m_chi2[0][2][0]; - } else if (name == "Chi2p0lo") { return &m_chi2[0][3][0]; - } else if (name == "Chi2p1lo") { return &m_chi2[0][4][0]; - } else if (name == "Chi2p2lo") { return &m_chi2[0][5][0]; - - // now high-gain fit variables - } else if (name == "Efitn0hi") { return &m_efit[1][0][0]; - } else if (name == "Efitn1hi") { return &m_efit[1][1][0]; - } else if (name == "Efitn2hi") { return &m_efit[1][2][0]; - } else if (name == "Efitp0hi") { return &m_efit[1][3][0]; - } else if (name == "Efitp1hi") { return &m_efit[1][4][0]; - } else if (name == "Efitp2hi") { return &m_efit[1][5][0]; - } else if (name == "Tfitn0hi") { return &m_tfit[1][0][0]; - } else if (name == "Tfitn1hi") { return &m_tfit[1][1][0]; - } else if (name == "Tfitn2hi") { return &m_tfit[1][2][0]; - } else if (name == "Tfitp0hi") { return &m_tfit[1][3][0]; - } else if (name == "Tfitp1hi") { return &m_tfit[1][4][0]; - } else if (name == "Tfitp2hi") { return &m_tfit[1][5][0]; - } else if (name == "Pedfitn0hi") { return &m_pedfit[1][0][0]; - } else if (name == "Pedfitn1hi") { return &m_pedfit[1][1][0]; - } else if (name == "Pedfitn2hi") { return &m_pedfit[1][2][0]; - } else if (name == "Pedfitp0hi") { return &m_pedfit[1][3][0]; - } else if (name == "Pedfitp1hi") { return &m_pedfit[1][4][0]; - } else if (name == "Pedfitp2hi") { return &m_pedfit[1][5][0]; - } else if (name == "Chi2n0hi") { return &m_chi2[1][0][0]; - } else if (name == "Chi2n1hi") { return &m_chi2[1][1][0]; - } else if (name == "Chi2n2hi") { return &m_chi2[1][2][0]; - } else if (name == "Chi2p0hi") { return &m_chi2[1][3][0]; - } else if (name == "Chi2p1hi") { return &m_chi2[1][4][0]; - } else if (name == "Chi2p2hi") { return &m_chi2[1][5][0]; - - // now low-gain flat filter variables - } else if (m_rawChannelContainerFlat != "" && name == "Enen0lo") { return &m_ene[0][0][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enen1lo") { return &m_ene[0][1][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enen2lo") { return &m_ene[0][2][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enep0lo") { return &m_ene[0][3][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enep1lo") { return &m_ene[0][4][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enep2lo") { return &m_ene[0][5][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timen0lo") { return &m_time[0][0][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timen1lo") { return &m_time[0][1][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timen2lo") { return &m_time[0][2][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timep0lo") { return &m_time[0][3][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timep1lo") { return &m_time[0][4][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timep2lo") { return &m_time[0][5][0]; - - // now high-gain flat filter variables - } else if (m_rawChannelContainerFlat != "" && name == "Enen0hi") { return &m_ene[1][0][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enen1hi") { return &m_ene[1][1][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enen2hi") { return &m_ene[1][2][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enep0hi") { return &m_ene[1][3][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enep1hi") { return &m_ene[1][4][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enep2hi") { return &m_ene[0][5][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timen0hi") { return &m_time[1][0][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timen1hi") { return &m_time[1][1][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timen2hi") { return &m_time[1][2][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timep0hi") { return &m_time[1][3][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timep1hi") { return &m_time[1][4][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timep2hi") { return &m_time[1][5][0]; - - } else { - return(NULL); - } - } else { // monogain - - if (name == "Efitn0") { return &m_efit[0][0][0]; - } else if (name == "Efitn1") { return &m_efit[0][1][0]; - } else if (name == "Efitn2") { return &m_efit[0][2][0]; - } else if (name == "Efitp0") { return &m_efit[0][3][0]; - } else if (name == "Efitp1") { return &m_efit[0][4][0]; - } else if (name == "Efitp2") { return &m_efit[0][5][0]; - } else if (name == "Tfitn0") { return &m_tfit[0][0][0]; - } else if (name == "Tfitn1") { return &m_tfit[0][1][0]; - } else if (name == "Tfitn2") { return &m_tfit[0][2][0]; - } else if (name == "Tfitp0") { return &m_tfit[0][3][0]; - } else if (name == "Tfitp1") { return &m_tfit[0][4][0]; - } else if (name == "Tfitp2") { return &m_tfit[0][5][0]; - } else if (name == "Pedfitn0") { return &m_pedfit[0][0][0]; - } else if (name == "Pedfitn1") { return &m_pedfit[0][1][0]; - } else if (name == "Pedfitn2") { return &m_pedfit[0][2][0]; - } else if (name == "Pedfitp0") { return &m_pedfit[0][3][0]; - } else if (name == "Pedfitp1") { return &m_pedfit[0][4][0]; - } else if (name == "Pedfitp2") { return &m_pedfit[0][5][0]; - } else if (name == "Chi2n0") { return &m_chi2[0][0][0]; - } else if (name == "Chi2n1") { return &m_chi2[0][1][0]; - } else if (name == "Chi2n2") { return &m_chi2[0][2][0]; - } else if (name == "Chi2p0") { return &m_chi2[0][3][0]; - } else if (name == "Chi2p1") { return &m_chi2[0][4][0]; - } else if (name == "Chi2p2") { return &m_chi2[0][5][0]; - - } else if (m_rawChannelContainerFlat != "" && name == "Enen0") { return &m_ene[0][0][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enen1") { return &m_ene[0][1][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enen2") { return &m_ene[0][2][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enep0") { return &m_ene[0][3][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enep1") { return &m_ene[0][4][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Enep2") { return &m_ene[0][5][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timen0") { return &m_time[0][0][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timen1") { return &m_time[0][1][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timen2") { return &m_time[0][2][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timep0") { return &m_time[0][3][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timep1") { return &m_time[0][4][0]; - } else if (m_rawChannelContainerFlat != "" && name == "Timep2") { return &m_time[0][5][0]; - - } else { - return(NULL); - } - } -} diff --git a/TileCalorimeter/TileTBRec/src/TileTBStat.cxx b/TileCalorimeter/TileTBRec/src/TileTBStat.cxx index 6ee6ad8defd50b0791cbe4ca6ff38e0649def8f7..10eaebfe26a818f0497933252eb489e9bdec6fa0 100755 --- a/TileCalorimeter/TileTBRec/src/TileTBStat.cxx +++ b/TileCalorimeter/TileTBRec/src/TileTBStat.cxx @@ -1,5 +1,5 @@ /* - Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration + Copyright (C) 2002-2018 CERN for the benefit of the ATLAS collaboration */ //***************************************************************************** @@ -22,6 +22,7 @@ //Atlas include #include "eformat/FullEventFragment.h" #include "ByteStreamCnvSvcBase/ROBDataProviderSvc.h" +#include "StoreGate/ReadHandle.h" #include "AthenaKernel/errorcheck.h" //TileCal include @@ -31,7 +32,6 @@ #include "TileEvent/TileDigitsContainer.h" #include "TileEvent/TileBeamElemContainer.h" #include "TileEvent/TileLaserObject.h" -#include "TileRecUtils/TileBeamInfoProvider.h" #include "TileByteStream/TileBeamElemContByteStreamCnv.h" #include "TileTBRec/TileTBStat.h" @@ -125,7 +125,6 @@ void StatInt::print(const char* s, bool minMaxOnly) { TileTBStat::TileTBStat(std::string name, ISvcLocator* pSvcLocator) : AthAlgorithm(name, pSvcLocator) , m_RobSvc("ROBDataProviderSvc", name) - , m_beamInfo("TileBeamInfoProvider/TileBeamInfoProvider") , m_beamCnv(0) , m_evtNr(0) , m_lasStatus(0) @@ -156,6 +155,7 @@ TileTBStat::TileTBStat(std::string name, ISvcLocator* pSvcLocator) declareProperty("PrintAllEvents", m_printAllEvents = false); declareProperty("DetectDummyFragments", m_detectDummyFragments = false); + declareProperty("TileDQstatus", m_dqStatusKey = "TileDQstatus"); m_runNo = m_evtMin = m_evtMax = m_evtBegin = m_evtNo = 0; @@ -179,11 +179,6 @@ StatusCode TileTBStat::initialize() { m_lasStatus = 0; - - CHECK( m_beamInfo.retrieve() ); - CHECK( m_beamInfo->setProperty("TileBeamElemContainer", m_beamElemContainer) ); - CHECK( m_beamInfo->setProperty("TileDigitsContainer", m_digitsContainer) ); - // start with event 0 m_evtNr = 0; m_runNo = m_evTime = m_evtNo = m_trigType = m_nSpill = m_timeBegin = m_timeLast = m_evtMax = 0; @@ -196,11 +191,15 @@ StatusCode TileTBStat::initialize() { m_timeStart = time(0); ATH_MSG_INFO( "initialization completed" ); + CHECK( m_dqStatusKey.initialize() ); + return StatusCode::SUCCESS; } StatusCode TileTBStat::execute() { + const EventContext& ctx = Gaudi::Hive::currentContext(); + const TileDQstatus* dqStatus = SG::makeHandle (m_dqStatusKey, ctx).get(); static bool first=true; static bool firstORsecond=true; @@ -296,11 +295,11 @@ StatusCode TileTBStat::execute() { } if (m_printAllEvents) - std::cout << "Fragments found in event " << m_beamCnv->eventFragment()->global_id() << " calib mode=" << m_beamInfo->checkCalibMode() << std::endl; + std::cout << "Fragments found in event " << m_beamCnv->eventFragment()->global_id() << " calib mode=" << dqStatus->calibMode() << std::endl; else if (firstORsecond) - std::cout << "Fragments found in first event, calib mode=" << m_beamInfo->checkCalibMode() << std::endl; + std::cout << "Fragments found in first event, calib mode=" << dqStatus->calibMode() << std::endl; else - std::cout << "Fragments found in second event, calib mode=" << m_beamInfo->checkCalibMode() << std::endl; + std::cout << "Fragments found in second event, calib mode=" << dqStatus->calibMode() << std::endl; std::cout << " ROB ID ROD ID Frag IDs" << std::endl; for (unsigned int i = 0; i < nrob; ++i) { std::cout << std::hex << " 0x" << m_fragMap[i].ROBid << " 0x" << m_fragMap[i].RODid; @@ -313,7 +312,7 @@ StatusCode TileTBStat::execute() { // take values from event header - memcpy(m_cisPar,m_beamInfo->cispar(), sizeof (m_cisPar)); + memcpy(m_cisPar,dqStatus->cispar(), sizeof (m_cisPar)); unsigned int testsum=0; for (int k = 4; k < 16; ++k) testsum += m_cisPar[k]; @@ -342,7 +341,7 @@ StatusCode TileTBStat::execute() { m_evTime = m_cisPar[10]; } - m_trigType = m_beamInfo->trigType(); + m_trigType = dqStatus->trigType(); if (m_trigType < 1 || m_trigType > 0x80 ) { if (m_evtNr == 0) ATH_MSG_WARNING( "no event trig type available (" << m_trigType << ") , taking trig from cispar (" << m_cisPar[12] << ")" ); @@ -362,11 +361,11 @@ StatusCode TileTBStat::execute() { m_timeBegin = m_evTime; m_evtBegin = m_evtNo; - m_calibMode = m_beamInfo->calibMode(); + m_calibMode = dqStatus->calibMode(); memcpy(m_cisBeg,m_cisPar,sizeof(m_cisBeg)); } else if (m_evtNr == 1) { // once again, first event can be junk - m_calibMode = m_beamInfo->calibMode(); + m_calibMode = dqStatus->calibMode(); } if ( ( m_evTime < m_timeBegin && (m_timeBegin - m_evTime) < 10*24*3600 ) || // less then 10 days shift in neg direction diff --git a/TileCalorimeter/TileTBRec/src/components/TileTBRec_entries.cxx b/TileCalorimeter/TileTBRec/src/components/TileTBRec_entries.cxx index 297c38bb95f5a7ce42139548005fa5faaf46bb3a..407c256632c226c250e516350282589894211e23 100644 --- a/TileCalorimeter/TileTBRec/src/components/TileTBRec_entries.cxx +++ b/TileCalorimeter/TileTBRec/src/components/TileTBRec_entries.cxx @@ -1,17 +1,11 @@ -#include "TileTBRec/TileTBNtuple.h" #include "TileTBRec/TileTBAANtuple.h" #include "TileTBRec/TileTBStat.h" #include "TileTBRec/TileTBDump.h" -#include "TileTBRec/TileTBOldNtupleRead.h" -#include "TileTBRec/TileTBOldNtupleWrite.h" #include "TileTBRec/TileDigitsGainFilter.h" -DECLARE_COMPONENT( TileTBNtuple ) DECLARE_COMPONENT( TileTBAANtuple ) DECLARE_COMPONENT( TileTBStat ) DECLARE_COMPONENT( TileTBDump ) -DECLARE_COMPONENT( TileTBOldNtupleRead ) -DECLARE_COMPONENT( TileTBOldNtupleWrite ) DECLARE_COMPONENT( TileDigitsGainFilter ) diff --git a/Tools/CoolDozer/python/RTTDozerApp.py b/Tools/CoolDozer/python/RTTDozerApp.py index e227ec66847d5c046ccf3c132e7471320e70f013..a1eaca39d378604e605b7718bef4228f19a3de7b 100644 --- a/Tools/CoolDozer/python/RTTDozerApp.py +++ b/Tools/CoolDozer/python/RTTDozerApp.py @@ -338,7 +338,7 @@ class RTTDozerApp( DozerApp ): else: - self.panic("--> db is closed, crap!") + self.panic("--> db is closed!") self.html( "Cannot open db..." ) self.info("-> exiting reader") diff --git a/Tools/PyUtils/python/scripts/gen_klass.py b/Tools/PyUtils/python/scripts/gen_klass.py index 6dfe33145024f4cf249233a708e9b16559f1cebb..8b76c4c07907d0a43f01f5f758883f2c09b5e1dd 100644 --- a/Tools/PyUtils/python/scripts/gen_klass.py +++ b/Tools/PyUtils/python/scripts/gen_klass.py @@ -269,7 +269,7 @@ public: virtual ~%(klass)s() override; virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; virtual StatusCode finalize() override; private: @@ -306,7 +306,7 @@ StatusCode %(klass)s::finalize() return StatusCode::SUCCESS; } -StatusCode %(klass)s::execute_r(const EventContext& context) const +StatusCode %(klass)s::execute(const EventContext& context) const { return StatusCode::SUCCESS; } diff --git a/Tracking/Acts/ActsGeometry/ActsGeometry/ActsExtrapolationAlg.h b/Tracking/Acts/ActsGeometry/ActsGeometry/ActsExtrapolationAlg.h index 804781a38aa82fca8aca5ae6259e5038a1925493..8199f5b18be8772ded74582195f383c91f6b7777 100755 --- a/Tracking/Acts/ActsGeometry/ActsGeometry/ActsExtrapolationAlg.h +++ b/Tracking/Acts/ActsGeometry/ActsGeometry/ActsExtrapolationAlg.h @@ -51,7 +51,7 @@ class ActsExtrapolationAlg : public AthReentrantAlgorithm { public: ActsExtrapolationAlg (const std::string& name, ISvcLocator* pSvcLocator); StatusCode initialize() override; - StatusCode execute_r(const EventContext& ctx) const override; + StatusCode execute(const EventContext& ctx) const override; StatusCode finalize() override; private: diff --git a/Tracking/Acts/ActsGeometry/src/ActsExtrapolationAlg.cxx b/Tracking/Acts/ActsGeometry/src/ActsExtrapolationAlg.cxx index f3b6efd85c0d10ea1ad21ede143aa2d5852a1f0e..7116c589e66a3718333779faaf679bd98fb98f0f 100755 --- a/Tracking/Acts/ActsGeometry/src/ActsExtrapolationAlg.cxx +++ b/Tracking/Acts/ActsGeometry/src/ActsExtrapolationAlg.cxx @@ -58,7 +58,7 @@ StatusCode ActsExtrapolationAlg::initialize() { return StatusCode::SUCCESS; } -StatusCode ActsExtrapolationAlg::execute_r(const EventContext& ctx) const +StatusCode ActsExtrapolationAlg::execute(const EventContext& ctx) const { ATH_MSG_VERBOSE(name() << "::" << __FUNCTION__); diff --git a/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/TrkCollectionAliasAlg/TrkCollectionAliasAlg.h b/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/TrkCollectionAliasAlg/TrkCollectionAliasAlg.h index 76247d48f6bdb14b0aa2ee5476404d67070045fb..f04d848c49879d0c212b8029efb4dcbafa8e50d9 100755 --- a/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/TrkCollectionAliasAlg/TrkCollectionAliasAlg.h +++ b/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/TrkCollectionAliasAlg/TrkCollectionAliasAlg.h @@ -39,7 +39,7 @@ namespace Trk /** standard Athena-Algorithm method */ StatusCode initialize(); /** standard Athena-Algorithm method */ - StatusCode execute_r(const EventContext& ctx) const; + StatusCode execute(const EventContext& ctx) const; /** standard Athena-Algorithm method */ StatusCode finalize(); diff --git a/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/src/TrkCollectionAliasAlg.cxx b/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/src/TrkCollectionAliasAlg.cxx index 74255a52b705ea39e43ad40308262d010c15ca14..5f8f82ab459cbedc01d3a6e6f5739eafe8c70b6b 100755 --- a/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/src/TrkCollectionAliasAlg.cxx +++ b/Tracking/TrkAlgorithms/TrkCollectionAliasAlg/src/TrkCollectionAliasAlg.cxx @@ -43,7 +43,7 @@ StatusCode Trk::TrkCollectionAliasAlg::finalize() //================ Execution ==================================================== -StatusCode Trk::TrkCollectionAliasAlg::execute_r(const EventContext& ctx) const +StatusCode Trk::TrkCollectionAliasAlg::execute(const EventContext& ctx) const { SG::ReadHandle<TrackCollection> tracks(m_collectionName, ctx ); return tracks.alias(m_aliasName); diff --git a/Tracking/TrkFitter/TrkRefitAlg/CMakeLists.txt b/Tracking/TrkFitter/TrkRefitAlg/CMakeLists.txt index 70017f1ba32d32f52a137c14cb6f433a7b46f7d5..aff343f6fe6ec53e810b945fbb4f72fcb8a55c5f 100644 --- a/Tracking/TrkFitter/TrkRefitAlg/CMakeLists.txt +++ b/Tracking/TrkFitter/TrkRefitAlg/CMakeLists.txt @@ -15,7 +15,6 @@ atlas_depends_on_subdirs( PUBLIC Tracking/TrkFitter/TrkFitterUtils InnerDetector/InDetConditions/BeamSpotConditionsData PRIVATE - InnerDetector/InDetConditions/InDetBeamSpotService Tracking/TrkDetDescr/TrkSurfaces Tracking/TrkEvent/TrkMeasurementBase Tracking/TrkEvent/TrkParameters diff --git a/Tracking/TrkFitter/TrkRefitAlg/src/ReFitTrack.cxx b/Tracking/TrkFitter/TrkRefitAlg/src/ReFitTrack.cxx index 71e2448159d54c800874aa049bd29af7601fb97d..0ddf51b33f948f1ea0e1a3f34611efa962018b3c 100755 --- a/Tracking/TrkFitter/TrkRefitAlg/src/ReFitTrack.cxx +++ b/Tracking/TrkFitter/TrkRefitAlg/src/ReFitTrack.cxx @@ -27,7 +27,6 @@ #include "TrkToolInterfaces/IPRD_AssociationTool.h" #include "TrkToolInterfaces/ITrackSelectorTool.h" #include "TrkExInterfaces/IExtrapolator.h" -#include "InDetBeamSpotService/IBeamCondSvc.h" #include "VxVertex/VxContainer.h" #include "VxVertex/RecVertex.h" diff --git a/Tracking/TrkTools/TrkParticleCreator/CMakeLists.txt b/Tracking/TrkTools/TrkParticleCreator/CMakeLists.txt index a18f7f9f6c123d3fcf9416d3b9f816c87cdb84d8..88a0726d4b452a8d673039657a5f734017f2f2fb 100644 --- a/Tracking/TrkTools/TrkParticleCreator/CMakeLists.txt +++ b/Tracking/TrkTools/TrkParticleCreator/CMakeLists.txt @@ -27,7 +27,6 @@ atlas_depends_on_subdirs( DetectorDescription/AtlasDetDescr DetectorDescription/GeoPrimitives DetectorDescription/IdDictDetDescr - InnerDetector/InDetConditions/InDetBeamSpotService InnerDetector/InDetConditions/BeamSpotConditionsData InnerDetector/InDetRecEvent/InDetPrepRawData InnerDetector/InDetRecEvent/InDetRIO_OnTrack diff --git a/Tracking/TrkTools/TrkParticleCreator/src/TrackParticleCreatorTool.cxx b/Tracking/TrkTools/TrkParticleCreator/src/TrackParticleCreatorTool.cxx index b737e56dac0c52189e6d3ce733032a857903a214..0f715ddce3258669c92294d86ee18229d9e3cd07 100644 --- a/Tracking/TrkTools/TrkParticleCreator/src/TrackParticleCreatorTool.cxx +++ b/Tracking/TrkTools/TrkParticleCreator/src/TrackParticleCreatorTool.cxx @@ -18,7 +18,6 @@ #include "TrkExInterfaces/IExtrapolator.h" #include "ITrackToVertex/ITrackToVertex.h" #include "MagFieldInterfaces/IMagFieldSvc.h" -#include "InDetBeamSpotService/IBeamCondSvc.h" #include "TrkTrack/Track.h" #include "Particle/TrackParticle.h" #include "VxVertex/VxCandidate.h" diff --git a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.cxx b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.cxx index cf49de8f78d389055edc392200a96fdef1335339..66e7c47f03ac14810961ed1bf9e375fd7c45eb6e 100644 --- a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.cxx +++ b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.cxx @@ -44,7 +44,7 @@ StatusCode HLTCaloCellMaker::initialize() { return StatusCode::SUCCESS; } -StatusCode HLTCaloCellMaker::execute_r( const EventContext& context ) const { +StatusCode HLTCaloCellMaker::execute( const EventContext& context ) const { auto roisHandle = SG::makeHandle( m_roiCollectionKey ); diff --git a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.h b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.h index 8bc57f09856657a5cb1d15efaeb6b0ea7ef07bf3..db57c58b91c267161d379c23618545f4bed6b2d4 100644 --- a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.h +++ b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellMaker.h @@ -39,7 +39,7 @@ class HLTCaloCellMaker: public AthReentrantAlgorithm { HLTCaloCellMaker(const std::string & name, ISvcLocator* pSvcLocator); ~HLTCaloCellMaker(); - StatusCode execute_r(const EventContext& context ) const ; + StatusCode execute(const EventContext& context ) const ; StatusCode initialize(); private: diff --git a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.cxx b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.cxx index dbe2c9194df939bcea33aaf02a96c3d3a0bc6ef4..873b4471cc9d0a18d6474b356e0b5eb2e3fb42b0 100644 --- a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.cxx +++ b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.cxx @@ -36,7 +36,7 @@ StatusCode HLTCaloCellSumMaker::initialize() { return StatusCode::SUCCESS; } -StatusCode HLTCaloCellSumMaker::execute_r( const EventContext& /*context*/ ) const { +StatusCode HLTCaloCellSumMaker::execute( const EventContext& /*context*/ ) const { if ( m_roiMode ) { diff --git a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.h b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.h index 95349f86e12128d721b83addeef65f116e9b1c1a..573c70c15335785fde18389d8662c300e271ffc3 100644 --- a/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.h +++ b/Trigger/TrigAlgorithms/TrigCaloRec/src/HLTCaloCellSumMaker.h @@ -29,7 +29,7 @@ class HLTCaloCellSumMaker: public AthReentrantAlgorithm { HLTCaloCellSumMaker(const std::string & name, ISvcLocator* pSvcLocator); ~HLTCaloCellSumMaker(); - StatusCode execute_r(const EventContext& context ) const ; + StatusCode execute(const EventContext& context ) const ; StatusCode initialize(); private: diff --git a/Trigger/TrigAlgorithms/TrigEFMissingET/TrigEFMissingET/EFMissingETAlgMT.h b/Trigger/TrigAlgorithms/TrigEFMissingET/TrigEFMissingET/EFMissingETAlgMT.h index 6c844543d1222b3f194da1d062318e7b97268909..3c463bc32749454104eba126ac9fd85100d6c096 100644 --- a/Trigger/TrigAlgorithms/TrigEFMissingET/TrigEFMissingET/EFMissingETAlgMT.h +++ b/Trigger/TrigAlgorithms/TrigEFMissingET/TrigEFMissingET/EFMissingETAlgMT.h @@ -32,7 +32,7 @@ class EFMissingETAlgMT : public ::AthReentrantAlgorithm //EFMissingETMT &operator=(const EFMissingETMT &alg); virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; private: diff --git a/Trigger/TrigAlgorithms/TrigEFMissingET/src/EFMissingETAlgMT.cxx b/Trigger/TrigAlgorithms/TrigEFMissingET/src/EFMissingETAlgMT.cxx index 55b1375d0a63636ae2f169479a4c770514f08926..1deffc8ab57dcc42a03fd5623cbc16ead2bc65d4 100644 --- a/Trigger/TrigAlgorithms/TrigEFMissingET/src/EFMissingETAlgMT.cxx +++ b/Trigger/TrigAlgorithms/TrigEFMissingET/src/EFMissingETAlgMT.cxx @@ -41,7 +41,7 @@ double toLinGeV( double x, double fallback = 0, double epsilon = 1e-6 ) { } -StatusCode EFMissingETAlgMT::execute_r( const EventContext& context ) const { +StatusCode EFMissingETAlgMT::execute( const EventContext& context ) const { ATH_MSG_DEBUG ( "Executing " << name() << "..." ); using namespace Monitored; auto totalTimer = MonitoredTimer::declare( "TIME_Total" ); diff --git a/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.cxx b/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.cxx index 0d5c56479898d99bc186a32888dca5cc1e801319..99ac204d60a5bcca8c1124f405019def259a745c 100644 --- a/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.cxx +++ b/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.cxx @@ -326,7 +326,7 @@ void TestCaloDataAccess::emulateFixedRoIs( const EventContext& context, std::vec } -StatusCode TestCaloDataAccess::execute_r( const EventContext& context ) const { +StatusCode TestCaloDataAccess::execute( const EventContext& context ) const { ATH_MSG_DEBUG ( "Executing " << name() << "..." ); std::vector<ParallelCallTest*> allRoIs; diff --git a/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.h b/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.h index 4e1adeb69133606e6156fcac959b7bbc16997cb4..2773288de16ea464296e4524346b01d52b402922 100644 --- a/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.h +++ b/Trigger/TrigAlgorithms/TrigT2CaloCommon/src/TestCaloDataAccess.h @@ -26,7 +26,7 @@ class TestCaloDataAccess TestCaloDataAccess( const std::string& name, ISvcLocator* pSvcLocator ); virtual ~TestCaloDataAccess(); virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; private: TestCaloDataAccess(); diff --git a/Trigger/TrigAlgorithms/TrigT2CaloEgamma/TrigT2CaloEgamma/T2CaloEgammaReFastAlgo.h b/Trigger/TrigAlgorithms/TrigT2CaloEgamma/TrigT2CaloEgamma/T2CaloEgammaReFastAlgo.h index cac73b16f54145144f13e240ae2bf1521a20b21c..e8eaf1b5b194d5f9a663ec25bb09d6fe7d440145 100755 --- a/Trigger/TrigAlgorithms/TrigT2CaloEgamma/TrigT2CaloEgamma/T2CaloEgammaReFastAlgo.h +++ b/Trigger/TrigAlgorithms/TrigT2CaloEgamma/TrigT2CaloEgamma/T2CaloEgammaReFastAlgo.h @@ -47,7 +47,7 @@ class T2CaloEgammaReFastAlgo: public AthReentrantAlgorithm { /** main execute will call FEX IAlgToolCalo::execute() to process RoI. called by the Steering per EMRoI. */ - StatusCode execute_r(const EventContext& context ) const; + StatusCode execute(const EventContext& context ) const; /** initialize. Called by the Steering. */ StatusCode initialize(); /** hltFinalize. Called by the Steering. */ diff --git a/Trigger/TrigAlgorithms/TrigT2CaloEgamma/src/T2CaloEgammaReFastAlgo.cxx b/Trigger/TrigAlgorithms/TrigT2CaloEgamma/src/T2CaloEgammaReFastAlgo.cxx index 5b16ba06c3b4f949b2658b8cd0fc79ff046dc4ed..23bf17a054db29331815d5e65a2d23e9dbf57aec 100755 --- a/Trigger/TrigAlgorithms/TrigT2CaloEgamma/src/T2CaloEgammaReFastAlgo.cxx +++ b/Trigger/TrigAlgorithms/TrigT2CaloEgamma/src/T2CaloEgammaReFastAlgo.cxx @@ -73,7 +73,7 @@ StatusCode T2CaloEgammaReFastAlgo::initialize() } -StatusCode T2CaloEgammaReFastAlgo::execute_r(const EventContext& context) const +StatusCode T2CaloEgammaReFastAlgo::execute(const EventContext& context) const { // Time total T2CaloEgamma execution time. // if ( m_timersvc ) m_timer[0]->start(); diff --git a/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.cxx b/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.cxx index 63f722c1d4e0894f86ab16b00b60b30518ebdb3d..53a9b8cc4b22b0d3984f9dcfb1525f942ba66b73 100644 --- a/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.cxx +++ b/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.cxx @@ -66,7 +66,7 @@ StatusCode TrigDecisionMakerMT::finalize() } -StatusCode TrigDecisionMakerMT::execute_r(const EventContext& context) const +StatusCode TrigDecisionMakerMT::execute(const EventContext& context) const { // increment event counter m_nEvents++; diff --git a/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.h b/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.h index 1d9e3a0af5e77d6d623734a98bdb66ca2a9d0446..4a9866733263c9d6959af6dc777241d7a6026e8d 100644 --- a/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.h +++ b/Trigger/TrigAnalysis/TrigDecisionMaker/src/TrigDecisionMakerMT.h @@ -76,7 +76,7 @@ namespace TrigDec { // IAlgorithm virtual methods to implement virtual StatusCode initialize() override; //!< std Gaudi initialize method -> read-in trigger configuration - virtual StatusCode execute_r( const EventContext& context ) const override; //!< Re-entrant execute to create the xAOD::TrigDecision + virtual StatusCode execute( const EventContext& context ) const override; //!< Re-entrant execute to create the xAOD::TrigDecision virtual StatusCode finalize() override; //!< std Gaudi finalize method -> print out statistics StatusCode getL1Result (const LVL1CTP::Lvl1Result*& result, const EventContext& context) const; //!< retrieve LVL1 result (called in execute) diff --git a/Trigger/TrigCost/TrigCostPython/macros/makeGroupXML.py b/Trigger/TrigCost/TrigCostPython/macros/makeGroupXML.py index 972806d256440e9ba55a6bc01b1d8a4e04f9b386..ea0f27c7374b4cd36b29cfe31465e69ef4b4d383 100755 --- a/Trigger/TrigCost/TrigCostPython/macros/makeGroupXML.py +++ b/Trigger/TrigCost/TrigCostPython/macros/makeGroupXML.py @@ -398,7 +398,7 @@ def MakeGroups(trig_list, level) : return groups -# Fill the group list with a bunch of crap +# Fill the group list with a bunch of stuff def MakeCumulativeGroups(group_dict) : cumu_group = dict() diff --git a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.cxx index a3fa7c9fc92f5390868c1a5f215be2e8df620c05..3a7a9e67fbe45b8932ce04ba2803660cee3c94f9 100644 --- a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.cxx +++ b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.cxx @@ -42,7 +42,7 @@ StatusCode TrigBjetEtHypoAlgMT::finalize() { return StatusCode::SUCCESS; } -StatusCode TrigBjetEtHypoAlgMT::execute_r( const EventContext& context ) const { +StatusCode TrigBjetEtHypoAlgMT::execute( const EventContext& context ) const { ATH_MSG_INFO ( "Executing " << name() << "..." ); // ========================================================================================================================== diff --git a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.h b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.h index 675eac792f5e821307240ad202bc7ff03c20fddc..fa57097df4b891a19c70375aef732c52ebbd777d 100644 --- a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.h +++ b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetEtHypoAlgMT.h @@ -34,7 +34,7 @@ class TrigBjetEtHypoAlgMT : public ::HypoBase { virtual ~TrigBjetEtHypoAlgMT(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.cxx index fa48a143de29d341530831641eeda641bf817a8a..3d5da42c57c207306c46c1320c17777f548b0022 100644 --- a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.cxx +++ b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.cxx @@ -42,7 +42,7 @@ StatusCode TrigBjetHypoAlgMT::finalize() { return StatusCode::SUCCESS; } -StatusCode TrigBjetHypoAlgMT::execute_r( const EventContext& context ) const { +StatusCode TrigBjetHypoAlgMT::execute( const EventContext& context ) const { ATH_MSG_DEBUG ( "Executing " << name() << "..." ); SG::ReadHandle< TrigCompositeUtils::DecisionContainer > prevDecisionHandle = SG::makeHandle( decisionInput(),context ); diff --git a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.h b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.h index a4d71f886a8ed5dced9a8bf6dce19a1b71b9aafc..e141515784890d8a6fc2c69a9b8a26195df3659a 100644 --- a/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.h +++ b/Trigger/TrigHypothesis/TrigBjetHypo/src/TrigBjetHypoAlgMT.h @@ -34,7 +34,7 @@ class TrigBjetHypoAlgMT : public ::HypoBase { virtual ~TrigBjetHypoAlgMT(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.cxx index c85abd2c4bf60516c1372221b0d480513b87a603..b5d7bcf9eb119224617abc759c0c677095712bd5 100644 --- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.cxx +++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.cxx @@ -33,7 +33,7 @@ StatusCode TrigL2CaloHypoAlgMT::finalize() { } -StatusCode TrigL2CaloHypoAlgMT::execute_r( const EventContext& context ) const { +StatusCode TrigL2CaloHypoAlgMT::execute( const EventContext& context ) const { ATH_MSG_DEBUG ( "Executing " << name() << "..." ); auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context ); if( not previousDecisionsHandle.isValid() ) {//implicit diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.h b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.h index 39d75c7f156c0bba703a36d0cac731c0fe26e4aa..a7a7d4697ba66aafbf9b9855fb01f1d0bc5f5d87 100644 --- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.h +++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2CaloHypoAlgMT.h @@ -27,7 +27,7 @@ class TrigL2CaloHypoAlgMT : public ::HypoBase { virtual ~TrigL2CaloHypoAlgMT(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.cxx index 439a3922b24cd7f7052ec20d760abcd32c351841..4d0b0016031389a77c63dbf2cde14e5d03f7de98 100644 --- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.cxx +++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.cxx @@ -38,7 +38,7 @@ StatusCode TrigL2ElectronHypoAlgMT::initialize() { return StatusCode::SUCCESS; } -StatusCode TrigL2ElectronHypoAlgMT::execute_r( const EventContext& context ) const { +StatusCode TrigL2ElectronHypoAlgMT::execute( const EventContext& context ) const { ATH_MSG_DEBUG ( "Executing " << name() << "..." ); auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context ); if( not previousDecisionsHandle.isValid() ) {//implicit diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.h b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.h index de5c9354cfb0b23c729732835722c0ce09bc46ba..530a4f1970d862165c1bd7f57ab354c35551eb59 100644 --- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.h +++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2ElectronHypoAlgMT.h @@ -30,7 +30,7 @@ class TrigL2ElectronHypoAlgMT : public ::HypoBase virtual ~TrigL2ElectronHypoAlgMT(); virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; virtual StatusCode finalize() override; diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.cxx index 5eee805ee8ad0bb6426596f585d3b35e45bec084..84267f8b9667c54870e1552dca856922bdebf6d8 100644 --- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.cxx +++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.cxx @@ -38,7 +38,7 @@ StatusCode TrigL2PhotonHypoAlgMT::finalize() { } -StatusCode TrigL2PhotonHypoAlgMT::execute_r( const EventContext& context ) const { +StatusCode TrigL2PhotonHypoAlgMT::execute( const EventContext& context ) const { ATH_MSG_DEBUG ( "Executing " << name() << "..." ); auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context ); if( not previousDecisionsHandle.isValid() ) {//implicit diff --git a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.h b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.h index b0c40fb1f76aabba75e568862942daa5b883a596..2961c2f5ef6545f82163b81e6d298a315d47c389 100644 --- a/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.h +++ b/Trigger/TrigHypothesis/TrigEgammaHypo/src/TrigL2PhotonHypoAlgMT.h @@ -33,7 +33,7 @@ class TrigL2PhotonHypoAlgMT : public ::HypoBase virtual ~TrigL2PhotonHypoAlgMT(); virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; virtual StatusCode finalize() override; diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx index b655c25ca093819010ec3514b98dd95ba648c975..e9d1626f137932879a9b57e8e759c0fecae60abb 100644 --- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx +++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.cxx @@ -34,7 +34,7 @@ StatusCode TrigJetHypoAlgMT::initialize() { } -StatusCode TrigJetHypoAlgMT::execute_r( const EventContext& context ) const { +StatusCode TrigJetHypoAlgMT::execute( const EventContext& context ) const { ATH_MSG_DEBUG ( "Executing " << name() << "..." ); diff --git a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.h b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.h index c9284f39d28f0ebf645fd072eef40d3f399f8c6d..d4413eb184e538ed3e8714bd6a22e9ae32f5cd13 100644 --- a/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.h +++ b/Trigger/TrigHypothesis/TrigHLTJetHypo/src/TrigJetHypoAlgMT.h @@ -26,7 +26,7 @@ class TrigJetHypoAlgMT : public ::HypoBase { virtual ~TrigJetHypoAlgMT(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.cxx b/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.cxx index 31dded544e14b61cdf1090b214446c424dd22388..5e2a85c76c9cb8fea45de1a47af2b19d8e715545 100644 --- a/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.cxx +++ b/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.cxx @@ -34,7 +34,7 @@ StatusCode TrigL2CaloRingerHypoAlgMT::initialize() { } -StatusCode TrigL2CaloRingerHypoAlgMT::execute_r( const EventContext& context ) const { +StatusCode TrigL2CaloRingerHypoAlgMT::execute( const EventContext& context ) const { ATH_MSG_DEBUG ( "Executing " << name() << "..." ); // prepare decisions container and link back to the clusters, and decision on clusters diff --git a/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.h b/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.h index a6bb833cd96faf7cd24da68672968ec5a64a8f30..2163e6e2840f9efadb5a976f97b7ee8cf739ca67 100644 --- a/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.h +++ b/Trigger/TrigHypothesis/TrigMultiVarHypo/src/TrigL2CaloRingerHypoAlgMT.h @@ -27,7 +27,7 @@ class TrigL2CaloRingerHypoAlgMT virtual ~TrigL2CaloRingerHypoAlgMT(); virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; private: diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMufastHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMufastHypoAlg.h index f0e47910b76f3417bda74bee9ce8204b9cd0fc04..c8582c347b07aa8e697151f7a3e76a47d057e42b 100644 --- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMufastHypoAlg.h +++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMufastHypoAlg.h @@ -33,7 +33,7 @@ class TrigMufastHypoAlg virtual ~TrigMufastHypoAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuisoHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuisoHypoAlg.h index a1f2d650b0fcd1488fc3789f503e6dc015ffe5b4..7c312b640cd9ab5eef50a8c143922153e06c07c6 100644 --- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuisoHypoAlg.h +++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuisoHypoAlg.h @@ -42,7 +42,7 @@ class TrigMuisoHypoAlg virtual ~TrigMuisoHypoAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFCombinerHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFCombinerHypoAlg.h index d1b8a8436f0f79e1a5b4806d28c31589b03334a9..01e488d97d9de7505b4a81af482c60cda62c64b6 100644 --- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFCombinerHypoAlg.h +++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFCombinerHypoAlg.h @@ -34,7 +34,7 @@ class TrigMuonEFCombinerHypoAlg virtual ~TrigMuonEFCombinerHypoAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFMSonlyHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFMSonlyHypoAlg.h index de0f356c40da839334ecc32a1cc4083542ca953b..52d0cc03178b3bcbf241fb32512432d02023a380 100644 --- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFMSonlyHypoAlg.h +++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFMSonlyHypoAlg.h @@ -34,7 +34,7 @@ class TrigMuonEFMSonlyHypoAlg virtual ~TrigMuonEFMSonlyHypoAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFTrackIsolationHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFTrackIsolationHypoAlg.h index c6fd5ff06fe445a78f13b1d7c7fbd81322c701db..490db37657c8a7d48e7293b5f6a5f13e7084d084 100644 --- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFTrackIsolationHypoAlg.h +++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigMuonEFTrackIsolationHypoAlg.h @@ -34,7 +34,7 @@ class TrigMuonEFTrackIsolationHypoAlg virtual ~TrigMuonEFTrackIsolationHypoAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigmuCombHypoAlg.h b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigmuCombHypoAlg.h index 6562a9155bf5c6a7e2ef7190cd2656664daa5a32..42e381e5de836f7e3570c53a90e919a123198edc 100644 --- a/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigmuCombHypoAlg.h +++ b/Trigger/TrigHypothesis/TrigMuonHypo/TrigMuonHypo/TrigmuCombHypoAlg.h @@ -34,7 +34,7 @@ class TrigmuCombHypoAlg virtual ~TrigmuCombHypoAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMufastHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMufastHypoAlg.cxx index eb7531faa666cef0a969b67653d368b06a9a04e4..3be67843f23e973cc7a8d573cbd055fb88ee9edb 100755 --- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMufastHypoAlg.cxx +++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMufastHypoAlg.cxx @@ -53,11 +53,11 @@ StatusCode TrigMufastHypoAlg::finalize() // -------------------------------------------------------------------------------- // -------------------------------------------------------------------------------- -StatusCode TrigMufastHypoAlg::execute_r( const EventContext& context ) const +StatusCode TrigMufastHypoAlg::execute( const EventContext& context ) const { // common for all Hypos, to move in the base class - ATH_MSG_DEBUG("StatusCode TrigMufastHypoAlg::execute_r start"); + ATH_MSG_DEBUG("StatusCode TrigMufastHypoAlg::execute start"); auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context ); if( not previousDecisionsHandle.isValid() ) {//implicit ATH_MSG_DEBUG( "No implicit RH for previous decisions "<< decisionInput().key()<<": is this expected?" ); @@ -144,7 +144,7 @@ StatusCode TrigMufastHypoAlg::execute_r( const EventContext& context ) const } - ATH_MSG_DEBUG("StatusCode TrigMufastHypoAlg::execute_r success"); + ATH_MSG_DEBUG("StatusCode TrigMufastHypoAlg::execute success"); return StatusCode::SUCCESS; } diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuisoHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuisoHypoAlg.cxx index 24be8036725e67f6a3cd7c7e98afa0a0fa0ce607..ee8041bba84fac3254da4a89ba7ea032a5f7bfa6 100644 --- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuisoHypoAlg.cxx +++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuisoHypoAlg.cxx @@ -50,10 +50,10 @@ StatusCode TrigMuisoHypoAlg::finalize() } -StatusCode TrigMuisoHypoAlg::execute_r( const EventContext& context) const +StatusCode TrigMuisoHypoAlg::execute( const EventContext& context) const { // common for all Hypos, to move in the base class - ATH_MSG_DEBUG("StatusCode TrigMuisoHypoAlg::execute_r start"); + ATH_MSG_DEBUG("StatusCode TrigMuisoHypoAlg::execute start"); auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context ); if( not previousDecisionsHandle.isValid() ) {//implicit ATH_MSG_DEBUG( "No implicit RH for previous decisions "<< decisionInput().key()<<": is this expected?" ); @@ -128,7 +128,7 @@ StatusCode TrigMuisoHypoAlg::execute_r( const EventContext& context) const } - ATH_MSG_DEBUG("StatusCode TrigMuisoHypoAlg::execute_r success"); + ATH_MSG_DEBUG("StatusCode TrigMuisoHypoAlg::execute success"); return StatusCode::SUCCESS; } diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFCombinerHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFCombinerHypoAlg.cxx index 42e93cea363a8a3f27046650ec902cf6a3afc346..d05c606b61d62826d7f189d13002ecbb92b6abb7 100755 --- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFCombinerHypoAlg.cxx +++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFCombinerHypoAlg.cxx @@ -54,9 +54,9 @@ StatusCode TrigMuonEFCombinerHypoAlg::finalize() // -------------------------------------------------------------------------------- // -------------------------------------------------------------------------------- -StatusCode TrigMuonEFCombinerHypoAlg::execute_r( const EventContext& context ) const +StatusCode TrigMuonEFCombinerHypoAlg::execute( const EventContext& context ) const { - ATH_MSG_DEBUG("StatusCode TrigMuonEFCombinerHypoAlg::execute_r start"); + ATH_MSG_DEBUG("StatusCode TrigMuonEFCombinerHypoAlg::execute start"); // common for all hypos, to move in the base class auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context ); @@ -148,7 +148,7 @@ StatusCode TrigMuonEFCombinerHypoAlg::execute_r( const EventContext& context ) c } else ATH_MSG_WARNING( "Output decisions are NOT valid with key : " << decisionOutput().key() ); } - ATH_MSG_DEBUG("StatusCode TrigMuonEFCombinerHypoAlg::execute_r success"); + ATH_MSG_DEBUG("StatusCode TrigMuonEFCombinerHypoAlg::execute success"); return StatusCode::SUCCESS; } diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFMSonlyHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFMSonlyHypoAlg.cxx index 900abc99a14de50d48b1076d6e35f09fd6aeaba8..1c9ddf33e41a1cb11d6de4d081ecb50774036f72 100755 --- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFMSonlyHypoAlg.cxx +++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFMSonlyHypoAlg.cxx @@ -54,9 +54,9 @@ StatusCode TrigMuonEFMSonlyHypoAlg::finalize() // -------------------------------------------------------------------------------- // -------------------------------------------------------------------------------- -StatusCode TrigMuonEFMSonlyHypoAlg::execute_r( const EventContext& context ) const +StatusCode TrigMuonEFMSonlyHypoAlg::execute( const EventContext& context ) const { - ATH_MSG_DEBUG("StatusCode TrigMuonEFMSonlyHypoAlg::execute_r start"); + ATH_MSG_DEBUG("StatusCode TrigMuonEFMSonlyHypoAlg::execute start"); // common for all hypos, to move in the base class auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context ); @@ -148,7 +148,7 @@ StatusCode TrigMuonEFMSonlyHypoAlg::execute_r( const EventContext& context ) con } else ATH_MSG_WARNING( "Output decisions are NOT valid with key : " << decisionOutput().key() ); } - ATH_MSG_DEBUG("StatusCode TrigMuonEFMSonlyHypoAlg::execute_r success"); + ATH_MSG_DEBUG("StatusCode TrigMuonEFMSonlyHypoAlg::execute success"); return StatusCode::SUCCESS; } diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFTrackIsolationHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFTrackIsolationHypoAlg.cxx index 002218a2af3844a24a4d82eddd63b1f7c1acef0f..d4c867e04959f83367392632a45a6c11de61217a 100755 --- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFTrackIsolationHypoAlg.cxx +++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigMuonEFTrackIsolationHypoAlg.cxx @@ -53,7 +53,7 @@ StatusCode TrigMuonEFTrackIsolationHypoAlg::finalize() // -------------------------------------------------------------------------------- // -------------------------------------------------------------------------------- -StatusCode TrigMuonEFTrackIsolationHypoAlg::execute_r( const EventContext& context ) const +StatusCode TrigMuonEFTrackIsolationHypoAlg::execute( const EventContext& context ) const { ATH_MSG_DEBUG("Executing ..."); diff --git a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigmuCombHypoAlg.cxx b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigmuCombHypoAlg.cxx index 9de510e8c804cdf6f56d85801f5ec3b683231912..72609a6d2a914659c8a88ce28cb3ed52520c9696 100644 --- a/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigmuCombHypoAlg.cxx +++ b/Trigger/TrigHypothesis/TrigMuonHypo/src/TrigmuCombHypoAlg.cxx @@ -55,10 +55,10 @@ StatusCode TrigmuCombHypoAlg::finalize() // -------------------------------------------------------------------------------- // -------------------------------------------------------------------------------- -StatusCode TrigmuCombHypoAlg::execute_r(const EventContext& context) const +StatusCode TrigmuCombHypoAlg::execute(const EventContext& context) const { // common for all Hypos, to move in the base class - ATH_MSG_DEBUG("StatusCode TrigmuCombHypoAlg::execute_r start"); + ATH_MSG_DEBUG("StatusCode TrigmuCombHypoAlg::execute start"); auto previousDecisionsHandle = SG::makeHandle( decisionInput(), context); if ( not previousDecisionsHandle.isValid() ) {//implicit ATH_MSG_DEBUG( "No implicit ReadHandles for previous decisions " << decisionInput().key() << ": is this expected?"); @@ -133,7 +133,7 @@ StatusCode TrigmuCombHypoAlg::execute_r(const EventContext& context) const } } - ATH_MSG_DEBUG("StatusCode TrigmuCombHypoAlg::execute_r success"); + ATH_MSG_DEBUG("StatusCode TrigmuCombHypoAlg::execute success"); return StatusCode::SUCCESS; } diff --git a/Trigger/TrigMonitoring/TrigIDJpsiMonitoring/TrigIDJpsiMonitoring/AnalysisConfig_Jpsi.h b/Trigger/TrigMonitoring/TrigIDJpsiMonitoring/TrigIDJpsiMonitoring/AnalysisConfig_Jpsi.h index 8f863bab35f7deb50c9e6479cd5a6b3b40326d63..ccca92f6a79b5c6abc519ef3f2902b15123ea998 100644 --- a/Trigger/TrigMonitoring/TrigIDJpsiMonitoring/TrigIDJpsiMonitoring/AnalysisConfig_Jpsi.h +++ b/Trigger/TrigMonitoring/TrigIDJpsiMonitoring/TrigIDJpsiMonitoring/AnalysisConfig_Jpsi.h @@ -154,7 +154,7 @@ namespace TrigInDetAnalysis { std::string idChainName; if(chain.find("2mu4T_") != std::string::npos) idChainName = "L2_mu4T_IDTrkNoCut"; //if(chain.find("2mu4T_") != std::string::npos) idChainName = "L2_muon_standalone_mu4T"; - //if(chain.find("2mu4T_") != std::string::npos) idChainName = "someshit"; + //if(chain.find("2mu4T_") != std::string::npos) idChainName = "somestuff"; if(chain.find("2mu4_") != std::string::npos) idChainName = "L2_mu4_IDTrkNoCut"; if(chain.find("2mu13_") != std::string::npos) idChainName = "L2_mu13_IDTrkNoCut"; if(chain.find("e4_etcut_Jpsi") != std::string::npos) idChainName = "L2_e4_etcutid"; diff --git a/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.cxx b/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.cxx index 3d42335fe41582536cef005dbf28afe804ba262c..7a9e1a901de16f9123aee2c7a292e046d2eb8850 100644 --- a/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.cxx +++ b/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.cxx @@ -84,7 +84,7 @@ StatusCode TrigROBMoni::initialize() if ( m_steering ) { // Make list of algorithms able to request data (all but Hypo) - vector<Algorithm*>::const_iterator a; + vector<Gaudi::Algorithm*>::const_iterator a; for ( a = m_steering->subAlgorithms()->begin(); a != m_steering->subAlgorithms()->end(); ++a ) { if ( dynamic_cast<const HLT::TECreateAlgo*>(*a) ) m_fexAlgos.push_back(*a); @@ -153,7 +153,7 @@ StatusCode TrigROBMoni::bookHists() m_fexAlgos.size(), 0, m_fexAlgos.size(), m_fexAlgos.size(), 0, m_fexAlgos.size()); - vector<Algorithm*>::const_iterator a; + vector<Gaudi::Algorithm*>::const_iterator a; int bin; for ( a = m_fexAlgos.begin(), bin=1; a != m_fexAlgos.end(); ++a, ++bin ) { m_h_shared_requests->GetXaxis()->SetBinLabel(bin, (*a)->name().c_str()); @@ -341,7 +341,7 @@ StatusCode HistSet<HTYPE>::book(TrigMonitorToolBase::TrigMonGroup& monGroup, hist[SDGROUP]->GetXaxis()->SetBinLabel(bin, (*sdg).second.c_str()); } - //vector<Algorithm*>::const_iterator a; + //vector<Gaudi::Algorithm*>::const_iterator a; //for ( a = montool->m_fexAlgos.begin(), bin=1; // a != montool->m_fexAlgos.end(); ++a, ++bin ) { // hist[ALGO]->GetXaxis()->SetBinLabel(bin, (*a)->name().c_str()); diff --git a/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.h b/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.h index 2974759e0abfabc82967799477c4a74c150f01ef..9c3670b2b103e2156efb4197063e673f37c2188d 100644 --- a/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.h +++ b/Trigger/TrigMonitoring/TrigSteerMonitor/src/TrigROBMoni.h @@ -148,7 +148,7 @@ private: const HLT::TrigSteer* m_steering; /// Steering FEX algos (the ones that can request data) - std::vector<Algorithm*> m_fexAlgos; + std::vector<Gaudi::Algorithm*> m_fexAlgos; /// Map to assign ROB history codes to bins std::map<robmonitor::ROBHistory, short> m_ROBHistoryToBin; diff --git a/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeHistTool.cxx b/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeHistTool.cxx index 7df3776e4220f5f5aead1158b47c60e32b5893ef..49e9e6e9e78f18e0a94b4ad018f186341e15c33e 100755 --- a/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeHistTool.cxx +++ b/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeHistTool.cxx @@ -66,7 +66,7 @@ StatusCode TrigTimeHistTool::bookHists() ATH_CHECK(timerSvc.retrieve()); // find out for whom we are running (i.e. Algo) - const Algorithm *parentAlg = dynamic_cast<const Algorithm*>(parent()); + const Gaudi::Algorithm *parentAlg = dynamic_cast<const Gaudi::Algorithm*>(parent()); if ( parentAlg ) m_parentName = parentAlg->name(); diff --git a/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeTreeTool.cxx b/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeTreeTool.cxx index f0cb0cc94334029ebb4b4eeae4d2f01791baf6a5..a6a20a9b48c91cc8043a9e5be567e2f2a80de805 100755 --- a/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeTreeTool.cxx +++ b/Trigger/TrigMonitoring/TrigTimeMonitor/src/TrigTimeTreeTool.cxx @@ -47,7 +47,7 @@ StatusCode TrigTimeTreeTool::bookHists() { ATH_CHECK(rootHistSvc.retrieve()); // find out for whom we are running (i.e. Algo) - const Algorithm *parentAlg = dynamic_cast<const Algorithm*>(parent()); + const Gaudi::Algorithm *parentAlg = dynamic_cast<const Gaudi::Algorithm*>(parent()); if ( parentAlg ) m_parentName = parentAlg->name(); diff --git a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/HypoBase.h b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/HypoBase.h index 3a83457515bd4c33ccc6c8fd0b8613c7582219d6..dfbb61fcbd841b126100994b91de23ed700095a5 100644 --- a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/HypoBase.h +++ b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/HypoBase.h @@ -24,7 +24,7 @@ This is a base class for HLT Hypos to reduce boilerplate and enforce the common /// initialise this base class and renounce input decision key handles virtual StatusCode sysInitialize() override; /// execute to be implemented in derived clas - virtual StatusCode execute_r(const EventContext&) const override = 0; + virtual StatusCode execute(const EventContext&) const override = 0; virtual StatusCode finalize() override = 0; virtual StatusCode initialize() override = 0; diff --git a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/InputMakerBase.h b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/InputMakerBase.h index 6d75733cad0e4f4a70a73317b466e1180311cffd..10d56a39c905e6f62cdd9cf5dd687950d68b8466 100644 --- a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/InputMakerBase.h +++ b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/InputMakerBase.h @@ -25,7 +25,7 @@ This is a base class for HLT InputMakers to reduce boilerplate and enforce the c /// initialise this base class and renounce input decision key handles virtual StatusCode sysInitialize() override; /// execute to be implemented in derived clas - virtual StatusCode execute_r(const EventContext&) const override = 0; + virtual StatusCode execute(const EventContext&) const override = 0; virtual StatusCode finalize() override = 0; virtual StatusCode initialize() override = 0; diff --git a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.h b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.h index 2fc341c12912bfbe7315bcf1dc83ea612190f403..f72f8f21b16729e9981b021606b7afc0a7101ac9 100644 --- a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.h +++ b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.h @@ -31,7 +31,7 @@ namespace TrigCompositeUtils { * @brief Creates and right away records the Container CONT with the key. * Returns the WriteHandle. * No Aux store. - * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower. + * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower. **/ template<class CONT> SG::WriteHandle<CONT> createAndStoreNoAux( const SG::WriteHandleKey<CONT>& key, const EventContext& ctx = Gaudi::Hive::currentContext()); @@ -40,7 +40,7 @@ namespace TrigCompositeUtils { * @brief Creates and right away records the Container CONT with the key. * Returns the WriteHandle. * With Aux store. - * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower. + * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower. **/ template<class CONT, class AUX> SG::WriteHandle<CONT> createAndStoreWithAux( const SG::WriteHandleKey<CONT>& key, const EventContext& ctx = Gaudi::Hive::currentContext()); @@ -48,7 +48,7 @@ namespace TrigCompositeUtils { /** * @brief Creates and right away records the DecisionContainer with the key. * Returns the WriteHandle. - * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower. + * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower. **/ SG::WriteHandle<DecisionContainer> createAndStore( const SG::WriteHandleKey<DecisionContainer>& key, const EventContext& ctx = Gaudi::Hive::currentContext() ); @@ -67,7 +67,7 @@ namespace TrigCompositeUtils { * output->push_back(d); * If provided, the name is assigned to the TC object * Note that the supplied DecisionContainer must have been recorded in the event store. - * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower. + * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower. **/ Decision* newDecisionIn ( DecisionContainer* dc, const std::string& name = "", const EventContext& ctx = Gaudi::Hive::currentContext() ); diff --git a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.icc b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.icc index a11b4bb04e0975fbec40ec01cadc899ecc22dba4..93edfe6534b6e3d21ea276e02ca6c463b14204ae 100644 --- a/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.icc +++ b/Trigger/TrigSteer/DecisionHandling/DecisionHandling/TrigCompositeUtils.icc @@ -7,7 +7,7 @@ namespace TrigCompositeUtils { * @brief Creates and right away records the Container CONT with the key. * No Aux store. * Returns the WriteHandle. - * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower. + * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower. **/ template<class CONT> SG::WriteHandle<CONT> createAndStoreNoAux( const SG::WriteHandleKey<CONT>& key, const EventContext& ctx ) { @@ -21,7 +21,7 @@ namespace TrigCompositeUtils { * @brief Creates and right away records the Container CONT with the key. * With Aux store. * Returns the WriteHandle. - * If possible provide the context that comes via an argument to execute_r otherwise it will default to looking it up which is slower. + * If possible provide the context that comes via an argument to execute otherwise it will default to looking it up which is slower. **/ template<class CONT, class AUX> SG::WriteHandle<CONT> createAndStoreWithAux( const SG::WriteHandleKey<CONT>& key, const EventContext& ctx ) { diff --git a/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.cxx b/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.cxx index 4049c021fc6d2bea275b1a04b14979b504665b6b..02488db94d84359d669f5d1ac3bc075fe5ea2606 100644 --- a/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.cxx +++ b/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.cxx @@ -156,7 +156,7 @@ void ComboHypo::fillDecisionsMap( std::vector< MultiplicityMap >& dmap, const E } } -StatusCode ComboHypo::execute_r(const EventContext& context ) const { +StatusCode ComboHypo::execute(const EventContext& context ) const { ATH_MSG_DEBUG( "Executing " << name() << "..." ); diff --git a/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.h b/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.h index df97b79b2c6815cf903b5f92cbf8439125d6f705..73879a2ce883a782d2d2eea1a73feba573e91583 100644 --- a/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.h +++ b/Trigger/TrigSteer/DecisionHandling/src/ComboHypo.h @@ -27,7 +27,7 @@ public: virtual ~ComboHypo() override; virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.cxx b/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.cxx index f05fdb890ec8edee689c0411cf31e05a2766fb08..46fb361a6da8485b3d041c294c2228c4935fa484 100644 --- a/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.cxx +++ b/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.cxx @@ -42,7 +42,7 @@ StatusCode DumpDecisions::finalize() { return StatusCode::SUCCESS; } -StatusCode DumpDecisions:: execute_r( const EventContext& ctx ) const { +StatusCode DumpDecisions:: execute( const EventContext& ctx ) const { using namespace TrigCompositeUtils; // DecisionInput decisionInput; auto decisionInput = SG::makeHandle( m_decisionKey, ctx ); diff --git a/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.h b/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.h index 71ec3ce57ac56ece71b872d08a6fbd93d72b6524..dc0af6a2977760ca9d4907b0259a6b7f445fe383 100644 --- a/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.h +++ b/Trigger/TrigSteer/DecisionHandling/src/DumpDecisions.h @@ -31,7 +31,7 @@ class DumpDecisions // Athena algorithm's Hooks StatusCode initialize() override; - StatusCode execute_r( const EventContext& ctx ) const override; + StatusCode execute( const EventContext& ctx ) const override; StatusCode finalize() override; private: diff --git a/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.cxx b/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.cxx index dcbd7fb491fa9250be960a6df57e05a23f18402a..2b4e32176d6405021bef99ebc593558704812158 100644 --- a/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.cxx +++ b/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.cxx @@ -31,7 +31,7 @@ StatusCode InputMakerForRoI::finalize() { } -StatusCode InputMakerForRoI::execute_r( const EventContext& context ) const { +StatusCode InputMakerForRoI::execute( const EventContext& context ) const { ATH_MSG_DEBUG( "Executing " << name() << "..." ); // call base class helper method to read input decisions, loop over them create outputs and connect them, returns with outputHandles filled diff --git a/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.h b/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.h index 121e9009d0ea5d22210564aa0d7f29f54856fc43..a18bd505d6e84892d40e28b51cbc85a511252cd2 100644 --- a/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.h +++ b/Trigger/TrigSteer/DecisionHandling/src/InputMakerForRoI.h @@ -24,7 +24,7 @@ InputMakerForRoI( const std::string& name, ISvcLocator* pSvcLocator ); virtual ~ InputMakerForRoI(); virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext&) const override; + virtual StatusCode execute(const EventContext&) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.cxx b/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.cxx index 5bdc223042b29986dccd3e666158147f862bedb7..332b3dd1692d94d51b956e1320f533e6d3e154df 100644 --- a/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.cxx +++ b/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.cxx @@ -45,7 +45,7 @@ StatusCode TriggerSummaryAlg::initialize() return StatusCode::SUCCESS; } -StatusCode TriggerSummaryAlg::execute_r(const EventContext& context) const +StatusCode TriggerSummaryAlg::execute(const EventContext& context) const { // that is certain input diff --git a/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.h b/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.h index 10f0f19d7add72905b68139048031a8c06ec3b53..e1e58dce8d2424457e1f6a97d0b65eeca52de3eb 100644 --- a/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.h +++ b/Trigger/TrigSteer/DecisionHandling/src/TriggerSummaryAlg.h @@ -26,7 +26,7 @@ class TriggerSummaryAlg : public ::AthReentrantAlgorithm { virtual ~TriggerSummaryAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; private: diff --git a/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.cxx b/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.cxx index 5dc84ebea373fb5e730e0868dd3dc5d1238a9ae4..fa9c2a3a4b5402d3daebe77106c6ad2a705b849d 100644 --- a/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.cxx +++ b/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.cxx @@ -27,7 +27,7 @@ StatusCode CreateFullScanRoI::finalize() return StatusCode::SUCCESS; } -StatusCode CreateFullScanRoI::execute_r(const EventContext& ctx) const +StatusCode CreateFullScanRoI::execute(const EventContext& ctx) const { using namespace TrigCompositeUtils; SG::WriteHandle<TrigRoiDescriptorCollection> handle1 = createAndStoreNoAux(m_roisKey, ctx ); diff --git a/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.h b/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.h index 884eec97ca479a306f23c6b8442baefeb6765459..7c2e0acda93f1cb65e5895c32202605d839d4ccd 100644 --- a/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.h +++ b/Trigger/TrigSteer/L1Decoder/src/CreateFullScanRoI.h @@ -20,7 +20,7 @@ public: virtual ~CreateFullScanRoI() override; virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigSteer/L1Decoder/src/L1Decoder.cxx b/Trigger/TrigSteer/L1Decoder/src/L1Decoder.cxx index 69930d8318c3f2ae3e9d3b84fb4cfa7df5bf025b..7a48e1618f1bc5066457cfc076105810a3ed24a5 100644 --- a/Trigger/TrigSteer/L1Decoder/src/L1Decoder.cxx +++ b/Trigger/TrigSteer/L1Decoder/src/L1Decoder.cxx @@ -63,7 +63,7 @@ StatusCode L1Decoder::readConfiguration() { return StatusCode::SUCCESS; } -StatusCode L1Decoder::execute_r (const EventContext& ctx) const { +StatusCode L1Decoder::execute (const EventContext& ctx) const { { auto timeStampHandle = SG::makeHandle( m_startStampKey, ctx ); ATH_CHECK( timeStampHandle.record( std::make_unique<TrigTimeStamp>() ) ); diff --git a/Trigger/TrigSteer/L1Decoder/src/L1Decoder.h b/Trigger/TrigSteer/L1Decoder/src/L1Decoder.h index dff2b0dcbcf6306a1ff9e5acba56a65de850e018..21d7b7791891fcb00b1957e9322f94dfaca66e21 100644 --- a/Trigger/TrigSteer/L1Decoder/src/L1Decoder.h +++ b/Trigger/TrigSteer/L1Decoder/src/L1Decoder.h @@ -30,7 +30,7 @@ public: L1Decoder(const std::string& name, ISvcLocator* pSvcLocator); virtual StatusCode initialize() override; virtual void handle(const Incident& incident) override; - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode finalize() override; protected: // protected to support unit testing diff --git a/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.cxx b/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.cxx index afec96c42b8db34fbafece5ba3802b053f738280..85e0064e0d7fa450b94fd034192c78512b78cbf1 100644 --- a/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.cxx +++ b/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.cxx @@ -38,9 +38,9 @@ StatusCode HLTResultMTByteStreamDecoderAlg::finalize() { } // ============================================================================= -// Implementation of AthReentrantAlgorithm::execute_r +// Implementation of AthReentrantAlgorithm::execute // ============================================================================= -StatusCode HLTResultMTByteStreamDecoderAlg::execute_r(const EventContext& eventContext) const { +StatusCode HLTResultMTByteStreamDecoderAlg::execute(const EventContext& eventContext) const { ATH_MSG_DEBUG("Executing " << name()); // Create and record the HLTResultMT object diff --git a/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.h b/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.h index 64e4b468ea581278362fe09194332f53fbfce26c..cf9b1eb5c114d3b0ed72210eac8ed8367676776a 100644 --- a/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.h +++ b/Trigger/TrigSteer/TrigHLTResultByteStream/src/HLTResultMTByteStreamDecoderAlg.h @@ -25,7 +25,7 @@ public: // ------------------------- AthReentrantAlgorithm methods ------------------- virtual StatusCode initialize() override; virtual StatusCode finalize() override; - virtual StatusCode execute_r(const EventContext& eventContext) const override; + virtual StatusCode execute(const EventContext& eventContext) const override; private: // ------------------------- Properties -------------------------------------- diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx index c1c18bdb09eb9bb93cbe415584ef37dba017f332..b39c0a242a603c7ca1177ca803032b366d252a70 100644 --- a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx +++ b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.cxx @@ -28,7 +28,7 @@ StatusCode DecisionSummaryMakerAlg::finalize() { return StatusCode::SUCCESS; } -StatusCode DecisionSummaryMakerAlg::execute_r(const EventContext& context) const { +StatusCode DecisionSummaryMakerAlg::execute(const EventContext& context) const { SG::WriteHandle<TrigCompositeUtils::DecisionContainer> outputHandle = TrigCompositeUtils::createAndStore( m_summaryKey, context ); auto container = outputHandle.ptr(); diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h index 4fc76f6d72caa2c292145b18876789eaa6094ec5..ab6e7740a364448a9f8a45ac9320710742cd0499 100644 --- a/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h +++ b/Trigger/TrigSteer/TrigOutputHandling/src/DecisionSummaryMakerAlg.h @@ -19,7 +19,7 @@ public: virtual ~DecisionSummaryMakerAlg() override; virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx index f73e203cec8a921b94c7025882674e5a0a5d282f..17fae8a7e6be48423e159404ed0655add3a3022e 100644 --- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx +++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.cxx @@ -19,6 +19,6 @@ StatusCode HLTResultMTMakerAlg::finalize() { return StatusCode::SUCCESS; } -StatusCode HLTResultMTMakerAlg::execute_r(const EventContext& context) const { +StatusCode HLTResultMTMakerAlg::execute(const EventContext& context) const { return m_resultMaker->makeResult(context); } diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h index 3a53f49c3530fec4b484e5df2d2b08bd2f3f90a5..b5b4577f2dfb0de21fccb70c7a35f48fcc4413d0 100644 --- a/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h +++ b/Trigger/TrigSteer/TrigOutputHandling/src/HLTResultMTMakerAlg.h @@ -18,7 +18,7 @@ public: virtual ~HLTResultMTMakerAlg() override; virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx index a4cbf6356c6ccbbc2d562e6990e30528aaa38119..ffa7506e9973c22abd9f7d70dbbf492d03eae9b0 100644 --- a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx +++ b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.cxx @@ -34,7 +34,7 @@ StatusCode TriggerEDMDeserialiserAlg::finalize() return StatusCode::SUCCESS; } -StatusCode TriggerEDMDeserialiserAlg::execute_r(const EventContext& context) const +StatusCode TriggerEDMDeserialiserAlg::execute(const EventContext& context) const { size_t buffSize = m_initialSerialisationBufferSize; diff --git a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h index b5dd0bd519e5550a42749907a31e6197b1e1d833..5b90c8094c48df5f5ba92cba0111549f6af2d5d1 100644 --- a/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h +++ b/Trigger/TrigSteer/TrigOutputHandling/src/TriggerEDMDeserialiserAlg.h @@ -34,7 +34,7 @@ public: virtual ~TriggerEDMDeserialiserAlg() override; virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext& context) const override; + virtual StatusCode execute(const EventContext& context) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigSteer/TrigSteering/TrigSteering/TrigSteer.h b/Trigger/TrigSteer/TrigSteering/TrigSteering/TrigSteer.h index 7d27e2fe44fc1dcaa15b35bb6befa9c8a120cd1e..0a5e47ea228f4515e3a2736e73fd9fc74d6ba566 100755 --- a/Trigger/TrigSteer/TrigSteering/TrigSteering/TrigSteer.h +++ b/Trigger/TrigSteer/TrigSteering/TrigSteering/TrigSteer.h @@ -33,7 +33,7 @@ #include "TrigConfHLTData/HLTSequence.h" #include "TrigNavigation/Navigation.h" -#include "AthenaBaseComps/AthAlgorithm.h" +#include "AthenaBaseComps/AthLegacySequence.h" #include "GaudiKernel/ToolHandle.h" #include "GaudiKernel/ServiceHandle.h" #include "GaudiKernel/IIncidentListener.h" @@ -101,7 +101,7 @@ namespace HLT { @author Nicolas Berger <Nicolas.Berger@cern.ch> @author Tomasz Bold <Tomasz.Bold@cern.ch> */ - class TrigSteer : public AthAlgorithm, + class TrigSteer : public AthLegacySequence, public Athena::TimeoutMaster, public virtual ISequenceProvider, public virtual IIncidentListener diff --git a/Trigger/TrigSteer/TrigSteering/src/Sequence.cxx b/Trigger/TrigSteer/TrigSteering/src/Sequence.cxx index 696e1d402f6dad01b70a83a8f435ed215f1abbba..9ca0d442a3b616acc178f227b9f12282e241f8a8 100755 --- a/Trigger/TrigSteer/TrigSteering/src/Sequence.cxx +++ b/Trigger/TrigSteer/TrigSteering/src/Sequence.cxx @@ -73,7 +73,7 @@ Sequence::Sequence(std::vector<unsigned int> inputTypes, return; } - const Algorithm* parentAlg = dynamic_cast<const Algorithm*>(ntool->parent()); // this is the way to get parent alg name (TrigSteer_L2/EF) ugh we need better way. + const Gaudi::Algorithm* parentAlg = dynamic_cast<const Gaudi::Algorithm*>(ntool->parent()); // this is the way to get parent alg name (TrigSteer_L2/EF) ugh we need better way. if ( !parentAlg ) { m_config->getMsgStream() << MSG::WARNING << "No parent algorithm for the sequence" << endmsg; return; diff --git a/Trigger/TrigSteer/TrigSteering/src/SteeringChain.cxx b/Trigger/TrigSteer/TrigSteering/src/SteeringChain.cxx index 28facadea11a37addd75dadf5d24e09edcbf80bd..b2d2b5f1fa9f8a778cf4393b1f059967d8927ce0 100644 --- a/Trigger/TrigSteer/TrigSteering/src/SteeringChain.cxx +++ b/Trigger/TrigSteer/TrigSteering/src/SteeringChain.cxx @@ -125,7 +125,7 @@ SteeringChain::SteeringChain( const TrigConf::HLTChain* configChain, ISequencePr m_config->getMsgStream() << MSG::WARNING << "Navigation tool not available" << endmsg; return; } - const Algorithm* parentAlg = dynamic_cast<const Algorithm*>(ntool->parent()); // this is the way to get parent alg name (TrigSteer_L2/EF) ugh we need better way. + const Gaudi::Algorithm* parentAlg = dynamic_cast<const Gaudi::Algorithm*>(ntool->parent()); // this is the way to get parent alg name (TrigSteer_L2/EF) ugh we need better way. if ( !parentAlg ) { m_config->getMsgStream() << MSG::WARNING << "Parent alg not available" << endmsg; return; diff --git a/Trigger/TrigSteer/TrigSteering/src/TrigSteer.cxx b/Trigger/TrigSteer/TrigSteering/src/TrigSteer.cxx index 07c4c97239b4f07f0378c3258470eec24b22cdd1..a18eeeaedb2b70c326c4863f7f81d41cab7d7f55 100755 --- a/Trigger/TrigSteer/TrigSteering/src/TrigSteer.cxx +++ b/Trigger/TrigSteer/TrigSteering/src/TrigSteer.cxx @@ -88,7 +88,7 @@ using namespace HLT; using namespace std; TrigSteer::TrigSteer(const std::string& name, ISvcLocator* pSvcLocator) - : AthAlgorithm(name, pSvcLocator), + : AthLegacySequence(name, pSvcLocator), m_config(0), m_stepForEB(0), m_configSvc("TrigConf::TrigConfigSvc/TrigConfigSvc", name), @@ -417,12 +417,10 @@ StatusCode TrigSteer::initialize() } - - - ATH_MSG_DEBUG("initializing done"); - return StatusCode::SUCCESS; + ATH_MSG_DEBUG("initializing subAlgs"); + return AthLegacySequence::initialize(); } @@ -449,7 +447,7 @@ StatusCode TrigSteer::finalize() delete m_config; m_config=0; - return StatusCode::SUCCESS; + return AthLegacySequence::finalize(); } @@ -1023,7 +1021,7 @@ HLT::Algo* TrigSteer::getAlgo(std::string name) if (iter != m_algos.end()) algo = iter->second; else { - Algorithm* algPointer; + Gaudi::Algorithm* algPointer; if (createSubAlgorithm(subAlg_type, subAlg_name, algPointer).isSuccess()) { algo = static_cast<HLT::Algo*>(algPointer); algo->setConfig(m_config); @@ -1136,7 +1134,7 @@ HLT::Sequence* TrigSteer::createSequence(const TrigConf::HLTSequence& seq, const // get input TE types and sequences std::vector<unsigned int> inputTypes; - std::vector< Sequence* > inputSequences; + std::vector< HLT::Sequence* > inputSequences; for( TrigConf::HLTTriggerElement* inputTE : seq.inputTEs() ) { unsigned int inputId = inputTE->id(); @@ -1144,7 +1142,7 @@ HLT::Sequence* TrigSteer::createSequence(const TrigConf::HLTSequence& seq, const // make sure we have the sequences producing these inputTEs: if ( producedFirstAtLevel(inputId) == m_hltLevel ) { - Sequence* newseq = findSeqForOutputTeType( inputId ); + HLT::Sequence* newseq = findSeqForOutputTeType( inputId ); // if seq not NULL and not in vector already, save it: if (newseq && find(inputSequences.begin(), inputSequences.end(), newseq) == inputSequences.end() ) { inputSequences.push_back(newseq); @@ -1160,7 +1158,7 @@ HLT::Sequence* TrigSteer::createSequence(const TrigConf::HLTSequence& seq, const // get topo_start_from TE types const TrigConf::HLTTriggerElement* hltTopoTE = seq.topoStartTE(); std::vector<unsigned int> topoStartTypes; - Sequence * topoStartFromSequence = 0; + HLT::Sequence * topoStartFromSequence = 0; // only add an entry if pointer not NULL if (hltTopoTE) { topoStartTypes.push_back( hltTopoTE->id() ); @@ -1188,7 +1186,7 @@ HLT::Sequence* TrigSteer::createSequence(const TrigConf::HLTSequence& seq, const HLT::Sequence* newseq = new HLT::Sequence(inputTypes, outputType, firstAlgo, tailAlgos, m_config, topoStartTypes); - for (std::vector< Sequence* >::const_iterator it = inputSequences.begin(); + for (std::vector< HLT::Sequence* >::const_iterator it = inputSequences.begin(); it != inputSequences.end(); ++it) { newseq->m_previousSequences.push_back( *it ); } @@ -1238,7 +1236,8 @@ StatusCode TrigSteer::start() ATH_MSG_DEBUG("monitoring tools bookHists done " << m_monTools << " " << m_opiTools); - return StatusCode::SUCCESS; + return AthLegacySequence::start(); + } @@ -1281,7 +1280,7 @@ StatusCode TrigSteer::stop() ATH_MSG_DEBUG("monitoring tools finalHists done " << m_monTools << " " << m_opiTools); - return StatusCode::SUCCESS; + return AthLegacySequence::stop(); } diff --git a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.cxx b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.cxx index c7e05ab604085e73c61bb917ce3e8de23ed4c671..e4c97ab6141cfc20d83d6abfd31af51f17683308 100644 --- a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.cxx +++ b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.cxx @@ -26,7 +26,7 @@ StatusCode EventViewCreatorAlgorithm::initialize() { } -StatusCode EventViewCreatorAlgorithm::execute_r( const EventContext& context ) const { +StatusCode EventViewCreatorAlgorithm::execute( const EventContext& context ) const { // create the output decisions, similar to inputs (copy basic links) std::vector< SG::WriteHandle<TrigCompositeUtils::DecisionContainer> > outputHandles; @@ -43,7 +43,7 @@ StatusCode EventViewCreatorAlgorithm::execute_r( const EventContext& context ) c // auto viewVector = std::make_unique< ViewContainer >(); auto contexts = std::vector<EventContext>( ); unsigned int viewCounter = 0; - unsigned int conditionsRun = getContext().getExtension<Atlas::ExtendedEventContext>().conditionsRun(); + unsigned int conditionsRun = context.getExtension<Atlas::ExtendedEventContext>().conditionsRun(); //map all RoIs that are stored std::vector <ElementLink<TrigRoiDescriptorCollection> > RoIsFromDecision; diff --git a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.h b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.h index 515bc9030d16a810e2d699487ee4b32cd6ab81d1..0950e60efffb9aa30fd06aed9d0b509fd09eb82f 100644 --- a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.h +++ b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithm.h @@ -34,7 +34,7 @@ class EventViewCreatorAlgorithm : public ::InputMakerBase EventViewCreatorAlgorithm( const std::string& name, ISvcLocator* pSvcLocator ); virtual ~EventViewCreatorAlgorithm(); virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext&) const override; + virtual StatusCode execute(const EventContext&) const override; virtual StatusCode finalize() override { return StatusCode::SUCCESS; } protected: diff --git a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.cxx b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.cxx index a3646d8045a70b02408ccd6d15df02d5f82dbb54..c9ec14c5bb42cba252d63cb93a2c603cb027bc5e 100644 --- a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.cxx +++ b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.cxx @@ -26,14 +26,12 @@ StatusCode EventViewCreatorAlgorithmWithJets::initialize() { return StatusCode::SUCCESS; } -StatusCode EventViewCreatorAlgorithmWithJets::execute_r( const EventContext& context ) const { +StatusCode EventViewCreatorAlgorithmWithJets::execute( const EventContext& context ) const { // create the output decisions, similar to inputs (copy basic links) std::vector< SG::WriteHandle<TrigCompositeUtils::DecisionContainer> > outputHandles; ATH_CHECK (decisionInputToOutput(context, outputHandles)); // make the views - - // make the views auto viewsHandle = SG::makeHandle( m_viewsKey ); auto viewVector1 = std::make_unique< ViewContainer >(); ATH_CHECK( viewsHandle.record( std::move( viewVector1 ) ) ); @@ -42,7 +40,7 @@ StatusCode EventViewCreatorAlgorithmWithJets::execute_r( const EventContext& con // auto viewVector = std::make_unique< ViewContainer >(); auto contexts = std::vector<EventContext>( ); unsigned int viewCounter = 0; - unsigned int conditionsRun = getContext().getExtension<Atlas::ExtendedEventContext>().conditionsRun(); + unsigned int conditionsRun = context.getExtension<Atlas::ExtendedEventContext>().conditionsRun(); //map all RoIs that are stored std::vector <ElementLink<TrigRoiDescriptorCollection> > RoIsFromDecision; diff --git a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.h b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.h index ff84d82709d468fccd032bdf2fdb76aaa2d09b2f..6d39520d6e56dada64fc554ee5c8404285ae2583 100644 --- a/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.h +++ b/Trigger/TrigSteer/ViewAlgs/src/EventViewCreatorAlgorithmWithJets.h @@ -21,7 +21,7 @@ class EventViewCreatorAlgorithmWithJets : public EventViewCreatorAlgorithm { virtual ~EventViewCreatorAlgorithmWithJets(); virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext&) const override; + virtual StatusCode execute(const EventContext&) const override; private: diff --git a/Trigger/TrigSteer/ViewAlgs/src/MergeViews.cxx b/Trigger/TrigSteer/ViewAlgs/src/MergeViews.cxx index bcb8ce19512f940c2b998a54ea6c01ae2ef88cd6..a930db5a5314aff108fd760c9cc5d906be172dc9 100644 --- a/Trigger/TrigSteer/ViewAlgs/src/MergeViews.cxx +++ b/Trigger/TrigSteer/ViewAlgs/src/MergeViews.cxx @@ -11,7 +11,7 @@ StatusCode MergeViews::initialize() { return StatusCode::SUCCESS; } -StatusCode MergeViews::execute_r( const EventContext& context ) const { +StatusCode MergeViews::execute( const EventContext& context ) const { auto viewsHandle = SG::makeHandle( m_viewsKey, context ); const ViewContainer& viewsRef = *viewsHandle; diff --git a/Trigger/TrigSteer/ViewAlgs/src/MergeViews.h b/Trigger/TrigSteer/ViewAlgs/src/MergeViews.h index 51ccf3339f6cfc2665c6e11fcebd2d779e71aef6..d07e60f4b04d37413d8d02e7fdf0c7b338237666 100644 --- a/Trigger/TrigSteer/ViewAlgs/src/MergeViews.h +++ b/Trigger/TrigSteer/ViewAlgs/src/MergeViews.h @@ -9,7 +9,7 @@ class MergeViews : virtual public AthReentrantAlgorithm { public: MergeViews(const std::string& name, ISvcLocator* pSvcLocator); StatusCode initialize() override; - StatusCode execute_r( const EventContext& context ) const override; + StatusCode execute( const EventContext& context ) const override; private: SG::ReadHandleKey< ViewContainer > m_viewsKey { this, "Views", "Views", "Collection of views to read from" }; ToolHandleArray<IViewsMergerTool> m_mergingTools {this, "MergingTools", {}, "Merging tools used to perform the merging action" }; diff --git a/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.cxx b/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.cxx index 58aba266704332970a150861afdd1740ac7caa62..b62dec32b329f8140dfb05bdc1dc41e15c060f08 100644 --- a/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.cxx +++ b/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.cxx @@ -34,7 +34,7 @@ StatusCode TestViewMerger::initialize() { } -//StatusCode TestViewMerger::execute_r( const EventContext& ctx ) const { +//StatusCode TestViewMerger::execute( const EventContext& ctx ) const { StatusCode TestViewMerger::execute(){ // auto viewsHandle = SG::makeHandle( m_viewsKey, ctx ); auto viewsHandle = SG::makeHandle( m_viewsKey ); diff --git a/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.h b/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.h index fde767a3c1605c90ae29a279e2dfb26521ef0de8..13c7b85b641ed3b7b739dd81c599665cbe2701bf 100644 --- a/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.h +++ b/Trigger/TrigSteer/ViewAlgsTest/src/TestViewMerger.h @@ -26,7 +26,7 @@ public: TestViewMerger( const std::string& name, ISvcLocator* pSvcLocator ); StatusCode initialize(); StatusCode execute(); - // StatusCode execute_r( const EventContext& ctx ) const; + // StatusCode execute( const EventContext& ctx ) const; private: SG::ReadHandleKey< ViewContainer > m_viewsKey; // will be used in evt context diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation_topOptions.py b/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation_topOptions.py index 945838b183d8a7dc5f69605a02b67f1c4263e07f..777d22b40f590021654157b68083596a2e9e4cd9 100644 --- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation_topOptions.py +++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/share/L1Simulation_topOptions.py @@ -1,6 +1,5 @@ include.block ("L1TopoSimulation/L1Simulation_topOptions.py") -# gbl.AthenaServices.SetFatalHandler(438) svcMgr.CoreDumpSvc.FatalHandler = 438 import traceback diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.cxx b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.cxx index b3fd0d71f413ff878f87e8c40da6036379ce45ce..f0572ac9b0e3dc735f7f9969ab7224ff1b7f1722 100644 --- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.cxx +++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.cxx @@ -52,7 +52,7 @@ LVL1::RoiB2TopoInputDataCnv::initialize() } StatusCode -LVL1::RoiB2TopoInputDataCnv::execute_r (const EventContext& ctx) const +LVL1::RoiB2TopoInputDataCnv::execute (const EventContext& ctx) const { ATH_MSG_DEBUG ("Executing " << name() << "..."); diff --git a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.h b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.h index 98a1e46d94f4df7d672f4807edad36c56e483688..b3d947a2e47142bfd738d66543537a3179794217 100644 --- a/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.h +++ b/Trigger/TrigT1/L1Topo/L1TopoSimulation/src/RoiB2TopoInputDataCnv.h @@ -35,7 +35,7 @@ namespace LVL1 { virtual ~RoiB2TopoInputDataCnv(); // Athena algorithm's Hooks - virtual StatusCode execute_r (const EventContext& ctx) const override; + virtual StatusCode execute (const EventContext& ctx) const override; virtual StatusCode initialize() override; //Finalize not overriden because no work is required diff --git a/Trigger/TrigT1/TrigT1NSWSimTools/src/MMT_struct.cxx b/Trigger/TrigT1/TrigT1NSWSimTools/src/MMT_struct.cxx index c845cd960d6e18344c1808c2d14d0de4bfa44ad8..a9255ece8fa498ba646a18807efd394f77bd8da2 100644 --- a/Trigger/TrigT1/TrigT1NSWSimTools/src/MMT_struct.cxx +++ b/Trigger/TrigT1/TrigT1NSWSimTools/src/MMT_struct.cxx @@ -835,7 +835,7 @@ void MMT_Parameters::fill_yzmod(){ //gamma--do here if necessary...problematic if so //beta angle--rotation around the y axis; the x coordinate or phi taken care of in correction to slope road limits in x in constructor - //z is changed, and so y must be scaled (should it?): THIS SHIT DOESN'T WORK.... + //z is changed, and so y must be scaled (should it?): THIS DOESN'T WORK.... // zadd-=1.*x*sin(beta)/MMTStructConst;yadd+=yup*zadd/zflt/MMTStructConst; zadd-=tan(beta)*tan(theta)*sin(phi)*zflt/MMTStructConst; yadd-=tan(beta)*tan(theta)*sin(phi)*yflt/MMTStructConst; diff --git a/Trigger/TrigValidation/TrigUpgradeTest/python/MuonSetup.py b/Trigger/TrigValidation/TrigUpgradeTest/python/MuonSetup.py index ab2ef56f89c2ec51a44ff51eac3579aa6235b4e4..b9ffce16245657d8b8ae3db06839a5cffe6f885c 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/python/MuonSetup.py +++ b/Trigger/TrigValidation/TrigUpgradeTest/python/MuonSetup.py @@ -4,6 +4,13 @@ from AthenaCommon.Constants import VERBOSE,DEBUG, INFO +### Output data name ### +muFastInfo = "MuonL2SAInfo" +muCombInfo = "MuonL2CBInfo" +muEFSAInfo = "Muons" +muL2ISInfo = "MuonL2ISInfo" +TrackParticlesName = "xAODTracks" + ### ==================== Data prepartion needed for the EF and L2 SA ==================== ### def makeMuonPrepDataAlgs(): @@ -174,25 +181,31 @@ def makeMuonPrepDataAlgs(): # This def should be removed in the future. # We have not yet integrated muon decoding tool, so this def is used now. -def makeMuFastAlgs(): +def muFastRecoSequence( RoIs, OutputLevel=INFO ): from MuonRecExample.MuonRecFlags import muonRecFlags from AthenaCommon.AppMgr import ToolSvc from AthenaCommon.DetFlags import DetFlags + from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq + + muFastRecoSequence = parOR("l2MuViewNode") + ### These configurations for decoding tools should be removed. ### ### CSC RDO data ### from MuonCSC_CnvTools.MuonCSC_CnvToolsConf import Muon__CscROD_Decoder CSCRodDecoder = Muon__CscROD_Decoder(name = "CscROD_Decoder_L2SA", IsCosmics = False, - IsOldCosmics = False ) + IsOldCosmics = False, + OutputLevel = OutputLevel ) ToolSvc += CSCRodDecoder from MuonCSC_CnvTools.MuonCSC_CnvToolsConf import Muon__CSC_RawDataProviderTool MuonCscRawDataProviderTool = Muon__CSC_RawDataProviderTool(name = "CSC_RawDataProviderTool_L2SA", RdoLocation = "CSCRDO_L2SA", - Decoder = CSCRodDecoder ) + Decoder = CSCRodDecoder, + OutputLevel = OutputLevel ) ToolSvc += MuonCscRawDataProviderTool from MuonCSC_CnvTools.MuonCSC_CnvToolsConf import Muon__CscRdoToCscPrepDataTool @@ -200,35 +213,39 @@ def makeMuFastAlgs(): RawDataProviderTool = MuonCscRawDataProviderTool, RDOContainer = MuonCscRawDataProviderTool.RdoLocation, OutputCollection = "CSC_Measurements_L2SA", - useBStoRdoTool = True) + useBStoRdoTool = True, + OutputLevel = OutputLevel ) ToolSvc += CscRdoToCscPrepDataTool from CscClusterization.CscClusterizationConf import CscThresholdClusterBuilderTool CscClusterBuilderTool = CscThresholdClusterBuilderTool(name = "CscThesholdClusterBuilderTool_L2SA", digit_key = CscRdoToCscPrepDataTool.OutputCollection, - cluster_key = "CSC_Clusters_L2SA" ) + cluster_key = "CSC_Clusters_L2SA", + OutputLevel = OutputLevel ) ToolSvc += CscClusterBuilderTool from TrigL2MuonSA.TrigL2MuonSAConf import TrigL2MuonSA__CscDataPreparator - L2CscDataPreparator = TrigL2MuonSA__CscDataPreparator(#OutputLevel = DEBUG, - CscPrepDataProvider = CscRdoToCscPrepDataTool, + L2CscDataPreparator = TrigL2MuonSA__CscDataPreparator(CscPrepDataProvider = CscRdoToCscPrepDataTool, CscClusterProvider = CscClusterBuilderTool, - CSCPrepDataContainer = CscClusterBuilderTool.cluster_key) + CSCPrepDataContainer = CscClusterBuilderTool.cluster_key, + OutputLevel = OutputLevel ) ToolSvc += L2CscDataPreparator ### MDT RDO data ### from MuonMDT_CnvTools.MuonMDT_CnvToolsConf import MdtROD_Decoder - MDTRodDecoder = MdtROD_Decoder(name = "MdtROD_Decoder_L2SA" ) + MDTRodDecoder = MdtROD_Decoder(name = "MdtROD_Decoder_L2SA", + OutputLevel = OutputLevel ) ToolSvc += MDTRodDecoder from MuonMDT_CnvTools.MuonMDT_CnvToolsConf import Muon__MDT_RawDataProviderTool MuonMdtRawDataProviderTool = Muon__MDT_RawDataProviderTool(name = "MDT_RawDataProviderTool_L2SA", RdoLocation = "MDTCSM_L2SA", - Decoder = MDTRodDecoder ) + Decoder = MDTRodDecoder, + OutputLevel = OutputLevel ) ToolSvc += MuonMdtRawDataProviderTool from MuonMDT_CnvTools.MuonMDT_CnvToolsConf import Muon__MdtRdoToPrepDataTool @@ -236,23 +253,25 @@ def makeMuFastAlgs(): #RawDataProviderTool = MuonMdtRawDataProviderTool, #useBStoRdoTool = True, RDOContainer = MuonMdtRawDataProviderTool.RdoLocation, - OutputCollection = "MDT_DriftCircles_L2SA") + OutputCollection = "MDT_DriftCircles_L2SA", + OutputLevel = OutputLevel ) ToolSvc += MdtRdoToMdtPrepDataTool from TrigL2MuonSA.TrigL2MuonSAConf import TrigL2MuonSA__MdtDataPreparator - L2MdtDataPreparator = TrigL2MuonSA__MdtDataPreparator(#OutputLevel = DEBUG, - DecodeBS = DetFlags.readRDOBS.MDT_on(), + L2MdtDataPreparator = TrigL2MuonSA__MdtDataPreparator(DecodeBS = DetFlags.readRDOBS.MDT_on(), MdtPrepDataProvider = MdtRdoToMdtPrepDataTool, MDTPrepDataContainer = MdtRdoToMdtPrepDataTool.OutputCollection, MDT_RawDataProvider = MuonMdtRawDataProviderTool, - MDTCSMContainer = MuonMdtRawDataProviderTool.RdoLocation ) + MDTCSMContainer = MuonMdtRawDataProviderTool.RdoLocation, + OutputLevel = OutputLevel ) ToolSvc += L2MdtDataPreparator ### RPC RDO data ### from MuonRPC_CnvTools.MuonRPC_CnvToolsConf import Muon__RpcROD_Decoder - RPCRodDecoder = Muon__RpcROD_Decoder(name = "RpcROD_Decoder_L2SA" ) + RPCRodDecoder = Muon__RpcROD_Decoder(name = "RpcROD_Decoder_L2SA", + OutputLevel = OutputLevel ) ToolSvc += RPCRodDecoder @@ -260,35 +279,39 @@ def makeMuFastAlgs(): MuonRpcRawDataProviderTool = Muon__RPC_RawDataProviderTool(name = "RPC_RawDataProviderTool_L2SA", RdoLocation = "RPCPAD_L2SA", RPCSec = "RPC_SECTORLOGIC_L2SA", - Decoder = RPCRodDecoder ) + Decoder = RPCRodDecoder, + OutputLevel = OutputLevel ) ToolSvc += MuonRpcRawDataProviderTool from MuonRPC_CnvTools.MuonRPC_CnvToolsConf import Muon__RpcRdoToPrepDataTool RpcRdoToRpcPrepDataTool = Muon__RpcRdoToPrepDataTool(name = "RpcRdoToPrepDataTool_L2SA", OutputCollection = MuonRpcRawDataProviderTool.RdoLocation, TriggerOutputCollection = "RPC_Measurements_L2SA", - InputCollection = "RPC_triggerHits_L2SA") + InputCollection = "RPC_triggerHits_L2SA", + OutputLevel = OutputLevel ) ToolSvc += RpcRdoToRpcPrepDataTool from TrigL2MuonSA.TrigL2MuonSAConf import TrigL2MuonSA__RpcDataPreparator - L2RpcDataPreparator = TrigL2MuonSA__RpcDataPreparator(#OutputLevel = DEBUG, - RpcPrepDataProvider = RpcRdoToRpcPrepDataTool, + L2RpcDataPreparator = TrigL2MuonSA__RpcDataPreparator(RpcPrepDataProvider = RpcRdoToRpcPrepDataTool, RpcPrepDataContainer = RpcRdoToRpcPrepDataTool.TriggerOutputCollection, RpcRawDataProvider = MuonRpcRawDataProviderTool, - DecodeBS = DetFlags.readRDOBS.RPC_on() ) + DecodeBS = DetFlags.readRDOBS.RPC_on(), + OutputLevel = OutputLevel ) ToolSvc += L2RpcDataPreparator ### TGC RDO data ### from MuonTGC_CnvTools.MuonTGC_CnvToolsConf import Muon__TGC_RodDecoderReadout - TGCRodDecoder = Muon__TGC_RodDecoderReadout(name = "TGC_RodDecoderReadout_L2SA" ) + TGCRodDecoder = Muon__TGC_RodDecoderReadout(name = "TGC_RodDecoderReadout_L2SA", + OutputLevel = OutputLevel ) ToolSvc += TGCRodDecoder from MuonTGC_CnvTools.MuonTGC_CnvToolsConf import Muon__TGC_RawDataProviderTool MuonTgcRawDataProviderTool = Muon__TGC_RawDataProviderTool(name = "TGC_RawDataProviderTool_L2SA", RdoLocation = "TGCRDO_L2SA", - Decoder = TGCRodDecoder ) + Decoder = TGCRodDecoder, + OutputLevel = OutputLevel ) ToolSvc += MuonTgcRawDataProviderTool from MuonTGC_CnvTools.MuonTGC_CnvToolsConf import Muon__TgcRdoToPrepDataTool @@ -297,14 +320,15 @@ def makeMuFastAlgs(): RDOContainer = MuonTgcRawDataProviderTool.RdoLocation, OutputCollection = "TGC_Measurements_L2SA", OutputCoinCollection = "TrigT1CoinDataCollection_L2SA", - useBStoRdoTool = True) + useBStoRdoTool = True, + OutputLevel = OutputLevel ) ToolSvc += TgcRdoToTgcPrepDataTool from TrigL2MuonSA.TrigL2MuonSAConf import TrigL2MuonSA__TgcDataPreparator - L2TgcDataPreparator = TrigL2MuonSA__TgcDataPreparator(#OutputLevel = DEBUG, - TgcPrepDataProvider = TgcRdoToTgcPrepDataTool, - TGCPrepDataContainer = TgcRdoToTgcPrepDataTool.OutputCollection ) + L2TgcDataPreparator = TrigL2MuonSA__TgcDataPreparator(TgcPrepDataProvider = TgcRdoToTgcPrepDataTool, + TGCPrepDataContainer = TgcRdoToTgcPrepDataTool.OutputCollection, + OutputLevel = OutputLevel ) ToolSvc += L2TgcDataPreparator @@ -320,11 +344,105 @@ def makeMuFastAlgs(): MuFastDataPreparator.TGCDataPreparator = L2TgcDataPreparator muFastAlg.DataPreparator = MuFastDataPreparator + muFastAlg.OutputLevel = OutputLevel + muFastAlg.OutputLevel = DEBUG + muFastAlg.RecMuonRoI = "RecMURoIs" + muFastAlg.MuRoIs = RoIs + muFastAlg.MuonL2SAInfo = muFastInfo + muFastAlg.MuonCalibrationStream = "MuonCalibrationStream" + muFastAlg.forID = "forID" + muFastAlg.forMS = "forMS" + + muFastRecoSequence += muFastAlg + sequenceOut = muFastAlg.MuonL2SAInfo + + return muFastRecoSequence, sequenceOut + + +def muCombRecoSequence( RoIs, OutputLevel=INFO ): + + + from MuonRecExample.MuonRecFlags import muonRecFlags + from AthenaCommon.AppMgr import ToolSvc + from AthenaCommon.DetFlags import DetFlags + from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq + import AthenaCommon.CfgMgr as CfgMgr - return muFastAlg + muCombRecoSequence = parOR("l2muCombViewNode") + + ### Define input data of Inner Detector algorithms ### + ### and Define EventViewNodes to run the algorithms ### + from TrigUpgradeTest.InDetSetup import makeInDetAlgs + (viewAlgs, eventAlgs) = makeInDetAlgs() + + from TrigFastTrackFinder.TrigFastTrackFinder_Config import TrigFastTrackFinder_Muon + theFTF_Muon = TrigFastTrackFinder_Muon() + theFTF_Muon.OutputLevel = OutputLevel + theFTF_Muon.isRoI_Seeded = True + viewAlgs.append(theFTF_Muon) + + ### A simple algorithm to confirm that data has been inherited from parent view ### + ### Required to satisfy data dependencies ### + ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muFastViewDataVerifier") + ViewVerify.DataObjects = [('xAOD::L2StandAloneMuonContainer','StoreGateSvc+'+muFastInfo)] + viewAlgs.append(ViewVerify) + + #TrackParticlesName = "" + for viewAlg in viewAlgs: + muCombRecoSequence += viewAlg + viewAlg.OutputLevel = OutputLevel + if viewAlg.properties().has_key("RoIs"): + viewAlg.RoIs = RoIs + if viewAlg.properties().has_key("roiCollectionName"): + viewAlg.roiCollectionName = RoIs + if viewAlg.name() == "InDetTrigTrackParticleCreatorAlg": + TrackParticlesName = viewAlg.TrackParticlesName + + ### please read out TrigmuCombMTConfig file ### + ### and set up to run muCombMT algorithm ### + from TrigmuComb.TrigmuCombMTConfig import TrigmuCombMTConfig + muCombAlg = TrigmuCombMTConfig("Muon", theFTF_Muon.getName()) + muCombAlg.OutputLevel = OutputLevel + muCombAlg.L2StandAloneMuonContainerName = muFastInfo + muCombAlg.TrackParticlesContainerName = TrackParticlesName + muCombAlg.L2CombinedMuonContainerName = muCombInfo + + muCombRecoSequence += muCombAlg + sequenceOut = muCombAlg.L2CombinedMuonContainerName + + return muCombRecoSequence, eventAlgs, sequenceOut, TrackParticlesName + + +def l2muisoRecoSequence( RoIs, OutputLevel=INFO ): + import AthenaCommon.CfgMgr as CfgMgr + + from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq + + l2muisoRecoSequence = parOR("l2muIsoViewNode") + + ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muCombViewDataVerifier") + ViewVerify.DataObjects = [('xAOD::TrackParticleContainer' , 'StoreGateSvc+'+TrackParticlesName), + ('xAOD::L2CombinedMuonContainer','StoreGateSvc+'+muCombInfo)] + + l2muisoRecoSequence += ViewVerify + + # set up algs + from TrigmuIso.TrigmuIsoConfig import TrigmuIsoMTConfig + trigL2muIso = TrigmuIsoMTConfig("TrigL2muIso") + trigL2muIso.OutputLevel = OutputLevel + trigL2muIso.MuonL2CBInfoName = muCombInfo + trigL2muIso.TrackParticlesName = TrackParticlesName + trigL2muIso.MuonL2ISInfoName = muL2ISInfo + + l2muisoRecoSequence += trigL2muIso + + sequenceOut = trigL2muIso.MuonL2ISInfoName -def makeMuEFSAAlgs(): + return l2muisoRecoSequence, sequenceOut + + +def muEFSARecoSequence( RoIs, OutputLevel=INFO ): from MuonRecExample.MuonRecFlags import muonRecFlags from AthenaCommon.DetFlags import DetFlags @@ -335,7 +453,10 @@ def makeMuEFSAAlgs(): from AthenaCommon.CfgGetter import getPublicTool, getPublicToolClone from AthenaCommon import CfgMgr - + from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq + + muEFSARecoSequence = parOR("efmsViewNode") + efAlgs = [] ### Provide Muon_PrepDataAlgorithms ### @@ -347,9 +468,9 @@ def makeMuEFSAAlgs(): efAlgs.append( viewAlg_MuonPRD ) from TrkDetDescrSvc.TrkDetDescrSvcConf import Trk__TrackingVolumesSvc - ServiceMgr += Trk__TrackingVolumesSvc("TrackingVolumesSvc",BuildVolumesFromTagInfo = False) + ServiceMgr += Trk__TrackingVolumesSvc("TrackingVolumesSvc",BuildVolumesFromTagInfo = False, OutputLevel=OutputLevel ) - theSegmentFinder = CfgGetter.getPublicToolClone("MuonSegmentFinder","MooSegmentFinder") + theSegmentFinder = CfgGetter.getPublicToolClone("MuonSegmentFinder","MooSegmentFinder", OutputLevel=OutputLevel ) theSegmentFinder.DoSummary=True CfgGetter.getPublicTool("MuonLayerHoughTool").DoTruth=False theSegmentFinderAlg=CfgMgr.MooSegmentFinderAlg( "MuonSegmentMaker", @@ -363,11 +484,12 @@ def makeMuEFSAAlgs(): UseTGCPriorBC = False, UseTGCNextBC = False, doTGCClust = muonRecFlags.doTGCClusterSegmentFinding(), - doRPCClust = muonRecFlags.doRPCClusterSegmentFinding(), OutputLevel=DEBUG ) + doRPCClust = muonRecFlags.doRPCClusterSegmentFinding(), OutputLevel=OutputLevel ) theNCBSegmentFinderAlg=CfgMgr.MooSegmentFinderAlg( "MuonSegmentMaker_NCB", + OutputLevel = OutputLevel, SegmentFinder = getPublicToolClone("MooSegmentFinder_NCB","MuonSegmentFinder", DoSummary=False, Csc2dSegmentMaker = getPublicToolClone("Csc2dSegmentMaker_NCB","Csc2dSegmentMaker", @@ -424,7 +546,7 @@ def makeMuEFSAAlgs(): muonparticlecreator = getPublicToolClone("MuonParticleCreator", "TrackParticleCreatorTool", UseTrackSummaryTool=False, UseMuonSummaryTool=True, KeepAllPerigee=True) thecreatortool= getPublicToolClone("MuonCreatorTool_SA", "MuonCreatorTool", ScatteringAngleTool="", MuonSelectionTool="", FillTimingInformation=False, UseCaloCells=False, MakeSAMuons=True, MomentumBalanceTool="", TrackParticleCreator=muonparticlecreator, OutputLevel=DEBUG) - themuoncreatoralg = CfgMgr.MuonCreatorAlg("MuonCreatorAlg", MuonCreatorTool=thecreatortool, CreateSAmuons=True, MakeClusters=False, TagMaps=[]) + themuoncreatoralg = CfgMgr.MuonCreatorAlg("MuonCreatorAlg", MuonCreatorTool=thecreatortool, CreateSAmuons=True, MakeClusters=False, TagMaps=[], MuonContainerLocation=muEFSAInfo) #Algorithms to views efAlgs.append( theSegmentFinderAlg ) @@ -433,6 +555,15 @@ def makeMuEFSAAlgs(): efAlgs.append( xAODTrackParticleCnvAlg ) efAlgs.append( theMuonCandidateAlg ) efAlgs.append( themuoncreatoralg ) + + # setup muEFMsonly algs + for efAlg in efAlgs: + if efAlg.properties().has_key("RoIs"): + efAlg.RoIs = RoIs + muEFSARecoSequence += efAlg + sequenceOut = themuoncreatoralg.MuonContainerLocation + - return efAlgs + return muEFSARecoSequence, sequenceOut + diff --git a/Trigger/TrigValidation/TrigUpgradeTest/python/muMenuDefs.py b/Trigger/TrigValidation/TrigUpgradeTest/python/muMenuDefs.py index 162de5402c675ecb80e4e530b35e96bc8e40ac30..2621d948d4efe564c9806422393a60963f3fb395 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/python/muMenuDefs.py +++ b/Trigger/TrigValidation/TrigUpgradeTest/python/muMenuDefs.py @@ -59,55 +59,32 @@ from ViewAlgs.ViewAlgsConf import EventViewCreatorAlgorithm ServiceMgr.ToolSvc.TrigDataAccess.ApplyOffsetCorrection = False -### Output data name ### -muFastInfo = "MuonL2SAInfo" -muCombInfo = "MuonL2CBInfo" -muEFSAInfo = "Muons" -muL2ISInfo = "MuonL2ISInfo" -# get Track container name -TrackParticlesName = "" -from TrigUpgradeTest.InDetSetup import makeInDetAlgs -(nameAlgs, evAlgs) = makeInDetAlgs() -for nameAlg in nameAlgs: - if nameAlg.name() == "InDetTrigTrackParticleCreatorAlg": - TrackParticlesName = nameAlg.TrackParticlesName - ### ************* Step1 ************* ### def muFastStep(): ### set the EVCreator ### - l2MuViewNode = parOR("l2MuViewNode") - l2MuViewsMaker = EventViewCreatorAlgorithm("l2MuViewsMaker", OutputLevel=DEBUG) l2MuViewsMaker.ViewFallThrough = True l2MuViewsMaker.RoIsLink = "initialRoI" # -||- l2MuViewsMaker.InViewRoIs = "MURoIs" # contract with the consumer l2MuViewsMaker.Views = "MUViewRoIs" - l2MuViewsMaker.ViewNodeName = l2MuViewNode.name() - ### set up muFast algs ### - from TrigUpgradeTest.MuonSetup import makeMuFastAlgs - muFastAlg = makeMuFastAlgs() - muFastAlg.OutputLevel = DEBUG - muFastAlg.RecMuonRoI = "RecMURoIs" - muFastAlg.MuRoIs = l2MuViewsMaker.InViewRoIs - muFastAlg.MuonL2SAInfo = muFastInfo - muFastAlg.MuonCalibrationStream = "MuonCalibrationStream" - muFastAlg.forID = "forID" - muFastAlg.forMS = "forMS" + ### get muFast reco sequence ### + from TrigUpgradeTest.MuonSetup import muFastRecoSequence + muFastRecoSequence, sequenceOut = muFastRecoSequence( l2MuViewsMaker.InViewRoIs, OutputLevel=DEBUG ) - l2MuViewNode += muFastAlg + l2MuViewsMaker.ViewNodeName = muFastRecoSequence.name() ### set up MuFastHypo ### from TrigMuonHypo.TrigMuonHypoConf import TrigMufastHypoAlg trigMufastHypo = TrigMufastHypoAlg("TrigL2MufastHypoAlg") trigMufastHypo.OutputLevel = DEBUG - trigMufastHypo.MuonL2SAInfoFromMuFastAlg = muFastInfo + trigMufastHypo.MuonL2SAInfoFromMuFastAlg = sequenceOut - l2muFastSequence = seqAND("l2muFastSequence", [ l2MuViewsMaker, l2MuViewNode ]) + l2muFastSequence = seqAND("l2muFastSequence", [ l2MuViewsMaker, muFastRecoSequence ]) from TrigMuonHypo.testTrigMuonHypoConfig import TrigMufastHypoToolFromName @@ -123,58 +100,26 @@ def muFastStep(): def muCombStep(): ### set the EVCreator ### - l2muCombViewNode = parOR("l2muCombViewNode") - l2muCombViewsMaker = EventViewCreatorAlgorithm("l2muCombViewsMaker", OutputLevel=DEBUG) l2muCombViewsMaker.ViewFallThrough = True l2muCombViewsMaker.RoIsLink = "roi" # -||- l2muCombViewsMaker.InViewRoIs = "EMIDRoIs" # contract with the consumer l2muCombViewsMaker.Views = "EMCombViewRoIs" - l2muCombViewsMaker.ViewNodeName = l2muCombViewNode.name() - - ### Define input data of Inner Detector algorithms ### - ### and Define EventViewNodes to run the algorithms ### - from TrigUpgradeTest.InDetSetup import makeInDetAlgs - (viewAlgs, eventAlgs) = makeInDetAlgs() - - from TrigFastTrackFinder.TrigFastTrackFinder_Config import TrigFastTrackFinder_Muon - theFTF_Muon = TrigFastTrackFinder_Muon() - theFTF_Muon.OutputLevel = DEBUG - theFTF_Muon.isRoI_Seeded = True - viewAlgs.append(theFTF_Muon) - - ### A simple algorithm to confirm that data has been inherited from parent view ### - ### Required to satisfy data dependencies ### - ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muFastViewDataVerifier") - ViewVerify.DataObjects = [('xAOD::L2StandAloneMuonContainer','StoreGateSvc+'+muFastInfo)] - viewAlgs.append(ViewVerify) - - for viewAlg in viewAlgs: - l2muCombViewNode += viewAlg - if viewAlg.properties().has_key("RoIs"): - viewAlg.RoIs = l2muCombViewsMaker.InViewRoIs - if viewAlg.properties().has_key("roiCollectionName"): - viewAlg.roiCollectionName = l2muCombViewsMaker.InViewRoIs - - ### please read out TrigmuCombMTConfig file ### - ### and set up to run muCombMT algorithm ### - from TrigmuComb.TrigmuCombMTConfig import TrigmuCombMTConfig - muCombAlg = TrigmuCombMTConfig("Muon", theFTF_Muon.getName()) - muCombAlg.OutputLevel = DEBUG - muCombAlg.L2StandAloneMuonContainerName = muFastInfo - muCombAlg.TrackParticlesContainerName = TrackParticlesName - muCombAlg.L2CombinedMuonContainerName = muCombInfo - - l2muCombViewNode += muCombAlg + ### get muComb reco sequence ### + from TrigUpgradeTest.MuonSetup import muCombRecoSequence + muCombRecoSequence, eventAlgs, sequenceOut, TrackParticlesName = muCombRecoSequence( l2muCombViewsMaker.InViewRoIs, OutputLevel=DEBUG ) + + l2muCombViewsMaker.ViewNodeName = muCombRecoSequence.name() + ### set up muCombHypo algorithm ### from TrigMuonHypo.TrigMuonHypoConf import TrigmuCombHypoAlg #trigmuCombHypo = TrigmuCombHypoAlg("L2muCombHypoAlg") # avoid to have "Comb" string in the name due to HLTCFConfig.py. trigmuCombHypo = TrigmuCombHypoAlg("TrigL2MuCBHypoAlg") trigmuCombHypo.OutputLevel = DEBUG - trigmuCombHypo.MuonL2CBInfoFromMuCombAlg = muCombInfo + trigmuCombHypo.MuonL2CBInfoFromMuCombAlg = sequenceOut - l2muCombSequence = seqAND("l2muCombSequence", eventAlgs + [l2muCombViewsMaker, l2muCombViewNode ] ) + l2muCombSequence = seqAND("l2muCombSequence", eventAlgs + [l2muCombViewsMaker, muCombRecoSequence] ) from TrigMuonHypo.testTrigMuonHypoConfig import TrigmuCombHypoToolFromName @@ -189,30 +134,25 @@ def muCombStep(): ### EFMSonly step ### def muEFMSStep(): - efmsViewNode = parOR("efmsViewNode") - efmsViewsMaker = EventViewCreatorAlgorithm("efmsViewsMaker", OutputLevel=DEBUG) efmsViewsMaker.ViewFallThrough = True efmsViewsMaker.RoIsLink = "initialRoI" # -||- efmsViewsMaker.InViewRoIs = "MUEFMSRoIs" # contract with the consumer efmsViewsMaker.Views = "MUEFMSViewRoIs" - efmsViewsMaker.ViewNodeName = efmsViewNode.name() - # setup muEFMsonly algs - from TrigUpgradeTest.MuonSetup import makeMuEFSAAlgs - efAlgs = makeMuEFSAAlgs() - for efAlg in efAlgs: - if efAlg.properties().has_key("RoIs"): - efAlg.RoIs = efmsViewsMaker.InViewRoIs - efmsViewNode += efAlg + ### get EF reco sequence ### + from TrigUpgradeTest.MuonSetup import muEFSARecoSequence + muEFMSRecoSequence, sequenceOut = muEFSARecoSequence( efmsViewsMaker.InViewRoIs, OutputLevel=DEBUG ) + + efmsViewsMaker.ViewNodeName = muEFMSRecoSequence.name() # setup MS-only hypo from TrigMuonHypo.TrigMuonHypoConf import TrigMuonEFMSonlyHypoAlg trigMuonEFMSHypo = TrigMuonEFMSonlyHypoAlg( "TrigMuonEFMSHypoAlg" ) trigMuonEFMSHypo.OutputLevel = DEBUG - trigMuonEFMSHypo.MuonDecisions = muEFSAInfo + trigMuonEFMSHypo.MuonDecisions = sequenceOut - muonEFMSonlySequence = seqAND( "muonEFMSonlySequence", [efmsViewsMaker, efmsViewNode] ) + muonEFMSonlySequence = seqAND( "muonEFMSonlySequence", [efmsViewsMaker, muEFMSRecoSequence] ) from TrigMuonHypo.testTrigMuonHypoConfig import TrigMuonEFMSonlyHypoToolFromName @@ -224,31 +164,26 @@ def muEFMSStep(): ### EFSA step ### def muEFSAStep(): - efsaViewNode = parOR("efsaViewNode") - efsaViewsMaker = EventViewCreatorAlgorithm("efsaViewsMaker", OutputLevel=DEBUG) efsaViewsMaker.ViewFallThrough = True #efsaViewsMaker.RoIsLink = "initialRoI" # -||- efsaViewsMaker.RoIsLink = "roi" # -||- efsaViewsMaker.InViewRoIs = "MUEFSARoIs" # contract with the consumer efsaViewsMaker.Views = "MUEFSAViewRoIs" - efsaViewsMaker.ViewNodeName = efsaViewNode.name() - # setup muEFMsonly algs - from TrigUpgradeTest.MuonSetup import makeMuEFSAAlgs - efAlgs = makeMuEFSAAlgs() - for efAlg in efAlgs: - if efAlg.properties().has_key("RoIs"): - efAlg.RoIs = efsaViewsMaker.InViewRoIs - efsaViewNode += efAlg + ### get EF reco sequence ### + from TrigUpgradeTest.MuonSetup import muEFSARecoSequence + muEFSARecoSequence, sequenceOut = muEFSARecoSequence( efsaViewsMaker.InViewRoIs, OutputLevel=DEBUG ) + + efsaViewsMaker.ViewNodeName = muEFSARecoSequence.name() # setup EFSA hypo from TrigMuonHypo.TrigMuonHypoConf import TrigMuonEFMSonlyHypoAlg trigMuonEFSAHypo = TrigMuonEFMSonlyHypoAlg( "TrigMuonEFSAHypoAlg" ) trigMuonEFSAHypo.OutputLevel = DEBUG - trigMuonEFSAHypo.MuonDecisions = muEFSAInfo + trigMuonEFSAHypo.MuonDecisions = sequenceOut - muonEFSAonlySequence = seqAND( "muonEFSAonlySequence", [efsaViewsMaker, efsaViewNode] ) + muonEFSAonlySequence = seqAND( "muonEFSAonlySequence", [efsaViewsMaker, muEFSARecoSequence ] ) from TrigMuonHypo.testTrigMuonHypoConfig import TrigMuonEFMSonlyHypoToolFromName @@ -260,38 +195,26 @@ def muEFSAStep(): ### l2Muiso step ### def muIsoStep(): - l2muIsoViewNode = parOR("l2muIsoViewNode") - l2muIsoViewsMaker = EventViewCreatorAlgorithm("l2muIsoViewsMaker", OutputLevel=DEBUG) l2muIsoViewsMaker.ViewFallThrough = True l2muIsoViewsMaker.RoIsLink = "roi" # -||- l2muIsoViewsMaker.InViewRoIs = "MUIsoRoIs" # contract with the consumer l2muIsoViewsMaker.Views = "MUIsoViewRoIs" - l2muIsoViewsMaker.ViewNodeName = l2muIsoViewNode.name() - ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muCombViewDataVerifier") - ViewVerify.DataObjects = [('xAOD::TrackParticleContainer' , 'StoreGateSvc+'+TrackParticlesName), - ('xAOD::L2CombinedMuonContainer','StoreGateSvc+'+muCombInfo)] - l2muIsoViewNode += ViewVerify + ### get EF reco sequence ### + from TrigUpgradeTest.MuonSetup import l2muisoRecoSequence + l2muisoRecoSequence, sequenceOut = l2muisoRecoSequence( l2muIsoViewsMaker.InViewRoIs, OutputLevel=DEBUG ) + + l2muIsoViewsMaker.ViewNodeName = l2muisoRecoSequence.name() - # set up algs - from TrigmuIso.TrigmuIsoConfig import TrigmuIsoMTConfig - trigL2muIso = TrigmuIsoMTConfig("TrigL2muIso") - trigL2muIso.OutputLevel = DEBUG - trigL2muIso.MuonL2CBInfoName = muCombInfo - trigL2muIso.TrackParticlesName = TrackParticlesName - trigL2muIso.MuonL2ISInfoName = muL2ISInfo - - l2muIsoViewNode += trigL2muIso - # set up hypo from TrigMuonHypo.TrigMuonHypoConf import TrigMuisoHypoAlg trigmuIsoHypo = TrigMuisoHypoAlg("L2MuisoHypoAlg") trigmuIsoHypo.OutputLevel = DEBUG - trigmuIsoHypo.MuonL2ISInfoName = muL2ISInfo + trigmuIsoHypo.MuonL2ISInfoName = sequenceOut ### Define a Sequence to run for muIso ### - l2muIsoSequence = seqAND("l2muIsoSequence", [ l2muIsoViewsMaker, l2muIsoViewNode ] ) + l2muIsoSequence = seqAND("l2muIsoSequence", [ l2muIsoViewsMaker, l2muisoRecoSequence ] ) from TrigMuonHypo.testTrigMuonHypoConfig import TrigMuisoHypoToolFromName diff --git a/Trigger/TrigValidation/TrigUpgradeTest/share/Calo.py b/Trigger/TrigValidation/TrigUpgradeTest/share/Calo.py index bc444d4b249df89126738d518d9d7bafdbae7de7..1b18215d59fc82fd48fe721e9dc6cbb61ac7bf21 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/share/Calo.py +++ b/Trigger/TrigValidation/TrigUpgradeTest/share/Calo.py @@ -55,7 +55,7 @@ if TriggerFlags.doCalo: from TrigT2CaloEgamma.TrigT2CaloEgammaConfig import T2CaloEgamma_ReFastAlgo algo=T2CaloEgamma_ReFastAlgo("testReFastAlgo") # temporary fix for Tile - algo.ExtraInputs=[('TileEMScale','ConditionStore+TileEMScale')] + algo.ExtraInputs=[('TileEMScale','ConditionStore+TileEMScale'),('TileBadChannels','ConditionStore+TileBadChannels')] algo.OutputLevel=VERBOSE algo.RoIs="StoreGateSvc+EMRoIs" diff --git a/Trigger/TrigValidation/TrigUpgradeTest/share/mu.withViews.py b/Trigger/TrigValidation/TrigUpgradeTest/share/mu.withViews.py index 154c7e86055a2eb7bf08365496d7e04a42c5e3ae..bbb34aa48762f09786816688b5f5cb38a8d2d36d 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/share/mu.withViews.py +++ b/Trigger/TrigValidation/TrigUpgradeTest/share/mu.withViews.py @@ -6,8 +6,6 @@ include("TrigUpgradeTest/testHLT_MT.py") -from AthenaCommon.DetFlags import DetFlags - TriggerFlags.doID = False; TriggerFlags.doMuon = True; @@ -24,24 +22,6 @@ if not 'doEFSA' in dir(): if not 'doEFISO' in dir(): doEFISO=True -### workaround to prevent online trigger folders to be enabled ### -if doL2CB or doL2ISO: - from InDetRecExample.InDetJobProperties import InDetFlags - InDetFlags.doCaloSeededBrem = False - InDetFlags.InDet25nsec = True - InDetFlags.doPrimaryVertex3DFinding = False - InDetFlags.doPrintConfigurables = False - InDetFlags.doResolveBackTracks = True - InDetFlags.doSiSPSeededTrackFinder = True - InDetFlags.doTRTPhaseCalculation = True - InDetFlags.doTRTSeededTrackFinder = True - InDetFlags.doTruth = False - InDetFlags.init() - - from InDetRecExample.InDetKeys import InDetKeys - -### PixelLorentzAngleSvc and SCTLorentzAngleSvc ### -include("InDetRecExample/InDetRecConditionsAccess.py") from AthenaCommon.AlgSequence import AlgSequence topSequence = AlgSequence() @@ -64,10 +44,6 @@ from AthenaCommon.AppMgr import ServiceMgr ServiceMgr.StoreGateSvc=Service("StoreGateSvc") ServiceMgr.StoreGateSvc.Dump=True -### for Control Flow ### -from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq -from DecisionHandling.DecisionHandlingConf import RoRSeqFilter, DumpDecisions - from AthenaCommon.AlgScheduler import AlgScheduler AlgScheduler.CheckDependencies( True ) @@ -76,9 +52,6 @@ AlgScheduler.ShowDataDependencies( True ) AlgScheduler.setDataLoaderAlg( 'SGInputLoader' ) -from AthenaCommon.CfgGetter import getPublicTool, getPublicToolClone -from AthenaCommon import CfgMgr - ### muon thresholds ### CTPToChainMapping = { "HLT_mu6" : "L1_MU6", "HLT_2mu6": "L1_2MU4" } @@ -115,26 +88,24 @@ def __mon(finalCollName, stepColls=[]): # Setup the standard muon chain # =============================================================================================== -## Used the algorithms as Step2 "muComb step" ### -viewAlgs = [] -if doL2CB: - # Only do setup of ID stuff if we run combined muon finding - from TrigUpgradeTest.InDetSetup import makeInDetAlgs - (viewAlgs, eventAlgs) = makeInDetAlgs() - - from TrigFastTrackFinder.TrigFastTrackFinder_Config import TrigFastTrackFinder_Muon - theFTF = TrigFastTrackFinder_Muon() - theFTF.OutputLevel = DEBUG - theFTF.TracksName = "TrigFastTrackFinder_MuTracks" - theFTF.isRoI_Seeded = True - viewAlgs.append(theFTF) - - ### A simple algorithm to confirm that data has been inherited from parent view ### - ### Required to satisfy data dependencies ### - ViewVerify = CfgMgr.AthViews__ViewDataVerifier("muFastViewDataVerifier") - ViewVerify.DataObjects = [('xAOD::L2StandAloneMuonContainer','StoreGateSvc+MuonL2SAInfo')] - viewAlgs.append(ViewVerify) +### workaround to prevent online trigger folders to be enabled ### +from AthenaCommon.DetFlags import DetFlags +from InDetRecExample.InDetJobProperties import InDetFlags +InDetFlags.doCaloSeededBrem = False +InDetFlags.InDet25nsec = True +InDetFlags.doPrimaryVertex3DFinding = False +InDetFlags.doPrintConfigurables = False +InDetFlags.doResolveBackTracks = True +InDetFlags.doSiSPSeededTrackFinder = True +InDetFlags.doTRTPhaseCalculation = True +InDetFlags.doTRTSeededTrackFinder = True +InDetFlags.doTruth = False +InDetFlags.init() + +from InDetRecExample.InDetKeys import InDetKeys +### PixelLorentzAngleSvc and SCTLorentzAngleSvc ### +include("InDetRecExample/InDetRecConditionsAccess.py") ### Load data from Muon detectors ### import MuonRecExample.MuonRecStandaloneOnlySetup @@ -149,12 +120,20 @@ from RecExConfig.RecFlags import rec from AthenaCommon.AlgSequence import AthSequencer from ViewAlgs.ViewAlgsConf import EventViewCreatorAlgorithm +svcMgr.ToolSvc.TrigDataAccess.ApplyOffsetCorrection = False + +### for Control Flow ### +from AthenaCommon.CFElements import parOR, seqAND, seqOR, stepSeq +from DecisionHandling.DecisionHandlingConf import RoRSeqFilter, DumpDecisions + +### for Cfg Getter and Manager ### +from AthenaCommon.CfgGetter import getPublicTool, getPublicToolClone +from AthenaCommon import CfgMgr + ### ************* Step1 ************* ### if TriggerFlags.doMuon: - svcMgr.ToolSvc.TrigDataAccess.ApplyOffsetCorrection = False - ### set up L1RoIsFilter ### filterL1RoIsAlg = RoRSeqFilter("filterL1RoIsAlg") filterL1RoIsAlg.Input = ["MURoIDecisions"] @@ -163,9 +142,8 @@ if TriggerFlags.doMuon: filterL1RoIsAlg.OutputLevel = DEBUG if doL2SA: - ### set the EVCreator ### - l2MuViewNode = parOR("l2MuViewNode") + ### set the EVCreator ### l2MuViewsMaker = EventViewCreatorAlgorithm("l2MuViewsMaker", OutputLevel=DEBUG) l2MuViewsMaker.ViewFallThrough = True l2MuViewsMaker.InputMakerInputDecisions = filterL1RoIsAlg.Output @@ -173,26 +151,18 @@ if TriggerFlags.doMuon: l2MuViewsMaker.RoIsLink = "initialRoI" # -||- l2MuViewsMaker.InViewRoIs = "MURoIs" # contract with the consumer l2MuViewsMaker.Views = "MUViewRoIs" - l2MuViewsMaker.ViewNodeName = l2MuViewNode.name() - - ### set up MuFastSteering ### - from TrigUpgradeTest.MuonSetup import makeMuFastAlgs - muFastAlg = makeMuFastAlgs() - muFastAlg.OutputLevel = DEBUG - muFastAlg.RecMuonRoI = "RecMURoIs" - muFastAlg.MuRoIs = l2MuViewsMaker.InViewRoIs - muFastAlg.MuonL2SAInfo = "MuonL2SAInfo" - muFastAlg.MuonCalibrationStream = "MuonCalibrationStream" - muFastAlg.forID = "forID" - muFastAlg.forMS = "forMS" - - l2MuViewNode += muFastAlg - + + ### get muFast reco sequence ### + from TrigUpgradeTest.MuonSetup import muFastRecoSequence + muFastRecoSequence, muFastSequenceOut = muFastRecoSequence( l2MuViewsMaker.InViewRoIs, OutputLevel=DEBUG ) + + l2MuViewsMaker.ViewNodeName = muFastRecoSequence.name() + ### set up MuFastHypo ### from TrigMuonHypo.TrigMuonHypoConfigMT import TrigMufastHypoConfig trigMufastHypo = TrigMufastHypoConfig("TrigL2MufastHypoAlg") trigMufastHypo.OutputLevel = DEBUG - trigMufastHypo.MuonL2SAInfoFromMuFastAlg = muFastAlg.MuonL2SAInfo + trigMufastHypo.MuonL2SAInfoFromMuFastAlg = muFastSequenceOut trigMufastHypo.HypoOutputDecisions = "L2MuonFastDecisions" trigMufastHypo.HypoInputDecisions = l2MuViewsMaker.InputMakerOutputDecisions[0] trigMufastHypo.HypoTools = [ trigMufastHypo.TrigMufastHypoToolFromName( "TrigL2MufastHypoTool", c ) for c in testChains ] @@ -201,14 +171,16 @@ if TriggerFlags.doMuon: muFastDecisionsDumper = DumpDecisions("muFastDecisionsDumper", OutputLevel=DEBUG, Decisions = trigMufastHypo.HypoOutputDecisions ) ### make sequences ### - l2muFastSequence = seqAND("l2muFastSequence", [ l2MuViewsMaker, l2MuViewNode, trigMufastHypo ]) + l2muFastSequence = seqAND("l2muFastSequence", [ l2MuViewsMaker, muFastRecoSequence, trigMufastHypo ]) + ### make step ### muFastStep = stepSeq("muFastStep", filterL1RoIsAlg, [ l2muFastSequence, muFastDecisionsDumper ] ) ### ************* Step2 ************* ### if doL2CB: + ### RoRSeqFilter step2 ### filterL2SAAlg = RoRSeqFilter("filterL2SAAlg") filterL2SAAlg.Input = [trigMufastHypo.HypoOutputDecisions] @@ -217,41 +189,19 @@ if TriggerFlags.doMuon: filterL2SAAlg.OutputLevel = DEBUG ### set the EVCreator ### - l2muCombViewNode = parOR("l2muCombViewNode") - l2muCombViewsMaker = EventViewCreatorAlgorithm("l2muCombViewsMaker", OutputLevel=DEBUG) l2muCombViewsMaker.ViewFallThrough = True - l2muCombViewsMaker.InputMakerInputDecisions = [ filterL2SAAlg.Output[0] ] # Output of TrigMufastHypo l2muCombViewsMaker.InputMakerOutputDecisions = [ "MUL2SADecisionsOutput" ] l2muCombViewsMaker.RoIsLink = "roi" # -||- l2muCombViewsMaker.InViewRoIs = "MUTrkRoIs" # contract with the consumer l2muCombViewsMaker.Views = "MUTrkViewRoIs" - l2muCombViewsMaker.ViewNodeName = l2muCombViewNode.name() - - ### Define input data of Inner Detector algorithms ### - ### and Define EventViewNodes to run the algprithms ### - TrackParticlesName = "" - for viewAlg in viewAlgs: - l2muCombViewNode += viewAlg - if viewAlg.properties().has_key("RoIs"): - viewAlg.RoIs = l2muCombViewsMaker.InViewRoIs - if viewAlg.properties().has_key("roiCollectionName"): - viewAlg.roiCollectionName = l2muCombViewsMaker.InViewRoIs - if viewAlg.name() == "InDetTrigTrackParticleCreatorAlg": - TrackParticlesName = viewAlg.TrackParticlesName - viewAlg.TrackName = theFTF.TracksName - - ### please read out TrigmuCombMTConfig file ### - ### and set up to run muCombMT algorithm ### - from TrigmuComb.TrigmuCombMTConfig import TrigmuCombMTConfig - muCombAlg = TrigmuCombMTConfig("Muon", theFTF.getName()) - muCombAlg.OutputLevel = DEBUG - muCombAlg.L2StandAloneMuonContainerName = muFastAlg.MuonL2SAInfo - muCombAlg.TrackParticlesContainerName = TrackParticlesName - muCombAlg.L2CombinedMuonContainerName = "MuonL2CBInfo" - - l2muCombViewNode += muCombAlg + + ### get muComb reco sequence ### + from TrigUpgradeTest.MuonSetup import muCombRecoSequence + muCombRecoSequence, eventAlgs, muCombSequenceOut, TrackParticlesName = muCombRecoSequence( l2muCombViewsMaker.InViewRoIs, OutputLevel=DEBUG ) + + l2muCombViewsMaker.ViewNodeName = muCombRecoSequence.name() ### set up muCombHypo algorithm ### from TrigMuonHypo.TrigMuonHypoConfigMT import TrigmuCombHypoConfig @@ -259,15 +209,16 @@ if TriggerFlags.doMuon: trigmuCombHypo.OutputLevel = DEBUG trigmuCombHypo.HypoOutputDecisions = "MuonL2CBDecisions" trigmuCombHypo.HypoInputDecisions = l2muCombViewsMaker.InputMakerOutputDecisions[0] - trigmuCombHypo.MuonL2CBInfoFromMuCombAlg = muCombAlg.L2CombinedMuonContainerName + trigmuCombHypo.MuonL2CBInfoFromMuCombAlg = muCombSequenceOut trigmuCombHypo.HypoTools = [ trigmuCombHypo.TrigmuCombHypoToolFromName( "TrigL2muCombHypoTool", c ) for c in testChains ] ### set the dumper ### muCombDecisionsDumper = DumpDecisions("muCombDecisionsDumper", OutputLevel=DEBUG, Decisions = trigmuCombHypo.HypoOutputDecisions ) - - ### Define a Sequence to run for muComb ### - l2muCombSequence = seqAND("l2muCombSequence", eventAlgs + [l2muCombViewsMaker, l2muCombViewNode, trigmuCombHypo ] ) + ### make sequence ### + l2muCombSequence = seqAND("l2muCombSequence", eventAlgs + [l2muCombViewsMaker, muCombRecoSequence, trigmuCombHypo ] ) + + ### make step ### muCombStep = stepSeq("muCombStep", filterL2SAAlg, [ l2muCombSequence, muCombDecisionsDumper ] ) @@ -288,8 +239,6 @@ if TriggerFlags.doMuon: filterEFSAAlg.OutputLevel = DEBUG ### set the EVCreator ### - efMuViewNode = parOR("efMuViewNode") - efMuViewsMaker = EventViewCreatorAlgorithm("efMuViewsMaker", OutputLevel=DEBUG) efMuViewsMaker.ViewFallThrough = True # probably wrong input to the EVMaker @@ -298,36 +247,35 @@ if TriggerFlags.doMuon: efMuViewsMaker.RoIsLink = "initialRoI" # -||- efMuViewsMaker.InViewRoIs = "MURoIs" # contract with the consumer efMuViewsMaker.Views = "EFMUViewRoIs" - efMuViewsMaker.ViewNodeName = efMuViewNode.name() - - # setup muEFMsonly algs - from TrigUpgradeTest.MuonSetup import makeMuEFSAAlgs - efAlgs = makeMuEFSAAlgs() - muEFSAInfo = "" - for efAlg in efAlgs: - if efAlg.properties().has_key("RoIs"): - efAlg.RoIs = efMuViewsMaker.InViewRoIs - if efAlg.properties().has_key("MuonContainerLocation"): - muEFSAInfo = "Muons" - efAlg.MuonContainerLocation = muEFSAInfo - efMuViewNode += efAlg + + ### get EF reco sequence ### + from TrigUpgradeTest.MuonSetup import muEFSARecoSequence + muEFMSRecoSequence, muEFSASequenceOut = muEFSARecoSequence( efMuViewsMaker.InViewRoIs, OutputLevel=DEBUG ) + + efMuViewsMaker.ViewNodeName = muEFMSRecoSequence.name() #Setup MS-only hypo from TrigMuonHypo.TrigMuonHypoConfigMT import TrigMuonEFMSonlyHypoConfig trigMuonEFSAHypo = TrigMuonEFMSonlyHypoConfig("TrigMuonEFSAHypoAlg") trigMuonEFSAHypo.OutputLevel = DEBUG - trigMuonEFSAHypo.MuonDecisions = muEFSAInfo + trigMuonEFSAHypo.MuonDecisions = muEFSASequenceOut trigMuonEFSAHypo.HypoOutputDecisions = "EFMuonSADecisions" trigMuonEFSAHypo.HypoInputDecisions = efMuViewsMaker.InputMakerOutputDecisions[0] trigMuonEFSAHypo.HypoTools = [ trigMuonEFSAHypo.TrigMuonEFMSonlyHypoToolFromName( "TrigMuonEFMSonlyHypoTool", c ) for c in testChains ] + ### set the dumper ### muonEFSADecisionsDumper = DumpDecisions("muonEFSADecisionsDumper", OutputLevel=DEBUG, Decisions = trigMuonEFSAHypo.HypoOutputDecisions ) - muEFSASequence = seqAND("muEFSASequence", [efMuViewsMaker, efMuViewNode, trigMuonEFSAHypo]) + + ### make sequence ### + muEFSASequence = seqAND("muEFSASequence", [efMuViewsMaker, muEFMSRecoSequence, trigMuonEFSAHypo]) + + ### make step ### muonEFSAStep = stepSeq("muonEFSAStep", filterEFSAAlg, [muEFSASequence, muonEFSADecisionsDumper]) if doL2CB and doL2ISO: + ### RoRSeqFilter step2 for muIso ### filterL2MuisoAlg = RoRSeqFilter("filterL2MuisoAlg") filterL2MuisoAlg.Input = [trigmuCombHypo.HypoOutputDecisions] @@ -336,8 +284,6 @@ if TriggerFlags.doMuon: filterL2MuisoAlg.OutputLevel = DEBUG ### set the EVCreator ### - l2muIsoViewNode = parOR("l2muIsoViewNode") - l2muIsoViewsMaker = EventViewCreatorAlgorithm("l2muIsoViewsMaker", OutputLevel=DEBUG) l2muIsoViewsMaker.ViewFallThrough = True l2muIsoViewsMaker.InputMakerInputDecisions = [ filterL2MuisoAlg.Output[0] ] # Output of TrigMufastHypo @@ -345,30 +291,29 @@ if TriggerFlags.doMuon: l2muIsoViewsMaker.RoIsLink = "roi" # -||- l2muIsoViewsMaker.InViewRoIs = "MUIsoRoIs" # contract with the consumer l2muIsoViewsMaker.Views = "MUIsoViewRoIs" - l2muIsoViewsMaker.ViewNodeName = l2muIsoViewNode.name() - from TrigmuIso.TrigmuIsoConfig import TrigmuIsoMTConfig - trigL2muIso = TrigmuIsoMTConfig("L2muIso") - trigL2muIso.OutputLevel = DEBUG - trigL2muIso.MuonL2CBInfoName = muCombAlg.L2CombinedMuonContainerName - trigL2muIso.TrackParticlesName = TrackParticlesName - trigL2muIso.MuonL2ISInfoName = "MuonL2ISInfo" + ### get EF reco sequence ### + from TrigUpgradeTest.MuonSetup import l2muisoRecoSequence + l2muisoRecoSequence, l2muIsoSequenceOut = l2muisoRecoSequence( l2muIsoViewsMaker.InViewRoIs, OutputLevel=DEBUG ) - l2muIsoViewNode += trigL2muIso + l2muIsoViewsMaker.ViewNodeName = l2muisoRecoSequence.name() from TrigMuonHypo.TrigMuonHypoConfigMT import TrigMuisoHypoConfig trigmuIsoHypo = TrigMuisoHypoConfig("TrigL2MuisoHypoAlg") trigmuIsoHypo.OutputLevel = DEBUG - trigmuIsoHypo.MuonL2ISInfoName = trigL2muIso.MuonL2ISInfoName + trigmuIsoHypo.MuonL2ISInfoName = l2muIsoSequenceOut trigmuIsoHypo.HypoOutputDecisions = "MuonL2IsoDecisions" trigmuIsoHypo.HypoInputDecisions = l2muIsoViewsMaker.InputMakerOutputDecisions[0] trigmuIsoHypo.HypoTools = [ trigmuIsoHypo.TrigMuisoHypoToolFromName( "TrigL2MuisoHypoTool", c ) for c in testChains ] ### set the dumper ### muIsoDecisionsDumper = DumpDecisions("muIsoDecisionsDumper", OutputLevel=DEBUG, Decisions = trigmuIsoHypo.HypoOutputDecisions ) - - ### Define a Sequence to run for muIso ### - muIsoStep = seqAND("muIsoStep", [ filterL2MuisoAlg, l2muIsoViewsMaker, l2muIsoViewNode, trigmuIsoHypo, muIsoDecisionsDumper ] ) + + ### make sequence ### + l2muIsoSequence = seqAND("l2muIsoSequence", [ l2muIsoViewsMaker, l2muisoRecoSequence, trigmuIsoHypo ]) + + ### make step ### + l2muIsoStep = seqAND("l2muIsoStep", filterL2MuisoAlg, [ l2muIsoSequence, muIsoDecisionsDumper ] ) # =============================================================================================== @@ -395,8 +340,8 @@ def muonViewsMergers( name ): if doL2SA==True: muonViewsMerger.TrigCompositeContainer += [ filterL1RoIsAlg.Output[0], trigMufastHypo.HypoOutputDecisions ] muonViewsMerger.L2StandAloneMuonContainerViews = [ l2MuViewsMaker.Views ] - muonViewsMerger.L2StandAloneMuonContainerInViews = [ muFastAlg.MuonL2SAInfo ] - muonViewsMerger.L2StandAloneMuonContainer = [ muFastAlg.MuonL2SAInfo ] + muonViewsMerger.L2StandAloneMuonContainerInViews = [ muFastSequenceOut ] + muonViewsMerger.L2StandAloneMuonContainer = [ muFastSequenceOut ] if doL2CB==True: muonViewsMerger.TrigCompositeContainer += [ filterL2SAAlg.Output[0], trigmuCombHypo.HypoOutputDecisions ] @@ -405,21 +350,20 @@ def muonViewsMergers( name ): muonViewsMerger.TrackParticleContainer = [ TrackParticlesName ] muonViewsMerger.L2CombinedMuonContainerViews = [ l2muCombViewsMaker.Views ] - muonViewsMerger.L2CombinedMuonContainerInViews = [ muCombAlg.L2CombinedMuonContainerName ] - muonViewsMerger.L2CombinedMuonContainer = [ muCombAlg.L2CombinedMuonContainerName ] + muonViewsMerger.L2CombinedMuonContainerInViews = [ muCombSequenceOut ] + muonViewsMerger.L2CombinedMuonContainer = [ muCombSequenceOut ] if doEFSA==True: muonViewsMerger.TrigCompositeContainer += [ filterEFSAAlg.Output[0], trigMuonEFSAHypo.HypoOutputDecisions ] muonViewsMerger.MuonContainerViews = [ efMuViewsMaker.Views ] - muonViewsMerger.MuonContainerInViews = [ muEFSAInfo ] - muonViewsMerger.MuonContainer = [ muEFSAInfo ] + muonViewsMerger.MuonContainerInViews = [ muEFSASequenceOut ] + muonViewsMerger.MuonContainer = [ muEFSASequenceOut ] if doL2CB==True and doL2ISO==True: # L2CB should be also executed with L2ISO muonViewsMerger.TrigCompositeContainer += [ filterL2MuisoAlg.Output[0], trigmuIsoHypo.HypoOutputDecisions ] muonViewsMerger.L2IsoMuonContainerViews = [ l2muIsoViewsMaker.Views ] - muonViewsMerger.L2IsoMuonContainerInViews = [ trigL2muIso.MuonL2ISInfoName ] - muonViewsMerger.L2IsoMuonContainer = [ trigL2muIso.MuonL2ISInfoName ] - + muonViewsMerger.L2IsoMuonContainerInViews = [ l2muIsoSequenceOut ] + muonViewsMerger.L2IsoMuonContainer = [ l2muIsoSequenceOut ] return muonViewsMerger @@ -449,22 +393,22 @@ def muonStreamESD( muonViewsMerger ): StreamESD.ItemList += [ "ROIB::RoIBResult#*" ] if doL2SA==True: - StreamESD.ItemList += [ "xAOD::L2StandAloneMuonContainer#"+muFastAlg.MuonL2SAInfo ] - StreamESD.ItemList += [ "xAOD::L2StandAloneMuonAuxContainer#"+muFastAlg.MuonL2SAInfo+"Aux." ] + StreamESD.ItemList += [ "xAOD::L2StandAloneMuonContainer#"+muFastSequenceOut ] + StreamESD.ItemList += [ "xAOD::L2StandAloneMuonAuxContainer#"+muFastSequenceOut+"Aux." ] if doL2CB==True: StreamESD.ItemList += [ "xAOD::TrackParticleContainer#"+TrackParticlesName, - "xAOD::L2CombinedMuonContainer#"+muCombAlg.L2CombinedMuonContainerName ] + "xAOD::L2CombinedMuonContainer#"+muCombSequenceOut ] StreamESD.ItemList += [ "xAOD::TrackParticleAuxContainer#"+TrackParticlesName+"Aux.", - "xAOD::L2CombinedMuonAuxContainer#"+muCombAlg.L2CombinedMuonContainerName+"Aux." ] + "xAOD::L2CombinedMuonAuxContainer#"+muCombSequenceOut+"Aux." ] if doEFSA==True: - StreamESD.ItemList += [ "xAOD::MuonContainer#"+muEFSAInfo ] - StreamESD.ItemList += [ "xAOD::MuonAuxContainer#"+muEFSAInfo+"Aux." ] + StreamESD.ItemList += [ "xAOD::MuonContainer#"+muEFSASequenceOut ] + StreamESD.ItemList += [ "xAOD::MuonAuxContainer#"+muEFSASequenceOut+"Aux." ] if doL2CB==True and doL2ISO==True: - StreamESD.ItemList += [ "xAOD::L2IsoMuonContainer#"+trigL2muIso.MuonL2ISInfoName ] - StreamESD.ItemList += [ "xAOD::L2IsoMuonAuxContainer#"+trigL2muIso.MuonL2ISInfoName+"Aux." ] + StreamESD.ItemList += [ "xAOD::L2IsoMuonContainer#"+l2muIsoSequenceOut ] + StreamESD.ItemList += [ "xAOD::L2IsoMuonAuxContainer#"+l2muIsoSequenceOut+"Aux." ] print "ESD file content " num = 0; @@ -591,7 +535,7 @@ if TriggerFlags.doMuon==True and TriggerFlags.doID==True: summary1 = summarySteps("Step2", ["MuonL2CBDecisions"] ) step1 = parOR("step1", [ muCombStep, summary1 ] ) summary2 = summarySteps("Step3", ["MuonL2IsoDecisions"] ) - step2 = parOR("step2", [ muIsoStep, summary2 ] ) + step2 = parOR("step2", [ l2muIsoStep, summary2 ] ) step0filter = parOR("step0filter", [ filterL1RoIsAlg ] ) step1filter = parOR("step1filter", [ filterL2SAAlg ] ) step2filter = parOR("step2filter", [ filterL2MuisoAlg] ) @@ -615,7 +559,7 @@ if TriggerFlags.doMuon==True and TriggerFlags.doID==True: summary1 = summarySteps("Step2", ["MuonL2CBDecisions"] ) step1 = parOR("step1", [ muCombStep, summary1 ] ) summary2 = summarySteps("Step3", ["EFMuonSADecisions", "MuonL2IsoDecisions"] ) - step2 = parOR("step2", [ muonEFSAStep, muIsoStep, summary2 ] ) + step2 = parOR("step2", [ muonEFSAStep, l2muIsoStep, summary2 ] ) step0filter = parOR("step0filter", [ filterL1RoIsAlg ] ) step1filter = parOR("step1filter", [ filterL2SAAlg ] ) step2filter = parOR("step2filter", [ filterEFSAAlg, filterL2MuisoAlg] ) diff --git a/Trigger/TrigValidation/TrigUpgradeTest/share/newJOtest.py b/Trigger/TrigValidation/TrigUpgradeTest/share/newJOtest.py index 2ab9062bdeed244bf8972e9ca5cd58d8e187ecb0..7de8533cd38ed12bb0152889b8a7051961c20229 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/share/newJOtest.py +++ b/Trigger/TrigValidation/TrigUpgradeTest/share/newJOtest.py @@ -3,7 +3,7 @@ # from AthenaConfiguration.ComponentAccumulator import ComponentAccumulator -from AthenaConfiguration.AllConfigFlags import ConfigFlags +from AthenaConfiguration.AllConfigFlags import ConfigFlags as flags from AthenaCommon.CFElements import parOR, seqOR, seqAND, stepSeq from AthenaCommon.AlgSequence import dumpMasterSequence from AthenaCommon.AppMgr import theApp @@ -14,7 +14,7 @@ from AthenaCommon.Configurable import Configurable Configurable.configurableRun3Behavior=1 -flags = ConfigFlags + setupMenu(flags) @@ -30,33 +30,9 @@ flags.lock() from AthenaCommon.Constants import INFO,DEBUG acc = ComponentAccumulator() -# make sure we run the right scheduler -# need to move elsewhere - -nThreads=1 - -from StoreGate.StoreGateConf import SG__HiveMgrSvc -eventDataSvc = SG__HiveMgrSvc("EventDataSvc") -eventDataSvc.NSlots = nThreads -eventDataSvc.OutputLevel = DEBUG -acc.addService( eventDataSvc ) - -from SGComps.SGCompsConf import SGInputLoader -inputLoader = SGInputLoader(DetStore = 'StoreGateSvc/DetectorStore', - EvtStore = 'StoreGateSvc', - ExtraInputs = [], - ExtraOutputs = [], - FailIfNoProxy = False, - Load = [], - NeededResources = []) - -acc.addEventAlgo( inputLoader) - from ByteStreamCnvSvc.ByteStreamConfig import TrigBSReadCfg acc.merge(TrigBSReadCfg(flags )) -#from AtlasGeoModel.GeoModelConfig import GeoModelCfg -#acc.merge(GeoModelCfg(flags )) from TrigUpgradeTest.TriggerHistSvcConfig import TriggerHistSvcConfig acc.merge(TriggerHistSvcConfig(flags )) @@ -66,22 +42,9 @@ from TriggerMenuMT.HLTMenuConfig.Menu.GenerateMenuMT_newJO import generateMenu from TriggerJobOpts.TriggerConfig import triggerRunCfg acc.merge( triggerRunCfg( flags, generateMenu ) ) - - -from EventInfoMgt.EventInfoMgtConf import TagInfoMgr -tagInfoMgr = TagInfoMgr() -tagInfoMgr.ExtraTagValuePairs = ['AtlasRelease', 'Athena-22.0.1'] # this has to come from somewhere else -acc.addService( tagInfoMgr ) - -acc.getService("EventPersistencySvc").CnvServices += [ tagInfoMgr.getName() ] -acc.getService("ProxyProviderSvc").ProviderNames += [ tagInfoMgr.getName() ] -acc.getService("IOVDbSvc").Folders += ['/TagInfo<metaOnly/>'] - - - -# setup algorithm sequences here, need few additional components +# TODO take care of merging RegSel, and remove it from here from RegionSelector.RegSelConfig import RegSelConfig -rsc, regSel = RegSelConfig( ConfigFlags ) +rsc, regSel = RegSelConfig( flags ) regSel.enableCalo=True regSel.enableID=False regSel.enablePixel = False diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.cxx b/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.cxx index 0162c069eae0f400372796e2dcab9225bbe7d02d..73fae66a2c04cb923d8b435c48888e110cbfb85c 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.cxx +++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.cxx @@ -89,7 +89,7 @@ namespace HLTTest { - StatusCode TestComboHypoAlg::execute_r( const EventContext& context ) const { + StatusCode TestComboHypoAlg::execute( const EventContext& context ) const { ATH_MSG_DEBUG ("Executing " << name() << "..."); diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.h b/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.h index fcea988e91ee3f4dad5c2c18f3963a3589814ad1..b9dd34708198a4a750f0c559f1de38130cb11ae2 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.h +++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestComboHypoAlg.h @@ -29,7 +29,7 @@ namespace HLTTest { //TestComboHypoAlg &operator=(const TestComboHypoAlg &alg); StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; //StatusCode execute() override; StatusCode finalize() override; diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.cxx b/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.cxx index 8ba0e9a9dde8740ae5bb288ca2f950b6348d2c62..94b86c7dfa59afef4fd0b43da787a54b6971f267 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.cxx +++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.cxx @@ -27,7 +27,7 @@ namespace HLTTest { } - StatusCode TestHypoAlg::execute_r( const EventContext& context ) const { + StatusCode TestHypoAlg::execute( const EventContext& context ) const { ATH_MSG_DEBUG( "Executing " << name() << "..." ); if ( m_recoInput.key().empty() ) { ATH_MSG_DEBUG( "No input configured, not producing the output" ); diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.h b/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.h index 17f3acd6bf34ae342433ed92f330537c0921dc29..07ec5d0e412251a55ce7c2b062f0cb9093f8fc68 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.h +++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestHypoAlg.h @@ -28,7 +28,7 @@ namespace HLTTest { virtual ~TestHypoAlg(); virtual StatusCode initialize() override; - virtual StatusCode execute_r( const EventContext& context ) const override; + virtual StatusCode execute( const EventContext& context ) const override; virtual StatusCode finalize() override; private: diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.cxx b/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.cxx index 6fd708d8ad67a2516c1bb9107be89a51949b2b05..3d7b76d870f9b2df38d784cfebf4933b5fe119ef 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.cxx +++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.cxx @@ -34,7 +34,7 @@ namespace HLTTest { } - StatusCode TestInputMaker::execute_r( const EventContext& context ) const { + StatusCode TestInputMaker::execute( const EventContext& context ) const { ATH_MSG_DEBUG( "Executing " << name() << "..." ); // call base class helper method to read input decisions, loop over them create outputs and connect them, returns with outputHandles filled diff --git a/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.h b/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.h index 4b5ac1207313d5bdce42dfe4b6d363362ea02405..04c586d370e5c2ee038ad16d1d87c9318252cd2c 100644 --- a/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.h +++ b/Trigger/TrigValidation/TrigUpgradeTest/src/TestInputMaker.h @@ -29,7 +29,7 @@ namespace HLTTest { TestInputMaker( const std::string& name, ISvcLocator* pSvcLocator ); virtual ~TestInputMaker(); virtual StatusCode initialize() override; - virtual StatusCode execute_r(const EventContext&) const override; + virtual StatusCode execute(const EventContext&) const override; virtual StatusCode finalize() override; private: