CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Member Functions | Private Attributes
WenuPlots Class Reference

#include <WenuPlots.h>

Inheritance diagram for WenuPlots:
edm::EDAnalyzer edm::EDConsumerBase

Public Member Functions

 WenuPlots (const edm::ParameterSet &)
 
 ~WenuPlots ()
 
- Public Member Functions inherited from edm::EDAnalyzer
 EDAnalyzer ()
 
std::string workerType () const
 
virtual ~EDAnalyzer ()
 
- Public Member Functions inherited from edm::EDConsumerBase
 EDConsumerBase ()
 
ProductHolderIndex indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void itemsToGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Private Member Functions

virtual void analyze (const edm::Event &, const edm::EventSetup &)
 
virtual void beginJob ()
 
Bool_t CheckCut (const pat::Electron *wenu, Int_t i)
 
Bool_t CheckCutInv (const pat::Electron *wenu, Int_t i)
 
Bool_t CheckCuts (const pat::Electron *ele)
 
Bool_t CheckCutsInverse (const pat::Electron *ele)
 
Bool_t CheckCutsNminusOne (const pat::Electron *ele, Int_t jj)
 
virtual void endJob ()
 
Bool_t PassPreselectionCriteria (const pat::Electron *ele)
 
Double_t ReturnCandVar (const pat::Electron *ele, Int_t i)
 

Private Attributes

Float_t calojet_et [5]
 
Float_t calojet_eta [5]
 
Float_t calojet_phi [5]
 
edm::InputTag caloJetCollectionTag_
 
Double_t cIso_EB_
 
Bool_t cIso_EB_inv
 
Double_t cIso_EE_
 
Bool_t cIso_EE_inv
 
std::vector< Double_t > CutVars_
 
Int_t DatasetTag_
 
Double_t deta_EB_
 
Bool_t deta_EB_inv
 
Double_t deta_EE_
 
Bool_t deta_EE_inv
 
Double_t dphi_EB_
 
Bool_t dphi_EB_inv
 
Double_t dphi_EE_
 
Bool_t dphi_EE_inv
 
Double_t DRJetFromElectron_
 
Double_t ecalIso_EB_
 
Bool_t ecalIso_EB_inv
 
Double_t ecalIso_EE_
 
Bool_t ecalIso_EE_inv
 
Double_t ecalIsoUser_EB_
 
Bool_t ecalIsoUser_EB_inv
 
Double_t ecalIsoUser_EE_
 
Bool_t ecalIsoUser_EE_inv
 
Float_t ele2nd_cand_et
 
Float_t ele2nd_cand_eta
 
Float_t ele2nd_cand_phi
 
Float_t ele2nd_cr_dcot
 
Float_t ele2nd_cr_dist
 
Int_t ele2nd_cr_mhitsinner
 
Int_t ele2nd_ctfCharge
 
Int_t ele2nd_ecalDriven
 
Float_t ele2nd_eop
 
Int_t ele2nd_gsfCharge
 
Float_t ele2nd_hltmatched_dr
 
Float_t ele2nd_id_deta
 
Float_t ele2nd_id_dphi
 
Float_t ele2nd_id_hoe
 
Float_t ele2nd_id_sihih
 
Float_t ele2nd_iso_ecal
 
Float_t ele2nd_iso_hcal
 
Float_t ele2nd_iso_track
 
Int_t ele2nd_passes_selection
 
Float_t ele2nd_pin
 
Float_t ele2nd_pout
 
Float_t ele2nd_sc_eta
 
Float_t ele2nd_sc_gsf_et
 
Float_t ele2nd_sc_phi
 
Float_t ele2nd_sc_rho
 
Int_t ele2nd_scPixCharge
 
Float_t ele2nd_tip_bs
 
Float_t ele2nd_tip_pv
 
Float_t ele2nd_tip_pvbs
 
Float_t ele2nd_vx
 
Float_t ele2nd_vy
 
Float_t ele2nd_vz
 
Float_t ele_cand_et
 
Float_t ele_cand_eta
 
Float_t ele_cand_phi
 
Float_t ele_cr_dcot
 
Float_t ele_cr_dist
 
Int_t ele_cr_mhitsinner
 
Int_t ele_ctfCharge
 
Float_t ele_eop
 
Int_t ele_gsfCharge
 
Float_t ele_hltmatched_dr
 
Float_t ele_id_deta
 
Float_t ele_id_dphi
 
Float_t ele_id_hoe
 
Float_t ele_id_sihih
 
Float_t ele_iso_ecal
 
Float_t ele_iso_hcal
 
Float_t ele_iso_track
 
Float_t ele_pin
 
Float_t ele_pout
 
Float_t ele_sc_energy
 
Float_t ele_sc_eta
 
Float_t ele_sc_gsf_et
 
Float_t ele_sc_phi
 
Float_t ele_sc_rho
 
Int_t ele_scPixCharge
 
Float_t ele_tip_bs
 
Float_t ele_tip_pv
 
Float_t ele_tip_pvbs
 
Float_t ele_vx
 
Float_t ele_vy
 
Float_t ele_vz
 
Double_t eop_EB_
 
Bool_t eop_EB_inv
 
Double_t eop_EE_
 
Bool_t eop_EE_inv
 
Float_t event_caloMET
 
Float_t event_caloMET_phi
 
Float_t event_caloMT
 
Float_t event_caloSumEt
 
Int_t event_datasetTag
 
Float_t event_pfMET
 
Float_t event_pfMET_phi
 
Float_t event_pfMT
 
Float_t event_pfSumEt
 
Float_t event_tcMET
 
Float_t event_tcMET_phi
 
Float_t event_tcMT
 
Float_t event_tcSumEt
 
Int_t event_triggerDecision
 
Long64_t eventNumber
 
TH1F * h_EB_deta
 
TH1F * h_EB_dphi
 
TH1F * h_EB_ecaliso
 
TH1F * h_EB_hcaliso
 
TH1F * h_EB_HoE
 
TH1F * h_EB_sIetaIeta
 
TH1F * h_EB_trkiso
 
TH1F * h_EE_deta
 
TH1F * h_EE_dphi
 
TH1F * h_EE_ecaliso
 
TH1F * h_EE_hcaliso
 
TH1F * h_EE_HoE
 
TH1F * h_EE_sIetaIeta
 
TH1F * h_EE_trkiso
 
TH1F * h_met
 
TH1F * h_met_EB
 
TH1F * h_met_EE
 
TH1F * h_met_inverse
 
TH1F * h_met_inverse_EB
 
TH1F * h_met_inverse_EE
 
TH1F * h_mt
 
TH1F * h_mt_EB
 
TH1F * h_mt_EE
 
TH1F * h_mt_inverse
 
TH1F * h_mt_inverse_EB
 
TH1F * h_mt_inverse_EE
 
TH1F * h_scEt
 
TH1F * h_scEta
 
TH1F * h_scPhi
 
TH1F * h_trackIso_eb_NmOne
 
TH1F * h_trackIso_ee_NmOne
 
Double_t hcalIso_EB_
 
Bool_t hcalIso_EB_inv
 
Double_t hcalIso_EE_
 
Bool_t hcalIso_EE_inv
 
Double_t hcalIsoUser_EB_
 
Bool_t hcalIsoUser_EB_inv
 
Double_t hcalIsoUser_EE_
 
Bool_t hcalIsoUser_EE_inv
 
TFile * histofile
 
Double_t hoe_EB_
 
Bool_t hoe_EB_inv
 
Double_t hoe_EE_
 
Bool_t hoe_EE_inv
 
Bool_t includeJetInformationInNtuples_
 
std::vector< Bool_t > InvVars_
 
Int_t lumiSection
 
Int_t maxNumberOfExpectedMissingHits_
 
Int_t nBarrelVars_
 
std::string outputFile_
 
Float_t pfjet_et [5]
 
Float_t pfjet_eta [5]
 
Float_t pfjet_phi [5]
 
edm::InputTag pfJetCollectionTag_
 
edm::InputTag PrimaryVerticesCollection_
 
edm::InputTag PrimaryVerticesCollectionBS_
 
Float_t pv_x
 
Float_t pv_y
 
Float_t pv_z
 
Float_t pvbs_x
 
Float_t pvbs_y
 
Float_t pvbs_z
 
Int_t runNumber
 
Double_t sihih_EB_
 
Bool_t sihih_EB_inv
 
Double_t sihih_EE_
 
Bool_t sihih_EE_inv
 
Bool_t storeAllSecondElectronVariables_
 
Bool_t storeExtraInformation_
 
Double_t tip_bspot_EB_
 
Bool_t tip_bspot_EB_inv
 
Double_t tip_bspot_EE_
 
Bool_t tip_bspot_EE_inv
 
Double_t trackIso_EB_
 
Bool_t trackIso_EB_inv
 
Double_t trackIso_EE_
 
Bool_t trackIso_EE_inv
 
Double_t trackIsoUser_EB_
 
Bool_t trackIsoUser_EB_inv
 
Double_t trackIsoUser_EE_
 
Bool_t trackIsoUser_EE_inv
 
Bool_t useConversionRejection_
 
Bool_t useExpectedMissingHits_
 
Bool_t usePrecalcID_
 
std::string usePrecalcIDSign_
 
std::string usePrecalcIDType_
 
Double_t usePrecalcIDValue_
 
Bool_t usePreselection_
 
Bool_t useValidFirstPXBHit_
 
TTree * vbtfPresele_tree
 
TTree * vbtfSele_tree
 
std::vector< Float_t > VtxNormalizedChi2
 
std::vector< Float_t > VtxNormalizedChi2BS
 
std::vector< Int_t > VtxTracksSize
 
std::vector< Int_t > VtxTracksSizeBS
 
TFile * WENU_VBTFpreseleFile_
 
std::string WENU_VBTFpreseleFileName_
 
TFile * WENU_VBTFselectionFile_
 
std::string WENU_VBTFselectionFileName_
 
edm::InputTag wenuCollectionTag_
 

Additional Inherited Members

- Public Types inherited from edm::EDAnalyzer
typedef EDAnalyzer ModuleType
 
typedef WorkerT< EDAnalyzerWorkerType
 
- Static Public Member Functions inherited from edm::EDAnalyzer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &)
 
- Protected Member Functions inherited from edm::EDAnalyzer
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
CurrentProcessingContext const * currentContext () const
 
- Protected Member Functions inherited from edm::EDConsumerBase
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 

Detailed Description

Definition at line 33 of file WenuPlots.h.

Constructor & Destructor Documentation

WenuPlots::WenuPlots ( const edm::ParameterSet iConfig)
explicit

Definition at line 61 of file WenuPlots.cc.

References caloJetCollectionTag_, cIso_EB_, cIso_EB_inv, cIso_EE_, cIso_EE_inv, gather_cfg::cout, DatasetTag_, deta_EB_, deta_EB_inv, deta_EE_, deta_EE_inv, dphi_EB_, dphi_EB_inv, dphi_EE_, dphi_EE_inv, DRJetFromElectron_, ecalIso_EB_, ecalIso_EB_inv, ecalIso_EE_, ecalIso_EE_inv, ecalIsoUser_EB_, ecalIsoUser_EB_inv, ecalIsoUser_EE_, ecalIsoUser_EE_inv, eop_EB_, eop_EB_inv, eop_EE_, eop_EE_inv, edm::ParameterSet::getUntrackedParameter(), hcalIso_EB_, hcalIso_EB_inv, hcalIso_EE_, hcalIso_EE_inv, hcalIsoUser_EB_, hcalIsoUser_EB_inv, hcalIsoUser_EE_, hcalIsoUser_EE_inv, hoe_EB_, hoe_EB_inv, hoe_EE_, hoe_EE_inv, includeJetInformationInNtuples_, maxNumberOfExpectedMissingHits_, outputFile_, pfJetCollectionTag_, PrimaryVerticesCollection_, PrimaryVerticesCollectionBS_, sihih_EB_, sihih_EB_inv, sihih_EE_, sihih_EE_inv, storeAllSecondElectronVariables_, storeExtraInformation_, AlCaHLTBitMon_QueryRunRegistry::string, tip_bspot_EB_, tip_bspot_EB_inv, tip_bspot_EE_, tip_bspot_EE_inv, trackIso_EB_, trackIso_EB_inv, trackIso_EE_, trackIso_EE_inv, trackIsoUser_EB_, trackIsoUser_EB_inv, trackIsoUser_EE_, trackIsoUser_EE_inv, useConversionRejection_, useExpectedMissingHits_, usePrecalcID_, usePrecalcIDSign_, usePrecalcIDType_, usePrecalcIDValue_, usePreselection_, useValidFirstPXBHit_, WENU_VBTFpreseleFileName_, WENU_VBTFselectionFileName_, and wenuCollectionTag_.

