1 |
#include "PhysicsTools/PatUtils/interface/EventHypothesisTools.h"
|
2 |
|
3 |
using namespace pat::eventhypothesis;
|
4 |
|
5 |
AndFilter::AndFilter(ParticleFilter *f1, ParticleFilter *f2) :
|
6 |
filters_(2)
|
7 |
{
|
8 |
filters_.push_back(f1); filters_.push_back(f2);
|
9 |
}
|
10 |
|
11 |
bool AndFilter::operator()(const CandRefType &cand, const std::string &role) const {
|
12 |
for (boost::ptr_vector<ParticleFilter>::const_iterator it = filters_.begin(); it != filters_.end(); ++it) {
|
13 |
if (! (*it)(cand, role) ) return false;
|
14 |
}
|
15 |
return true;
|
16 |
}
|
17 |
|
18 |
OrFilter::OrFilter(ParticleFilter *f1, ParticleFilter *f2) :
|
19 |
filters_(2)
|
20 |
{
|
21 |
filters_.push_back(f1); filters_.push_back(f2);
|
22 |
}
|
23 |
|
24 |
bool OrFilter::operator()(const CandRefType &cand, const std::string &role) const {
|
25 |
for (boost::ptr_vector<ParticleFilter>::const_iterator it = filters_.begin(); it != filters_.end(); ++it) {
|
26 |
if ( (*it)(cand, role) ) return true;
|
27 |
}
|
28 |
return false;
|
29 |
}
|
30 |
|
31 |
ByPdgId::ByPdgId(int32_t pdgCode, bool alsoAntiparticle) :
|
32 |
pdgCode_(alsoAntiparticle ? std::abs(pdgCode) : pdgCode),
|
33 |
antiparticle_(alsoAntiparticle)
|
34 |
{
|
35 |
}
|
36 |
|
37 |
bool ByPdgId::operator()(const CandRefType &cand, const std::string &role) const {
|
38 |
return antiparticle_ ?
|
39 |
(std::abs(cand->pdgId()) == pdgCode_) :
|
40 |
(cand->pdgId() == pdgCode_);
|
41 |
}
|
42 |
|
43 |
ByString::ByString(const std::string &cut) :
|
44 |
sel_(cut)
|
45 |
{
|
46 |
}
|
47 |
|
48 |
bool ByString::operator()(const CandRefType &cand, const std::string &role) const {
|
49 |
return sel_(*cand);
|
50 |
}
|