#include <stdio.h>
#endif
+/* must be included before fftw3.h */
#if HAVE_COMPLEX_H
#include <complex.h>
#endif
-/*
-#include <complex.h>
-#include <fftw3.h>
-#define FFTW_TYPE fftwf_complex
-*/
+
#if HAVE_FFTW3_H
#include <fftw3.h>
-//#define FFTW_TYPE fftwf_complex
#endif
#if HAVE_MATH_H
#include <string.h>
#endif
-#ifdef ALSA_SUPPORT
-#ifdef LADCCA_SUPPORT
-#include <ladcca/ladcca.h>
-extern cca_client_t * aubio_cca_client;
-#endif /* LADCCA_SUPPORT */
-#endif /* ALSA_SUPPORT */
-
-
#include "types.h"
/****
#define AUBIO_NEW(_t) (_t*)malloc(sizeof(_t))
#define AUBIO_ARRAY(_t,_n) (_t*)malloc((_n)*sizeof(_t))
#define AUBIO_MEMCPY(_dst,_src,_n) memcpy(_dst,_src,_n)
-#define AUBIO_MEMSET(_dst,_src,_t) memset(_dst,_src,sizeof(_t))
+#define AUBIO_MEMSET(_dst,_src,_t) memset(_dst,_src,_t)
#define AUBIO_FREE(_p) free(_p)
AUBIO_FAIL = -1
} aubio_status;
-#define AUBIO_ERR(...) fprintf(stderr,__VA_ARGS__)
-#define AUBIO_MSG(...) fprintf(stdout,__VA_ARGS__)
-#define AUBIO_DBG(...) fprintf(stderr,__VA_ARGS__)
-#define AUBIO_QUIT(_s) exit(_s)
-#define AUBIO_SPRINTF sprintf
+#ifdef HAVE_C99_VARARGS_MACROS
+#define AUBIO_ERR(...) fprintf(stderr,__VA_ARGS__)
+#define AUBIO_MSG(...) fprintf(stdout,__VA_ARGS__)
+#define AUBIO_DBG(...) fprintf(stderr,__VA_ARGS__)
+#else
+#define AUBIO_ERR(format, args...) fprintf(stderr, format , ##args)
+#define AUBIO_MSG(format, args...) fprintf(stdout, format , ##args)
+#define AUBIO_DBG(format, args...) fprintf(stderr, format , ##args)
+#endif
+
+#define AUBIO_QUIT(_s) exit(_s)
+#define AUBIO_SPRINTF sprintf
+
+/* Libc shortcuts */
+#define PI (M_PI)
+#define TWO_PI (PI*2.)
+
+/* aliases to math.h functions */
+#define EXP expf
+#define COS cosf
+#define SIN sinf
+#define ABS fabsf
+#define POW powf
+#define SQRT sqrtf
+#define LOG10 log10f
+#define LOG logf
+#define FLOOR floorf
+#define TRUNC truncf
+
+/* aliases to complex.h functions */
+#if !defined(HAVE_COMPLEX_H) || defined(WIN32)
+/* mingw32 does not know about c*f functions */
+#define EXPC cexp
+/** complex = CEXPC(complex) */
+#define CEXPC cexp
+/** sample = ARGC(complex) */
+#define ARGC carg
+/** sample = ABSC(complex) norm */
+#define ABSC cabs
+/** sample = REAL(complex) */
+#define REAL creal
+/** sample = IMAG(complex) */
+#define IMAG cimag
+#else
+/** sample = EXPC(complex) */
+#define EXPC cexpf
+/** complex = CEXPC(complex) */
+#define CEXPC cexp
+/** sample = ARGC(complex) */
+#define ARGC cargf
+/** sample = ABSC(complex) norm */
+#define ABSC cabsf
+/** sample = REAL(complex) */
+#define REAL crealf
+/** sample = IMAG(complex) */
+#define IMAG cimagf
+#endif
+
+/* handy shortcuts */
+#define DB2LIN(g) (POW(10.0f,(g)*0.05f))
+#define LIN2DB(v) (20.0f*LOG10(v))
+#define SQR(_a) (_a*_a)
+
+#define ELEM_SWAP(a,b) { register smpl_t t=(a);(a)=(b);(b)=t; }
#endif/*_AUBIO_PRIV_H*/