|  | ATLAS Offline Software
    | 
 
 
 
#include <TauShotFinder.h>
|  | 
|  | ASG_TOOL_CLASS2 (TauShotFinder, TauRecToolBase, ITauToolBase) | 
|  | 
|  | TauShotFinder (const std::string &name) | 
|  | 
| virtual | ~TauShotFinder ()=default | 
|  | 
| virtual StatusCode | initialize () override | 
|  | Tool initializer.  More... 
 | 
|  | 
| virtual StatusCode | executeShotFinder (xAOD::TauJet &pTau, xAOD::CaloClusterContainer &tauShotCaloClusContainer, xAOD::PFOContainer &tauShotPFOContainer) const override | 
|  | 
| virtual StatusCode | eventInitialize () override | 
|  | Event initializer - called at the beginning of each event.  More... 
 | 
|  | 
| virtual StatusCode | execute (xAOD::TauJet &pTau) const override | 
|  | Execute - called for each tau candidate.  More... 
 | 
|  | 
| virtual StatusCode | executePi0CreateROI (xAOD::TauJet &pTau, CaloConstCellContainer &caloCellContainer, boost::dynamic_bitset<> &map) const override | 
|  | 
| virtual StatusCode | executeVertexFinder (xAOD::TauJet &pTau, const xAOD::VertexContainer *vertexContainer=nullptr) const override | 
|  | 
| virtual StatusCode | executeTrackFinder (xAOD::TauJet &pTau, xAOD::TauTrackContainer &tauTrackContainer) const override | 
|  | 
| virtual StatusCode | executeTrackClassifier (xAOD::TauJet &pTau, xAOD::TauTrackContainer &tauTrackContainer) const override | 
|  | 
| virtual StatusCode | executePi0ClusterCreator (xAOD::TauJet &pTau, xAOD::PFOContainer &neutralPFOContainer, xAOD::PFOContainer &hadronicPFOContainer, const xAOD::CaloClusterContainer &pCaloClusterContainer) const override | 
|  | 
| virtual StatusCode | executeVertexVariables (xAOD::TauJet &pTau, xAOD::VertexContainer &vertexContainer) const override | 
|  | 
| virtual StatusCode | executePi0ClusterScaler (xAOD::TauJet &pTau, xAOD::PFOContainer &neutralPFOContainer, xAOD::PFOContainer &chargedPFOContainer) const override | 
|  | 
| virtual StatusCode | executePi0nPFO (xAOD::TauJet &pTau, xAOD::PFOContainer &neutralPFOContainer) const override | 
|  | 
| virtual StatusCode | executePanTau (xAOD::TauJet &pTau, xAOD::ParticleContainer &particleContainer, xAOD::PFOContainer &neutralPFOContainer) const override | 
|  | 
| virtual StatusCode | eventFinalize () override | 
|  | Event finalizer - called at the end of each event.  More... 
 | 
|  | 
| virtual StatusCode | finalize () override | 
|  | Finalizer.  More... 
 | 
|  | 
| std::string | find_file (const std::string &fname) const | 
|  | 
| virtual StatusCode | readConfig () override | 
|  | 
| virtual void | print () const | 
|  | Print the state of the tool.  More... 
 | 
|  | 
| ServiceHandle< StoreGateSvc > & | evtStore () | 
|  | The standard StoreGateSvc(event store) Returns (kind of) a pointer to theStoreGateSvc.  More...
 | 
|  | 
| const ServiceHandle< StoreGateSvc > & | evtStore () const | 
|  | The standard StoreGateSvc(event store) Returns (kind of) a pointer to theStoreGateSvc.  More...
 | 
|  | 
| const ServiceHandle< StoreGateSvc > & | detStore () const | 
|  | The standard StoreGateSvc/DetectorStoreReturns (kind of) a pointer to theStoreGateSvc.  More...
 | 
|  | 
| virtual StatusCode | sysInitialize () override | 
|  | Perform system initialization for an algorithm.  More... 
 | 
|  | 
| virtual StatusCode | sysStart () override | 
|  | Handle START transition.  More... 
 | 
|  | 
| virtual std::vector< Gaudi::DataHandle * > | inputHandles () const override | 
|  | Return this algorithm's input handles.  More... 
 | 
|  | 
| virtual std::vector< Gaudi::DataHandle * > | outputHandles () const override | 
|  | Return this algorithm's output handles.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareProperty (Gaudi::Property< T, V, H > &t) | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleKey &hndl, const std::string &doc, const SG::VarHandleKeyType &) | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleBase &hndl, const std::string &doc, const SG::VarHandleType &) | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, SG::VarHandleKeyArray &hndArr, const std::string &doc, const SG::VarHandleKeyArrayType &) | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, T &property, const std::string &doc, const SG::NotHandleType &) | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase * | declareProperty (const std::string &name, T &property, const std::string &doc="none") | 
|  | Declare a new Gaudi property.  More... 
 | 