63 {
65 // I N P U T P A R A M E T E R S
67 //
69 // WENU COLLECTION //////////////////////////////////////////////////////
70 //
71 
73  ("wenuCollectionTag");
74  //
75  // code parameters
76  //
77  std::string outputFile_D = "histos.root";
78  outputFile_ = iConfig.getUntrackedParameter<std::string>("outputFile", outputFile_D);
79  WENU_VBTFselectionFileName_ = iConfig.getUntrackedParameter<std::string>("WENU_VBTFselectionFileName");
80  WENU_VBTFpreseleFileName_ = iConfig.getUntrackedParameter<std::string>("WENU_VBTFpreseleFileName");
81  DatasetTag_ = iConfig.getUntrackedParameter<Int_t>("DatasetTag");
82  //
83  // use of precalculatedID
84  // if you use it, then no other cuts are applied
85  usePrecalcID_ = iConfig.getUntrackedParameter<Bool_t>("usePrecalcID",false);
86  if (usePrecalcID_) {
87  usePrecalcIDType_ = iConfig.getUntrackedParameter<std::string>("usePrecalcIDType");
88  usePrecalcIDSign_ = iConfig.getUntrackedParameter<std::string>("usePrecalcIDSign","=");
89  usePrecalcIDValue_= iConfig.getUntrackedParameter<Double_t>("usePrecalcIDValue");
90  }
91  useValidFirstPXBHit_ = iConfig.getUntrackedParameter<Bool_t>("useValidFirstPXBHit",false);
92  useConversionRejection_ = iConfig.getUntrackedParameter<Bool_t>("useConversionRejection",false);
93  useExpectedMissingHits_ = iConfig.getUntrackedParameter<Bool_t>("useExpectedMissingHits",false);
94 
95  maxNumberOfExpectedMissingHits_ = iConfig.getUntrackedParameter<Int_t>("maxNumberOfExpectedMissingHits",1);
96  if (not usePrecalcID_) {
97  if (useValidFirstPXBHit_) std::cout << "WenuPlots: Warning: you have demanded a valid 1st layer PXB hit" << std::endl;
98  if (useConversionRejection_) std::cout << "WenuPlots: Warning: you have demanded egamma conversion rejection criteria to be applied" << std::endl;
99  if (useExpectedMissingHits_) std::cout << "WenuPlots: Warning: you have demanded at most "
100  <<maxNumberOfExpectedMissingHits_ << " missing inner hits "<< std::endl;
101  }
102  else {
103  std::cout << "WenuPlots: Using Precalculated ID with type " << usePrecalcIDType_
104  << usePrecalcIDSign_ << usePrecalcIDValue_ << std::endl;
105  }
106  if ((useValidFirstPXBHit_ || useExpectedMissingHits_ || useConversionRejection_) && (not usePrecalcID_)) {
107  usePreselection_ = true;
108  } else { usePreselection_ = false; }
109  includeJetInformationInNtuples_ = iConfig.getUntrackedParameter<Bool_t>("includeJetInformationInNtuples", false);
111  caloJetCollectionTag_ = iConfig.getUntrackedParameter<edm::InputTag>("caloJetCollectionTag");
112  pfJetCollectionTag_ = iConfig.getUntrackedParameter<edm::InputTag>("pfJetCollectionTag");
113  DRJetFromElectron_ = iConfig.getUntrackedParameter<Double_t>("DRJetFromElectron");
114  }
115  storeExtraInformation_ = iConfig.getUntrackedParameter<Bool_t>("storeExtraInformation");
116  storeAllSecondElectronVariables_ = iConfig.getUntrackedParameter<Bool_t>("storeAllSecondElectronVariables", false);
117  // primary vtx collections
119  ("PrimaryVerticesCollection", edm::InputTag("offlinePrimaryVertices"));
121  ("PrimaryVerticesCollectionBS",edm::InputTag("offlinePrimaryVerticesWithBS"));
122  //
123  // the selection cuts:
124  trackIso_EB_ = iConfig.getUntrackedParameter<Double_t>("trackIso_EB", 1000.);
125  ecalIso_EB_ = iConfig.getUntrackedParameter<Double_t>("ecalIso_EB", 1000.);
126  hcalIso_EB_ = iConfig.getUntrackedParameter<Double_t>("hcalIso_EB", 1000.);
127  //
128  trackIso_EE_ = iConfig.getUntrackedParameter<Double_t>("trackIso_EE", 1000.);
129  ecalIso_EE_ = iConfig.getUntrackedParameter<Double_t>("ecalIso_EE", 1000.);
130  hcalIso_EE_ = iConfig.getUntrackedParameter<Double_t>("hcalIso_EE", 1000.);
131  //
132  sihih_EB_ = iConfig.getUntrackedParameter<Double_t>("sihih_EB");
133  dphi_EB_ = iConfig.getUntrackedParameter<Double_t>("dphi_EB");
134  deta_EB_ = iConfig.getUntrackedParameter<Double_t>("deta_EB");
135  hoe_EB_ = iConfig.getUntrackedParameter<Double_t>("hoe_EB");
136  cIso_EB_ = iConfig.getUntrackedParameter<Double_t>("cIso_EB", 1000.);
137  tip_bspot_EB_=iConfig.getUntrackedParameter<Double_t>("tip_bspot_EB", 1000.);
138  eop_EB_=iConfig.getUntrackedParameter<Double_t>("eop_EB", 1000.);
139  //
140  sihih_EE_ = iConfig.getUntrackedParameter<Double_t>("sihih_EE");
141  dphi_EE_ = iConfig.getUntrackedParameter<Double_t>("dphi_EE");
142  deta_EE_ = iConfig.getUntrackedParameter<Double_t>("deta_EE");
143  hoe_EE_ = iConfig.getUntrackedParameter<Double_t>("hoe_EE");
144  cIso_EE_ = iConfig.getUntrackedParameter<Double_t>("cIso_EE", 1000.);
145  tip_bspot_EE_=iConfig.getUntrackedParameter<Double_t>("tip_bspot_EE", 1000.);
146  eop_EE_=iConfig.getUntrackedParameter<Double_t>("eop_EE", 1000.);
147  //
148  trackIsoUser_EB_ = iConfig.getUntrackedParameter<Double_t>("trackIsoUser_EB", 1000.);
149  ecalIsoUser_EB_ = iConfig.getUntrackedParameter<Double_t>("ecalIsoUser_EB", 1000.);
150  hcalIsoUser_EB_ = iConfig.getUntrackedParameter<Double_t>("hcalIsoUser_EB", 1000.);
151  trackIsoUser_EE_ = iConfig.getUntrackedParameter<Double_t>("trackIsoUser_EE", 1000.);
152  ecalIsoUser_EE_ = iConfig.getUntrackedParameter<Double_t>("ecalIsoUser_EE", 1000.);
153  hcalIsoUser_EE_ = iConfig.getUntrackedParameter<Double_t>("hcalIsoUser_EE", 1000.);
154  //
155  trackIso_EB_inv = iConfig.getUntrackedParameter<Bool_t>("trackIso_EB_inv", false);
156  ecalIso_EB_inv = iConfig.getUntrackedParameter<Bool_t>("ecalIso_EB_inv", false);
157  hcalIso_EB_inv = iConfig.getUntrackedParameter<Bool_t>("hcalIso_EB_inv", false);
158  //
159  trackIso_EE_inv = iConfig.getUntrackedParameter<Bool_t>("trackIso_EE_inv", false);
160  ecalIso_EE_inv = iConfig.getUntrackedParameter<Bool_t>("ecalIso_EE_inv", false);
161  hcalIso_EE_inv = iConfig.getUntrackedParameter<Bool_t>("hcalIso_EE_inv", false);
162  //
163  sihih_EB_inv = iConfig.getUntrackedParameter<Bool_t>("sihih_EB_inv", false);
164  dphi_EB_inv = iConfig.getUntrackedParameter<Bool_t>("dphi_EB_inv", false);
165  deta_EB_inv = iConfig.getUntrackedParameter<Bool_t>("deta_EB_inv", false);
166  hoe_EB_inv = iConfig.getUntrackedParameter<Bool_t>("hoe_EB_inv", false);
167  cIso_EB_inv = iConfig.getUntrackedParameter<Bool_t>("cIso_EB_inv", false);
168  tip_bspot_EB_inv=iConfig.getUntrackedParameter<Bool_t>("tip_bspot_EB_inv", false);
169  eop_EB_inv=iConfig.getUntrackedParameter<Bool_t>("eop_EB_inv", false);
170  //
171  sihih_EE_inv = iConfig.getUntrackedParameter<Bool_t>("sihih_EE_inv", false);
172  dphi_EE_inv = iConfig.getUntrackedParameter<Bool_t>("dphi_EE_inv", false);
173  deta_EE_inv = iConfig.getUntrackedParameter<Bool_t>("deta_EE_inv", false);
174  hoe_EE_inv = iConfig.getUntrackedParameter<Bool_t>("hoe_EE_inv", false);
175  cIso_EE_inv = iConfig.getUntrackedParameter<Bool_t>("cIso_EE_inv", false);
176  tip_bspot_EE_inv=iConfig.getUntrackedParameter<Bool_t>("tip_bspot_EE_inv", false);
177  eop_EE_inv=iConfig.getUntrackedParameter<Bool_t>("eop_EE_inv", false);
178  //
179  trackIsoUser_EB_inv = iConfig.getUntrackedParameter<Bool_t>("trackIsoUser_EB_inv", false);
180  ecalIsoUser_EB_inv = iConfig.getUntrackedParameter<Bool_t>("ecalIsoUser_EB_inv", false);
181  hcalIsoUser_EB_inv = iConfig.getUntrackedParameter<Bool_t>("hcalIsoUser_EB_inv", false);
182  trackIsoUser_EE_inv = iConfig.getUntrackedParameter<Bool_t>("trackIsoUser_EE_inv", false);
183  ecalIsoUser_EE_inv = iConfig.getUntrackedParameter<Bool_t>("ecalIsoUser_EE_inv", false);
184  hcalIsoUser_EE_inv = iConfig.getUntrackedParameter<Bool_t>("hcalIsoUser_EE_inv", false);
185 
186 }
Double_t trackIsoUser_EB_
Definition: WenuPlots.h:141
T getUntrackedParameter(std::string const &, T const &) const
Int_t maxNumberOfExpectedMissingHits_
Definition: WenuPlots.h:61
Double_t cIso_EE_
Definition: WenuPlots.h:137
Double_t trackIso_EB_
Definition: WenuPlots.h:117
std::string WENU_VBTFselectionFileName_
Definition: WenuPlots.h:229
Bool_t hcalIso_EE_inv
Definition: WenuPlots.h:154
edm::InputTag wenuCollectionTag_
Definition: WenuPlots.h:64
Bool_t deta_EE_inv
Definition: WenuPlots.h:165
Double_t eop_EE_
Definition: WenuPlots.h:139
Bool_t ecalIso_EB_inv
Definition: WenuPlots.h:149
Double_t trackIsoUser_EE_
Definition: WenuPlots.h:144
Double_t cIso_EB_
Definition: WenuPlots.h:129
Bool_t tip_bspot_EE_inv
Definition: WenuPlots.h:169
Bool_t tip_bspot_EB_inv
Definition: WenuPlots.h:161
std::string WENU_VBTFpreseleFileName_
Definition: WenuPlots.h:230
Double_t ecalIsoUser_EB_
Definition: WenuPlots.h:142
Bool_t includeJetInformationInNtuples_
Definition: WenuPlots.h:231
Double_t dphi_EE_
Definition: WenuPlots.h:135
Bool_t sihih_EE_inv
Definition: WenuPlots.h:164
Bool_t dphi_EE_inv
Definition: WenuPlots.h:166
Bool_t hcalIsoUser_EE_inv
Definition: WenuPlots.h:177
Bool_t usePreselection_
Definition: WenuPlots.h:62
Double_t tip_bspot_EB_
Definition: WenuPlots.h:130
Bool_t ecalIso_EE_inv
Definition: WenuPlots.h:153
Double_t deta_EE_
Definition: WenuPlots.h:134
Bool_t useExpectedMissingHits_
Definition: WenuPlots.h:60
Int_t DatasetTag_
Definition: WenuPlots.h:234
Double_t hcalIso_EB_
Definition: WenuPlots.h:119
std::string usePrecalcIDSign_
Definition: WenuPlots.h:54
Double_t trackIso_EE_
Definition: WenuPlots.h:121
Double_t deta_EB_
Definition: WenuPlots.h:126
Double_t hcalIsoUser_EB_
Definition: WenuPlots.h:143
Double_t hcalIso_EE_
Definition: WenuPlots.h:123
Bool_t deta_EB_inv
Definition: WenuPlots.h:157
Bool_t hcalIsoUser_EB_inv
Definition: WenuPlots.h:174
Double_t sihih_EE_
Definition: WenuPlots.h:133
Bool_t ecalIsoUser_EE_inv
Definition: WenuPlots.h:176
Bool_t eop_EE_inv
Definition: WenuPlots.h:170
edm::InputTag PrimaryVerticesCollectionBS_
Definition: WenuPlots.h:68
Double_t ecalIso_EB_
Definition: WenuPlots.h:118
Double_t eop_EB_
Definition: WenuPlots.h:131
Double_t usePrecalcIDValue_
Definition: WenuPlots.h:56
Double_t hcalIsoUser_EE_
Definition: WenuPlots.h:146
Bool_t trackIso_EE_inv
Definition: WenuPlots.h:152
edm::InputTag caloJetCollectionTag_
Definition: WenuPlots.h:65
Bool_t eop_EB_inv
Definition: WenuPlots.h:162
Bool_t storeAllSecondElectronVariables_
Definition: WenuPlots.h:236
Bool_t useConversionRejection_
Definition: WenuPlots.h:59
Bool_t sihih_EB_inv
Definition: WenuPlots.h:156
edm::InputTag PrimaryVerticesCollection_
Definition: WenuPlots.h:67
Bool_t cIso_EB_inv
Definition: WenuPlots.h:160
Bool_t trackIsoUser_EE_inv
Definition: WenuPlots.h:175
Bool_t hcalIso_EB_inv
Definition: WenuPlots.h:150
Bool_t storeExtraInformation_
Definition: WenuPlots.h:232
Bool_t hoe_EE_inv
Definition: WenuPlots.h:167
Bool_t useValidFirstPXBHit_
Definition: WenuPlots.h:58
edm::InputTag pfJetCollectionTag_
Definition: WenuPlots.h:66
std::string usePrecalcIDType_
Definition: WenuPlots.h:55
Bool_t ecalIsoUser_EB_inv
Definition: WenuPlots.h:173
Double_t DRJetFromElectron_
Definition: WenuPlots.h:233
Bool_t cIso_EE_inv
Definition: WenuPlots.h:168
std::string outputFile_
Definition: WenuPlots.h:63
Bool_t dphi_EB_inv
Definition: WenuPlots.h:158
tuple cout
Definition: gather_cfg.py:121
Double_t hoe_EB_
Definition: WenuPlots.h:128
Bool_t trackIsoUser_EB_inv
Definition: WenuPlots.h:172
Double_t tip_bspot_EE_
Definition: WenuPlots.h:138
Double_t dphi_EB_
Definition: WenuPlots.h:127
Double_t sihih_EB_
Definition: WenuPlots.h:125
Bool_t trackIso_EB_inv
Definition: WenuPlots.h:148
Double_t ecalIsoUser_EE_
Definition: WenuPlots.h:145
Double_t ecalIso_EE_
Definition: WenuPlots.h:122
Bool_t usePrecalcID_
Definition: WenuPlots.h:53
Bool_t hoe_EB_inv
Definition: WenuPlots.h:159
Double_t hoe_EE_
Definition: WenuPlots.h:136
WenuPlots::~WenuPlots ( )

Definition at line 190 of file WenuPlots.cc.

191 {
192 
193  // do anything here that needs to be done at desctruction time
194  // (e.g. close files, deallocate resources etc.)
195 
196 }

Member Function Documentation

void WenuPlots::analyze ( const edm::Event iEvent,
const edm::EventSetup es 
)
privatevirtual

Implements edm::EDAnalyzer.

Definition at line 205 of file WenuPlots.cc.

References calojet_et, calojet_eta, calojet_phi, caloJetCollectionTag_, FamosSequences_cff::caloJets, reco::GsfElectron::chargeInfo(), CheckCuts(), CheckCutsInverse(), CheckCutsNminusOne(), pat::Electron::closestCtfTrackRef(), reco::GsfElectron::convDcot(), reco::GsfElectron::convDist(), gather_cfg::cout, DatasetTag_, pat::Electron::dB(), reco::GsfElectron::deltaEtaSuperClusterTrackAtVtx(), reco::GsfElectron::deltaPhiSuperClusterTrackAtVtx(), reco::deltaR(), reco::GsfElectron::dr03IsolationVariables(), DRJetFromElectron_, reco::GsfElectron::ecalDrivenSeed(), pat::EcalIso, reco::GsfElectron::IsolationVariables::ecalRecHitSumEt, ele2nd_cand_et, ele2nd_cand_eta, ele2nd_cand_phi, ele2nd_cr_dcot, ele2nd_cr_dist, ele2nd_cr_mhitsinner, ele2nd_ctfCharge, ele2nd_ecalDriven, ele2nd_eop, ele2nd_gsfCharge, ele2nd_hltmatched_dr, ele2nd_id_deta, ele2nd_id_dphi, ele2nd_id_hoe, ele2nd_id_sihih, ele2nd_iso_ecal, ele2nd_iso_hcal, ele2nd_iso_track, ele2nd_passes_selection, ele2nd_pin, ele2nd_pout, ele2nd_sc_eta, ele2nd_sc_gsf_et, ele2nd_sc_phi, ele2nd_sc_rho, ele2nd_scPixCharge, ele2nd_tip_bs, ele2nd_tip_pv, ele2nd_tip_pvbs, ele2nd_vx, ele2nd_vy, ele2nd_vz, ele_cand_et, ele_cand_eta, ele_cand_phi, ele_cr_dcot, ele_cr_dist, ele_cr_mhitsinner, ele_ctfCharge, ele_eop, ele_gsfCharge, ele_hltmatched_dr, ele_id_deta, ele_id_dphi, ele_id_hoe, ele_id_sihih, ele_iso_ecal, ele_iso_hcal, ele_iso_track, ele_pin, ele_pout, ele_sc_energy, ele_sc_eta, ele_sc_gsf_et, ele_sc_phi, ele_sc_rho, ele_scPixCharge, ele_tip_bs, ele_tip_pv, ele_tip_pvbs, ele_vx, ele_vy, ele_vz, pat::Electron::electronID(), reco::GsfElectron::eSuperClusterOverP(), reco::LeafCandidate::et(), reco::LeafCandidate::eta(), edm::EventAuxiliary::event(), event_caloMET, event_caloMET_phi, event_caloMT, event_caloSumEt, event_datasetTag, event_pfMET, event_pfMET_phi, event_pfMT, event_pfSumEt, event_tcMET, event_tcMET_phi, event_tcMT, event_tcSumEt, event_triggerDecision, edm::Event::eventAuxiliary(), eventNumber, edm::Event::getByLabel(), pat::Electron::gsfTrack(), h_EB_deta, h_EB_dphi, h_EB_ecaliso, h_EB_hcaliso, h_EB_HoE, h_EB_sIetaIeta, h_EB_trkiso, h_EE_deta, h_EE_dphi, h_EE_ecaliso, h_EE_hcaliso, h_EE_HoE, h_EE_sIetaIeta, h_EE_trkiso, h_met, h_met_EB, h_met_EE, h_met_inverse, h_met_inverse_EB, h_met_inverse_EE, h_mt, h_mt_EB, h_mt_EE, h_mt_inverse, h_mt_inverse_EB, h_mt_inverse_EE, h_scEt, h_scEta, h_scPhi, h_trackIso_eb_NmOne, h_trackIso_ee_NmOne, reco::GsfElectron::hadronicOverEm(), reco::GsfElectron::IsolationVariables::hcalDepth1TowerSumEt, reco::GsfElectron::IsolationVariables::hcalDepth2TowerSumEt, pat::HcalIso, i, includeJetInformationInNtuples_, pat::Electron::isElectronIDAvailable(), edm::Ref< C, T, F >::isNonnull(), edm::HandleBase::isValid(), edm::EventBase::luminosityBlock(), lumiSection, CaloMET_cfi::met, PassPreselectionCriteria(), pfjet_et, pfjet_eta, pfjet_phi, pfJetCollectionTag_, pfJets_cff::pfJets, reco::LeafCandidate::phi(), position, PrimaryVerticesCollection_, PrimaryVerticesCollectionBS_, edm::Handle< T >::product(), pv_x, pv_y, pv_z, pvbs_x, pvbs_y, pvbs_z, edm::Event::run(), runNumber, reco::GsfElectron::ChargeInfo::scPixCharge, reco::GsfElectron::sigmaIetaIeta(), mathSSE::sqrt(), storeAllSecondElectronVariables_, storeExtraInformation_, pat::Electron::superCluster(), reco::GsfElectron::IsolationVariables::tkSumPt, pat::TrackIso, reco::GsfElectron::trackMomentumAtVtx(), reco::GsfElectron::trackMomentumOut(), usePrecalcID_, usePreselection_, pat::PATObject< ObjectType >::userFloat(), vbtfPresele_tree, vbtfSele_tree, VtxNormalizedChi2, VtxNormalizedChi2BS, VtxTracksSize, VtxTracksSizeBS, reco::LeafCandidate::vx(), reco::LeafCandidate::vy(), reco::LeafCandidate::vz(), wenuCollectionTag_, x, detailsBasic3DVector::y, and detailsBasic3DVector::z.

