CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
List of all members | Public Types | Public Member Functions
TtFullLepEvtPartons Class Reference

Class to fill partons in a well defined order for fully-leptonic ttbar events. More...

#include "AnalysisDataFormats/TopObjects/interface/TtFullLepEvtPartons.h"

Inheritance diagram for TtFullLepEvtPartons:
TtEventPartons

Public Types

enum  { B, BBar, Lepton, LeptonBar }
 

Public Member Functions

 TtFullLepEvtPartons (const std::vector< std::string > &partonsToIgnore=std::vector< std::string >())
 default constructor More...
 
std::vector< const
reco::Candidate * > 
vec (const TtGenEvent &genEvt) override
 return vector of partons in the order defined in the corresponding enum More...
 
 ~TtFullLepEvtPartons () override
 default destructor More...
 
- Public Member Functions inherited from TtEventPartons
void expand (std::vector< int > &vec)
 insert dummy index -3 for all partons that were chosen to be ignored More...
 
 TtEventPartons ()
 default constructor More...
 
virtual ~TtEventPartons ()
 default destructor More...
 

Additional Inherited Members

- Protected Member Functions inherited from TtEventPartons
reco::CandidatedummyCandidatePtr () const
 return pointer to an empty reco::Candidate More...
 
void prune (std::vector< const reco::Candidate * > &vec)
 erase partons from vector if they where chosen to be ignored More...
 
- Protected Attributes inherited from TtEventPartons
std::vector< bool > ignorePartons_
 flag partons that were chosen not to be used More...
 

Detailed Description

Class to fill partons in a well defined order for fully-leptonic ttbar events.

This class is mainly used for the jet-parton matching in TopTools.

Definition at line 21 of file TtFullLepEvtPartons.h.

Member Enumeration Documentation

anonymous enum

fully-leptonic parton enum used to define the order in the vector for lepton and jet combinatorics

Enumerator
B 
BBar 
Lepton 
LeptonBar 

Definition at line 25 of file TtFullLepEvtPartons.h.

Constructor & Destructor Documentation

TtFullLepEvtPartons::TtFullLepEvtPartons ( const std::vector< std::string > &  partonsToIgnore = std::vector<std::string>())

default constructor

Definition at line 6 of file TtFullLepEvtPartons.cc.

References B, BBar, Exception, mps_fire::i, TtEventPartons::ignorePartons_, and str.

6  {
7  // default: use all partons
8  for (unsigned int i = 0; i < 2; i++)
9  ignorePartons_.push_back(false);
10  // read vector of strings and flag partons to be ignored
11  for (std::vector<std::string>::const_iterator str = partonsToIgnore.begin(); str != partonsToIgnore.end(); ++str) {
12  if ((*str) == "B")
13  ignorePartons_[B] = true;
14  else if ((*str) == "BBar")
15  ignorePartons_[BBar] = true;
16  else
17  throw cms::Exception("Configuration")
18  << "The following string in partonsToIgnore is not supported: " << (*str) << "\n";
19  }
20 }
std::vector< bool > ignorePartons_
flag partons that were chosen not to be used
#define str(s)
TtFullLepEvtPartons::~TtFullLepEvtPartons ( )
inlineoverride

default destructor

Definition at line 31 of file TtFullLepEvtPartons.h.

31 {};

Member Function Documentation

std::vector< const reco::Candidate * > TtFullLepEvtPartons::vec ( const TtGenEvent genEvt)
overridevirtual

return vector of partons in the order defined in the corresponding enum

Implements TtEventPartons.

Definition at line 22 of file TtFullLepEvtPartons.cc.

References B, TopGenEvent::b(), BBar, TopGenEvent::bBar(), TtEventPartons::dummyCandidatePtr(), mps_fire::i, TtGenEvent::isFullLeptonic(), and TtEventPartons::prune().

22  {
23  std::vector<const reco::Candidate*> vec;
24 
25  if (genEvt.isFullLeptonic()) {
26  // fill vector with partons from genEvent
27  // (use enum for positions of the partons in the vector)
28  vec.resize(2);
29  vec[B] = genEvt.b() ? genEvt.b() : dummyCandidatePtr();
30  vec[BBar] = genEvt.bBar() ? genEvt.bBar() : dummyCandidatePtr();
31  } else {
32  // fill vector with dummy objects if the event is not fully-leptonic ttbar
33  for (unsigned i = 0; i < 2; i++)
34  vec.push_back(dummyCandidatePtr());
35  }
36 
37  // erase partons from vector if they where chosen to be ignored
38  prune(vec);
39 
40  return vec;
41 }
const reco::GenParticle * b() const
return b quark if available; 0 else
Definition: TopGenEvent.h:97
std::vector< const reco::Candidate * > vec(const TtGenEvent &genEvt) override
return vector of partons in the order defined in the corresponding enum
void prune(std::vector< const reco::Candidate * > &vec)
erase partons from vector if they where chosen to be ignored
const reco::GenParticle * bBar() const
return anti-b quark if available; 0 else
Definition: TopGenEvent.h:99
bool isFullLeptonic(bool excludeTauLeptons=false) const
check if the event can be classified as full leptonic
Definition: TtGenEvent.h:42
reco::Candidate * dummyCandidatePtr() const
return pointer to an empty reco::Candidate