|  | 
| void | updateVHKA (Gaudi::Details::PropertyBase &) | 
|  | 
| MsgStream & | msg () const | 
|  | 
| MsgStream & | msg (const MSG::Level lvl) const | 
|  | 
| bool | msgLvl (const MSG::Level lvl) const | 
|  | 
|  | 
| Gaudi::Property< bool > | m_in_trigger {this, "inTrigger", false, "Indicate if the tool is running on trigger"} | 
|  | 
| Gaudi::Property< bool > | m_in_AOD {this, "inAOD", false, "Indicate if the tool is running on AOD"} | 
|  | 
| Gaudi::Property< bool > | m_in_EleRM {this, "inEleRM", false, "Indicate if the tool is running on EleRM routine"} | 
|  | 
| Gaudi::Property< std::string > | m_tauRecToolsTag {this, "calibFolder", "tauRecTools/R22_preprod", "CVMFS path to the tau calibration folder"} | 
|  | 
|  | 
| StatusCode | selectCells (const xAOD::TauJet &tau, const CaloCellContainer &cellContainer, const CaloDetDescrManager *detMgr, std::vector< const CaloCell * > &cells) const | 
|  | Apply preselection of the cells Cells within dR < 0.4, in EM1, and pt > 100 MeV are selected.  More... 
 | 
|  | 
| StatusCode | selectSeedCells (const xAOD::TauJet &tau, const CaloCellContainer &cellContainer, const CaloDetDescrManager *detMgr, std::vector< const CaloCell * > &seedCells) const | 
|  | Select the seed cells used to construct the shot Cells must sastisfy:  More... 
 | 
|  | 
| bool | isPhiNeighbour (IdentifierHash cell1Hash, IdentifierHash cell2Hash) const | 
|  | Check whether two cells are neighbours in the phi direction.  More... 
 | 
|  | 
| const CaloCell * | getPhiNeighbour (const CaloCell &seedCell, const std::vector< const CaloCell * > &seedCells) const | 
|  | Get the hottest neighbour cell in the phi direction.  More... 
 | 
|  | 
| std::vector< const CaloCell * > | getEtaNeighbours (const CaloCell &cell, const CaloCellContainer &cellContainer, int maxDepth) const | 
|  | Get neighbour cells in the eta direction.  More... 
 | 
|  | 
| void | addEtaNeighbours (const CaloCell &cell, const CaloCellContainer &cellContainer, std::vector< const CaloCell * > &cells, int depth, int maxDepth, bool next) const | 
|  | Get neighbour cells in the eta direction.  More... 
 | 
|  | 
| xAOD::CaloCluster * | createShotCluster (const CaloCell *cell, const CaloCell *phiNeighCell, const CaloCellContainer &cellContainer, xAOD::CaloClusterContainer *clusterContainer) const | 
|  | Create the shot cluster Shot cluster contains 5x1 cells from the seed cell and hottestneighbour cell in the phi direction.  More... 
 | 
|  | 
| int | getEtaBin (float eta) const | 
|  | Get eta bin.  More... 
 | 
|  | 
| int | getNPhotons (float eta, float energy) const | 
|  | Get NPhotons in shot.  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &) | 
|  | specialization for handling Gaudi::Property<SG::VarHandleKey>  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyArrayType &) | 
|  | specialization for handling Gaudi::Property<SG::VarHandleKeyArray>  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleType &) | 
|  | specialization for handling Gaudi::Property<SG::VarHandleBase>  More... 
 | 
|  | 
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &t, const SG::NotHandleType &) | 
|  | specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray>  More... 
 | 
|  | 
|  | 
| Gaudi::Property< int > | m_nCellsInEta {this, "NCellsInEta"} | 
|  | 
| Gaudi::Property< std::vector< float > > | m_minPtCut {this, "MinPtCut"} | 
|  | 
| Gaudi::Property< std::vector< float > > | m_doubleShotCut {this, "AutoDoubleShotCut"} | 
|  | 
| Gaudi::Property< bool > | m_removeElectronCells {this, "RemoveElectronCells", false} | 
|  | 
| SG::ReadHandleKey< CaloCellContainer > | m_caloCellInputContainer {this,"Key_caloCellInputContainer", "AllCalo", "input vertex container key"} | 
|  | 
| SG::ReadCondHandleKey< CaloDetDescrManager > | m_caloMgrKey {this,"CaloDetDescrManager", "CaloDetDescrManager"} | 
|  | 
| ToolHandle< IHadronicCalibrationTool > | m_caloWeightTool {this, "CaloWeightTool", "H1WeightToolCSC12Generic"} | 
|  | 
| SG::ReadHandleKey< xAOD::CaloClusterContainer > | m_removedClusterInputContainer {this,"Key_RemovedClusterInputContainer", "", "input removed cluster key"} | 
|  | 
| const CaloCell_ID * | m_calo_id = nullptr | 
|  | calo cell navigation  More... 
 | 
