9 for (std::map<int, double>::iterator iter = esigma_.begin(); iter != esigma_.end(); ++iter) {
10 iter->second = s * (iter->second);
15 LogDebug(
"PileUpSubtractor") <<
"The subtractor correcting jets...\n";
20 (*fjInputs_) = fjOriginalInputs_;
21 rescaleRMS(nSigmaPU_);
22 subtractPedestal(*fjInputs_);
23 const fastjet::JetDefinition&
def = *fjJetDefinition_;
24 if (!doAreaFastjet_ && !doRhoFastjet_) {
27 fjClusterSeq_ =
ClusterSequencePtr(
new fastjet::ClusterSequenceArea(*fjInputs_, def, *fjActiveArea_));
30 (*fjJets_) = fastjet::sorted_by_pt(fjClusterSeq_->inclusive_jets(jetPtMin_));
32 jetOffset_.reserve(fjJets_->size());
34 vector<fastjet::PseudoJet>::iterator pseudojetTMP = fjJets_->begin(), jetsEnd = fjJets_->end();
35 for (; pseudojetTMP != jetsEnd; ++pseudojetTMP) {
36 int ijet = pseudojetTMP - fjJets_->begin();
39 std::vector<fastjet::PseudoJet>
towers = sorted_by_pt(pseudojetTMP->constituents());
42 for (vector<fastjet::PseudoJet>::const_iterator ito = towers.begin(), towEnd = towers.end(); ito != towEnd; ++ito) {
44 int it =
ieta(originalTower);
45 double Original_Et = originalTower->
et();
46 double etnew = Original_Et - (*emean_.find(it)).
second - (*esigma_.find(it)).
second;
49 newjetet = newjetet + etnew;
50 jetOffset_[ijet] += Original_Et - etnew;
56 LogDebug(
"PileUpSubtractor") <<
"The subtractor subtracting pedestals...\n";
60 vector<fastjet::PseudoJet> newcoll;
62 for (vector<fastjet::PseudoJet>::iterator input_object = coll.begin(), fjInputsEnd = coll.end();
63 input_object != fjInputsEnd;
70 double Original_Et = itow->
et();
72 Original_Et = getEt(itow);
75 double etnew = Original_Et - (*(emean_.find(it))).second - (*(esigma_.find(it))).second;
76 float mScale = etnew / input_object->Et();
81 input_object->py() * mScale,
82 input_object->pz() * mScale,
83 input_object->e() * mScale);
85 int index = input_object->user_index();
86 input_object->reset_momentum(towP4.px(), towP4.py(), towP4.pz(), towP4.energy());
87 input_object->set_user_index(index);
89 if (etnew > 0. && dropZeroTowers_)
90 newcoll.push_back(*input_object);
98 LogDebug(
"PileUpSubtractor") <<
"The subtractor calculating pedestals...\n";
100 map<int, double> emean2;
101 map<int, int> ntowers;
103 int ietaold = -10000;
108 for (
int i = ietamin_;
i < ietamax_ + 1;
i++) {
115 for (vector<fastjet::PseudoJet>::const_iterator input_object = coll.begin(), fjInputsEnd = coll.end();
116 input_object != fjInputsEnd;
119 ieta0 =
ieta(originalTower);
120 double Original_Et = originalTower->
et();
122 Original_Et = getEt(originalTower);
125 if (ieta0 - ietaold != 0) {
126 emean_[ieta0] = emean_[ieta0] + Original_Et;
127 emean2[ieta0] = emean2[ieta0] + Original_Et * Original_Et;
131 emean_[ieta0] = emean_[ieta0] + Original_Et;
132 emean2[ieta0] = emean2[ieta0] + Original_Et * Original_Et;
137 for (map<int, int>::const_iterator gt = geomtowers_.begin(); gt != geomtowers_.end(); gt++) {
138 int it = (*gt).first;
140 double e1 = (*(emean_.find(it))).second;
141 double e2 = (*emean2.find(it)).
second;
142 int nt = (*gt).second - (*(ntowersWithJets_.find(it))).second;
144 LogDebug(
"PileUpSubtractor") <<
" ieta : " << it <<
" number of towers : " << nt <<
" e1 : " << e1 <<
" e2 : " << e2
148 emean_[it] = e1 /
nt;
149 double eee = e2 / nt - e1 * e1 / (nt *
nt);
152 esigma_[it] = nSigmaPU_ *
sqrt(eee);
157 LogDebug(
"PileUpSubtractor") <<
" ieta : " << it <<
" Pedestals : " << emean_[it] <<
" " << esigma_[it] <<
"\n";
void calculatePedestal(std::vector< fastjet::PseudoJet > const &coll) override
double getEt(const reco::CandidatePtr &in) const
ROOT::Math::LorentzVector< ROOT::Math::PxPyPzE4D< double > > XYZTLorentzVectorD
Lorentz vector with cylindrical internal representation using pseudorapidity.
T const * get() const
Returns C++ pointer to the item.
Sin< T >::type sin(const T &t)
double getEta(const reco::CandidatePtr &in) const
Geom::Theta< T > theta() const
U second(std::pair< T, U > const &p)
virtual double et() const =0
transverse energy
void offsetCorrectJets() override
void rescaleRMS(double s)
void subtractPedestal(std::vector< fastjet::PseudoJet > &coll) override
CaloTowerDetId id() const
std::shared_ptr< fastjet::ClusterSequence > ClusterSequencePtr