CommissioningHistosUsingDb

DetInfo

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102

#ifndef DQM_SiStripCommissioningClients_CommissioningHistosUsingDb_H
#define DQM_SiStripCommissioningClients_CommissioningHistosUsingDb_H

#include "Geometry/Records/interface/TrackerTopologyRcd.h"
#include "DataFormats/SiStripCommon/interface/SiStripConstants.h"
#include "DQM/SiStripCommissioningClients/interface/CommissioningHistograms.h"
#include "OnlineDB/SiStripConfigDb/interface/SiStripConfigDb.h"
#include "boost/range/iterator_range.hpp"
#include <string>
#include <map>
#include <cstdint>

class SiStripConfigDb;
class SiStripFedCabling;
class TrackerTopology;

class CommissioningHistosUsingDb : public virtual CommissioningHistograms {
  // ---------- public interface ----------

public:
  CommissioningHistosUsingDb(SiStripConfigDb* const,
                             edm::ESGetToken<TrackerTopology, TrackerTopologyRcd> tTopoToken,
                             sistrip::RunType = sistrip::UNDEFINED_RUN_TYPE);

  ~CommissioningHistosUsingDb() override;

  void configure(const edm::ParameterSet&, const edm::EventSetup&) override;

  void uploadToConfigDb();

  bool doUploadAnal() const;

  bool doUploadConf() const;

  void doUploadAnal(bool);

  void doUploadConf(bool);

  // ---------- protected methods ----------

protected:
  void buildDetInfo();

  virtual void addDcuDetIds();

  virtual void uploadConfigurations() { ; }

  void uploadAnalyses();

  virtual void createAnalyses(SiStripConfigDb::AnalysisDescriptionsV&);

  virtual void create(SiStripConfigDb::AnalysisDescriptionsV&, Analysis) { ; }

  SiStripConfigDb* const db() const;

  SiStripFedCabling* const cabling() const;

  class DetInfo {
  public:
    uint32_t dcuId_;
    uint32_t detId_;
    uint16_t pairs_;
    DetInfo() : dcuId_(sistrip::invalid32_), detId_(sistrip::invalid32_), pairs_(sistrip::invalid_) { ; }
  };

  std::pair<std::string, DetInfo> detInfo(const SiStripFecKey&);

  bool deviceIsPresent(const SiStripFecKey&);

  // ---------- private member data ----------

private:
  CommissioningHistosUsingDb();

  sistrip::RunType runType_;

  SiStripConfigDb* db_;

  SiStripFedCabling* cabling_;

  typedef std::map<uint32_t, DetInfo> DetInfos;

  std::map<std::string, DetInfos> detInfo_;

  bool uploadAnal_;

  bool uploadConf_;

  edm::ESGetToken<TrackerTopology, TrackerTopologyRcd> tTopoToken_;
};

inline void CommissioningHistosUsingDb::doUploadConf(bool upload) { uploadConf_ = upload; }
inline void CommissioningHistosUsingDb::doUploadAnal(bool upload) { uploadAnal_ = upload; }

inline bool CommissioningHistosUsingDb::doUploadAnal() const { return uploadAnal_; }
inline bool CommissioningHistosUsingDb::doUploadConf() const { return uploadConf_; }

inline SiStripConfigDb* const CommissioningHistosUsingDb::db() const { return db_; }
inline SiStripFedCabling* const CommissioningHistosUsingDb::cabling() const { return cabling_; }

#endif  // DQM_SiStripCommissioningClients_CommissioningHistosUsingDb_H