Skip to content

Commit

Permalink
Merged BHtaggerImplementation_12_3_0pre4 from repository jainshilpi w…
Browse files Browse the repository at this point in the history
…ith cms-merge-topic
  • Loading branch information
jainshilpi committed Feb 7, 2022
2 parents 9c3a5ca + ee342ca commit 9317de2
Show file tree
Hide file tree
Showing 12 changed files with 636 additions and 4 deletions.
9 changes: 9 additions & 0 deletions DataFormats/EgammaCandidates/interface/Photon.h
Original file line number Diff line number Diff line change
Expand Up @@ -579,6 +579,14 @@ namespace reco {
// go back to run2-like 2 effective depths if desired - depth 1 is the normal depth 1, depth 2 is the sum over the rest
void hcalToRun2EffDepth();

///MVA based beam halo tagger - trained for EE and for pT > 200 GeV
float haloTaggerMVAVal() const { return haloTaggerMVAVal_; }

///set the haloTaggerMVAVal here
void setHaloTaggerMVAVal(float x) {
haloTaggerMVAVal_ = x;
}

private:
/// check overlap with another candidate
bool overlap(const Candidate&) const override;
Expand All @@ -599,6 +607,7 @@ namespace reco {
MIPVariables mipVariableBlock_;
PflowIsolationVariables pfIsolation_;
PflowIDVariables pfID_;
float haloTaggerMVAVal_;
};

} // namespace reco
Expand Down
5 changes: 3 additions & 2 deletions DataFormats/EgammaCandidates/src/Photon.cc
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
using namespace reco;

Photon::Photon(const LorentzVector& p4, const Point& caloPos, const PhotonCoreRef& core, const Point& vtx)
: RecoCandidate(0, p4, vtx, 22), caloPosition_(caloPos), photonCore_(core), pixelSeed_(false) {}
: RecoCandidate(0, p4, vtx, 22), caloPosition_(caloPos), photonCore_(core), pixelSeed_(false),haloTaggerMVAVal_(-999) {}

Photon::Photon(const Photon& rhs)
: RecoCandidate(rhs),
Expand All @@ -19,7 +19,8 @@ Photon::Photon(const Photon& rhs)
saturationInfo_(rhs.saturationInfo_),
eCorrections_(rhs.eCorrections_),
mipVariableBlock_(rhs.mipVariableBlock_),
pfIsolation_(rhs.pfIsolation_) {}
pfIsolation_(rhs.pfIsolation_),
haloTaggerMVAVal_(rhs.haloTaggerMVAVal_) {}

Photon::~Photon() {}

Expand Down
3 changes: 2 additions & 1 deletion DataFormats/EgammaCandidates/src/classes_def.xml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,8 @@
</ioread>


<class name="reco::Photon" ClassVersion="17">
<class name="reco::Photon" ClassVersion="18">
<version ClassVersion="18" checksum="2393532952"/>
<version ClassVersion="17" checksum="4077732720"/>
<version ClassVersion="16" checksum="3459546220"/>
<version ClassVersion="15" checksum="577991108"/>
Expand Down
3 changes: 2 additions & 1 deletion DataFormats/PatCandidates/src/classes_def_objects.xml
Original file line number Diff line number Diff line change
Expand Up @@ -222,7 +222,8 @@
</ioread>

<class name="std::vector<pat::tau::TauPFEssential>" />
<class name="pat::Photon" ClassVersion="21">
<class name="pat::Photon" ClassVersion="22">
<version ClassVersion="22" checksum="1415449268"/>
<version ClassVersion="21" checksum="3263223164"/>
<version ClassVersion="20" checksum="1579185367"/>
<version ClassVersion="19" checksum="4285818507"/>
Expand Down
3 changes: 3 additions & 0 deletions RecoEgamma/EgammaPhotonProducers/python/gedPhotons_cfi.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
from RecoEgamma.PhotonIdentification.pfIsolationCalculator_cfi import *
from RecoEgamma.PhotonIdentification.isolationCalculator_cfi import *
from RecoEgamma.PhotonIdentification.mipVariable_cfi import *
from RecoEgamma.PhotonIdentification.mvaHaloVariable_cfi import *
from RecoEcal.EgammaClusterProducers.hybridSuperClusters_cfi import *
from RecoEcal.EgammaClusterProducers.multi5x5BasicClusters_cfi import *

