750{
752 return;
753 }
754
758 return;
759 }
760
764 return;
765 }
766
767 auto current_span = convert_variant<double>(
m_data[0]);
768 std::vector<double> current_data(current_span.begin(), current_span.end());
769
770 auto channels = deinterleave_channels<double>(
771 std::span<const double>(current_data.data(), current_data.size()),
773
774 std::vector<double> reorganized_data;
777 } else {
778 reorganized_data.reserve(current_data.size());
779 for (const auto& channel : channels) {
780 reorganized_data.insert(reorganized_data.end(), channel.begin(), channel.end());
781 }
782 }
783
785
788
791}
std::atomic< bool > m_double_extraction_dirty
std::vector< DataVariant > m_data
void invalidate_span_cache()
Invalidate the span cache when data or layout changes.
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.
@ ROW_MAJOR
C/C++ style (last dimension varies fastest)
@ PLANAR
Separate DataVariant per logical unit (LLL...RRR for stereo)
@ INTERLEAVED
Single DataVariant with interleaved data (LRLRLR for stereo)
std::vector< T > interleave_channels(const std::vector< std::vector< T > > &channels)
Interleave multiple channels of data into a single vector.
OrganizationStrategy organization
MemoryLayout memory_layout