9#ifndef TPGLIBS_TPGPIPELINE_HPP_
10#define TPGLIBS_TPGPIPELINE_HPP_
18#include <nlohmann/json.hpp>
29template <
typename T,
typename U>
45 virtual void configure(
const std::vector<std::pair<std::string, nlohmann::json>> configs,
const std::vector<std::pair<dunedaq::trgdataformats::channel_t, int16_t>> channel_plane_numbers) {
46 std::shared_ptr<processor_t> prev_processor =
nullptr;
48 for (
int i = 0; i < 16; i++) {
49 m_channels.at(i) = channel_plane_numbers[i].first;
53 for (
const auto& name_config : configs) {
55 std::shared_ptr<processor_t> processor =
m_factory->create_processor(name_config.first);
61 if (!prev_processor) {
63 prev_processor = processor;
68 prev_processor->set_next_processor(processor);
69 prev_processor = processor;
76 virtual std::vector<dunedaq::trgdataformats::TriggerPrimitive>
process(
const signal_t& signal) {
79 std::vector<dunedaq::trgdataformats::TriggerPrimitive> tps;
101 std::vector<std::shared_ptr<AbstractProcessor<signal_t>>> processor_references;
104 auto current_processor = std::static_pointer_cast<AbstractProcessor<signal_t>>(
m_processor_head);
105 while (current_processor !=
nullptr) {
106 processor_references.push_back(current_processor);
107 current_processor = current_processor->get_next_processor();
109 return processor_references;
115 for (
auto sot_minimum : sot_minima) {
131 std::array<dunedaq::trgdataformats::channel_t, 16>
m_channels;
static std::shared_ptr< AbstractFactory< T > > get_instance()
Singleton get instance function.
Abstract class for the TPG pipeline.
virtual ~TPGPipeline()=default
std::array< int16_t, 16 > m_plane_numbers
Detector plane numbers for the 16 channels that are being processed.
std::array< dunedaq::trgdataformats::channel_t, 16 > m_channels
Detector channel numbers for the 16 channels that are being processed.
std::shared_ptr< processor_t > m_processor_head
Processor head to start from.
signal_t m_adc_integral_hi
signal_t m_adc_peak
The ADC peak for channels that are considered active.
std::shared_ptr< AbstractFactory< processor_t > > m_factory
Processor factory singleton.
signal_t m_adc_integral_lo
The on-going ADC integral for channels that are considered active.
virtual void set_sot_minima(const std::vector< uint16_t > &sot_minima)
Set the samples over threshold minimum values.
signal_t m_samples_over_threshold
The samples over threshold for channels that are considered active.
T processor_t
Processor type to use. Generally AVX.
virtual bool check_for_tps(const signal_t &tp_mask)=0
Pure virtual function that will check if any TPs can be generated.
std::array< uint16_t, 3 > m_sot_minima
The samples over threshold minimum that a TP from plane i must have.
virtual void configure(const std::vector< std::pair< std::string, nlohmann::json > > configs, const std::vector< std::pair< dunedaq::trgdataformats::channel_t, int16_t > > channel_plane_numbers)
Configure the pieces to the pipeline.
virtual std::vector< std::shared_ptr< AbstractProcessor< signal_t > > > get_all_processor_references()
Return reference to all processors in this pipeline.
U signal_t
Signal type to use. Generally __m256i.
virtual std::vector< dunedaq::trgdataformats::TriggerPrimitive > process(const signal_t &signal)
Process a signal through the pipeline.
signal_t m_samples_to_peak
The number of samples from time_start to the ADC peak.
virtual std::vector< dunedaq::trgdataformats::TriggerPrimitive > generate_tps(const signal_t &tp_mask)=0
Pure virtual function that will generate TPs given a mask to draw from.
virtual signal_t save_state(const signal_t &processed_signal)=0
Pure virtual function that will save the state of the generation.