ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/UserCode/MitPhysics/Mods/interface/GeneratorMod.h
Revision: 1.22
Committed: Sun Apr 5 18:36:26 2009 UTC (16 years, 1 month ago) by loizides
Content type: text/plain
Branch: MAIN
CVS Tags: Mit_009
Changes since 1.21: +1 -2 lines
Log Message:
Cleanup

File Contents

# User Rev Content
1 loizides 1.1 //--------------------------------------------------------------------------------------------------
2 loizides 1.22 // $Id: GeneratorMod.h,v 1.21 2009/04/03 22:42:59 ceballos Exp $
3 loizides 1.1 //
4     // GeneratorMod
5     //
6 loizides 1.4 // This module collects interesting generator information and publishes collections
7     // for subsequent modules.
8 loizides 1.1 //
9 loizides 1.4 // Authors: G.Ceballos
10 loizides 1.1 //--------------------------------------------------------------------------------------------------
11    
12 loizides 1.4 #ifndef MITPHYSICS_MODS_GENERATORMOD_H
13     #define MITPHYSICS_MODS_GENERATORMOD_H
14 loizides 1.1
15     #include "MitAna/TreeMod/interface/BaseMod.h"
16     #include "MitAna/DataTree/interface/Collections.h"
17    
18     class TH1D;
19     class TH2D;
20    
21     namespace mithep
22     {
23     class GeneratorMod : public BaseMod
24     {
25     public:
26     GeneratorMod(const char *name="GeneratorMod",
27 loizides 1.4 const char *title="Generator information module");
28    
29 loizides 1.12 const char *GetMCPartName() const { return fMCPartName; }
30 ceballos 1.21 const char *GetMCMETName() const { return fMCMETName; }
31 loizides 1.19 const char *GetMCLeptonsName() const { return fMCLeptonsName; }
32 loizides 1.12 const char *GetMCAllLeptonsName() const { return fMCAllLeptonsName; }
33     const char *GetMCTausName() const { return fMCTausName; }
34     const char *GetMCNeutrinosName() const { return fMCNeutrinosName; }
35     const char *GetMCQuarksName() const { return fMCQuarksName; }
36     const char *GetMCqqHsName() const { return fMCqqHsName; }
37     const char *GetMCBosonsName() const { return fMCBosonsName; }
38     const char *GetMCPhotonsName() const { return fMCPhotonsName; }
39     void SetMCPartName(const char *s) { fMCPartName = s; }
40 ceballos 1.21 void SetMCMETName(const char * s) { fMCMETName = s; }
41 loizides 1.12 void SetMCLeptonsName(const char * s) { fMCLeptonsName = s; }
42     void SetMCAllLeptonsName(const char * s) { fMCAllLeptonsName = s; }
43     void SetMCTausName(const char *s) { fMCTausName = s; }
44     void SetMCNeutrinosName(const char *s) { fMCNeutrinosName = s; }
45     void SetMCQuarksName(const char *s) { fMCQuarksName = s; }
46     void SetMCqqHsName(const char *s) { fMCqqHsName = s; }
47     void SetMCBosonsName(const char *s) { fMCBosonsName = s; }
48     void SetMCPhotonsName(const char *s) { fMCPhotonsName = s; }
49     void SetPtLeptonMin(Double_t x) { fPtLeptonMin = x; }
50     void SetEtaLeptonMax(Double_t x) { fEtaLeptonMax = x; }
51     void SetPtPhotonMin(Double_t x) { fPtPhotonMin = x; }
52     void SetEtaPhotonMax(Double_t x) { fEtaPhotonMax = x; }
53 loizides 1.19 void SetPdgIdCut(UInt_t d) { fPdgIdCut = d; }
54 ceballos 1.18 void SetMassMinCut(Double_t x) { fMassMinCut = x; }
55     void SetMassMaxCut(Double_t x) { fMassMaxCut = x; }
56 loizides 1.4
57 loizides 1.1 protected:
58 loizides 1.14 void Process();
59     void SlaveBegin();
60    
61 loizides 1.12 Bool_t fFillHist; //=true then fill histos (def=0)
62     TString fMCPartName; //name of MCParticle branch
63 ceballos 1.21 TString fMCMETName; //name of met coll
64     TString fMCLeptonsName; //name of lepton coll (from W/Z/H)
65 loizides 1.12 TString fMCAllLeptonsName; //name of lepton coll (all)
66     TString fMCTausName; //name of tau coll (hadronic decays)
67     TString fMCNeutrinosName; //name of neutrinos coll
68     TString fMCQuarksName; //name of quarks coll
69     TString fMCqqHsName; //name of qqH coll
70     TString fMCBosonsName; //name of bosons coll
71     TString fMCPhotonsName; //name of photons coll
72     Double_t fPtLeptonMin; //pt min for leptons
73     Double_t fEtaLeptonMax; //eta max for leptons
74     Double_t fPtPhotonMin; //pt min for photons
75     Double_t fEtaPhotonMax; //eta max for photons
76 loizides 1.19 UInt_t fPdgIdCut; //pdg id for particle used to select on mass (0=off)
77     Double_t fMassMinCut; //mass min for given PdgId particle
78     Double_t fMassMaxCut; //mass max for given PdgId particle
79 loizides 1.12 const MCParticleCol *fParticles; //!MCParticle branch
80 ceballos 1.21 TH1D *hDGenMet[10]; //!histos for gen MET
81     TH1D *hDGenLeptons[40]; //!histos for W/Z/H leptons
82 loizides 1.12 TH1D *hDGenAllLeptons[20]; //!histos for all leptons
83     TH1D *hDGenTaus[20]; //!histos for taus
84     TH1D *hDGenNeutrinos[20]; //!histos for neutrinos
85     TH1D *hDGenQuarks[20]; //!histos for quarks
86     TH1D *hDGenWBF[20]; //!histos for WBF
87     TH1D *hDGenBosons[20]; //!histos for bosons
88     TH1D *hDGenPhotons[20]; //!histos for photons
89 loizides 1.13 TH1D *hDVMass[20]; //!histos for auxiliar work
90 ceballos 1.17
91 loizides 1.16 ClassDef(GeneratorMod, 1) // Module to gather generator information
92 loizides 1.1 };
93     }
94     #endif