aboutsummaryrefslogtreecommitdiffstats
path: root/templates/2_convolve_overlap_save.cpp
diff options
context:
space:
mode:
authorClyne <clyne@bitgloo.com>2022-05-24 17:38:05 -0400
committerClyne <clyne@bitgloo.com>2022-05-24 17:38:05 -0400
commit5902a67796000c7546d07fa778b26619c4588c3a (patch)
tree1c1fa04635a3c248d07fde4dce8857885ca23952 /templates/2_convolve_overlap_save.cpp
parent1cf4908a23dc5537be0bab1089ffcaa7079d5434 (diff)
parentdff847ff4455e7b8c5123167a7d01afe7c45f585 (diff)
Merge pull request 'devel: Ready for pre-release' (#1) from devel into masterv0.1
Reviewed-on: https://code.bitgloo.com/clyne/stmdspgui/pulls/1
Diffstat (limited to 'templates/2_convolve_overlap_save.cpp')
-rw-r--r--templates/2_convolve_overlap_save.cpp47
1 files changed, 0 insertions, 47 deletions
diff --git a/templates/2_convolve_overlap_save.cpp b/templates/2_convolve_overlap_save.cpp
deleted file mode 100644
index 57c020a..0000000
--- a/templates/2_convolve_overlap_save.cpp
+++ /dev/null
@@ -1,47 +0,0 @@
-/**
- * 2_convolve_overlap_save.cpp
- * Written by Clyne Sullivan.
- *
- * This convolution examples takes an overlap-save approach, where samples from the previous run
- * are saved so that the overall operation is not interrupted (i.e. the observed output will
- * transition smoothly between processed "chunks").
- *
- * Note that there are still improvements that can be made to the code; for example, notice every
- * spot where an integer/float conversion is necessary. Operations like these may slow down the
- * computation.
- */
-
-Sample *process_data(Samples samples)
-{
- static Sample buffer[samples.size()];
-
- constexpr unsigned int filter_size = 3;
- float filter[filter_size] = {
- 0.3333, 0.3333, 0.3333
- };
-
- // Keep a buffer of extra samples for overlap-save
- static Sample prev[filter_size];
-
- for (int n = 0; n < samples.size(); n++) {
- buffer[n] = 0;
-
- for (int k = 0; k < filter_size; k++) {
- int i = n - (filter_size - 1) + k;
-
- // If i is >= 0, access current sample buffer.
- // If i is < 0, provide the previous samples from the 'prev' buffer
- if (i >= 0)
- buffer[n] += samples[i] * filter[k];
- else
- buffer[n] += prev[filter_size - 1 + i] * filter[k];
- }
- }
-
- // Save samples for the next convolution run
- for (int i = 0; i < filter_size; i++)
- prev[i] = samples[samples.size() - filter_size + i];
-
- return buffer;
-}
-