RTC Toolkit 4.0.1
Loading...
Searching...
No Matches
frequencyEstimator.hpp
Go to the documentation of this file.
1
12#ifndef RTCTK_COMPONENTFRAMEWORK_FREQUENCYESTIMATOR_HPP
13#define RTCTK_COMPONENTFRAMEWORK_FREQUENCYESTIMATOR_HPP
14
17
18#include <chrono>
19#include <string>
20
22
30template <typename ClockType = std::chrono::steady_clock>
32public:
41 std::string const& desc,
42 std::string const& prefix = "")
43 : m_num_samples(0), m_start_time(ClockType::now()), m_frequency_estimate(0) {
44 std::string path;
45 if (prefix == "") {
46 path = "frequency_estimate";
47 } else {
48 path = prefix + "/frequency_estimate";
49 }
50
51 try {
52 m_frequency_estimate_reg =
53 metrics.AddCounter(&m_frequency_estimate, CounterMetricInfo(path, desc + " [Hz]"));
54 } catch (...) {
55 LOG4CPLUS_ERROR(GetLogger("rtctk"),
56 "FrequencyEstimator: Failed to register to metrics service. "
57 "Will ignore and continue anyway: "
58 << NestedExceptionPrinter(std::current_exception()));
59 }
60 }
61
70 inline void Tick() noexcept {
71 using namespace std::chrono_literals;
72
73 ++m_num_samples;
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());
79 m_num_samples = 0;
80 }
81 }
82
91 double GetValue() const {
92 return m_frequency_estimate.Load();
93 }
94
100 void Reset() {
101 m_frequency_estimate.Store(0);
102 m_start_time = ClockType::now();
103 m_num_samples = 0;
104 }
105
106private:
107 uint32_t m_num_samples;
108 typename ClockType::time_point m_start_time;
109
110 perfc::CounterDouble m_frequency_estimate;
111 perfc::ScopedRegistration m_frequency_estimate_reg;
112};
113
114} // namespace rtctk::componentFramework
115
116#endif // RTCTK_COMPONENTFRAMEWORK_FREQUENCYESTIMATOR_HPP
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