FSQDQM

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 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138
#ifndef FSQDQM_H
#define FSQDQM_H

#include "DQMServices/Core/interface/DQMEDAnalyzer.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/LuminosityBlock.h"
#include "FWCore/Framework/interface/Run.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/Utilities/interface/InputTag.h"
#include "DataFormats/Candidate/interface/Candidate.h"
#include "DataFormats/Candidate/interface/CandidateFwd.h"

// Trigger stuff
#include "DataFormats/Common/interface/TriggerResults.h"
#include "HLTrigger/HLTcore/interface/HLTConfigProvider.h"

#include "DataFormats/Common/interface/Handle.h"
#include "FWCore/Framework/interface/DataKeyTags.h"
#include "Geometry/CaloGeometry/interface/CaloGeometry.h"
#include "Geometry/CaloGeometry/interface/CaloCellGeometry.h"
#include "DataFormats/MuonReco/interface/Muon.h"
#include "DataFormats/MuonReco/interface/MuonFwd.h"
#include <DataFormats/EgammaCandidates/interface/GsfElectron.h>

#include "TrackingTools/TrajectoryState/interface/TrajectoryStateOnSurface.h"
#include "DataFormats/GeometryCommonDetAlgo/interface/Measurement1D.h"
#include "DataFormats/GeometryVector/interface/GlobalVector.h"
#include "DataFormats/VertexReco/interface/Vertex.h"

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

// ParticleFlow
#include "DataFormats/ParticleFlowCandidate/interface/PFCandidate.h"

// EGamma
#include "DataFormats/EgammaCandidates/interface/GsfElectron.h"
#include "DataFormats/EgammaCandidates/interface/GsfElectronFwd.h"
#include "DataFormats/EgammaCandidates/interface/Electron.h"
#include "DataFormats/EgammaCandidates/interface/ElectronFwd.h"

// Muon
#include "DataFormats/MuonReco/interface/Muon.h"
#include "DataFormats/MuonReco/interface/MuonFwd.h"
#include "DataFormats/MuonReco/interface/MuonSelectors.h"
#include "DataFormats/MuonReco/interface/MuonIsolation.h"

// Jets
#include "DataFormats/JetReco/interface/PFJetCollection.h"
#include "DataFormats/JetReco/interface/BasicJetCollection.h"
#include "DataFormats/JetReco/interface/CaloJetCollection.h"

// MET
#include "DataFormats/METReco/interface/CaloMETCollection.h"
#include "DataFormats/METReco/interface/PFMETCollection.h"
#include "DataFormats/METReco/interface/GenMETCollection.h"
#include "DataFormats/METReco/interface/CaloMET.h"
#include "DataFormats/METReco/interface/PFMET.h"
#include "DataFormats/METReco/interface/MET.h"
#include "DataFormats/METReco/interface/METCollection.h"

//
#include "DataFormats/EcalRecHit/interface/EcalRecHitCollections.h"
#include "RecoEcal/EgammaCoreTools/interface/EcalClusterTools.h"

#include "CommonTools/Utils/interface/StringCutObjectSelector.h"

#include "DataFormats/Math/interface/deltaPhi.h"

#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <map>
#include <cmath>

class FSQDQM : public DQMEDAnalyzer {
public:
  FSQDQM(const edm::ParameterSet &ps);
  ~FSQDQM() override;

protected:
  void analyze(edm::Event const &e, edm::EventSetup const &eSetup) override;

private:
  void bookHistograms(DQMStore::IBooker &bei, edm::Run const &, edm::EventSetup const &) override;
  void bookHistos(DQMStore *bei);

  edm::InputTag vertex_;
  std::string labelBS_, labelTrack_, labelPFJet_, labelCastorJet_;
  edm::EDGetTokenT<edm::View<reco::Vertex> > pvs_;
  edm::EDGetTokenT<reco::TrackCollection> tok_track_;
  edm::EDGetTokenT<reco::PFJetCollection> tok_pfjet_;
  edm::EDGetTokenT<reco::BasicJetCollection> tok_castorjet_;

  std::vector<int> hltresults;
  unsigned int runNumber_, eventNumber_, lumiNumber_, bxNumber_;

  //Histograms
  MonitorElement *PFJetpt;
  MonitorElement *PFJeteta;
  MonitorElement *PFJetphi;

  MonitorElement *CastorJetphi;
  MonitorElement *CastorJetMulti;
  MonitorElement *PFJetMulti;
  MonitorElement *PFJetRapidity;
  MonitorElement *Track_HP_Phi;
  MonitorElement *Track_HP_Eta;
  MonitorElement *Track_HP_Pt;
  MonitorElement *Track_HP_ptErr_over_pt;
  MonitorElement *Track_HP_dzvtx_over_dzerr;
  MonitorElement *Track_HP_dxyvtx_over_dxyerror;
  MonitorElement *NPV;
  MonitorElement *PV_chi2;
  MonitorElement *PV_d0;
  MonitorElement *PV_numTrks;
  MonitorElement *PV_sumTrks;
  MonitorElement *h_ptsum_towards;
  MonitorElement *h_ptsum_transverse;
  MonitorElement *h_ptsum_away;
  MonitorElement *h_ntracks_towards;
  MonitorElement *h_ntracks_transverse;
  MonitorElement *h_ntracks_away;
  MonitorElement *h_trkptsum;
  MonitorElement *h_ntracks;

  MonitorElement *h_leadingtrkpt_ntrk_away;
  MonitorElement *h_leadingtrkpt_ntrk_towards;
  MonitorElement *h_leadingtrkpt_ntrk_transverse;
  MonitorElement *h_leadingtrkpt_ptsum_away;
  MonitorElement *h_leadingtrkpt_ptsum_towards;
  MonitorElement *h_leadingtrkpt_ptsum_transverse;

  //  math::XYZPoint RefVtx;
};
#endif