206 {
207  using namespace std;
208  //
209  // Get the collections here
210  //
212  iEvent.getByLabel(wenuCollectionTag_, WenuCands);
213 
214  if (not WenuCands.isValid()) {
215  cout << "Warning: no wenu candidates in this event..." << endl;
216  return;
217  }
218  const pat::CompositeCandidateCollection *wcands = WenuCands.product();
219  const pat::CompositeCandidateCollection::const_iterator
220  wenuIter = wcands->begin();
221  const pat::CompositeCandidate wenu = *wenuIter;
222  //
223  // get the parts of the composite candidate:
224  const pat::Electron * myElec=
225  dynamic_cast<const pat::Electron*> (wenu.daughter("electron"));
226  const pat::MET * myMet=
227  dynamic_cast<const pat::MET*> (wenu.daughter("met"));
228  const pat::MET * myPfMet=
229  dynamic_cast<const pat::MET*> (wenu.daughter("pfmet"));
230  const pat::MET * myTcMet=
231  dynamic_cast<const pat::MET*> (wenu.daughter("tcmet"));
232  // _______________________________________________________________________
233  //
234  // VBTF Root tuple production --------------------------------------------
235  // _______________________________________________________________________
236  //
237  // .......................................................................
238  // vbtf produces 2 root tuples: one that contains the highest pT electron
239  // that passes a user defined selection and one other with only the
240  // preselection criteria applied
241  // .......................................................................
242  //
243  // fill the tree variables
244  runNumber = iEvent.run();
245  eventNumber = Long64_t( iEvent.eventAuxiliary().event() );
246  lumiSection = (Int_t) iEvent.luminosityBlock();
247  //
248  ele_sc_eta = (Float_t) myElec->superCluster()->eta();
249  ele_sc_phi = (Float_t) myElec->superCluster()->phi();
250  double scx = myElec->superCluster()->x();
251  double scy = myElec->superCluster()->y();
252  double scz = myElec->superCluster()->z();
253  ele_sc_rho = (Float_t) sqrt( scx*scx + scy*scy + scz*scz );
254  ele_sc_energy = (Float_t) myElec->superCluster()->energy();
255  ele_sc_gsf_et = (Float_t) myElec->superCluster()->energy()/TMath::CosH(myElec->gsfTrack()->eta());
256  ele_cand_eta = (Float_t) myElec->eta();
257  ele_cand_phi = (Float_t) myElec->phi();
258  ele_cand_et = (Float_t) myElec->et();
259  //
260  ele_iso_track = (Float_t) myElec->dr03IsolationVariables().tkSumPt / ele_cand_et;
261  ele_iso_ecal = (Float_t) myElec->dr03IsolationVariables().ecalRecHitSumEt/ele_cand_et;
262  ele_iso_hcal = (Float_t) ( myElec->dr03IsolationVariables().hcalDepth1TowerSumEt +
263  myElec->dr03IsolationVariables().hcalDepth2TowerSumEt) / ele_cand_et;
264  //
265  ele_id_sihih = (Float_t) myElec->sigmaIetaIeta();
266  ele_id_deta = (Float_t) myElec->deltaEtaSuperClusterTrackAtVtx();
267  ele_id_dphi = (Float_t) myElec->deltaPhiSuperClusterTrackAtVtx();
268  ele_id_hoe = (Float_t) myElec->hadronicOverEm();
269  //
270  ele_cr_mhitsinner= myElec->gsfTrack()->trackerExpectedHitsInner().numberOfHits();
271  ele_cr_dcot = myElec->convDcot();
272  ele_cr_dist = myElec->convDist();
273  //
274  ele_vx = (Float_t) myElec->vx();
275  ele_vy = (Float_t) myElec->vy();
276  ele_vz = (Float_t) myElec->vz();
277  // get the primary vtx information
278  // no BS
281  const std::vector<reco::Vertex> Vtx = *(pVtx.product());
282  // with BS
285  const std::vector<reco::Vertex> VtxBS = *(pVtxBS.product());
286  if (Vtx.size() > 0) {
287  pv_x = Float_t(Vtx[0].position().x());
288  pv_y = Float_t(Vtx[0].position().y());
289  pv_z = Float_t(Vtx[0].position().z());
290  ele_tip_pv = myElec->gsfTrack()->dxy(Vtx[0].position());
291  } else {
292  pv_x = -999999.;
293  pv_y = -999999.;
294  pv_z = -999999.;
295  ele_tip_pv = -999999.;
296  }
297  if (VtxBS.size() > 0) {
298  pvbs_x = Float_t(VtxBS[0].position().x());
299  pvbs_y = Float_t(VtxBS[0].position().y());
300  pvbs_z = Float_t(VtxBS[0].position().z());
301  ele_tip_pvbs = myElec->gsfTrack()->dxy(VtxBS[0].position());
302  } else {
303  pvbs_x = -999999.;
304  pvbs_y = -999999.;
305  pvbs_z = -999999.;
306  ele_tip_pvbs = -999999.;
307  }
308 
309  //
310  ele_gsfCharge = (Int_t) myElec->gsfTrack()->charge();
311  // must keep the ctf track collection, i.e. general track collection
312  ele_ctfCharge = (Int_t) myElec->closestCtfTrackRef().isNonnull() ? myElec->closestCtfTrackRef()->charge():-9999;
313  ele_scPixCharge = (Int_t) myElec->chargeInfo().scPixCharge;
314  ele_eop = (Float_t) myElec->eSuperClusterOverP();
315  ele_tip_bs = (Float_t) -myElec->dB();
316  //ele_tip_pv = myElec->userFloat("ele_tip_pv");
317  ele_pin = (Float_t) myElec->trackMomentumAtVtx().R();
318  ele_pout = (Float_t) myElec->trackMomentumOut().R();
319  //
320  event_caloMET = (Float_t) myMet->et();
321  event_pfMET = (Float_t) myPfMet->et();
322  event_tcMET = (Float_t) myTcMet->et();
323  event_caloMET_phi= (Float_t) myMet->phi();
324  event_pfMET_phi = (Float_t) myPfMet->phi();
325  event_tcMET_phi = (Float_t) myTcMet->phi();
326  event_caloSumEt = (Float_t) myMet->sumEt();
327  event_pfSumEt = (Float_t) myPfMet->sumEt();
328  event_tcSumEt = (Float_t) myTcMet->sumEt();
329  // transverse mass for the user's convenience
330  event_caloMT = (Float_t) TMath::Sqrt(2.*(ele_sc_gsf_et*event_caloMET -
332  + ele_sc_gsf_et*TMath::Sin(ele_sc_phi)*event_caloMET*TMath::Sin(event_caloMET_phi)
333  ) ) );
334  event_pfMT = (Float_t) TMath::Sqrt(2.*(ele_sc_gsf_et*event_pfMET -
335  (ele_sc_gsf_et*TMath::Cos(ele_sc_phi)*event_pfMET*TMath::Cos(event_pfMET_phi)
336  + ele_sc_gsf_et*TMath::Sin(ele_sc_phi)*event_pfMET*TMath::Sin(event_pfMET_phi)
337  ) ) );
338  event_tcMT = (Float_t) TMath::Sqrt(2.*(ele_sc_gsf_et*event_tcMET -
339  (ele_sc_gsf_et*TMath::Cos(ele_sc_phi)*event_tcMET*TMath::Cos(event_tcMET_phi)
340  + ele_sc_gsf_et*TMath::Sin(ele_sc_phi)*event_tcMET*TMath::Sin(event_tcMET_phi)
341  ) ) );
343  // jet information - only if the user asks for it
344  // keep the 5 highest et jets of the event that are further than DR> DRJetFromElectron_
346  // initialize the array of the jet information
347  for (int i=0; i<5; ++i) {
348  calojet_et[i] = -999999; calojet_eta[i] = -999999; calojet_phi[i] = -999999;
349  pfjet_et[i] = -999999; pfjet_eta[i] = -999999; pfjet_phi[i] = -999999;
350  }
351  // get hold of the jet collections
354  iEvent.getByLabel(caloJetCollectionTag_, pCaloJets);
355  iEvent.getByLabel(pfJetCollectionTag_, pPfJets);
356  //
357  // calo jets now:
358  if (pCaloJets.isValid()) {
359  const reco::CaloJetCollection *caloJets = pCaloJets.product();
360  int nCaloJets = (int) caloJets->size();
361  if (nCaloJets>0) {
362  float *nCaloET = new float[nCaloJets];
363  float *nCaloEta = new float[nCaloJets];
364  float *nCaloPhi = new float[nCaloJets];
365  reco::CaloJetCollection::const_iterator cjet = caloJets->begin();
366  int counter = 0;
367  for (; cjet != caloJets->end(); ++cjet) {
368  // store them only if they are far enough from the electron
369  Double_t DR = reco::deltaR(cjet->eta(), cjet->phi(), myElec->gsfTrack()->eta(), ele_sc_phi);
370  if (DR > DRJetFromElectron_) {
371  nCaloET[counter] = cjet->et();
372  nCaloEta[counter] = cjet->eta();
373  nCaloPhi[counter] = cjet->phi();
374  ++counter;
375  }
376  }
377  int *caloJetSorted = new int[nCaloJets];
378  TMath::Sort(nCaloJets, nCaloET, caloJetSorted, true);
379  for (int i=0; i<nCaloJets; ++i) {
380  if (i>=5) break;
381  calojet_et[i] = nCaloET[ caloJetSorted[i] ];
382  calojet_eta[i] = nCaloEta[ caloJetSorted[i] ];
383  calojet_phi[i] = nCaloPhi[ caloJetSorted[i] ];
384  }
385  delete [] caloJetSorted;
386  delete [] nCaloET;
387  delete [] nCaloEta;
388  delete [] nCaloPhi;
389  }
390  } else {
391  std::cout << "WenuPlots: Could not get caloJet collection with name "
392  << caloJetCollectionTag_ << std::endl;
393  }
394  //
395  // pf jets now:
396  if (pPfJets.isValid()) {
397  const reco::PFJetCollection *pfJets = pPfJets.product();
398  int nPfJets = (int) pfJets->size();
399  if (nPfJets>0) {
400  float *nPfET = new float[nPfJets];
401  float *nPfEta = new float[nPfJets];
402  float *nPfPhi = new float[nPfJets];
403  reco::PFJetCollection::const_iterator pjet = pfJets->begin();
404  int counter = 0;
405  for (; pjet != pfJets->end(); ++pjet) {
406  // store them only if they are far enough from the electron
407  Double_t DR = reco::deltaR(pjet->eta(), pjet->phi(), myElec->gsfTrack()->eta(), ele_sc_phi);
408  if (DR > DRJetFromElectron_) {
409  nPfET[counter] = pjet->et();
410  nPfEta[counter] = pjet->eta();
411  nPfPhi[counter] = pjet->phi();
412  ++counter;
413  }
414  }
415  int *pfJetSorted = new int[nPfJets];
416  TMath::Sort(nPfJets, nPfET, pfJetSorted, true);
417  for (int i=0; i<nPfJets; ++i) {
418  if (i>=5) break;
419  pfjet_et[i] = nPfET[ pfJetSorted[i] ];
420  pfjet_eta[i] = nPfEta[ pfJetSorted[i] ];
421  pfjet_phi[i] = nPfPhi[ pfJetSorted[i] ];
422  }
423  delete [] pfJetSorted;
424  delete [] nPfET;
425  delete [] nPfEta;
426  delete [] nPfPhi;
427  }
428  } else {
429  std::cout << "WenuPlots: Could not get pfJet collection with name "
430  << pfJetCollectionTag_ << std::endl;
431  }
432 
433  }
434  // second electron information - in preselected ntuple only
435  ele2nd_sc_gsf_et = -1; // also in sele tree
436  ele2nd_sc_eta = -1;
437  ele2nd_sc_phi = -1;
438  ele2nd_sc_rho = 0;
439  ele2nd_cand_eta = 0;
440  ele2nd_cand_phi = 0;
441  ele2nd_cand_et = 0;
442  ele2nd_pin = 0;
443  ele2nd_pout = 0;
444  ele2nd_passes_selection = -1; // also in sele tree
445  ele2nd_ecalDriven= 0;
446  //
447  // second electron selection variables: only if requested by the user
448  //
449  ele2nd_iso_track = 0;
450  ele2nd_iso_ecal = 0;
451  ele2nd_iso_hcal = 0;
452  //
453  ele2nd_id_sihih = 0;
454  ele2nd_id_deta = 0;
455  ele2nd_id_dphi = 0;
456  ele2nd_id_hoe = 0;
457  //
459  ele2nd_cr_dcot = 0;
460  ele2nd_cr_dist = 0;
461  //
462  ele2nd_vx = 0;
463  ele2nd_vy = 0;
464  ele2nd_vz = 0;
465  //
466  ele2nd_gsfCharge = 0;
467  // must keep the ctf track collection, i.e. general track collection
468  ele2nd_ctfCharge = 0;
469  ele2nd_scPixCharge = 0;
470  ele2nd_eop = 0;
471  ele2nd_tip_bs = 0;
472  ele2nd_tip_pv = 0;
474  //
475  // convention for ele2nd_passes_selection
476  // 0 passes no selection
477  // 1 passes WP95
478  // 2 passes WP90
479  // 3 passes WP85
480  // 4 passes WP80
481  // 5 passes WP70
482  // 6 passes WP60
483  if (myElec->userInt("hasSecondElectron") == 1 && storeExtraInformation_) {
484  const pat::Electron * mySecondElec=
485  dynamic_cast<const pat::Electron*> (wenu.daughter("secondElec"));
486  ele2nd_sc_gsf_et = (Float_t) mySecondElec->superCluster()->energy()/TMath::CosH(mySecondElec->gsfTrack()->eta());
487 
488  ele2nd_sc_eta = (Float_t) mySecondElec->superCluster()->eta();
489  ele2nd_sc_phi = (Float_t) mySecondElec->superCluster()->phi();
490  double sc2x = mySecondElec->superCluster()->x();
491  double sc2y = mySecondElec->superCluster()->y();
492  double sc2z = mySecondElec->superCluster()->z();
493  ele2nd_sc_rho = (Float_t) sqrt(sc2x*sc2x + sc2y*sc2y + sc2z*sc2z);
494  ele2nd_cand_eta = (Float_t) mySecondElec->eta();
495  ele2nd_cand_phi = (Float_t) mySecondElec->phi();
496  ele2nd_cand_et = (Float_t) mySecondElec->et();
497  ele2nd_pin = (Float_t) mySecondElec->trackMomentumAtVtx().R();;
498  ele2nd_pout = (Float_t) mySecondElec->trackMomentumOut().R();
499  ele2nd_ecalDriven= (Int_t) mySecondElec->ecalDrivenSeed();
500  // check the selections
501  bool isIDCalc = mySecondElec->isElectronIDAvailable("simpleEleId95relIso") &&
502  mySecondElec->isElectronIDAvailable("simpleEleId90relIso") &&
503  mySecondElec->isElectronIDAvailable("simpleEleId85relIso") &&
504  mySecondElec->isElectronIDAvailable("simpleEleId80relIso") &&
505  mySecondElec->isElectronIDAvailable("simpleEleId70relIso") &&
506  mySecondElec->isElectronIDAvailable("simpleEleId60relIso");
507  if (isIDCalc) {
509  if (fabs(mySecondElec->electronID("simpleEleId60relIso")-7) < 0.1) ele2nd_passes_selection = 6;
510  else if (fabs(mySecondElec->electronID("simpleEleId70relIso")-7) < 0.1) ele2nd_passes_selection = 5;
511  else if (fabs(mySecondElec->electronID("simpleEleId80relIso")-7) < 0.1) ele2nd_passes_selection = 4;
512  else if (fabs(mySecondElec->electronID("simpleEleId85relIso")-7) < 0.1) ele2nd_passes_selection = 3;
513  else if (fabs(mySecondElec->electronID("simpleEleId90relIso")-7) < 0.1) ele2nd_passes_selection = 2;
514  else if (fabs(mySecondElec->electronID("simpleEleId95relIso")-7) < 0.1) ele2nd_passes_selection = 1;
515  }
517  ele2nd_iso_track = (Float_t) mySecondElec->dr03IsolationVariables().tkSumPt / ele2nd_cand_et;
519  ele2nd_iso_hcal = (Float_t) ( mySecondElec->dr03IsolationVariables().hcalDepth1TowerSumEt +
521  ele2nd_id_sihih = (Float_t) mySecondElec->sigmaIetaIeta();
522  ele2nd_id_deta = (Float_t) mySecondElec->deltaEtaSuperClusterTrackAtVtx();
523  ele2nd_id_dphi = (Float_t) mySecondElec->deltaPhiSuperClusterTrackAtVtx();
524  ele2nd_id_hoe = (Float_t) mySecondElec->hadronicOverEm();
525 
526  ele2nd_cr_mhitsinner = mySecondElec->gsfTrack()->trackerExpectedHitsInner().numberOfHits();
527  ele2nd_cr_dcot = mySecondElec->convDcot();
528  ele2nd_cr_dist = mySecondElec->convDist();
529 
530  ele2nd_vx = (Float_t) mySecondElec->vx();
531  ele2nd_vy = (Float_t) mySecondElec->vy();
532  ele2nd_vz = (Float_t) mySecondElec->vz();
533  ele2nd_gsfCharge = (Int_t) mySecondElec->gsfTrack()->charge();
534  // must keep the ctf track collection, i.e. general track collection
535  ele2nd_ctfCharge = (Int_t) mySecondElec->closestCtfTrackRef().isNonnull() ? mySecondElec->closestCtfTrackRef()->charge():-9999;
536  ele2nd_scPixCharge = (Int_t) mySecondElec->chargeInfo().scPixCharge;
537  ele2nd_eop = (Float_t) mySecondElec->eSuperClusterOverP();
538  ele2nd_tip_bs = (Float_t) -mySecondElec->dB();
539  if (Vtx.size() > 0) {
540  ele2nd_tip_pv = mySecondElec->gsfTrack()->dxy(Vtx[0].position());
541  }
542  if (VtxBS.size() > 0) {
543  ele2nd_tip_pvbs = mySecondElec->gsfTrack()->dxy(VtxBS[0].position());
544  }
545  ele2nd_hltmatched_dr = mySecondElec->userFloat("HLTMatchingDR");
546  }
547  }
548  // some extra information
550  ele_hltmatched_dr = -999.;
551  VtxTracksSize.clear();
552  VtxNormalizedChi2.clear();
553  VtxTracksSizeBS.clear();
554  VtxNormalizedChi2BS.clear();
556  if (myElec->hasUserFloat("HLTMatchingDR")) {
557  ele_hltmatched_dr = myElec->userFloat("HLTMatchingDR");
558  }
559  if (myElec->hasUserInt("triggerDecision")) {
560  event_triggerDecision = myElec->userInt("triggerDecision");
561  }
562  // extra information related to the primary vtx collection
563  for (Int_t i=0; i < (Int_t) Vtx.size(); ++i) {
564  VtxTracksSize.push_back(Vtx[i].tracksSize());
565  VtxNormalizedChi2.push_back(Vtx[i].normalizedChi2());
566  }
567  for (Int_t i=0; i < (Int_t) VtxBS.size(); ++i) {
568  VtxTracksSizeBS.push_back(VtxBS[i].tracksSize());
569  VtxNormalizedChi2BS.push_back(VtxBS[i].normalizedChi2());
570  }
571  }
572  // if the electron passes the selection
573  // it is meant to be a precalculated selection here, in order to include
574  // conversion rejection too
575  if (CheckCuts(myElec) && myElec->userInt("failsSecondElectronCut") == 0) {
576  vbtfSele_tree->Fill();
577  }
578  vbtfPresele_tree->Fill();
579 
580 
581 
582  //
583  // _______________________________________________________________________
584  //
585  // histogram production --------------------------------------------------
586  // _______________________________________________________________________
587  //
588  // if you want some preselection: Conv rejection, hit pattern
589  if (usePreselection_) {
590  if (not PassPreselectionCriteria(myElec)) return;
591  }
592  //
593  // some variables here
594  Double_t scEta = myElec->superCluster()->eta();
595  Double_t scPhi = myElec->superCluster()->phi();
596  Double_t scEt = myElec->superCluster()->energy()/TMath::CosH(scEta);
597  Double_t met = myMet->et();
598  Double_t metPhi = myMet->phi();
599  Double_t mt = TMath::Sqrt(2.0*scEt*met*(1.0-(TMath::Cos(scPhi)*TMath::Cos(metPhi)+TMath::Sin(scPhi)*TMath::Sin(metPhi))));
600 
601  Double_t trackIso = myElec->userIsolation(pat::TrackIso);
602  Double_t ecalIso = myElec->userIsolation(pat::EcalIso);
603  Double_t hcalIso = myElec->userIsolation(pat::HcalIso);
604  Double_t sihih = myElec->scSigmaIEtaIEta();
605  Double_t dphi = myElec->deltaPhiSuperClusterTrackAtVtx();
606  Double_t deta = myElec->deltaEtaSuperClusterTrackAtVtx();
607  Double_t HoE = myElec->hadronicOverEm();
608  //
609  //
610  //
611  // the inverted selection plots:
612  // only if not using precalcID
613  if (not usePrecalcID_) {
614  if (CheckCutsInverse(myElec)){
615  //std::cout << "-----------------INVERSION-----------passed" << std::endl;
616  h_met_inverse->Fill(met);
617  h_mt_inverse->Fill(mt);
618  if(TMath::Abs(scEta)<1.479){
619  h_met_inverse_EB->Fill(met);
620  h_mt_inverse_EB->Fill(mt);
621  }
622  if(TMath::Abs(scEta)>1.479){
623  h_met_inverse_EE->Fill(met);
624  h_mt_inverse_EE->Fill(mt);
625  }
626  }
627  }
628  //
630  //
631  // N-1 plots: plot some variable so that all the other cuts are satisfied
632  //
633  // make these plots only if you have the normal selection, not pre-calced
634  if (not usePrecalcID_) {
635  if ( TMath::Abs(scEta) < 1.479) { // reminder: the precise fiducial cuts are in
636  // in the filter
637  if (CheckCutsNminusOne(myElec, 0))
638  h_trackIso_eb_NmOne->Fill(trackIso);
639  }
640  else {
641  if (CheckCutsNminusOne(myElec, 0))
642  h_trackIso_ee_NmOne->Fill(trackIso);
643  }
644  }
645  //
646  // SELECTION APPLICATION
647  //
648  // from here on you have only events that pass the full selection
649  if (not CheckCuts(myElec)) return;
651 
652  h_met->Fill(met);
653  h_mt->Fill(mt);
654  if(TMath::Abs(scEta)<1.479){
655  h_met_EB->Fill(met);
656  h_mt_EB->Fill(mt);
657 
658  h_EB_trkiso->Fill( trackIso );
659  h_EB_ecaliso->Fill( ecalIso );
660  h_EB_hcaliso->Fill( hcalIso );
661  h_EB_sIetaIeta->Fill( sihih );
662  h_EB_dphi->Fill( dphi );
663  h_EB_deta->Fill( deta );
664  h_EB_HoE->Fill( HoE );
665 
666  }
667  if(TMath::Abs(scEta)>1.479){
668  h_met_EE->Fill(met);
669  h_mt_EE->Fill(mt);
670 
671  h_EE_trkiso->Fill( trackIso );
672  h_EE_ecaliso->Fill( ecalIso );
673  h_EE_hcaliso->Fill( hcalIso );
674  h_EE_sIetaIeta->Fill( sihih );
675  h_EE_dphi->Fill( dphi );
676  h_EE_deta->Fill( deta );
677  h_EE_HoE->Fill( HoE );
678 
679  }
680  // uncomment for debugging purposes
681  /*
682  std::cout << "tracIso: " << trackIso << ", " << myElec->trackIso() << ", ecaliso: " << ecalIso
683  << ", " << myElec->ecalIso() << ", hcaliso: " << hcalIso << ", " << myElec->hcalIso()
684  << ", mishits: "
685  << myElec->gsfTrack()->trackerExpectedHitsInner().numberOfHits()
686  << std::endl;
687  std::cout << "Electron ID: 95relIso=" << myElec->electronID("simpleEleId95relIso")
688  << " 90relIso=" << myElec->electronID("simpleEleId90relIso")
689  << " 85relIso=" << myElec->electronID("simpleEleId85relIso")
690  << " 80relIso=" << myElec->electronID("simpleEleId80relIso")
691  << " 70relIso=" << myElec->electronID("simpleEleId70relIso")
692  << " 60relIso=" << myElec->electronID("simpleEleId60relIso")
693  << " 95cIso=" << myElec->electronID("simpleEleId95cIso")
694  << " 90cIso=" << myElec->electronID("simpleEleId90cIso")
695  << " 85cIso=" << myElec->electronID("simpleEleId85cIso")
696  << " 80cIso=" << myElec->electronID("simpleEleId80cIso")
697  << " 70cIso=" << myElec->electronID("simpleEleId70cIso")
698  << " 60cIso=" << myElec->electronID("simpleEleId60cIso")
699  << std::endl;
700  std::cout << "mySelection: " << (CheckCuts(myElec) && PassPreselectionCriteria(myElec)) << endl;
701  */
702  h_scEt->Fill(scEt);
703  h_scEta->Fill(scEta);
704  h_scPhi->Fill(scPhi);
705 
706 }
Float_t ele_vy
Definition: WenuPlots.h:196
TH1F * h_mt_inverse_EE
Definition: WenuPlots.h:88
Analysis-level particle class.
Analysis-level MET class.
Definition: MET.h:42
Float_t ele2nd_cr_dcot
Definition: WenuPlots.h:240
Int_t ele2nd_ctfCharge
Definition: WenuPlots.h:242
Float_t ele2nd_id_deta
Definition: WenuPlots.h:239
virtual double et() const GCC11_FINAL
transverse energy
int i
Definition: DBlmapReader.cc:9
Float_t ele2nd_sc_gsf_et
Definition: WenuPlots.h:211
Bool_t PassPreselectionCriteria(const pat::Electron *ele)
Definition: WenuPlots.cc:819
Float_t ele_iso_ecal
Definition: WenuPlots.h:192
TH1F * h_met_inverse_EB
Definition: WenuPlots.h:81
edm::InputTag wenuCollectionTag_
Definition: WenuPlots.h:64
float eSuperClusterOverP() const
Definition: GsfElectron.h:229
reco::TrackRef closestCtfTrackRef() const
override the reco::GsfElectron::closestCtfTrackRef method, to access the internal storage of the trac...
Definition: Electron.cc:177
Float_t event_caloMET
Definition: WenuPlots.h:201
Float_t ele_iso_hcal
Definition: WenuPlots.h:192
Float_t ele2nd_tip_bs
Definition: WenuPlots.h:243
Float_t ele2nd_id_hoe
Definition: WenuPlots.h:239
Float_t ele_eop
Definition: WenuPlots.h:200
TH1F * h_EE_trkiso
Definition: WenuPlots.h:103
Float_t pfjet_eta[5]
Definition: WenuPlots.h:209
Float_t ele2nd_eop
Definition: WenuPlots.h:243
TH1F * h_EB_HoE
Definition: WenuPlots.h:101
TH1F * h_met_EB
Definition: WenuPlots.h:80
Float_t pvbs_z
Definition: WenuPlots.h:249
Int_t lumiSection
Definition: WenuPlots.h:187
Float_t event_tcMET_phi
Definition: WenuPlots.h:203
Int_t ele2nd_passes_selection
Definition: WenuPlots.h:219
TH1F * h_mt
Definition: WenuPlots.h:77
Float_t ele_vz
Definition: WenuPlots.h:196
Float_t ele_pout
Definition: WenuPlots.h:197
reco::SuperClusterRef superCluster() const
override the reco::GsfElectron::superCluster method, to access the internal storage of the superclust...
Definition: Electron.cc:150
Float_t ele_sc_rho
Definition: WenuPlots.h:189
Int_t ele2nd_scPixCharge
Definition: WenuPlots.h:242
Float_t event_caloMET_phi
Definition: WenuPlots.h:203
Float_t ele_id_dphi
Definition: WenuPlots.h:193
TH1F * h_trackIso_ee_NmOne
Definition: WenuPlots.h:113
math::XYZVectorF trackMomentumAtVtx() const
Definition: GsfElectron.h:272
Float_t ele_cr_dist
Definition: WenuPlots.h:194
edm::LuminosityBlockNumber_t luminosityBlock() const
Definition: EventBase.h:59
TH1F * h_scPhi
Definition: WenuPlots.h:93
Int_t ele2nd_ecalDriven
Definition: WenuPlots.h:220
Int_t ele_gsfCharge
Definition: WenuPlots.h:199
reco::GsfTrackRef gsfTrack() const
override the reco::GsfElectron::gsfTrack method, to access the internal storage of the supercluster ...
Definition: Electron.cc:131
Float_t calojet_eta[5]
Definition: WenuPlots.h:206
Bool_t includeJetInformationInNtuples_
Definition: WenuPlots.h:231
Int_t runNumber
Definition: WenuPlots.h:187
TTree * vbtfSele_tree
Definition: WenuPlots.h:227
TH1F * h_EB_trkiso
Definition: WenuPlots.h:95
Float_t ele2nd_pout
Definition: WenuPlots.h:218
Float_t pv_x
Definition: WenuPlots.h:198
Bool_t usePreselection_
Definition: WenuPlots.h:62
Float_t ele2nd_vy
Definition: WenuPlots.h:241
Float_t event_caloSumEt
Definition: WenuPlots.h:202
Float_t ele2nd_sc_eta
Definition: WenuPlots.h:212
Bool_t CheckCutsInverse(const pat::Electron *ele)
Definition: WenuPlots.cc:752
Float_t ele2nd_sc_phi
Definition: WenuPlots.h:213
float convDist() const
Definition: GsfElectron.h:498
Bool_t CheckCuts(const pat::Electron *ele)
Definition: WenuPlots.cc:723
Float_t ele_sc_eta
Definition: WenuPlots.h:189
virtual double vy() const
y coordinate of vertex position
TH1F * h_EE_sIetaIeta
Definition: WenuPlots.h:106
Float_t ele2nd_vx
Definition: WenuPlots.h:241
Float_t ele2nd_id_sihih
Definition: WenuPlots.h:239
Float_t event_pfMET
Definition: WenuPlots.h:201
float float float z
static int position[TOTALCHAMBERS][3]
Definition: ReadPGInfo.cc:509
float userFloat(const std::string &key) const
Definition: PATObject.h:753
TH1F * h_EB_sIetaIeta
Definition: WenuPlots.h:98
Int_t DatasetTag_
Definition: WenuPlots.h:234
Float_t ele2nd_cand_phi
Definition: WenuPlots.h:216
Float_t pv_y
Definition: WenuPlots.h:198
Float_t ele_sc_phi
Definition: WenuPlots.h:189
float convDcot() const
Definition: GsfElectron.h:499
TH1F * h_met_EE
Definition: WenuPlots.h:85
TH1F * h_met
Definition: WenuPlots.h:75
TH1F * h_EB_ecaliso
Definition: WenuPlots.h:96
Float_t ele_id_deta
Definition: WenuPlots.h:193
bool isNonnull() const
Checks for non-null.
Definition: Ref.h:250
TH1F * h_scEt
Definition: WenuPlots.h:91
Float_t ele2nd_cand_et
Definition: WenuPlots.h:237
Float_t ele_cand_et
Definition: WenuPlots.h:191
virtual float phi() const GCC11_FINAL
momentum azimuthal angle
float deltaEtaSuperClusterTrackAtVtx() const
Definition: GsfElectron.h:233
TH1F * h_EE_ecaliso
Definition: WenuPlots.h:104
TH1F * h_EB_hcaliso
Definition: WenuPlots.h:97
float sigmaIetaIeta() const
Definition: GsfElectron.h:382
Float_t ele2nd_pin
Definition: WenuPlots.h:217
float hadronicOverEm() const
Definition: GsfElectron.h:403
TH1F * h_met_inverse
Definition: WenuPlots.h:76
Float_t ele2nd_tip_pvbs
Definition: WenuPlots.h:250
Int_t event_triggerDecision
Definition: WenuPlots.h:222
Float_t ele2nd_hltmatched_dr
Definition: WenuPlots.h:244
edm::InputTag PrimaryVerticesCollectionBS_
Definition: WenuPlots.h:68
Float_t pvbs_x
Definition: WenuPlots.h:249
T sqrt(T t)
Definition: SSEVec.h:48
Float_t ele2nd_sc_rho
Definition: WenuPlots.h:214
Float_t ele2nd_cand_eta
Definition: WenuPlots.h:215
math::XYZVectorF trackMomentumOut() const
Definition: GsfElectron.h:274
float deltaPhiSuperClusterTrackAtVtx() const
Definition: GsfElectron.h:236
Float_t ele_hltmatched_dr
Definition: WenuPlots.h:221
Float_t ele_vx
Definition: WenuPlots.h:196
TH1F * h_met_inverse_EE
Definition: WenuPlots.h:86
TH1F * h_mt_inverse
Definition: WenuPlots.h:78
TH1F * h_EE_dphi
Definition: WenuPlots.h:107
Float_t ele_tip_pvbs
Definition: WenuPlots.h:250
RunNumber_t run() const
Definition: Event.h:76
edm::InputTag caloJetCollectionTag_
Definition: WenuPlots.h:65
Float_t ele_id_hoe
Definition: WenuPlots.h:193
auto deltaR(const T1 &t1, const T2 &t2) -> decltype(t1.eta())
Definition: deltaR.h:30
Int_t ele_scPixCharge
Definition: WenuPlots.h:199
std::vector< Int_t > VtxTracksSizeBS
Definition: WenuPlots.h:247
Bool_t storeAllSecondElectronVariables_
Definition: WenuPlots.h:236
Float_t calojet_phi[5]
Definition: WenuPlots.h:207
std::vector< Int_t > VtxTracksSize
Definition: WenuPlots.h:245
TH1F * h_EB_deta
Definition: WenuPlots.h:100
Float_t ele_tip_pv
Definition: WenuPlots.h:200
bool isValid() const
Definition: HandleBase.h:76
virtual double vz() const
z coordinate of vertex position
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:361
TH1F * h_scEta
Definition: WenuPlots.h:92
Float_t ele2nd_iso_hcal
Definition: WenuPlots.h:238
Float_t pfjet_phi[5]
Definition: WenuPlots.h:210
Float_t ele_iso_track
Definition: WenuPlots.h:192
Int_t ele2nd_gsfCharge
Definition: WenuPlots.h:242
TTree * vbtfPresele_tree
Definition: WenuPlots.h:228
Int_t event_datasetTag
Definition: WenuPlots.h:223
Float_t ele_pin
Definition: WenuPlots.h:197
TH1F * h_EB_dphi
Definition: WenuPlots.h:99
virtual float eta() const GCC11_FINAL
momentum pseudorapidity
Float_t event_tcSumEt
Definition: WenuPlots.h:202
Int_t ele_cr_mhitsinner
Definition: WenuPlots.h:195
TH1F * h_trackIso_eb_NmOne
Definition: WenuPlots.h:112
EventAuxiliary const & eventAuxiliary() const
Definition: Event.h:65
Float_t pv_z
Definition: WenuPlots.h:198
const ChargeInfo & chargeInfo() const
Definition: GsfElectron.h:142
Float_t ele2nd_iso_track
Definition: WenuPlots.h:238
float electronID(const std::string &name) const
Returns a specific electron ID associated to the pat::Electron given its name.
Definition: Electron.cc:315
Bool_t CheckCutsNminusOne(const pat::Electron *ele, Int_t jj)
Definition: WenuPlots.cc:761
std::vector< CompositeCandidate > CompositeCandidateCollection
edm::InputTag PrimaryVerticesCollection_
Definition: WenuPlots.h:67
Float_t ele_cand_eta
Definition: WenuPlots.h:191
Float_t pfjet_et[5]
Definition: WenuPlots.h:208
Bool_t storeExtraInformation_
Definition: WenuPlots.h:232
Float_t ele2nd_vz
Definition: WenuPlots.h:241
Int_t ele_ctfCharge
Definition: WenuPlots.h:199
Analysis-level electron class.
Definition: Electron.h:52
Float_t event_pfMT
Definition: WenuPlots.h:204
Float_t event_tcMT
Definition: WenuPlots.h:204
T const * product() const
Definition: Handle.h:74
bool isElectronIDAvailable(const std::string &name) const
Returns true if a specific ID is available in this pat::Electron.
Definition: Electron.cc:330
edm::InputTag pfJetCollectionTag_
Definition: WenuPlots.h:66
Float_t ele_cand_phi
Definition: WenuPlots.h:191
std::vector< PFJet > PFJetCollection
collection of PFJet objects
TH1F * h_EE_deta
Definition: WenuPlots.h:108
TH1F * h_mt_inverse_EB
Definition: WenuPlots.h:83
Double_t DRJetFromElectron_
Definition: WenuPlots.h:233
const IsolationVariables & dr03IsolationVariables() const
Definition: GsfElectron.h:444
Float_t ele2nd_tip_pv
Definition: WenuPlots.h:243
Float_t ele2nd_cr_dist
Definition: WenuPlots.h:240
Float_t event_tcMET
Definition: WenuPlots.h:201
Float_t event_pfMET_phi
Definition: WenuPlots.h:203
Float_t pvbs_y
Definition: WenuPlots.h:249
Float_t event_caloMT
Definition: WenuPlots.h:204
TH1F * h_mt_EB
Definition: WenuPlots.h:82
virtual double vx() const
x coordinate of vertex position
Float_t ele2nd_id_dphi
Definition: WenuPlots.h:239
tuple cout
Definition: gather_cfg.py:121
Float_t calojet_et[5]
Definition: WenuPlots.h:205
Float_t ele_id_sihih
Definition: WenuPlots.h:193
Float_t ele_tip_bs
Definition: WenuPlots.h:200
std::vector< Float_t > VtxNormalizedChi2BS
Definition: WenuPlots.h:248
TH1F * h_mt_EE
Definition: WenuPlots.h:87
Definition: DDAxes.h:10
Int_t ele2nd_cr_mhitsinner
Definition: WenuPlots.h:242
Float_t ele2nd_iso_ecal
Definition: WenuPlots.h:238
tuple pfJets
Definition: pfJets_cff.py:8
Float_t ele_cr_dcot
Definition: WenuPlots.h:194
Float_t ele_sc_energy
Definition: WenuPlots.h:189
EventNumber_t event() const
double dB(IpType type=None) const
Impact parameter wrt primary vertex or beamspot.
Definition: Electron.cc:378
TH1F * h_EE_HoE
Definition: WenuPlots.h:109
Float_t ele_sc_gsf_et
Definition: WenuPlots.h:190
Bool_t usePrecalcID_
Definition: WenuPlots.h:53
TH1F * h_EE_hcaliso
Definition: WenuPlots.h:105
Float_t event_pfSumEt
Definition: WenuPlots.h:202
std::vector< CaloJet > CaloJetCollection
collection of CaloJet objects
bool ecalDrivenSeed() const
Definition: GsfElectron.h:172
std::vector< Float_t > VtxNormalizedChi2
Definition: WenuPlots.h:246
Long64_t eventNumber
Definition: WenuPlots.h:188
void WenuPlots::beginJob ( void  )
privatevirtual

