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

◆ create_dimensions()

std::vector< DataDimension > MayaFlux::Kakshya::DataDimension::create_dimensions ( DataModality  modality,
const std::vector< uint64_t > &  shape,
MemoryLayout  layout = MemoryLayout::ROW_MAJOR 
)
static

Create dimension descriptors for a data modality.

Parameters
modalityTarget data modality
shapeDimensional sizes
layoutMemory layout strategy
Returns
Vector of DataDimension objects

Definition at line 108 of file NDData.cpp.

112{
113 std::vector<DataDimension> dims;
114 auto strides = calculate_strides(shape, layout);
115
116 switch (modality) {
118 if (shape.size() != 1) {
119 error<std::invalid_argument>(
122 std::source_location::current(),
123 "AUDIO_1D requires 1D shape");
124 }
125 dims.push_back(DataDimension::time(shape[0]));
126 break;
127
129 if (shape.size() != 2) {
130 error<std::invalid_argument>(
133 std::source_location::current(),
134 "AUDIO_MULTICHANNEL requires 2D shape [samples, channels]");
135 }
136 dims.push_back(DataDimension::time(shape[0]));
137 dims.push_back(DataDimension::channel(shape[1], strides[1]));
138 break;
139
141 if (shape.size() != 2) {
142 error<std::invalid_argument>(
145 std::source_location::current(),
146 "IMAGE_2D requires 2D shape [height, width]");
147 }
148 dims.push_back(DataDimension::spatial(shape[0], 'y', strides[0]));
149 dims.push_back(DataDimension::spatial(shape[1], 'x', strides[1]));
150 break;
151
153 if (shape.size() != 3) {
154 error<std::invalid_argument>(
157 std::source_location::current(),
158 "IMAGE_COLOR requires 3D shape [height, width, channels]");
159 }
160 dims.push_back(DataDimension::spatial(shape[0], 'y', strides[0]));
161 dims.push_back(DataDimension::spatial(shape[1], 'x', strides[1]));
162 dims.push_back(DataDimension::channel(shape[2], strides[2]));
163 break;
164
166 if (shape.size() != 2) {
167 error<std::invalid_argument>(
170 std::source_location::current(),
171 "SPECTRAL_2D requires 2D shape [time_windows, frequency_bins]");
172 }
173 dims.push_back(DataDimension::time(shape[0], "time_windows"));
174 dims.push_back(DataDimension::frequency(shape[1]));
175 dims[1].stride = strides[1];
176 break;
177
179 if (shape.size() != 3) {
180 error<std::invalid_argument>(
183 std::source_location::current(),
184 "VOLUMETRIC_3D requires 3D shape [x, y, z]");
185 }
186 dims.push_back(DataDimension::spatial(shape[0], 'x', strides[0]));
187 dims.push_back(DataDimension::spatial(shape[1], 'y', strides[1]));
188 dims.push_back(DataDimension::spatial(shape[2], 'z', strides[2]));
189 break;
190
192 if (shape.size() != 3) {
193 error<std::invalid_argument>(
196 std::source_location::current(),
197 "VIDEO_GRAYSCALE requires 3D shape [frames, height, width]");
198 }
199 dims.push_back(DataDimension::time(shape[0], "frames"));
200 dims.push_back(DataDimension::spatial(shape[1], 'y', strides[1]));
201 dims.push_back(DataDimension::spatial(shape[2], 'x', strides[2]));
202 break;
203
205 if (shape.size() != 4) {
206 error<std::invalid_argument>(
209 std::source_location::current(),
210 "VIDEO_COLOR requires 4D shape [frames, height, width, channels]");
211 }
212 dims.push_back(DataDimension::time(shape[0], "frames"));
213 dims.push_back(DataDimension::spatial(shape[1], 'y', strides[1]));
214 dims.push_back(DataDimension::spatial(shape[2], 'x', strides[2]));
215 dims.push_back(DataDimension::channel(shape[3], strides[3]));
216 break;
217
218 default:
219 error<std::invalid_argument>(
222 std::source_location::current(),
223 "Unsupported modality for dimension creation: {}", modality_to_string(modality));
224 }
225
226 return dims;
227}
@ Runtime
General runtime operations (default fallback)
@ Kakshya
Containers[Signalsource, Stream, File], Regions, DataProcessors.
@ AUDIO_MULTICHANNEL
Multi-channel audio.
@ SPECTRAL_2D
2D spectral data (time + frequency)
@ VOLUMETRIC_3D
3D volumetric data
@ VIDEO_GRAYSCALE
3D video (time + 2D grayscale)
@ VIDEO_COLOR
4D video (time + 2D + color)
@ IMAGE_COLOR
2D RGB/RGBA image
@ IMAGE_2D
2D image (grayscale or single channel)
std::string_view modality_to_string(DataModality modality)
Convert DataModality enum to string representation.
Definition NDData.cpp:83
static DataDimension spatial(uint64_t size, char axis, uint64_t stride=1, std::string name="spatial")
Convenience constructor for a spatial dimension.
Definition NDData.cpp:32
static DataDimension frequency(uint64_t bins, std::string name="frequency")
Convenience constructor for a frequency dimension.
Definition NDData.cpp:27
static DataDimension time(uint64_t samples, std::string name="time")
Convenience constructor for a temporal (time) dimension.
Definition NDData.cpp:17
static std::vector< uint64_t > calculate_strides(const std::vector< uint64_t > &shape, MemoryLayout layout)
Calculate memory strides based on shape and layout.
Definition NDData.cpp:229
static DataDimension channel(uint64_t count, uint64_t stride=1)
Convenience constructor for a channel dimension.
Definition NDData.cpp:22

References MayaFlux::Kakshya::AUDIO_1D, MayaFlux::Kakshya::AUDIO_MULTICHANNEL, calculate_strides(), channel(), frequency(), MayaFlux::Kakshya::IMAGE_2D, MayaFlux::Kakshya::IMAGE_COLOR, MayaFlux::Journal::Kakshya, MayaFlux::Kakshya::modality_to_string(), MayaFlux::Journal::Runtime, spatial(), MayaFlux::Kakshya::SPECTRAL_2D, time(), MayaFlux::Kakshya::VIDEO_COLOR, MayaFlux::Kakshya::VIDEO_GRAYSCALE, and MayaFlux::Kakshya::VOLUMETRIC_3D.

Referenced by MayaFlux::Yantra::infer_from_region(), MayaFlux::Yantra::infer_from_region_group(), MayaFlux::Kakshya::SoundStreamContainer::setup_dimensions(), MayaFlux::Kakshya::VideoStreamContainer::setup_dimensions(), and MayaFlux::Kakshya::WindowContainer::setup_dimensions().

+ Here is the call graph for this function:
+ Here is the caller graph for this function: