EICrecon
JANA based reconstruction for the EPIC detector
Loading...
Searching...
No Matches
TrackParamTruthInit_factory.h
Go to the documentation of this file.
1// Created by Dmitry Romanov
2// Subject to the terms in the LICENSE file found in the top-level directory.
3//
4
5#pragma once
6
7#include <JANA/JEvent.h>
8#include <edm4eic/TrackParametersCollection.h>
9#include <memory>
10#include <string>
11#include <utility>
12#include <vector>
13
19
20namespace eicrecon {
21
23 : public JOmniFactory<TrackParamTruthInit_factory, TrackParamTruthInitConfig> {
24
25private:
27 std::unique_ptr<AlgoT> m_algo;
28
29 PodioInput<edm4hep::EventHeader> m_headers_input{this};
30 PodioInput<edm4hep::MCParticle> m_particles_input{this};
31 PodioOutput<edm4eic::TrackSeed> m_seeds_output{this};
32 PodioOutput<edm4eic::TrackParameters> m_parameters_output{this};
33
34 ParameterRef<double> m_maxVertexX{this, "MaxVertexX", config().maxVertexX,
35 "Maximum abs(vertex x) for truth tracks turned into seed"};
36 ParameterRef<double> m_maxVertexY{this, "MaxVertexY", config().maxVertexY,
37 "Maximum abs(vertex y) for truth tracks turned into seed"};
38 ParameterRef<double> m_maxVertexZ{this, "MaxVertexZ", config().maxVertexZ,
39 "Maximum abs(vertex z) for truth tracks turned into seed"};
40 ParameterRef<double> m_minMomentum{this, "MinMomentum", config().minMomentum,
41 "Minimum momentum for truth tracks turned into seed"};
42 ParameterRef<double> m_maxEtaForward{
43 this, "MaxEtaForward", config().maxEtaForward,
44 "Maximum forward abs(eta) for truth tracks turned into seed"};
45 ParameterRef<double> m_maxEtaBackward{
46 this, "MaxEtaBackward", config().maxEtaBackward,
47 "Maximum backward abs(eta) for truth tracks turned into seed"};
48 ParameterRef<double> m_momentumSmear{
49 this, "MomentumSmear", config().momentumSmear,
50 "Momentum magnitude fraction to use as width of gaussian smearing"};
51
52 Service<ACTSGeo_service> m_ACTSGeoSvc{this};
53 Service<AlgorithmsInit_service> m_algorithmsInit{this};
54
55public:
56 void Configure() {
57 m_algo = std::make_unique<AlgoT>(GetPrefix());
58 m_algo->level(static_cast<algorithms::LogLevel>(logger()->level()));
59 m_algo->applyConfig(config());
60 m_algo->init();
61 }
62
63 void Process(int32_t /* run_number */, uint64_t /* event_number */) {
64 m_algo->process({m_headers_input(), m_particles_input()},
65 {m_seeds_output().get(), m_parameters_output().get()});
66 }
67};
68
69} // namespace eicrecon
Definition JOmniFactory.h:30
TrackParamTruthInitConfig & 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
Definition TrackParamTruthInit_factory.h:23
void Process(int32_t, uint64_t)
Definition TrackParamTruthInit_factory.h:63
void Configure()
Definition TrackParamTruthInit_factory.h:56
Definition TrackParamTruthInit.h:29
-client
Definition CalorimeterClusterRecoCoG.cc:37
double maxVertexZ
Definition TrackParamTruthInitConfig.h:13
double maxEtaForward
Definition TrackParamTruthInitConfig.h:15
double maxVertexY
Definition TrackParamTruthInitConfig.h:12
double momentumSmear
Definition TrackParamTruthInitConfig.h:17
double maxEtaBackward
Definition TrackParamTruthInitConfig.h:16
double minMomentum
Definition TrackParamTruthInitConfig.h:14
double maxVertexX
Definition TrackParamTruthInitConfig.h:11