Reimplemented from edm::EDAnalyzer.

Definition at line 861 of file WenuPlots.cc.

References calojet_et, calojet_eta, calojet_phi, cIso_EB_, cIso_EB_inv, cIso_EE_, cIso_EE_inv, CutVars_, deta_EB_, deta_EB_inv, deta_EE_, deta_EE_inv, dphi_EB_, dphi_EB_inv, dphi_EE_, dphi_EE_inv, ecalIso_EB_, ecalIso_EB_inv, ecalIso_EE_, ecalIso_EE_inv, ecalIsoUser_EB_, ecalIsoUser_EB_inv, ecalIsoUser_EE_, ecalIsoUser_EE_inv, ele2nd_cand_et, ele2nd_cand_eta, ele2nd_cand_phi, ele2nd_cr_dcot, ele2nd_cr_dist, ele2nd_cr_mhitsinner, ele2nd_ctfCharge, ele2nd_ecalDriven, ele2nd_eop, ele2nd_gsfCharge, ele2nd_hltmatched_dr, ele2nd_id_deta, ele2nd_id_dphi, ele2nd_id_hoe, ele2nd_id_sihih, ele2nd_iso_ecal, ele2nd_iso_hcal, ele2nd_iso_track, ele2nd_passes_selection, ele2nd_pin, ele2nd_pout, ele2nd_sc_eta, ele2nd_sc_gsf_et, ele2nd_sc_phi, ele2nd_sc_rho, ele2nd_scPixCharge, ele2nd_tip_bs, ele2nd_tip_pv, ele2nd_vx, ele2nd_vy, ele2nd_vz, ele_cand_et, ele_cand_eta, ele_cand_phi, ele_cr_dcot, ele_cr_dist, ele_cr_mhitsinner, ele_ctfCharge, ele_eop, ele_gsfCharge, ele_hltmatched_dr, ele_id_deta, ele_id_dphi, ele_id_hoe, ele_id_sihih, ele_iso_ecal, ele_iso_hcal, ele_iso_track, ele_pin, ele_pout, ele_sc_energy, ele_sc_eta, ele_sc_gsf_et, ele_sc_phi, ele_sc_rho, ele_scPixCharge, ele_tip_bs, ele_tip_pv, ele_vx, ele_vy, ele_vz, eop_EB_, eop_EB_inv, eop_EE_, eop_EE_inv, event_caloMET, event_caloMET_phi, event_caloMT, event_caloSumEt, event_datasetTag, event_pfMET, event_pfMET_phi, event_pfMT, event_pfSumEt, event_tcMET, event_tcMET_phi, event_tcMT, event_tcSumEt, event_triggerDecision, eventNumber, h_EB_deta, h_EB_dphi, h_EB_ecaliso, h_EB_hcaliso, h_EB_HoE, h_EB_sIetaIeta, h_EB_trkiso, h_EE_deta, h_EE_dphi, h_EE_ecaliso, h_EE_hcaliso, h_EE_HoE, h_EE_sIetaIeta, h_EE_trkiso, h_met, h_met_EB, h_met_EE, h_met_inverse, h_met_inverse_EB, h_met_inverse_EE, h_mt, h_mt_EB, h_mt_EE, h_mt_inverse, h_mt_inverse_EB, h_mt_inverse_EE, h_scEt, h_scEta, h_scPhi, h_trackIso_eb_NmOne, h_trackIso_ee_NmOne, hcalIso_EB_, hcalIso_EB_inv, hcalIso_EE_, hcalIso_EE_inv, hcalIsoUser_EB_, hcalIsoUser_EB_inv, hcalIsoUser_EE_, hcalIsoUser_EE_inv, hoe_EB_, hoe_EB_inv, hoe_EE_, hoe_EE_inv, includeJetInformationInNtuples_, InvVars_, lumiSection, nBarrelVars_, pfjet_et, pfjet_eta, pfjet_phi, pv_x, pv_y, pv_z, runNumber, sihih_EB_, sihih_EB_inv, sihih_EE_, sihih_EE_inv, storeAllSecondElectronVariables_, storeExtraInformation_, tip_bspot_EB_, tip_bspot_EB_inv, tip_bspot_EE_, tip_bspot_EE_inv, trackIso_EB_, trackIso_EB_inv, trackIso_EE_, trackIso_EE_inv, trackIsoUser_EB_, trackIsoUser_EB_inv, trackIsoUser_EE_, trackIsoUser_EE_inv, vbtfPresele_tree, vbtfSele_tree, VtxNormalizedChi2, VtxNormalizedChi2BS, VtxTracksSize, VtxTracksSizeBS, WENU_VBTFpreseleFile_, WENU_VBTFpreseleFileName_, WENU_VBTFselectionFile_, and WENU_VBTFselectionFileName_.

