From 54d9ed923e0db1bfdbc77615158853547a24cbb2 Mon Sep 17 00:00:00 2001 From: Slava Krutelyov Date: Mon, 1 Feb 2016 18:04:56 +0100 Subject: [PATCH] add extra initialization checks for short-cirquited cases with no inputs (effects not accounted in PR 11902) --- .../plugins/VirtualJetProducer.cc | 41 ++++++++++++------- 1 file changed, 26 insertions(+), 15 deletions(-) diff --git a/RecoJets/JetProducers/plugins/VirtualJetProducer.cc b/RecoJets/JetProducers/plugins/VirtualJetProducer.cc index a0333bc0feb85..6bc39c0091e7c 100644 --- a/RecoJets/JetProducers/plugins/VirtualJetProducer.cc +++ b/RecoJets/JetProducers/plugins/VirtualJetProducer.cc @@ -618,16 +618,21 @@ void VirtualJetProducer::writeJets( edm::Event & iEvent, edm::EventSetup const& fastjet::ClusterSequenceAreaBase const* clusterSequenceWithArea = dynamic_cast ( &*fjClusterSeq_ ); - - for(int ie = 0; ie < nEta; ++ie){ - double eta = puCenters_[ie]; - double etamin=eta-puWidth_; - double etamax=eta+puWidth_; - fastjet::RangeDefinition range_rho(etamin,etamax); - fastjet::BackgroundEstimator bkgestim(*clusterSequenceWithArea,range_rho); - bkgestim.set_excluded_jets(fjexcluded_jets); - rhos->push_back(bkgestim.rho()); - sigmas->push_back(bkgestim.sigma()); + if (clusterSequenceWithArea ==nullptr ){ + if (fjJets_.size() > 0) { + throw cms::Exception("LogicError")<<"fjClusterSeq is not initialized while inputs are present\n "; + } + } else { + for(int ie = 0; ie < nEta; ++ie){ + double eta = puCenters_[ie]; + double etamin=eta-puWidth_; + double etamax=eta+puWidth_; + fastjet::RangeDefinition range_rho(etamin,etamax); + fastjet::BackgroundEstimator bkgestim(*clusterSequenceWithArea,range_rho); + bkgestim.set_excluded_jets(fjexcluded_jets); + rhos->push_back(bkgestim.rho()); + sigmas->push_back(bkgestim.sigma()); + } } iEvent.put(rhos,"rhos"); iEvent.put(sigmas,"sigmas"); @@ -644,11 +649,17 @@ void VirtualJetProducer::writeJets( edm::Event & iEvent, edm::EventSetup const& edm::LogWarning("StrangeNEmtpyJets") << "n_empty_jets is : " << clusterSequenceWithArea->n_empty_jets(*fjRangeDef_) << " with range " << fjRangeDef_->description() << "."; } */ - clusterSequenceWithArea->get_median_rho_and_sigma(*fjRangeDef_,false,*rho,*sigma,mean_area); - if((*rho < 0)|| (edm::isNotFinite(*rho))) { - edm::LogError("BadRho") << "rho value is " << *rho << " area:" << mean_area << " and n_empty_jets: " << clusterSequenceWithArea->n_empty_jets(*fjRangeDef_) << " with range " << fjRangeDef_->description() - <<". Setting rho to rezo."; - *rho = 0; + if (clusterSequenceWithArea ==nullptr ){ + if (fjJets_.size() > 0) { + throw cms::Exception("LogicError")<<"fjClusterSeq is not initialized while inputs are present\n "; + } + } else { + clusterSequenceWithArea->get_median_rho_and_sigma(*fjRangeDef_,false,*rho,*sigma,mean_area); + if((*rho < 0)|| (edm::isNotFinite(*rho))) { + edm::LogError("BadRho") << "rho value is " << *rho << " area:" << mean_area << " and n_empty_jets: " << clusterSequenceWithArea->n_empty_jets(*fjRangeDef_) << " with range " << fjRangeDef_->description() + <<". Setting rho to rezo."; + *rho = 0; + } } iEvent.put(rho,"rho"); iEvent.put(sigma,"sigma");