FastJet  3.3.4
07-subtraction.cc
Go to the documentation of this file.
1 //----------------------------------------------------------------------
2 /// \file
3 /// \page Example07 07 - subtracting jet background contamination
4 ///
5 /// fastjet subtraction example program.
6 ///
7 /// run it with : ./07-subtraction < data/Pythia-Zp2jets-lhc-pileup-1ev.dat
8 ///
9 /// Source code: 07-subtraction.cc
10 //----------------------------------------------------------------------
11 
12 //STARTHEADER
13 // $Id: 07-subtraction.cc 4354 2018-04-22 07:12:37Z salam $
14 //
15 // Copyright (c) 2005-2018, Matteo Cacciari, Gavin P. Salam and Gregory Soyez
16 //
17 //----------------------------------------------------------------------
18 // This file is part of FastJet.
19 //
20 // FastJet is free software; you can redistribute it and/or modify
21 // it under the terms of the GNU General Public License as published by
22 // the Free Software Foundation; either version 2 of the License, or
23 // (at your option) any later version.
24 //
25 // The algorithms that underlie FastJet have required considerable
26 // development and are described in hep-ph/0512210. If you use
27 // FastJet as part of work towards a scientific publication, please
28 // include a citation to the FastJet paper.
29 //
30 // FastJet is distributed in the hope that it will be useful,
31 // but WITHOUT ANY WARRANTY; without even the implied warranty of
32 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
33 // GNU General Public License for more details.
34 //
35 // You should have received a copy of the GNU General Public License
36 // along with FastJet. If not, see <http://www.gnu.org/licenses/>.
37 //----------------------------------------------------------------------
38 //ENDHEADER
39 
40 #include "fastjet/PseudoJet.hh"
41 #include "fastjet/ClusterSequenceArea.hh"
42 #include "fastjet/Selector.hh"
43 #include "fastjet/tools/JetMedianBackgroundEstimator.hh"
44 #include "fastjet/tools/Subtractor.hh"
45 #include <iostream> // needed for io
46 #include <fastjet/config.h> // for the FASTJET_VERSION_NUMBER preprocessor symbol
47 
48 using namespace std;
49 using namespace fastjet;
50 
51 int main(){
52 
53  // read in input particles
54  //
55  // since we use here simulated data we can split the hard event
56  // from the full (i.e. with pileup added) one
57  //----------------------------------------------------------
58 
59  vector<PseudoJet> hard_event, full_event;
60 
61  // read in input particles. Keep the hard event generated by PYTHIA
62  // separated from the full event, so as to be able to gauge the
63  // "goodness" of the subtraction from the full event, which also
64  // includes pileup
65  double particle_maxrap = 5.0;
66 
67  string line;
68  int nsub = 0; // counter to keep track of which sub-event we're reading
69  while (getline(cin, line)) {
70  istringstream linestream(line);
71  // take substrings to avoid problems when there are extra "pollution"
72  // characters (e.g. line-feed).
73  if (line.substr(0,4) == "#END") {break;}
74  if (line.substr(0,9) == "#SUBSTART") {
75  // if more sub events follow, make copy of first one (the hard one) here
76  if (nsub == 1) hard_event = full_event;
77  nsub += 1;
78  }
79  if (line.substr(0,1) == "#") {continue;}
80  double px,py,pz,E;
81  linestream >> px >> py >> pz >> E;
82  // you can construct
83  PseudoJet particle(px,py,pz,E);
84 
85  // push event onto back of full_event vector
86  if (abs(particle.rap()) <= particle_maxrap) full_event.push_back(particle);
87  }
88 
89  // if we have read in only one event, copy it across here...
90  if (nsub == 1) hard_event = full_event;
91 
92  // if there was nothing in the event
93  if (nsub == 0) {
94  cerr << "Error: read empty event\n";
95  exit(-1);
96  }
97 
98 
99  // create a jet definition for the clustering
100  // We use the anti-kt algorithm with a radius of 0.5
101  //----------------------------------------------------------
102  double R = 0.5;
103  JetDefinition jet_def(antikt_algorithm, R);
104 
105  // create an area definition for the clustering
106  //----------------------------------------------------------
107  // ghosts should go up to the acceptance of the detector or
108  // (with infinite acceptance) at least 2R beyond the region
109  // where you plan to investigate jets.
110  double ghost_maxrap = 6.0;
111  GhostedAreaSpec area_spec(ghost_maxrap);
112  AreaDefinition area_def(active_area, area_spec);
113 
114  // run the jet clustering with the above jet and area definitions
115  // for both the hard and full event
116  //
117  // We retrieve the jets above 7 GeV in both case (note that the
118  // 7-GeV cut we be applied again later on after we subtract the jets
119  // from the full event)
120  // ----------------------------------------------------------
121  ClusterSequenceArea clust_seq_hard(hard_event, jet_def, area_def);
122  ClusterSequenceArea clust_seq_full(full_event, jet_def, area_def);
123 
124  double ptmin = 7.0;
125  vector<PseudoJet> hard_jets = sorted_by_pt(clust_seq_hard.inclusive_jets(ptmin));
126  vector<PseudoJet> full_jets = sorted_by_pt(clust_seq_full.inclusive_jets(ptmin));
127 
128  // Now turn to the estimation of the background (for the full event)
129  //
130  // There are different ways to do that. In general, this also
131  // requires clustering the particles that will be handled internally
132  // in FastJet.
133  //
134  // The suggested way to proceed is to use a BackgroundEstimator
135  // constructed from the following 3 arguments:
136  // - a jet definition used to cluster the particles.
137  // . We strongly recommend using the kt or Cambridge/Aachen
138  // algorithm (a warning will be issued otherwise)
139  // . The choice of the radius is a bit more subtle. R=0.4 has
140  // been chosen to limit the impact of hard jets; in samples of
141  // dominantly sparse events it may cause the UE/pileup to be
142  // underestimated a little, a slightly larger value (0.5 or
143  // 0.6) may be better.
144  // - An area definition for which we recommend the use of explicit
145  // ghosts (i.e. active_area_explicit_ghosts)
146  // As mentionned in the area example (06-area.cc), ghosts should
147  // extend sufficiently far in rapidity to cover the jets used in
148  // the computation of the background (see also the comment below)
149  // - A Selector specifying the range over which we will keep the
150  // jets entering the estimation of the background (you should
151  // thus make sure the ghosts extend far enough in rapidity to
152  // cover the range, a warning will be issued otherwise).
153  // In this particular example, the two hardest jets in the event
154  // are removed from the background estimation
155  // ----------------------------------------------------------
156  JetDefinition jet_def_bkgd(kt_algorithm, 0.4);
157  AreaDefinition area_def_bkgd(active_area_explicit_ghosts,
158  GhostedAreaSpec(ghost_maxrap));
159  Selector selector = SelectorAbsRapMax(4.5) * (!SelectorNHardest(2));
160  JetMedianBackgroundEstimator bkgd_estimator(selector, jet_def_bkgd, area_def_bkgd);
161 
162  // To help manipulate the background estimator, we also provide a
163  // transformer that allows to apply directly the background
164  // subtraction on the jets. This will use the background estimator
165  // to compute rho for the jets to be subtracted.
166  // ----------------------------------------------------------
167  Subtractor subtractor(&bkgd_estimator);
168 
169  // since FastJet 3.1.0, rho_m is supported natively in background
170  // estimation (both JetMedianBackgroundEstimator and
171  // GridMedianBackgroundEstimator).
172  //
173  // For backward-compatibility reasons its use is by default switched off
174  // (as is the enforcement of m>0 for the subtracted jets). The
175  // following 2 lines of code switch these on. They are strongly
176  // recommended and should become the default in future versions of
177  // FastJet.
178  //
179  // Note that we also illustrate the use of the
180  // FASTJET_VERSION_NUMBER macro
181 #if FASTJET_VERSION_NUMBER >= 30100
182  subtractor.set_use_rho_m(true);
183  subtractor.set_safe_mass(true);
184 #endif
185 
186  // Finally, once we have an event, we can just tell the background
187  // estimator to use that list of particles
188  // This could be done directly when declaring the background
189  // estimator but the usage below can more easily be accomodated to a
190  // loop over a set of events.
191  // ----------------------------------------------------------
192  bkgd_estimator.set_particles(full_event);
193 
194  // show a summary of what was done so far
195  // - the description of the algorithms, areas and ranges used
196  // - the background properties
197  // - the jets in the hard event
198  //----------------------------------------------------------
199  cout << "Main clustering:" << endl;
200  cout << " Ran: " << jet_def.description() << endl;
201  cout << " Area: " << area_def.description() << endl;
202  cout << " Particles up to |y|=" << particle_maxrap << endl;
203  cout << endl;
204 
205  cout << "Background estimation:" << endl;
206  cout << " " << bkgd_estimator.description() << endl << endl;;
207  cout << " Giving, for the full event" << endl;
208  cout << " rho = " << bkgd_estimator.rho() << endl;
209  cout << " sigma = " << bkgd_estimator.sigma() << endl;
210 #if FASTJET_VERSION_NUMBER >= 30100
211  cout << " rho_m = " << bkgd_estimator.rho_m() << endl;
212  cout << " sigma_m = " << bkgd_estimator.sigma_m() << endl;
213 #endif
214  cout << endl;
215 
216  cout << "Jets above " << ptmin << " GeV in the hard event (" << hard_event.size() << " particles)" << endl;
217  cout << "---------------------------------------\n";
218  printf("%5s %15s %15s %15s %15s %15s\n","jet #", "rapidity", "phi", "pt", "m", "area");
219  for (unsigned int i = 0; i < hard_jets.size(); i++) {
220  printf("%5u %15.8f %15.8f %15.8f %15.8f %15.8f\n", i,
221  hard_jets[i].rap(), hard_jets[i].phi(), hard_jets[i].pt(), hard_jets[i].m(),
222  hard_jets[i].area());
223  }
224  cout << endl;
225 
226  // Once the background properties have been computed, subtraction
227  // can be applied on the jets. Subtraction is performed on the
228  // full 4-vector
229  //
230  // We output the jets before and after subtraction
231  // ----------------------------------------------------------
232  cout << "Jets above " << ptmin << " GeV in the full event (" << full_event.size() << " particles)" << endl;
233  cout << "---------------------------------------\n";
234  printf("%5s %15s %15s %15s %15s %15s %15s %15s %15s %15s\n","jet #", "rapidity", "phi", "pt", "m", "area", "rap_sub", "phi_sub", "pt_sub", "m_sub");
235  unsigned int idx=0;
236 
237  // get the subtracted jets
238  vector<PseudoJet> subtracted_jets = subtractor(full_jets);
239 
240  for (unsigned int i=0; i<full_jets.size(); i++){
241  // re-apply the pt cut
242  if (subtracted_jets[i].pt2() >= ptmin*ptmin){
243  printf("%5u %15.8f %15.8f %15.8f %15.8f %15.8f %15.8f %15.8f %15.8f %15.8f\n", idx,
244  full_jets[i].rap(), full_jets[i].phi(), full_jets[i].pt(), full_jets[i].m(),
245  full_jets[i].area(),
246  subtracted_jets[i].rap(), subtracted_jets[i].phi(),
247  subtracted_jets[i].pt(),
248  subtracted_jets[i].m());
249  idx++;
250  }
251  }
252 
253  return 0;
254 }
fastjet::SelectorAbsRapMax
Selector SelectorAbsRapMax(double absrapmax)
select objects with |rap| <= absrapmax
Definition: Selector.cc:880
fastjet
Definition: AreaDefinition.cc:37
fastjet::SelectorNHardest
Selector SelectorNHardest(unsigned int n)
select the n hardest objects
Definition: Selector.cc:1074
fastjet::JetDefinition
Definition: JetDefinition.hh:250
fastjet::JetMedianBackgroundEstimator
Definition: JetMedianBackgroundEstimator.hh:80
fastjet::AreaDefinition
Definition: AreaDefinition.hh:82
fastjet::ClusterSequenceArea
Definition: ClusterSequenceArea.hh:51
main
int main()
an example program showing how to use fastjet
Definition: 01-basic.cc:50
fastjet::GhostedAreaSpec
Definition: GhostedAreaSpec.hh:65
fastjet::PseudoJet
Definition: PseudoJet.hh:67
fastjet::Selector
Definition: Selector.hh:149
fastjet::Subtractor
Definition: Subtractor.hh:62
fastjet::sorted_by_pt
vector< PseudoJet > sorted_by_pt(const vector< PseudoJet > &jets)
return a vector of jets sorted into decreasing kt2
Definition: PseudoJet.cc:774