Split single-channel data into overlapping windows.
904{
905 auto extractor = std::make_shared<Yantra::FeatureExtractor<>>(window_size, hop_size,
906 Yantra::ExtractionMethod::OVERLAPPING_WINDOWS);
907 extractor->set_parameter("overlap", double(hop_size) / window_size);
908
910 auto result = extractor->apply_operation(input);
911
912 auto extracted_data = result.
data[0];
913
914 std::vector<std::vector<double>> segments;
915 for (size_t i = 0; i < extracted_data.size(); i += window_size) {
916 size_t end_idx = std::min(i + window_size, extracted_data.size());
917 segments.emplace_back(extracted_data.begin() + i, extracted_data.begin() + end_idx);
918 }
919
920 return segments;
921}
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.
T data
The actual computation data.
Input/Output container for computation pipeline data flow with structure preservation.