SiStripActionExecutor

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
#ifndef _SiStripActionExecutor_h_
#define _SiStripActionExecutor_h_

#include "DQM/SiStripMonitorClient/interface/SiStripConfigWriter.h"
#include "DQM/SiStripMonitorClient/interface/SiStripQualityChecker.h"
#include "DQM/SiStripMonitorClient/interface/SiStripSummaryCreator.h"
#include "DQM/SiStripMonitorClient/interface/SiStripTrackerMapCreator.h"

#include "DQMServices/Core/interface/DQMStore.h"

#include "FWCore/ParameterSet/interface/ParameterSet.h"

#include <map>
#include <vector>
#include <string>
#include <TTree.h>

class MonitorUserInterface;
class SiStripFedCabling;
class SiStripDetCabling;

class SiStripActionExecutor {
public:
  typedef dqm::harvesting::MonitorElement MonitorElement;
  typedef dqm::harvesting::DQMStore DQMStore;

  SiStripActionExecutor(edm::ParameterSet const& ps);
  virtual ~SiStripActionExecutor();

  bool readConfiguration();
  bool readTkMapConfiguration(const SiStripDetCabling* detCabling,
                              const TkDetMap* tkDetMap,
                              const TrackerTopology* tTopo);

  void saveMEs(DQMStore& dqm_store, std::string fname);
  void createSummary(DQMStore& dqm_store);
  void createSummaryOffline(DQMStore& dqm_store);
  void createTkMap(const edm::ParameterSet& tkmapPset, DQMStore& dqm_store, const std::string& map_type);
  void createOfflineTkMap(const edm::ParameterSet& tkmapPset,
                          DQMStore& dqm_store,
                          std::string& map_type,
                          const SiStripQuality* stripQuality);
  void createTkInfoFile(std::vector<std::string> tkhmap_names,
                        TTree* tkinfo_tree,
                        DQMStore& dqm_store,
                        const GeometricDet* geomDet);

  void createStatus(DQMStore& dqm_store);
  void fillDummyStatus();
  void fillStatus(DQMStore& dqm_store,
                  const SiStripDetCabling* cabling,
                  const TkDetMap* tkDetMap,
                  const TrackerTopology* tTopo);
  void fillStatusAtLumi(DQMStore& dqm_store);

  void createDummyShiftReport();
  void createShiftReport(DQMStore& dqm_store);
  void printReportSummary(MonitorElement* me, std::ostringstream& str_val, std::string name);
  void printShiftHistoParameters(DQMStore& dqm_store,
                                 std::map<std::string, std::vector<std::string>> const& layout_map,
                                 std::ostringstream& str_val);
  void printFaultyModuleList(DQMStore& dqm_store, std::ostringstream& str_val);
  void createFaultyModuleMEs(DQMStore& dqm_store);

private:
  std::vector<std::string> tkMapMENames{};

  std::unique_ptr<SiStripSummaryCreator> summaryCreator_{nullptr};
  std::unique_ptr<SiStripTrackerMapCreator> tkMapCreator_{nullptr};
  std::unique_ptr<SiStripQualityChecker> qualityChecker_{nullptr};
  std::unique_ptr<SiStripConfigWriter> configWriter_{nullptr};

  edm::ParameterSet const pSet_;
};
#endif