Without period, y=k*t+b and y=base+drift_rate*t grow infinitely, which is unrealistic for industrial simulation. period_ms makes t wrap modulo the period, producing sawtooth patterns that simulate per-cycle behavior (e.g. tension build-up per coil, sensor drift per shift).
17 lines
493 B
C
17 lines
493 B
C
#pragma once
|
|
#include <TestProject/RNG/model/IModel.h>
|
|
#include <nlohmann/json.hpp>
|
|
using json = nlohmann::json;
|
|
|
|
struct DriftModel : IModel {
|
|
float base, drift_rate;
|
|
size_t period_ticks;
|
|
DriftModel(const json& params, float defaultVal)
|
|
: base(defaultVal), drift_rate(params.value("drift_rate", 0.0f))
|
|
, period_ticks(params.value("period_ms", 0) / 20) {}
|
|
float evaluate(size_t t) override {
|
|
if (period_ticks > 0) t %= period_ticks;
|
|
return base + drift_rate * t;
|
|
}
|
|
};
|