CMS 3D CMS Logo

TriggerSummaryProducerRAW.cc
Go to the documentation of this file.
1 
12 
22 
23 #include <memory>
24 #include <vector>
25 
26 //
27 // constructors and destructor
28 //
30  pn_(ps.getParameter<std::string>("processName"))
31 {
32  if (pn_=="@") {
33 
35  if (tns.isAvailable()) {
36  pn_ = tns->getProcessName();
37  } else {
38  edm::LogError("TriggerSummaryProducerRaw") << "HLT Error: TriggerNamesService not available!";
39  pn_="*";
40  }
41  }
42 
43  LogDebug("TriggerSummaryProducerRaw") << "Using process name: '" << pn_ <<"'";
44  produces<trigger::TriggerEventWithRefs>();
45 
46  // Tell the getter what type of products to get and
47  // also the process to get them from
49  callWhenNewProductsRegistered(getterOfProducts_);
50 }
51 
53 
54 //
55 // member functions
56 //
57 
60  desc.add<std::string>("processName","@");
61  descriptions.add("triggerSummaryProducerRAW", desc);
62 }
63 
64 // ------------ method called to produce the data ------------
65 void
67 {
68  using namespace std;
69  using namespace edm;
70  using namespace reco;
71  using namespace trigger;
72 
73  std::vector<edm::Handle<trigger::TriggerFilterObjectWithRefs> > fobs;
74  getterOfProducts_.fillHandles(iEvent, fobs);
75 
76  const unsigned int nfob(fobs.size());
77  LogDebug("TriggerSummaryProducerRaw") << "Number of filter objects found: " << nfob;
78 
79  // construct single RAW product
80  unique_ptr<TriggerEventWithRefs> product(new TriggerEventWithRefs(pn_,nfob));
81  for (unsigned int ifob=0; ifob!=nfob; ++ifob) {
82  const string& label (fobs[ifob].provenance()->moduleLabel());
83  const string& instance (fobs[ifob].provenance()->productInstanceName());
84  const string& process (fobs[ifob].provenance()->processName());
85  const InputTag tag(label,instance,process);
86  LogTrace("TriggerSummaryProducerRaw")
87  << ifob << " " << tag << endl
88  << " Sizes: "
89  << " 1/" << fobs[ifob]->photonSize()
90  << " 2/" << fobs[ifob]->electronSize()
91  << " 3/" << fobs[ifob]->muonSize()
92  << " 4/" << fobs[ifob]->jetSize()
93  << " 5/" << fobs[ifob]->compositeSize()
94  << " 6/" << fobs[ifob]->basemetSize()
95  << " 7/" << fobs[ifob]->calometSize()
96 
97  << " 8/" << fobs[ifob]->pixtrackSize()
98  << " 9/" << fobs[ifob]->l1emSize()
99  << " A/" << fobs[ifob]->l1muonSize()
100  << " B/" << fobs[ifob]->l1jetSize()
101  << " C/" << fobs[ifob]->l1etmissSize()
102  << " D/" << fobs[ifob]->l1hfringsSize()
103  << " E/" << fobs[ifob]->pfjetSize()
104  << " F/" << fobs[ifob]->pftauSize()
105  << " G/" << fobs[ifob]->pfmetSize()
106  << " I/" << fobs[ifob]->l1tmuonSize()
107  << " J/" << fobs[ifob]->l1tegammaSize()
108  << " K/" << fobs[ifob]->l1tjetSize()
109  << " L/" << fobs[ifob]->l1ttauSize()
110  << " M/" << fobs[ifob]->l1tetsumSize()
111  << endl;
112  LogTrace("TriggerSummaryProducerRaw") << "TriggerSummaryProducerRaw::addFilterObjects( )"
113  << "\n fobs[ifob]->l1tmuonIds().size() = " << fobs[ifob]->l1tmuonIds().size()
114  << "\n fobs[ifob]->l1tmuonRefs().size() = " << fobs[ifob]->l1tmuonRefs().size() << endl;
115  LogTrace("TriggerSummaryProducerRaw") << "TriggerSummaryProducerRaw::addFilterObjects( )"
116  << "\n fobs[ifob]->l1tegammaIds().size() = " << fobs[ifob]->l1tegammaIds().size()
117  << "\n fobs[ifob]->l1tegammaRefs().size() = " << fobs[ifob]->l1tegammaRefs().size() << endl;
118  LogTrace("TriggerSummaryProducerRaw") << "TriggerSummaryProducerRaw::addFilterObjects( )"
119  << "\n fobs[ifob]->l1tjetIds().size() = " << fobs[ifob]->l1tjetIds().size()
120  << "\n fobs[ifob]->l1tjetRefs().size() = " << fobs[ifob]->l1tjetRefs().size() << endl;
121  LogTrace("TriggerSummaryProducerRaw") << "TriggerSummaryProducerRaw::addFilterObjects( )"
122  << "\n fobs[ifob]->l1ttauIds().size() = " << fobs[ifob]->l1ttauIds().size()
123  << "\n fobs[ifob]->l1ttauRefs().size() = " << fobs[ifob]->l1ttauRefs().size() << endl;
124  LogTrace("TriggerSummaryProducerRaw") << "TriggerSummaryProducerRaw::addFilterObjects( )"
125  << "\n fobs[ifob]->l1tetsumIds().size() = " << fobs[ifob]->l1tetsumIds().size()
126  << "\n fobs[ifob]->l1tetsumRefs().size() = " << fobs[ifob]->l1tetsumRefs().size() << endl;
127  product->addFilterObject(tag,*fobs[ifob]);
128  }
129 
130  // place product in Event
131  OrphanHandle<TriggerEventWithRefs> ref = iEvent.put(std::move(product));
132  LogTrace("TriggerSummaryProducerRaw") << "Number of filter objects packed: " << ref->size();
133 
134  return;
135 }
#define LogDebug(id)
void callWhenNewProductsRegistered(std::function< void(BranchDescription const &)> const &func)
Definition: ProducerBase.h:76
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:127
std::string const & getProcessName() const
static PFTauRenderPlugin instance
edm::GetterOfProducts< trigger::TriggerFilterObjectWithRefs > getterOfProducts_
TriggerSummaryProducerRAW(const edm::ParameterSet &)
int iEvent
Definition: GenABIO.cc:230
~TriggerSummaryProducerRAW() override
bool isAvailable() const
Definition: Service.h:46
ParameterDescriptionBase * add(U const &iLabel, T const &value)
#define LogTrace(id)
std::string pn_
process name
size_type size() const
number of filters
void add(std::string const &label, ParameterSetDescription const &psetDescription)
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
fixed size matrix
HLT enums.
void fillHandles(edm::Event const &event, std::vector< edm::Handle< T > > &handles) const
void produce(edm::Event &, const edm::EventSetup &) override
def move(src, dest)
Definition: eostools.py:510