OpenEV
Extending OpenCV to event-based vision
Loading...
Searching...
No Matches
circular.hpp
Go to the documentation of this file.
1
6#ifndef OPENEV_CONTAINERS_CIRCULAR_HPP
7#define OPENEV_CONTAINERS_CIRCULAR_HPP
8
10#include <boost/circular_buffer.hpp>
11#include <numeric>
12
13namespace ev {
19template <typename T>
20class CircularBuffer_ : public boost::circular_buffer<Event_<T>> {
21 using boost::circular_buffer<Event_<T>>::circular_buffer;
22
23public:
25 template <typename... Args>
26 inline void emplace_back(Args &&...args) {
27 boost::circular_buffer<Event_<T>>::push_back(Event_<T>(std::forward<Args>(args)...));
28 }
29
30 template <typename... Args>
31 inline void emplace_front(Args &&...args) {
32 boost::circular_buffer<Event_<T>>::push_front(Event_<T>(std::forward<Args>(args)...));
33 }
40 [[nodiscard]] inline double duration() const {
41 return boost::circular_buffer<Event_<T>>::back().t - boost::circular_buffer<Event_<T>>::front().t;
42 }
43
48 [[nodiscard]] inline double rate() const {
49 return boost::circular_buffer<Event_<T>>::size() / duration();
50 }
51
56 [[nodiscard]] Eventd mean() const {
57 const double x = std::accumulate(boost::circular_buffer<Event_<T>>::begin(), boost::circular_buffer<Event_<T>>::end(), 0.0, [](double sum, const Event_<T> &e) { return sum + e.x; }) / boost::circular_buffer<Event_<T>>::size();
58 const double y = std::accumulate(boost::circular_buffer<Event_<T>>::begin(), boost::circular_buffer<Event_<T>>::end(), 0.0, [](double sum, const Event_<T> &e) { return sum + e.y; }) / boost::circular_buffer<Event_<T>>::size();
59 const double t = std::accumulate(boost::circular_buffer<Event_<T>>::begin(), boost::circular_buffer<Event_<T>>::end(), 0.0, [](double sum, const Event_<T> &e) { return sum + e.t; }) / boost::circular_buffer<Event_<T>>::size();
60 const double p = std::accumulate(boost::circular_buffer<Event_<T>>::begin(), boost::circular_buffer<Event_<T>>::end(), 0.0, [](double sum, const Event_<T> &e) { return sum + e.p; }) / boost::circular_buffer<Event_<T>>::size();
61 return {x, y, t, p > 0.5};
62 }
63
68 [[nodiscard]] inline cv::Point2d meanPoint() const {
69 const double x = std::accumulate(boost::circular_buffer<Event_<T>>::begin(), boost::circular_buffer<Event_<T>>::end(), 0.0, [](double sum, const Event_<T> &e) { return sum + e.x; }) / boost::circular_buffer<Event_<T>>::size();
70 const double y = std::accumulate(boost::circular_buffer<Event_<T>>::begin(), boost::circular_buffer<Event_<T>>::end(), 0.0, [](double sum, const Event_<T> &e) { return sum + e.y; }) / boost::circular_buffer<Event_<T>>::size();
71 return {x, y};
72 }
73
78 [[nodiscard]] inline double meanTime() const {
79 return std::accumulate(boost::circular_buffer<Event_<T>>::begin(), boost::circular_buffer<Event_<T>>::end(), 0.0, [](double sum, const Event_<T> &e) { return sum + e.t; }) / boost::circular_buffer<Event_<T>>::size();
80 }
81
86 [[nodiscard]] inline double midTime() const {
87 return 0.5 * (boost::circular_buffer<Event_<T>>::front().t + boost::circular_buffer<Event_<T>>::back().t);
88 }
89};
95} // namespace ev
96
97#endif // OPENEV_CONTAINERS_CIRCULAR_HPP
This class extends boost::circular_buffer to implement event circular buffers. For more information,...
Definition circular.hpp:20
double rate() const
Compute event rate as the ratio between the number of events and the time difference between the last...
Definition circular.hpp:48
Eventd mean() const
Compute the mean of the events.
Definition circular.hpp:56
double midTime() const
Calculate the midpoint time between the oldest and the newest event.
Definition circular.hpp:86
double duration() const
Time difference between the last and the first event.
Definition circular.hpp:40
cv::Point2d meanPoint() const
Compute the mean x,y point of the events.
Definition circular.hpp:68
double meanTime() const
Compute the mean time of the events.
Definition circular.hpp:78
This class extends cv::Point_<T> for event data. For more information, please refer here.
Definition types.hpp:60
bool p
Definition types.hpp:63
double t
Definition types.hpp:62
Basic event-based vision structures based on OpenCV components.