12#ifndef RTCTK_COMPONENTFRAMEWORK_FREQUENCYESTIMATOR_HPP
13#define RTCTK_COMPONENTFRAMEWORK_FREQUENCYESTIMATOR_HPP
30template <
typename ClockType = std::chrono::steady_clock>
41 std::string
const& desc,
42 std::string
const& prefix =
"")
43 : m_num_samples(0), m_start_time(ClockType::now()), m_frequency_estimate(0) {
46 path =
"frequency_estimate";
48 path = prefix +
"/frequency_estimate";
52 m_frequency_estimate_reg =
56 "FrequencyEstimator: Failed to register to metrics service. "
57 "Will ignore and continue anyway: "
70 inline void Tick() noexcept {
71 using namespace std::chrono_literals;
74 auto now_time = ClockType::now();
75 std::chrono::duration<double, std::ratio<1>> elapsed_time = now_time - m_start_time;
76 if (elapsed_time > 1s) {
77 m_start_time = now_time;
78 m_frequency_estimate.Store(m_num_samples / elapsed_time.count());
92 return m_frequency_estimate.Load();
101 m_frequency_estimate.Store(0);
102 m_start_time = ClockType::now();
107 uint32_t m_num_samples;
108 typename ClockType::time_point m_start_time;
110 perfc::CounterDouble m_frequency_estimate;
111 perfc::ScopedRegistration m_frequency_estimate_reg;
Component metrics interface.
Definition: componentMetricsIf.hpp:184
virtual perfc::ScopedRegistration AddCounter(CounterVariant counter, CounterMetricInfo info)=0
Add a counter to be included in component metrics, identified by its address, together with info to t...
Defines auxiliary information associated with each counter registered with ComponentMetricsIf.
Definition: componentMetricsIf.hpp:46
Estimates the frequency in which Tick is called and publishes result to OLDB.
Definition: frequencyEstimator.hpp:31
FrequencyEstimator(ComponentMetricsIf &metrics, std::string const &desc, std::string const &prefix="")
Construct instance.
Definition: frequencyEstimator.hpp:40
double GetValue() const
Method to get the measured frequency in Hz.
Definition: frequencyEstimator.hpp:91
void Reset()
Method to reset the estimator.
Definition: frequencyEstimator.hpp:100
void Tick() noexcept
Method to be called repeatedly from within the hot loop that should be measured.
Definition: frequencyEstimator.hpp:70
Adapter object intended to be used in contexts without direct access to the output-stream object.
Definition: exceptions.hpp:185
Header file for ComponentMetricsIf.
log4cplus::Logger & GetLogger(const std::string &name="app")
Get handle to a specific logger.
Definition: logger.cpp:180
Logging Support Library based on log4cplus.
Definition: commandReplier.cpp:22