BeamSpotProblemMonitor

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

/** \class BeamSpotProblemMonitor
 * *
 *  \author  Sushil S. Chauhan/UC Davis
 *      
 *
 */
// C++
#include <string>
// CMS
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "DataFormats/Scalers/interface/BeamSpotOnline.h"
#include "DataFormats/Scalers/interface/DcsStatus.h"
#include "DataFormats/TrackReco/interface/Track.h"
#include "DataFormats/TrackReco/interface/TrackFwd.h"
#include "DQMServices/Core/interface/DQMStore.h"
#include "DQMServices/Core/interface/DQMOneEDAnalyzer.h"

//
// class declaration
//

class BeamSpotProblemMonitor : public DQMOneLumiEDAnalyzer<> {
public:
  explicit BeamSpotProblemMonitor(const edm::ParameterSet&);
  static void fillDescriptions(edm::ConfigurationDescriptions&);

protected:
  //The order it runs

  // BeginRun
  void bookHistograms(DQMStore::IBooker& i, const edm::Run& r, const edm::EventSetup& c) override;
  void analyze(const edm::Event& e, const edm::EventSetup& c) override;
  void dqmBeginLuminosityBlock(const edm::LuminosityBlock& lumiSeg, const edm::EventSetup& context) override;
  void dqmEndLuminosityBlock(const edm::LuminosityBlock& lumiSeg, const edm::EventSetup& c) override;
  // EndRun
  void dqmEndRun(const edm::Run& r, const edm::EventSetup& c) override;

private:
  void fillPlots(int&, int&, int);
  std::string monitorName_;
  const edm::EDGetTokenT<DcsStatusCollection> dcsStatus_;       // dcs status collection
  const edm::EDGetTokenT<BeamSpotOnlineCollection> scalertag_;  // scalar collection
  const edm::EDGetTokenT<reco::TrackCollection> trkSrc_;        //  track collection

  int nTracks_;
  const int nCosmicTrk_;
  const int fitNLumi_;
  const bool debug_;
  const bool onlineMode_;
  const bool doTest_;
  const int alarmONThreshold_;
  const int alarmOFFThreshold_;

  int lastlumi_;  // previous LS processed
  int nextlumi_;  // next LS of Fit
  bool processed_;

  //Alarm Variable
  bool alarmOn_;
  double beamSpotStatus_;
  int beamSpotFromDB_;

  // MonitorElements:
  MonitorElement* beamSpotStatusLumi_ = nullptr;
  MonitorElement* beamSpotStatusLumiAll_ = nullptr;
  MonitorElement* beamSpotError_ = nullptr;
};

#endif

// Local Variables:
// show-trailing-whitespace: t
// truncate-lines: t
// End: