Get data for a specific region.
85{
87
89 if (spans.empty())
90 return {};
91
92 std::span<const double> const_span(spans[0].data(), spans[0].size());
95 }
96
97 auto const_spans = spans | std::views::transform([](const auto& span) {
98 return std::span<const double>(span.data(), span.size());
99 });
100
101 auto extracted_channels = extract_region_data<double>(
102 std::vector<std::span<const double>>(const_spans.begin(), const_spans.end()),
104
105 return extracted_channels
106 | std::views::transform([](auto&& channel) {
107 return DataVariant(std::forward<
decltype(channel)>(channel));
108 })
109 | std::ranges::to<std::vector>();
110}
const std::vector< std::span< double > > & get_span_cache() const
Get the cached spans for each channel, recomputing if dirty.
ContainerDataStructure m_structure
std::variant< std::vector< double >, std::vector< float >, std::vector< uint8_t >, std::vector< uint16_t >, std::vector< uint32_t >, std::vector< std::complex< float > >, std::vector< std::complex< double > >, std::vector< glm::vec2 >, std::vector< glm::vec3 >, std::vector< glm::vec4 >, std::vector< glm::mat4 > > DataVariant
Multi-type data storage for different precision needs.
@ INTERLEAVED
Single DataVariant with interleaved data (LRLRLR for stereo)
std::vector< DataDimension > dimensions
OrganizationStrategy organization