bb9f5c715f
Build Packages / build:rpm (ubuntu2204_nocuda) (push) Successful in 9m55s
Build Packages / build:rpm (rocky8_nocuda) (push) Successful in 10m28s
Build Packages / build:rpm (ubuntu2404_nocuda) (push) Successful in 8m56s
Build Packages / build:rpm (rocky9_nocuda) (push) Successful in 11m47s
Build Packages / build:rpm (rocky8_sls9) (push) Successful in 13m7s
Build Packages / build:rpm (ubuntu2204) (push) Successful in 12m31s
Build Packages / build:rpm (rocky8) (push) Successful in 12m59s
Build Packages / build:rpm (rocky9) (push) Successful in 14m5s
Build Packages / build:rpm (rocky9_sls9) (push) Successful in 15m30s
Build Packages / Generate python client (push) Successful in 1m18s
Build Packages / Build documentation (push) Successful in 1m3s
Build Packages / Create release (push) Has been skipped
Build Packages / build:rpm (ubuntu2404) (push) Successful in 10m8s
Build Packages / XDS test (durin plugin) (push) Successful in 9m16s
Build Packages / XDS test (neggia plugin) (push) Successful in 7m59s
Build Packages / XDS test (JFJoch plugin) (push) Successful in 9m12s
Build Packages / DIALS test (push) Successful in 11m44s
Build Packages / Unit tests (push) Successful in 1h23m8s
This is an UNSTABLE release. The release has significant modifications and bug fixes, if things go wrong, it is better to revert to 1.0.0-rc.132. * Multiple small bug fixes scattered across the whole code base. (detected with GPT-5.4) * jfjoch_viewer: Improve image render performance Reviewed-on: #44 Co-authored-by: Filip Leonarski <filip.leonarski@psi.ch> Co-committed-by: Filip Leonarski <filip.leonarski@psi.ch>
39 lines
871 B
C++
39 lines
871 B
C++
// SPDX-FileCopyrightText: 2024 Filip Leonarski, Paul Scherrer Institute <filip.leonarski@psi.ch>
|
|
// SPDX-License-Identifier: GPL-3.0-only
|
|
|
|
#include <cmath>
|
|
#include "MovingAverage.h"
|
|
|
|
#include "JFJochException.h"
|
|
|
|
MovingAverage::MovingAverage(size_t elems) : elems(elems) {
|
|
if (elems == 0)
|
|
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid, "Moving average size must be positive");
|
|
|
|
}
|
|
|
|
void MovingAverage::Add(float val) {
|
|
std::unique_lock ul(m);
|
|
|
|
if (q.size() >= elems)
|
|
q.pop_front();
|
|
q.push_back(val);
|
|
}
|
|
|
|
void MovingAverage::Add(std::optional<float> val) {
|
|
if (val)
|
|
Add(val.value());
|
|
}
|
|
|
|
std::optional<float> MovingAverage::Read() const {
|
|
std::unique_lock ul(m);
|
|
|
|
if (q.empty())
|
|
return {};
|
|
|
|
float sum = 0;
|
|
for (const auto &elem: q)
|
|
sum += elem;
|
|
|
|
return sum / q.size();
|
|
} |