862 {
863  //std::cout << "In beginJob()" << std::endl;
864  // Double_t Pi = TMath::Pi();
865  // TString histo_file = outputFile_;
866  // histofile = new TFile( histo_file,"RECREATE");
867 
868  h_met = new TH1F("h_met", "h_met", 200, 0, 200);
869  h_met_inverse = new TH1F("h_met_inverse", "h_met_inverse", 200, 0, 200);
870 
871  h_mt = new TH1F("h_mt", "h_mt", 200, 0, 200);
872  h_mt_inverse = new TH1F("h_mt_inverse", "h_mt_inverse", 200, 0, 200);
873 
874 
875  h_met_EB = new TH1F("h_met_EB", "h_met_EB", 200, 0, 200);
876  h_met_inverse_EB = new TH1F("h_met_inverse_EB", "h_met_inverse_EB", 200, 0, 200);
877 
878  h_mt_EB = new TH1F("h_mt_EB", "h_mt_EB", 200, 0, 200);
879  h_mt_inverse_EB = new TH1F("h_mt_inverse_EB", "h_mt_inverse_EB", 200, 0, 200);
880 
881 
882  h_met_EE = new TH1F("h_met_EE", "h_met_EE", 200, 0, 200);
883  h_met_inverse_EE = new TH1F("h_met_inverse_EE", "h_met_inverse_EE", 200, 0, 200);
884 
885  h_mt_EE = new TH1F("h_mt_EE", "h_mt_EE", 200, 0, 200);
886  h_mt_inverse_EE = new TH1F("h_mt_inverse_EE", "h_mt_inverse_EE", 200, 0, 200);
887 
888 
889  h_scEt = new TH1F("h_scEt", "h_scEt", 200, 0, 100);
890  h_scEta = new TH1F("h_scEta", "h_scEta", 200, -3, 3);
891  h_scPhi = new TH1F("h_scPhi", "h_scPhi", 200, -4, 4);
892 
893 
894  //VALIDATION PLOTS
895  //EB
896  h_EB_trkiso = new TH1F("h_EB_trkiso","h_EB_trkiso",200 , 0.0, 9.0);
897  h_EB_ecaliso = new TH1F("h_EB_ecaliso","h_EB_ecaliso",200, 0.0 , 9.0);
898  h_EB_hcaliso = new TH1F("h_EB_hcaliso","h_EB_hcaliso",200, 0.0 , 9.0);
899  h_EB_sIetaIeta = new TH1F("h_EB_sIetaIeta","h_EB_sIetaIeta",200, 0.0 , 0.02 );
900  h_EB_dphi = new TH1F("h_EB_dphi","h_EB_dphi",200, -0.03 , 0.03 );
901  h_EB_deta = new TH1F("h_EB_deta","h_EB_deta",200, -0.01 , 0.01) ;
902  h_EB_HoE = new TH1F("h_EB_HoE","h_EB_HoE",200, 0.0 , 0.2 );
903  //EE
904  h_EE_trkiso = new TH1F("h_EE_trkiso","h_EE_trkiso",200 , 0.0, 9.0);
905  h_EE_ecaliso = new TH1F("h_EE_ecaliso","h_EE_ecaliso",200, 0.0 , 9.0);
906  h_EE_hcaliso = new TH1F("h_EE_hcaliso","h_EE_hcaliso",200, 0.0 , 9.0);
907  h_EE_sIetaIeta = new TH1F("h_EE_sIetaIeta","h_EE_sIetaIeta",200, 0.0 , 0.1 );
908  h_EE_dphi = new TH1F("h_EE_dphi","h_EE_dphi",200, -0.03 , 0.03 );
909  h_EE_deta = new TH1F("h_EE_deta","h_EE_deta",200, -0.01 , 0.01) ;
910  h_EE_HoE = new TH1F("h_EE_HoE","h_EE_HoE",200, 0.0 , 0.2 );
911 
912 
913  //
914  //
916  new TH1F("h_trackIso_eb_NmOne","trackIso EB N-1 plot",80,0,8);
918  new TH1F("h_trackIso_ee_NmOne","trackIso EE N-1 plot",80,0,8);
919 
920 
921  // if you add some new variable change the nBarrelVars_ accordingly
922  // reminder: in the current implementation you must have the same number
923  // of vars in both barrel and endcaps
924  nBarrelVars_ = 13;
925  //
926  // Put EB variables together and EE variables together
927  // number of barrel variables = number of endcap variable
928  // if you don't want to use some variable put a very high cut
929  CutVars_.push_back( trackIso_EB_ );//0
930  CutVars_.push_back( ecalIso_EB_ ); //1
931  CutVars_.push_back( hcalIso_EB_ ); //2
932  CutVars_.push_back( sihih_EB_ ); //3
933  CutVars_.push_back( dphi_EB_ ); //4
934  CutVars_.push_back( deta_EB_ ); //5
935  CutVars_.push_back( hoe_EB_ ); //6
936  CutVars_.push_back( cIso_EB_ ); //7
937  CutVars_.push_back( tip_bspot_EB_);//8
938  CutVars_.push_back( eop_EB_ ); //9
939  CutVars_.push_back( trackIsoUser_EB_ );//10
940  CutVars_.push_back( ecalIsoUser_EB_ );//11
941  CutVars_.push_back( hcalIsoUser_EB_ );//12
942  //
943  CutVars_.push_back( trackIso_EE_);//0
944  CutVars_.push_back( ecalIso_EE_); //1
945  CutVars_.push_back( hcalIso_EE_); //2
946  CutVars_.push_back( sihih_EE_); //3
947  CutVars_.push_back( dphi_EE_); //4
948  CutVars_.push_back( deta_EE_); //5
949  CutVars_.push_back( hoe_EE_ ); //6
950  CutVars_.push_back( cIso_EE_ ); //7
951  CutVars_.push_back(tip_bspot_EE_);//8
952  CutVars_.push_back( eop_EE_ ); //9
953  CutVars_.push_back( trackIsoUser_EE_ );//10
954  CutVars_.push_back( ecalIsoUser_EE_ );//11
955  CutVars_.push_back( hcalIsoUser_EE_ );//12
956  //
957  InvVars_.push_back( trackIso_EB_inv);//0
958  InvVars_.push_back( ecalIso_EB_inv); //1
959  InvVars_.push_back( hcalIso_EB_inv); //2
960  InvVars_.push_back( sihih_EB_inv); //3
961  InvVars_.push_back( dphi_EB_inv); //4
962  InvVars_.push_back( deta_EB_inv); //5
963  InvVars_.push_back( hoe_EB_inv); //6
964  InvVars_.push_back( cIso_EB_inv); //7
965  InvVars_.push_back(tip_bspot_EB_inv);//8
966  InvVars_.push_back( eop_EB_inv); //9
967  InvVars_.push_back( trackIsoUser_EB_inv );//10
968  InvVars_.push_back( ecalIsoUser_EB_inv );//11
969  InvVars_.push_back( hcalIsoUser_EB_inv );//12
970  //
971  InvVars_.push_back( trackIso_EE_inv);//0
972  InvVars_.push_back( ecalIso_EE_inv); //1
973  InvVars_.push_back( hcalIso_EE_inv); //2
974  InvVars_.push_back( sihih_EE_inv); //3
975  InvVars_.push_back( dphi_EE_inv); //4
976  InvVars_.push_back( deta_EE_inv); //5
977  InvVars_.push_back( hoe_EE_inv); //6
978  InvVars_.push_back( cIso_EE_inv); //7
979  InvVars_.push_back(tip_bspot_EE_inv);//8
980  InvVars_.push_back( eop_EE_inv); //9
981  InvVars_.push_back( trackIsoUser_EE_inv );//10
982  InvVars_.push_back( ecalIsoUser_EE_inv );//11
983  InvVars_.push_back( hcalIsoUser_EE_inv );//12
984  //
985  //
986  // ________________________________________________________________________
987  //
988  // The VBTF Root Tuples ---------------------------------------------------
989  // ________________________________________________________________________
990  //
992  "RECREATE");
993 
994  vbtfSele_tree = new TTree("vbtfSele_tree",
995  "Tree to store the W Candidates that pass the VBTF selection");
996  vbtfSele_tree->Branch("runNumber", &runNumber, "runNumber/I");
997  vbtfSele_tree->Branch("eventNumber", &eventNumber, "eventNumber/L");
998  vbtfSele_tree->Branch("lumiSection", &lumiSection, "lumiSection/I");
999  //
1000  vbtfSele_tree->Branch("ele_sc_gsf_et", &ele_sc_gsf_et,"ele_sc_gsf_et/F");
1001  vbtfSele_tree->Branch("ele_sc_energy", &ele_sc_energy,"ele_sc_energy/F");
1002  vbtfSele_tree->Branch("ele_sc_eta", &ele_sc_eta,"ele_sc_eta/F");
1003  vbtfSele_tree->Branch("ele_sc_phi", &ele_sc_phi,"ele_sc_phi/F");
1004  vbtfSele_tree->Branch("ele_sc_rho", &ele_sc_rho,"ele_sc_rho/F");
1005  vbtfSele_tree->Branch("ele_cand_et", &ele_cand_et, "ele_cand_et/F");
1006  vbtfSele_tree->Branch("ele_cand_eta", &ele_cand_eta,"ele_cand_eta/F");
1007  vbtfSele_tree->Branch("ele_cand_phi",&ele_cand_phi,"ele_cand_phi/F");
1008  vbtfSele_tree->Branch("ele_iso_track",&ele_iso_track,"ele_iso_track/F");
1009  vbtfSele_tree->Branch("ele_iso_ecal",&ele_iso_ecal,"ele_iso_ecal/F");
1010  vbtfSele_tree->Branch("ele_iso_hcal",&ele_iso_hcal,"ele_iso_hcal/F");
1011  vbtfSele_tree->Branch("ele_id_sihih",&ele_id_sihih,"ele_id_sihih/F");
1012  vbtfSele_tree->Branch("ele_id_deta",&ele_id_deta,"ele_id_deta/F");
1013  vbtfSele_tree->Branch("ele_id_dphi",&ele_id_dphi,"ele_id_dphi/F");
1014  vbtfSele_tree->Branch("ele_id_hoe",&ele_id_hoe,"ele_id_hoe/F");
1015  vbtfSele_tree->Branch("ele_cr_mhitsinner",&ele_cr_mhitsinner,"ele_cr_mhitsinner/I");
1016  vbtfSele_tree->Branch("ele_cr_dcot",&ele_cr_dcot,"ele_cr_dcot/F");
1017  vbtfSele_tree->Branch("ele_cr_dist",&ele_cr_dist,"ele_cr_dist/F");
1018  vbtfSele_tree->Branch("ele_vx",&ele_vx,"ele_vx/F");
1019  vbtfSele_tree->Branch("ele_vy",&ele_vy,"ele_vy/F");
1020  vbtfSele_tree->Branch("ele_vz",&ele_vz,"ele_vz/F");
1021  vbtfSele_tree->Branch("pv_x",&pv_x,"pv_x/F");
1022  vbtfSele_tree->Branch("pv_y",&pv_y,"pv_y/F");
1023  vbtfSele_tree->Branch("pv_z",&pv_z,"pv_z/F");
1024  vbtfSele_tree->Branch("ele_gsfCharge",&ele_gsfCharge,"ele_gsfCharge/I");
1025  vbtfSele_tree->Branch("ele_ctfCharge",&ele_ctfCharge,"ele_ctfCharge/I");
1026  vbtfSele_tree->Branch("ele_scPixCharge",&ele_scPixCharge,"ele_scPixCharge/I");
1027  vbtfSele_tree->Branch("ele_eop",&ele_eop,"ele_eop/F");
1028  vbtfSele_tree->Branch("ele_tip_bs",&ele_tip_bs,"ele_tip_bs/F");
1029  vbtfSele_tree->Branch("ele_tip_pv",&ele_tip_pv,"ele_tip_pv/F");
1030  vbtfSele_tree->Branch("ele_pin",&ele_pin,"ele_pin/F");
1031  vbtfSele_tree->Branch("ele_pout",&ele_pout,"ele_pout/F");
1032  vbtfSele_tree->Branch("event_caloMET",&event_caloMET,"event_caloMET/F");
1033  vbtfSele_tree->Branch("event_pfMET",&event_pfMET,"event_pfMET/F");
1034  vbtfSele_tree->Branch("event_tcMET",&event_tcMET,"event_tcMET/F");
1035  vbtfSele_tree->Branch("event_caloMT",&event_caloMT,"event_caloMT/F");
1036  vbtfSele_tree->Branch("event_pfMT",&event_pfMT,"event_pfMT/F");
1037  vbtfSele_tree->Branch("event_tcMT",&event_tcMT,"event_tcMT/F");
1038  vbtfSele_tree->Branch("event_caloMET_phi",&event_caloMET_phi,"event_caloMET_phi/F");
1039  vbtfSele_tree->Branch("event_pfMET_phi",&event_pfMET_phi,"event_pfMET_phi/F");
1040  vbtfSele_tree->Branch("event_tcMET_phi",&event_tcMET_phi,"event_tcMET_phi/F");
1041  //
1042  // the extra jet variables:
1044  vbtfSele_tree->Branch("calojet_et",calojet_et,"calojet_et[5]/F");
1045  vbtfSele_tree->Branch("calojet_eta",calojet_eta,"calojet_eta[5]/F");
1046  vbtfSele_tree->Branch("calojet_phi",calojet_phi,"calojet_phi[5]/F");
1047  vbtfSele_tree->Branch("pfjet_et",pfjet_et,"pfjet_et[5]/F");
1048  vbtfSele_tree->Branch("pfjet_eta",pfjet_eta,"pfjet_eta[5]/F");
1049  vbtfSele_tree->Branch("pfjet_phi",pfjet_phi,"pfjet_phi[5]/F");
1050  }
1051  if (storeExtraInformation_) {
1052  vbtfSele_tree->Branch("ele2nd_sc_gsf_et", &ele2nd_sc_gsf_et,"ele2nd_sc_gsf_et/F");
1053  vbtfSele_tree->Branch("ele2nd_passes_selection", &ele2nd_passes_selection,"ele2nd_passes_selection/I");
1054  vbtfSele_tree->Branch("ele2nd_ecalDriven",&ele2nd_ecalDriven,"ele2nd_ecalDriven/I");
1055  vbtfSele_tree->Branch("event_caloSumEt",&event_caloSumEt,"event_caloSumEt/F");
1056  vbtfSele_tree->Branch("event_pfSumEt",&event_pfSumEt,"event_pfSumEt/F");
1057  vbtfSele_tree->Branch("event_tcSumEt",&event_tcSumEt,"event_tcSumEt/F");
1058  }
1059  vbtfSele_tree->Branch("event_datasetTag",&event_datasetTag,"event_dataSetTag/I");
1060  //
1061  //
1062  // everything after preselection
1063  //
1064  WENU_VBTFpreseleFile_ = new TFile(TString(WENU_VBTFpreseleFileName_),
1065  "RECREATE");
1066 
1067  vbtfPresele_tree = new TTree("vbtfPresele_tree",
1068  "Tree to store the W Candidates that pass the VBTF preselection");
1069  vbtfPresele_tree->Branch("runNumber", &runNumber, "runNumber/I");
1070  vbtfPresele_tree->Branch("eventNumber", &eventNumber, "eventNumber/L");
1071  vbtfPresele_tree->Branch("lumiSection", &lumiSection, "lumiSection/I");
1072  //
1073  vbtfPresele_tree->Branch("ele_sc_gsf_et", &ele_sc_gsf_et,"ele_sc_gsf_et/F");
1074  vbtfPresele_tree->Branch("ele_sc_energy", &ele_sc_energy,"ele_sc_energy/F");
1075  vbtfPresele_tree->Branch("ele_sc_eta", &ele_sc_eta,"ele_sc_eta/F");
1076  vbtfPresele_tree->Branch("ele_sc_phi", &ele_sc_phi,"ele_sc_phi/F");
1077  vbtfPresele_tree->Branch("ele_sc_rho", &ele_sc_rho,"ele_sc_rho/F");
1078  vbtfPresele_tree->Branch("ele_cand_et", &ele_cand_et, "ele_cand_et/F");
1079  vbtfPresele_tree->Branch("ele_cand_eta", &ele_cand_eta,"ele_cand_eta/F");
1080  vbtfPresele_tree->Branch("ele_cand_phi",&ele_cand_phi,"ele_cand_phi/F");
1081  vbtfPresele_tree->Branch("ele_iso_track",&ele_iso_track,"ele_iso_track/F");
1082  vbtfPresele_tree->Branch("ele_iso_ecal",&ele_iso_ecal,"ele_iso_ecal/F");
1083  vbtfPresele_tree->Branch("ele_iso_hcal",&ele_iso_hcal,"ele_iso_hcal/F");
1084  vbtfPresele_tree->Branch("ele_id_sihih",&ele_id_sihih,"ele_id_sihih/F");
1085  vbtfPresele_tree->Branch("ele_id_deta",&ele_id_deta,"ele_id_deta/F");
1086  vbtfPresele_tree->Branch("ele_id_dphi",&ele_id_dphi,"ele_id_dphi/F");
1087  vbtfPresele_tree->Branch("ele_id_hoe",&ele_id_hoe,"ele_id_hoe/F");
1088  vbtfPresele_tree->Branch("ele_cr_mhitsinner",&ele_cr_mhitsinner,"ele_cr_mhitsinner/I");
1089  vbtfPresele_tree->Branch("ele_cr_dcot",&ele_cr_dcot,"ele_cr_dcot/F");
1090  vbtfPresele_tree->Branch("ele_cr_dist",&ele_cr_dist,"ele_cr_dist/F");
1091  vbtfPresele_tree->Branch("ele_vx",&ele_vx,"ele_vx/F");
1092  vbtfPresele_tree->Branch("ele_vy",&ele_vy,"ele_vy/F");
1093  vbtfPresele_tree->Branch("ele_vz",&ele_vz,"ele_vz/F");
1094  vbtfPresele_tree->Branch("pv_x",&pv_x,"pv_x/F");
1095  vbtfPresele_tree->Branch("pv_y",&pv_y,"pv_y/F");
1096  vbtfPresele_tree->Branch("pv_z",&pv_z,"pv_z/F");
1097  vbtfPresele_tree->Branch("ele_gsfCharge",&ele_gsfCharge,"ele_gsfCharge/I");
1098  vbtfPresele_tree->Branch("ele_ctfCharge",&ele_ctfCharge,"ele_ctfCharge/I");
1099  vbtfPresele_tree->Branch("ele_scPixCharge",&ele_scPixCharge,"ele_scPixCharge/I");
1100  vbtfPresele_tree->Branch("ele_eop",&ele_eop,"ele_eop/F");
1101  vbtfPresele_tree->Branch("ele_tip_bs",&ele_tip_bs,"ele_tip_bs/F");
1102  vbtfPresele_tree->Branch("ele_tip_pv",&ele_tip_pv,"ele_tip_pv/F");
1103  vbtfPresele_tree->Branch("ele_pin",&ele_pin,"ele_pin/F");
1104  vbtfPresele_tree->Branch("ele_pout",&ele_pout,"ele_pout/F");
1105  vbtfPresele_tree->Branch("event_caloMET",&event_caloMET,"event_caloMET/F");
1106  vbtfPresele_tree->Branch("event_pfMET",&event_pfMET,"event_pfMET/F");
1107  vbtfPresele_tree->Branch("event_tcMET",&event_tcMET,"event_tcMET/F");
1108  vbtfPresele_tree->Branch("event_caloMT",&event_caloMT,"event_caloMT/F");
1109  vbtfPresele_tree->Branch("event_pfMT",&event_pfMT,"event_pfMT/F");
1110  vbtfPresele_tree->Branch("event_tcMT",&event_tcMT,"event_tcMT/F");
1111  vbtfPresele_tree->Branch("event_caloMET_phi",&event_caloMET_phi,"event_caloMET_phi/F");
1112  vbtfPresele_tree->Branch("event_pfMET_phi",&event_pfMET_phi,"event_pfMET_phi/F");
1113  vbtfPresele_tree->Branch("event_tcMET_phi",&event_tcMET_phi,"event_tcMET_phi/F");
1114  vbtfPresele_tree->Branch("event_caloSumEt",&event_caloSumEt,"event_caloSumEt/F");
1115  vbtfPresele_tree->Branch("event_pfSumEt",&event_pfSumEt,"event_pfSumEt/F");
1116  vbtfPresele_tree->Branch("event_tcSumEt",&event_tcSumEt,"event_tcSumEt/F");
1117  // the extra jet variables:
1119  vbtfPresele_tree->Branch("calojet_et",calojet_et,"calojet_et[5]/F");
1120  vbtfPresele_tree->Branch("calojet_eta",calojet_eta,"calojet_eta[5]/F");
1121  vbtfPresele_tree->Branch("calojet_phi",calojet_phi,"calojet_phi[5]/F");
1122  vbtfPresele_tree->Branch("pfjet_et",pfjet_et,"pfjet_et[5]/F");
1123  vbtfPresele_tree->Branch("pfjet_eta",pfjet_eta,"pfjet_eta[5]/F");
1124  vbtfPresele_tree->Branch("pfjet_phi",pfjet_phi,"pfjet_phi[5]/F");
1125  }
1126  if (storeExtraInformation_) {
1127  vbtfPresele_tree->Branch("ele2nd_sc_gsf_et",&ele2nd_sc_gsf_et,"ele2nd_sc_gsf_et/F");
1128  vbtfPresele_tree->Branch("ele2nd_sc_eta",&ele2nd_sc_eta,"ele2nd_sc_eta/F");
1129  vbtfPresele_tree->Branch("ele2nd_sc_phi",&ele2nd_sc_phi,"ele2nd_sc_phi/F");
1130  vbtfPresele_tree->Branch("ele2nd_sc_rho",&ele2nd_sc_rho,"ele2nd_sc_rho/F");
1131  vbtfPresele_tree->Branch("ele2nd_cand_eta",&ele2nd_cand_eta,"ele2nd_cand_eta/F");
1132  vbtfPresele_tree->Branch("ele2nd_cand_phi",&ele2nd_cand_phi,"ele2nd_cand_phi/F");
1133  vbtfPresele_tree->Branch("ele2nd_pin",&ele2nd_pin,"ele2nd_pin/F");
1134  vbtfPresele_tree->Branch("ele2nd_pout",&ele2nd_pout,"ele2nd_pout/F");
1135  vbtfPresele_tree->Branch("ele2nd_ecalDriven",&ele2nd_ecalDriven,"ele2nd_ecalDriven/I");
1136  vbtfPresele_tree->Branch("ele2nd_passes_selection",&ele2nd_passes_selection,"ele2nd_passes_selection/I");
1137  vbtfPresele_tree->Branch("ele_hltmatched_dr",&ele_hltmatched_dr,"ele_hltmatched_dr/F");
1138  vbtfPresele_tree->Branch("event_triggerDecision",&event_triggerDecision,"event_triggerDecision/I");
1139  vbtfPresele_tree->Branch("VtxTracksSize",&VtxTracksSize);
1140  vbtfPresele_tree->Branch("VtxNormalizedChi2",&VtxNormalizedChi2);
1141  vbtfPresele_tree->Branch("VtxTracksSizeBS",&VtxTracksSizeBS);
1142  vbtfPresele_tree->Branch("VtxNormalizedChi2BS",&VtxNormalizedChi2BS);
1143  }
1145  vbtfPresele_tree->Branch("ele2nd_cand_et",&ele2nd_cand_et,"ele2nd_cand_et/F");
1146  vbtfPresele_tree->Branch("ele2nd_iso_track",&ele2nd_iso_track ,"ele2nd_iso_track /F");
1147  vbtfPresele_tree->Branch("ele2nd_iso_ecal",&ele2nd_iso_ecal,"ele2nd_iso_ecal/F");
1148  vbtfPresele_tree->Branch("ele2nd_iso_hcal",&ele2nd_iso_hcal,"ele2nd_iso_hcal/F");
1149  vbtfPresele_tree->Branch("ele2nd_id_sihih",&ele2nd_id_sihih,"ele2nd_id_sihih/F");
1150  vbtfPresele_tree->Branch("ele2nd_id_deta",&ele2nd_id_deta,"ele2nd_id_deta/F");
1151  vbtfPresele_tree->Branch("ele2nd_id_dphi",&ele2nd_id_dphi,"ele2nd_id_dphi/F");
1152  vbtfPresele_tree->Branch("ele2nd_id_hoe",&ele2nd_id_hoe,"ele2nd_id_hoe/F");
1153  vbtfPresele_tree->Branch("ele2nd_cr_mhitsinner",&ele2nd_cr_mhitsinner,"ele2nd_cr_mhitsinner/I");
1154  vbtfPresele_tree->Branch("ele2nd_cr_dcot",&ele2nd_cr_dcot,"ele2nd_cr_dcot/F");
1155  vbtfPresele_tree->Branch("ele2nd_cr_dist",&ele2nd_cr_dist ,"ele2nd_cr_dist/F");
1156  vbtfPresele_tree->Branch("ele2nd_vx",&ele2nd_vx,"ele2nd_vx/F");
1157  vbtfPresele_tree->Branch("ele2nd_vy",&ele2nd_vy,"ele2nd_vy/F");
1158  vbtfPresele_tree->Branch("ele2nd_vz",&ele2nd_vz,"ele2nd_vz/F");
1159 
1160  vbtfPresele_tree->Branch("ele2nd_gsfCharge",&ele2nd_gsfCharge,"ele2nd_gsfCharge/I");
1161  vbtfPresele_tree->Branch("ele2nd_ctfCharge",&ele2nd_ctfCharge,"ele2nd_ctfCharge/I");
1162  vbtfPresele_tree->Branch("ele2nd_scPixCharge",&ele2nd_scPixCharge,"ele2nd_scPixCharge/I");
1163  vbtfPresele_tree->Branch("ele2nd_eop",&ele2nd_eop,"ele2nd_eop/F");
1164  vbtfPresele_tree->Branch("ele2nd_tip_bs",&ele2nd_tip_bs,"ele2nd_tip_bs/F");
1165  vbtfPresele_tree->Branch("ele2nd_tip_pv",&ele2nd_tip_pv,"ele2nd_tip_pv/F");
1166  vbtfPresele_tree->Branch("ele2nd_hltmatched_dr",&ele2nd_hltmatched_dr,"ele2nd_hltmatched_dr/F");
1167  }
1168  vbtfPresele_tree->Branch("event_datasetTag",&event_datasetTag,"event_dataSetTag/I");
1169 
1170  //
1171  // _________________________________________________________________________
1172  //
1173  //
1174  //
1175 
1176 
1177 }
Float_t ele_vy
Definition: WenuPlots.h:196
TH1F * h_mt_inverse_EE
Definition: WenuPlots.h:88
Float_t ele2nd_cr_dcot
Definition: WenuPlots.h:240
Double_t trackIsoUser_EB_
Definition: WenuPlots.h:141
Int_t ele2nd_ctfCharge
Definition: WenuPlots.h:242
Float_t ele2nd_id_deta
Definition: WenuPlots.h:239
Float_t ele2nd_sc_gsf_et
Definition: WenuPlots.h:211
Double_t cIso_EE_
Definition: WenuPlots.h:137
Double_t trackIso_EB_
Definition: WenuPlots.h:117
Float_t ele_iso_ecal
Definition: WenuPlots.h:192
std::string WENU_VBTFselectionFileName_
Definition: WenuPlots.h:229
TH1F * h_met_inverse_EB
Definition: WenuPlots.h:81
Bool_t hcalIso_EE_inv
Definition: WenuPlots.h:154
Bool_t deta_EE_inv
Definition: WenuPlots.h:165
Float_t event_caloMET
Definition: WenuPlots.h:201
Float_t ele_iso_hcal
Definition: WenuPlots.h:192
Float_t ele2nd_tip_bs
Definition: WenuPlots.h:243
Float_t ele2nd_id_hoe
Definition: WenuPlots.h:239
Double_t eop_EE_
Definition: WenuPlots.h:139
Float_t ele_eop
Definition: WenuPlots.h:200
Bool_t ecalIso_EB_inv
Definition: WenuPlots.h:149
TH1F * h_EE_trkiso
Definition: WenuPlots.h:103
Double_t trackIsoUser_EE_
Definition: WenuPlots.h:144
Int_t nBarrelVars_
Definition: WenuPlots.h:180
Float_t pfjet_eta[5]
Definition: WenuPlots.h:209
Float_t ele2nd_eop
Definition: WenuPlots.h:243
TH1F * h_EB_HoE
Definition: WenuPlots.h:101
TH1F * h_met_EB
Definition: WenuPlots.h:80
Int_t lumiSection
Definition: WenuPlots.h:187
Float_t event_tcMET_phi
Definition: WenuPlots.h:203
Int_t ele2nd_passes_selection
Definition: WenuPlots.h:219
TH1F * h_mt
Definition: WenuPlots.h:77
Float_t ele_vz
Definition: WenuPlots.h:196
Double_t cIso_EB_
Definition: WenuPlots.h:129
Float_t ele_pout
Definition: WenuPlots.h:197
Float_t ele_sc_rho
Definition: WenuPlots.h:189
Int_t ele2nd_scPixCharge
Definition: WenuPlots.h:242
Bool_t tip_bspot_EE_inv
Definition: WenuPlots.h:169
Float_t event_caloMET_phi
Definition: WenuPlots.h:203
Float_t ele_id_dphi
Definition: WenuPlots.h:193
TH1F * h_trackIso_ee_NmOne
Definition: WenuPlots.h:113
Bool_t tip_bspot_EB_inv
Definition: WenuPlots.h:161
Float_t ele_cr_dist
Definition: WenuPlots.h:194
std::string WENU_VBTFpreseleFileName_
Definition: WenuPlots.h:230
TH1F * h_scPhi
Definition: WenuPlots.h:93
Int_t ele2nd_ecalDriven
Definition: WenuPlots.h:220
Double_t ecalIsoUser_EB_
Definition: WenuPlots.h:142
Int_t ele_gsfCharge
Definition: WenuPlots.h:199
Float_t calojet_eta[5]
Definition: WenuPlots.h:206
Bool_t includeJetInformationInNtuples_
Definition: WenuPlots.h:231
Int_t runNumber
Definition: WenuPlots.h:187
Double_t dphi_EE_
Definition: WenuPlots.h:135
Bool_t sihih_EE_inv
Definition: WenuPlots.h:164
TTree * vbtfSele_tree
Definition: WenuPlots.h:227
TH1F * h_EB_trkiso
Definition: WenuPlots.h:95
Float_t ele2nd_pout
Definition: WenuPlots.h:218
Bool_t dphi_EE_inv
Definition: WenuPlots.h:166
Bool_t hcalIsoUser_EE_inv
Definition: WenuPlots.h:177
Float_t pv_x
Definition: WenuPlots.h:198
Float_t ele2nd_vy
Definition: WenuPlots.h:241
Float_t event_caloSumEt
Definition: WenuPlots.h:202
Double_t tip_bspot_EB_
Definition: WenuPlots.h:130
Float_t ele2nd_sc_eta
Definition: WenuPlots.h:212
Float_t ele2nd_sc_phi
Definition: WenuPlots.h:213
Bool_t ecalIso_EE_inv
Definition: WenuPlots.h:153
std::vector< Double_t > CutVars_
Definition: WenuPlots.h:182
Float_t ele_sc_eta
Definition: WenuPlots.h:189
Double_t deta_EE_
Definition: WenuPlots.h:134
TH1F * h_EE_sIetaIeta
Definition: WenuPlots.h:106
Float_t ele2nd_vx
Definition: WenuPlots.h:241
Float_t ele2nd_id_sihih
Definition: WenuPlots.h:239
Float_t event_pfMET
Definition: WenuPlots.h:201
TH1F * h_EB_sIetaIeta
Definition: WenuPlots.h:98
Float_t ele2nd_cand_phi
Definition: WenuPlots.h:216
Double_t hcalIso_EB_
Definition: WenuPlots.h:119
Float_t pv_y
Definition: WenuPlots.h:198
Float_t ele_sc_phi
Definition: WenuPlots.h:189
Double_t trackIso_EE_
Definition: WenuPlots.h:121
TH1F * h_met_EE
Definition: WenuPlots.h:85
Double_t deta_EB_
Definition: WenuPlots.h:126
TH1F * h_met
Definition: WenuPlots.h:75
TH1F * h_EB_ecaliso
Definition: WenuPlots.h:96
Float_t ele_id_deta
Definition: WenuPlots.h:193
Double_t hcalIsoUser_EB_
Definition: WenuPlots.h:143
TH1F * h_scEt
Definition: WenuPlots.h:91
Double_t hcalIso_EE_
Definition: WenuPlots.h:123
Float_t ele2nd_cand_et
Definition: WenuPlots.h:237
Float_t ele_cand_et
Definition: WenuPlots.h:191
Bool_t deta_EB_inv
Definition: WenuPlots.h:157
TFile * WENU_VBTFselectionFile_
Definition: WenuPlots.h:226
Bool_t hcalIsoUser_EB_inv
Definition: WenuPlots.h:174
Double_t sihih_EE_
Definition: WenuPlots.h:133
TH1F * h_EE_ecaliso
Definition: WenuPlots.h:104
TH1F * h_EB_hcaliso
Definition: WenuPlots.h:97
Float_t ele2nd_pin
Definition: WenuPlots.h:217
TH1F * h_met_inverse
Definition: WenuPlots.h:76
Bool_t ecalIsoUser_EE_inv
Definition: WenuPlots.h:176
Int_t event_triggerDecision
Definition: WenuPlots.h:222
Float_t ele2nd_hltmatched_dr
Definition: WenuPlots.h:244
Bool_t eop_EE_inv
Definition: WenuPlots.h:170
Float_t ele2nd_sc_rho
Definition: WenuPlots.h:214
Double_t ecalIso_EB_
Definition: WenuPlots.h:118
Float_t ele2nd_cand_eta
Definition: WenuPlots.h:215
Float_t ele_hltmatched_dr
Definition: WenuPlots.h:221
Float_t ele_vx
Definition: WenuPlots.h:196
Double_t eop_EB_
Definition: WenuPlots.h:131
TH1F * h_met_inverse_EE
Definition: WenuPlots.h:86
TH1F * h_mt_inverse
Definition: WenuPlots.h:78
TH1F * h_EE_dphi
Definition: WenuPlots.h:107
Double_t hcalIsoUser_EE_
Definition: WenuPlots.h:146
Bool_t trackIso_EE_inv
Definition: WenuPlots.h:152
Float_t ele_id_hoe
Definition: WenuPlots.h:193
Int_t ele_scPixCharge
Definition: WenuPlots.h:199
std::vector< Int_t > VtxTracksSizeBS
Definition: WenuPlots.h:247
Bool_t eop_EB_inv
Definition: WenuPlots.h:162
Bool_t storeAllSecondElectronVariables_
Definition: WenuPlots.h:236
Float_t calojet_phi[5]
Definition: WenuPlots.h:207
std::vector< Int_t > VtxTracksSize
Definition: WenuPlots.h:245
TH1F * h_EB_deta
Definition: WenuPlots.h:100
Float_t ele_tip_pv
Definition: WenuPlots.h:200
TFile * WENU_VBTFpreseleFile_
Definition: WenuPlots.h:225
TH1F * h_scEta
Definition: WenuPlots.h:92
Float_t ele2nd_iso_hcal
Definition: WenuPlots.h:238
Float_t pfjet_phi[5]
Definition: WenuPlots.h:210
Float_t ele_iso_track
Definition: WenuPlots.h:192
Int_t ele2nd_gsfCharge
Definition: WenuPlots.h:242
TTree * vbtfPresele_tree
Definition: WenuPlots.h:228
Int_t event_datasetTag
Definition: WenuPlots.h:223
Float_t ele_pin
Definition: WenuPlots.h:197
TH1F * h_EB_dphi
Definition: WenuPlots.h:99
Float_t event_tcSumEt
Definition: WenuPlots.h:202
Int_t ele_cr_mhitsinner
Definition: WenuPlots.h:195
TH1F * h_trackIso_eb_NmOne
Definition: WenuPlots.h:112
Float_t pv_z
Definition: WenuPlots.h:198
Bool_t sihih_EB_inv
Definition: WenuPlots.h:156
Float_t ele2nd_iso_track
Definition: WenuPlots.h:238
Float_t ele_cand_eta
Definition: WenuPlots.h:191
Bool_t cIso_EB_inv
Definition: WenuPlots.h:160
Bool_t trackIsoUser_EE_inv
Definition: WenuPlots.h:175
Float_t pfjet_et[5]
Definition: WenuPlots.h:208
Bool_t hcalIso_EB_inv
Definition: WenuPlots.h:150
Bool_t storeExtraInformation_
Definition: WenuPlots.h:232
Bool_t hoe_EE_inv
Definition: WenuPlots.h:167
Float_t ele2nd_vz
Definition: WenuPlots.h:241
Int_t ele_ctfCharge
Definition: WenuPlots.h:199
Float_t event_pfMT
Definition: WenuPlots.h:204
Float_t event_tcMT
Definition: WenuPlots.h:204
Float_t ele_cand_phi
Definition: WenuPlots.h:191
Bool_t ecalIsoUser_EB_inv
Definition: WenuPlots.h:173
TH1F * h_EE_deta
Definition: WenuPlots.h:108
TH1F * h_mt_inverse_EB
Definition: WenuPlots.h:83
Float_t ele2nd_tip_pv
Definition: WenuPlots.h:243
Float_t ele2nd_cr_dist
Definition: WenuPlots.h:240
Float_t event_tcMET
Definition: WenuPlots.h:201
Float_t event_pfMET_phi
Definition: WenuPlots.h:203
Bool_t cIso_EE_inv
Definition: WenuPlots.h:168
Float_t event_caloMT
Definition: WenuPlots.h:204
TH1F * h_mt_EB
Definition: WenuPlots.h:82
Float_t ele2nd_id_dphi
Definition: WenuPlots.h:239
Bool_t dphi_EB_inv
Definition: WenuPlots.h:158
Float_t calojet_et[5]
Definition: WenuPlots.h:205
Double_t hoe_EB_
Definition: WenuPlots.h:128
Float_t ele_id_sihih
Definition: WenuPlots.h:193
Bool_t trackIsoUser_EB_inv
Definition: WenuPlots.h:172
Float_t ele_tip_bs
Definition: WenuPlots.h:200
std::vector< Float_t > VtxNormalizedChi2BS
Definition: WenuPlots.h:248
TH1F * h_mt_EE
Definition: WenuPlots.h:87
Int_t ele2nd_cr_mhitsinner
Definition: WenuPlots.h:242
Double_t tip_bspot_EE_
Definition: WenuPlots.h:138
Double_t dphi_EB_
Definition: WenuPlots.h:127
Double_t sihih_EB_
Definition: WenuPlots.h:125
Float_t ele2nd_iso_ecal
Definition: WenuPlots.h:238
std::vector< Bool_t > InvVars_
Definition: WenuPlots.h:183
Float_t ele_cr_dcot
Definition: WenuPlots.h:194
Bool_t trackIso_EB_inv
Definition: WenuPlots.h:148
Double_t ecalIsoUser_EE_
Definition: WenuPlots.h:145
Float_t ele_sc_energy
Definition: WenuPlots.h:189
Double_t ecalIso_EE_
Definition: WenuPlots.h:122
TH1F * h_EE_HoE
Definition: WenuPlots.h:109
Float_t ele_sc_gsf_et
Definition: WenuPlots.h:190
TH1F * h_EE_hcaliso
Definition: WenuPlots.h:105
Float_t event_pfSumEt
Definition: WenuPlots.h:202
Bool_t hoe_EB_inv
Definition: WenuPlots.h:159
Double_t hoe_EE_
Definition: WenuPlots.h:136
std::vector< Float_t > VtxNormalizedChi2
Definition: WenuPlots.h:246
Long64_t eventNumber
Definition: WenuPlots.h:188
Bool_t WenuPlots::CheckCut ( const pat::Electron wenu,
Int_t  i 
)
private

