src/pitchyin.c
authorPaul Brossier <piem@altern.org>
Tue, 30 Nov 2004 22:28:53 +0000 (22:28 +0000)
committerPaul Brossier <piem@altern.org>
Tue, 30 Nov 2004 22:28:53 +0000 (22:28 +0000)
ChangeLog
src/pitchyin.c

index 2f6128cd239d920b97ebf7777afc2d3b55e0eefb..2f8b495703e702b4d50e92f72d5e2d9deedcafed 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,7 @@
 2004-11-39  Paul Brossier <piem@altern.org>
        * configure.ac: added -lmx on macosx
+       * python/aubiocut: seeks for local minima before peak
+       * src/pitchyinc.c: adds draft for all-in-one faster function
 
 2004-10-28  Paul Brossier <piem@altern.org>
        * src/Makefile.am: added config.h installation
index e9abde26af2cada2508fc17c7dcd96abbddfdfe5..61f425d38ffb46c9bb5d05b6388e80fa02d328ef 100644 (file)
@@ -86,3 +86,44 @@ uint_t aubio_pitchyin_getpitch(fvec_t * yin) {
        return 0;
 }
 
+
+/* all the above in one */
+void aubio_pitchyin_getpitchfast(fvec_t * input, fvec_t * yin){
+       uint_t c,j,tau;
+       smpl_t tmp, tmp2;
+       for (c=0;c<input->channels;c++)
+       {
+               for (tau=0;tau<yin->length;tau++)
+               {
+                       yin->data[c][tau] = 0.;
+               }
+               for (tau=1;tau<yin->length;tau++)
+               {
+                       for (j=0;j<yin->length;j++)
+                       {
+                               tmp = input->data[c][j] - input->data[c][j+tau];
+                               yin->data[c][tau] += SQR(tmp);
+                       }
+               }
+               tmp2 = 0.;
+               yin->data[c][0] = 1.;
+               for (tau=1;tau<yin->length;tau++)
+               {
+                       tmp += yin->data[c][tau];
+                       yin->data[c][tau] *= tau/tmp;
+               }
+       }
+       /* should merge the following with above */
+       do 
+       {
+               if(yin->data[c][tau] < 0.1) { 
+                       while (yin->data[c][tau+1] < yin->data[c][tau]) {
+                               tau++;
+                       }
+                       return tau;
+               }
+               tau++;
+       } while (tau<yin->length);
+       return 0;
+}
+