57 [[nodiscard]] std::shared_ptr<Core::Window>
get_window()
const {
return m_window; }
63 [[nodiscard]] std::vector<DataDimension> get_dimensions()
const override;
64 [[nodiscard]] uint64_t get_total_elements()
const override;
65 [[nodiscard]]
MemoryLayout get_memory_layout()
const override;
74 [[nodiscard]] std::vector<DataVariant> get_region_data(
const Region& region)
const override;
75 void set_region_data(
const Region& region,
const std::vector<DataVariant>& data)
override;
77 [[nodiscard]] std::vector<DataVariant> get_region_group_data(
const RegionGroup& group)
const override;
78 [[nodiscard]] std::vector<DataVariant> get_segments_data(
const std::vector<RegionSegment>& segments)
const override;
80 [[nodiscard]]
double get_value_at(
const std::vector<uint64_t>& coordinates)
const override;
81 void set_value_at(
const std::vector<uint64_t>& coordinates,
double value)
override;
83 [[nodiscard]] uint64_t coordinates_to_linear_index(
const std::vector<uint64_t>& coordinates)
const override;
84 [[nodiscard]] std::vector<uint64_t> linear_index_to_coordinates(uint64_t linear_index)
const override;
86 void clear()
override;
88 void unlock()
override;
89 bool try_lock()
override;
91 [[nodiscard]]
const void* get_raw_data()
const override;
92 [[nodiscard]]
bool has_data()
const override;
104 [[nodiscard]] std::unordered_map<std::string, RegionGroup> get_all_region_groups()
const override;
111 void load_region(
const Region& region)
override;
116 void unload_region(
const Region& region)
override;
121 [[nodiscard]]
bool is_region_loaded(
const Region& region)
const override;
130 void register_state_change_callback(
131 std::function<
void(
const std::shared_ptr<SignalSourceContainer>&,
ProcessingState)> callback)
override;
132 void unregister_state_change_callback()
override;
134 [[nodiscard]]
bool is_ready_for_processing()
const override;
135 void mark_ready_for_processing(
bool ready)
override;
137 void create_default_processor()
override;
138 void process_default()
override;
140 void set_default_processor(
const std::shared_ptr<DataProcessor>& processor)
override;
141 [[nodiscard]] std::shared_ptr<DataProcessor> get_default_processor()
const override;
143 [[nodiscard]] std::shared_ptr<DataProcessingChain> get_processing_chain()
override;
144 void set_processing_chain(
const std::shared_ptr<DataProcessingChain>& chain)
override;
152 uint32_t register_dimension_reader(uint32_t dimension_index)
override;
153 void unregister_dimension_reader(uint32_t dimension_index)
override;
154 [[nodiscard]]
bool has_active_readers()
const override;
155 void mark_dimension_consumed(uint32_t dimension_index, uint32_t reader_id)
override;
156 [[nodiscard]]
bool all_dimensions_consumed()
const override;
158 [[nodiscard]] std::vector<DataVariant>& get_processed_data()
override;
159 [[nodiscard]]
const std::vector<DataVariant>& get_processed_data()
const override;
160 [[nodiscard]]
const std::vector<DataVariant>& get_data()
override;
165 [[nodiscard]]
DataAccess channel_data(
size_t channel_index)
override;
166 [[nodiscard]] std::vector<DataAccess> all_channel_data()
override;
180 std::atomic<ProcessingState> m_processing_state { ProcessingState::IDLE };
181 std::atomic<bool> m_ready_for_processing {
false };
188 std::atomic<uint32_t> m_registered_readers { 0 };
189 std::atomic<uint32_t> m_consumed_readers { 0 };
190 std::atomic<uint32_t> m_next_reader_id { 0 };
192 void setup_dimensions();