shithub: aubio

Download patch

ref: ed1deac8ca3b75cdccddf62388f1f4164ecc1578
parent: 8f68dfbce6a384264ae9121a30aa359fc7c0fcd8
author: Paul Brossier <piem@piem.org>
date: Sat Mar 2 17:54:28 EST 2013

tests/src/temporal/: improve test examples

--- a/tests/src/temporal/test-biquad.c
+++ b/tests/src/temporal/test-biquad.c
@@ -1,15 +1,31 @@
 #include <aubio.h>
 
-int main(){
-        /* allocate some memory */
-        uint_t win_s      = 1024;                       /* window size */
-        fvec_t * in       = new_fvec (win_s); /* input buffer */
-        aubio_filter_t * o = new_aubio_filter_biquad(0.3,0.2,0.1,0.2,0.3);
+int main () {
+  uint_t win_s = 64; // window size
 
-        aubio_filter_do_filtfilt(o,in,in);
-        aubio_filter_do(o,in);
+  // create biquad filter with `b0`, `b1`, `b2`, `a1`, `a2`
+  aubio_filter_t * o = new_aubio_filter_biquad(0.3,0.2,0.1,0.2,0.3);
 
-        del_aubio_filter(o);
-        del_fvec(in);
-        return 0;
+  fvec_t * in_vec  = new_fvec (win_s); // input buffer
+  fvec_t * tmp_vec = new_fvec (win_s); // temporary buffer
+  fvec_t * out_vec = new_fvec (win_s); // output buffer
+
+  uint_t times = 100;
+  while ( times-- ) {
+    // copy to out, then filter out
+    aubio_filter_do_outplace(o, in_vec, out_vec);
+    // in-place filtering
+    aubio_filter_do(o, in_vec);
+    // in-place filtering
+    aubio_filter_do_filtfilt(o, in_vec, out_vec);
+    fvec_print(in_vec);
+  }
+
+  // memory clean-up, one for each new
+  del_aubio_filter(o);
+  del_fvec(in_vec);
+  del_fvec(tmp_vec);
+  del_fvec(out_vec);
+
+  return 0;
 }