X-Git-Url: https://git.sesse.net/?p=c64tapwav;a=blobdiff_plain;f=decode.cpp;h=3662566737d4d4fc415a525d2071f9185ce0e8b0;hp=a90ae8e6944167dc6051fb69c1f7e3f3450d8f2e;hb=22be96e6cc5a38d73af6fc65bc8802b05cac8325;hpb=31b7a4c1f1b1a90c0598f67b9f859fc66c53debb diff --git a/decode.cpp b/decode.cpp index a90ae8e..3662566 100644 --- a/decode.cpp +++ b/decode.cpp @@ -7,6 +7,9 @@ #include #include #include +#ifdef __AVX__ +#include +#endif #include #include @@ -328,17 +331,30 @@ std::vector crop(const std::vector& pcm, float crop_start, float c return std::vector(pcm.begin() + start_sample, pcm.begin() + end_sample); } -// TODO: Support AVX here. std::vector do_fir_filter(const std::vector& pcm, const float* filter) { std::vector filtered_pcm; - filtered_pcm.reserve(pcm.size()); - for (unsigned i = NUM_FILTER_COEFF; i < pcm.size(); ++i) { + filtered_pcm.resize(pcm.size()); + unsigned i = NUM_FILTER_COEFF; +#ifdef __AVX__ + unsigned avx_end = i + ((pcm.size() - i) & ~7); + for ( ; i < avx_end; i += 8) { + __m256 s = _mm256_setzero_ps(); + for (int j = 0; j < NUM_FILTER_COEFF; ++j) { + __m256 f = _mm256_set1_ps(filter[j]); + s = _mm256_fmadd_ps(f, _mm256_load_ps(&pcm[i - j]), s); + } + _mm256_storeu_ps(&filtered_pcm[i], s); + } +#endif + // Do what we couldn't do with AVX (which is everything for non-AVX machines) + // as scalar code. + for (; i < pcm.size(); ++i) { float s = 0.0f; for (int j = 0; j < NUM_FILTER_COEFF; ++j) { s += filter[j] * pcm[i - j]; } - filtered_pcm.push_back(s); + filtered_pcm[i] = s; } if (output_filtered) { @@ -528,11 +544,11 @@ void spsa_train(const std::vector &pcm, int sample_rate) std::swap(pulses1, pulses2); } if (badness1 < best_badness) { - printf("\nNew best filter (badness=%f):", badness1); + fprintf(stderr, "\nNew best filter (badness=%f):", badness1); for (int i = 0; i < NUM_FILTER_COEFF; ++i) { - printf(" %.5f", vals1[i + 2]); + fprintf(stderr, " %.5f", vals1[i + 2]); } - printf(", hysteresis limits = %f %f\n", vals1[0], vals1[1]); + fprintf(stderr, ", hysteresis limits = %f %f\n", vals1[0], vals1[1]); best_badness = badness1; find_kmeans(pulses1, 1.0, train_snap_points); @@ -541,8 +557,8 @@ void spsa_train(const std::vector &pcm, int sample_rate) output_cycle_plot(pulses1, 1.0); } } - printf("%d ", n); - fflush(stdout); + fprintf(stderr, "%d ", n); + fflush(stderr); } }