ATLAS Offline Software
SiLocAlignDBTool.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 
7 
8 namespace AFP
9 {
10  SiLocAlignDBTool::SiLocAlignDBTool(const std::string& type, const std::string& name, const IInterface* parent) :
11  base_class(type, name, parent)
12  {
13  }
14 
15 
17  {
19  ATH_MSG_DEBUG( "using DB with key " << m_rch_loc.fullKey() );
20  return StatusCode::SUCCESS;
21  }
22 
24  {
25  ATH_MSG_DEBUG("in the finalize of SiLocAlignDBTool, bye bye");
26  return StatusCode::SUCCESS;
27  }
28 
29 
30  nlohmann::json SiLocAlignDBTool::alignmentData(const EventContext& ctx) const
31  {
32  ATH_MSG_DEBUG("will get local alignment for run "<<ctx.eventID().run_number()<<", lb "<<ctx.eventID().lumi_block()<<", event "<<ctx.eventID().event_number());
33 
35  const CondAttrListCollection* attrLocList { *ch_loc};
36  if ( attrLocList == nullptr )
37  {
38  ATH_MSG_WARNING("local alignment data for key " << m_rch_loc.fullKey() << " not found, returning empty string");
39  return nlohmann::json::parse("");
40  }
41 
42  if(attrLocList->size()>1) ATH_MSG_INFO("there should be only one real channel in "<< m_rch_loc.fullKey() <<", there are "<<attrLocList->size()<<" real channels, only the first one will be used ");
43 
44  CondAttrListCollection::const_iterator itr = attrLocList->begin();
45  const coral::AttributeList &atr = itr->second;
46  std::string data = *(static_cast<const std::string *>((atr["data"]).addressOfData()));
47 
49  }
50 
51 
52  const SiLocAlignData SiLocAlignDBTool::alignment(const nlohmann::json& jsondata, const int stationID, const int layerID) const
53  {
54  ATH_MSG_DEBUG("will get local alignment for station "<<stationID<<", layerID "<<layerID);
55  nlohmann::json channeldata=jsondata["data"];
56 
57  // first, try to guess the channel nr.
58  int guess_ch=stationID*4+layerID;
59 
60  nlohmann::json aligndata=channeldata.at(std::to_string(guess_ch)); // because using int would be too simple
61  int st=aligndata["stationID"];
62  int la=aligndata["layerID"];
63  if(stationID==st && layerID==la)
64  {
65  ATH_MSG_DEBUG("channel guessed correctly, stationID "<<st<<", layerId "<<la<<", channel guess "<<guess_ch);
66  return SiLocAlignData(st, la, aligndata["shiftX"], aligndata["shiftY"], aligndata["shiftZ"], aligndata["alpha"], aligndata["beta"], aligndata["gamma"]);
67  }
68  else
69  {
70  ATH_MSG_DEBUG("channel was not guessed correctly, stationID "<<st<<", layerId "<<la<<", channel guess "<<guess_ch);
71  }
72 
73  // if guess is not correct, loop over all channels
74  for(auto& chan : channeldata.items())
75  {
76  // channels are ordered alphabetically: 0,1,10,...,15,2,3,...,9
77  nlohmann::json aligndata=chan.value();
78 
79  int st=aligndata["stationID"];
80  int la=aligndata["layerID"];
81 
82  if(stationID==st && layerID==la)
83  {
84  ATH_MSG_DEBUG("channel found for stationID "<<st<<", layerId "<<la<<", channel nr. "<<chan.key());
85  return SiLocAlignData(st, la, aligndata["shiftX"], aligndata["shiftY"], aligndata["shiftZ"], aligndata["alpha"], aligndata["beta"], aligndata["gamma"]);
86  }
87  }
88 
89  ATH_MSG_WARNING("local alignment data stationID "<<stationID<<", layerId "<<layerID<<" not found in any channels, returning zeros");
90  return SiLocAlignData(stationID,layerID);
91  }
92 
93 } // AFP namespace
data
char data[hepevt_bytes_allocation_ATLAS]
Definition: HepEvt.cxx:11
SG::ReadCondHandle
Definition: ReadCondHandle.h:44
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
json
nlohmann::json json
Definition: HistogramDef.cxx:9
AFP::SiLocAlignDBTool::finalize
virtual StatusCode finalize() override
Does nothing.
Definition: SiLocAlignDBTool.cxx:23
parse
std::map< std::string, std::string > parse(const std::string &list)
Definition: egammaLayerRecalibTool.cxx:1054
python.PyKernel.AttributeList
AttributeList
Definition: PyKernel.py:36
CondAttrListCollection
This class is a collection of AttributeLists where each one is associated with a channel number....
Definition: CondAttrListCollection.h:52
AFP
Header file for interface of SiGlobAlignDBTool used to read global alignment for database.
Definition: ISiGlobAlignDBTool.h:18
ReadCellNoiseFromCool.chan
chan
Definition: ReadCellNoiseFromCool.py:52
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
test_pyathena.parent
parent
Definition: test_pyathena.py:15
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
AFP::SiLocAlignDBTool::alignmentData
nlohmann::json alignmentData(const EventContext &ctx) const override
Provide alignment parameters for a given plane. Returns zeros if no data available.
Definition: SiLocAlignDBTool.cxx:30
SiLocAlignDBTool.h
Header file for SiLocAlignDBTool used to read local alignment for database.
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:221
ActsTrk::to_string
std::string to_string(const DetectorType &type)
Definition: GeometryDefs.h:34
SG::CondHandleKey::initialize
StatusCode initialize(bool used=true)
AFP::SiLocAlignDBTool::initialize
virtual StatusCode initialize() override
Does nothing.
Definition: SiLocAlignDBTool.cxx:16
AFP::SiLocAlignData
Class storing information about alignment.
Definition: SiLocAlignData.h:24
AFP::SiLocAlignDBTool::alignment
const SiLocAlignData alignment(const nlohmann::json &jsondata, const int stationID, const int planeID) const override
Definition: SiLocAlignDBTool.cxx:52
AFP::SiLocAlignDBTool::SiLocAlignDBTool
SiLocAlignDBTool(const std::string &type, const std::string &name, const IInterface *parent)
Definition: SiLocAlignDBTool.cxx:10
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
CondAttrListCollection::const_iterator
ChanAttrListMap::const_iterator const_iterator
Definition: CondAttrListCollection.h:63
python.CaloScaleNoiseConfig.type
type
Definition: CaloScaleNoiseConfig.py:78
AFP::SiLocAlignDBTool::m_rch_loc
SG::ReadCondHandleKey< CondAttrListCollection > m_rch_loc
Definition: SiLocAlignDBTool.h:52