DvsenseDriver  1.1.3
The SDK for dvsense products.
载入中...
搜索中...
未找到
DvsApsFusionProccessor.hpp
1#ifndef DVS_APS_FUSION_PROCCESSOR_HPP
2#define DVS_APS_FUSION_PROCCESSOR_HPP
3#include "DvsenseBase/EventBase/EventTypes.hpp"
4#include "DvsenseBase/ApsBase/ApsTypes.h"
5#include "DvsenseBase/Utils/ObjectPool/DsObjectPoolFactory.h"
6#include <queue>
7#include <mutex>
8
9#ifdef _WIN32
10#define DVSENSE_API __declspec(dllexport)
11#else
12#define DVSENSE_API
13#endif // _WIN32
14namespace dvsense
15{
16 class DVSENSE_API DvsApsFusionProccessor
17 {
18 public:
26 {
27 dvs_events_frame_pool_ = DsObjectPoolFactory::createUniqueDsObjectPoolWithArgs<Event2DVector>(10, 3*1024*1024);
28 dvs_events_buffer_ = dvs_events_frame_pool_->acquire();
29 dvs_events_buffer_->clear();
30 fusion_data_callback_ = nullptr;
31 }
32
33 void clear()
34 {
35 std::unique_lock<std::mutex> lock(fusion_queue_mutex_);
36 while (!aps_frame_queue_.empty())
37 {
38 aps_frame_queue_.pop();
39 }
40 while (!dvs_events_frame_queue_.empty())
41 {
42 dvs_events_frame_queue_.pop();
43 }
44 dvs_events_buffer_->clear();
45 }
46
53 void addFusionDataCallback(DsFusionDataCallback cb)
54 {
55 fusion_data_callback_ = cb;
56 }
62 {
63 fusion_data_callback_ = nullptr;
64 }
65
70 void addDvsData(const Event2D *begin, const Event2D *end)
71 {
72 dvs_events_buffer_->insert(dvs_events_buffer_->end(), begin, end);
73 }
74
79 void addApsData(const ApsFrame &frame)
80 {
81
82 std::unique_lock<std::mutex> fusion_lock(fusion_queue_mutex_);
83 aps_frame_queue_.push(frame.clone());
84 fusionData();
85 }
86
91 void addSyncSignal(const EventTriggerIn &trigger_in)
92 {
93 if (trigger_in.polarity == 1)
94 {
95 std::unique_lock<std::mutex> fusion_lock(fusion_queue_mutex_);
96 dvs_events_frame_queue_.push(dvs_events_buffer_);
97 dvs_events_buffer_ = dvs_events_frame_pool_->acquire();
98 dvs_events_buffer_->clear();
99 fusionData();
100 }
101 }
102
108 {
109 while (!aps_frame_queue_.empty() && !dvs_events_frame_queue_.empty())
110 {
111 ApsFrame frame = aps_frame_queue_.front();
112 aps_frame_queue_.pop();
113 DsObjectPool<Event2DVector>::ptr_type dvs_events = dvs_events_frame_queue_.front();
114 dvs_events_frame_queue_.pop();
115 if (fusion_data_callback_)
116 {
117 fusion_data_callback_(frame, dvs_events->data(), dvs_events->data() + dvs_events->size());
118 }
119 }
120 }
121
122 private:
123 std::unique_ptr<DsObjectPool<Event2DVector>> dvs_events_frame_pool_;
124 std::queue<DsObjectPool<Event2DVector>::ptr_type> dvs_events_frame_queue_;
125 DsObjectPool<Event2DVector>::ptr_type dvs_events_buffer_;
126
127 std::queue<ApsFrame> aps_frame_queue_;
128 DsFusionDataCallback fusion_data_callback_;
129 std::mutex fusion_queue_mutex_;
130 };
131} // namespace dvsense
132
133#endif // DVS_APS_FUSION_PROCCESSOR_HPP
定义 DvsApsFusionProccessor.hpp:17
void addFusionDataCallback(DsFusionDataCallback cb)
添加融合数据回调函数
定义 DvsApsFusionProccessor.hpp:53
void addSyncSignal(const EventTriggerIn &trigger_in)
添加同步信号用于融合
定义 DvsApsFusionProccessor.hpp:91
void addApsData(const ApsFrame &frame)
添加aps数据用于融合
定义 DvsApsFusionProccessor.hpp:79
void fusionData()
对dvs与aps数据进行融合,并调用回调函数
定义 DvsApsFusionProccessor.hpp:107
void addDvsData(const Event2D *begin, const Event2D *end)
添加dvs数据用于融合
定义 DvsApsFusionProccessor.hpp:70
void removeFusionDataCallback()
清除融合数据回调函数
定义 DvsApsFusionProccessor.hpp:61
void clear()
定义 DvsApsFusionProccessor.hpp:33
DvsApsFusionProccessor()
构造函数
定义 DvsApsFusionProccessor.hpp:25
定义 TypeUtils.hpp:9