ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/UserCode/MitProd/TreeFiller/interface/FillerMetaInfos.h
Revision: 1.25
Committed: Thu Nov 19 15:10:33 2009 UTC (15 years, 5 months ago) by loizides
Content type: text/plain
Branch: MAIN
CVS Tags: Mit_012b
Changes since 1.24: +9 -1 lines
Log Message:
Added L1

File Contents

# User Rev Content
1 loizides 1.1 //--------------------------------------------------------------------------------------------------
2 loizides 1.25 // $Id: FillerMetaInfos.h,v 1.24 2009/09/25 08:42:50 loizides Exp $
3 loizides 1.1 //
4     // FillerMetaInfos
5 loizides 1.15 //
6 loizides 1.19 // Implementation of a filler that stores all of the meta information, as well as the L1 and HLT
7     // trigger info into the corresponding bambu objects.
8 loizides 1.1 //
9     // Authors: C.Loizides
10     //--------------------------------------------------------------------------------------------------
11    
12 loizides 1.9 #ifndef MITPROD_TREEFILLER_FILLERMETAINFOS_H
13     #define MITPROD_TREEFILLER_FILLERMETAINFOS_H
14 loizides 1.1
15 loizides 1.18 #include "HLTrigger/HLTcore/interface/HLTConfigProvider.h"
16 loizides 1.25 #include "MitAna/DataTree/interface/L1TriggerMaskFwd.h"
17 loizides 1.21 #include "MitAna/DataTree/interface/TriggerObjectBaseFwd.h"
18     #include "MitAna/DataTree/interface/TriggerObjectRelFwd.h"
19 loizides 1.1 #include "MitProd/TreeFiller/interface/BaseFiller.h"
20 loizides 1.10
21     class THashTable;
22 loizides 1.1
23     namespace mithep
24     {
25 loizides 1.5 class RunInfo;
26     class EventHeader;
27     class LAHeader;
28 loizides 1.12 class TriggerMask;
29 loizides 1.5
30 loizides 1.1 class FillerMetaInfos : public BaseFiller
31     {
32     public:
33 loizides 1.13 FillerMetaInfos(const edm::ParameterSet &cfg, const char *name="MetaInfos", bool active=1);
34 loizides 1.1 ~FillerMetaInfos();
35    
36 loizides 1.24 void BookDataBlock(TreeWriter &tws, const edm::EventSetup &es);
37 loizides 1.16 void FillDataBlock(const edm::Event &e, const edm::EventSetup &es);
38     void FillRunInfo(const edm::Event &e, const edm::EventSetup &es);
39     void FillHltInfo(const edm::Event &e, const edm::EventSetup &es);
40     void FillHltTrig(const edm::Event &e, const edm::EventSetup &es);
41 loizides 1.25 void FillL1Trig(const edm::Event &e, const edm::EventSetup &es);
42 loizides 1.5
43 loizides 1.1 private:
44 loizides 1.23 const char *Istr() const;
45    
46     std::string evtName_; //event branch name (must be unique)
47     std::string runTreeName_; //run info tree name (must be unique)
48     std::string lahTreeName_; //look-ahead header tree name (must be unique)
49     std::string hltTreeName_; //hlt tree name (must be unique)
50 loizides 1.10 Bool_t hltActive_; //=true if HLT info are filled
51 loizides 1.17 std::vector<std::string> hltProcNames_; //HLT process name(s)
52     std::string hltProcName_; //HLT process name to be used
53 loizides 1.10 std::string hltResName_; //HLT trigger results edm name
54     std::string hltEvtName_; //HLT trigger event edm name
55     std::string hltTableName_; //HLT trigger table branch name
56     std::string hltLabelName_; //HLT trigger label branch name
57     std::string hltBitsName_; //HLT trigger bits branch name
58     std::string hltObjsName_; //HLT trigger branch name
59 loizides 1.25 Bool_t l1Active_; //=true if some L1 info are filled
60     std::string l1GTRecName_; //L1 global trigger record edm name
61     std::string l1TBitsName_; //L1 technical bit name
62     std::string l1ABitsName_; //L1 algo bit name
63 loizides 1.10 TreeWriter *tws_; //tree writer (not owned)
64     EventHeader *eventHeader_; //event header
65     LAHeader *evtLAHeader_; //look-ahead event header
66     RunInfo *runInfo_; //run info block
67     TTree *runTree_; //run info tree (not owned)
68     TTree *laTree_; //look ahead tree (not owned)
69     Int_t runEntries_; //number of run info entries
70     std::map<UInt_t,Int_t> runmap_; //map between run number and entry number
71 loizides 1.12 TriggerMask *hltBits_; //HLT trigger bit mask
72 loizides 1.11 std::vector<std::string> *hltTable_; //HLT trigger table
73 loizides 1.10 std::map<std::string,Short_t> *hltTabMap_; //HLT trigger labels map
74 loizides 1.11 std::vector<std::string> *hltLabels_; //HLT module labels
75 loizides 1.10 std::map<std::string,Short_t> *hltLabMap_; //HLT module labels map
76     TriggerObjectBaseArr *hltObjs_; //HLT trigger objects
77     TriggerObjectRelArr *hltRels_; //HLT trigger objects relation
78     TTree *hltTree_; //HLT trigger tree (not owned)
79     HLTConfigProvider hltConfig_; //HLT config from provenance
80     Int_t hltEntries_; //number of hlt info entries
81     UShort_t fileNum_; //file number of current file
82 loizides 1.25 L1TriggerMask *l1TBits_; //L1 technical trigger bit mask
83     L1TriggerMask *l1ABits_; //L1 algorithm trigger bit mask
84 loizides 1.7
85 loizides 1.23 static Int_t instance_; //counts active instances
86 loizides 1.1 };
87     }
88     #endif