|  | 
| StoreGateSvc_t | m_evtStore | 
|  | Pointer to StoreGate (event store by default)  More... 
 | 
|  | 
| StoreGateSvc_t | m_detStore | 
|  | Pointer to StoreGate (detector store by default)  More... 
 | 
|  | 
| std::vector< SG::VarHandleKeyArray * > | m_vhka | 
|  | 
| bool | m_varHandleArraysDeclared | 
|  | 
Definition at line 30 of file TauShotFinder.h.
 
◆ StoreGateSvc_t
◆ TauShotFinder()
      
        
          | TauShotFinder::TauShotFinder | ( | const std::string & | name | ) |  | 
      
 
 
◆ ~TauShotFinder()
  
  | 
        
          | virtual TauShotFinder::~TauShotFinder | ( |  | ) |  |  | virtualdefault | 
 
 
◆ addEtaNeighbours()
Get neighbour cells in the eta direction. 
Definition at line 340 of file TauShotFinder.cxx.
  348   if (
depth > maxDepth) 
return;
 
  352   std::vector<IdentifierHash> neigHashes;
 
  363     if (!newCell) 
continue;
 
  365     cells.push_back(newCell);
 
  368     if (neigHashes.size() > 1) {
 
 
 
 
◆ ASG_TOOL_CLASS2()
◆ createShotCluster()
Create the shot cluster Shot cluster contains 5x1 cells from the seed cell and hottestneighbour cell in the phi direction. 
Definition at line 377 of file TauShotFinder.cxx.
  386   std::vector<const CaloCell*> windowNeighbours = this->
getEtaNeighbours(*cell, cellContainer, maxDepth);
 
  388     std::vector<const CaloCell*> mergeCells = this->
getEtaNeighbours(*phiNeigCell, cellContainer, maxDepth);
 
  389     windowNeighbours.push_back(phiNeigCell);
 
  390     windowNeighbours.insert(windowNeighbours.end(), mergeCells.begin(), mergeCells.end());
 
 
 
 
◆ declareGaudiProperty() [1/4]
specialization for handling Gaudi::Property<SG::VarHandleKeyArray> 
Definition at line 170 of file AthCommonDataStore.h.
  175                                                        hndl.documentation());
 
 
 
 
◆ declareGaudiProperty() [2/4]
specialization for handling Gaudi::Property<SG::VarHandleKey> 
Definition at line 156 of file AthCommonDataStore.h.
  161                                                        hndl.documentation());
 
 
 
 
◆ declareGaudiProperty() [3/4]
specialization for handling Gaudi::Property<SG::VarHandleBase> 
Definition at line 184 of file AthCommonDataStore.h.
  189                                                        hndl.documentation());
 
 
 
 
