EICrecon
JANA based reconstruction for the EPIC detector
Loading...
Searching...
No Matches
TruthEnergyPositionClusterMerger_factory.h
Go to the documentation of this file.
1// SPDX-License-Identifier: LGPL-3.0-or-later
2// Copyright (C) 2023 Wouter Deconinck
3
4#pragma once
5
6#include <edm4eic/EDM4eicVersion.h>
10
11namespace eicrecon {
12
14 : public JOmniFactory<TruthEnergyPositionClusterMerger_factory, NoConfig> {
15public:
17
18private:
19 std::unique_ptr<AlgoT> m_algo;
20
21 PodioInput<edm4hep::MCParticle> m_mcparticles_input{this};
22 PodioInput<edm4eic::Cluster> m_energy_clusters_input{this};
23 PodioInput<edm4eic::MCRecoClusterParticleAssociation> m_energy_assocs_input{this};
24 PodioInput<edm4eic::Cluster> m_position_clusters_input{this};
25 PodioInput<edm4eic::MCRecoClusterParticleAssociation> m_position_assocs_input{this};
26
27 PodioOutput<edm4eic::Cluster> m_clusters_output{this};
28#if EDM4EIC_BUILD_VERSION >= EDM4EIC_VERSION(8, 7, 0)
29 PodioOutput<edm4eic::MCRecoClusterParticleLink> m_links_output{this};
30#endif
31 PodioOutput<edm4eic::MCRecoClusterParticleAssociation> m_assocs_output{this};
32
33 Service<AlgorithmsInit_service> m_algorithmsInit{this};
34
35public:
36 void Configure() {
37 m_algo = std::make_unique<AlgoT>(GetPrefix());
38 m_algo->level(static_cast<algorithms::LogLevel>(logger()->level()));
39 m_algo->applyConfig(config());
40 m_algo->init();
41 }
42
43 void Process(int32_t /* run_number */, uint64_t /* event_number */) {
44 m_algo->process({m_mcparticles_input(), m_energy_clusters_input(), m_energy_assocs_input(),
45 m_position_clusters_input(), m_position_assocs_input()},
46 {m_clusters_output().get(),
47#if EDM4EIC_BUILD_VERSION >= EDM4EIC_VERSION(8, 7, 0)
48 m_links_output().get(),
49#endif
50 m_assocs_output().get()});
51 }
52};
53
54} // namespace eicrecon
Definition JOmniFactory.h:30
NoConfig & config()
Retrieve reference to embedded config object.
Definition JOmniFactory.h:576
std::shared_ptr< spdlog::logger > & logger()
Retrieve reference to already-configured logger.
Definition JOmniFactory.h:573
std::string GetPrefix()
Definition JOmniFactory.h:570
Definition TruthEnergyPositionClusterMerger_factory.h:14
void Configure()
Definition TruthEnergyPositionClusterMerger_factory.h:36
void Process(int32_t, uint64_t)
Definition TruthEnergyPositionClusterMerger_factory.h:43
Definition TruthEnergyPositionClusterMerger.h:43
-client
Definition CalorimeterClusterRecoCoG.cc:37