ATLAS Offline Software
xAODEmTauROIRetriever.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
3 */
4 
6 
7 #include <string>
8 
9 #include "CLHEP/Units/SystemOfUnits.h"
10 
11 //#include "AnalysisTriggerEvent/LVL1_ROI.h"
12 
13 //#include "TrigT1CaloEvent/CPMRoI.h"
14 //#include "TrigT1Interfaces/CPRoIDecoder.h"
15 
17 
18 namespace JiveXML {
19 
20  //--------------------------------------------------------------------------
21 
22  xAODEmTauROIRetriever::xAODEmTauROIRetriever(const std::string& type, const std::string& name, const IInterface* parent):
23  AthAlgTool(type, name, parent), m_typeName("EmTauROI")
24  {
25 
26  declareInterface<IDataRetriever>(this);
27  }
28 
29  //--------------------------------------------------------------------------
30 
31  StatusCode xAODEmTauROIRetriever::retrieve(ToolHandle<IFormatTool> &FormatTool) {
32 
33  DataVect phi;
34  DataVect eta;
36  DataVect energyEM;
37  DataVect energyTAU;
40 
42 
43  const xAOD::EmTauRoIContainer* emTauRoIs = 0;
44 
45  //xAOD::EmTauRoIContainer* emTauRoIs = 0;
46 
47  // L1JetObject -not- available
48  m_sgKey = "LVL1EmTauRoIs";
49  if ( evtStore()->retrieve(emTauRoIs,m_sgKey).isFailure() ) {
50  if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << "No LVL1EmTauROIs found in SG " << endmsg;
51  return StatusCode::SUCCESS;
52  }
53  if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << "Found LVL1EmTauROIs in SG ! " << endmsg;
54 
56  xAOD::EmTauRoIContainer::const_iterator itEMe = emTauRoIs->end();
57 
58  //if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << "xAOD EmTauROIs retrieved from StoreGate with size: " << (emTauRoIs->size()) <<endmsg;
59 
60  int counter = 0;
61  for (; itEM != itEMe; ++itEM)
62  {
63  phi.push_back(DataType( (*itEM)->phi()) );
64  eta.push_back(DataType( (*itEM)->eta()) );
65 
66  if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << "xAOD EmTauRoI #" << counter++
67  << ", eta: " << (*itEM)->eta() << ", phi: " << (*itEM)->phi() << endmsg;
68 
69 // Placeholders ! No direct access to those in Run-2
70 // Reference:
71 // Event/xAOD/xAODTrigger/trunk/Root/EmTauRoI_v2.cxx
72 // jpt 9Jan15:
73  energy.push_back(DataType( 0. ));
74  energyEM.push_back(DataType( 0. ));
75  energyTAU.push_back(DataType( 0. ));
76  roiWord.push_back(DataType( 0. ));
77  thrPattern.push_back(DataType( 0. ));
78  }
79 
80  DataMap myDataMap;
81  myDataMap["energy"] = energy;
82  myDataMap["phi"] = phi;
83  myDataMap["eta"] = eta;
84  myDataMap["energy"] = energy;
85  myDataMap["energyEM"] = energyEM;
86  myDataMap["energyTAU"] = energyTAU;
87  myDataMap["roiWord"] = roiWord;
88  myDataMap["thrPattern"] = thrPattern;
89 
90  if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << dataTypeName() << ": "<< phi.size()
91  << " from: " << m_sgKey << endmsg;
92 
93  //forward data to formating tool
94  return FormatTool->AddToEvent(dataTypeName(), m_sgKey, &myDataMap);
95  }
96 }
JiveXML::xAODEmTauROIRetriever::m_sgKey
std::string m_sgKey
Definition: xAODEmTauROIRetriever.h:50
DataModel_detail::const_iterator
Const iterator class for DataVector/DataList.
Definition: DVLIterator.h:82
phi
Scalar phi() const
phi method
Definition: AmgMatrixBasePlugin.h:64
eta
Scalar eta() const
pseudorapidity method
Definition: AmgMatrixBasePlugin.h:79
JiveXML::DataVect
std::vector< DataType > DataVect
Defines a map with a key and a vector of DataType objects e.g.
Definition: DataType.h:58
DataType
OFFLINE_FRAGMENTS_NAMESPACE::PointerType DataType
Definition: RoIBResultByteStreamTool.cxx:25
AthCommonMsg< AlgTool >::msgLvl
bool msgLvl(const MSG::Level lvl) const
Definition: AthCommonMsg.h:30
JiveXML::DataMap
std::map< std::string, DataVect > DataMap
Definition: DataType.h:59
xAOD::roiWord
roiWord
Definition: TrigMissingET_v1.cxx:36
AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore
ServiceHandle< StoreGateSvc > & evtStore()
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
Definition: AthCommonDataStore.h:85
JiveXML::xAODEmTauROIRetriever::xAODEmTauROIRetriever
xAODEmTauROIRetriever(const std::string &type, const std::string &name, const IInterface *parent)
Standard Constructor.
Definition: xAODEmTauROIRetriever.cxx:22
ParticleGun_FastCalo_ChargeFlip_Config.energy
energy
Definition: ParticleGun_FastCalo_ChargeFlip_Config.py:78
endmsg
#define endmsg
Definition: AnalysisConfig_Ntuple.cxx:63
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
test_pyathena.parent
parent
Definition: test_pyathena.py:15
JiveXML::xAODEmTauROIRetriever::dataTypeName
virtual std::string dataTypeName() const
Return the name of the data type.
Definition: xAODEmTauROIRetriever.h:43
DataVector
Derived DataVector<T>.
Definition: DataVector.h:581
JiveXML
This header is shared inbetween the C-style server thread and the C++ Athena ServerSvc.
Definition: BadLArRetriever.cxx:21
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:192
EmTauRoIContainer.h
DataVector::end
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
xAOD::thrPattern
thrPattern
Definition: EmTauRoI_v2.cxx:60
python.CaloScaleNoiseConfig.type
type
Definition: CaloScaleNoiseConfig.py:78
DEBUG
#define DEBUG
Definition: page_access.h:11
AthCommonMsg< AlgTool >::msg
MsgStream & msg() const
Definition: AthCommonMsg.h:24
JiveXML::xAODEmTauROIRetriever::retrieve
virtual StatusCode retrieve(ToolHandle< IFormatTool > &FormatTool)
Retrieve all the data.
Definition: xAODEmTauROIRetriever.cxx:31
xAODEmTauROIRetriever.h
AthAlgTool
Definition: AthAlgTool.h:26
test_pyathena.counter
counter
Definition: test_pyathena.py:15
DataVector::begin
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.