LArSoft  v10_04_05
Liquid Argon Software toolkit - https://larsoft.org/
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
lariov::DetPedestalRetrievalAlg Class Reference

Retrieves channel information: pedestal and RMS. More...

#include "DetPedestalRetrievalAlg.h"

Inheritance diagram for lariov::DetPedestalRetrievalAlg:
lariov::DatabaseRetrievalAlg

Public Member Functions

 DetPedestalRetrievalAlg (const std::string &foldername, const std::string &url, const std::string &tag="")
 Constructors. More...
 
 DetPedestalRetrievalAlg (fhicl::ParameterSet const &p)
 
void Reconfigure (fhicl::ParameterSet const &p) override
 Reconfigure function called by fhicl constructor. More...
 
void UpdateTimeStamp (DBTimeStamp_t ts)
 Update event time stamp. More...
 
bool Update (DBTimeStamp_t ts)
 Update Snapshot and inherited DBFolder if using database. Return true if updated. More...
 
const DetPedestalPedestal (DBChannelID_t ch) const
 Retrieve pedestal information. More...
 
float PedMean (DBChannelID_t ch) const override
 
float PedRms (DBChannelID_t ch) const override
 
float PedMeanErr (DBChannelID_t ch) const override
 
float PedRmsErr (DBChannelID_t ch) const override
 
bool UpdateFolder (DBTimeStamp_t ts)
 Return true if fFolder is successfully updated. More...
 
const std::string & URL () const
 Get connection information. More...
 
const std::string & FolderName () const
 
const std::string & Tag () const
 
const IOVTimeStampBegin () const
 Get Timestamp information. More...
 
const IOVTimeStampEnd () const
 

Static Public Attributes

static constexpr unsigned int NCOLUMNS = 5
 
static constexpr const char * FIELD_NAMES [NCOLUMNS]
 
static constexpr const char * FIELD_TYPES [NCOLUMNS]
 

Protected Attributes

std::unique_ptr< DBFolderfFolder
 

Private Member Functions

bool DBUpdate () const
 Do actual database updates. More...
 
bool DBUpdate (DBTimeStamp_t ts) const
 

Private Attributes

DBTimeStamp_t fEventTimeStamp
 
DBTimeStamp_t fCurrentTimeStamp
 
DataSource::ds fDataSource
 
Snapshot< DetPedestalfData
 

Detailed Description

Retrieves channel information: pedestal and RMS.

Configuration parameters

  • DatabaseRetrievalAlg (parameter set, mandatory): configuration for the database; see lariov::DatabaseRetrievalAlg
  • UseDB (boolean, default: false): retrieve information from the database
  • UseFile (boolean, default: false): retrieve information from a file; not implemented yet
  • DefaultCollMean (real, default: 400.0): pedestal value returned for collection plane channels when /UseDB/ and /UseFile/ parameters are false
  • DefaultIndMean (real, default: 2048.0): pedestal value returned for induction plane channels when /UseDB/ and /UseFile/ parameters are false
  • DefaultCollRms (real, default: 0.3): pedestal RMS value returned for collection plane channels when /UseDB/ and /UseFile/ parameters are false
  • DefaultIndRms (real, default: 0.3): pedestal RMS value returned for induction plane channels when /UseDB/ and /UseFile/ parameters are false
  • DefaultMeanErr (real, default: 0.0): error on the pedestal value for all channels returned when /UseDB/ and /UseFile/ parameters are false
  • DefaultRmsErr (real, default: 0.0): error on the RMS value for all channels returned when /UseDB/ and /UseFile/ parameters are false

Definition at line 58 of file DetPedestalRetrievalAlg.h.

Constructor & Destructor Documentation

lariov::DetPedestalRetrievalAlg::DetPedestalRetrievalAlg ( const std::string &  foldername,
const std::string &  url,
const std::string &  tag = "" 
)

Constructors.

Definition at line 22 of file DetPedestalRetrievalAlg.cxx.

References fData, lariov::IOVTimeStamp::MaxTimeStamp(), lariov::IOVTimeStamp::SetStamp(), lariov::IOVTimeStamp::Stamp(), lariov::IOVTimeStamp::SubStamp(), and tmp.