Definition at line 770 of file WenuPlots.cc.

References CutVars_, i, nBarrelVars_, ReturnCandVar(), and pat::Electron::superCluster().

Referenced by CheckCuts(), and CheckCutsNminusOne().

770  {
771  Double_t fabseta = TMath::Abs(ele->superCluster()->eta());
772  if ( fabseta<1.479) {
773  return TMath::Abs(ReturnCandVar(ele, i)) < CutVars_[i];
774  }
775  return TMath::Abs(ReturnCandVar(ele, i)) < CutVars_[i+nBarrelVars_];
776 }
int i
Definition: DBlmapReader.cc:9
Int_t nBarrelVars_
Definition: WenuPlots.h:180
std::vector< Double_t > CutVars_
Definition: WenuPlots.h:182
Double_t ReturnCandVar(const pat::Electron *ele, Int_t i)
Definition: WenuPlots.cc:792
Bool_t WenuPlots::CheckCutInv ( const pat::Electron wenu,
Int_t  i 
)
private

Definition at line 778 of file WenuPlots.cc.

References CutVars_, i, InvVars_, nBarrelVars_, ReturnCandVar(), and pat::Electron::superCluster().

Referenced by CheckCutsInverse().

778  {
779  Double_t fabseta = TMath::Abs(ele->superCluster()->eta());
780  if ( fabseta<1.479) {
781  if (InvVars_[i])
782  return TMath::Abs(ReturnCandVar(ele, i))>CutVars_[i];
783  return TMath::Abs(ReturnCandVar(ele, i)) < CutVars_[i];
784  }
785  if (InvVars_[i+nBarrelVars_]) {
786  if (InvVars_[i])
787  return TMath::Abs(ReturnCandVar(ele, i))>CutVars_[i+nBarrelVars_];
788  }
789  return TMath::Abs(ReturnCandVar(ele, i)) < CutVars_[i+nBarrelVars_];
790 }
int i
Definition: DBlmapReader.cc:9
Int_t nBarrelVars_
Definition: WenuPlots.h:180
std::vector< Double_t > CutVars_
Definition: WenuPlots.h:182
Double_t ReturnCandVar(const pat::Electron *ele, Int_t i)
Definition: WenuPlots.cc:792
std::vector< Bool_t > InvVars_
Definition: WenuPlots.h:183
Bool_t WenuPlots::CheckCuts ( const pat::Electron ele)
private

