summaryrefslogtreecommitdiff
path: root/util
diff options
context:
space:
mode:
Diffstat (limited to 'util')
-rw-r--r--util/spkmodem_recv/spkmodem-recv.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/util/spkmodem_recv/spkmodem-recv.c b/util/spkmodem_recv/spkmodem-recv.c
index eaf80717..f2b5e78d 100644
--- a/util/spkmodem_recv/spkmodem-recv.c
+++ b/util/spkmodem_recv/spkmodem-recv.c
@@ -186,15 +186,22 @@ decode_pulse(struct decoder_state *st)
ringpos = st->ringpos;
sep_pos = st->sep_pos;
+ /*
+ * Moving sum of the last N
+ * pulses; O(1) per sample.
+ */
old_ring = st->pulse[ringpos];
old_sep = st->pulse[sep_pos];
-
st->freq_data -= old_ring;
st->freq_data += old_sep;
st->freq_separator -= old_sep;
sample = read_sample(st);
+ /*
+ * Noise suppression, with a frequency
+ * tolerancy defined by THRESHOLD.
+ */
if ((unsigned)(sample + THRESHOLD)
> (unsigned)(2 * THRESHOLD))
new_pulse = 1;