25  : DatabaseRetrievalAlg(foldername, url, tag)
26  , fEventTimeStamp(0)
29  {
30  fData.Clear();
31  IOVTimeStamp tmp = IOVTimeStamp::MaxTimeStamp();
32  tmp.SetStamp(tmp.Stamp() - 1, tmp.SubStamp());
33  fData.SetIoV(tmp, IOVTimeStamp::MaxTimeStamp());
34  }
Float_t tmp
Definition: plot.C:35
DatabaseRetrievalAlg(const std::string &foldername, const std::string &url, const std::string &url2="", const std::string &tag="", bool usesqlite=false, bool testmode=false)
Constructors.
static IOVTimeStamp MaxTimeStamp()
lariov::DetPedestalRetrievalAlg::DetPedestalRetrievalAlg ( fhicl::ParameterSet const &  p)

Definition at line 36 of file DetPedestalRetrievalAlg.cxx.

References Reconfigure().

37  : DatabaseRetrievalAlg(p.get<fhicl::ParameterSet>("DatabaseRetrievalAlg"))
38  {
39  this->Reconfigure(p);
40  }
DatabaseRetrievalAlg(const std::string &foldername, const std::string &url, const std::string &url2="", const std::string &tag="", bool usesqlite=false, bool testmode=false)
Constructors.
void Reconfigure(fhicl::ParameterSet const &p) override
Reconfigure function called by fhicl constructor.

Member Function Documentation

const IOVTimeStamp& lariov::DatabaseRetrievalAlg::Begin ( ) const
inlineinherited

Get Timestamp information.

Definition at line 63 of file DatabaseRetrievalAlg.h.

Referenced by lariov::SIOVPmtGainProvider::DBUpdate(), lariov::SIOVElectronicsCalibProvider::DBUpdate(), DBUpdate(), and lariov::SIOVChannelStatusProvider::DBUpdate().

63 { return fFolder->CachedStart(); }
std::unique_ptr< DBFolder > fFolder
bool lariov::DetPedestalRetrievalAlg::DBUpdate ( ) const
private

Do actual database updates.

Definition at line 160 of file DetPedestalRetrievalAlg.cxx.

References fEventTimeStamp.

Referenced by Pedestal(), and Update().

161  {
162  return DBUpdate(fEventTimeStamp);
163  }
bool DBUpdate() const
Do actual database updates.
bool lariov::DetPedestalRetrievalAlg::DBUpdate ( DBTimeStamp_t  ts) const
private

Definition at line 168 of file DetPedestalRetrievalAlg.cxx.

References lariov::DatabaseRetrievalAlg::Begin(), lariov::DataSource::Database, lariov::DatabaseRetrievalAlg::End(), fCurrentTimeStamp, fData, fDataSource, lariov::DatabaseRetrievalAlg::fFolder, pmtana::mean(), lariov::DetPedestal::SetPedMean(), lariov::DetPedestal::SetPedMeanErr(), lariov::DetPedestal::SetPedRms(), lariov::DetPedestal::SetPedRmsErr(), and lariov::DatabaseRetrievalAlg::UpdateFolder().

169  {
170  // A static mutex that is shared across all invocations of the function.
171  static std::mutex mutex;
172  std::lock_guard<std::mutex> lock(mutex);
173 
174  bool result = false;
176 
177  mf::LogInfo("DetPedestalRetrievalAlg")
178  << "DetPedestalRetrievalAlg::DBUpdate called with new timestamp.";
179  fCurrentTimeStamp = ts;
180 
181  // Call non-const base class method.
182 
183  result = const_cast<DetPedestalRetrievalAlg*>(this)->UpdateFolder(ts);
184  if (result) {
185 
186  //DBFolder was updated, so now update the Snapshot
187  fData.Clear();
188  fData.SetIoV(this->Begin(), this->End());
189 
190  std::vector<DBChannelID_t> channels;
191  fFolder->GetChannelList(channels);
192  for (auto it = channels.begin(); it != channels.end(); ++it) {
193 
194  double mean, mean_err, rms, rms_err;
195  fFolder->GetNamedChannelData(*it, "mean", mean);
196  fFolder->GetNamedChannelData(*it, "mean_err", mean_err);
197  fFolder->GetNamedChannelData(*it, "rms", rms);
198  fFolder->GetNamedChannelData(*it, "rms_err", rms_err);
199 
200  DetPedestal pd(*it);
201  pd.SetPedMean((float)mean);
202  pd.SetPedMeanErr((float)mean_err);
203  pd.SetPedRms((float)rms);
204  pd.SetPedRmsErr((float)rms_err);
205 
206  fData.AddOrReplaceRow(pd);
207  }
208  }
209  }
210 
211  return result;
212  }
std::unique_ptr< DBFolder > fFolder
MaybeLogger_< ELseverityLevel::ELsev_info, false > LogInfo
bool UpdateFolder(DBTimeStamp_t ts)
Return true if fFolder is successfully updated.
DetPedestalRetrievalAlg(const std::string &foldername, const std::string &url, const std::string &tag="")
Constructors.
const IOVTimeStamp & End() const
double mean(const std::vector< short > &wf, size_t start, size_t nsample)
Definition: UtilFunc.cxx:13
const IOVTimeStamp & Begin() const
Get Timestamp information.
const IOVTimeStamp& lariov::DatabaseRetrievalAlg::End ( ) const
inlineinherited
const std::string& lariov::DatabaseRetrievalAlg::FolderName ( ) const
inlineinherited

