CMS 3D CMS Logo

All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
TriggerSummaryProducerRAW.cc
Go to the documentation of this file.
1 
14 
16 
17 #include<string>
18 
19 //
20 // constructors and destructor
21 //
23  pn_(ps.getParameter<std::string>("processName")),
24  selector_(edm::ProcessNameSelector(pn_)),
25  tns_(), fobs_()
26 {
27  if (pn_=="@") {
28  // use tns
30  // get tns pointer
32  if (tns_!=0) {
34  } else {
35  edm::LogError("TriggerSummaryProducerRaw") << "HLT Error: TriggerNamesService pointer = 0!";
36  pn_="*";
37  }
38  } else {
39  edm::LogError("TriggerSummaryProducerRaw") << "HLT Error: TriggerNamesService not available!";
40  pn_="*";
41  }
43  }
44 
45  LogDebug("TriggerSummaryProducerRaw") << "Using process name: '" << pn_ <<"'";
46  produces<trigger::TriggerEventWithRefs>();
47 
48 }
49 
51 {
52 }
53 
54 //
55 // member functions
56 //
57 
58 // ------------ method called to produce the data ------------
59 void
61 {
62  using namespace std;
63  using namespace edm;
64  using namespace reco;
65  using namespace trigger;
66 
67  // reset from previous event
68  fobs_.clear();
69 
70  // get all filter objects created in requested process
71  iEvent.getMany(selector_,fobs_);
72  const unsigned int nfob(fobs_.size());
73  LogDebug("TriggerSummaryProducerRaw") << "Number of filter objects found: " << nfob;
74 
75  // construct single RAW product
76  auto_ptr<TriggerEventWithRefs> product(new TriggerEventWithRefs(pn_,nfob));
77  for (unsigned int ifob=0; ifob!=nfob; ++ifob) {
78  const string& label (fobs_[ifob].provenance()->moduleLabel());
79  const string& instance (fobs_[ifob].provenance()->productInstanceName());
80  const string& process (fobs_[ifob].provenance()->processName());
81  const InputTag tag(label,instance,process);
82  LogTrace("TriggerSummaryProducerRaw")
83  << ifob << " " << tag << endl
84  << " Sizes: "
85  << " 1/" << fobs_[ifob]->photonSize()
86  << " 2/" << fobs_[ifob]->electronSize()
87  << " 3/" << fobs_[ifob]->muonSize()
88  << " 4/" << fobs_[ifob]->jetSize()
89  << " 5/" << fobs_[ifob]->compositeSize()
90  << " 6/" << fobs_[ifob]->basemetSize()
91  << " 7/" << fobs_[ifob]->calometSize()
92  << " 8/" << fobs_[ifob]->pixtrackSize()
93  << " 9/" << fobs_[ifob]->l1emSize()
94  << " A/" << fobs_[ifob]->l1muonSize()
95  << " B/" << fobs_[ifob]->l1jetSize()
96  << " C/" << fobs_[ifob]->l1etmissSize()
97  << " D/" << fobs_[ifob]->l1hfringsSize()
98  << " E/" << fobs_[ifob]->pfjetSize()
99  << " F/" << fobs_[ifob]->pftauSize()
100  << endl;
101  product->addFilterObject(tag,*fobs_[ifob]);
102  }
103 
104  // place product in Event
105  OrphanHandle<TriggerEventWithRefs> ref = iEvent.put(product);
106  LogTrace("TriggerSummaryProducerRaw") << "Number of filter objects packed: " << ref->size();
107 
108  return;
109 }
#define LogDebug(id)
std::string const & getProcessName() const
static PFTauRenderPlugin instance
TriggerSummaryProducerRAW(const edm::ParameterSet &)
int iEvent
Definition: GenABIO.cc:243
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:85
void getMany(SelectorBase const &sel, std::vector< Handle< PROD > > &results) const
Definition: Event.h:388
std::vector< edm::Handle< trigger::TriggerFilterObjectWithRefs > > fobs_
handles to the filter objects
#define LogTrace(id)
std::string pn_
process name
edm::service::TriggerNamesService * tns_
the pointer to the current TriggerNamesService
virtual void produce(edm::Event &, const edm::EventSetup &)
edm::ProcessNameSelector selector_
selector for getMany methods
tuple process
Definition: LaserDQM_cfg.py:3