ATLAS Offline Software
MuonCalibDbCalibrationSource.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2017 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 // this
7 
13 
14 // coral
15 #include "CoralBase/Attribute.h"
16 #include "CoralBase/AttributeList.h"
17 
18 // MuonCalibIdentifier//MuonCalibIdentifier
21 
22 // MuonCalibMath
23 #include "GaudiKernel/IMessageSvc.h"
24 #include "GaudiKernel/MsgStream.h"
26 // MuonCalibStandALoneBase
29 // c - c++
30 #include "exception"
31 #include "iostream"
32 #include "sstream"
33 
34 namespace MuonCalib {
36  MuonCalibDbCalibrationSource::MuonCalibDbCalibrationSource(const std::string& t, const std::string& n, const IInterface* p) :
38  declareInterface<IMuonCalibConditionsSource>(this);
39  declareProperty("SiteName", m_site_name);
40  declareProperty("HeadId", m_head_id);
41  declareProperty("ConnectionString", m_calib_connection_string);
42  declareProperty("WorkingSchema", m_calib_working_schema);
43  declareProperty("UserName", m_username);
44  declareProperty("Password", m_password);
45  declareProperty("Region", m_region_str);
46  m_mdt_tube_cols.push_back(std::string("TUBE_ID"));
47  m_mdt_tube_cols.push_back(std::string("P4"));
48  m_mdt_tube_cols.push_back(std::string("VALIDFLAG"));
49  m_mdt_tube_cols.push_back(std::string("ADC_1"));
50  m_store_t0 = true;
51  m_store_rt = true;
52  declareProperty("StoreT0", m_store_t0);
53  declareProperty("StoreRT", m_store_rt);
54  m_t0_offset = 0.0;
55  declareProperty("DriftTimeOffsetsVsR", m_drift_time_offsets);
56  declareProperty("T0Offset", m_t0_offset);
57  m_time_slewing_applied = false;
58  declareProperty("TimeSlewingApplied", m_time_slewing_applied);
60  declareProperty("BFieldCorrectionApplied", m_b_field_correction_applied);
61  m_creation_flags = 0;
62  }
63 
65  // process region
67  if (!m_region) {
68  ATH_MSG_FATAL("Error initializing RegionSelectorBase::GetRegion with region string: '" << m_region_str);
69  return StatusCode::FAILURE;
70  }
71  // open conneciton to calibration db
72  m_connection = std::make_unique<CalibDbConnection>(m_calib_connection_string, m_calib_working_schema);
74  if (!m_connection->OpenConnection()) {
75  ATH_MSG_FATAL("Cannot open connection to calibration database!");
76  return StatusCode::FAILURE;
77  }
78  m_head_ops = std::make_unique<CalibHeadOperations>(*m_connection);
79  int lowrun, uprun, lowtime, uptime;
80  if (!m_head_ops->GetHeadInfo(m_head_id, lowrun, uprun, lowtime, uptime)) {
81  ATH_MSG_FATAL("Cannot get header " << m_head_id << "from calib datbase");
82  return StatusCode::FAILURE;
83  }
85  m_iov_end = uprun;
86  m_iov_end++;
87  m_data_connection.reset(m_head_ops->GetDataConnection(m_head_id, false));
88  if (!m_data_connection) {
89  ATH_MSG_FATAL("Cannot open data connection!");
90  return StatusCode::FAILURE;
91  }
92  if (!m_data_connection->OpenConnection()) {
93  ATH_MSG_FATAL("Cannot open data connection!");
94  return StatusCode::FAILURE;
95  }
96  m_creation_flags = 0;
99  return StatusCode::SUCCESS;
100  }
101 
102  bool MuonCalibDbCalibrationSource::StoreT0Chamber(const int& chamber, const std::map<TubeId, coral::AttributeList>& rows) {
104  if (!m_region->Result(id)) { return true; }
105  NtupleStationId sid(id);
106  sid.SetMultilayer(0);
107  std::string data_string;
108  std::ostringstream f;
109  f << chamber << m_site_name << m_head_id;
110  if (!m_inserter->StartT0Chamber(sid)) {
111  ATH_MSG_WARNING("Cannot insert chamber " << chamber);
112  return true;
113  }
114  for (const auto & row : rows) {
115  if (!m_inserter->AppendT0(row.second["P4"].data<float>() + m_t0_offset, row.second["VALIDFLAG"].data<short>(),
116  row.second["ADC_1"].data<float>())) {
117  ATH_MSG_WARNING("Wrong number of tubes in database for " << sid.regionId() << "!");
118  break;
119  }
120  }
122  return true;
123  }
124 
125  bool MuonCalibDbCalibrationSource::StoreRtChamber(const int& chamber, const std::map<int, SamplePoint>& points) {
127  if (!m_region->Result(id)) { return true; }
128  NtupleStationId sid(id);
129  sid.SetMultilayer(0);
130  std::ostringstream f;
131  f << chamber << m_site_name << m_head_id;
132  if (m_drift_time_offsets.size()) {
133  float slice_width = 14.6 / static_cast<float>(m_drift_time_offsets.size());
134  std::map<int, SamplePoint> points_cp(points);
135  for (auto & it : points_cp) {
136  int slice_number = static_cast<int>(std::floor(it.second.x2() / slice_width));
137  if (slice_number < 0) slice_number = 0;
138  if (slice_number >= static_cast<int>(m_drift_time_offsets.size()))
139  slice_number = static_cast<int>(m_drift_time_offsets.size()) - 1;
140  it.second.set_x1(it.second.x1() + m_drift_time_offsets[slice_number]);
141  }
142  m_inserter->StoreRtChamber(sid, points_cp, f.str(), m_creation_flags);
143  } else {
145  }
146  return true;
147  }
148 
149  bool MuonCalibDbCalibrationSource::insert_calibration(bool store_t0, bool store_rt) {
150  try {
151  if (store_t0 && m_store_t0) {
153  if (!t0_op.ReadForConditions(m_site_name, m_head_id, *this)) {
154  ATH_MSG_WARNING("T0 insert failed!");
155  return false;
156  }
157  }
158  if (store_rt && m_store_rt) {
160  if (!rt_op.ReadForConditions(m_site_name, m_head_id, *this)) {
161  ATH_MSG_WARNING("RT insert failed!");
162  return false;
163  }
164  }
165  } // try
166  catch (const std::exception& e) {
167  ATH_MSG_FATAL("Exception: " << e.what());
168  return false;
169  }
170  return true;
171  }
172 
173 } // namespace MuonCalib
CalibDbConnection.h
MuonCalib::MuonCalibDbCalibrationSource::m_calib_connection_string
std::string m_calib_connection_string
Definition: MuonCalibDbCalibrationSource.h:53
AllowedVariables::e
e
Definition: AsgElectronSelectorTool.cxx:37
query_example.row
row
Definition: query_example.py:24
MuonCalib::MuonCalibDbCalibrationSource::m_head_id
int m_head_id
Definition: MuonCalibDbCalibrationSource.h:49
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
MuonCalib::MuonCalibDbCalibrationSource::m_region
std::unique_ptr< RegionSelectorBase > m_region
Definition: MuonCalibDbCalibrationSource.h:73
MuonCalib::NtupleStationId::SetMultilayer
void SetMultilayer(const int &ml)
Definition: NtupleStationId.h:110
MuonCalib::MuonCalibDbCalibrationSource::MuonCalibDbCalibrationSource
MuonCalibDbCalibrationSource(const std::string &t, const std::string &n, const IInterface *p)
constructor
Definition: MuonCalibDbCalibrationSource.cxx:36
MuonCalib::MuonCalibDbCalibrationSource::StoreT0Chamber
bool StoreT0Chamber(const int &chamber, const std::map< TubeId, coral::AttributeList > &rows)
call back for t0
Definition: MuonCalibDbCalibrationSource.cxx:102
MuonCalib::NtupleStationId::regionId
std::string regionId() const
return the region id string
Definition: NtupleStationId.cxx:69
MuonCalib::RegionSelectorBase::GetRegion
static std::unique_ptr< RegionSelectorBase > GetRegion(const std::string &input)
create a region from a string
Definition: RegionSelectorBase.cxx:13
MuonCalib::MuonCalibDbCalibrationSource::m_iov_end
int m_iov_end
Definition: MuonCalibDbCalibrationSource.h:51
MuonCalib::MuonCalibDbCalibrationSource::initialize
StatusCode initialize()
initialize
Definition: MuonCalibDbCalibrationSource.cxx:64
calibdata.chamber
chamber
Definition: calibdata.py:32
MuonCalib::MuonCalibDbCalibrationSource::m_mdt_tube_cols
std::vector< std::string > m_mdt_tube_cols
Definition: MuonCalibDbCalibrationSource.h:69
AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T > &t)
Definition: AthCommonDataStore.h:145
MuonCalib::NtupleStationId
Definition: NtupleStationId.h:36
MuonCalib::IMuonCalibConditionsSource::m_inserter
CoolInserter * m_inserter
Definition: IMuonCalibConditionsSource.h:31
skel.it
it
Definition: skel.GENtoEVGEN.py:396
calibdata.uptime
uptime
Definition: calibdata.py:36
MuonCalib::MuonCalibDbCalibrationSource::StoreRtChamber
bool StoreRtChamber(const int &chamber, const std::map< int, SamplePoint > &points)
Definition: MuonCalibDbCalibrationSource.cxx:125
CalibT0DbOperations.h
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
MuonCalib::MuonCalibDbCalibrationSource::m_time_slewing_applied
bool m_time_slewing_applied
Definition: MuonCalibDbCalibrationSource.h:65
MuonCalib::CoolInserter::StoreT0Chamber
bool StoreT0Chamber(const NtupleStationId &id, const std::string &file, unsigned int creation_flags=0)
Definition: CoolInserter.cxx:193
NtupleStationId.h
MuonCalib::CalibRtDbOperations::ReadForConditions
bool ReadForConditions(const std::string &, int head_id, IConditionsStorage &storage)
Definition: CalibRtDbOperations.cxx:157
MuonCalib::MuonCalibDbCalibrationSource::m_iov_start
int m_iov_start
Definition: MuonCalibDbCalibrationSource.h:51
MuonCalib::MuonCalibDbCalibrationSource::m_username
std::string m_username
Definition: MuonCalibDbCalibrationSource.h:55
MuonCalib::MuonCalibDbCalibrationSource::m_store_rt
bool m_store_rt
Definition: MuonCalibDbCalibrationSource.h:61
MuonCalibDbCalibrationSource.h
MuonCalib::CoolInserter::AppendT0
bool AppendT0(float t0, int validflag, float adc0)
Definition: CoolInserter.cxx:184
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
MuonCalib::CalibT0DbOperations
Definition: CalibT0DbOperations.h:29
beamspotman.n
n
Definition: beamspotman.py:731
MuonCalib::IConditionsStorage
Definition: IConditionsStorage.h:21
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
calibdata.uprun
uprun
Definition: calibdata.py:34
MuonCalib::MuonCalibDbCalibrationSource::m_drift_time_offsets
std::vector< float > m_drift_time_offsets
Definition: MuonCalibDbCalibrationSource.h:59
calibdata.exception
exception
Definition: calibdata.py:496
MuonCalib::MuonCalibDbCalibrationSource::m_calib_working_schema
std::string m_calib_working_schema
Definition: MuonCalibDbCalibrationSource.h:53
MuonCalib
CscCalcPed - algorithm that finds the Cathode Strip Chamber pedestals from an RDO.
Definition: CscCalcPed.cxx:22
MuonCalib::MuonCalibDbCalibrationSource::m_password
std::string m_password
Definition: MuonCalibDbCalibrationSource.h:55
CoolInserter.h
hist_file_dump.f
f
Definition: hist_file_dump.py:135
MuonCalib::MuonCalibDbCalibrationSource::m_b_field_correction_applied
bool m_b_field_correction_applied
Definition: MuonCalibDbCalibrationSource.h:65
MuonCalib::MuonCalibDbCalibrationSource::m_region_str
std::string m_region_str
Definition: MuonCalibDbCalibrationSource.h:57
beamspotnt.rows
list rows
Definition: bin/beamspotnt.py:1112
MuonCalib::B_FIELD_CORRECTIONS_APPLIED
@ B_FIELD_CORRECTIONS_APPLIED
Definition: MdtCalibCreationFlags.h:10
MuonCalib::CalibRtDbOperations
Definition: CalibRtDbOperations.h:25
MuonCalib::CalibT0DbOperations::ReadForConditions
bool ReadForConditions(const std::string &site_name, int head_id, IConditionsStorage &storage)
Definition: CalibT0DbOperations.cxx:301
MuonCalib::MuonCalibDbCalibrationSource::~MuonCalibDbCalibrationSource
virtual ~MuonCalibDbCalibrationSource()
MuonCalib::TIME_SLEWING_CORRECTION_APPLIED
@ TIME_SLEWING_CORRECTION_APPLIED
Definition: MdtCalibCreationFlags.h:10
id
SG::auxid_t id
Definition: Control/AthContainers/Root/debug.cxx:227
MuonCalib::MuonCalibDbCalibrationSource::m_store_t0
bool m_store_t0
Definition: MuonCalibDbCalibrationSource.h:61
MuonCalib::MuonFixedId
Definition: MuonFixedId.h:50
MuonCalib::MuonCalibDbCalibrationSource::m_data_connection
std::unique_ptr< CalibDbConnection > m_data_connection
Definition: MuonCalibDbCalibrationSource.h:71
MuonCalib::MuonCalibDbCalibrationSource::m_creation_flags
unsigned int m_creation_flags
Definition: MuonCalibDbCalibrationSource.h:66
MuonCalib::MuonCalibDbCalibrationSource::m_connection
std::unique_ptr< CalibDbConnection > m_connection
Definition: MuonCalibDbCalibrationSource.h:70
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
calibdata.lowrun
lowrun
Definition: calibdata.py:33
CalibRtDbOperations.h
RegionSelectorBase.h
MuonCalib::MuonCalibDbCalibrationSource::m_t0_offset
float m_t0_offset
Definition: MuonCalibDbCalibrationSource.h:63
MuonCalib::IMuonCalibConditionsSource
Definition: IMuonCalibConditionsSource.h:17
MdtCalibCreationFlags.h
SamplePoint.h
MuonCalib::MuonCalibDbCalibrationSource::m_site_name
std::string m_site_name
Definition: MuonCalibDbCalibrationSource.h:48
AthAlgTool
Definition: AthAlgTool.h:26
MuonCalib::MuonCalibDbCalibrationSource::insert_calibration
bool insert_calibration(bool store_t0, bool store_rt)
insert calibration
Definition: MuonCalibDbCalibrationSource.cxx:149
MuonCalib::CoolInserter::StoreRtChamber
bool StoreRtChamber(const NtupleStationId &id, const std::map< int, SamplePoint > &points, const std::string &file, unsigned int creation_flags=0)
Definition: CoolInserter.cxx:250
MuonFixedId.h
MuonCalib::CoolInserter::StartT0Chamber
bool StartT0Chamber(const NtupleStationId &sid)
Definition: CoolInserter.cxx:155
jobOptions.points
points
Definition: jobOptions.GenevaPy8_Zmumu.py:97
CalibHeadOperations.h
MuonCalib::MuonCalibDbCalibrationSource::m_head_ops
std::unique_ptr< CalibHeadOperations > m_head_ops
Definition: MuonCalibDbCalibrationSource.h:72
calibdata.lowtime
lowtime
Definition: calibdata.py:35