Definition at line 59 of file DatabaseRetrievalAlg.h.

59 { return fFolder->FolderName(); }
std::unique_ptr< DBFolder > fFolder
const DetPedestal & lariov::DetPedestalRetrievalAlg::Pedestal ( DBChannelID_t  ch) const

Retrieve pedestal information.

Definition at line 214 of file DetPedestalRetrievalAlg.cxx.

References DBUpdate(), and fData.

Referenced by PedMean(), PedMeanErr(), PedRms(), and PedRmsErr().

215  {
216  DBUpdate();
217  return fData.GetRow(ch);
218  }
bool DBUpdate() const
Do actual database updates.
float lariov::DetPedestalRetrievalAlg::PedMean ( DBChannelID_t  ch) const
override

Definition at line 220 of file DetPedestalRetrievalAlg.cxx.

References Pedestal(), and lariov::DetPedestal::PedMean().

221  {
222  return this->Pedestal(ch).PedMean();
223  }
float PedMean() const
Definition: DetPedestal.h:32
const DetPedestal & Pedestal(DBChannelID_t ch) const
Retrieve pedestal information.
float lariov::DetPedestalRetrievalAlg::PedMeanErr ( DBChannelID_t  ch) const
override

Definition at line 230 of file DetPedestalRetrievalAlg.cxx.

References Pedestal(), and lariov::DetPedestal::PedMeanErr().

231  {
232  return this->Pedestal(ch).PedMeanErr();
233  }
float PedMeanErr() const
Definition: DetPedestal.h:34
const DetPedestal & Pedestal(DBChannelID_t ch) const
Retrieve pedestal information.
float lariov::DetPedestalRetrievalAlg::PedRms ( DBChannelID_t  ch) const
override

Definition at line 225 of file DetPedestalRetrievalAlg.cxx.

References Pedestal(), and lariov::DetPedestal::PedRms().

226  {
227  return this->Pedestal(ch).PedRms();
228  }
const DetPedestal & Pedestal(DBChannelID_t ch) const
Retrieve pedestal information.
float PedRms() const
Definition: DetPedestal.h:33
float lariov::DetPedestalRetrievalAlg::PedRmsErr ( DBChannelID_t  ch) const
override

Definition at line 235 of file DetPedestalRetrievalAlg.cxx.

References Pedestal(), and lariov::DetPedestal::PedRmsErr().

236  {
237  return this->Pedestal(ch).PedRmsErr();
238  }
const DetPedestal & Pedestal(DBChannelID_t ch) const
Retrieve pedestal information.
float PedRmsErr() const
Definition: DetPedestal.h:35
void lariov::DetPedestalRetrievalAlg::Reconfigure ( fhicl::ParameterSet const &  p)
overridevirtual

Reconfigure function called by fhicl constructor.

Reimplemented from lariov::DatabaseRetrievalAlg.

Definition at line 42 of file DetPedestalRetrievalAlg.cxx.

References lariov::DataSource::Database, lariov::DataSource::Default, fData, fDataSource, file, lariov::DataSource::File, Get, fhicl::ParameterSet::get(), geo::kCollection, geo::kInduction, lariov::IOVTimeStamp::MaxTimeStamp(), lariov::DatabaseRetrievalAlg::Reconfigure(), lariov::ChData::SetChannel(), lariov::DetPedestal::SetPedMean(), lariov::DetPedestal::SetPedMeanErr(), lariov::DetPedestal::SetPedRms(), lariov::DetPedestal::SetPedRmsErr(), lariov::IOVTimeStamp::SetStamp(), lariov::IOVTimeStamp::Stamp(), lariov::IOVTimeStamp::SubStamp(), and tmp.

