From de1fcfbe5f21a7a4d6d264841acc112eb70f66dd Mon Sep 17 00:00:00 2001 From: gferraro Date: Thu, 24 Oct 2024 14:56:59 +0200 Subject: [PATCH 1/2] add noise correction --- src/pdmfilter.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/pdmfilter.rs b/src/pdmfilter.rs index 4555027..fb1ab17 100644 --- a/src/pdmfilter.rs +++ b/src/pdmfilter.rs @@ -40,6 +40,8 @@ impl PDMFilter { if lp_hz != 0.0 { self.lp_alpha = (lp_hz * 256.0 / (lp_hz + self.fs as f32 / (2.0 * PI))) as u32; } + + //high pass filter does not seem to be doing anything if hp_hz != 0.0 { self.hp_alpha = (self.fs as f32 * 256.0 / (2.0 * PI * hp_hz + self.fs as f32)) as u32; } @@ -55,13 +57,16 @@ impl PDMFilter { PDM_DECIMATION as usize, sinc_out.as_mut(), ); + + // https://s3.amazonaws.com/embeddedrelated/user/114298/lti%20filters_3552.pdf + //adding 0x00008000 to sum, to undo filter noise bias let sum = convolve( &sinc_out, PDM_DECIMATION as usize * 2 - 1, &sinc, PDM_DECIMATION as usize, sinc2[1..].as_mut(), - ); + ) + 0x00008000; self.sub_const = sum >> 1; self.div_const = self.sub_const * MAX_VOLUME as u32 / 32768 / FILTER_GAIN as u32; From f589a019cd37c9fd9cade7d35b672274812731cb Mon Sep 17 00:00:00 2001 From: gferraro Date: Thu, 24 Oct 2024 15:01:43 +0200 Subject: [PATCH 2/2] change gain --- src/pdmfilter.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pdmfilter.rs b/src/pdmfilter.rs index fb1ab17..a6b84aa 100644 --- a/src/pdmfilter.rs +++ b/src/pdmfilter.rs @@ -1,7 +1,7 @@ const PDM_DECIMATION: u8 = 64; const PI: f32 = 3.14159; const SINCN: u8 = 3; -const FILTER_GAIN: u8 = 64; +const FILTER_GAIN: u8 = 16; const MAX_VOLUME: u8 = 64; //this is ported from