DUNE-DAQ
DUNE Trigger and Data Acquisition software
Loading...
Searching...
No Matches
NaiveRunSumProcessor.cpp
Go to the documentation of this file.
1
10
11namespace tpglibs {
12
13REGISTER_NAIVEPROCESSOR_CREATOR("NaiveRunSumProcessor", NaiveRunSumProcessor)
14
15void NaiveRunSumProcessor::configure(const nlohmann::json& config, const int16_t* plane_numbers) {
16 int16_t config_memory[3] = {config["memory_factor_plane0"],
17 config["memory_factor_plane1"],
18 config["memory_factor_plane2"]};
19 int16_t config_scale[3] = {config["scale_factor_plane0"],
20 config["scale_factor_plane1"],
21 config["scale_factor_plane2"]};
22
23 for (int i = 0; i < 16; i++) {
24 m_memory_factor[i] = config_memory[plane_numbers[i]];
25 m_scale_factor[i] = config_scale[plane_numbers[i]];
26 }
27}
28
30 for (int i = 0; i < 16; i++) {
31 int32_t scaled_rs = _naive_div_int16(m_running_sum[i], 10);
32 scaled_rs *= m_memory_factor[i];
33
34 int32_t scaled_signal = _naive_div_int16(signal[i], 10);
35 scaled_signal *= m_scale_factor[i];
36
37 int32_t intermediate = scaled_signal + scaled_rs;
38 m_running_sum[i] = std::min(intermediate, INT16_MAX);
39 }
41}
42
43} // namespace tpglibs
#define REGISTER_NAIVEPROCESSOR_CREATOR(processor_name, processor_class)
Factory registration macro.
virtual naive_array_t process(const naive_array_t &signal) override
Simple signal pass-through on naive type.
std::array< int16_t, 16 > naive_array_t
The naive version uses a standard array instead of __m256i.
Naive signal processor: Calculates the running sum of the signal.
naive_array_t m_scale_factor
The S factor in the model equation.
naive_array_t process(const naive_array_t &signal) override
Calculate and store the running sum.
naive_array_t m_running_sum
The RS in the model equation.
naive_array_t m_memory_factor
The R factor in the model equation.
int16_t _naive_div_int16(const int16_t &a, const int16_t &b)
Naive model of AVX division in AVXUtils.