Referenced by DetPedestalRetrievalAlg().

43  {
44  this->DatabaseRetrievalAlg::Reconfigure(p.get<fhicl::ParameterSet>("DatabaseRetrievalAlg"));
45  fData.Clear();
46  IOVTimeStamp tmp = IOVTimeStamp::MaxTimeStamp();
47  tmp.SetStamp(tmp.Stamp() - 1, tmp.SubStamp());
48  fData.SetIoV(tmp, IOVTimeStamp::MaxTimeStamp());
49 
50  bool UseDB = p.get<bool>("UseDB", false);
51  bool UseFile = p.get<bool>("UseFile", false);
52  std::string fileName = p.get<std::string>("FileName", "");
53 
54  //priority: (1) use db, (2) use table, (3) use defaults
55  //If none are specified, use defaults
56  if (UseDB)
58  else if (UseFile)
60  else
62 
64  std::cout << "Using default pedestal values\n";
65  float default_collmean = p.get<float>("DefaultCollMean", 400.0);
66  float default_collrms = p.get<float>("DefaultCollRms", 0.3);
67  float default_mean_err = p.get<float>("DefaultMeanErr", 0.0);
68  float default_rms_err = p.get<float>("DefaultRmsErr", 0.0);
69  float default_indmean = p.get<float>("DefaultIndMean", 2048.0);
70  float default_indrms = p.get<float>("DefaultIndRms", 0.3);
71 
72  DetPedestal DefaultColl(0);
73  DetPedestal DefaultInd(0);
74 
75  DefaultColl.SetPedMean(default_collmean);
76  DefaultColl.SetPedMeanErr(default_mean_err);
77  DefaultColl.SetPedRms(default_collrms);
78  DefaultColl.SetPedRmsErr(default_rms_err);
79 
80  DefaultInd.SetPedMean(default_indmean);
81  DefaultInd.SetPedMeanErr(default_mean_err);
82  DefaultInd.SetPedRms(default_indrms);
83  DefaultInd.SetPedRmsErr(default_rms_err);
84 
85  auto const& wireReadoutGeom = art::ServiceHandle<geo::WireReadout>()->Get();
86  for (auto const& wid : wireReadoutGeom.Iterate<geo::WireID>()) {
87  DBChannelID_t ch = wireReadoutGeom.PlaneWireToChannel(wid);
88 
89  if (wireReadoutGeom.SignalType(ch) == geo::kCollection) {
90  DefaultColl.SetChannel(ch);
91  fData.AddOrReplaceRow(DefaultColl);
92  }
93  else if (wireReadoutGeom.SignalType(ch) == geo::kInduction) {
94  DefaultInd.SetChannel(ch);
95  fData.AddOrReplaceRow(DefaultInd);
96  }
97  else
98  throw IOVDataError("Wire type is not collection or induction!");
99  }
100  }
101  else if (fDataSource == DataSource::File) {
102  cet::search_path sp("FW_SEARCH_PATH");
103  std::string abs_fp = sp.find_file(fileName);
104  std::cout << "Using pedestals from local file: " << abs_fp << "\n";
105  std::ifstream file(abs_fp);
106  if (!file) {
107  throw cet::exception("DetPedestalRetrievalAlg") << "File " << abs_fp << " is not found.";
108  }
109 
110  std::string line;
111  DetPedestal dp(0);
112  while (std::getline(file, line)) {
113  size_t current_comma = line.find(',');
114  DBChannelID_t ch = (DBChannelID_t)std::stoi(line.substr(0, current_comma));
115  float ped = std::stof(
116  line.substr(current_comma + 1, line.find(',', current_comma + 1) - (current_comma + 1)));
117 
118  current_comma = line.find(',', current_comma + 1);
119  float rms = std::stof(
120  line.substr(current_comma + 1, line.find(',', current_comma + 1) - (current_comma + 1)));
121 
122  current_comma = line.find(',', current_comma + 1);
123  float ped_err = std::stof(
124  line.substr(current_comma + 1, line.find(',', current_comma + 1) - (current_comma + 1)));
125 
126  current_comma = line.find(',', current_comma + 1);
127  float rms_err = std::stof(line.substr(current_comma + 1));
128 
129  dp.SetChannel(ch);
130  dp.SetPedMean(ped);
131  dp.SetPedMeanErr(ped_err);
132  dp.SetPedRms(rms);
133  dp.SetPedRmsErr(rms_err);
134  fData.AddOrReplaceRow(dp);
135  }
136  } // if source from file
137  else {
138  std::cout << "Using pedestals from conditions database\n";
139  }
140  }
virtual void Reconfigure(fhicl::ParameterSet const &p)
Configure using fhicl::ParameterSet.
cout<< "Opened file "<< fin<< " ixs= "<< ixs<< endl;if(ixs==0) hhh=(TH1F *) fff-> Get("h1")
Definition: AddMC.C:8
Float_t tmp
Definition: plot.C:35
Signal from induction planes.
Definition: geo_types.h:147
TFile * file
static IOVTimeStamp MaxTimeStamp()
cet::coded_exception< error, detail::translate > exception
Definition: exception.h:33
Signal from collection planes.
Definition: geo_types.h:148
const std::string& lariov::DatabaseRetrievalAlg::Tag ( ) const
inlineinherited