◆ declareGaudiProperty() [4/4]
◆ declareProperty() [1/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | hndl | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This is the version for types that derive from SG::VarHandleBase. The property value object is put on the input and output lists as appropriate; then we forward to the base class. 
Definition at line 245 of file AthCommonDataStore.h.
  250     this->declare(hndl.
vhKey());
 
  251     hndl.
vhKey().setOwner(
this);
 
  253     return PBASE::declareProperty(
name,hndl,
doc);
 
 
 
 
◆ declareProperty() [2/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | hndl | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This is the version for types that derive from SG::VarHandleKey. The property value object is put on the input and output lists as appropriate; then we forward to the base class. 
Definition at line 221 of file AthCommonDataStore.h.
  229     return PBASE::declareProperty(
name,hndl,
doc);
 
 
 
 
◆ declareProperty() [3/6]
◆ declareProperty() [4/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | property | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This is the generic version, for types that do not derive from SG::VarHandleKey. It just forwards to the base class version of declareProperty. 
Definition at line 333 of file AthCommonDataStore.h.
  338     return PBASE::declareProperty(
name, property, 
doc);
 
 
 
 
◆ declareProperty() [5/6]
Declare a new Gaudi property. 
- Parameters
- 
  
    | name | Name of the property. |  | property | Object holding the property value. |  | doc | Documentation string for the property. |  
 
This dispatches to either the generic declareProperty or the one for VarHandle/Key/KeyArray. 
Definition at line 352 of file AthCommonDataStore.h.
 
 
◆ declareProperty() [6/6]
◆ detStore()
◆ eventFinalize()
  
  | 
        
          | StatusCode TauRecToolBase::eventFinalize | ( |  | ) |  |  | overridevirtualinherited | 
 
 
◆ eventInitialize()
  
  | 
        
          | StatusCode TauRecToolBase::eventInitialize | ( |  | ) |  |  | overridevirtualinherited | 
 
 
◆ evtStore() [1/2]
◆ evtStore() [2/2]
◆ execute()
  
  | 
        
          | StatusCode TauRecToolBase::execute | ( | xAOD::TauJet & | pTau | ) | const |  | overridevirtualinherited | 
 
Execute - called for each tau candidate. 
Implements ITauToolBase.
Reimplemented in TauDecayModeNNClassifier, TauCombinedTES, MvaTESVariableDecorator, MvaTESEvaluator, TauWPDecorator, TauAxisSetter, TauGNNEvaluator, TauEleOverlapChecker, TauJetRNNEvaluator, TauCalibrateLC, TauClusterFinder, TauSubstructureVariables, TauVertexedClusterDecorator, TauAODSelector, TauElectronVetoVariables, JetSeedBuilder, TauCellVariables, TauCommonCalcVars, TauIDVarCalculator, and TauAODMuonRemovalTool.
Definition at line 138 of file TauRecToolBase.cxx.
  140   return StatusCode::FAILURE;
 
 
 
 
◆ executePanTau()
◆ executePi0ClusterCreator()
◆ executePi0ClusterScaler()
◆ executePi0CreateROI()
◆ executePi0nPFO()
◆ executeShotFinder()
Reimplemented from TauRecToolBase.
Definition at line 32 of file TauShotFinder.cxx.
   36   std::vector<ElementLink<xAOD::PFOContainer>> 
empty;
 
   37   tau.setShotPFOLinks(empty);
 
   41      return StatusCode::SUCCESS;
 
   45   if (!caloCellInHandle.isValid()) {
 
   46     ATH_MSG_ERROR (
"Could not retrieve HiveDataObj with key " << caloCellInHandle.key());
 
   47     return StatusCode::FAILURE;
 
   57   std::vector<const CaloCell*> seedCells;
 
   62   while (!seedCells.empty()) {
 
   69     shotPFOContainer.push_back(shot);
 
   87       shot->
setP4( 
static_cast<float>(
pt), 
static_cast<float>(
cell->eta()), 
static_cast<float>(
phi), 
static_cast<float>(
cell->m()));
 
  120     tau.addShotPFOLink(PFOElementLink);
 
  123     auto cellIndex = 
std::find(seedCells.begin(), seedCells.end(), 
cell);
 
  124     seedCells.erase(cellIndex);
 
  126       cellIndex = 
std::find(seedCells.begin(), seedCells.end(), phiNeigCell);
 
  127       seedCells.erase(cellIndex);
 
  131   return StatusCode::SUCCESS;
 
 
 
 
◆ executeTrackClassifier()
◆ executeTrackFinder()
◆ executeVertexFinder()
◆ executeVertexVariables()
◆ extraDeps_update_handler()
Add StoreName to extra input/output deps as needed. 
use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given 
 
 
◆ finalize()
  
  | 
        
          | StatusCode TauRecToolBase::finalize | ( |  | ) |  |  | overridevirtualinherited | 
 
 
◆ find_file()
  
  | 
        
          | std::string TauRecToolBase::find_file | ( | const std::string & | fname | ) | const |  | inherited | 
 
 
◆ getEtaBin()
  
  | 
        
          | int TauShotFinder::getEtaBin | ( | float | eta | ) | const |  | private | 
 
 
◆ getEtaNeighbours()
Get neighbour cells in the eta direction. 
Definition at line 325 of file TauShotFinder.cxx.
  328     std::vector<const CaloCell*> 
cells;
 
 
 
 
◆ getKey()
Get the (hashed) key of an object that is in the event store. 
This is a bit of a special one. StoreGateSvc and xAOD::TEvent both provide ways for getting the SG::sgkey_t key for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.
In order to allow tools to efficiently perform this operation, they can use this helper function.
- See also
- asg::AsgTool::getName
- Parameters
- 
  
    | ptr | The bare pointer to the object that the event store should know about |  
 
- Returns
- The hashed key of the object in the store. If not found, an invalid (zero) key. 
Definition at line 119 of file AsgTool.cxx.
  121 #ifdef XAOD_STANDALONE 
  127       return ( 
proxy == 
nullptr ? 0 : 
proxy->sgkey() );
 
  128 #endif // XAOD_STANDALONE 
 
 
 
◆ getName()
  
  | 
        
          | const std::string & asg::AsgTool::getName | ( | const void * | ptr | ) | const |  | inherited | 
 
Get the name of an object that is / should be in the event store. 
This is a bit of a special one. StoreGateSvc and xAOD::TEvent both provide ways for getting the std::string name for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.
In order to allow tools to efficiently perform this operation, they can use this helper function.
- See also
- asg::AsgTool::getKey
- Parameters
- 
  
    | ptr | The bare pointer to the object that the event store should know about |  
 
- Returns
- The string name of the object in the store. If not found, an empty string. 
Definition at line 106 of file AsgTool.cxx.
  108 #ifdef XAOD_STANDALONE 
  114       static const std::string 
dummy = 
"";
 
  116 #endif // XAOD_STANDALONE 
 
 
 
◆ getNPhotons()
  
  | 
        
          | int TauShotFinder::getNPhotons | ( | float | eta, |  
          |  |  | float | energy |  
          |  | ) |  | const |  | private | 
 
 
◆ getPhiNeighbour()
Get the hottest neighbour cell in the phi direction. 
Definition at line 297 of file TauShotFinder.cxx.
  303   std::vector<const CaloCell*> neighCells;
 
  304   for (
const CaloCell* neighCell : seedCells) {
 
  305     if (neighCell == &seedCell) 
continue;
 
  309       neighCells.push_back(neighCell);
 
  312   std::sort(neighCells.begin(),neighCells.end(),ptSort(*
this)); 
 
  315   const CaloCell* phiNeigCell = 
nullptr;
 
  316   if (!neighCells.empty()) {
 
  317     phiNeigCell = neighCells[0];
 
 
 
 
◆ getProperty()
template<class T > 
  
  | 
        
          | const T* asg::AsgTool::getProperty | ( | const std::string & | name | ) | const |  | inherited | 
 
Get one of the tool's properties. 
 
 
◆ inAOD()
  
  | 
        
          | bool TauRecToolBase::inAOD | ( |  | ) | const |  | inlineprotectedinherited | 
 
 
◆ inEleRM()
  
  | 
        
          | bool TauRecToolBase::inEleRM | ( |  | ) | const |  | inlineprotectedinherited | 
 
 
◆ initialize()
  
  | 
        
          | StatusCode TauShotFinder::initialize | ( |  | ) |  |  | overridevirtual | 
 
 
◆ inputHandles()
Return this algorithm's input handles. 
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA. 
 
 
◆ inTrigger()
  
  | 
        
          | bool TauRecToolBase::inTrigger | ( |  | ) | const |  | inlineprotectedinherited | 
 
 
◆ isPhiNeighbour()
Check whether two cells are neighbours in the phi direction. 
Definition at line 275 of file TauShotFinder.cxx.
  276   std::vector<IdentifierHash> neigHashes;
 
  280   if (neigHashes.size() > 1) {
 
  281     ATH_MSG_DEBUG(cell1Hash << 
" has " << neigHashes.size()  <<  
" neighbours in the next phi direction !"); 
 
  283   if (
std::find(neigHashes.begin(), neigHashes.end(), cell2Hash) != neigHashes.end()) {
 
  289   if (neigHashes.size() > 1) {
 
  290     ATH_MSG_DEBUG(cell1Hash << 
" has " << neigHashes.size()  <<  
" neighbours in the previous phi direction !"); 
 
  292   return std::find(neigHashes.begin(), neigHashes.end(), cell2Hash) != neigHashes.end();
 
 
 
 
◆ msg() [1/2]
◆ msg() [2/2]
◆ msg_level_name()
  
  | 
        
          | const std::string & asg::AsgTool::msg_level_name | ( |  | ) | const |  | inherited | 
 
A deprecated function for getting the message level's name. 
Instead of using this, weirdly named function, user code should get the string name of the current minimum message level (in case they really need it...), with:
 MSG::name( msg().level() ) 
This function's name doesn't follow the ATLAS coding rules, and as such will be removed in the not too distant future.
- Returns
- The string name of the current minimum message level that's printed 
Definition at line 101 of file AsgTool.cxx.
 
 
◆ msgLvl()
◆ outputHandles()
Return this algorithm's output handles. 
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA. 
 
 
◆ print()
  
  | 
        
          | void asg::AsgTool::print | ( |  | ) | const |  | virtualinherited | 
 
Print the state of the tool. 
Implements asg::IAsgTool.
Reimplemented in JetRecTool, JetFinder, JetModifiedMassDrop, JetFromPseudojet, JetReclusterer, JetReclusteringTool, JetTruthLabelingTool, JetPileupLabelingTool, HI::HIPileupTool, LundVariablesTool, JetDumper, JetBottomUpSoftDrop, JetRecursiveSoftDrop, JetSoftDrop, JetConstituentsRetriever, JetSubStructureMomentToolsBase, JetSplitter, JetToolRunner, JetPruner, JetPseudojetRetriever, JetTrimmer, AsgHelloTool, and KtDeltaRTool.
Definition at line 131 of file AsgTool.cxx.
 
 
◆ readConfig()
  
  | 
        
          | StatusCode TauRecToolBase::readConfig | ( |  | ) |  |  | overridevirtualinherited | 
 
Implements ITauToolBase.
Definition at line 27 of file TauRecToolBase.cxx.
   32 #ifndef XAOD_STANDALONE 
   33   bool configPathDeclared = 
false;
 
   34   for (Gaudi::Details::PropertyBase* property : getProperties())
 
   36     if (property->name() == 
"ConfigPath")
 
   38       configPathDeclared = 
true;
 
   42   if (!configPathDeclared)
 
   43 #elif defined(XAOD_STANDALONE) 
   44   PropertyMgr::PropMap_t property_map = getPropertyMgr()->getProperties();
 
   45   if (property_map.find(
"ConfigPath") == property_map.end())
 
   47 #   error "What environment are we in?!?" 
   48 #endif // XAOD_STANDALONE 
   50     ATH_MSG_INFO(
"No config file path property declared yet, this is not recommended");
 
   51     return StatusCode::SUCCESS;
 
   55   const std::string* config_file_path_property;
 
   58   config_file_path_property = getProperty<std::string>(
"ConfigPath");
 
   59   std::string config_file_path = 
find_file(*config_file_path_property);
 
   63   THashList* lList = 
env.GetTable();
 
   64   for( Int_t 
i = 0; lList && 
i < lList->GetEntries(); ++
i )
 
   68 #ifndef XAOD_STANDALONE 
   70     const std::type_info* 
type = 
getProperty(lList->At( 
i )->GetName()).type_info();
 
   73     if (*
type == 
typeid(
bool))
 
   75         bool(
env.GetValue(lList->At( 
i )->GetName(),
bool(
true))));
 
   76     else if (*
type == 
typeid(
int))
 
   78         env.GetValue(lList->At( 
i )->GetName(),
int(0)));
 
   79     else if (*
type == 
typeid(
float))
 
   81         env.GetValue(lList->At( 
i )->GetName(),
float(0)));
 
   82     else if (*
type == 
typeid(
double))
 
   84         env.GetValue(lList->At( 
i )->GetName(),
double(0)));
 
   85     else if (*
type == 
typeid(std::string))
 
   87         env.GetValue(lList->At( 
i )->GetName(),
""));
 
   94         bool(
env.GetValue(lList->At( 
i )->GetName(),
bool(
true))));
 
   97         env.GetValue(lList->At( 
i )->GetName(),
int(0)));
 
  100         env.GetValue(lList->At( 
i )->GetName(),
float(0)));
 
  103         env.GetValue(lList->At( 
i )->GetName(),
double(0)));
 
  106         env.GetValue(lList->At( 
i )->GetName(),
""));
 
  107 #endif // XAOD_STANDALONE 
  110 #ifndef XAOD_STANDALONE 
  111       ATH_MSG_FATAL(
"there was a problem to find the correct type enum: "<<
type->name());
 
  114 #endif // XAOD_STANDALONE 
  115       return StatusCode::FAILURE;
 
  117     if (!
sc.isSuccess()) {
 
  118       ATH_MSG_FATAL(
"failed to set property: " << lList->At( 
i )->GetName());
 
  119       return StatusCode::FAILURE;
 
  122   return StatusCode::SUCCESS;
 
 
 
 
◆ renounce()
◆ renounceArray()
◆ selectCells()
Apply preselection of the cells Cells within dR < 0.4, in EM1, and pt > 100 MeV are selected. 
Definition at line 174 of file TauShotFinder.cxx.
  179   std::vector<const CaloCell*> removed_cells;
 
  182     if (!removedClustersHandle.isValid()){
 
  183       ATH_MSG_ERROR (
"Could not retrieve HiveDataObj with key " << removedClustersHandle.key());
 
  184       return StatusCode::FAILURE;
 
  188     for (
auto cluster : *removed_clusters_cont){
 
  189       for(
auto cell_it = cluster->cell_cbegin(); cell_it != cluster->cell_cend(); cell_it++){
 
  190         removed_cells.push_back(*cell_it);
 
  196   std::vector<CaloCell_ID::SUBCALO> emSubCaloBlocks;
 
  198   std::unique_ptr<CaloCellList> cellList = std::make_unique<CaloCellList>(detMgr, &cellContainer, emSubCaloBlocks);
 
  210     int sampling = 
cell->caloDDE()->getSampling();
 
  215   return StatusCode::SUCCESS;
 
 
 
 
◆ selectSeedCells()
Select the seed cells used to construct the shot Cells must sastisfy: 
- pre-selction: dR < 0.4, in EM1, and pt > 100 MeV
- have largest pt among the neighbours in the eta direction
- no other seed cells as neighbors in the eta direction 
Definition at line 220 of file TauShotFinder.cxx.
  226   assert(seedCells.empty());
 
  227   std::vector<const CaloCell*> 
cells;
 
  231   std::set<IdentifierHash> seedCellHashes;
 
  237     std::vector<IdentifierHash> nextEtaHashes;
 
  239     std::vector<IdentifierHash> prevEtaHashes;
 
  242     std::vector<IdentifierHash> neighHashes = nextEtaHashes; 
 
  243     neighHashes.insert(neighHashes.end(),prevEtaHashes.begin(),prevEtaHashes.end()); 
 
  250       if (seedCellHashes.find(neighHash) != seedCellHashes.end()) {
 
  257       if (!neighCell) 
continue;
 
  266     seedCells.push_back(
cell); 
 
  270   return StatusCode::SUCCESS;
 
 
 
 
◆ sysInitialize()
◆ sysStart()
Handle START transition. 
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container. 
 
 
◆ updateVHKA()
◆ m_calo_id
◆ m_caloCellInputContainer
◆ m_caloMgrKey
◆ m_caloWeightTool
◆ m_detStore
◆ m_doubleShotCut
  
  | 
        
          | Gaudi::Property<std::vector<float> > TauShotFinder::m_doubleShotCut {this, "AutoDoubleShotCut"} |  | private | 
 
 
◆ m_evtStore
◆ m_in_AOD
  
  | 
        
          | Gaudi::Property<bool> TauRecToolBase::m_in_AOD {this, "inAOD", false, "Indicate if the tool is running on AOD"} |  | protectedinherited | 
 
 
◆ m_in_EleRM
  
  | 
        
          | Gaudi::Property<bool> TauRecToolBase::m_in_EleRM {this, "inEleRM", false, "Indicate if the tool is running on EleRM routine"} |  | protectedinherited | 
 
 
◆ m_in_trigger
  
  | 
        
          | Gaudi::Property<bool> TauRecToolBase::m_in_trigger {this, "inTrigger", false, "Indicate if the tool is running on trigger"} |  | protectedinherited | 
 
 
◆ m_minPtCut
  
  | 
        
          | Gaudi::Property<std::vector<float> > TauShotFinder::m_minPtCut {this, "MinPtCut"} |  | private | 
 
 
◆ m_nCellsInEta
  
  | 
        
          | Gaudi::Property<int> TauShotFinder::m_nCellsInEta {this, "NCellsInEta"} |  | private | 
 
 
◆ m_removedClusterInputContainer
◆ m_removeElectronCells
  
  | 
        
          | Gaudi::Property<bool> TauShotFinder::m_removeElectronCells {this, "RemoveElectronCells", false} |  | private | 
 
 
◆ m_tauRecToolsTag
  
  | 
        
          | Gaudi::Property<std::string> TauRecToolBase::m_tauRecToolsTag {this, "calibFolder", "tauRecTools/R22_preprod", "CVMFS path to the tau calibration folder"} |  | protectedinherited | 
 
 
◆ m_varHandleArraysDeclared
◆ m_vhka
The documentation for this class was generated from the following files:
 
static std::unique_ptr< xAOD::CaloCluster > makeCluster(const CaloCellContainer *cellCont)
Creates a valid CaloCluster with a private Aux-Store and CellLink container.
def retrieve(aClass, aKey=None)
SG::ReadHandleKey< CaloCellContainer > m_caloCellInputContainer
virtual double pt() const
transverse momentum
Type
Property type enumeration.
Gaudi::Property< std::vector< float > > m_minPtCut
@ depth
pointing depth of the shower as calculated in egammaqgcld
std::vector< std::vector< const CaloCell * > > getCellBlock(const xAOD::PFO &shot, const CaloCell_ID *calo_id)
Get cell block with (currently) 2 x 5 cells in correct order for variable calculations.
virtual double phi() const override final
get phi (through CaloDetDescrElement)
bool toContainedElement(BaseConstReference data, ElementType element, IProxyDict *sg=0)
Set from element pointer and a reference to the container (storable)
Scalar phi() const
phi method
void select(double eta, double phi, double deta, double dphi)
std::string find(const std::string &s)
return a remapped string
virtual double eta() const
The pseudorapidity ( ) of the particle.
Scalar eta() const
pseudorapidity method
xAOD::CaloCluster * createShotCluster(const CaloCell *cell, const CaloCell *phiNeighCell, const CaloCellContainer &cellContainer, xAOD::CaloClusterContainer *clusterContainer) const
Create the shot cluster Shot cluster contains 5x1 cells from the seed cell and hottestneighbour cell ...
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
std::vector< SG::VarHandleKeyArray * > m_vhka
SG::ReadCondHandleKey< CaloDetDescrManager > m_caloMgrKey
const CaloCell * getPhiNeighbour(const CaloCell &seedCell, const std::vector< const CaloCell * > &seedCells) const
Get the hottest neighbour cell in the phi direction.
bool dPhi(const xAOD::TauJet &tau, const xAOD::CaloVertexedTopoCluster &cluster, float &out)
__HOSTDEV__ double Phi_mpi_pi(double)
void addEtaNeighbours(const CaloCell &cell, const CaloCellContainer &cellContainer, std::vector< const CaloCell * > &cells, int depth, int maxDepth, bool next) const
Get neighbour cells in the eta direction.
ToolHandle< IHadronicCalibrationTool > m_caloWeightTool
const ServiceHandle< StoreGateSvc > & detStore() const
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual void setOwner(IDataHandleHolder *o)=0
bool setClusterLink(const ElementLink< xAOD::CaloClusterContainer > &theCluster)
Set a cluster constituent - does NOT append to existing container
Gaudi::Property< int > m_nCellsInEta
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
ServiceHandle< StoreGateSvc > & evtStore()
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
virtual double phi() const
The azimuthal angle ( ) of the particle.
void setProperty(columnar::PythonToolHandle &self, const std::string &key, nb::object value)
Description of a calorimeter cluster.
setSAddress setEtaMS setDirPhiMS setDirZMS setBarrelRadius setEndcapAlpha setEndcapRadius setInterceptInner setEtaMap etaBin
int getNPhotons(float eta, float energy) const
Get NPhotons in shot.
IdentifierHash calo_hash() const
cell calo hash
void reserve(const size_t s)
Method to reserve space the underlying vector<pair>
PFO_v1 PFO
Definition of the current "pfo version".
::StatusCode StatusCode
StatusCode definition for legacy code.
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
const CaloDetDescrElement * caloDDE() const
get pointer to CaloDetDescrElement (data member)
const std::string & name(Level lvl)
Convenience function for translating message levels to strings.
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
void setBDTPi0Score(float BDTPi0Score)
set BDT Score used to classify clusters as Pi0 like or not
float ptWindow(const std::vector< std::vector< const CaloCell * >> &shotCells, int windowSize, const ToolHandle< IHadronicCalibrationTool > &caloWeightTool)
pt in a window of (currently) 2 x windowSize cells
virtual void renounce()=0
const CaloCell * findCell(const IdentifierHash theHash) const
fast find method given identifier hash.
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
ElementLink implementation for ROOT usage.
bool isPhiNeighbour(IdentifierHash cell1Hash, IdentifierHash cell2Hash) const
Check whether two cells are neighbours in the phi direction.
Class describing a particle flow object.
StatusCode selectCells(const xAOD::TauJet &tau, const CaloCellContainer &cellContainer, const CaloDetDescrManager *detMgr, std::vector< const CaloCell * > &cells) const
Apply preselection of the cells Cells within dR < 0.4, in EM1, and pt > 100 MeV are selected.
int get_neighbours(const IdentifierHash caloHash, const LArNeighbours::neighbourOption &option, std::vector< IdentifierHash > &neighbourList) const
access to hashes for neighbours return == 0 for neighbours found
StatusCode initialize(bool used=true)
int getEtaBin(float eta) const
Get eta bin.
Container class for CaloCell.
std::string PathResolverFindCalibFile(const std::string &logical_file_name)
Gaudi::Property< bool > m_removeElectronCells
std::vector< const CaloCell * > getEtaNeighbours(const CaloCell &cell, const CaloCellContainer &cellContainer, int maxDepth) const
Get neighbour cells in the eta direction.
void setP4(const FourMom_t &vec)
set the 4-vec
void setCharge(float charge)
set charge of PFO
const CaloCell_ID * m_calo_id
calo cell navigation
bool empty() const noexcept
This class provides the client interface for accessing the detector description information common to...
Data object for each calorimeter readout cell.
void sort(typename std::reverse_iterator< DataModel_detail::iterator< DVL > > beg, typename std::reverse_iterator< DataModel_detail::iterator< DVL > > end, const Compare &comp)
Specialization of sort for DataVector/List.
@ tauShots_nCellsInEta
These are the variables describing Tau Shot objects, which are built from EM1 cells.
StatusCode selectSeedCells(const xAOD::TauJet &tau, const CaloCellContainer &cellContainer, const CaloDetDescrManager *detMgr, std::vector< const CaloCell * > &seedCells) const
Select the seed cells used to construct the shot Cells must sastisfy:
CaloClusterCellLink * getOwnCellLinks()
Get a pointer to the owned CaloClusterCellLink object (non-const version)
bool addCell(const unsigned index, const double weight)
Method to add a cell to the cluster (Beware: Kinematics not updated!)
bool absEta(const xAOD::TauJet &tau, float &out)
int findIndex(const IdentifierHash theHash) const
Return index of the cell with a given hash.
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
static void calculateKine(xAOD::CaloCluster *clu, const bool useweight=true, const bool updateLayers=true, const bool useGPUCriteria=false)
Helper class to calculate cluster kinematics based on cells.
This is a "hash" representation of an Identifier. This encodes a 32 bit index which can be used to lo...
void setAttribute(PFODetails::PFOAttributes AttributeType, const T &anAttribute)
Set a PFO Variable via enum - overwrite is allowed.
SG::ReadHandleKey< xAOD::CaloClusterContainer > m_removedClusterInputContainer
Gaudi::Property< std::vector< float > > m_doubleShotCut
void setCenterMag(float CenterMag)
set CenterMag moment needed for vertex correction