From ba1d0fd593da58e39630e25ad5861360c5af1da2 Mon Sep 17 00:00:00 2001
From: Whitney Armstrong <warmstrong@anl.gov>
Date: Sat, 7 Aug 2021 00:15:52 -0500
Subject: [PATCH] 	modified:   scripts/emcal_barrel_pi0_analysis.cxx

---
 .../scripts/emcal_barrel_pi0_analysis.cxx     | 211 +++++++++---------
 1 file changed, 108 insertions(+), 103 deletions(-)

diff --git a/benchmarks/barrel_ecal/scripts/emcal_barrel_pi0_analysis.cxx b/benchmarks/barrel_ecal/scripts/emcal_barrel_pi0_analysis.cxx
index c56b5c66..f56d9d78 100644
--- a/benchmarks/barrel_ecal/scripts/emcal_barrel_pi0_analysis.cxx
+++ b/benchmarks/barrel_ecal/scripts/emcal_barrel_pi0_analysis.cxx
@@ -117,121 +117,126 @@ void emcal_barrel_pi0_analysis(const char* input_fname = "sim_output/sim_emcal_b
   auto hpid   = d1.Histo1D({"hpid",   "PID; PID; Count",                                   100,  -220,   220}, "pid");
   auto hdau   = d1.Histo1D({"hdau",   "Number of Daughters; Number of Daughters; Count",   10,   0,      10},  "dau");
 
+  // put this line above GetMean below so it can be lazily evaluated with the histgorams.
+  auto nevents_thrown = d1.Count();
+
   const double meanE     = hEthr->GetMean(); 
 
   // Event Counts
-  auto nevents_thrown = d1.Count();
   std::cout << "Number of Thrown Events: " << (*nevents_thrown) << "\n";
 
   // Draw Histograms
   TCanvas *c1 = new TCanvas("c1", "c1", 700, 500);
   c1->SetLogy(1);
+  fmt::print("0\n");
   auto h1 = hEthr->DrawCopy();
-  h1->GetYaxis()->SetTitleOffset(1.4);
+  //h1->GetYaxis()->SetTitleOffset(1.4);
   h1->SetLineWidth(2);
   h1->SetLineColor(kBlue);
   c1->SaveAs("results/emcal_barrel_pi0_Ethr.png");
   c1->SaveAs("results/emcal_barrel_pi0_Ethr.pdf");
 
-  TCanvas *c2 = new TCanvas("c2", "c2", 700, 500);
-  c2->SetLogy(1);
-  h1 = hNhits->DrawCopy();
-  h1->GetYaxis()->SetTitleOffset(1.4);
-  h1->SetLineWidth(2);
-  h1->SetLineColor(kBlue);
-  c2->SaveAs("results/emcal_barrel_pi0_nhits.png");
-  c2->SaveAs("results/emcal_barrel_pi0_nhits.pdf");
-
-  TCanvas *c3 = new TCanvas("c3", "c3", 700, 500);
-  c3->SetLogy(1);
-  h1 = hEsim->DrawCopy();
-  h1->GetYaxis()->SetTitleOffset(1.4);
-  h1->SetLineWidth(2);
-  h1->SetLineColor(kBlue);
-  c3->SaveAs("results/emcal_barrel_pi0_Esim.png"); 
-  c3->SaveAs("results/emcal_barrel_pi0_Esim.pdf");
-
-  TCanvas *c4 = new TCanvas("c4", "c4", 700, 500);
-  c4->SetLogy(1);
-  h1 = hfsam->DrawCopy();
-  h1->GetYaxis()->SetTitleOffset(1.4);
-  h1->SetLineWidth(2);
-  h1->SetLineColor(kBlue);
-  h1->Fit("gaus","","",0.005,0.1);
-  h1->GetFunction("gaus")->SetLineWidth(2);
-  h1->GetFunction("gaus")->SetLineColor(kRed);
-  c4->SaveAs("results/emcal_barrel_pi0_fsam.png");
-  c4->SaveAs("results/emcal_barrel_pi0_fsam.pdf");
-
-  TCanvas *c5 = new TCanvas("c5", "c5", 700, 500);
-  c5->SetLogy(1);
-  h1 = hpid->DrawCopy();
-  h1->GetYaxis()->SetTitleOffset(1.4);
-  h1->SetLineWidth(2);
-  h1->SetLineColor(kBlue);
-  c5->SaveAs("results/emcal_barrel_pi0_pid.png");
-  c5->SaveAs("results/emcal_barrel_pi0_pid.pdf");
-
-  TCanvas *c6 = new TCanvas("c6", "c6", 700, 500);
-  c5->SetLogy(1);
-  h1 = hdau->DrawCopy();
-  h1->GetYaxis()->SetTitleOffset(1.4);
-  h1->SetLineWidth(2);
-  h1->SetLineColor(kBlue);
-  c6->SaveAs("results/emcal_barrel_pi0_dau.png");
-  c6->SaveAs("results/emcal_barrel_pi0_dau.pdf");
-
-  // Energy Resolution Calculation
-  std::string test_tag = "Barrel_emcal_pi0";// TODO: Change test_tag to something else
-  std:string detEle    = "Barrel_emcal";
-
-  // Energy resolution in the barrel region (-1 < eta < 1)
-  // Taken from : Initial considerations for EMCal of the EIC detector by A. Bazilevsky
-  // sigma_E / E = 12% / E^0.5 convoluted with 2%
-  // sigma_E / E = [ (0.12/E^0.5)^2 + 0.02^2]^0.5, with E in [GeV]
-  
-  double resolutionTarget = TMath::Sqrt(0.12 * 0.12 / meanE + 0.02 * 0.02);
-
-  common_bench::Test pi0_energy_resolution{
-   {{"name", fmt::format("{}_energy_resolution", test_tag)},
-   {"title", "Pi0 Energy resolution"},
-   {"description",
-    fmt::format("Pi0 energy resolution for {}, estimated using a Gaussian fit.", detEle)},
-   {"quantity", "resolution (in %)"},
-   {"target", std::to_string(resolutionTarget)}}
-  };
-
-  // Histograms and Fitting
-  auto hdE          = d1.Histo1D({"hdE",      "dE; dE[GeV]; Events",              100, -3.0, 3.0}, "dE");
-  auto hdE_rel      = d1.Histo1D({"hdE_rel",  "dE Relative; dE Relative; Events", 100, -3.0, 3.0}, "dE_rel");
-  auto hdEcopy      = hdE->DrawCopy();
-  hdEcopy->Fit("gaus", "", "", -3.0,  3.0);
-  double* res       = hdEcopy->GetFunction("gaus")->GetParameters();
-  double sigmaOverE = res[2] / meanE;
-
-  // Pass/Fail
-  sigmaOverE <= resolutionTarget ? pi0_energy_resolution.pass(sigmaOverE) : pi0_energy_resolution.fail(sigmaOverE);
-  std::printf("Energy Resolution is %f\n", res[2]);
-
-  // Energy Resolution Histogram Plotting
-  auto *cdE = new TCanvas("cdE", "cdE", 700, 500);
-  cdE->SetLogy(1);
-  h1 = hdEcopy->DrawCopy();
-  hdEcopy->GetYaxis()->SetTitleOffset(1.4);
-  hdEcopy->SetLineWidth(2);
-  hdEcopy->SetLineColor(kBlue);
-  hdEcopy->GetFunction("gaus")->SetLineWidth(2);
-  hdEcopy->GetFunction("gaus")->SetLineColor(kRed);
-  cdE->SaveAs("results/emcal_barrel_pi0_dE.png");
-  cdE->SaveAs("results/emcal_barrel_pi0_dE.pdf");
-
-  auto *cdE_rel = new TCanvas("cdE_rel", "cdE_rel", 700, 500);
-  h1 = hdE_rel->DrawCopy();
-  hdE_rel->GetYaxis()->SetTitleOffset(1.4);
-  hdE_rel->SetLineWidth(2);
-  hdE_rel->SetLineColor(kBlue);
-  cdE_rel->SaveAs("results/emcal_barrel_pi0_dE_rel.png");
-  cdE_rel->SaveAs("results/emcal_barrel_pi0_dE_rel.pdf");
-
-  common_bench::write_test({pi0_energy_resolution}, fmt::format("results/{}_pi0.json", detEle));
+  fmt::print("1\n");
+
+  //TCanvas *c2 = new TCanvas("c2", "c2", 700, 500);
+  //c2->SetLogy(1);
+  //h1 = hNhits->DrawCopy();
+  //h1->GetYaxis()->SetTitleOffset(1.4);
+  //h1->SetLineWidth(2);
+  //h1->SetLineColor(kBlue);
+  //c2->SaveAs("results/emcal_barrel_pi0_nhits.png");
+  //c2->SaveAs("results/emcal_barrel_pi0_nhits.pdf");
+
+  //TCanvas *c3 = new TCanvas("c3", "c3", 700, 500);
+  //c3->SetLogy(1);
+  //h1 = hEsim->DrawCopy();
+  //h1->GetYaxis()->SetTitleOffset(1.4);
+  //h1->SetLineWidth(2);
+  //h1->SetLineColor(kBlue);
+  //c3->SaveAs("results/emcal_barrel_pi0_Esim.png"); 
+  //c3->SaveAs("results/emcal_barrel_pi0_Esim.pdf");
+
+  //TCanvas *c4 = new TCanvas("c4", "c4", 700, 500);
+  //c4->SetLogy(1);
+  //h1 = hfsam->DrawCopy();
+  //h1->GetYaxis()->SetTitleOffset(1.4);
+  //h1->SetLineWidth(2);
+  //h1->SetLineColor(kBlue);
+  //h1->Fit("gaus","","",0.005,0.1);
+  //h1->GetFunction("gaus")->SetLineWidth(2);
+  //h1->GetFunction("gaus")->SetLineColor(kRed);
+  //c4->SaveAs("results/emcal_barrel_pi0_fsam.png");
+  //c4->SaveAs("results/emcal_barrel_pi0_fsam.pdf");
+
+  //TCanvas *c5 = new TCanvas("c5", "c5", 700, 500);
+  //c5->SetLogy(1);
+  //h1 = hpid->DrawCopy();
+  //h1->GetYaxis()->SetTitleOffset(1.4);
+  //h1->SetLineWidth(2);
+  //h1->SetLineColor(kBlue);
+  //c5->SaveAs("results/emcal_barrel_pi0_pid.png");
+  //c5->SaveAs("results/emcal_barrel_pi0_pid.pdf");
+
+  //TCanvas *c6 = new TCanvas("c6", "c6", 700, 500);
+  //c5->SetLogy(1);
+  //h1 = hdau->DrawCopy();
+  //h1->GetYaxis()->SetTitleOffset(1.4);
+  //h1->SetLineWidth(2);
+  //h1->SetLineColor(kBlue);
+  //c6->SaveAs("results/emcal_barrel_pi0_dau.png");
+  //c6->SaveAs("results/emcal_barrel_pi0_dau.pdf");
+
+  //// Energy Resolution Calculation
+  //std::string test_tag = "Barrel_emcal_pi0";// TODO: Change test_tag to something else
+  //std:string detEle    = "Barrel_emcal";
+
+  //// Energy resolution in the barrel region (-1 < eta < 1)
+  //// Taken from : Initial considerations for EMCal of the EIC detector by A. Bazilevsky
+  //// sigma_E / E = 12% / E^0.5 convoluted with 2%
+  //// sigma_E / E = [ (0.12/E^0.5)^2 + 0.02^2]^0.5, with E in [GeV]
+  //
+  //double resolutionTarget = TMath::Sqrt(0.12 * 0.12 / meanE + 0.02 * 0.02);
+
+  //common_bench::Test pi0_energy_resolution{
+  // {{"name", fmt::format("{}_energy_resolution", test_tag)},
+  // {"title", "Pi0 Energy resolution"},
+  // {"description",
+  //  fmt::format("Pi0 energy resolution for {}, estimated using a Gaussian fit.", detEle)},
+  // {"quantity", "resolution (in %)"},
+  // {"target", std::to_string(resolutionTarget)}}
+  //};
+
+  //// Histograms and Fitting
+  //auto hdE          = d1.Histo1D({"hdE",      "dE; dE[GeV]; Events",              100, -3.0, 3.0}, "dE");
+  //auto hdE_rel      = d1.Histo1D({"hdE_rel",  "dE Relative; dE Relative; Events", 100, -3.0, 3.0}, "dE_rel");
+  //auto hdEcopy      = hdE->DrawCopy();
+  //hdEcopy->Fit("gaus", "", "", -3.0,  3.0);
+  //double* res       = hdEcopy->GetFunction("gaus")->GetParameters();
+  //double sigmaOverE = res[2] / meanE;
+
+  //// Pass/Fail
+  //sigmaOverE <= resolutionTarget ? pi0_energy_resolution.pass(sigmaOverE) : pi0_energy_resolution.fail(sigmaOverE);
+  //std::printf("Energy Resolution is %f\n", res[2]);
+
+  //// Energy Resolution Histogram Plotting
+  //auto *cdE = new TCanvas("cdE", "cdE", 700, 500);
+  //cdE->SetLogy(1);
+  //h1 = hdEcopy->DrawCopy();
+  //hdEcopy->GetYaxis()->SetTitleOffset(1.4);
+  //hdEcopy->SetLineWidth(2);
+  //hdEcopy->SetLineColor(kBlue);
+  //hdEcopy->GetFunction("gaus")->SetLineWidth(2);
+  //hdEcopy->GetFunction("gaus")->SetLineColor(kRed);
+  //cdE->SaveAs("results/emcal_barrel_pi0_dE.png");
+  //cdE->SaveAs("results/emcal_barrel_pi0_dE.pdf");
+
+  //auto *cdE_rel = new TCanvas("cdE_rel", "cdE_rel", 700, 500);
+  //h1 = hdE_rel->DrawCopy();
+  //hdE_rel->GetYaxis()->SetTitleOffset(1.4);
+  //hdE_rel->SetLineWidth(2);
+  //hdE_rel->SetLineColor(kBlue);
+  //cdE_rel->SaveAs("results/emcal_barrel_pi0_dE_rel.png");
+  //cdE_rel->SaveAs("results/emcal_barrel_pi0_dE_rel.pdf");
+
+  //common_bench::write_test({pi0_energy_resolution}, fmt::format("results/{}_pi0.json", detEle));
 }
-- 
GitLab