|
| 1 | +#include <iostream> |
| 2 | +#include <chrono> |
| 3 | + |
| 4 | +#include "TFile.h" |
| 5 | +#include "TTree.h" |
| 6 | + |
| 7 | +#include "fastjet/PseudoJet.hh" |
| 8 | +#include "fastjet/ClusterSequenceArea.hh" |
| 9 | + |
| 10 | +#include "include/ProgressBar.h" |
| 11 | + |
| 12 | +#include "PU14/EventMixer.hh" |
| 13 | +#include "PU14/CmdLine.hh" |
| 14 | +#include "PU14/PU14.hh" |
| 15 | + |
| 16 | +#include "include/jetCollection.hh" |
| 17 | +#include "include/csSubtractor.hh" |
| 18 | +#include "include/csSubtractorFullEvent.hh" |
| 19 | +#include "include/skSubtractor.hh" |
| 20 | +#include "include/softDropGroomer.hh" |
| 21 | +#include "include/treeWriter.hh" |
| 22 | +#include "include/jetMatcher.hh" |
| 23 | +#include "include/randomCones.hh" |
| 24 | +#include "include/Angularity.hh" |
| 25 | + |
| 26 | +using namespace std; |
| 27 | +using namespace fastjet; |
| 28 | + |
| 29 | +// ./runCSVariations -hard /eos/project/j/jetquenching/JetWorkshop2017/samples/pythia8/dijet120/PythiaEventsTune14PtHat120_0.pu14 -pileup /eos/project/j/jetquenching/JetWorkshop2017/samples/thermal/Mult7000/ThermalEventsMult7000PtAv1.20_0.pu14 -nev 10 |
| 30 | + |
| 31 | +int main (int argc, char ** argv) { |
| 32 | + |
| 33 | + auto start_time = std::chrono::steady_clock::now(); |
| 34 | + |
| 35 | + CmdLine cmdline(argc,argv); |
| 36 | + // inputs read from command line |
| 37 | + int nEvent = cmdline.value<int>("-nev",1); // first argument: command line option; second argument: default value |
| 38 | + //bool verbose = cmdline.present("-verbose"); |
| 39 | + |
| 40 | + std::cout << "will run on " << nEvent << " events" << std::endl; |
| 41 | + |
| 42 | + // Uncomment to silence fastjet banner |
| 43 | + ClusterSequence::set_fastjet_banner_stream(NULL); |
| 44 | + |
| 45 | + //to write info to root tree |
| 46 | + treeWriter trw("jetTree"); |
| 47 | + |
| 48 | + //Jet definition |
| 49 | + double R = 0.4; |
| 50 | + double ghostRapMax = 6.0; |
| 51 | + double ghost_area = 0.005; |
| 52 | + int active_area_repeats = 1; |
| 53 | + fastjet::GhostedAreaSpec ghost_spec(ghostRapMax, active_area_repeats, ghost_area); |
| 54 | + fastjet::AreaDefinition area_def = fastjet::AreaDefinition(fastjet::active_area,ghost_spec); |
| 55 | + fastjet::JetDefinition jet_def(antikt_algorithm, R); |
| 56 | + |
| 57 | + double jetRapMax = 3.0; |
| 58 | + fastjet::Selector jet_selector = SelectorAbsRapMax(jetRapMax); |
| 59 | + |
| 60 | + Angularity width(1.,1.,R); |
| 61 | + Angularity pTD(0.,2.,R); |
| 62 | + |
| 63 | + ProgressBar Bar(cout, nEvent); |
| 64 | + Bar.SetStyle(-1); |
| 65 | + |
| 66 | + EventMixer mixer(&cmdline); //the mixing machinery from PU14 workshop |
| 67 | + |
| 68 | + // loop over events |
| 69 | + int iev = 0; |
| 70 | + unsigned int entryDiv = (nEvent > 200) ? nEvent / 200 : 1; |
| 71 | + while ( mixer.next_event() && iev < nEvent ) |
| 72 | + { |
| 73 | + // increment event number |
| 74 | + iev++; |
| 75 | + |
| 76 | + Bar.Update(iev); |
| 77 | + Bar.PrintWithMod(entryDiv); |
| 78 | + |
| 79 | + std::vector<fastjet::PseudoJet> particlesMerged = mixer.particles(); |
| 80 | + |
| 81 | + std::vector<double> eventWeight; |
| 82 | + eventWeight.push_back(mixer.hard_weight()); |
| 83 | + eventWeight.push_back(mixer.pu_weight()); |
| 84 | + |
| 85 | + // cluster hard event only |
| 86 | + std::vector<fastjet::PseudoJet> particlesBkg, particlesSig; |
| 87 | + SelectorIsHard().sift(particlesMerged, particlesSig, particlesBkg); // this sifts the full event into two vectors of PseudoJet, one for the hard event, one for the underlying event |
| 88 | + |
| 89 | + //--------------------------------------------------------------------------- |
| 90 | + // jet clustering |
| 91 | + //--------------------------------------------------------------------------- |
| 92 | + |
| 93 | + // run the clustering, extract the signal jets |
| 94 | + fastjet::ClusterSequenceArea csSig(particlesSig, jet_def, area_def); |
| 95 | + jetCollection jetCollectionSig(sorted_by_pt(jet_selector(csSig.inclusive_jets(10.)))); |
| 96 | + |
| 97 | + //--------------------------------------------------------------------------- |
| 98 | + // background subtraction |
| 99 | + //--------------------------------------------------------------------------- |
| 100 | + |
| 101 | + //run jet-by-jet constituent subtraction on mixed (hard+UE) event |
| 102 | + const int ncs = 5; |
| 103 | + double alpha[ncs] = {-2.,-1.,0.,1.,2.}; |
| 104 | + std::vector<jetCollection> jetCollectionCSs; |
| 105 | + std::vector<double> rho; |
| 106 | + std::vector<double> rhom; |
| 107 | + for(int ics = 0; ics<ncs; ++ics) { |
| 108 | + csSubtractor csSub(R, alpha[ics], -1, 0.005,ghostRapMax,jetRapMax); |
| 109 | + csSub.setInputParticles(particlesMerged); |
| 110 | + jetCollection jetCollectionCS(csSub.doSubtraction()); |
| 111 | + |
| 112 | + if(ics==3) { |
| 113 | + //Background densities used by constituent subtraction |
| 114 | + rho.push_back(csSub.getRho()); |
| 115 | + rhom.push_back(csSub.getRhoM()); |
| 116 | + } |
| 117 | + jetCollectionCSs.push_back(jetCollectionCS); |
| 118 | + } |
| 119 | + |
| 120 | + |
| 121 | + //--------------------------------------------------------------------------- |
| 122 | + // Groom the jets |
| 123 | + //--------------------------------------------------------------------------- |
| 124 | + |
| 125 | + |
| 126 | + //SoftDrop grooming classic for signal jets (zcut=0.1, beta=0) |
| 127 | + softDropGroomer sdgSig(0.1, 0.0, R); |
| 128 | + jetCollection jetCollectionSigSD(sdgSig.doGrooming(jetCollectionSig)); |
| 129 | + jetCollectionSigSD.addVector("zgSigSD", sdgSig.getZgs()); |
| 130 | + jetCollectionSigSD.addVector("ndropSigSD", sdgSig.getNDroppedBranches()); |
| 131 | + jetCollectionSigSD.addVector("dr12SigSD", sdgSig.getDR12()); |
| 132 | + |
| 133 | + //SoftDrop grooming classic for CS jets (zcut=0.1, beta=0) |
| 134 | + std::vector<jetCollection> jetCollectionCSSDs; |
| 135 | + |
| 136 | + for(int ics = 0; ics<ncs; ++ics) { |
| 137 | + softDropGroomer sdgCS(0.1, 0.0, R); |
| 138 | + jetCollection jetCollectionCSSD(sdgCS.doGrooming(jetCollectionCSs[ics])); |
| 139 | + jetCollectionCSSD.addVector(Form("csJetSD_%dzg",ics), sdgCS.getZgs()); |
| 140 | + jetCollectionCSSD.addVector(Form("csJetSD_%dndrop",ics), sdgCS.getNDroppedBranches()); |
| 141 | + jetCollectionCSSD.addVector(Form("csJetSD_%ddr12",ics), sdgCS.getDR12()); |
| 142 | + |
| 143 | + jetCollectionCSSDs.push_back(jetCollectionCSSD); |
| 144 | + //std::cout << "n CS jets: " << jetCollectionCSs[ics].getJet().size() << |
| 145 | + // " n CSSD jets: " << jetCollectionCSSDs[ics].getJet().size() << std::endl; |
| 146 | + } |
| 147 | + |
| 148 | + |
| 149 | + //match the CS jets to signal jets |
| 150 | + for(int ics = 0; ics<ncs; ++ics) { |
| 151 | + jetMatcher jmCS(R); |
| 152 | + jmCS.setBaseJets(jetCollectionCSs[ics]); |
| 153 | + jmCS.setTagJets(jetCollectionSig); |
| 154 | + jmCS.matchJets(); |
| 155 | + |
| 156 | + jmCS.reorderedToTag(jetCollectionCSs[ics]); |
| 157 | + jmCS.reorderedToTag(jetCollectionCSSDs[ics]); |
| 158 | + } |
| 159 | + |
| 160 | + //--------------------------------------------------------------------------- |
| 161 | + // write tree |
| 162 | + //--------------------------------------------------------------------------- |
| 163 | + |
| 164 | + //Give variable we want to write out to treeWriter. |
| 165 | + //Only vectors of the types 'jetCollection', and 'double', 'int', 'fastjet::PseudoJet' are supported |
| 166 | + |
| 167 | + trw.addCollection("sigJet", jetCollectionSig); |
| 168 | + trw.addCollection("sigJetSD", jetCollectionSigSD); |
| 169 | + |
| 170 | + for(int ics = 0; ics<ncs; ++ics) { |
| 171 | + trw.addCollection(Form("csJet_%d",ics), jetCollectionCSs[ics]); |
| 172 | + trw.addCollection(Form("csJetSD_%d",ics), jetCollectionCSSDs[ics]); |
| 173 | + } |
| 174 | + trw.addCollection("csRho", rho); |
| 175 | + trw.addCollection("csRhom", rhom); |
| 176 | + |
| 177 | + trw.addCollection("eventWeight", eventWeight); |
| 178 | + |
| 179 | + trw.fillTree(); |
| 180 | + |
| 181 | + }//event loop |
| 182 | + |
| 183 | + Bar.Update(nEvent); |
| 184 | + Bar.Print(); |
| 185 | + Bar.PrintLine(); |
| 186 | + |
| 187 | + TTree *trOut = trw.getTree(); |
| 188 | + |
| 189 | + TFile *fout = new TFile("JetToyHIResultCSVariations.root","RECREATE"); |
| 190 | + trOut->Write(); |
| 191 | + fout->Write(); |
| 192 | + fout->Close(); |
| 193 | + |
| 194 | + double time_in_seconds = std::chrono::duration_cast<std::chrono::milliseconds> |
| 195 | + (std::chrono::steady_clock::now() - start_time).count() / 1000.0; |
| 196 | + std::cout << "runFromFile: " << time_in_seconds << std::endl; |
| 197 | +} |
0 commit comments