Expand Down Expand Up @@ -39,6 +40,7 @@
isolationSumsCalculatorSet = cms.PSet(isolationSumsCalculator),
PFIsolationCalculatorSet = cms.PSet(pfIsolationCalculator),
mipVariableSet = cms.PSet(mipVariable),
mvaBasedHaloVariableSet = cms.PSet(mvaHaloVariable),
usePrimaryVertex = cms.bool(True),
primaryVertexProducer = cms.InputTag('offlinePrimaryVerticesWithBS'),
posCalc_t0_endcPresh = cms.double(3.6),
Expand All @@ -51,6 +53,7 @@
endcapEcalHits = cms.InputTag("ecalRecHit","EcalRecHitsEE"),
preshowerHits = cms.InputTag("ecalPreshowerRecHit","EcalRecHitsES"),
runMIPTagger = cms.bool(True),
runMVABasedHaloTagger = cms.bool(True),
highEt = cms.double(100.),
minR9Barrel = cms.double(0.94),
minR9Endcap = cms.double(0.95),
Expand Down
4 changes: 4 additions & 0 deletions RecoEgamma/EgammaPhotonProducers/python/photons_cfi.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

from RecoEgamma.PhotonIdentification.isolationCalculator_cfi import *
from RecoEgamma.PhotonIdentification.mipVariable_cfi import *
from RecoEgamma.PhotonIdentification.mvaHaloVariable_cfi import *
from RecoEcal.EgammaClusterProducers.hybridSuperClusters_cfi import *
from RecoEcal.EgammaClusterProducers.multi5x5BasicClusters_cfi import *
from RecoEgamma.EgammaIsolationAlgos.egammaHBHERecHitThreshold_cff import egammaHBHERecHit
Expand Down Expand Up @@ -30,6 +31,7 @@
candidateP4type = cms.string("fromEcalEnergy"),
isolationSumsCalculatorSet = cms.PSet(isolationSumsCalculator),
mipVariableSet = cms.PSet(mipVariable),
mvaBasedHaloVariableSet = cms.PSet(mvaHaloVariable),
usePrimaryVertex = cms.bool(True),
primaryVertexProducer = cms.InputTag('offlinePrimaryVerticesWithBS'),
posCalc_t0_endcPresh = cms.double(3.6),
Expand All @@ -42,6 +44,7 @@
endcapEcalHits = cms.InputTag("ecalRecHit","EcalRecHitsEE"),
preshowerHits = cms.InputTag("ecalPreshowerRecHit","EcalRecHitsES"),
runMIPTagger = cms.bool(True),
runMVABasedHaloTagger = cms.bool(True),
highEt = cms.double(100.),
minR9Barrel = cms.double(0.94),
minR9Endcap = cms.double(0.95),
Expand Down Expand Up @@ -161,6 +164,7 @@
hbheModule = cms.string('hbhereco'),
endcapEcalHits = cms.InputTag("ecalRecHit","EcalRecHitsEE"),
runMIPTagger = cms.bool(True),
runMVABasedHaloTagger = cms.bool(False),
highEt = cms.double(100.),
minR9Barrel = cms.double(10.0),
minR9Endcap = cms.double(10.0),
Expand Down
16 changes: 16 additions & 0 deletions RecoEgamma/EgammaPhotonProducers/src/GEDPhotonProducer.cc
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@
#include "RecoEgamma/EgammaPhotonAlgos/interface/PhotonEnergyCorrector.h"
#include "RecoEgamma/PhotonIdentification/interface/PhotonIsolationCalculator.h"
#include "RecoEgamma/PhotonIdentification/interface/PhotonMIPHaloTagger.h"
#include "RecoEgamma/PhotonIdentification/interface/PhotonMVABasedHaloTagger.h"
#include "RecoLocalCalo/EcalRecAlgos/interface/EcalSeverityLevelAlgo.h"
#include "RecoLocalCalo/EcalRecAlgos/interface/EcalSeverityLevelAlgoRcd.h"
#include "CondFormats/EcalObjects/interface/EcalPFRecHitThresholds.h"
Expand Down Expand Up @@ -174,6 +175,7 @@ class GEDPhotonProducer : public edm::stream::EDProducer<edm::GlobalCache<CacheD
double minR9Barrel_;
double minR9Endcap_;
bool runMIPTagger_;
bool runMVABasedHaloTagger_;

