// Example showing basic usage of energy correlator classes.
//
// Compile it with "make example" and run it with
//
// ./example_basic_usage < ../data/single-event.dat
//
// Copyright (c) 2013-2016
// Andrew Larkoski, Lina Necib, Gavin Salam, and Jesse Thaler
//
// $Id: example.cc 958 2016-08-17 00:25:14Z linoush $
//----------------------------------------------------------------------
// This file is part of FastJet contrib.
//
// It is free software; you can redistribute it and/or modify it under
// the terms of the GNU General Public License as published by the
// Free Software Foundation; either version 2 of the License, or (at
// your option) any later version.
//
// It is distributed in the hope that it will be useful, but WITHOUT
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
// or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
// License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this code. If not, see .
//----------------------------------------------------------------------
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include "fastjet/PseudoJet.hh"
#include "fastjet/ClusterSequence.hh"
#include "fastjet/JetDefinition.hh"
#include
#include "EnergyCorrelator.hh" // In external code, this should be fastjet/contrib/EnergyCorrelator.hh
using namespace std;
using namespace fastjet;
using namespace fastjet::contrib;
// forward declaration to make things clearer
void read_event(vector &event);
void analyze(const vector & input_particles);
//----------------------------------------------------------------------
int main(){
//----------------------------------------------------------
// read in input particles
vector event;
read_event(event);
cout << "# read an event with " << event.size() << " particles" << endl;
//----------------------------------------------------------
// illustrate how this EnergyCorrelator contrib works
analyze(event);
return 0;
}
// read in input particles
void read_event(vector &event){
string line;
while (getline(cin, line)) {
istringstream linestream(line);
// take substrings to avoid problems when there are extra "pollution"
// characters (e.g. line-feed).
if (line.substr(0,4) == "#END") {return;}
if (line.substr(0,1) == "#") {continue;}
double px,py,pz,E;
linestream >> px >> py >> pz >> E;
PseudoJet particle(px,py,pz,E);
// push event onto back of full_event vector
event.push_back(particle);
}
}
////////
//
// Main Routine for Analysis
//
///////
void analyze(const vector & input_particles) {
/////// EnergyCorrelator /////////////////////////////
// Initial clustering with anti-kt algorithm
JetAlgorithm algorithm = antikt_algorithm;
double jet_rad = 1.00; // jet radius for anti-kt algorithm
JetDefinition jetDef = JetDefinition(algorithm,jet_rad,E_scheme,Best);
ClusterSequence clust_seq(input_particles,jetDef);
vector antikt_jets = sorted_by_pt(clust_seq.inclusive_jets());
for (int j = 0; j < 1; j++) { // Hardest jet per event
if (antikt_jets[j].perp() > 200) {
PseudoJet myJet = antikt_jets[j];
// The angularity is set by the value of beta
double beta;
cout << "-------------------------------------------------------------------------------------" << endl;
cout << "EnergyCorrelator: C series " << endl;
cout << "-------------------------------------------------------------------------------------" << endl;
printf("%7s %14s %14s %14s\n","beta", "C1", "C2", "C3");
beta = 1.0;
//Defining the Cseries for beta= 1.0
EnergyCorrelatorC1 C1s(beta);
EnergyCorrelatorC2 C2s(beta);
EnergyCorrelatorCseries C3s(3, beta);
printf("%7.3f %14.6f %14.6f %14.6f\n",beta,C1s(myJet),C2s(myJet),C3s(myJet));
beta = 2.0;
//Defining the Cseries for beta= 2.0
EnergyCorrelatorC1 C1s_2(beta);
EnergyCorrelatorC2 C2s_2(beta);
EnergyCorrelatorCseries C3s_2(3, beta);
printf("%7.3f %14.6f %14.6f %14.6f\n",beta,C1s_2(myJet),C2s_2(myJet),C3s_2(myJet));
cout << "-------------------------------------------------------------------------------------" << endl;
cout << "EnergyCorrelator: D2, orignal (alpha=beta) and generalized " << endl;
cout << "-------------------------------------------------------------------------------------" << endl;
printf("%7s %14s %14s %14s\n","beta","D2", "D2(alpha=1)", "D2(alpha=2)");
beta = 1.0;
EnergyCorrelatorD2 d2(beta);
double alpha = 1.0;
EnergyCorrelatorGeneralizedD2 d2_generalized(alpha, beta);
alpha = 2.0;
EnergyCorrelatorGeneralizedD2 d2_generalized_2(alpha, beta);
printf("%7.3f %14.6f %14.6f %14.6f\n",beta,d2(myJet), d2_generalized(myJet), d2_generalized_2(myJet));
beta = 2.0;
EnergyCorrelatorD2 d2_2(beta);
alpha = 1.0;
EnergyCorrelatorGeneralizedD2 d2_generalized_3(alpha, beta);
alpha = 2.0;
EnergyCorrelatorGeneralizedD2 d2_generalized_4(alpha, beta);
printf("%7.3f %14.6f %14.6f %14.6f\n",beta,d2_2(myJet), d2_generalized_3(myJet), d2_generalized_4(myJet));
cout << "-------------------------------------------------------------------------------------" << endl;
cout << "EnergyCorrelator: N series " << endl;
cout << "-------------------------------------------------------------------------------------" << endl;
printf("%7s %14s %14s\n","beta", "N2", "N3");
beta = 1.0;
// Directly defining the EnergyCorrelator N2 and N3
EnergyCorrelatorN2 N2(beta);
EnergyCorrelatorN3 N3(beta);
printf("%7.3f %14.6f %14.6f\n",beta, N2(myJet), N3(myJet));
beta = 2.0;
EnergyCorrelatorN2 N2_2(beta);
EnergyCorrelatorN3 N3_2(beta);
printf("%7.3f %14.6f %14.6f\n",beta, N2_2(myJet), N3_2(myJet));
cout << "-------------------------------------------------------------------------------------" << endl;
cout << "EnergyCorrelator: M series " << endl;
cout << "-------------------------------------------------------------------------------------" << endl;
printf("%7s %14s %14s\n","beta", "M2", "M3");
beta = 1.0;
//Directly defining M2
EnergyCorrelatorM2 M2(beta);
EnergyCorrelatorMseries M3(3, beta);
printf("%7.3f %14.6f %14.6f\n", beta, M2(myJet), M3(myJet));
beta = 2.0;
EnergyCorrelatorM2 M2_2(beta);
EnergyCorrelatorMseries M3_2(3, beta);
printf("%7.3f %14.6f %14.6f\n", beta, M2_2(myJet), M3_2(myJet));
cout << "-------------------------------------------------------------------------------------" << endl;
cout << "EnergyCorrelator: U series " << endl;
cout << "-------------------------------------------------------------------------------------" << endl;
printf("%7s %14s %14s %14s\n","beta", "U1", "U2", "U3");
beta = 0.5;
//Defining the Useries for beta= 0.5
EnergyCorrelatorU1 U1s(beta);
EnergyCorrelatorU2 U2s(beta);
EnergyCorrelatorU3 U3s(beta);
printf("%7.3f %14.8f %14.8f %14.8f\n",beta,U1s(myJet),U2s(myJet),U3s(myJet));
beta = 1.0;
//Defining the Useries for beta= 1.0
EnergyCorrelatorU1 U1s_2(beta);
EnergyCorrelatorU2 U2s_2(beta);
EnergyCorrelatorU3 U3s_2(beta);
printf("%7.3f %14.8f %14.8f %14.8f\n",beta,U1s_2(myJet),U2s_2(myJet),U3s_2(myJet));
beta = 2.0;
//Defining the Useries for beta= 2.0
EnergyCorrelatorU1 U1s_3(beta);
EnergyCorrelatorU2 U2s_3(beta);
EnergyCorrelatorU3 U3s_3(beta);
printf("%7.3f %14.8f %14.8f %14.8f\n",beta,U1s_3(myJet),U2s_3(myJet),U3s_3(myJet));
}
}
}