aubio 0.4.9
spectral/test-filterbank.c
#include <aubio.h>
int main (void)
{
uint_t win_s = 1024; // window size
uint_t n_filters = 13; // number of filters
cvec_t *in_spec = new_cvec (win_s); // input vector of samples
fvec_t *out_filters = new_fvec (n_filters); // per-band outputs
if (new_aubio_filterbank(0, win_s)) return 1;
if (new_aubio_filterbank(n_filters, 0)) return 1;
// create filterbank object
aubio_filterbank_t *o = new_aubio_filterbank (n_filters, win_s);
if (aubio_filterbank_set_power(o, power)) {
return 1;
}
if (aubio_filterbank_set_norm(o, norm)) {
return 1;
}
// apply filterbank ten times
uint_t n = 10;
while (n) {
aubio_filterbank_do (o, in_spec, out_filters);
n--;
}
// print out filterbank coeffs
fmat_t *coeffs; // pointer to the coefficients
fmat_print (coeffs);
fmat_print (coeffs);
//fvec_print (out_filters);
// clean up
del_cvec (in_spec);
del_fvec (out_filters);
return 0;
}
Global aubio include file.
cvec_t * new_cvec(uint_t length)
cvec_t buffer creation function
void del_cvec(cvec_t *s)
cvec_t buffer deletion function
uint_t aubio_filterbank_set_power(aubio_filterbank_t *f, smpl_t power)
set power parameter
smpl_t aubio_filterbank_get_norm(aubio_filterbank_t *f)
get norm parameter
void del_aubio_filterbank(aubio_filterbank_t *f)
destroy filterbank object
uint_t aubio_filterbank_set_norm(aubio_filterbank_t *f, smpl_t norm)
set norm parameter
aubio_filterbank_t * new_aubio_filterbank(uint_t n_filters, uint_t win_s)
create filterbank object
fmat_t * aubio_filterbank_get_coeffs(const aubio_filterbank_t *f)
return a pointer to the matrix object containing all filter coefficients
struct _aubio_filterbank_t aubio_filterbank_t
filterbank object
Definition: filterbank.h:45
uint_t aubio_filterbank_set_coeffs(aubio_filterbank_t *f, const fmat_t *filters)
copy filter coefficients to the filterbank
void aubio_filterbank_do(aubio_filterbank_t *f, const cvec_t *in, fvec_t *out)
compute filterbank
smpl_t aubio_filterbank_get_power(aubio_filterbank_t *f)
get power parameter
void fmat_print(const fmat_t *s)
print out fmat data
fvec_t * new_fvec(uint_t length)
fvec_t buffer creation function
void del_fvec(fvec_t *s)
fvec_t buffer deletion function
void aubio_cleanup(void)
clean up cached memory at the end of program
Vector of real-valued phase and spectrum data.
Definition: cvec.h:63
Buffer for real data.
Definition: fmat.h:40
Buffer for real data.
Definition: fvec.h:67
unsigned int uint_t
unsigned integer
Definition: types.h:60
float smpl_t
short sample format (32 or 64 bits)
Definition: types.h:41