20 using namespace boost;
30 std::vector<double> calibHF_eta_step;
31 std::vector<double> calibHF_a_EMonly;
32 std::vector<double> calibHF_b_HADonly;
33 std::vector<double> calibHF_a_EMHAD;
34 std::vector<double> calibHF_b_EMHAD;
36 calibHF_eta_step = iConfig.
getParameter<std::vector<double> >(
"calibHF_eta_step");
37 calibHF_a_EMonly = iConfig.
getParameter<std::vector<double> >(
"calibHF_a_EMonly");
38 calibHF_b_HADonly = iConfig.
getParameter<std::vector<double> >(
"calibHF_b_HADonly");
39 calibHF_a_EMHAD = iConfig.
getParameter<std::vector<double> >(
"calibHF_a_EMHAD");
40 calibHF_b_EMHAD = iConfig.
getParameter<std::vector<double> >(
"calibHF_b_EMHAD");
41 boost::shared_ptr<PFEnergyCalibrationHF>
42 thepfEnergyCalibrationHF (
new PFEnergyCalibrationHF(calibHF_use,calibHF_eta_step,calibHF_a_EMonly,calibHF_b_HADonly,calibHF_a_EMHAD,calibHF_b_EMHAD) ) ;
52 if( iConfig.
existsAs<
bool>(
"useEGammaFilters") ) {
53 use_EGammaFilters_ = iConfig.
getParameter<
bool>(
"useEGammaFilters");
55 use_EGammaFilters_ =
false;
69 if(use_EGammaFilters_) {
70 usePFElectrons_ =
false;
71 usePFPhotons_ =
false;
79 = (usePFPhotons_) ? iConfig.
getParameter<
bool>(
"useRegressionFromDB") :
false;
84 if( useEGammaElectrons_) {
92 std::vector<double> calibPFSCEle_Fbrem_barrel;
93 std::vector<double> calibPFSCEle_Fbrem_endcap;
94 std::vector<double> calibPFSCEle_barrel;
95 std::vector<double> calibPFSCEle_endcap;
96 usePFSCEleCalib = iConfig.
getParameter<
bool>(
"usePFSCEleCalib");
97 calibPFSCEle_Fbrem_barrel = iConfig.
getParameter<std::vector<double> >(
"calibPFSCEle_Fbrem_barrel");
98 calibPFSCEle_Fbrem_endcap = iConfig.
getParameter<std::vector<double> >(
"calibPFSCEle_Fbrem_endcap");
99 calibPFSCEle_barrel = iConfig.
getParameter<std::vector<double> >(
"calibPFSCEle_barrel");
100 calibPFSCEle_endcap = iConfig.
getParameter<std::vector<double> >(
"calibPFSCEle_endcap");
101 boost::shared_ptr<PFSCEnergyCalibration>
102 thePFSCEnergyCalibration (
new PFSCEnergyCalibration(calibPFSCEle_Fbrem_barrel,calibPFSCEle_Fbrem_endcap,
103 calibPFSCEle_barrel,calibPFSCEle_endcap ));
105 bool useEGammaSupercluster = iConfig.
getParameter<
bool>(
"useEGammaSupercluster");
106 double sumEtEcalIsoForEgammaSC_barrel = iConfig.
getParameter<
double>(
"sumEtEcalIsoForEgammaSC_barrel");
107 double sumEtEcalIsoForEgammaSC_endcap = iConfig.
getParameter<
double>(
"sumEtEcalIsoForEgammaSC_endcap");
108 double coneEcalIsoForEgammaSC = iConfig.
getParameter<
double>(
"coneEcalIsoForEgammaSC");
109 double sumPtTrackIsoForEgammaSC_barrel = iConfig.
getParameter<
double>(
"sumPtTrackIsoForEgammaSC_barrel");
110 double sumPtTrackIsoForEgammaSC_endcap = iConfig.
getParameter<
double>(
"sumPtTrackIsoForEgammaSC_endcap");
111 double coneTrackIsoForEgammaSC = iConfig.
getParameter<
double>(
"coneTrackIsoForEgammaSC");
112 unsigned int nTrackIsoForEgammaSC = iConfig.
getParameter<
unsigned int>(
"nTrackIsoForEgammaSC");
116 produces<reco::PFCandidateCollection>();
117 produces<reco::PFCandidateCollection>(
"CleanedHF");
118 produces<reco::PFCandidateCollection>(
"CleanedCosmicsMuons");
119 produces<reco::PFCandidateCollection>(
"CleanedTrackerAndGlobalMuons");
120 produces<reco::PFCandidateCollection>(
"CleanedFakeMuons");
121 produces<reco::PFCandidateCollection>(
"CleanedPunchThroughMuons");
122 produces<reco::PFCandidateCollection>(
"CleanedPunchThroughNeutralHadrons");
123 produces<reco::PFCandidateCollection>(
"AddedMuonsAndHadrons");
126 if (usePFElectrons_) {
127 produces<reco::PFCandidateCollection>(electronOutputCol_);
128 produces<reco::PFCandidateElectronExtraCollection>(electronExtraOutputCol_);
132 produces<reco::PFCandidatePhotonExtraCollection>(photonExtraOutputCol_);
146 string mvaWeightFileEleID
147 = iConfig.
getParameter<
string>(
"pf_electronID_mvaWeightFile");
149 bool applyCrackCorrectionsForElectrons
150 = iConfig.
getParameter<
bool>(
"pf_electronID_crackCorrection");
152 string path_mvaWeightFileEleID;
160 string path_mvaWeightFileConvID;
161 string mvaWeightFileConvID;
162 string path_mvaWeightFileGCorr;
163 string path_mvaWeightFileLCorr;
165 string path_mvaWeightFileRes;
166 double mvaConvCut=-99.;
167 double sumPtTrackIsoForPhoton = 99.;
168 double sumPtTrackIsoSlopeForPhoton = 99.;
172 mvaWeightFileConvID =iConfig.
getParameter<
string>(
"pf_convID_mvaWeightFile");
173 mvaConvCut = iConfig.
getParameter<
double>(
"pf_conv_mvaCut");
175 sumPtTrackIsoForPhoton = iConfig.
getParameter<
double>(
"sumPtTrackIsoForPhoton");
176 sumPtTrackIsoSlopeForPhoton = iConfig.
getParameter<
double>(
"sumPtTrackIsoSlopeForPhoton");
181 if(!useRegressionFromDB_) {
182 string mvaWeightFileLCorr=iConfig.
getParameter<
string>(
"pf_locC_mvaWeightFile");
184 string mvaWeightFileGCorr=iConfig.
getParameter<
string>(
"pf_GlobC_mvaWeightFile");
186 string mvaWeightFileRes=iConfig.
getParameter<
string>(
"pf_Res_mvaWeightFile");
189 TFile *fgbr =
new TFile(path_mvaWeightFileGCorr.c_str(),
"READ");
190 ReaderGC_ =(
const GBRForest*)fgbr->Get(
"GBRForest");
191 TFile *fgbr2 =
new TFile(path_mvaWeightFileLCorr.c_str(),
"READ");
192 ReaderLC_ = (
const GBRForest*)fgbr2->Get(
"GBRForest");
193 TFile *fgbr3 =
new TFile(path_mvaWeightFileRes.c_str(),
"READ");
194 ReaderRes_ = (
const GBRForest*)fgbr3->Get(
"GBRForest");
195 LogDebug(
"PFProducer")<<
"Will set regressions from binary files " <<endl;
202 bool useProtectionsForJetMET(
false);
203 double ele_iso_pt(0.0), ele_iso_mva_barrel(0.0), ele_iso_mva_endcap(0.0),
204 ele_iso_combIso_barrel(0.0), ele_iso_combIso_endcap(0.0),
206 unsigned int ele_missinghits(0);
207 double ph_MinEt(0.0), ph_combIso(0.0), ph_HoE(0.0),
208 ph_sietaieta_eb(0.0),ph_sietaieta_ee(0.0);
209 string ele_iso_mvaWeightFile(
""), ele_iso_path_mvaWeightFile(
"");
213 if(use_EGammaFilters_) {
214 ele_iso_mvaWeightFile = iConfig.
getParameter<
string>(
"isolatedElectronID_mvaWeightFile");
216 inputTagPFEGammaCandidates_ = consumes<edm::View<reco::PFCandidate> >((iConfig.
getParameter<
edm::InputTag>(
"PFEGammaCandidates")));
217 inputTagValueMapGedElectrons_ = consumes<edm::ValueMap<reco::GsfElectronRef>>(iConfig.
getParameter<
edm::InputTag>(
"GedElectronValueMap"));
218 inputTagValueMapGedPhotons_ = consumes<edm::ValueMap<reco::PhotonRef> >(iConfig.
getParameter<
edm::InputTag>(
"GedPhotonValueMap"));
219 ele_iso_pt = iConfig.
getParameter<
double>(
"electron_iso_pt");
220 ele_iso_mva_barrel = iConfig.
getParameter<
double>(
"electron_iso_mva_barrel");
221 ele_iso_mva_endcap = iConfig.
getParameter<
double>(
"electron_iso_mva_endcap");
222 ele_iso_combIso_barrel = iConfig.
getParameter<
double>(
"electron_iso_combIso_barrel");
223 ele_iso_combIso_endcap = iConfig.
getParameter<
double>(
"electron_iso_combIso_endcap");
224 ele_noniso_mva = iConfig.
getParameter<
double>(
"electron_noniso_mvaCut");
225 ele_missinghits = iConfig.
getParameter<
unsigned int>(
"electron_missinghits");
226 ph_MinEt = iConfig.
getParameter<
double>(
"photon_MinEt");
227 ph_combIso = iConfig.
getParameter<
double>(
"photon_combIso");
229 ph_sietaieta_eb = iConfig.
getParameter<
double>(
"photon_SigmaiEtaiEta_barrel");
230 ph_sietaieta_ee = iConfig.
getParameter<
double>(
"photon_SigmaiEtaiEta_endcap");
231 useProtectionsForJetMET =
233 ele_protectionsForJetMET =
235 ph_protectionsForJetMET =
241 bool rejectTracks_Bad
244 bool rejectTracks_Step45
247 bool usePFNuclearInteractions
248 = iConfig.
getParameter<
bool>(
"usePFNuclearInteractions");
250 bool usePFConversions
256 double dptRel_DispVtx
265 useCalibrationsFromDB_
268 boost::shared_ptr<PFEnergyCalibration>
276 pfAlgo_.reset(
new PFAlgo);
282 pfAlgo_->setParameters( nSigmaECAL,
285 thepfEnergyCalibrationHF);
288 pfAlgo_->setPFEleParameters(mvaEleCut,
289 path_mvaWeightFileEleID,
291 thePFSCEnergyCalibration,
293 sumEtEcalIsoForEgammaSC_barrel,
294 sumEtEcalIsoForEgammaSC_endcap,
295 coneEcalIsoForEgammaSC,
296 sumPtTrackIsoForEgammaSC_barrel,
297 sumPtTrackIsoForEgammaSC_endcap,
298 nTrackIsoForEgammaSC,
299 coneTrackIsoForEgammaSC,
300 applyCrackCorrectionsForElectrons,
303 useEGammaSupercluster);
308 pfAlgo_->setPFPhotonParameters(usePFPhotons_,
309 path_mvaWeightFileConvID,
314 sumPtTrackIsoForPhoton,
315 sumPtTrackIsoSlopeForPhoton);
319 pfAlgo_->setEGammaParameters(use_EGammaFilters_,
320 ele_iso_path_mvaWeightFile,
324 ele_iso_combIso_barrel,
325 ele_iso_combIso_endcap,
328 useProtectionsForJetMET,
329 ele_protectionsForJetMET,
335 ph_protectionsForJetMET);
339 pfAlgo_->setDisplacedVerticesParameters(rejectTracks_Bad,
341 usePFNuclearInteractions,
346 if (usePFNuclearInteractions)
347 pfAlgo_->setCandConnectorParameters( iCfgCandConnector );
352 pfAlgo_->setPFMuonAndFakeParameters(iConfig);
357 double minHFCleaningPt
359 double minSignificance
361 double maxSignificance
363 double minSignificanceReduction
364 = iConfig.
getParameter<
double>(
"minSignificanceReduction");
371 pfAlgo_->setPostHFCleaningParameters(postHFCleaning,
375 minSignificanceReduction,
380 std::vector<edm::InputTag>
tags =iConfig.
getParameter< std::vector<edm::InputTag> >(
"cleanedHF");
381 for (
unsigned int i=0;
i<tags.size();++
i)
382 inputTagCleanedHF_.push_back(consumes<reco::PFRecHitCollection>(tags[
i]));
385 useVerticesForNeutral_ = iConfig.
getParameter<
bool>(
"useVerticesForNeutral");
389 pfAlgo_->setHOTag(useHO_);
397 pfAlgo_->setDebug( debug_ );
426 if ( useCalibrationsFromDB_ ) {
433 pfAlgo_->thePFEnergyCalibration()->setCalibrationFunctions(pfCalibrations);
457 if(useRegressionFromDB_) {
465 ReaderLCEB_=readerPFLCEB.
product();
467 ReaderLCEE_=readerPFLCEE.
product();
469 ReaderGCBarrel_=readerPFGCEB.
product();
471 ReaderGCEndCapHighr9_=readerPFGCEEHR9.
product();
473 ReaderGCEndCapLowr9_=readerPFGCEELR9.
product();
475 ReaderEcalRes_=readerPFRes.
product();
484 pfAlgo_->setPFPhotonRegWeights(ReaderLCEB_,ReaderLCEE_,ReaderGCBarrel_,ReaderGCEndCapHighr9_, ReaderGCEndCapLowr9_, ReaderEcalRes_ );
493 LogDebug(
"PFProducer")<<
"START event: "
495 <<
" in run "<<iEvent.
id().
run()<<endl;
501 bool gotVertices = iEvent.
getByToken(vertices_,vertices);
504 err<<
"Cannot find vertices for this event.Continuing Without them ";
505 LogError(
"PFProducer")<<err.str()<<endl;
509 pfAlgo_->setPFVertexParameters(useVerticesForNeutral_,vertices.
product());
521 if ( postMuonCleaning_ ) {
524 pfAlgo_->setMuonHandle(muons);
527 if (useEGammaElectrons_) {
529 iEvent.
getByToken( inputTagEgammaElectrons_, egelectrons );
530 pfAlgo_->setEGElectronCollection(*egelectrons);
533 if(use_EGammaFilters_) {
538 iEvent.
getByToken(inputTagPFEGammaCandidates_,pfEgammaCandidates);
543 iEvent.
getByToken(inputTagValueMapGedElectrons_,valueMapGedElectrons);
546 iEvent.
getByToken(inputTagValueMapGedPhotons_,valueMapGedPhotons);
548 pfAlgo_->setEGammaCollections(*pfEgammaCandidates,
549 *valueMapGedElectrons,
550 *valueMapGedPhotons);
555 LogDebug(
"PFProducer")<<
"particle flow is starting"<<endl;
559 pfAlgo_->reconstructParticles( blocks );
563 str<<(*pfAlgo_)<<endl;
565 LogInfo(
"PFProducer") <<str.str()<<endl;
571 if(usePFElectrons_) {
572 auto_ptr< reco::PFCandidateElectronExtraCollection >
573 pOutputElectronCandidateExtraCollection( pfAlgo_->transferElectronExtra() );
576 iEvent.
put(pOutputElectronCandidateExtraCollection,electronExtraOutputCol_);
577 pfAlgo_->setElectronExtraRef(electronExtraProd);
583 auto_ptr< reco::PFCandidatePhotonExtraCollection >
584 pOutputPhotonCandidateExtraCollection( pfAlgo_->transferPhotonExtra() );
587 iEvent.
put(pOutputPhotonCandidateExtraCollection,photonExtraOutputCol_);
588 pfAlgo_->setPhotonExtraRef(photonExtraProd);
592 auto_ptr< reco::PFCandidateCollection >
593 pCosmicsMuonCleanedCandidateCollection( pfAlgo_->getPFMuonAlgo()->transferCleanedCosmicCandidates() );
595 auto_ptr< reco::PFCandidateCollection >
596 pTrackerAndGlobalCleanedMuonCandidateCollection( pfAlgo_->getPFMuonAlgo()->transferCleanedTrackerAndGlobalCandidates() );
598 auto_ptr< reco::PFCandidateCollection >
599 pFakeCleanedMuonCandidateCollection( pfAlgo_->getPFMuonAlgo()->transferCleanedFakeCandidates() );
601 auto_ptr< reco::PFCandidateCollection >
602 pPunchThroughMuonCleanedCandidateCollection( pfAlgo_->getPFMuonAlgo()->transferPunchThroughCleanedMuonCandidates() );
604 auto_ptr< reco::PFCandidateCollection >
605 pPunchThroughHadronCleanedCandidateCollection( pfAlgo_->getPFMuonAlgo()->transferPunchThroughCleanedHadronCandidates() );
607 auto_ptr< reco::PFCandidateCollection >
608 pAddedMuonCandidateCollection( pfAlgo_->getPFMuonAlgo()->transferAddedMuonCandidates() );
612 for (
unsigned ihf=0;
ihf<inputTagCleanedHF_.size(); ++
ihf ) {
614 bool foundHF = iEvent.
getByToken( inputTagCleanedHF_[
ihf], hfCleaned );
615 if (!foundHF)
continue;
616 for (
unsigned jhf=0; jhf<(*hfCleaned).size(); ++jhf ) {
617 hfCopy.push_back( (*hfCleaned)[jhf] );
620 pfAlgo_->checkCleaning( hfCopy );
623 auto_ptr< reco::PFCandidateCollection >
624 pCleanedCandidateCollection( pfAlgo_->transferCleanedCandidates() );
628 auto_ptr< reco::PFCandidateCollection >
629 pOutputCandidateCollection( pfAlgo_->transferCandidates() );
633 LogDebug(
"PFProducer")<<
"particle flow: putting products in the event"<<endl;
634 if ( verbose_ )
std::cout <<
"particle flow: putting products in the event. Here the full list"<<endl;
636 for( reco::PFCandidateCollection::const_iterator itCand = (*pOutputCandidateCollection).begin(); itCand != (*pOutputCandidateCollection).end(); itCand++) {
638 if (verbose_ )
std::cout << nC <<
")" << (*itCand).particleId() << std::endl;
645 iEvent.
put(pOutputCandidateCollection);
646 iEvent.
put(pCleanedCandidateCollection,
"CleanedHF");
648 if ( postMuonCleaning_ ) {
649 iEvent.
put(pCosmicsMuonCleanedCandidateCollection,
"CleanedCosmicsMuons");
650 iEvent.
put(pTrackerAndGlobalCleanedMuonCandidateCollection,
"CleanedTrackerAndGlobalMuons");
651 iEvent.
put(pFakeCleanedMuonCandidateCollection,
"CleanedFakeMuons");
652 iEvent.
put(pPunchThroughMuonCleanedCandidateCollection,
"CleanedPunchThroughMuons");
653 iEvent.
put(pPunchThroughHadronCleanedCandidateCollection,
"CleanedPunchThroughNeutralHadrons");
654 iEvent.
put(pAddedMuonCandidateCollection,
"AddedMuonsAndHadrons");
659 auto_ptr< reco::PFCandidateCollection >
660 pOutputElectronCandidateCollection( pfAlgo_->transferElectronCandidates() );
661 iEvent.
put(pOutputElectronCandidateCollection,electronOutputCol_);
T getParameter(std::string const &) const
EventNumber_t event() const
T getUntrackedParameter(std::string const &, T const &) const
bool existsAs(std::string const ¶meterName, bool trackiness=true) const
checks if a parameter exists as a given type
bool getByToken(EDGetToken token, Handle< PROD > &result) const
std::vector< PFRecHit > PFRecHitCollection
collection of PFRecHit objects
virtual void produce(edm::Event &, const edm::EventSetup &) override
PFProducer(const edm::ParameterSet &)
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
virtual void beginRun(const edm::Run &, const edm::EventSetup &) override
T const * product() const
T const * product() const
volatile std::atomic< bool > shutdown_flag false