File indexing completed on 2024-04-06 12:22:55
0001 #ifndef MONSHAPEQUALITYDAT_H
0002 #define MONSHAPEQUALITYDAT_H
0003
0004 #include <map>
0005 #include <stdexcept>
0006
0007 #include "OnlineDB/EcalCondDB/interface/IDataItem.h"
0008 #include "OnlineDB/EcalCondDB/interface/MonRunTag.h"
0009 #include "OnlineDB/EcalCondDB/interface/MonRunIOV.h"
0010 #include "OnlineDB/EcalCondDB/interface/EcalLogicID.h"
0011
0012 class MonShapeQualityDat : public IDataItem {
0013 public:
0014 friend class EcalCondDBInterface;
0015 MonShapeQualityDat();
0016 ~MonShapeQualityDat() override;
0017
0018
0019 inline std::string getTable() override { return "MON_SHAPE_QUALITY_DAT"; }
0020
0021 inline void setAvgChi2(float chi2) { m_avgChi2 = chi2; }
0022 inline float getAvgChi2() const { return m_avgChi2; }
0023
0024 private:
0025 void prepareWrite() noexcept(false) override;
0026
0027 void writeDB(const EcalLogicID* ecid, const MonShapeQualityDat* item, MonRunIOV* iov) noexcept(false);
0028
0029 void writeArrayDB(const std::map<EcalLogicID, MonShapeQualityDat>* data, MonRunIOV* iov) noexcept(false);
0030
0031 void fetchData(std::map<EcalLogicID, MonShapeQualityDat>* fillVec, MonRunIOV* iov) noexcept(false);
0032
0033
0034 float m_avgChi2;
0035 };
0036
0037 #endif