RecoStepInfo recoStep_;

Expand All @@ -183,6 +185,8 @@ class GEDPhotonProducer : public edm::stream::EDProducer<edm::GlobalCache<CacheD

//MIP
std::unique_ptr<PhotonMIPHaloTagger> photonMIPHaloTagger_ = nullptr;
//MVA based Halo tagger for the EE photons
std::unique_ptr<PhotonMVABasedHaloTagger> photonMVABasedHaloTagger_ = nullptr;

std::vector<double> preselCutValuesBarrel_;
std::vector<double> preselCutValuesEndcap_;
Expand Down Expand Up @@ -318,6 +322,7 @@ GEDPhotonProducer::GEDPhotonProducer(const edm::ParameterSet& config, const Cach
minR9Endcap_ = config.getParameter<double>("minR9Endcap");
usePrimaryVertex_ = config.getParameter<bool>("usePrimaryVertex");
runMIPTagger_ = config.getParameter<bool>("runMIPTagger");
runMVABasedHaloTagger_ = config.getParameter<bool>("runMVABasedHaloTagger");

candidateP4type_ = config.getParameter<std::string>("candidateP4type");
valueMapPFCandPhoton_ = config.getParameter<std::string>("valueMapPhotons");
Expand Down Expand Up @@ -411,6 +416,12 @@ GEDPhotonProducer::GEDPhotonProducer(const edm::ParameterSet& config, const Cach
photonMIPHaloTagger_->setup(mipVariableSet, consumesCollector());
}

if (recoStep_.isFinal() && runMVABasedHaloTagger_) {
edm::ParameterSet mvaBasedHaloVariableSet = config.getParameter<edm::ParameterSet>("mvaBasedHaloVariableSet");
photonMVABasedHaloTagger_ = std::make_unique<PhotonMVABasedHaloTagger>(mvaBasedHaloVariableSet, consumesCollector());

}

///Get the set for PF cluster isolation calculator
const edm::ParameterSet& pfECALClusIsolCfg = config.getParameter<edm::ParameterSet>("pfECALClusIsolCfg");
pfClusterProducer_ =
Expand Down Expand Up @@ -1057,6 +1068,11 @@ void GEDPhotonProducer::fillPhotonCollection(edm::Event& evt,
reco::Photon newCandidate(*phoRef);
iSC++;

if (runMVABasedHaloTagger_) { ///sets values only for EE, for EB it always returns 1
float BHmva = photonMVABasedHaloTagger_->calculateMVA(&newCandidate, evt, es);
newCandidate.setHaloTaggerMVAVal(BHmva);
}

// Calculate the PF isolation
reco::Photon::PflowIsolationVariables pfIso;
// The PFID are not recomputed since they have been already computed in the first loop with the DNN
Expand Down
16 changes: 16 additions & 0 deletions RecoEgamma/EgammaPhotonProducers/src/PhotonProducer.cc
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
#include "RecoEgamma/EgammaPhotonAlgos/interface/PhotonEnergyCorrector.h"
#include "RecoEgamma/PhotonIdentification/interface/PhotonIsolationCalculator.h"
#include "RecoEgamma/PhotonIdentification/interface/PhotonMIPHaloTagger.h"
#include "RecoEgamma/PhotonIdentification/interface/PhotonMVABasedHaloTagger.h"
#include "RecoLocalCalo/EcalRecAlgos/interface/EcalSeverityLevelAlgo.h"
#include "RecoLocalCalo/EcalRecAlgos/interface/EcalSeverityLevelAlgoRcd.h"
#include "RecoEgamma/EgammaElectronAlgos/interface/ElectronHcalHelper.h"
Expand Down Expand Up @@ -83,6 +84,7 @@ class PhotonProducer : public edm::stream::EDProducer<> {
double minR9Barrel_;
double minR9Endcap_;
bool runMIPTagger_;
bool runMVABasedHaloTagger_;

bool validConversions_;

Expand All @@ -95,6 +97,8 @@ class PhotonProducer : public edm::stream::EDProducer<> {

//MIP
PhotonMIPHaloTagger photonMIPHaloTagger_;
//MVA based Halo tagger for the EE photons
std::unique_ptr<PhotonMVABasedHaloTagger> photonMVABasedHaloTagger_ = nullptr;

std::vector<double> preselCutValuesBarrel_;
std::vector<double> preselCutValuesEndcap_;
Expand Down Expand Up @@ -127,6 +131,7 @@ PhotonProducer::PhotonProducer(const edm::ParameterSet& config)
minR9Endcap_ = config.getParameter<double>("minR9Endcap");
usePrimaryVertex_ = config.getParameter<bool>("usePrimaryVertex");
runMIPTagger_ = config.getParameter<bool>("runMIPTagger");
runMVABasedHaloTagger_ = config.getParameter<bool>("runMVABasedHaloTagger");

candidateP4type_ = config.getParameter<std::string>("candidateP4type");

Expand Down Expand Up @@ -231,6 +236,12 @@ PhotonProducer::PhotonProducer(const edm::ParameterSet& config)
edm::ParameterSet mipVariableSet = config.getParameter<edm::ParameterSet>("mipVariableSet");
photonMIPHaloTagger_.setup(mipVariableSet, consumesCollector());

if (runMVABasedHaloTagger_) {
edm::ParameterSet mvaBasedHaloVariableSet = config.getParameter<edm::ParameterSet>("mvaBasedHaloVariableSet");
photonMVABasedHaloTagger_ = std::make_unique<PhotonMVABasedHaloTagger>(mvaBasedHaloVariableSet, consumesCollector());
}


// Register the product
produces<reco::PhotonCollection>(PhotonCollection_);
}
Expand Down Expand Up @@ -487,6 +498,11 @@ void PhotonProducer::fillPhotonCollection(edm::Event& evt,
newCandidate.setMIPVariables(mipVar);
}

if (runMVABasedHaloTagger_) { ///sets values only for EE, for EB it always returns 1
double BHmva = photonMVABasedHaloTagger_->calculateMVA(&newCandidate, evt, es);
newCandidate.setHaloTaggerMVAVal(BHmva);
}

/// Pre-selection loose isolation cuts
bool isLooseEM = true;
if (newCandidate.pt() < highEt_) {
Expand Down
1 change: 1 addition & 0 deletions RecoEgamma/PhotonIdentification/BuildFile.xml
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
<use name="RecoLocalCalo/EcalRecAlgos"/>
<use name="RecoLocalCalo/HcalRecAlgos"/>
<use name="PhysicsTools/TensorFlow" />
<use name="CommonTools/MVAUtils" />
<export>
<lib name="1"/>
</export>
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
/** \class PhotonMVABasedHaloTagger
* \author Shilpi Jain (University of Minnesota)
* Links to the presentation:
1. ECAL DPG: https://indico.cern.ch/event/991261/contributions/4283096/attachments/2219229/3757719/beamHalo_31march_v1.pdf
2. JetMET POG: https://indico.cern.ch/event/1027614/contributions/4314949/attachments/2224472/3767396/beamHalo_12April.pdf
*/

#ifndef PhotonMVABasedHaloTagger_H
#define PhotonMVABasedHaloTagger_H

#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "DataFormats/EcalRecHit/interface/EcalRecHitCollections.h"
#include "DataFormats/EgammaCandidates/interface/Photon.h"
#include "FWCore/Framework/interface/ConsumesCollector.h"
#include "Geometry/CaloGeometry/interface/CaloGeometry.h"
#include "Geometry/Records/interface/CaloGeometryRecord.h"
#include "DataFormats/HcalRecHit/interface/HcalRecHitCollections.h"
#include "CondFormats/GBRForest/interface/GBRForest.h"
#include "RecoEcal/EgammaCoreTools/interface/EcalClusterLazyTools.h"
#include "RecoEgamma/EgammaIsolationAlgos/interface/EgammaHcalIsolation.h"
#include "CondFormats/EcalObjects/interface/EcalPFRecHitThresholds.h"
#include "CondFormats/DataRecord/interface/EcalPFRecHitThresholdsRcd.h"
#include <vector>

class PhotonMVABasedHaloTagger {
public:
PhotonMVABasedHaloTagger(const edm::ParameterSet& conf, edm::ConsumesCollector&& iC);
virtual ~PhotonMVABasedHaloTagger(){};

double calculateMVA(const reco::Photon* pho,
const edm::Event&iEvent,
const edm::EventSetup& es
);


void calphoClusCoordinECAL(const CaloGeometry* geo,
const reco::Photon*,
const EcalPFRecHitThresholds *thresholds,
edm::Handle<EcalRecHitCollection> ecalrechitCollHandle
);


void calmatchedHBHECoordForBothHypothesis(const CaloGeometry* geo,
const reco::Photon*,
edm::Handle<HBHERecHitCollection> hbheHitHandle
);


void calmatchedESCoordForBothHypothesis(const CaloGeometry* geo,
const reco::Photon*,
edm::Handle<EcalRecHitCollection> esrechitCollHandle
);

double calAngleBetweenEEAndSubDet(int nhits,
double subdetClusX,
double subdetClusY,
double subdetClusZ);


private:
int hcalClusNhits_samedPhi_, hcalClusNhits_samedR_;
int ecalClusNhits_, preshowerNhits_samedPhi_, preshowerNhits_samedR_;
double hcalClusX_samedPhi_, hcalClusY_samedPhi_, hcalClusZ_samedPhi_, hcalClusX_samedR_, hcalClusY_samedR_, hcalClusZ_samedR_;
double hcalClusE_samedPhi_, hcalClusE_samedR_;

double ecalClusX_, ecalClusY_, ecalClusZ_;
double preshowerX_samedPhi_, preshowerY_samedPhi_, preshowerZ_samedPhi_, preshowerX_samedR_, preshowerY_samedR_, preshowerZ_samedR_;
double ecalClusE_, preshowerE_samedPhi_, preshowerE_samedR_;
double noiseThrES_;

EgammaHcalIsolation::arrayHB recHitEThresholdHB_;
EgammaHcalIsolation::arrayHE recHitEThresholdHE_;

std::string trainingFileName_;

const edm::ESGetToken<CaloGeometry, CaloGeometryRecord> geometryToken_;
const edm::ESGetToken<EcalPFRecHitThresholds, EcalPFRecHitThresholdsRcd> ecalPFRechitThresholdsToken_;
const EcalClusterLazyTools::ESGetTokens ecalClusterToolsESGetTokens_;

edm::ESHandle<CaloGeometry> pG_;
edm::EDGetTokenT<double> rhoLabel_;
edm::EDGetTokenT<EcalRecHitCollection> EBecalCollection_;
edm::EDGetTokenT<EcalRecHitCollection> EEecalCollection_;
edm::EDGetTokenT<EcalRecHitCollection> ESCollection_;
edm::EDGetTokenT<HBHERecHitCollection> HBHERecHitsCollection_;
std::unique_ptr<const GBRForest> gbr_;

};

#endif // PhotonMVABasedHaloTagger_H
20 changes: 20 additions & 0 deletions RecoEgamma/PhotonIdentification/python/mvaHaloVariable_cfi.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import FWCore.ParameterSet.Config as cms
from RecoEgamma.EgammaIsolationAlgos.egammaHBHERecHitThreshold_cff import egammaHBHERecHit

pathToHaloMVATrainingFile = "RecoEgamma/PhotonIdentification/data/xgboostToTMVA_BHtagger.xml"
mvaHaloVariable = cms.PSet(
#required inputs
trainingFileName = cms.string(pathToHaloMVATrainingFile),
rhoLabel = cms.InputTag("fixedGridRhoFastjetAllTmp"),
barrelEcalRecHitCollection = cms.InputTag("ecalRecHit","EcalRecHitsEB"),
endcapEcalRecHitCollection = cms.InputTag("ecalRecHit","EcalRecHitsEE"),
esRecHitCollection = cms.InputTag("ecalPreshowerRecHit","EcalRecHitsES"),
HBHERecHitsCollection = egammaHBHERecHit.hbheRecHits,
recHitEThresholdHB = egammaHBHERecHit.recHitEThresholdHB,
recHitEThresholdHE = egammaHBHERecHit.recHitEThresholdHE,
noiseThrES = cms.double(0.0)


)


Loading

0 comments on commit 9317de2

Please sign in to comment.