source: swig/aubio.i @ 40acfbc

feature/autosinkfeature/cnnfeature/cnn_orgfeature/constantqfeature/crepefeature/crepe_orgfeature/pitchshiftfeature/pydocstringsfeature/timestretchfix/ffmpeg5pitchshiftsamplertimestretchyinfft+
Last change on this file since 40acfbc was b01bd4a, checked in by Paul Brossier <piem@piem.org>, 15 years ago

src/temporal: derive biquad from filter, use in peakpicker

  • Property mode set to 100644
File size: 10.8 KB
RevLine 
[96fb8ad]1%module aubiowrapper
2
3%{
4#include "aubio.h"
[740f06b]5%}
[96fb8ad]6
7/* type aliases */
8typedef unsigned int uint_t;
9typedef int sint_t;
10typedef float smpl_t;
11
12/* fvec */
[e5f49af]13fvec_t * new_fvec(uint_t length, uint_t channels);
14void del_fvec(fvec_t *s);
[96fb8ad]15smpl_t fvec_read_sample(fvec_t *s, uint_t channel, uint_t position);
16void fvec_write_sample(fvec_t *s, smpl_t data, uint_t channel, uint_t position);
17smpl_t * fvec_get_channel(fvec_t *s, uint_t channel);
18void fvec_put_channel(fvec_t *s, smpl_t * data, uint_t channel);
19smpl_t ** fvec_get_data(fvec_t *s);
20
21/* another way, passing -c++ option to swig */
22/*
23class fvec_t{
24public:
25    %extend {
26        fvec_t(uint_t length, uint_t channels){
27            return new_fvec(length, channels);
28        }
29        ~fvec_t() {
30            del_fvec(self);
31        }
32        smpl_t get( uint_t channel, uint_t position) {
33            return fvec_read_sample(self,channel,position);
34        }
35        void set( smpl_t data, uint_t channel, uint_t position) {
36            fvec_write_sample(self, data, channel, position);
37        }
38        #smpl_t * fvec_get_channel(fvec_t *s, uint_t channel);
39        #void fvec_put_channel(fvec_t *s, smpl_t * data, uint_t channel);
40    }
41};
42*/
43
44/* cvec */
[e5f49af]45cvec_t * new_cvec(uint_t length, uint_t channels);
46void del_cvec(cvec_t *s);
47void cvec_write_norm(cvec_t *s, smpl_t data, uint_t channel, uint_t position);
48void cvec_write_phas(cvec_t *s, smpl_t data, uint_t channel, uint_t position);
49smpl_t cvec_read_norm(cvec_t *s, uint_t channel, uint_t position);
50smpl_t cvec_read_phas(cvec_t *s, uint_t channel, uint_t position);
51void cvec_put_norm_channel(cvec_t *s, smpl_t * data, uint_t channel);
52void cvec_put_phas_channel(cvec_t *s, smpl_t * data, uint_t channel);
53smpl_t * cvec_get_norm_channel(cvec_t *s, uint_t channel);
54smpl_t * cvec_get_phas_channel(cvec_t *s, uint_t channel);
55smpl_t ** cvec_get_norm(cvec_t *s);
56smpl_t ** cvec_get_phas(cvec_t *s);
[96fb8ad]57
58
59/* fft */
[e5f49af]60aubio_fft_t * new_aubio_fft(uint_t size, uint_t channels);
61void del_aubio_fft(aubio_fft_t * s);
62void aubio_fft_do (aubio_fft_t *s, fvec_t * input, cvec_t * spectrum);
63void aubio_fft_rdo (aubio_fft_t *s, cvec_t * spectrum, fvec_t * output);
64void aubio_fft_do_complex (aubio_fft_t *s, fvec_t * input, fvec_t * compspec);
65void aubio_fft_rdo_complex (aubio_fft_t *s, fvec_t * compspec, fvec_t * output);
66void aubio_fft_get_spectrum(fvec_t * compspec, cvec_t * spectrum);
67void aubio_fft_get_realimag(cvec_t * spectrum, fvec_t * compspec);
68void aubio_fft_get_phas(fvec_t * compspec, cvec_t * spectrum);
69void aubio_fft_get_imag(cvec_t * spectrum, fvec_t * compspec);
70void aubio_fft_get_norm(fvec_t * compspec, cvec_t * spectrum);
71void aubio_fft_get_real(cvec_t * spectrum, fvec_t * compspec);
[ec10780]72
[96fb8ad]73/* filter */
[59c046d]74aubio_filter_t * new_aubio_filter(uint_t order, uint_t channels);
[e5f49af]75void aubio_filter_do(aubio_filter_t * b, fvec_t * in);
76void aubio_filter_do_outplace(aubio_filter_t * b, fvec_t * in, fvec_t * out);
77void aubio_filter_do_filtfilt(aubio_filter_t * b, fvec_t * in, fvec_t * tmp);
78void del_aubio_filter(aubio_filter_t * b);
[4123f16]79
[59c046d]80aubio_filter_t * new_aubio_filter_a_weighting (uint_t channels, uint_t samplerate);
81uint_t aubio_filter_set_a_weighting (aubio_filter_t * b, uint_t samplerate);
[4123f16]82
[59c046d]83aubio_filter_t * new_aubio_filter_c_weighting (uint_t channels, uint_t samplerate);
84uint_t aubio_filter_set_c_weighting (aubio_filter_t * b, uint_t samplerate);
[96fb8ad]85
86/* biquad */
[b01bd4a]87aubio_filter_t * new_aubio_filter_biquad(lsmp_t b1, lsmp_t b2, lsmp_t b3, lsmp_t a2, lsmp_t a3, uint_t channels);
88uint_t aubio_filter_set_biquad (aubio_filter_t * b, lsmp_t b1, lsmp_t b2, lsmp_t b3, lsmp_t a2, lsmp_t a3);
[96fb8ad]89
90/* hist */
[e5f49af]91aubio_hist_t * new_aubio_hist(smpl_t flow, smpl_t fhig, uint_t nelems, uint_t channels);
92void del_aubio_hist(aubio_hist_t *s);
93void aubio_hist_do(aubio_hist_t *s, fvec_t * input);
94void aubio_hist_do_notnull(aubio_hist_t *s, fvec_t * input);
95void aubio_hist_dyn_notnull(aubio_hist_t *s, fvec_t *input);
96void aubio_hist_weight(aubio_hist_t *s);
97smpl_t aubio_hist_mean(aubio_hist_t *s);
[96fb8ad]98
99/* mathutils */
[74516f7]100fvec_t * new_aubio_window(char * wintype, uint_t size);
[28d8c4a]101smpl_t aubio_unwrap2pi (smpl_t phase);
[8b28524]102smpl_t fvec_mean(fvec_t *s);
[1e2c82f]103smpl_t fvec_max(fvec_t *s);
[2f64b0e]104smpl_t fvec_min(fvec_t *s);
105uint_t fvec_min_elem(fvec_t *s);
[1e2c82f]106uint_t fvec_max_elem(fvec_t *s);
[5c4ec3c]107void fvec_shift(fvec_t *s);
108smpl_t fvec_sum(fvec_t *s);
109smpl_t fvec_local_energy(fvec_t * f);
110smpl_t fvec_local_hfc(fvec_t * f);
111smpl_t fvec_alpha_norm(fvec_t * DF, smpl_t alpha);
[c0b295c]112void fvec_min_removal(fvec_t * mag);
[5c4ec3c]113void fvec_alpha_normalise(fvec_t * mag, uint_t alpha);
114void fvec_add(fvec_t * mag, smpl_t threshold);
[e5f49af]115void fvec_adapt_thres(fvec_t * vec, fvec_t * tmp, uint_t post, uint_t pre, uint_t channel);
116smpl_t fvec_moving_thres(fvec_t * vec, fvec_t * tmp, uint_t post, uint_t pre, uint_t pos, uint_t channel);
117smpl_t fvec_median_channel (fvec_t * input, uint_t channel);
[5c4ec3c]118smpl_t fvec_quadint(fvec_t * x,uint_t pos, uint_t span);
[28d8c4a]119smpl_t aubio_quadfrac(smpl_t s0, smpl_t s1, smpl_t s2, smpl_t pf);
[5c4ec3c]120uint_t fvec_peakpick(fvec_t * input, uint_t pos);
[28d8c4a]121smpl_t aubio_bintomidi(smpl_t bin, smpl_t samplerate, smpl_t fftsize);
[79c2e52]122smpl_t aubio_miditobin(smpl_t midi, smpl_t samplerate, smpl_t fftsize);
[28d8c4a]123smpl_t aubio_bintofreq(smpl_t bin, smpl_t samplerate, smpl_t fftsize);
[79c2e52]124smpl_t aubio_freqtobin(smpl_t freq, smpl_t samplerate, smpl_t fftsize);
[28d8c4a]125smpl_t aubio_freqtomidi(smpl_t freq);
[79c2e52]126smpl_t aubio_miditofreq(smpl_t midi);
[96fb8ad]127uint_t aubio_silence_detection(fvec_t * ibuf, smpl_t threshold);
128smpl_t aubio_level_detection(fvec_t * ibuf, smpl_t threshold);
[fe4f78a]129void aubio_autocorr(fvec_t * in, fvec_t * acf);
[5507e9d]130smpl_t aubio_zero_crossing_rate(fvec_t * input);
[c8b80cd]131smpl_t aubio_spectral_centroid(cvec_t * spectrum, smpl_t samplerate);
[96fb8ad]132
[bc4ba75]133/* filterbank */
[dc73a4d0]134aubio_filterbank_t * new_aubio_filterbank(uint_t win_s, uint_t channels);
[59c046d]135void aubio_filterbank_set_triangle_bands (aubio_filterbank_t *fb, fvec_t *freqs, uint_t samplerate);
[1e37ade]136void aubio_filterbank_set_mel_coeffs_slaney(aubio_filterbank_t *fb, uint_t samplerate);
[dc73a4d0]137void del_aubio_filterbank(aubio_filterbank_t * fb);
138void aubio_filterbank_do(aubio_filterbank_t * fb, cvec_t * in, fvec_t *out);
[06cae6c]139fvec_t * aubio_filterbank_get_coeffs(aubio_filterbank_t * fb);
[bc4ba75]140
141/* mfcc */
[adcf405]142aubio_mfcc_t * new_aubio_mfcc (uint_t win_s, uint_t samplerate, uint_t n_filters, uint_t n_coefs);
[bc4ba75]143void del_aubio_mfcc(aubio_mfcc_t *mf);
144void aubio_mfcc_do(aubio_mfcc_t *mf, cvec_t *in, fvec_t *out);
145
[96fb8ad]146/* scale */
[e5f49af]147aubio_scale_t * new_aubio_scale(smpl_t flow, smpl_t fhig, smpl_t ilow, smpl_t ihig);
148uint_t aubio_scale_set_limits (aubio_scale_t *s, smpl_t ilow, smpl_t ihig, smpl_t olow, smpl_t ohig);
149void aubio_scale_do(aubio_scale_t *s, fvec_t * input);
150void del_aubio_scale(aubio_scale_t *s);
[96fb8ad]151
152/* resampling */
[740f06b]153#if HAVE_SAMPLERATE
[e5f49af]154aubio_resampler_t * new_aubio_resampler(float ratio, uint_t type);
155void aubio_resampler_do (aubio_resampler_t *s, fvec_t * input,  fvec_t * output);
156void del_aubio_resampler(aubio_resampler_t *s);
[740f06b]157#endif /* HAVE_SAMPLERATE */
[96fb8ad]158
159/* onset detection */
[b4f5967]160aubio_onsetdetection_t * new_aubio_onsetdetection(char * onset_mode, uint_t size, uint_t channels);
[01b8fcc]161void aubio_onsetdetection_do (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset);
[2a00568]162void del_aubio_onsetdetection(aubio_onsetdetection_t *o);
[96fb8ad]163
164/* pvoc */
165aubio_pvoc_t * new_aubio_pvoc (uint_t win_s, uint_t hop_s, uint_t channels);
166void del_aubio_pvoc(aubio_pvoc_t *pv);
167void aubio_pvoc_do(aubio_pvoc_t *pv, fvec_t *in, cvec_t * fftgrain);
168void aubio_pvoc_rdo(aubio_pvoc_t *pv, cvec_t * fftgrain, fvec_t *out);
169
170/* pitch detection */
[ca1abdd]171aubio_pitch_t *new_aubio_pitch (char *pitch_mode,
[fe163ad]172    uint_t bufsize, uint_t hopsize, uint_t channels, uint_t samplerate);
[ca1abdd]173void aubio_pitch_do (aubio_pitch_t * p, fvec_t * ibuf, fvec_t * obuf);
174uint_t aubio_pitch_set_tolerance(aubio_pitch_t *p, smpl_t thres);
175uint_t aubio_pitch_set_unit(aubio_pitch_t *p, char * pitch_unit);
176void del_aubio_pitch(aubio_pitch_t * p);
[8e8bc50]177
[96fb8ad]178/* pitch mcomb */
[05773a2c]179aubio_pitchmcomb_t * new_aubio_pitchmcomb(uint_t bufsize, uint_t hopsize, uint_t channels);
180void aubio_pitchmcomb_do (aubio_pitchmcomb_t * p, cvec_t * fftgrain, fvec_t * out);
[7a04950]181void del_aubio_pitchmcomb (aubio_pitchmcomb_t *p);
[96fb8ad]182
183/* pitch yin */
[05773a2c]184aubio_pitchyin_t * new_aubio_pitchyin(uint_t bufsize);
185void aubio_pitchyin_do (aubio_pitchyin_t *o, fvec_t * in, fvec_t *out);
186void del_aubio_pitchyin (aubio_pitchyin_t *p);
[96fb8ad]187
[7a04950]188/* pitch schmitt */
[05773a2c]189aubio_pitchschmitt_t * new_aubio_pitchschmitt (uint_t size);
190void aubio_pitchschmitt_do (aubio_pitchschmitt_t *p, fvec_t * input, fvec_t *out);
[7a04950]191void del_aubio_pitchschmitt (aubio_pitchschmitt_t *p);
192
193/* pitch fcomb */
[4afa096d]194aubio_pitchfcomb_t * new_aubio_pitchfcomb (uint_t size, uint_t hopsize, uint_t samplerate);
[05773a2c]195void aubio_pitchfcomb_do (aubio_pitchfcomb_t *p, fvec_t * input, fvec_t *out);
[7a04950]196void del_aubio_pitchfcomb (aubio_pitchfcomb_t *p);
197
[96fb8ad]198/* peakpicker */
[e5f49af]199aubio_peakpicker_t * new_aubio_peakpicker(uint_t channels);
200void aubio_peakpicker_do(aubio_peakpicker_t * p, fvec_t * df, fvec_t * out);
[8766cb6]201smpl_t aubio_peakpicker_get_thresholded_input(aubio_peakpicker_t* p);
202void del_aubio_peakpicker(aubio_peakpicker_t * p);
[740f06b]203uint_t aubio_peakpicker_set_threshold(aubio_peakpicker_t * p, smpl_t threshold);
[8766cb6]204smpl_t aubio_peakpicker_get_threshold(aubio_peakpicker_t * p);
[96fb8ad]205
206/* transient/steady state separation */
[740f06b]207aubio_tss_t *new_aubio_tss (uint_t win_s, uint_t hop_s, uint_t channels);
208void del_aubio_tss (aubio_tss_t * s);
209void aubio_tss_do (aubio_tss_t * s, cvec_t * input, cvec_t * trans,
210    cvec_t * stead);
211uint_t aubio_tss_set_threshold (aubio_tss_t * o, smpl_t thrs);
212uint_t aubio_tss_set_alpha (aubio_tss_t * o, smpl_t alpha);
213uint_t aubio_tss_set_beta (aubio_tss_t * o, smpl_t beta);
[96fb8ad]214
[de92b1c]215/* beattracking */
216aubio_beattracking_t * new_aubio_beattracking(uint_t winlen, uint_t channels);
217void aubio_beattracking_do(aubio_beattracking_t * bt, fvec_t * dfframes, fvec_t * out);
218void del_aubio_beattracking(aubio_beattracking_t * p);
[e34b010]219smpl_t aubio_beattracking_get_bpm(aubio_beattracking_t * p);
220smpl_t aubio_beattracking_get_confidence(aubio_beattracking_t * p);
[de92b1c]221
[740f06b]222/* tempo */
223typedef struct _aubio_tempo_t aubio_tempo_t;
224aubio_tempo_t * new_aubio_tempo (char_t * mode,
225    uint_t buf_size, uint_t hop_size, uint_t channels, uint_t samplerate);
226void aubio_tempo_do (aubio_tempo_t *o, fvec_t * input, fvec_t * tempo);
227uint_t aubio_tempo_set_silence(aubio_tempo_t * o, smpl_t silence);
228uint_t aubio_tempo_set_threshold(aubio_tempo_t * o, smpl_t threshold);
229smpl_t aubio_tempo_get_bpm(aubio_tempo_t * bt);
230smpl_t aubio_tempo_get_confidence(aubio_tempo_t * bt);
231void del_aubio_tempo(aubio_tempo_t * o);
232
233/* sndfile */
234%{
235#if HAVE_SNDFILE
236#include "sndfileio.h"
237%}
[e5f49af]238aubio_sndfile_t * new_aubio_sndfile_ro (const char * inputfile);
239aubio_sndfile_t * new_aubio_sndfile_wo(aubio_sndfile_t * existingfile, const char * outputname);
240void aubio_sndfile_info(aubio_sndfile_t * file);
241int aubio_sndfile_write(aubio_sndfile_t * file, int frames, fvec_t * write);
242int aubio_sndfile_read(aubio_sndfile_t * file, int frames, fvec_t * read);
243int del_aubio_sndfile(aubio_sndfile_t * file);
244uint_t aubio_sndfile_channels(aubio_sndfile_t * file);
245uint_t aubio_sndfile_samplerate(aubio_sndfile_t * file);
[740f06b]246%{
247#endif /* HAVE_SNDFILE */
248%}
Note: See TracBrowser for help on using the repository browser.