diff options
author | FreeArtMan <dos21h@gmail.com> | 2015-10-22 21:08:08 +0100 |
---|---|---|
committer | FreeArtMan <dos21h@gmail.com> | 2015-10-22 21:08:08 +0100 |
commit | 802b7e84fdaeb496a640bf001289fcb7d5a29040 (patch) | |
tree | e9de75278e491ab44823c65c6f4007cdea96e3fb /test/sdr_fm.c | |
parent | 4a1b311c007ab30ab6911474d41e0d2b5d42adad (diff) | |
download | radiola-802b7e84fdaeb496a640bf001289fcb7d5a29040.tar.gz radiola-802b7e84fdaeb496a640bf001289fcb7d5a29040.zip |
sdr_fm added filter from mini_fm, sound delay problems
Diffstat (limited to 'test/sdr_fm.c')
-rw-r--r-- | test/sdr_fm.c | 65 |
1 files changed, 60 insertions, 5 deletions
diff --git a/test/sdr_fm.c b/test/sdr_fm.c index 97c3a4a..24c69d0 100644 --- a/test/sdr_fm.c +++ b/test/sdr_fm.c @@ -13,7 +13,7 @@ #define RESAMPLE_RATE 50000 #define CENTER_FREQ 101100000 -#define FFT_LEVEL 12 +#define FFT_LEVEL 18 #define FFT_SIZE (1 << FFT_LEVEL) #define SAMPLE_LENGHT (2 * FFT_SIZE) #define PRESCALE 8 @@ -191,6 +191,57 @@ float ph_ch( uint8_t i1, uint8_t q1 ) return out; } +//delay filtering +void delay_filt( uint8_t *buf, int buf_len ) +{ + //delay length + const int n=10; + + int i=0; + uint32_t cycle=0; + uint32_t avg_i=0, avg_q=0; + uint32_t cyc_buffer_i[n],delay_i=0; + uint32_t cyc_buffer_q[n],delay_q=0; + uint8_t in1=0,in2=0,out1=0,out2=0; + + memset( cyc_buffer_i, 0, n*sizeof(uint32_t) ); + memset( cyc_buffer_q, 0, n*sizeof(uint32_t) ); + + //for (i=0; i<(buf_len-(n*2));i+=2) + for (i=0 ; i<(buf_len-1) ; i+=2 ) + //for (i=0; i<1000; i+=2) + { + in1 = buf[i]; + in2 = buf[i+1]; + + //average + avg_i += (uint32_t)in1; + avg_q += (uint32_t)in2; + + delay_i = cyc_buffer_i[cycle]; + delay_q = cyc_buffer_q[cycle]; + + cyc_buffer_i[cycle] = avg_i; + cyc_buffer_q[cycle] = avg_q; + cycle = cycle + 1; + //cycle += 1; + if ( cycle >= n ) + { + cycle = 0; + } + + out1 = (avg_i - delay_i)/n; + out2 = (avg_q - delay_q)/n; + + buf[i] = out1; + buf[i+1] = out2; + + //printf("%d,avg=[%d,%d],delay=[%d,%d],in=[%d,%d],out=[%d,%d]\n", + // cycle, avg_i,avg_q,delay_i,delay_q,in1,in2,out1,out2); + + } +} + int main( int argc, char **argv ) { @@ -279,7 +330,10 @@ int main( int argc, char **argv ) //{ // fbuf[i] = to_float(sample_buf[i]); //} - //delay + //delay boxed filter + delay_filt( sample_buf, sample_len ); + + //rotate by 90 degrees uint8_t //rotate_90( sample_buf, sample_len ); @@ -319,10 +373,11 @@ int main( int argc, char **argv ) //sound_buf[m] = (signed short)(10000.0f*(sum/20.0)); sound_buf[m] = (signed short)(10000.0f*(sum/20.0)); } - write(1, sound_buf, ((SAMPLE_LENGHT/20)*sizeof(signed short))); - - //play + + //write to play + write(1, sound_buf, ((SAMPLE_LENGHT/20)*sizeof(signed short))); + //exit(0); //usleep(1); //printf("Sample\n"); } |