ATLAS Offline Software
LArSuperCellMonAlg.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2021 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 // NAME: LArSuperCellMonAlg.cxx
6 // based on LArCellMonAlg:
7 // L. Morvaj, P.Strizenec, D. Oliveira Damazio - develop for Digital Trigger monitoring (2021)
8 // ********************************************************************
9 #include "LArSuperCellMonAlg.h"
10 
11 
12 #include "CaloDetDescr/CaloDetDescrElement.h"
14 #include "Identifier/Identifier.h"
18 
19 //#include "AthenaMonitoring/DQBadLBFilterTool.h"
20 //#include "AthenaMonitoring/DQAtlasReadyFilterTool.h"
21 
23 #include "AthenaKernel/Units.h"
24 
26 
27 #include <cassert>
28 #include <algorithm>
29 
31 LArSuperCellMonAlg::LArSuperCellMonAlg(const std::string& name, ISvcLocator* pSvcLocator)
32  :AthMonitorAlgorithm(name, pSvcLocator),
33  // m_badChannelMask("BadLArRawChannelMask",this),
34  m_calo_id(nullptr)
35 {
36 }
37 
38 
39 
41 }
42 
45 
46  ATH_MSG_DEBUG("LArSuperCellMonAlg::initialize() start");
47 
48 
49  //Identfier-helpers
51 
56 
59 
60  ATH_MSG_DEBUG("LArSuperCellMonAlg::initialize() is done!");
61 
63 }
64 
65 
66 
68 
69  return StatusCode::SUCCESS;
70 }
71 
72 
74 StatusCode LArSuperCellMonAlg::fillHistograms(const EventContext& ctx) const{
75 
76  ATH_MSG_DEBUG("LArSuperCellMonAlg::fillHistograms() starts");
77 
79  const CaloCellContainer* superCellCont = superCellHdl.cptr();
80  if(!superCellCont){
81  ATH_MSG_ERROR("The requested SC container key " << m_superCellContainerKey.key() << " could not be retrieved. !!!");
82  return StatusCode::SUCCESS;
83  }
84 
86  const CaloCellContainer* superCellRefCont = superCellRefHdl.cptr();
87  if(!superCellRefCont){
88  ATH_MSG_ERROR("The requested SC ref container key " << m_superCellContainerRefKey.key() << " could not be retrieved. !!!");
89  return StatusCode::SUCCESS;
90  }
91 
93  const CaloNoise *noisep = *noiseHdl;
94 
95 
96  const CaloCellContainer *superCellRecoCont = nullptr;
97  if(m_doSCReco){
99  if (!hSCetRecoContainer.isValid()) {
100  ATH_MSG_ERROR("The requested SC ET reco container key could not be retrieved. !!!");
101  }else{
102  superCellRecoCont = hSCetRecoContainer.cptr();
103  ATH_MSG_DEBUG("SCetRecoContainer.size() " << hSCetRecoContainer->size());
104  }
105  }
106 
107  if (ctx.evt()==0) {
108  ATH_CHECK(createPerJobHistograms(superCellCont, noisep));
109  }
110 
111  //get LB
112  auto lumiBlock = Monitored::Scalar<unsigned int>("lumiBlock",0);
113  lumiBlock = ctx.eventID().lumi_block();
114  auto bcid = Monitored::Scalar<unsigned int>("bcid",0);
115  bcid = ctx.eventID().bunch_crossing_id();
116  int bcidFFB = bcid;
117  if (!m_bcDataKey.empty()){
120  }
121 
122 
123 
125 
126  CaloCellContainer::const_iterator SCit = superCellCont->begin();
127  CaloCellContainer::const_iterator SCit_e = superCellCont->end();
128 
129  std::vector<std::reference_wrapper<Monitored::IMonitoredVariable>> variables;
130 
131  for ( ; SCit!=SCit_e;++SCit) {
132 
133  const CaloCell* superCell = *SCit;
134  variables.clear();
135  // Discard masked cells from monitoring
136  int SCprov = superCell->provenance()&0xFFF;
137  if (m_removeMasked && ((SCprov&0x80)==0x80)) continue;
138  float SCet = superCell->et();
139  const CaloDetDescrElement* SCcaloDDE = superCell->caloDDE();
140  float SCeta,SCphi;
141  unsigned iLyr, iLyrNS;
142  float SCt = superCell->time();
143 
144  getHistoCoordinates(SCcaloDDE, SCeta, SCphi, iLyr, iLyrNS);
145 
146 
147  bool SCpassTime = LArProv::test(SCprov,LArProv::SCTIMEPASS);//SCprov & 0x200;
148  bool SCpassPF = LArProv::test(SCprov,LArProv::SCPASSBCIDMAX);// SCprov & 0x40;
149 
150  const CaloCell* superCellRef = superCellRefCont->findCell( SCcaloDDE->identifyHash() );
151  float SCetRef = superCellRef->et();
152  float SCetDiff = SCet - SCetRef;
153  float resolution = -1000;
154  float resolutionPass = -1000;
155  float resolutionHET = -1000;
156  if ( SCetRef > m_thresholdsForResolution) resolution = 100.0*(SCet-SCetRef)/SCetRef;
157  if ( SCpassTime || SCpassPF ) resolutionPass = resolution;
158  if ( SCet > 4e3 ) resolutionHET=resolution;
159 
160  // real monitoring business
161  auto MSCet = Monitored::Scalar<float>("superCellEt",SCet);
162  auto MSCt = Monitored::Scalar<float>("superCelltime",SCt);
163  auto MSCprov = Monitored::Scalar<int>("superCellprovenance",SCprov);
164  auto MSCeta = Monitored::Scalar<float>("superCellEta",SCeta);
165  auto MSCphi = Monitored::Scalar<float>("superCellPhi",SCphi);
166  auto MSCres = Monitored::Scalar<float>("resolution",resolution);
167  auto MSCresPass = Monitored::Scalar<float>("resolutionPass",resolutionPass);
168  auto MSCresHET = Monitored::Scalar<float>("resolutionHET",resolutionHET);
169  auto MSCetRef = Monitored::Scalar<float>("superCellEtRef",SCetRef);
170  auto MSCtRef = Monitored::Scalar<float>("superCelltimeRef",superCellRef->time());
171  auto MSCprovRef = Monitored::Scalar<int>("superCellprovenanceRef",(superCellRef->provenance()&0xFFF));
172  auto MSCetDiff = Monitored::Scalar<float>("superCellEtDiff",SCetDiff);
173  variables.push_back(MSCet);
174  variables.push_back(MSCt);
175  variables.push_back(MSCprov);
176  variables.push_back(MSCeta);
177  if ( SCetRef > m_thresholdsForResolution ) variables.push_back(MSCres);
178  if ( (SCetRef > m_thresholdsForResolution ) && (SCpassTime || SCpassPF ) ) variables.push_back(MSCresPass);
179  if ( (SCetRef > m_thresholdsForResolution ) && (SCet > 4e3 ) ) variables.push_back(MSCresHET);
180  variables.push_back(MSCphi);
181  variables.push_back(MSCetRef);
182  // let us put conditional to force building the linearity plot
183  // only when the new signal passes BCID
184  variables.push_back(MSCtRef);
185  variables.push_back(MSCprovRef);
186  variables.push_back(MSCetDiff);
187 
188  // per layer
189  auto layerName=m_layerNames[iLyr];
190  auto LMSCet = Monitored::Scalar<float>("superCellEt_"+layerName,SCet);
191  auto LMSCt = Monitored::Scalar<float>("superCelltime_"+layerName,SCt);
192  auto LMSCprov = Monitored::Scalar<int>("superCellprovenance_"+layerName,SCprov);
193  auto LMSCeta = Monitored::Scalar<float>("superCellEta_"+layerName,SCeta);
194  auto LMSCphi = Monitored::Scalar<float>("superCellPhi_"+layerName,SCphi);
195  auto LMSCres = Monitored::Scalar<float>("resolution_"+layerName,resolution);
196  auto LMSCresPass = Monitored::Scalar<float>("resolutionPass_"+layerName,resolutionPass);
197  auto LMSCresHET = Monitored::Scalar<float>("resolutionHET_"+layerName,resolutionHET);
198  auto LMSCetRef = Monitored::Scalar<float>("superCellEtRef_"+layerName,SCetRef);
199  auto LMSCtRef = Monitored::Scalar<float>("superCelltimeRef_"+layerName,superCellRef->time());
200  auto LMSCprovRef = Monitored::Scalar<int>("superCellprovenanceRef_"+layerName,(superCellRef->provenance()&0xFFF));
201 
202  auto MBCIDFFB = Monitored::Scalar<int>("BCID",bcidFFB);
203  auto LMSCetDiff = Monitored::Scalar<float>("superCellEtDiff_"+layerName,SCetDiff);
204  variables.push_back(LMSCet);
205  variables.push_back(LMSCt);
206  variables.push_back(LMSCprov);
207  variables.push_back(LMSCeta);
208  if ( SCetRef > m_thresholdsForResolution ) variables.push_back(LMSCres);
209  if ( (SCetRef > m_thresholdsForResolution ) && (SCpassTime || SCpassPF ) ) variables.push_back(LMSCresPass);
210  if ( (SCetRef > m_thresholdsForResolution ) && (SCet > 4e3 ) ) variables.push_back(LMSCresHET);
211  variables.push_back(LMSCphi);
212  variables.push_back(LMSCetRef);
213  if ( SCpassTime || SCpassPF ) variables.push_back(LMSCtRef);
214  variables.push_back(LMSCprovRef);
215  variables.push_back(MBCIDFFB);
216  variables.push_back(LMSCetDiff);
217 
218  auto MSCtReco = Monitored::Scalar<float>("superCelltimeReco",0.);
219  auto MSCetReco = Monitored::Scalar<float>("superCellEtReco",0.);
220  auto LMSCtReco = Monitored::Scalar<float>("superCelltimeReco_"+layerName,0.);
221  if(m_doSCReco){
222  const CaloCell* superCellReco = superCellRecoCont->findCell( SCcaloDDE->identifyHash() );
223  if(superCellReco) {
224  float SCetReco = superCellReco->et();
225  float SCtimeReco = superCellReco->time();
226  MSCtReco = SCtimeReco;
227  MSCetReco = SCetReco;
228  LMSCtReco = SCtimeReco;
229  variables.push_back(MSCtReco);
230  variables.push_back(LMSCtReco);
231  variables.push_back(MSCetReco);
232  }
233  }
235 
236  } // end loop over SC
237 
238 
239 
240 
241  ATH_MSG_DEBUG("LArSuperCellMonAlg::fillLarHists() is done");
242  return StatusCode::SUCCESS;
243 }
244 
245 
247 
248  ATH_MSG_INFO("Creating the once-per-job histograms");
249 
250  if(!noisep){
251  ATH_MSG_ERROR("Do not have DB noise, doing nothing !!!");
252  return StatusCode::SUCCESS;
253  }
254 
255  //The following histograms can be considered constants for one job
256  //(in fact, they are constant for an entire run or even run-periode)
257  //ActiveCells in eta/phi (to normalize 1D occupancy plots)
258  //BadChannel word
259  //Database noise
260 
261  auto doDatabaseNoisePlot = Monitored::Scalar<bool>("doDatabaseNoisePlot",m_doDatabaseNoiseVsEtaPhi);
262 
263  // if(!doDatabaseNoisePlot && !doCellsActiveEtaPlot && !doCellsActivePhiPlot) {
264  if(!doDatabaseNoisePlot) {
265  ATH_MSG_INFO("No once-per-job histogram requested");
266  return StatusCode::SUCCESS;
267  }
268 
269 
270  //filling:
271 
273  CaloCellContainer::const_iterator it_e = cellCont->end();
274  for ( ; it!=it_e;++it) {
275  const CaloCell* cell = *it;
276  Identifier id = cell->ID();
277  bool is_lar=m_calo_id->is_lar(id);
278  if(!is_lar) continue;
279  const CaloDetDescrElement* caloDDEl=cell->caloDDE();
280  float celleta, cellphi;
281  unsigned iLyr, iLyrNS;
282 
283 
284  getHistoCoordinates(caloDDEl, celleta, cellphi, iLyr, iLyrNS);
285 
286  auto mon_eta = Monitored::Scalar<float>("celleta_"+m_layerNames[iLyr],celleta);
287  auto mon_phi = Monitored::Scalar<float>("cellphi_"+m_layerNames[iLyr],cellphi);
288  auto cellnoisedb = Monitored::Scalar<float>("cellnoisedb_"+m_layerNames[iLyr],noisep->getNoise(id,cell->gain()));
289 
290  fill(m_MonGroupName,cellnoisedb,mon_eta,mon_phi);
291 
292 
293  }//end loop over cells
294 
295  return StatusCode::SUCCESS;
296 }
297 
298 
299 
300 std::string LArSuperCellMonAlg::strToLower(const std::string& input) const {
301  std::string output;
302  for (const auto& c : input) {
303  output.push_back(std::tolower(c));
304  }
305  return output;
306 }
307 
308 
309 
310 void LArSuperCellMonAlg::getHistoCoordinates(const CaloDetDescrElement* dde, float& celleta, float& cellphi, unsigned& iLyr, unsigned& iLyrNS) const {
311 
312  celleta=dde->eta_raw();
313  cellphi=dde->phi_raw();
314 
315  int calosample=dde->getSampling();
316  if (dde->is_lar_em_endcap_inner()) calosample-=1; //Here, we consider the two layers of the EMEC IW as EME1 and EME2 instad of layer 2 and 3
317  iLyrNS=m_caloSamplingToLyrNS.at(calosample); //will throw if out of bounds
318  if ((iLyrNS==EMB1NS || iLyrNS==EMB2NS) && m_calo_id->region(dde->identify())==1) {
319  //We are in the awkward region 1 of the EM Barrel
320  //Looking at the image at http://atlas.web.cern.ch/Atlas/GROUPS/LIQARGEXT/TDR/figures6/figure6-17.eps
321  //may be useful to understand what's going on here.
322 
323  //In brief: Region 1, layer 1 is closer related ot the middle compartment (aka layer 2)
324  // and region 1, layer 2 closer related to the back compartment (aka layer 3)
325  iLyrNS+=1;
326 
327  //Layer 2: 0<eta<1.4 + 1.4<eta<1.475, deta = 0.025. 3 rows of cells from region 1
328  //Layer 3: 0<eta<1.35 (deta=0.050) + 1.4<eta<1.475 (deta = 0.075). 1 row of cell from region 1 with different dEta
329  }
330 
331  const unsigned side=(celleta>0) ? 0 : 1; //Value >0 means A-side
332  iLyr=iLyrNS*2+side; //Getting LayerEnum value. This logic works because of the way the enums LayerEnum and LayerEnumNoSides are set up.
333  return;
334 }
335 
336 
python.PyKernel.retrieve
def retrieve(aClass, aKey=None)
Definition: PyKernel.py:110
CaloDetDescrElement::is_lar_em_endcap_inner
bool is_lar_em_endcap_inner() const
cell belongs to the inner wheel of EM end cap
Definition: CaloDetDescrElement.cxx:113
DataModel_detail::const_iterator
Const iterator class for DataVector/DataList.
Definition: DVLIterator.h:82
LArSuperCellMonAlg::m_superCellContainerRefKey
SG::ReadHandleKey< CaloCellContainer > m_superCellContainerRefKey
Definition: LArSuperCellMonAlg.h:55
CaloCell_Base_ID::region
int region(const Identifier id) const
LAr field values (NOT_VALID == invalid request)
ReadCellNoiseFromCool.cell
cell
Definition: ReadCellNoiseFromCool.py:53
checkCoolLatestUpdate.variables
variables
Definition: checkCoolLatestUpdate.py:13
SG::ReadCondHandle
Definition: ReadCondHandle.h:44
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
LArSuperCellMonAlg.h
AtlasDetectorID::is_lar
bool is_lar(Identifier id) const
Definition: AtlasDetectorID.h:689
LArProv::SCPASSBCIDMAX
@ SCPASSBCIDMAX
Definition: LArProvenance.h:25
SG::ReadHandle
Definition: StoreGate/StoreGate/ReadHandle.h:70
CaloDetDescrElement
This class groups all DetDescr information related to a CaloCell. Provides a generic interface for al...
Definition: Calorimeter/CaloDetDescr/CaloDetDescr/CaloDetDescrElement.h:66
LArSuperCellMonAlg::m_doSCReco
BooleanProperty m_doSCReco
Definition: LArSuperCellMonAlg.h:96
skel.it
it
Definition: skel.GENtoEVGEN.py:396
LArSuperCellMonAlg::m_doDatabaseNoiseVsEtaPhi
BooleanProperty m_doDatabaseNoiseVsEtaPhi
Definition: LArSuperCellMonAlg.h:94
SG::VarHandleKey::key
const std::string & key() const
Return the StoreGate ID for the referenced object.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:141
LArSuperCellMonAlg::m_thresholdsForResolution
FloatProperty m_thresholdsForResolution
Definition: LArSuperCellMonAlg.h:110
CaloCell::provenance
uint16_t provenance() const
get provenance (data member)
Definition: CaloCell.h:338
LArSuperCellMonAlg::m_calo_id
const CaloCell_ID * m_calo_id
Definition: LArSuperCellMonAlg.h:143
SG::VarHandleKey::empty
bool empty() const
Test if the key is blank.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:150
LArSuperCellMonAlg::m_layerNames
StringArrayProperty m_layerNames
Definition: LArSuperCellMonAlg.h:83
CaloCell::time
float time() const
get time (data member)
Definition: CaloCell.h:352
CaloNoise::getNoise
float getNoise(const IdentifierHash h, const int gain) const
Accessor by IdentifierHash and gain.
Definition: CaloNoise.h:34
Dedxcorrection::resolution
double resolution[nGasTypes][nParametersResolution]
Definition: TRT_ToT_Corrections.h:46
LArSuperCellMonAlg::m_superCellContainerKey
SG::ReadHandleKey< CaloCellContainer > m_superCellContainerKey
Definition: LArSuperCellMonAlg.h:54
CaloDetDescrManager.h
Definition of CaloDetDescrManager.
CaloDetDescrElement::eta_raw
float eta_raw() const
cell eta_raw
Definition: Calorimeter/CaloDetDescr/CaloDetDescr/CaloDetDescrElement.h:350
CaloCell_ID.h
AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::detStore
const ServiceHandle< StoreGateSvc > & detStore() const
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
Definition: AthCommonDataStore.h:95
TRT::Hit::side
@ side
Definition: HitInfo.h:83
AthMonitorAlgorithm
Base class for Athena Monitoring Algorithms.
Definition: AthMonitorAlgorithm.h:36
LArSuperCellMonAlg::m_bcDataKey
SG::ReadCondHandleKey< BunchCrossingCondData > m_bcDataKey
Property: Bunch crossing data (MC only) (conditions input).
Definition: LArSuperCellMonAlg.h:60
CaloDetDescrElement::identify
Identifier identify() const override final
cell identifier
Definition: CaloDetDescrElement.cxx:63
LArSuperCellMonAlg::m_MonGroupName
Gaudi::Property< std::string > m_MonGroupName
Definition: LArSuperCellMonAlg.h:62
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
CheckAppliedSFs.e3
e3
Definition: CheckAppliedSFs.py:264
LArSuperCellMonAlg::LArSuperCellMonAlg
LArSuperCellMonAlg(const std::string &name, ISvcLocator *pSvcLocator)
Definition: LArSuperCellMonAlg.cxx:31
LArSuperCellMonAlg::~LArSuperCellMonAlg
~LArSuperCellMonAlg()
Definition: LArSuperCellMonAlg.cxx:40
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
LArSuperCellMonAlg::fillHistograms
virtual StatusCode fillHistograms(const EventContext &ctx) const override final
adds event to the monitoring histograms
Definition: LArSuperCellMonAlg.cxx:74
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
CaloCell::caloDDE
const CaloDetDescrElement * caloDDE() const
get pointer to CaloDetDescrElement (data member)
Definition: CaloCell.h:305
tolower
void tolower(std::string &s)
Definition: AthenaSummarySvc.cxx:111
PlotPulseshapeFromCool.input
input
Definition: PlotPulseshapeFromCool.py:106
BunchCrossingCondData::BunchCrossings
@ BunchCrossings
Distance in units of 25 nanoseconds.
Definition: BunchCrossingCondData.h:132
CaloCell::et
virtual double et() const override final
get et
Definition: CaloCell.h:407
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
AthMonitorAlgorithm::fill
void fill(const ToolHandle< GenericMonitoringTool > &groupHandle, std::vector< std::reference_wrapper< Monitored::IMonitoredVariable >> &&variables) const
Fills a vector of variables to a group by reference.
SG::VarHandleKey::initialize
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:103
LArProv::SCTIMEPASS
@ SCTIMEPASS
Definition: LArProvenance.h:30
LArSuperCellMonAlg::EMB1NS
@ EMB1NS
Definition: LArSuperCellMonAlg.h:106
LArSuperCellMonAlg::strToLower
std::string strToLower(const std::string &input) const
Definition: LArSuperCellMonAlg.cxx:300
BunchCrossingCondData::distanceFromFront
int distanceFromFront(const bcid_type bcid, const BunchDistanceType type=NanoSec) const
The distance of the specific bunch crossing from the front of the train.
Definition: BunchCrossingCondData.cxx:38
CaloCellContainer::findCell
const CaloCell * findCell(const IdentifierHash theHash) const
fast find method given identifier hash.
Definition: CaloCellContainer.cxx:345
CaloNoise
Definition: CaloNoise.h:16
merge.output
output
Definition: merge.py:17
LArSuperCellMonAlg::initThresh
StatusCode initThresh()
Definition: LArSuperCellMonAlg.cxx:67
HWIdentifier.h
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
LArProv::test
bool test(const uint16_t prov, const LArProvenance check)
Definition: LArProvenance.h:38
CaloDetDescrElement::identifyHash
IdentifierHash identifyHash() const override final
cell subcalo hash same as subcalo_hash(), but kept for backward compatibility
Definition: Calorimeter/CaloDetDescr/CaloDetDescr/CaloDetDescrElement.h:424
SG::CondHandleKey::initialize
StatusCode initialize(bool used=true)
xAOD::bcid
setEventNumber setTimeStamp bcid
Definition: EventInfo_v1.cxx:133
Units.h
Wrapper to avoid constant divisions when using units.
CaloCellContainer.h
CaloCellContainer
Container class for CaloCell.
Definition: CaloCellContainer.h:55
AthMonitorAlgorithm::initialize
virtual StatusCode initialize() override
initialize
Definition: AthMonitorAlgorithm.cxx:18
DataVector::end
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
CaloCell
Data object for each calorimeter readout cell.
Definition: CaloCell.h:57
CaloDetDescrElement::getSampling
CaloCell_ID::CaloSample getSampling() const
cell sampling
Definition: Calorimeter/CaloDetDescr/CaloDetDescr/CaloDetDescrElement.h:395
LArSuperCellMonAlg::initialize
virtual StatusCode initialize() override final
initialize
Definition: LArSuperCellMonAlg.cxx:44
LArSuperCellMonAlg::m_superCellContainerRecoKey
SG::ReadHandleKey< CaloCellContainer > m_superCellContainerRecoKey
Definition: LArSuperCellMonAlg.h:56
LArSuperCellMonAlg::m_noiseCDOKey
SG::ReadCondHandleKey< CaloNoise > m_noiseCDOKey
Definition: LArSuperCellMonAlg.h:69
LArProvenance.h
LArSuperCellMonAlg::m_removeMasked
BooleanProperty m_removeMasked
Definition: LArSuperCellMonAlg.h:111
LArSuperCellMonAlg::m_caloSamplingToLyrNS
const std::map< unsigned, LayerEnumNoSides > m_caloSamplingToLyrNS
Definition: LArSuperCellMonAlg.h:119
Monitored::Scalar
Declare a monitored scalar variable.
Definition: MonitoredScalar.h:34
xAOD::lumiBlock
setTeId lumiBlock
Definition: L2StandAloneMuon_v1.cxx:327
CaloGain.h
SG::AllowEmpty
@ AllowEmpty
Definition: StoreGate/StoreGate/VarHandleKey.h:30
LArSuperCellMonAlg::getHistoCoordinates
void getHistoCoordinates(const CaloDetDescrElement *dde, float &celleta, float &cellphi, unsigned &iLyr, unsigned &iLyrNS) const
Definition: LArSuperCellMonAlg.cxx:310
LArSuperCellMonAlg::EMB2NS
@ EMB2NS
Definition: LArSuperCellMonAlg.h:106
python.compressB64.c
def c
Definition: compressB64.py:93
DataVector::begin
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
CaloDetDescrElement::phi_raw
float phi_raw() const
cell phi_raw
Definition: Calorimeter/CaloDetDescr/CaloDetDescr/CaloDetDescrElement.h:352
LArSuperCellMonAlg::createPerJobHistograms
StatusCode createPerJobHistograms(const CaloCellContainer *cellcont, const CaloNoise *noisep) const
Definition: LArSuperCellMonAlg.cxx:246
Identifier
Definition: IdentifierFieldParser.cxx:14