Definition at line 723 of file WenuPlots.cc.

References CheckCut(), gather_cfg::cout, pat::Electron::electronID(), i, nBarrelVars_, usePrecalcID_, usePrecalcIDSign_, usePrecalcIDType_, and usePrecalcIDValue_.

Referenced by analyze().

724 {
725  if (usePrecalcID_) {
726  if (not ele-> isElectronIDAvailable(usePrecalcIDType_)) {
727  std::cout << "Error! not existing ID with name: "
728  << usePrecalcIDType_ << " function will return true!"
729  << std::endl;
730  return true;
731  }
732  Double_t val = ele->electronID(usePrecalcIDType_);
733  if (usePrecalcIDSign_ == "<") {
734  return val < usePrecalcIDValue_;
735  }
736  else if (usePrecalcIDSign_ == ">") {
737  return val > usePrecalcIDValue_;
738  }
739  else { // equality: it returns 0,1,2,3 but as float
740  return TMath::Abs(val-usePrecalcIDValue_)<0.1;
741  }
742  }
743  else {
744  for (int i=0; i<nBarrelVars_; ++i) {
745  if (not CheckCut(ele, i)) return false;
746  }
747  return true;
748  }
749 }
int i
Definition: DBlmapReader.cc:9
Int_t nBarrelVars_
Definition: WenuPlots.h:180
std::string usePrecalcIDSign_
Definition: WenuPlots.h:54
Double_t usePrecalcIDValue_
Definition: WenuPlots.h:56
float electronID(const std::string &name) const
Returns a specific electron ID associated to the pat::Electron given its name.
Definition: Electron.cc:315
std::string usePrecalcIDType_
Definition: WenuPlots.h:55
tuple cout
Definition: gather_cfg.py:121
Bool_t usePrecalcID_
Definition: WenuPlots.h:53
Bool_t CheckCut(const pat::Electron *wenu, Int_t i)
Definition: WenuPlots.cc:770
Bool_t WenuPlots::CheckCutsInverse ( const pat::Electron ele)
private

Definition at line 752 of file WenuPlots.cc.

References CheckCutInv(), i, and nBarrelVars_.

Referenced by analyze().

753 {
754  for (int i=0; i<nBarrelVars_; ++i){
755  if ( CheckCutInv(ele, i) == false) return false;
756  }
757  return true;
758 
759 }
int i
Definition: DBlmapReader.cc:9
Int_t nBarrelVars_
Definition: WenuPlots.h:180
Bool_t CheckCutInv(const pat::Electron *wenu, Int_t i)
Definition: WenuPlots.cc:778
Bool_t WenuPlots::CheckCutsNminusOne ( const pat::Electron ele,
Int_t  jj 
)
private

Definition at line 761 of file WenuPlots.cc.

References CheckCut(), i, and nBarrelVars_.

Referenced by analyze().

762 {
763  for (int i=0; i<nBarrelVars_; ++i){
764  if (i==jj) continue;
765  if ( CheckCut(ele, i) == false) return false;
766  }
767  return true;
768 }
int i
Definition: DBlmapReader.cc:9
Int_t nBarrelVars_
Definition: WenuPlots.h:180
Bool_t CheckCut(const pat::Electron *wenu, Int_t i)
Definition: WenuPlots.cc:770
void WenuPlots::endJob ( void  )
privatevirtual

Reimplemented from edm::EDAnalyzer.

Definition at line 1181 of file WenuPlots.cc.

References h_EB_deta, h_EB_dphi, h_EB_ecaliso, h_EB_hcaliso, h_EB_HoE, h_EB_sIetaIeta, h_EB_trkiso, h_EE_deta, h_EE_dphi, h_EE_ecaliso, h_EE_hcaliso, h_EE_HoE, h_EE_sIetaIeta, h_EE_trkiso, h_met, h_met_EB, h_met_EE, h_met_inverse, h_met_inverse_EB, h_met_inverse_EE, h_mt, h_mt_EB, h_mt_EE, h_mt_inverse, h_mt_inverse_EB, h_mt_inverse_EE, h_scEt, h_scEta, h_scPhi, h_trackIso_eb_NmOne, h_trackIso_ee_NmOne, runonSM::newfile, outputFile_, WENU_VBTFpreseleFile_, and WENU_VBTFselectionFile_.

1181  {
1182  TFile * newfile = new TFile(TString(outputFile_),"RECREATE");
1183  //
1184  // for consistency all the plots are in the root file
1185  // even though they may be empty (in the case when
1186  // usePrecalcID_== true inverted and N-1 are empty)
1187  h_met->Write();
1188  h_met_inverse->Write();
1189  h_mt->Write();
1190  h_mt_inverse->Write();
1191 
1192  h_met_EB->Write();
1193  h_met_inverse_EB->Write();
1194  h_mt_EB->Write();
1195  h_mt_inverse_EB->Write();
1196 
1197  h_met_EE->Write();
1198  h_met_inverse_EE->Write();
1199  h_mt_EE->Write();
1200  h_mt_inverse_EE->Write();
1201 
1202  h_scEt->Write();
1203  h_scEta->Write();
1204  h_scPhi->Write();
1205 
1206  h_EB_trkiso->Write();
1207  h_EB_ecaliso->Write();
1208  h_EB_hcaliso->Write();
1209  h_EB_sIetaIeta->Write();
1210  h_EB_dphi->Write();
1211  h_EB_deta->Write();
1212  h_EB_HoE->Write();
1213 
1214  h_EE_trkiso->Write();
1215  h_EE_ecaliso->Write();
1216  h_EE_hcaliso->Write();
1217  h_EE_sIetaIeta->Write();
1218  h_EE_dphi->Write();
1219  h_EE_deta->Write();
1220  h_EE_HoE->Write();
1221 
1222  //
1223  h_trackIso_eb_NmOne->Write();
1224  h_trackIso_ee_NmOne->Write();
1225  //
1226  newfile->Close();
1227  //
1228  // write the VBTF trees
1229  //
1230  WENU_VBTFpreseleFile_->Write();
1231  WENU_VBTFpreseleFile_->Close();
1232  WENU_VBTFselectionFile_->Write();
1233  WENU_VBTFselectionFile_->Close();
1234 
1235 }
TH1F * h_mt_inverse_EE
Definition: WenuPlots.h:88
TH1F * h_met_inverse_EB
Definition: WenuPlots.h:81
TH1F * h_EE_trkiso
Definition: WenuPlots.h:103
TH1F * h_EB_HoE
Definition: WenuPlots.h:101
TH1F * h_met_EB
Definition: WenuPlots.h:80
TH1F * h_mt
Definition: WenuPlots.h:77
TH1F * h_trackIso_ee_NmOne
Definition: WenuPlots.h:113
TH1F * h_scPhi
Definition: WenuPlots.h:93
TH1F * h_EB_trkiso
Definition: WenuPlots.h:95
TH1F * h_EE_sIetaIeta
Definition: WenuPlots.h:106
TH1F * h_EB_sIetaIeta
Definition: WenuPlots.h:98
TH1F * h_met_EE
Definition: WenuPlots.h:85
TH1F * h_met
Definition: WenuPlots.h:75
TH1F * h_EB_ecaliso
Definition: WenuPlots.h:96
TH1F * h_scEt
Definition: WenuPlots.h:91
tuple newfile
Definition: runonSM.py:48
TFile * WENU_VBTFselectionFile_
Definition: WenuPlots.h:226
TH1F * h_EE_ecaliso
Definition: WenuPlots.h:104
TH1F * h_EB_hcaliso
Definition: WenuPlots.h:97
TH1F * h_met_inverse
Definition: WenuPlots.h:76
TH1F * h_met_inverse_EE
Definition: WenuPlots.h:86
TH1F * h_mt_inverse
Definition: WenuPlots.h:78
TH1F * h_EE_dphi
Definition: WenuPlots.h:107
TH1F * h_EB_deta
Definition: WenuPlots.h:100
TFile * WENU_VBTFpreseleFile_
Definition: WenuPlots.h:225
TH1F * h_scEta
Definition: WenuPlots.h:92
TH1F * h_EB_dphi
Definition: WenuPlots.h:99
TH1F * h_trackIso_eb_NmOne
Definition: WenuPlots.h:112
TH1F * h_EE_deta
Definition: WenuPlots.h:108
TH1F * h_mt_inverse_EB
Definition: WenuPlots.h:83
std::string outputFile_
Definition: WenuPlots.h:63
TH1F * h_mt_EB
Definition: WenuPlots.h:82
TH1F * h_mt_EE
Definition: WenuPlots.h:87
TH1F * h_EE_HoE
Definition: WenuPlots.h:109
TH1F * h_EE_hcaliso
Definition: WenuPlots.h:105
Bool_t WenuPlots::PassPreselectionCriteria ( const pat::Electron ele)
private

Definition at line 819 of file WenuPlots.cc.

References gather_cfg::cout, pat::PATObject< ObjectType >::hasUserInt(), maxNumberOfExpectedMissingHits_, useConversionRejection_, useExpectedMissingHits_, pat::PATObject< ObjectType >::userInt(), and useValidFirstPXBHit_.

Referenced by analyze().

819  {
820  Bool_t passConvRej = true;
821  Bool_t passPXB = true;
822  Bool_t passEMH = true;
824  if (ele->hasUserInt("PassConversionRejection")) {
825  //std::cout << "con rej: " << ele->userInt("PassConversionRejection") << std::endl;
826  if (not (ele->userInt("PassConversionRejection")==1)) passConvRej = false;
827  }
828  else {
829  std::cout << "WenuPlots: WARNING: Conversion Rejection Request Disregarded: "
830  << "you must calculate it before " << std::endl;
831  // return true;
832  }
833  }
834  if (useValidFirstPXBHit_) {
835  if (ele->hasUserInt("PassValidFirstPXBHit")) {
836  //std::cout << "valid1stPXB: " << ele->userInt("PassValidFirstPXBHit") << std::endl;
837  if (not (ele->userInt("PassValidFirstPXBHit")==1)) passPXB = false;
838  }
839  else {
840  std::cout << "WenuPlots: WARNING: Valid First PXB Hit Request Disregarded: "
841  << "you must calculate it before " << std::endl;
842  // return true;
843  }
844  }
846  if (ele->hasUserInt("NumberOfExpectedMissingHits")) {
847  //std::cout << "missing hits: " << ele->userInt("NumberOfExpectedMissingHits") << std::endl;
848  if (ele->userInt("NumberOfExpectedMissingHits")>maxNumberOfExpectedMissingHits_)
849  passEMH = false;
850  }
851  else {
852  std::cout << "WenuPlots: WARNING: Number of Expected Missing Hits Request Disregarded: "
853  << "you must calculate it before " << std::endl;
854  // return true;
855  }
856  }
857  return passConvRej && passPXB && passEMH;
858 }
Int_t maxNumberOfExpectedMissingHits_
Definition: WenuPlots.h:61
Bool_t useExpectedMissingHits_
Definition: WenuPlots.h:60
bool hasUserInt(const std::string &key) const
Return true if there is a user-defined int with a given name.
Definition: PATObject.h:337
Bool_t useConversionRejection_
Definition: WenuPlots.h:59
int32_t userInt(const std::string &key) const
Definition: PATObject.h:772
Bool_t useValidFirstPXBHit_
Definition: WenuPlots.h:58
tuple cout
Definition: gather_cfg.py:121
Double_t WenuPlots::ReturnCandVar ( const pat::Electron ele,
Int_t  i 
)
private