Definition at line 60 of file DatabaseRetrievalAlg.h.

60 { return fFolder->Tag(); }
std::unique_ptr< DBFolder > fFolder
bool lariov::DetPedestalRetrievalAlg::Update ( DBTimeStamp_t  ts)

Update Snapshot and inherited DBFolder if using database. Return true if updated.

Definition at line 152 of file DetPedestalRetrievalAlg.cxx.

References DBUpdate(), and fEventTimeStamp.

153  {
154  fEventTimeStamp = ts;
155  return DBUpdate(ts);
156  }
bool DBUpdate() const
Do actual database updates.
bool lariov::DatabaseRetrievalAlg::UpdateFolder ( DBTimeStamp_t  ts)
inlineinherited

Return true if fFolder is successfully updated.

Definition at line 55 of file DatabaseRetrievalAlg.h.

Referenced by lariov::SIOVPmtGainProvider::DBUpdate(), lariov::SIOVElectronicsCalibProvider::DBUpdate(), DBUpdate(), and lariov::SIOVChannelStatusProvider::DBUpdate().

55 { return fFolder->UpdateData(ts); }
std::unique_ptr< DBFolder > fFolder
void lariov::DetPedestalRetrievalAlg::UpdateTimeStamp ( DBTimeStamp_t  ts)

Update event time stamp.

Definition at line 144 of file DetPedestalRetrievalAlg.cxx.

References fEventTimeStamp.

Referenced by lariov::SIOVDetPedestalService::PreProcessEvent().

145  {
146  mf::LogInfo("DetPedestalRetrievalAlg") << "DetPedestalRetrievalAlg::UpdateTimeStamp called.";
147  fEventTimeStamp = ts;
148  }
MaybeLogger_< ELseverityLevel::ELsev_info, false > LogInfo
const std::string& lariov::DatabaseRetrievalAlg::URL ( ) const
inlineinherited

Get connection information.

Definition at line 58 of file DatabaseRetrievalAlg.h.

58 { return fFolder->URL(); }
std::unique_ptr< DBFolder > fFolder

Member Data Documentation

DBTimeStamp_t lariov::DetPedestalRetrievalAlg::fCurrentTimeStamp
mutableprivate

Definition at line 106 of file DetPedestalRetrievalAlg.h.

Referenced by DBUpdate().

Snapshot<DetPedestal> lariov::DetPedestalRetrievalAlg::fData
mutableprivate
DataSource::ds lariov::DetPedestalRetrievalAlg::fDataSource
private

Definition at line 108 of file DetPedestalRetrievalAlg.h.

Referenced by DBUpdate(), and Reconfigure().

DBTimeStamp_t lariov::DetPedestalRetrievalAlg::fEventTimeStamp
private

Definition at line 105 of file DetPedestalRetrievalAlg.h.

Referenced by DBUpdate(), Update(), and UpdateTimeStamp().

constexpr const char* lariov::DetPedestalRetrievalAlg::FIELD_NAMES[NCOLUMNS]
static
Initial value:
= {"channel",
"mean",
"mean_err",
"rms",
"rms_err"}

Definition at line 86 of file DetPedestalRetrievalAlg.h.

constexpr const char* lariov::DetPedestalRetrievalAlg::FIELD_TYPES[NCOLUMNS]
static
Initial value:
= {"unsigned int",
"float",
"float",
"float",
"float"}

Definition at line 91 of file DetPedestalRetrievalAlg.h.

constexpr unsigned int lariov::DetPedestalRetrievalAlg::NCOLUMNS = 5
static

Definition at line 85 of file DetPedestalRetrievalAlg.h.


The documentation for this class was generated from the following files: