Loading [MathJax]/extensions/tex2jax.js
 |
ATLAS Offline Software
|
Go to the documentation of this file.
44 m_triggerTowerContainerName(
LVL1::TrigT1CaloDefs::xAODTriggerTowerLocation),
45 m_outputFolderName(
"/L1CaloRampMaker/L1CaloRampDataContainer"),
46 m_gainStrategyFolder(
"/TRIGGER/Receivers/Conditions/Strategy"),
52 m_isFcalLowEta(false),
53 m_isFcalHighEta(false),
54 m_checkProvenance(false),
55 m_nEventsPerStep(200),
57 m_fadcSaturationCut(963),
58 m_tileSaturationCut(150.),
59 m_ttTool(
"LVL1::L1TriggerTowerToolRun3/L1TriggerTowerToolRun3"),
60 m_xAODTTTools(
"LVL1::L1CaloxAODOfflineTriggerTowerTools/L1CaloxAODOfflineTriggerTowerTools", this),
61 m_jmTools(
"LVL1::L1CaloOfflineTriggerTowerTools/L1CaloOfflineTriggerTowerTools", this),
64 m_lvl1Helper(nullptr),
65 m_rampDataContainer(nullptr)
101 return StatusCode::FAILURE;
113 return StatusCode::SUCCESS;
123 <<
" events, skipping the rest" );
126 return StatusCode::SUCCESS;
131 if (eventInfo->eventNumber() == 0 &&
m_nEvent > 1) {
134 return StatusCode::SUCCESS;
139 if(!
sc.isSuccess()) {
142 return StatusCode::RECOVERABLE;
146 const EventContext& ctx = getContext();
150 const unsigned evt=ctx.eventID().event_number();
165 unsigned int runNumber = eventInfo->runNumber();
166 std::string gainStrategy(
"");
172 bool consistent(
true);
173 for (; itr != itrE; ++itr) {
174 const unsigned int channel = itr->first;
177 const std::string
strategy(attrList[
"name"].data<std::string>());
178 const std::string
status(attrList[
"status"].data<std::string>());
181 <<
", status = " <<
status );
182 if (gainStrategy ==
"") gainStrategy =
strategy;
183 else if (gainStrategy !=
strategy) consistent =
false;
185 std::string newStrategy(
"");
186 if (
runNumber == 219978) newStrategy =
"GainOneOvEmecFcalLowEta";
187 if (
runNumber == 219979) newStrategy =
"GainOneOvEmbFcalHighEta";
188 if (
runNumber == 219980) newStrategy =
"CalibGainsEt";
189 if (
runNumber == 220013) newStrategy =
"GainOneOvEmecFcalLowEta";
190 if (
runNumber == 220014) newStrategy =
"GainOneOvEmbFcalHighEta";
191 if (
runNumber == 220015) newStrategy =
"CalibGainsEt";
192 if (
runNumber == 222871) newStrategy =
"GainOne";
193 if (
runNumber == 222872) newStrategy =
"GainOne";
194 if (
runNumber == 222873) newStrategy =
"GainOne";
195 if (
runNumber == 223073) newStrategy =
"GainOne";
196 if (
runNumber == 223074) newStrategy =
"GainOne";
197 if (
runNumber == 223075) newStrategy =
"GainOne";
198 if (newStrategy !=
"") {
199 ATH_MSG_INFO(
"Changing Gain Strategy to " << newStrategy);
200 gainStrategy = newStrategy;
202 if (gainStrategy !=
"" && consistent) {
203 m_isGain1 = (gainStrategy.find(
"GainOne") != std::string::npos);
204 m_isOvEmb = (gainStrategy.find(
"OvEmb") != std::string::npos);
205 m_isOvEmec = (gainStrategy.find(
"OvEmec") != std::string::npos);
206 m_isFcalLowEta = (gainStrategy.find(
"FcalLowEta") != std::string::npos);
207 m_isFcalHighEta = (gainStrategy.find(
"FcalHighEta") != std::string::npos);
208 }
else if (gainStrategy ==
"") {
239 for(
auto *
tt : *tts) {
241 if(
tt->isJepSaturated())
continue;
244 auto max = std::max_element(
tt->adc().begin(),
tt->adc().end());
250 if(
m_ttTool->disabledChannel(
tt->coolId()))
continue;
266 if(specialChannelIt == specialChannelRangeEnd || level1Energy < specialChannelIt->
second) {
267 ATH_MSG_DEBUG(
"Adding Energy for " <<
tt->coolId() <<
":" << caloEnergy <<
" vs. " << level1Energy);
271 specialChannelIt->second = -1000;
279 return StatusCode::SUCCESS;
291 for(
auto*
tt: *tts) {
303 auto id =
m_ttTool->identifier(
tt->eta(),
tt->phi(),
tt->sampling());
306 if(
tt->sampling() == 0) {
311 std::vector<float> etRec =
m_jmTools->hadTTCellsEtByReceiver(&T);
312 if (etRec.size() == 2) {
315 else et = etRec[0] + etRec[1];
316 }
else if (etRec.size() == 1)
et = etRec[0];
322 std::vector<float> energyRec =
m_jmTools->emTTCellsEnergyByReceiver(&T);
323 if (energyRec.size() == 2) {
326 else energy = energyRec[1];
328 }
else et = energyRec[0] / std::cosh(
tt->eta());
330 et = ttCellsEnergy(*
tt) / std::cosh(
tt->eta());
340 auto max = std::max_element(
tt->adc().begin(),
tt->adc().end());
344 << std::hex <<
tt->coolId() << std::dec <<
"!");
358 auto id =
m_ttTool->identifier(
tt->eta(),
tt->phi(),
tt->sampling());
361 if(fabs(
tt->eta()) > 2.5) {
363 }
else if(fabs(
tt->eta()) > 1.9) {
384 (
cell->time()*oneOverNCells))));
387 if(!(
cell->provenance() & 0x100)) {
388 it->second.first += 1;
390 it->second.second += (
cell->time()*oneOverNCells);
399 std::ofstream bad_ofciter(
"bad-ofciter.txt");
402 bad_ofciter <<
"0x" << std::hex <<
it->first <<
" "
409 return StatusCode::SUCCESS;
def retrieve(aClass, aKey=None)
const_iterator end() const
Extra patterns decribing particle interation process.
SG::ReadCondHandleKey< CondAttrListCollection > m_strategy
This file defines the class for a collection of AttributeLists where each one is associated with a ch...
bool is_fcal(const Identifier id) const
Test wether given tower or layer is part of the FCAL.
const CaloLVL1_ID * m_lvl1Helper
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T > &t)
const_iterator begin() const
Access to Chan/AttributeList pairs via iterators.
virtual ~L1CaloRampMaker()
bool is_barrel_end(const Identifier id) const
Test wether given tower or layer is part of the EM barrel END.
Helper class to provide constant type-safe access to aux data.
std::map< unsigned int, std::pair< unsigned int, double > > m_mapBadOFCIteration
This class is a collection of AttributeLists where each one is associated with a channel number....
eFexTowerBuilder creates xAOD::eFexTowerContainer from supercells (LATOME) and triggerTowers (TREX) i...
const ServiceHandle< StoreGateSvc > & detStore() const
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
bool is_hec(const Identifier id) const
Test wether given tower or layer is part of the HEC.
void checkProvenance(const xAOD::TriggerTower *tt)
std::map< int, int > m_specialChannelRange
ServiceHandle< StoreGateSvc > & evtStore()
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
SG::ReadCondHandleKey< L1CaloPprDisabledChannelContainerRun2 > m_pprDisabledChannelContainer
This class initializes the Calo (LAr and Tile) offline identifiers.
SG::ReadHandleKey< CaloCellContainer > m_caloCellsKey
double m_tileSaturationCut
::StatusCode StatusCode
StatusCode definition for legacy code.
L1CaloRampMaker(const std::string &name, ISvcLocator *pSvcLocator)
Description of TriggerTower_v2.
const CaloLVL1_ID * getLVL1_ID(void) const
#define CHECK(...)
Evaluate an expression and check for errors.
Container of L1CaloRampData objects.
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
double getTriggerTowerEnergy(const xAOD::TriggerTower *tt, SG::ReadCondHandle< L1CaloPprChanCalibContainer > pprCond)
ToolHandle< LVL1::IL1TriggerTowerToolRun3 > m_ttTool
SG::ReadCondHandleKey< L1CaloPprChanCalibContainer > m_pprChanCalibContainer
Trigger towers are the inputs to all other parts of the calorimeter trigger.
Helpers for checking error return status codes and reporting errors.
StatusCode initialize(bool used=true)
std::string m_outputFolderName
Container class for CaloCell.
std::string m_gainStrategyFolder
Class describing the basic event information.
const L1CaloPprChanCalib * pprChanCalib(unsigned int channelId) const
void setupRampDataContainer(const xAOD::TriggerTowerContainer *triggerTowerContainer)
std::unique_ptr< L1CaloRampDataContainer > m_rampDataContainer
#define ATH_MSG_WARNING(x)
ChanAttrListMap::const_iterator const_iterator
unsigned int pedValue() const
SG::ReadCondHandleKey< LArOnOffIdMapping > m_cablingKey
ToolHandle< LVL1::IL1CaloxAODOfflineTriggerTowerTools > m_xAODTTTools
virtual unsigned int ttKey(const TriggerTower &tower)
returns the key of the passed tower
unsigned int m_nEventsPerStep
bool is_tile(const Identifier id) const
Test wether given tower or layer is part of the Tile Calorimeter.
ToolHandle< LVL1::IL1CaloOfflineTriggerTowerTools > m_jmTools
double getCaloEnergy(const xAOD::TriggerTower *tt)
Transient class to store the RampData calculated from calibration runs.
The TriggerTowerKey object provides the key for each trigger tower depending on its eta-phi coords.
std::string m_triggerTowerContainerName