Definition at line 792 of file WenuPlots.cc.

References gather_cfg::cout, pat::Electron::dB(), reco::GsfElectron::deltaEtaSuperClusterTrackAtVtx(), reco::GsfElectron::deltaPhiSuperClusterTrackAtVtx(), reco::GsfElectron::dr03EcalRecHitSumEt(), reco::GsfElectron::dr03HcalTowerSumEt(), reco::GsfElectron::dr03TkSumPt(), pat::EcalIso, reco::GsfElectron::eSuperClusterOverP(), reco::GsfElectron::hadronicOverEm(), pat::HcalIso, reco::GsfElectron::isEB(), max(), reco::GsfElectron::p4(), reco::GsfElectron::scSigmaIEtaIEta(), pat::TrackIso, and pat::Lepton< LeptonType >::userIsolation().

Referenced by CheckCut(), and CheckCutInv().

792  {
793  if (i==0) return ele->dr03TkSumPt()/ele->p4().Pt();
794  else if (i==1) return ele->dr03EcalRecHitSumEt()/ele->p4().Pt();
795  else if (i==2) return ele->dr03HcalTowerSumEt()/ele->p4().Pt();
796  else if (i==3) return ele->scSigmaIEtaIEta();
797  else if (i==4) return ele->deltaPhiSuperClusterTrackAtVtx();
798  else if (i==5) return ele->deltaEtaSuperClusterTrackAtVtx();
799  else if (i==6) return ele->hadronicOverEm();
800  else if (i==7) {
801  if (ele->isEB()){
802  return ( ele->dr03TkSumPt()+std::max(float(0.),ele->dr03EcalRecHitSumEt()-1)
803  + ele->dr03HcalTowerSumEt())/ele->p4().Pt(); }
804  else { // pedestal subtraction is only in barrel
805  return ( ele->dr03TkSumPt()+ele->dr03EcalRecHitSumEt()
806  + ele->dr03HcalTowerSumEt())/ele->p4().Pt(); }
807  }
808  // else if (i==8) return ele->gsfTrack()->dxy(bspotPosition_);
809  else if (i==8) return fabs(ele->dB());
810  else if (i==9) return ele->eSuperClusterOverP();
811  else if (i==10) return ele->userIsolation(pat::TrackIso);
812  else if (i==11) return ele->userIsolation(pat::EcalIso);
813  else if (i==12) return ele->userIsolation(pat::HcalIso);
814  std::cout << "Error in WenuPlots::ReturnCandVar" << std::endl;
815  return -1.;
816 
817 }
int i
Definition: DBlmapReader.cc:9
const LorentzVector & p4(P4Kind kind) const
Definition: GsfElectron.cc:204
float eSuperClusterOverP() const
Definition: GsfElectron.h:229
bool isEB() const
Definition: GsfElectron.h:330
float deltaEtaSuperClusterTrackAtVtx() const
Definition: GsfElectron.h:233
float hadronicOverEm() const
Definition: GsfElectron.h:403
const T & max(const T &a, const T &b)
float deltaPhiSuperClusterTrackAtVtx() const
Definition: GsfElectron.h:236
float dr03TkSumPt() const
Definition: GsfElectron.h:436
float scSigmaIEtaIEta() const
Definition: GsfElectron.h:399
float userIsolation(IsolationKeys key) const
Definition: Lepton.h:51
float dr03EcalRecHitSumEt() const
Definition: GsfElectron.h:437
float dr03HcalTowerSumEt() const
Definition: GsfElectron.h:440
tuple cout
Definition: gather_cfg.py:121
double dB(IpType type=None) const
Impact parameter wrt primary vertex or beamspot.
Definition: Electron.cc:378

Member Data Documentation

Float_t WenuPlots::calojet_et[5]
private

Definition at line 205 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::calojet_eta[5]
private

Definition at line 206 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::calojet_phi[5]
private

Definition at line 207 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

edm::InputTag WenuPlots::caloJetCollectionTag_
private

Definition at line 65 of file WenuPlots.h.

Referenced by analyze(), and WenuPlots().

Double_t WenuPlots::cIso_EB_
private

Definition at line 129 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::cIso_EB_inv
private

Definition at line 160 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::cIso_EE_
private

Definition at line 137 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::cIso_EE_inv
private

Definition at line 168 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

std::vector<Double_t> WenuPlots::CutVars_
private

Definition at line 182 of file WenuPlots.h.

Referenced by beginJob(), CheckCut(), and CheckCutInv().

Int_t WenuPlots::DatasetTag_
private

Definition at line 234 of file WenuPlots.h.

Referenced by analyze(), and WenuPlots().

Double_t WenuPlots::deta_EB_
private

Definition at line 126 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::deta_EB_inv
private

Definition at line 157 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::deta_EE_
private

Definition at line 134 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::deta_EE_inv
private

Definition at line 165 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::dphi_EB_
private

Definition at line 127 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::dphi_EB_inv
private

Definition at line 158 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::dphi_EE_
private

Definition at line 135 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::dphi_EE_inv
private

Definition at line 166 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::DRJetFromElectron_
private

Definition at line 233 of file WenuPlots.h.

Referenced by analyze(), and WenuPlots().

Double_t WenuPlots::ecalIso_EB_
private

Definition at line 118 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::ecalIso_EB_inv
private

Definition at line 149 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::ecalIso_EE_
private

Definition at line 122 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::ecalIso_EE_inv
private

Definition at line 153 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::ecalIsoUser_EB_
private

Definition at line 142 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::ecalIsoUser_EB_inv
private

Definition at line 173 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::ecalIsoUser_EE_
private

Definition at line 145 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::ecalIsoUser_EE_inv
private

Definition at line 176 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Float_t WenuPlots::ele2nd_cand_et
private

Definition at line 237 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_cand_eta
private

Definition at line 215 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_cand_phi
private

Definition at line 216 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_cr_dcot
private

Definition at line 240 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_cr_dist
private

Definition at line 240 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele2nd_cr_mhitsinner
private

Definition at line 242 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele2nd_ctfCharge
private

Definition at line 242 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele2nd_ecalDriven
private

Definition at line 220 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_eop
private

Definition at line 243 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele2nd_gsfCharge
private

Definition at line 242 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_hltmatched_dr
private

Definition at line 244 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_id_deta
private

Definition at line 239 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_id_dphi
private

Definition at line 239 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_id_hoe
private

Definition at line 239 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_id_sihih
private

Definition at line 239 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_iso_ecal
private

Definition at line 238 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_iso_hcal
private

Definition at line 238 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_iso_track
private

Definition at line 238 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele2nd_passes_selection
private

Definition at line 219 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_pin
private

Definition at line 217 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_pout
private

Definition at line 218 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_sc_eta
private

Definition at line 212 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_sc_gsf_et
private

Definition at line 211 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_sc_phi
private

Definition at line 213 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_sc_rho
private

Definition at line 214 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele2nd_scPixCharge
private

Definition at line 242 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_tip_bs
private

Definition at line 243 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_tip_pv
private

Definition at line 243 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_tip_pvbs
private

Definition at line 250 of file WenuPlots.h.

Referenced by analyze().

Float_t WenuPlots::ele2nd_vx
private

Definition at line 241 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_vy
private

Definition at line 241 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele2nd_vz
private

Definition at line 241 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_cand_et
private

Definition at line 191 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_cand_eta
private

Definition at line 191 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_cand_phi
private

Definition at line 191 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_cr_dcot
private

Definition at line 194 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_cr_dist
private

Definition at line 194 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele_cr_mhitsinner
private

Definition at line 195 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele_ctfCharge
private

Definition at line 199 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_eop
private

Definition at line 200 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele_gsfCharge
private

Definition at line 199 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_hltmatched_dr
private

Definition at line 221 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_id_deta
private

Definition at line 193 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_id_dphi
private

Definition at line 193 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_id_hoe
private

Definition at line 193 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_id_sihih
private

Definition at line 193 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_iso_ecal
private

Definition at line 192 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_iso_hcal
private

Definition at line 192 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_iso_track
private

Definition at line 192 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_pin
private

Definition at line 197 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_pout
private

Definition at line 197 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_sc_energy
private

Definition at line 189 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_sc_eta
private

Definition at line 189 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_sc_gsf_et
private

Definition at line 190 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_sc_phi
private

Definition at line 189 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_sc_rho
private

Definition at line 189 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::ele_scPixCharge
private

Definition at line 199 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_tip_bs
private

Definition at line 200 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_tip_pv
private

Definition at line 200 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_tip_pvbs
private

Definition at line 250 of file WenuPlots.h.

Referenced by analyze().

Float_t WenuPlots::ele_vx
private

Definition at line 196 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_vy
private

Definition at line 196 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::ele_vz
private

Definition at line 196 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Double_t WenuPlots::eop_EB_
private

Definition at line 131 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::eop_EB_inv
private

Definition at line 162 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::eop_EE_
private

Definition at line 139 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::eop_EE_inv
private

Definition at line 170 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Float_t WenuPlots::event_caloMET
private

Definition at line 201 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_caloMET_phi
private

Definition at line 203 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_caloMT
private

Definition at line 204 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_caloSumEt
private

Definition at line 202 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::event_datasetTag
private

Definition at line 223 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_pfMET
private

Definition at line 201 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_pfMET_phi
private

Definition at line 203 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_pfMT
private

Definition at line 204 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_pfSumEt
private

Definition at line 202 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_tcMET
private

Definition at line 201 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_tcMET_phi
private

Definition at line 203 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_tcMT
private

Definition at line 204 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::event_tcSumEt
private

Definition at line 202 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::event_triggerDecision
private

Definition at line 222 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Long64_t WenuPlots::eventNumber
private
TH1F* WenuPlots::h_EB_deta
private

Definition at line 100 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EB_dphi
private

Definition at line 99 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EB_ecaliso
private

Definition at line 96 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EB_hcaliso
private

Definition at line 97 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EB_HoE
private

Definition at line 101 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EB_sIetaIeta
private

Definition at line 98 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EB_trkiso
private

Definition at line 95 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EE_deta
private

Definition at line 108 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EE_dphi
private

Definition at line 107 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EE_ecaliso
private

Definition at line 104 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EE_hcaliso
private

Definition at line 105 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EE_HoE
private

Definition at line 109 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EE_sIetaIeta
private

Definition at line 106 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_EE_trkiso
private

Definition at line 103 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_met
private

Definition at line 75 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_met_EB
private

Definition at line 80 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_met_EE
private

Definition at line 85 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_met_inverse
private

Definition at line 76 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_met_inverse_EB
private

Definition at line 81 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_met_inverse_EE
private

Definition at line 86 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_mt
private

Definition at line 77 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_mt_EB
private

Definition at line 82 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_mt_EE
private

Definition at line 87 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_mt_inverse
private

Definition at line 78 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_mt_inverse_EB
private

Definition at line 83 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_mt_inverse_EE
private

Definition at line 88 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_scEt
private

Definition at line 91 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_scEta
private

Definition at line 92 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_scPhi
private

Definition at line 93 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_trackIso_eb_NmOne
private

Definition at line 112 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

TH1F* WenuPlots::h_trackIso_ee_NmOne
private

Definition at line 113 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and endJob().

Double_t WenuPlots::hcalIso_EB_
private

Definition at line 119 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::hcalIso_EB_inv
private

Definition at line 150 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::hcalIso_EE_
private

Definition at line 123 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::hcalIso_EE_inv
private

Definition at line 154 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::hcalIsoUser_EB_
private

Definition at line 143 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::hcalIsoUser_EB_inv
private

Definition at line 174 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::hcalIsoUser_EE_
private

Definition at line 146 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::hcalIsoUser_EE_inv
private

Definition at line 177 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

TFile* WenuPlots::histofile
private

Definition at line 69 of file WenuPlots.h.

Double_t WenuPlots::hoe_EB_
private

Definition at line 128 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::hoe_EB_inv
private

Definition at line 159 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::hoe_EE_
private

Definition at line 136 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::hoe_EE_inv
private

Definition at line 167 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::includeJetInformationInNtuples_
private

Definition at line 231 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and WenuPlots().

std::vector<Bool_t> WenuPlots::InvVars_
private

Definition at line 183 of file WenuPlots.h.

Referenced by beginJob(), and CheckCutInv().

Int_t WenuPlots::lumiSection
private

Definition at line 187 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Int_t WenuPlots::maxNumberOfExpectedMissingHits_
private

Definition at line 61 of file WenuPlots.h.

Referenced by PassPreselectionCriteria(), and WenuPlots().

Int_t WenuPlots::nBarrelVars_
private
std::string WenuPlots::outputFile_
private

Definition at line 63 of file WenuPlots.h.

Referenced by endJob(), and WenuPlots().

Float_t WenuPlots::pfjet_et[5]
private

Definition at line 208 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::pfjet_eta[5]
private

Definition at line 209 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::pfjet_phi[5]
private

Definition at line 210 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

edm::InputTag WenuPlots::pfJetCollectionTag_
private

Definition at line 66 of file WenuPlots.h.

Referenced by analyze(), and WenuPlots().

edm::InputTag WenuPlots::PrimaryVerticesCollection_
private

Definition at line 67 of file WenuPlots.h.

Referenced by analyze(), and WenuPlots().

edm::InputTag WenuPlots::PrimaryVerticesCollectionBS_
private

Definition at line 68 of file WenuPlots.h.

Referenced by analyze(), and WenuPlots().

Float_t WenuPlots::pv_x
private

Definition at line 198 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::pv_y
private

Definition at line 198 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::pv_z
private

Definition at line 198 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Float_t WenuPlots::pvbs_x
private

Definition at line 249 of file WenuPlots.h.

Referenced by analyze().

Float_t WenuPlots::pvbs_y
private

Definition at line 249 of file WenuPlots.h.

Referenced by analyze().

Float_t WenuPlots::pvbs_z
private

Definition at line 249 of file WenuPlots.h.

Referenced by analyze().

Int_t WenuPlots::runNumber
private

Definition at line 187 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

Double_t WenuPlots::sihih_EB_
private

Definition at line 125 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::sihih_EB_inv
private

Definition at line 156 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::sihih_EE_
private

Definition at line 133 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::sihih_EE_inv
private

Definition at line 164 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::storeAllSecondElectronVariables_
private

Definition at line 236 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and WenuPlots().

Bool_t WenuPlots::storeExtraInformation_
private

Definition at line 232 of file WenuPlots.h.

Referenced by analyze(), beginJob(), and WenuPlots().

Double_t WenuPlots::tip_bspot_EB_
private

Definition at line 130 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::tip_bspot_EB_inv
private

Definition at line 161 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::tip_bspot_EE_
private

Definition at line 138 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::tip_bspot_EE_inv
private

Definition at line 169 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::trackIso_EB_
private

Definition at line 117 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::trackIso_EB_inv
private

Definition at line 148 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::trackIso_EE_
private

Definition at line 121 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::trackIso_EE_inv
private

Definition at line 152 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::trackIsoUser_EB_
private

Definition at line 141 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::trackIsoUser_EB_inv
private

Definition at line 172 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Double_t WenuPlots::trackIsoUser_EE_
private

Definition at line 144 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::trackIsoUser_EE_inv
private

Definition at line 175 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

Bool_t WenuPlots::useConversionRejection_
private

Definition at line 59 of file WenuPlots.h.

Referenced by PassPreselectionCriteria(), and WenuPlots().

Bool_t WenuPlots::useExpectedMissingHits_
private

Definition at line 60 of file WenuPlots.h.

Referenced by PassPreselectionCriteria(), and WenuPlots().

Bool_t WenuPlots::usePrecalcID_
private

Definition at line 53 of file WenuPlots.h.

Referenced by analyze(), CheckCuts(), and WenuPlots().

std::string WenuPlots::usePrecalcIDSign_
private

Definition at line 54 of file WenuPlots.h.

Referenced by CheckCuts(), and WenuPlots().

std::string WenuPlots::usePrecalcIDType_
private

Definition at line 55 of file WenuPlots.h.

Referenced by CheckCuts(), and WenuPlots().

Double_t WenuPlots::usePrecalcIDValue_
private

Definition at line 56 of file WenuPlots.h.

Referenced by CheckCuts(), and WenuPlots().

Bool_t WenuPlots::usePreselection_
private

Definition at line 62 of file WenuPlots.h.

Referenced by analyze(), and WenuPlots().

Bool_t WenuPlots::useValidFirstPXBHit_
private

Definition at line 58 of file WenuPlots.h.

Referenced by PassPreselectionCriteria(), and WenuPlots().

TTree* WenuPlots::vbtfPresele_tree
private

Definition at line 228 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

TTree* WenuPlots::vbtfSele_tree
private

Definition at line 227 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

std::vector<Float_t> WenuPlots::VtxNormalizedChi2
private

Definition at line 246 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

std::vector<Float_t> WenuPlots::VtxNormalizedChi2BS
private

Definition at line 248 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

std::vector<Int_t> WenuPlots::VtxTracksSize
private

Definition at line 245 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

std::vector<Int_t> WenuPlots::VtxTracksSizeBS
private

Definition at line 247 of file WenuPlots.h.

Referenced by analyze(), and beginJob().

TFile* WenuPlots::WENU_VBTFpreseleFile_
private

Definition at line 225 of file WenuPlots.h.

Referenced by beginJob(), and endJob().

std::string WenuPlots::WENU_VBTFpreseleFileName_
private

Definition at line 230 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

TFile* WenuPlots::WENU_VBTFselectionFile_
private

Definition at line 226 of file WenuPlots.h.

Referenced by beginJob(), and endJob().

std::string WenuPlots::WENU_VBTFselectionFileName_
private

Definition at line 229 of file WenuPlots.h.

Referenced by beginJob(), and WenuPlots().

edm::InputTag WenuPlots::wenuCollectionTag_
private

Definition at line 64 of file WenuPlots.h.

Referenced by analyze(), and WenuPlots().