MayaFlux 0.4.0
Digital-First Multimedia Processing Framework
Loading...
Searching...
No Matches

◆ process()

void MayaFlux::Kakshya::SpatialRegionProcessor::process ( const std::shared_ptr< SignalSourceContainer > &  container)
overridevirtual

Extract all active regions from processed_data[0] in parallel.

   For each OrganizedRegion in m_organized_regions, extracts pixel
   data via extract_nd_region and appends to processed_data.
   Sets OrganizedRegion::state to ACTIVE during extraction and
   PROCESSED on completion.  Failed extractions are logged and
   skipped without aborting the frame.
Parameters
containerSource container; processed_data[0] must hold the full-surface buffer.

Implements MayaFlux::Kakshya::DataProcessor.

Definition at line 84 of file SpatialRegionProcessor.cpp.

85{
86 if (!container) {
88 "SpatialRegionProcessor::process — null container");
89 return;
90 }
91
92 auto& processed = container->get_processed_data();
93
94 if (processed.empty()) {
96 "SpatialRegionProcessor: processed_data empty, no readback available");
97 container->update_processing_state(ProcessingState::IDLE);
98 return;
99 }
100
101 const bool src_empty = std::visit(
102 [](const auto& v) { return v.empty(); }, processed[0]);
103
104 if (src_empty) {
106 "SpatialRegionProcessor: processed_data[0] empty, skipping extraction");
107 container->update_processing_state(ProcessingState::IDLE);
108 return;
109 }
110
111 if (m_organized_regions.empty()) {
112 container->update_processing_state(ProcessingState::IDLE);
113 return;
114 }
115
116 m_is_processing.store(true, std::memory_order_release);
117 container->update_processing_state(ProcessingState::PROCESSING);
118
119 const auto& dims = container->get_structure().dimensions;
120
121 std::vector<DataVariant> extracts;
122 extracts.reserve(m_organized_regions.size());
123
124 std::visit([&](const auto& src_vec) {
125 using T = typename std::decay_t<decltype(src_vec)>::value_type;
126
127 if constexpr (std::is_same_v<T, uint8_t>
128 || std::is_same_v<T, uint16_t>
129 || std::is_same_v<T, uint32_t>
130 || std::is_same_v<T, float>) {
131
132 const std::span<const T> src { src_vec.data(), src_vec.size() };
133
134 for (auto& org : m_organized_regions) {
135 if (org.segments.empty()) {
137 "SpatialRegionProcessor: OrganizedRegion '{}[{}]' has no segments, skipping",
138 org.group_name, org.region_index);
139 continue;
140 }
141
142 org.state = RegionState::ACTIVE;
143
144 try {
145 extracts.emplace_back(
146 extract_nd_region<T>(src, org.segments[0].source_region, dims));
147 org.state = RegionState::READY;
148 } catch (const std::exception& e) {
150 "SpatialRegionProcessor: extraction failed for '{}[{}]' — {}",
151 org.group_name, org.region_index, e.what());
152 org.state = RegionState::IDLE;
153 }
154 }
155 } else {
157 "SpatialRegionProcessor: processed_data[0] holds a type not suitable "
158 "for spatial pixel extraction ({}); no regions extracted",
159 typeid(T).name());
160 }
161 },
162 processed[0]);
163
164 processed = std::move(extracts);
165
166 m_is_processing.store(false, std::memory_order_release);
167 container->update_processing_state(ProcessingState::PROCESSED);
168}
#define MF_RT_WARN(comp, ctx,...)
#define MF_RT_ERROR(comp, ctx,...)
#define MF_RT_TRACE(comp, ctx,...)
std::vector< OrganizedRegion > m_organized_regions
@ ContainerProcessing
Container operations (Kakshya - file/stream/region processing)
@ Kakshya
Containers[Signalsource, Stream, File], Regions, DataProcessors.
@ IDLE
Container is inactive with no data or not ready for processing.
@ PROCESSING
Container is actively being processed.
@ PROCESSED
Container has completed processing and results are available.
@ ACTIVE
Currently being processed.
@ READY
Ready for processing.
@ IDLE
Not being processed.

References MayaFlux::Kakshya::ACTIVE, MayaFlux::Journal::ContainerProcessing, MayaFlux::Kakshya::IDLE, MayaFlux::Journal::Kakshya, MayaFlux::Kakshya::RegionProcessorBase::m_is_processing, MayaFlux::Kakshya::RegionProcessorBase::m_organized_regions, MF_RT_ERROR, MF_RT_TRACE, MF_RT_WARN, MayaFlux::Kakshya::PROCESSED, MayaFlux::Kakshya::PROCESSING, and MayaFlux::Kakshya::READY.