16 invert_ ( cfg.getParameter<bool>(
"invert" ) ),
27 allowedTauDecays.
existsAs<
bool>(
"muon" )||
28 allowedTauDecays.
existsAs<
bool>(
"oneProng" )||
29 allowedTauDecays.
existsAs<
bool>(
"threeProng") );
41 decayBranchA_.push_back(decayBranchA.getParameter<
bool>(
"electron"));
42 decayBranchA_.push_back(decayBranchA.getParameter<
bool>(
"muon" ));
43 decayBranchA_.push_back(decayBranchA.getParameter<
bool>(
"tau" ));
66 unsigned int iTop=0,iBeauty=0,iElec=0,iMuon=0,iTau=0;
67 for(reco::GenParticleCollection::const_iterator
top=parts.begin();
top!=parts.end(); ++
top){
104 log <<
"----------------------" <<
"\n"
105 <<
" iTop : " << iTop <<
"\n"
106 <<
" iBeauty : " << iBeauty <<
"\n"
107 <<
" iElec : " << iElec <<
"\n"
108 <<
" iMuon : " << iMuon <<
"\n"
109 <<
" iTau : " << iTau+iLep;
111 log <<
" (" << iTau <<
")\n";
116 log <<
"- - - - - - - - - - - " <<
"\n";
118 iLep+=iElec+iMuon+iTau;
122 if( (iTop==2) && (iBeauty==2) ){
140 if(iElec+iMuon+iTau!=channel){
144 if((iElec==2)||(iMuon==2)||(iTau==2)) {
175 return (
std::abs(part->pdgId())==pdgId) ?
true :
false;
195 return (part.
charge()!=0);
208 bool electronTau =
false;
209 bool muonTau =
false;
210 unsigned int nch = 0;
217 if(daughter->pdgId()==tau.
pdgId()){
std::vector< GenParticle > GenParticleCollection
collection of GenParticles
T getParameter(std::string const &) const
bool existsAs(std::string const ¶meterName, bool trackiness=true) const
checks if a parameter exists as a given type
Decay decayBranchA_
top decay branch 1
virtual int status() const =0
status word
bool accept(const edm::Event &event, const edm::TriggerResults &triggerTable, const std::string &triggerPath)
bool search(reco::GenParticleCollection::const_iterator &part, int pdgId, std::string &inputType) const
search for particle with pdgId in given listing (for top)
static const unsigned int kDecayChannels
virtual const_iterator end() const =0
last daughter const_iterator
bool restrictTauDecays_
restrict tau decays
Abs< T >::type abs(const T &t)
virtual int charge() const =0
electric charge
TtDecayChannelSelector(const edm::ParameterSet &)
std contructor
unsigned int countProngs(const reco::Candidate &part) const
count the number of charged particles for tau decays
Decay decayBranchB_
top decay branch 2
virtual int pdgId() const =0
PDG identifier.
bool allowElectron_
allow tau decays into electron
bool tauDecay(const reco::Candidate &) const
check tau decay to be leptonic, 1-prong or 3-prong
bool allow3Prong_
allow 2-prong tau decays
bool allowMuon_
allow tau decays into muon
unsigned int decayChannel() const
return decay channel to select for from configuration
unsigned int checkSum(const Decay &vec) const
~TtDecayChannelSelector()
default destructor
bool operator()(const reco::GenParticleCollection &parts, std::string inputType) const
operator for decay channel selection
static const std::string kGenParticles
virtual const_iterator begin() const =0
first daughter const_iterator
bool allow1Prong_
allow 1-prong tau decays
volatile std::atomic< bool > shutdown_flag false
bool invert_
invert selection