diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index a2502a9efcb27b5705d011796db01f5b6b0667ce..2e23d0c41b3eed0c8f7aa4013550ed5026be9f69 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,4 +1,5 @@ -image: eicweb.phy.anl.gov:4567/eic/npdet/npdet:latest +image: eicweb.phy.anl.gov:4567/eic/npdet/npdet:latest +p default: artifacts: @@ -107,7 +108,7 @@ track_test_1_dummy_test: - bash trackers/dummy_test.sh allow_failure: true -roman_pot_benchmark: +roman_pot_nhits: stage: benchmarks tags: - sodium @@ -115,6 +116,14 @@ roman_pot_benchmark: - root -b -q trackers/simple_tracking.cxx+ allow_failure: true +roman_pot_eta: + stage: benchmarks + tags: + - sodium + script: + - root -b -q trackers/roman_pot_hit_eta.cxx+ + allow_failure: true + zdc_benchmark: stage: benchmarks tags: diff --git a/trackers/roman_pot_hit_eta.cxx b/trackers/roman_pot_hit_eta.cxx new file mode 100644 index 0000000000000000000000000000000000000000..ebe3b06c65f339789ecc6ae7c9151122e6a029fd --- /dev/null +++ b/trackers/roman_pot_hit_eta.cxx @@ -0,0 +1,62 @@ +//R__LOAD_LIBRARY(libfmt.so) +//#include "fmt/core.h" +R__LOAD_LIBRARY(libDDG4IO.so) +// +//#include "DD4hep/Detector.h" +#include "DDG4/Geant4Data.h" +//#include "DDRec/CellIDPositionConverter.h" +//#include "DDRec/SurfaceManager.h" +//#include "DDRec/Surface.h" +#include "ROOT/RDataFrame.hxx" +// +//#include "lcio2/MCParticleData.h" +//#include "lcio2/ReconstructedParticleData.h" + +//#include "Math/Vector3D.h" +//#include "Math/Vector4D.h" +//#include "Math/VectorUtil.h" +#include "TCanvas.h" +//#include "TLegend.h" +//#include "TMath.h" +//#include "TRandom3.h" +//#include "TFile.h" +//#include "TH1F.h" +//#include "TH1D.h" +//#include "TTree.h" +#include "TChain.h" +//#include "TF1.h" +#include <random> +//#include "lcio2/TrackerRawDataData.h" +//#include "lcio2/TrackerRawData.h" + +void roman_pot_hit_eta(const char* fname = "./sim_output/roman_pot_out.root"){ + + ROOT::EnableImplicitMT(); // Tell ROOT you want to go parallel + double degree = TMath::Pi()/180.0; + + TChain* t = new TChain("EVENT"); + t->Add(fname); + + ROOT::RDataFrame d0(*t); + auto hits_eta = [&](const std::vector<dd4hep::sim::Geant4Tracker::Hit*>& hits){ + std::vector<double> result; + for (const auto& h: hits){ + result.push_back(h->momentum.eta()); + } + return result; + }; + + auto d1 = d0.Define("hits_eta", hits_eta, {"ForwardRomanPotHits"}); + + auto h1 = d1.Histo1D(TH1D("h1", "hits_eta", 300, 0,20), "hits_eta"); + auto n1 = h1->GetMean(); + std::cout << "Pseudorapidity of hits: " << n1 << std::endl; + TCanvas* c = new TCanvas(); + h1->DrawClone(); + + if (n1 < 5) { + std::quick_exit(1); + } + +} +