File indexing completed on 2025-02-22 10:33:27
0001
0002
0003
0004 #pragma once
0005
0006 #include "algorithms/calorimetry/HEXPLIT.h"
0007 #include "services/algorithms_init/AlgorithmsInit_service.h"
0008 #include "extensions/jana/JOmniFactory.h"
0009
0010
0011 namespace eicrecon {
0012
0013 class HEXPLIT_factory : public JOmniFactory<HEXPLIT_factory, HEXPLITConfig> {
0014
0015 using AlgoT = eicrecon::HEXPLIT;
0016 private:
0017 std::unique_ptr<AlgoT> m_algo;
0018 PodioInput<edm4eic::CalorimeterHit> m_rec_hits_input {this};
0019 PodioOutput<edm4eic::CalorimeterHit> m_subcell_hits_output {this};
0020
0021 ParameterRef<double> m_MIP {this, "MIP", config().MIP};
0022 ParameterRef<double> m_Emin_in_MIPs {this, "Emin_in_MIPs", config().Emin_in_MIPs};
0023 ParameterRef<double> m_tmax {this, "tmax", config().tmax};
0024
0025 Service<AlgorithmsInit_service> m_algorithmsInit {this};
0026
0027 public:
0028 void Configure() {
0029 m_algo = std::make_unique<AlgoT>(GetPrefix());
0030 m_algo->level(static_cast<algorithms::LogLevel>(logger()->level()));
0031 m_algo->applyConfig(config());
0032 m_algo->init();
0033 }
0034
0035 void ChangeRun(int64_t run_number) {
0036 }
0037
0038 void Process(int64_t run_number, uint64_t event_number) {
0039 m_algo->process({m_rec_hits_input()},{m_subcell_hits_output().get()});
0040 }
0041 };
0042
0043 }