25 #include <unordered_map> 38 :
citk::IsolationConeDefinitionBase(c),
39 _vetoConeSize2EB(
std::
pow(c.getParameter<double>(
"VetoConeSizeBarrel"), 2.0)),
40 _vetoConeSize2EE(
std::
pow(c.getParameter<double>(
"VetoConeSizeEndcaps"), 2.0)),
41 _miniAODVertexCodes(c.getParameter<
std::vector<unsigned> >(
"miniAODVertexCodes")),
42 _vertexIndex(c.getParameter<
int>(
"vertexIndex")),
43 _isolateAgainst(c.getParameter<
std::
string>(
"isolateAgainst")) {
45 sprintf(buf,
"BarVeto%.2f-EndVeto%.2f",
std::sqrt(_vetoConeSize2EB),
std::sqrt(_vetoConeSize2EE));
47 auto decimal = _additionalCode.find(
'.');
48 while (decimal != std::string::npos) {
49 _additionalCode.erase(decimal, 1);
50 decimal = _additionalCode.find(
'.');
64 const float _vetoConeSize2EB, _vetoConeSize2EE;
79 bool isEB = (seed->seed().subdetId() ==
EcalBarrel);
81 const float vetoConeSize2 = (isEB ? _vetoConeSize2EB : _vetoConeSize2EE);
84 if (aspacked->charge() != 0) {
85 bool is_vertex_allowed =
false;
86 for (
const unsigned vtxtype : _miniAODVertexCodes) {
87 if (vtxtype == aspacked->fromPV(_vertexIndex)) {
88 is_vertex_allowed =
true;
92 result &= (is_vertex_allowed);
94 result &= deltar2 > vetoConeSize2 && deltar2 < _coneSize2;
96 result &= deltar2 > vetoConeSize2 && deltar2 < _coneSize2;
98 throw cms::Exception(
"InvalidIsolationInput") <<
"The supplied candidate to be used as isolation " 99 <<
"was neither a reco::PFCandidate nor a pat::PackedCandidate!";
const unsigned _vertexIndex
T const * get() const
Returns C++ pointer to the item.
const std::vector< unsigned > _miniAODVertexCodes
bool isInIsolationCone(const reco::CandidatePtr &photon, const reco::CandidatePtr &pfCandidate) const final
edm::Ptr< pat::PackedCandidate > PackedCandidatePtr
void setConsumes(edm::ConsumesCollector) override
const std::string _isolateAgainst
edm::EDGetTokenT< reco::VertexCollection > _vtxToken
bool isNonnull() const
Checks for non-null.
edm::Ptr< reco::Photon > recoPhotonPtr
constexpr auto deltaR2(const T1 &t1, const T2 &t2) -> decltype(t1.eta())
~PhotonPFIsolationWithConeVeto() override
Destructor.
#define DEFINE_EDM_PLUGIN(factory, type, name)
PhotonPFIsolationWithConeVeto(const edm::ParameterSet &c)
Power< A, B >::type pow(const A &a, const B &b)