70 [[nodiscard]] std::shared_ptr<Core::Window>
get_window()
const {
return m_window; }
85 [[nodiscard]] std::vector<DataDimension> get_dimensions()
const override;
86 [[nodiscard]] uint64_t get_total_elements()
const override;
87 [[nodiscard]]
MemoryLayout get_memory_layout()
const override;
96 [[nodiscard]] std::vector<DataVariant> get_region_data(
const Region& region)
const override;
108 [[nodiscard]] std::shared_ptr<Core::VKImage> to_image()
const;
123 [[nodiscard]] std::shared_ptr<Core::VKImage> to_image(
124 const std::shared_ptr<Buffers::VKBuffer>& staging)
const;
137 [[nodiscard]] std::shared_ptr<Core::VKImage> region_to_image(
const Region& region)
const;
139 void set_region_data(
const Region& region,
const std::vector<DataVariant>& data)
override;
141 [[nodiscard]] std::vector<DataVariant> get_region_group_data(
const RegionGroup& group)
const override;
142 [[nodiscard]] std::vector<DataVariant> get_segments_data(
const std::vector<RegionSegment>& segments)
const override;
144 [[nodiscard]]
double get_value_at(
const std::vector<uint64_t>& coordinates)
const override;
145 void set_value_at(
const std::vector<uint64_t>& coordinates,
double value)
override;
147 [[nodiscard]] uint64_t coordinates_to_linear_index(
const std::vector<uint64_t>& coordinates)
const override;
148 [[nodiscard]] std::vector<uint64_t> linear_index_to_coordinates(uint64_t linear_index)
const override;
150 void clear()
override;
151 void lock()
override;
152 void unlock()
override;
153 bool try_lock()
override;
155 [[nodiscard]]
const void* get_raw_data()
const override;
156 [[nodiscard]]
bool has_data()
const override;
168 [[nodiscard]] std::unordered_map<std::string, RegionGroup> get_all_region_groups()
const override;
175 void load_region(
const Region& region)
override;
180 void unload_region(
const Region& region)
override;
185 [[nodiscard]]
bool is_region_loaded(
const Region& region)
const override;
194 void register_state_change_callback(
195 std::function<
void(
const std::shared_ptr<SignalSourceContainer>&,
ProcessingState)> callback)
override;
196 void unregister_state_change_callback()
override;
198 [[nodiscard]]
bool is_ready_for_processing()
const override;
199 void mark_ready_for_processing(
bool ready)
override;
201 void create_default_processor()
override;
202 void process_default()
override;
204 void set_default_processor(
const std::shared_ptr<DataProcessor>& processor)
override;
205 [[nodiscard]] std::shared_ptr<DataProcessor> get_default_processor()
const override;
207 [[nodiscard]] std::shared_ptr<DataProcessingChain> get_processing_chain()
override;
208 void set_processing_chain(
const std::shared_ptr<DataProcessingChain>& chain)
override;
210 [[nodiscard]] uint64_t get_frame_size()
const override;
211 [[nodiscard]] uint64_t get_num_frames()
const override;
212 [[nodiscard]] std::span<const double> get_frame(uint64_t frame_index)
const override;
213 void get_frames(std::span<double> output, uint64_t start_frame, uint64_t num_frames)
const override;
221 uint32_t register_dimension_reader(uint32_t dimension_index)
override;
222 void unregister_dimension_reader(uint32_t dimension_index)
override;
223 [[nodiscard]]
bool has_active_readers()
const override;
224 void mark_dimension_consumed(uint32_t dimension_index, uint32_t reader_id)
override;
225 [[nodiscard]]
bool all_dimensions_consumed()
const override;
227 [[nodiscard]] std::vector<DataVariant>& get_processed_data()
override;
228 [[nodiscard]]
const std::vector<DataVariant>& get_processed_data()
const override;
229 [[nodiscard]]
const std::vector<DataVariant>& get_data()
override;
234 [[nodiscard]]
DataAccess channel_data(
size_t channel_index)
override;
235 [[nodiscard]] std::vector<DataAccess> all_channel_data()
override;
249 std::atomic<ProcessingState> m_processing_state { ProcessingState::IDLE };
250 std::atomic<bool> m_ready_for_processing {
false };
259 std::atomic<uint32_t> m_registered_readers { 0 };
260 std::atomic<uint32_t> m_consumed_readers { 0 };
261 std::atomic<uint32_t> m_next_reader_id { 0 };
263 void setup_dimensions();