source: swig/aubio.i @ 207ed19

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

src/mathutils.c: rename fvec_dc_removal to fvec_min_removal

  • Property mode set to 100644
File size: 12.4 KB
RevLine 
[96fb8ad]1%module aubiowrapper
2
3%{
4        #include "aubio.h"
[205da86]5        #include "aubioext.h"
[96fb8ad]6%}
7
8#include "aubio.h"
[205da86]9#include "aubioext.h"
[96fb8ad]10
11/* type aliases */
12typedef unsigned int uint_t;
13typedef int sint_t;
14typedef float smpl_t;
15
16/* fvec */
17extern fvec_t * new_fvec(uint_t length, uint_t channels);
18extern void del_fvec(fvec_t *s);
19smpl_t fvec_read_sample(fvec_t *s, uint_t channel, uint_t position);
20void fvec_write_sample(fvec_t *s, smpl_t data, uint_t channel, uint_t position);
21smpl_t * fvec_get_channel(fvec_t *s, uint_t channel);
22void fvec_put_channel(fvec_t *s, smpl_t * data, uint_t channel);
23smpl_t ** fvec_get_data(fvec_t *s);
24
25/* another way, passing -c++ option to swig */
26/*
27class fvec_t{
28public:
29    %extend {
30        fvec_t(uint_t length, uint_t channels){
31            return new_fvec(length, channels);
32        }
33        ~fvec_t() {
34            del_fvec(self);
35        }
36        smpl_t get( uint_t channel, uint_t position) {
37            return fvec_read_sample(self,channel,position);
38        }
39        void set( smpl_t data, uint_t channel, uint_t position) {
40            fvec_write_sample(self, data, channel, position);
41        }
42        #smpl_t * fvec_get_channel(fvec_t *s, uint_t channel);
43        #void fvec_put_channel(fvec_t *s, smpl_t * data, uint_t channel);
44    }
45};
46*/
47
48/* cvec */
49extern cvec_t * new_cvec(uint_t length, uint_t channels);
50extern void del_cvec(cvec_t *s);
[7c206df]51extern void cvec_write_norm(cvec_t *s, smpl_t data, uint_t channel, uint_t position);
52extern void cvec_write_phas(cvec_t *s, smpl_t data, uint_t channel, uint_t position);
53extern smpl_t cvec_read_norm(cvec_t *s, uint_t channel, uint_t position);
54extern smpl_t cvec_read_phas(cvec_t *s, uint_t channel, uint_t position);
55extern void cvec_put_norm_channel(cvec_t *s, smpl_t * data, uint_t channel);
56extern void cvec_put_phas_channel(cvec_t *s, smpl_t * data, uint_t channel);
57extern smpl_t * cvec_get_norm_channel(cvec_t *s, uint_t channel);
58extern smpl_t * cvec_get_phas_channel(cvec_t *s, uint_t channel);
59extern smpl_t ** cvec_get_norm(cvec_t *s);
60extern smpl_t ** cvec_get_phas(cvec_t *s);
[96fb8ad]61
62
63/* sndfile */
[9a91031]64#if HAVE_SNDFILE
[5e9c68a]65extern aubio_sndfile_t * new_aubio_sndfile_ro (const char * inputfile);
66extern aubio_sndfile_t * new_aubio_sndfile_wo(aubio_sndfile_t * existingfile, const char * outputname);
67extern void aubio_sndfile_info(aubio_sndfile_t * file);
68extern int aubio_sndfile_write(aubio_sndfile_t * file, int frames, fvec_t * write);
69extern int aubio_sndfile_read(aubio_sndfile_t * file, int frames, fvec_t * read);
70extern int del_aubio_sndfile(aubio_sndfile_t * file);
71extern uint_t aubio_sndfile_channels(aubio_sndfile_t * file);
72extern uint_t aubio_sndfile_samplerate(aubio_sndfile_t * file);
[9a91031]73#endif /* HAVE_SNDFILE */
[96fb8ad]74
75/* fft */
[49407f3]76extern aubio_fft_t * new_aubio_fft(uint_t size, uint_t channels);
77extern void del_aubio_fft(aubio_fft_t * s);
78extern void aubio_fft_do (aubio_fft_t *s, fvec_t * input, cvec_t * spectrum);
79extern void aubio_fft_rdo (aubio_fft_t *s, cvec_t * spectrum, fvec_t * output);
80extern void aubio_fft_do_complex (aubio_fft_t *s, fvec_t * input, fvec_t * compspec);
81extern void aubio_fft_rdo_complex (aubio_fft_t *s, fvec_t * compspec, fvec_t * output);
82extern void aubio_fft_get_spectrum(fvec_t * compspec, cvec_t * spectrum);
83extern void aubio_fft_get_realimag(cvec_t * spectrum, fvec_t * compspec);
84extern void aubio_fft_get_phas(fvec_t * compspec, cvec_t * spectrum);
85extern void aubio_fft_get_imag(cvec_t * spectrum, fvec_t * compspec);
86extern void aubio_fft_get_norm(fvec_t * compspec, cvec_t * spectrum);
87extern void aubio_fft_get_real(cvec_t * spectrum, fvec_t * compspec);
[ec10780]88
[96fb8ad]89/* filter */
[a7667ce]90extern aubio_filter_t * new_aubio_filter(uint_t samplerate, uint_t order, uint_t channels);
[96fb8ad]91extern void aubio_filter_do(aubio_filter_t * b, fvec_t * in);
92extern void aubio_filter_do_outplace(aubio_filter_t * b, fvec_t * in, fvec_t * out);
93extern void aubio_filter_do_filtfilt(aubio_filter_t * b, fvec_t * in, fvec_t * tmp);
[4123f16]94extern void del_aubio_filter(aubio_filter_t * b);
95
[bc4e175]96extern aubio_filter_t * new_aubio_filter_a_weighting (uint_t samplerate, uint_t channels);
97extern void aubio_filter_set_a_weighting (aubio_filter_t * b);
[4123f16]98
[bc4e175]99extern aubio_filter_t * new_aubio_filter_c_weighting (uint_t samplerate, uint_t channels);
100extern void aubio_filter_set_c_weighting (aubio_filter_t * b);
[96fb8ad]101
102/* biquad */
103extern aubio_biquad_t * new_aubio_biquad(lsmp_t b1, lsmp_t b2, lsmp_t b3, lsmp_t a2, lsmp_t a3);
104extern void aubio_biquad_do(aubio_biquad_t * b, fvec_t * in);
105extern void aubio_biquad_do_filtfilt(aubio_biquad_t * b, fvec_t * in, fvec_t * tmp);
[055d674]106extern void del_aubio_biquad(aubio_biquad_t * b);
[96fb8ad]107
108/* hist */
109extern aubio_hist_t * new_aubio_hist(smpl_t flow, smpl_t fhig, uint_t nelems, uint_t channels);
110extern void del_aubio_hist(aubio_hist_t *s);
111extern void aubio_hist_do(aubio_hist_t *s, fvec_t * input);
112extern void aubio_hist_do_notnull(aubio_hist_t *s, fvec_t * input);
[49407f3]113extern void aubio_hist_dyn_notnull(aubio_hist_t *s, fvec_t *input);
114extern void aubio_hist_weight(aubio_hist_t *s);
115extern smpl_t aubio_hist_mean(aubio_hist_t *s);
[96fb8ad]116
117/* mathutils */
118typedef enum {
[b4b0324]119        aubio_win_rectangle,
120        aubio_win_hamming,
121        aubio_win_hanning,
122        aubio_win_hanningz,
123        aubio_win_blackman,
124        aubio_win_blackman_harris,
125        aubio_win_gaussian,
126        aubio_win_welch,
127        aubio_win_parzen
[28d8c4a]128} aubio_window_type;
[96fb8ad]129
[d84d19e]130fvec_t * new_aubio_window(uint_t size, aubio_window_type wintype);
[28d8c4a]131smpl_t aubio_unwrap2pi (smpl_t phase);
[8b28524]132smpl_t fvec_mean(fvec_t *s);
[1e2c82f]133smpl_t fvec_max(fvec_t *s);
[2f64b0e]134smpl_t fvec_min(fvec_t *s);
135uint_t fvec_min_elem(fvec_t *s);
[1e2c82f]136uint_t fvec_max_elem(fvec_t *s);
[5c4ec3c]137void fvec_shift(fvec_t *s);
138smpl_t fvec_sum(fvec_t *s);
139smpl_t fvec_local_energy(fvec_t * f);
140smpl_t fvec_local_hfc(fvec_t * f);
141smpl_t fvec_alpha_norm(fvec_t * DF, smpl_t alpha);
[c0b295c]142void fvec_min_removal(fvec_t * mag);
[5c4ec3c]143void fvec_alpha_normalise(fvec_t * mag, uint_t alpha);
144void fvec_add(fvec_t * mag, smpl_t threshold);
145void fvec_adapt_thres(fvec_t * vec, fvec_t * tmp, uint_t post, uint_t pre);
146smpl_t fvec_moving_thres(fvec_t * vec, fvec_t * tmp, uint_t post, uint_t pre, uint_t pos);
147smpl_t fvec_median(fvec_t * input);
148smpl_t fvec_quadint(fvec_t * x,uint_t pos, uint_t span);
[28d8c4a]149smpl_t aubio_quadfrac(smpl_t s0, smpl_t s1, smpl_t s2, smpl_t pf);
[5c4ec3c]150uint_t fvec_peakpick(fvec_t * input, uint_t pos);
[28d8c4a]151smpl_t aubio_bintomidi(smpl_t bin, smpl_t samplerate, smpl_t fftsize);
[79c2e52]152smpl_t aubio_miditobin(smpl_t midi, smpl_t samplerate, smpl_t fftsize);
[28d8c4a]153smpl_t aubio_bintofreq(smpl_t bin, smpl_t samplerate, smpl_t fftsize);
[79c2e52]154smpl_t aubio_freqtobin(smpl_t freq, smpl_t samplerate, smpl_t fftsize);
[28d8c4a]155smpl_t aubio_freqtomidi(smpl_t freq);
[79c2e52]156smpl_t aubio_miditofreq(smpl_t midi);
[96fb8ad]157uint_t aubio_silence_detection(fvec_t * ibuf, smpl_t threshold);
158smpl_t aubio_level_detection(fvec_t * ibuf, smpl_t threshold);
[fe4f78a]159void aubio_autocorr(fvec_t * in, fvec_t * acf);
[5507e9d]160smpl_t aubio_zero_crossing_rate(fvec_t * input);
[c8b80cd]161smpl_t aubio_spectral_centroid(cvec_t * spectrum, smpl_t samplerate);
[96fb8ad]162
[bc4ba75]163/* filterbank */
[dc73a4d0]164aubio_filterbank_t * new_aubio_filterbank(uint_t win_s, uint_t channels);
[1e37ade]165void aubio_filterbank_set_mel_coeffs(aubio_filterbank_t *fb, fvec_t *freqs, uint_t samplerate);
166void aubio_filterbank_set_mel_coeffs_slaney(aubio_filterbank_t *fb, uint_t samplerate);
[dc73a4d0]167void del_aubio_filterbank(aubio_filterbank_t * fb);
168void aubio_filterbank_do(aubio_filterbank_t * fb, cvec_t * in, fvec_t *out);
[06cae6c]169fvec_t * aubio_filterbank_get_coeffs(aubio_filterbank_t * fb);
[bc4ba75]170
171/* mfcc */
[adcf405]172aubio_mfcc_t * new_aubio_mfcc (uint_t win_s, uint_t samplerate, uint_t n_filters, uint_t n_coefs);
[bc4ba75]173void del_aubio_mfcc(aubio_mfcc_t *mf);
174void aubio_mfcc_do(aubio_mfcc_t *mf, cvec_t *in, fvec_t *out);
175
[96fb8ad]176/* scale */
[b061ef8]177extern aubio_scale_t * new_aubio_scale(smpl_t flow, smpl_t fhig, smpl_t ilow, smpl_t ihig);
[96fb8ad]178extern void aubio_scale_set (aubio_scale_t *s, smpl_t ilow, smpl_t ihig, smpl_t olow, smpl_t ohig);
179extern void aubio_scale_do(aubio_scale_t *s, fvec_t * input);
180extern void del_aubio_scale(aubio_scale_t *s);
181
182/* resampling */
[9a91031]183#if HAVE_LIBSAMPLERATE
[96fb8ad]184extern aubio_resampler_t * new_aubio_resampler(float ratio, uint_t type);
185extern uint_t aubio_resampler_process(aubio_resampler_t *s, fvec_t * input,  fvec_t * output);
186extern void del_aubio_resampler(aubio_resampler_t *s);
[9a91031]187#endif /* HAVE_LIBSAMPLERATE */
[96fb8ad]188
189/* onset detection */
[5cf415f]190typedef enum {
191        aubio_onset_energy,
192        aubio_onset_specdiff,
193        aubio_onset_hfc,
194        aubio_onset_complex,
195        aubio_onset_phase,
196        aubio_onset_kl,
[c7f32b1]197        aubio_onset_mkl,
198        aubio_onset_specflux,
[5cf415f]199} aubio_onsetdetection_type;
[96fb8ad]200aubio_onsetdetection_t * new_aubio_onsetdetection(aubio_onsetdetection_type type, uint_t size, uint_t channels);
201void aubio_onsetdetection(aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset);
[2a00568]202void del_aubio_onsetdetection(aubio_onsetdetection_t *o);
[96fb8ad]203
204/* should these still be exposed ? */
205void aubio_onsetdetection_energy  (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset);
[5cf415f]206void aubio_onsetdetection_hfc     (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset);
[96fb8ad]207void aubio_onsetdetection_complex (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset);
208void aubio_onsetdetection_phase   (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset);
209void aubio_onsetdetection_specdiff(aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset);
[5cf415f]210void aubio_onsetdetection_kl      (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset);
211void aubio_onsetdetection_mkl     (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset);
[96fb8ad]212
213/* pvoc */
214aubio_pvoc_t * new_aubio_pvoc (uint_t win_s, uint_t hop_s, uint_t channels);
215void del_aubio_pvoc(aubio_pvoc_t *pv);
216void aubio_pvoc_do(aubio_pvoc_t *pv, fvec_t *in, cvec_t * fftgrain);
217void aubio_pvoc_rdo(aubio_pvoc_t *pv, cvec_t * fftgrain, fvec_t *out);
218
219/* pitch detection */
[8e8bc50]220typedef enum {
[5e9c68a]221        aubio_pitch_yin,
222        aubio_pitch_mcomb,
223        aubio_pitch_schmitt,
[650e39b]224        aubio_pitch_fcomb,
[b061ef8]225        aubio_pitch_yinfft
[8e8bc50]226} aubio_pitchdetection_type;
227
228typedef enum {
[5e9c68a]229        aubio_pitchm_freq,
230        aubio_pitchm_midi,
231        aubio_pitchm_cent,
232        aubio_pitchm_bin
[8e8bc50]233} aubio_pitchdetection_mode;
234
235smpl_t aubio_pitchdetection(aubio_pitchdetection_t * p, fvec_t * ibuf);
236
[4afa096d]237void aubio_pitchdetection_set_yinthresh(aubio_pitchdetection_t *p, smpl_t thres);
238
[8e8bc50]239void del_aubio_pitchdetection(aubio_pitchdetection_t * p);
240
241aubio_pitchdetection_t * new_aubio_pitchdetection(uint_t bufsize,
[b061ef8]242    uint_t hopsize,
243    uint_t channels,
244    uint_t samplerate,
245    aubio_pitchdetection_type type,
246    aubio_pitchdetection_mode mode);
[8e8bc50]247
[96fb8ad]248
249/* pitch mcomb */
[650e39b]250aubio_pitchmcomb_t * new_aubio_pitchmcomb(uint_t bufsize, uint_t hopsize, uint_t channels, uint_t samplerate);
[96fb8ad]251smpl_t aubio_pitchmcomb_detect(aubio_pitchmcomb_t * p, cvec_t * fftgrain);
252uint_t aubio_pitch_cands(aubio_pitchmcomb_t * p, cvec_t * fftgrain, smpl_t * cands);
[7a04950]253void del_aubio_pitchmcomb (aubio_pitchmcomb_t *p);
[96fb8ad]254
255/* pitch yin */
256void aubio_pitchyin_diff(fvec_t *input, fvec_t *yin);
257void aubio_pitchyin_getcum(fvec_t *yin);
258uint_t aubio_pitchyin_getpitch(fvec_t *yin);
[650e39b]259smpl_t aubio_pitchyin_getpitchfast(fvec_t * input, fvec_t *yin, smpl_t tol);
[96fb8ad]260
[7a04950]261/* pitch schmitt */
262aubio_pitchschmitt_t * new_aubio_pitchschmitt (uint_t size, uint_t samplerate);
263smpl_t aubio_pitchschmitt_detect (aubio_pitchschmitt_t *p, fvec_t * input);
264void del_aubio_pitchschmitt (aubio_pitchschmitt_t *p);
265
266/* pitch fcomb */
[4afa096d]267aubio_pitchfcomb_t * new_aubio_pitchfcomb (uint_t size, uint_t hopsize, uint_t samplerate);
[7a04950]268smpl_t aubio_pitchfcomb_detect (aubio_pitchfcomb_t *p, fvec_t * input);
269void del_aubio_pitchfcomb (aubio_pitchfcomb_t *p);
270
[96fb8ad]271/* peakpicker */
272aubio_pickpeak_t * new_aubio_peakpicker(smpl_t threshold);
273uint_t aubio_peakpick_pimrt(fvec_t * DF, aubio_pickpeak_t * p);
274uint_t aubio_peakpick_pimrt_wt( fvec_t* DF, aubio_pickpeak_t* p, smpl_t* peakval );
[3822b73]275smpl_t aubio_peakpick_pimrt_getval(aubio_pickpeak_t* p);
[96fb8ad]276void del_aubio_peakpicker(aubio_pickpeak_t * p);
[3822b73]277void aubio_peakpicker_set_threshold(aubio_pickpeak_t * p, smpl_t threshold);
278smpl_t aubio_peakpicker_get_threshold(aubio_pickpeak_t * p);
[96fb8ad]279
280/* transient/steady state separation */
281aubio_tss_t * new_aubio_tss(smpl_t thrs, smpl_t alfa, smpl_t beta,
282    uint_t size, uint_t overlap,uint_t channels);
283void del_aubio_tss(aubio_tss_t *s);
284void aubio_tss_do(aubio_tss_t *s, cvec_t * input, cvec_t * trans, cvec_t * stead);
285
[de92b1c]286/* beattracking */
287aubio_beattracking_t * new_aubio_beattracking(uint_t winlen, uint_t channels);
288void aubio_beattracking_do(aubio_beattracking_t * bt, fvec_t * dfframes, fvec_t * out);
289void del_aubio_beattracking(aubio_beattracking_t * p);
[e34b010]290smpl_t aubio_beattracking_get_bpm(aubio_beattracking_t * p);
291smpl_t aubio_beattracking_get_confidence(aubio_beattracking_t * p);
[de92b1c]292
Note: See TracBrowser for help on using the repository browser.