[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 */ |
---|
| 12 | typedef unsigned int uint_t; |
---|
| 13 | typedef int sint_t; |
---|
| 14 | typedef float smpl_t; |
---|
| 15 | |
---|
| 16 | /* fvec */ |
---|
| 17 | extern fvec_t * new_fvec(uint_t length, uint_t channels); |
---|
| 18 | extern void del_fvec(fvec_t *s); |
---|
| 19 | smpl_t fvec_read_sample(fvec_t *s, uint_t channel, uint_t position); |
---|
| 20 | void fvec_write_sample(fvec_t *s, smpl_t data, uint_t channel, uint_t position); |
---|
| 21 | smpl_t * fvec_get_channel(fvec_t *s, uint_t channel); |
---|
| 22 | void fvec_put_channel(fvec_t *s, smpl_t * data, uint_t channel); |
---|
| 23 | smpl_t ** fvec_get_data(fvec_t *s); |
---|
| 24 | |
---|
| 25 | /* another way, passing -c++ option to swig */ |
---|
| 26 | /* |
---|
| 27 | class fvec_t{ |
---|
| 28 | public: |
---|
| 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 */ |
---|
| 49 | extern cvec_t * new_cvec(uint_t length, uint_t channels); |
---|
| 50 | extern void del_cvec(cvec_t *s); |
---|
[7c206df] | 51 | extern void cvec_write_norm(cvec_t *s, smpl_t data, uint_t channel, uint_t position); |
---|
| 52 | extern void cvec_write_phas(cvec_t *s, smpl_t data, uint_t channel, uint_t position); |
---|
| 53 | extern smpl_t cvec_read_norm(cvec_t *s, uint_t channel, uint_t position); |
---|
| 54 | extern smpl_t cvec_read_phas(cvec_t *s, uint_t channel, uint_t position); |
---|
| 55 | extern void cvec_put_norm_channel(cvec_t *s, smpl_t * data, uint_t channel); |
---|
| 56 | extern void cvec_put_phas_channel(cvec_t *s, smpl_t * data, uint_t channel); |
---|
| 57 | extern smpl_t * cvec_get_norm_channel(cvec_t *s, uint_t channel); |
---|
| 58 | extern smpl_t * cvec_get_phas_channel(cvec_t *s, uint_t channel); |
---|
| 59 | extern smpl_t ** cvec_get_norm(cvec_t *s); |
---|
| 60 | extern smpl_t ** cvec_get_phas(cvec_t *s); |
---|
[96fb8ad] | 61 | |
---|
| 62 | |
---|
| 63 | /* sndfile */ |
---|
[5e9c68a] | 64 | extern aubio_sndfile_t * new_aubio_sndfile_ro (const char * inputfile); |
---|
| 65 | extern aubio_sndfile_t * new_aubio_sndfile_wo(aubio_sndfile_t * existingfile, const char * outputname); |
---|
| 66 | extern void aubio_sndfile_info(aubio_sndfile_t * file); |
---|
| 67 | extern int aubio_sndfile_write(aubio_sndfile_t * file, int frames, fvec_t * write); |
---|
| 68 | extern int aubio_sndfile_read(aubio_sndfile_t * file, int frames, fvec_t * read); |
---|
| 69 | extern int del_aubio_sndfile(aubio_sndfile_t * file); |
---|
| 70 | extern uint_t aubio_sndfile_channels(aubio_sndfile_t * file); |
---|
| 71 | extern uint_t aubio_sndfile_samplerate(aubio_sndfile_t * file); |
---|
[96fb8ad] | 72 | |
---|
| 73 | /* fft */ |
---|
| 74 | extern void aubio_fft_getnorm(smpl_t * norm, fft_data_t * spectrum, uint_t size); |
---|
| 75 | extern void aubio_fft_getphas(smpl_t * phase, fft_data_t * spectrum, uint_t size); |
---|
| 76 | |
---|
[ec10780] | 77 | extern aubio_mfft_t * new_aubio_mfft(uint_t winsize, uint_t channels); |
---|
| 78 | extern void aubio_mfft_do (aubio_mfft_t * fft,fvec_t * in,cvec_t * fftgrain); |
---|
| 79 | extern void aubio_mfft_rdo(aubio_mfft_t * fft,cvec_t * fftgrain, fvec_t * out); |
---|
| 80 | extern void del_aubio_mfft(aubio_mfft_t * fft); |
---|
| 81 | |
---|
| 82 | |
---|
[96fb8ad] | 83 | /* filter */ |
---|
| 84 | extern aubio_filter_t * new_aubio_filter(uint_t samplerate, uint_t order); |
---|
| 85 | extern aubio_filter_t * new_aubio_adsgn_filter(uint_t samplerate); |
---|
| 86 | extern aubio_filter_t * new_aubio_cdsgn_filter(uint_t samplerate); |
---|
| 87 | extern void aubio_filter_do(aubio_filter_t * b, fvec_t * in); |
---|
| 88 | extern void aubio_filter_do_outplace(aubio_filter_t * b, fvec_t * in, fvec_t * out); |
---|
| 89 | extern void aubio_filter_do_filtfilt(aubio_filter_t * b, fvec_t * in, fvec_t * tmp); |
---|
| 90 | /*extern int del_aubio_filter(aubio_filter_t * b);*/ |
---|
| 91 | |
---|
| 92 | /* biquad */ |
---|
| 93 | extern aubio_biquad_t * new_aubio_biquad(lsmp_t b1, lsmp_t b2, lsmp_t b3, lsmp_t a2, lsmp_t a3); |
---|
| 94 | extern void aubio_biquad_do(aubio_biquad_t * b, fvec_t * in); |
---|
| 95 | extern void aubio_biquad_do_filtfilt(aubio_biquad_t * b, fvec_t * in, fvec_t * tmp); |
---|
| 96 | /*extern int del_aubio_biquad(aubio_biquad_t * b);*/ |
---|
| 97 | |
---|
| 98 | /* hist */ |
---|
| 99 | extern aubio_hist_t * new_aubio_hist(smpl_t flow, smpl_t fhig, uint_t nelems, uint_t channels); |
---|
| 100 | extern void del_aubio_hist(aubio_hist_t *s); |
---|
| 101 | extern void aubio_hist_do(aubio_hist_t *s, fvec_t * input); |
---|
| 102 | extern void aubio_hist_do_notnull(aubio_hist_t *s, fvec_t * input); |
---|
| 103 | extern void aubio_hist_dyn_notnull (aubio_hist_t *s, fvec_t *input); |
---|
| 104 | |
---|
| 105 | /* mathutils */ |
---|
| 106 | typedef enum { |
---|
[b4b0324] | 107 | aubio_win_rectangle, |
---|
| 108 | aubio_win_hamming, |
---|
| 109 | aubio_win_hanning, |
---|
| 110 | aubio_win_hanningz, |
---|
| 111 | aubio_win_blackman, |
---|
| 112 | aubio_win_blackman_harris, |
---|
| 113 | aubio_win_gaussian, |
---|
| 114 | aubio_win_welch, |
---|
| 115 | aubio_win_parzen |
---|
[28d8c4a] | 116 | } aubio_window_type; |
---|
[96fb8ad] | 117 | |
---|
[28d8c4a] | 118 | void aubio_window(smpl_t *w, uint_t size, aubio_window_type wintype); |
---|
| 119 | smpl_t aubio_unwrap2pi (smpl_t phase); |
---|
[96fb8ad] | 120 | smpl_t vec_mean(fvec_t *s); |
---|
| 121 | smpl_t vec_max(fvec_t *s); |
---|
| 122 | smpl_t vec_min(fvec_t *s); |
---|
| 123 | uint_t vec_min_elem(fvec_t *s); |
---|
| 124 | uint_t vec_max_elem(fvec_t *s); |
---|
| 125 | void vec_shift(fvec_t *s); |
---|
| 126 | smpl_t vec_sum(fvec_t *s); |
---|
| 127 | smpl_t vec_local_energy(fvec_t * f); |
---|
| 128 | smpl_t vec_local_hfc(fvec_t * f); |
---|
| 129 | smpl_t vec_alpha_norm(fvec_t * DF, smpl_t alpha); |
---|
| 130 | void vec_dc_removal(fvec_t * mag); |
---|
| 131 | void vec_alpha_normalise(fvec_t * mag, uint_t alpha); |
---|
| 132 | void vec_add(fvec_t * mag, smpl_t threshold); |
---|
| 133 | void vec_adapt_thres(fvec_t * vec, fvec_t * tmp, uint_t post, uint_t pre); |
---|
| 134 | smpl_t vec_moving_thres(fvec_t * vec, fvec_t * tmp, uint_t post, uint_t pre, uint_t pos); |
---|
| 135 | smpl_t vec_median(fvec_t * input); |
---|
| 136 | smpl_t vec_quadint(fvec_t * x,uint_t pos); |
---|
[28d8c4a] | 137 | smpl_t aubio_quadfrac(smpl_t s0, smpl_t s1, smpl_t s2, smpl_t pf); |
---|
[96fb8ad] | 138 | uint_t vec_peakpick(fvec_t * input, uint_t pos); |
---|
[28d8c4a] | 139 | smpl_t aubio_bintomidi(smpl_t bin, smpl_t samplerate, smpl_t fftsize); |
---|
[79c2e52] | 140 | smpl_t aubio_miditobin(smpl_t midi, smpl_t samplerate, smpl_t fftsize); |
---|
[28d8c4a] | 141 | smpl_t aubio_bintofreq(smpl_t bin, smpl_t samplerate, smpl_t fftsize); |
---|
[79c2e52] | 142 | smpl_t aubio_freqtobin(smpl_t freq, smpl_t samplerate, smpl_t fftsize); |
---|
[28d8c4a] | 143 | smpl_t aubio_freqtomidi(smpl_t freq); |
---|
[79c2e52] | 144 | smpl_t aubio_miditofreq(smpl_t midi); |
---|
[96fb8ad] | 145 | uint_t aubio_silence_detection(fvec_t * ibuf, smpl_t threshold); |
---|
| 146 | smpl_t aubio_level_detection(fvec_t * ibuf, smpl_t threshold); |
---|
| 147 | |
---|
| 148 | /* scale */ |
---|
| 149 | extern aubio_scale_t * new_aubio_scale(smpl_t flow, smpl_t fhig, smpl_t ilow, smpl_t ihig ); |
---|
| 150 | extern void aubio_scale_set (aubio_scale_t *s, smpl_t ilow, smpl_t ihig, smpl_t olow, smpl_t ohig); |
---|
| 151 | extern void aubio_scale_do(aubio_scale_t *s, fvec_t * input); |
---|
| 152 | extern void del_aubio_scale(aubio_scale_t *s); |
---|
| 153 | |
---|
| 154 | /* resampling */ |
---|
| 155 | extern aubio_resampler_t * new_aubio_resampler(float ratio, uint_t type); |
---|
| 156 | extern uint_t aubio_resampler_process(aubio_resampler_t *s, fvec_t * input, fvec_t * output); |
---|
| 157 | extern void del_aubio_resampler(aubio_resampler_t *s); |
---|
| 158 | |
---|
| 159 | /* onset detection */ |
---|
[5cf415f] | 160 | typedef enum { |
---|
| 161 | aubio_onset_energy, |
---|
| 162 | aubio_onset_specdiff, |
---|
| 163 | aubio_onset_hfc, |
---|
| 164 | aubio_onset_complex, |
---|
| 165 | aubio_onset_phase, |
---|
| 166 | aubio_onset_kl, |
---|
| 167 | aubio_onset_mkl |
---|
| 168 | } aubio_onsetdetection_type; |
---|
[96fb8ad] | 169 | aubio_onsetdetection_t * new_aubio_onsetdetection(aubio_onsetdetection_type type, uint_t size, uint_t channels); |
---|
| 170 | void aubio_onsetdetection(aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset); |
---|
| 171 | void aubio_onsetdetection_free(aubio_onsetdetection_t *o); |
---|
| 172 | |
---|
| 173 | /* should these still be exposed ? */ |
---|
| 174 | void aubio_onsetdetection_energy (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset); |
---|
[5cf415f] | 175 | void aubio_onsetdetection_hfc (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset); |
---|
[96fb8ad] | 176 | void aubio_onsetdetection_complex (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset); |
---|
| 177 | void aubio_onsetdetection_phase (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset); |
---|
| 178 | void aubio_onsetdetection_specdiff(aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset); |
---|
[5cf415f] | 179 | void aubio_onsetdetection_kl (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset); |
---|
| 180 | void aubio_onsetdetection_mkl (aubio_onsetdetection_t *o, cvec_t * fftgrain, fvec_t * onset); |
---|
[96fb8ad] | 181 | |
---|
| 182 | /* pvoc */ |
---|
| 183 | aubio_pvoc_t * new_aubio_pvoc (uint_t win_s, uint_t hop_s, uint_t channels); |
---|
| 184 | void del_aubio_pvoc(aubio_pvoc_t *pv); |
---|
| 185 | void aubio_pvoc_do(aubio_pvoc_t *pv, fvec_t *in, cvec_t * fftgrain); |
---|
| 186 | void aubio_pvoc_rdo(aubio_pvoc_t *pv, cvec_t * fftgrain, fvec_t *out); |
---|
| 187 | |
---|
| 188 | /* pitch detection */ |
---|
[8e8bc50] | 189 | typedef enum { |
---|
[5e9c68a] | 190 | aubio_pitch_yin, |
---|
| 191 | aubio_pitch_mcomb, |
---|
| 192 | aubio_pitch_schmitt, |
---|
| 193 | aubio_pitch_fcomb |
---|
[8e8bc50] | 194 | } aubio_pitchdetection_type; |
---|
| 195 | |
---|
| 196 | typedef enum { |
---|
[5e9c68a] | 197 | aubio_pitchm_freq, |
---|
| 198 | aubio_pitchm_midi, |
---|
| 199 | aubio_pitchm_cent, |
---|
| 200 | aubio_pitchm_bin |
---|
[8e8bc50] | 201 | } aubio_pitchdetection_mode; |
---|
| 202 | |
---|
| 203 | smpl_t aubio_pitchdetection(aubio_pitchdetection_t * p, fvec_t * ibuf); |
---|
| 204 | smpl_t aubio_pitchdetection_mcomb(aubio_pitchdetection_t *p, fvec_t * ibuf); |
---|
| 205 | smpl_t aubio_pitchdetection_yin(aubio_pitchdetection_t *p, fvec_t *ibuf); |
---|
| 206 | |
---|
| 207 | void del_aubio_pitchdetection(aubio_pitchdetection_t * p); |
---|
| 208 | |
---|
| 209 | aubio_pitchdetection_t * new_aubio_pitchdetection(uint_t bufsize, |
---|
| 210 | uint_t hopsize, |
---|
| 211 | uint_t channels, |
---|
| 212 | uint_t samplerate, |
---|
| 213 | aubio_pitchdetection_type type, |
---|
| 214 | aubio_pitchdetection_mode mode); |
---|
| 215 | |
---|
[96fb8ad] | 216 | |
---|
| 217 | /* pitch mcomb */ |
---|
| 218 | aubio_pitchmcomb_t * new_aubio_pitchmcomb(uint_t size, uint_t channels); |
---|
| 219 | smpl_t aubio_pitchmcomb_detect(aubio_pitchmcomb_t * p, cvec_t * fftgrain); |
---|
| 220 | uint_t aubio_pitch_cands(aubio_pitchmcomb_t * p, cvec_t * fftgrain, smpl_t * cands); |
---|
[7a04950] | 221 | void del_aubio_pitchmcomb (aubio_pitchmcomb_t *p); |
---|
[96fb8ad] | 222 | |
---|
| 223 | /* pitch yin */ |
---|
| 224 | void aubio_pitchyin_diff(fvec_t *input, fvec_t *yin); |
---|
| 225 | void aubio_pitchyin_getcum(fvec_t *yin); |
---|
| 226 | uint_t aubio_pitchyin_getpitch(fvec_t *yin); |
---|
[23a44c1] | 227 | uint_t aubio_pitchyin_getpitchfast(fvec_t * input, fvec_t *yin, smpl_t tol); |
---|
[96fb8ad] | 228 | |
---|
[7a04950] | 229 | /* pitch schmitt */ |
---|
| 230 | aubio_pitchschmitt_t * new_aubio_pitchschmitt (uint_t size, uint_t samplerate); |
---|
| 231 | smpl_t aubio_pitchschmitt_detect (aubio_pitchschmitt_t *p, fvec_t * input); |
---|
| 232 | void del_aubio_pitchschmitt (aubio_pitchschmitt_t *p); |
---|
| 233 | |
---|
| 234 | /* pitch fcomb */ |
---|
| 235 | aubio_pitchfcomb_t * new_aubio_pitchfcomb (uint_t size, uint_t samplerate); |
---|
| 236 | smpl_t aubio_pitchfcomb_detect (aubio_pitchfcomb_t *p, fvec_t * input); |
---|
| 237 | void del_aubio_pitchfcomb (aubio_pitchfcomb_t *p); |
---|
| 238 | |
---|
[96fb8ad] | 239 | /* peakpicker */ |
---|
| 240 | aubio_pickpeak_t * new_aubio_peakpicker(smpl_t threshold); |
---|
| 241 | uint_t aubio_peakpick_pimrt(fvec_t * DF, aubio_pickpeak_t * p); |
---|
[de92b1c] | 242 | smpl_t aubio_peakpick_pimrt_getval(aubio_pickpeak_t* p); |
---|
[96fb8ad] | 243 | uint_t aubio_peakpick_pimrt_wt( fvec_t* DF, aubio_pickpeak_t* p, smpl_t* peakval ); |
---|
| 244 | void del_aubio_peakpicker(aubio_pickpeak_t * p); |
---|
| 245 | |
---|
| 246 | /* transient/steady state separation */ |
---|
| 247 | aubio_tss_t * new_aubio_tss(smpl_t thrs, smpl_t alfa, smpl_t beta, |
---|
| 248 | uint_t size, uint_t overlap,uint_t channels); |
---|
| 249 | void del_aubio_tss(aubio_tss_t *s); |
---|
| 250 | void aubio_tss_do(aubio_tss_t *s, cvec_t * input, cvec_t * trans, cvec_t * stead); |
---|
| 251 | |
---|
[de92b1c] | 252 | /* beattracking */ |
---|
| 253 | aubio_beattracking_t * new_aubio_beattracking(uint_t winlen, uint_t channels); |
---|
| 254 | void aubio_beattracking_do(aubio_beattracking_t * bt, fvec_t * dfframes, fvec_t * out); |
---|
| 255 | void del_aubio_beattracking(aubio_beattracking_t * p); |
---|
| 256 | |
---|
| 257 | |
---|
[96fb8ad] | 258 | |
---|
| 259 | /* jack */ |
---|
| 260 | #ifdef JACK_SUPPORT |
---|
| 261 | extern aubio_jack_t * new_aubio_jack (uint_t inchannels, uint_t outchannels, aubio_process_func_t callback); |
---|
| 262 | typedef int (*aubio_process_func_t)(smpl_t **input, smpl_t **output, int nframes); |
---|
| 263 | extern uint_t aubio_jack_activate(aubio_jack_t *jack_setup); |
---|
| 264 | extern void aubio_jack_close(aubio_jack_t *jack_setup); |
---|
| 265 | #endif |
---|
| 266 | |
---|
| 267 | /* midi */ |
---|
| 268 | enum aubio_midi_event_type { |
---|
| 269 | /* channel messages */ |
---|
| 270 | NOTE_OFF = 0x80, |
---|
| 271 | NOTE_ON = 0x90, |
---|
| 272 | KEY_PRESSURE = 0xa0, |
---|
| 273 | CONTROL_CHANGE = 0xb0, |
---|
| 274 | PROGRAM_CHANGE = 0xc0, |
---|
| 275 | CHANNEL_PRESSURE = 0xd0, |
---|
| 276 | PITCH_BEND = 0xe0, |
---|
| 277 | /* system exclusive */ |
---|
| 278 | MIDI_SYSEX = 0xf0, |
---|
| 279 | /* system common - never in midi files */ |
---|
| 280 | MIDI_TIME_CODE = 0xf1, |
---|
| 281 | MIDI_SONG_POSITION = 0xf2, |
---|
| 282 | MIDI_SONG_SELECT = 0xf3, |
---|
| 283 | MIDI_TUNE_REQUEST = 0xf6, |
---|
| 284 | MIDI_EOX = 0xf7, |
---|
| 285 | /* system real-time - never in midi files */ |
---|
| 286 | MIDI_SYNC = 0xf8, |
---|
| 287 | MIDI_TICK = 0xf9, |
---|
| 288 | MIDI_START = 0xfa, |
---|
| 289 | MIDI_CONTINUE = 0xfb, |
---|
| 290 | MIDI_STOP = 0xfc, |
---|
| 291 | MIDI_ACTIVE_SENSING = 0xfe, |
---|
| 292 | MIDI_SYSTEM_RESET = 0xff, |
---|
| 293 | /* meta event - for midi files only */ |
---|
| 294 | MIDI_META_EVENT = 0xff |
---|
| 295 | }; |
---|
| 296 | |
---|
| 297 | enum aubio_midi_control_change { |
---|
| 298 | BANK_SELECT_MSB = 0x00, |
---|
| 299 | MODULATION_MSB = 0x01, |
---|
| 300 | BREATH_MSB = 0x02, |
---|
| 301 | FOOT_MSB = 0x04, |
---|
| 302 | PORTAMENTO_TIME_MSB = 0x05, |
---|
| 303 | DATA_ENTRY_MSB = 0x06, |
---|
| 304 | VOLUME_MSB = 0x07, |
---|
| 305 | BALANCE_MSB = 0x08, |
---|
| 306 | PAN_MSB = 0x0A, |
---|
| 307 | EXPRESSION_MSB = 0x0B, |
---|
| 308 | EFFECTS1_MSB = 0x0C, |
---|
| 309 | EFFECTS2_MSB = 0x0D, |
---|
| 310 | GPC1_MSB = 0x10, /* general purpose controller */ |
---|
| 311 | GPC2_MSB = 0x11, |
---|
| 312 | GPC3_MSB = 0x12, |
---|
| 313 | GPC4_MSB = 0x13, |
---|
| 314 | BANK_SELECT_LSB = 0x20, |
---|
| 315 | MODULATION_WHEEL_LSB = 0x21, |
---|
| 316 | BREATH_LSB = 0x22, |
---|
| 317 | FOOT_LSB = 0x24, |
---|
| 318 | PORTAMENTO_TIME_LSB = 0x25, |
---|
| 319 | DATA_ENTRY_LSB = 0x26, |
---|
| 320 | VOLUME_LSB = 0x27, |
---|
| 321 | BALANCE_LSB = 0x28, |
---|
| 322 | PAN_LSB = 0x2A, |
---|
| 323 | EXPRESSION_LSB = 0x2B, |
---|
| 324 | EFFECTS1_LSB = 0x2C, |
---|
| 325 | EFFECTS2_LSB = 0x2D, |
---|
| 326 | GPC1_LSB = 0x30, |
---|
| 327 | GPC2_LSB = 0x31, |
---|
| 328 | GPC3_LSB = 0x32, |
---|
| 329 | GPC4_LSB = 0x33, |
---|
| 330 | SUSTAIN_SWITCH = 0x40, |
---|
| 331 | PORTAMENTO_SWITCH = 0x41, |
---|
| 332 | SOSTENUTO_SWITCH = 0x42, |
---|
| 333 | SOFT_PEDAL_SWITCH = 0x43, |
---|
| 334 | LEGATO_SWITCH = 0x45, |
---|
| 335 | HOLD2_SWITCH = 0x45, |
---|
| 336 | SOUND_CTRL1 = 0x46, |
---|
| 337 | SOUND_CTRL2 = 0x47, |
---|
| 338 | SOUND_CTRL3 = 0x48, |
---|
| 339 | SOUND_CTRL4 = 0x49, |
---|
| 340 | SOUND_CTRL5 = 0x4A, |
---|
| 341 | SOUND_CTRL6 = 0x4B, |
---|
| 342 | SOUND_CTRL7 = 0x4C, |
---|
| 343 | SOUND_CTRL8 = 0x4D, |
---|
| 344 | SOUND_CTRL9 = 0x4E, |
---|
| 345 | SOUND_CTRL10 = 0x4F, |
---|
| 346 | GPC5 = 0x50, |
---|
| 347 | GPC6 = 0x51, |
---|
| 348 | GPC7 = 0x52, |
---|
| 349 | GPC8 = 0x53, |
---|
| 350 | PORTAMENTO_CTRL = 0x54, |
---|
| 351 | EFFECTS_DEPTH1 = 0x5B, |
---|
| 352 | EFFECTS_DEPTH2 = 0x5C, |
---|
| 353 | EFFECTS_DEPTH3 = 0x5D, |
---|
| 354 | EFFECTS_DEPTH4 = 0x5E, |
---|
| 355 | EFFECTS_DEPTH5 = 0x5F, |
---|
| 356 | DATA_ENTRY_INCR = 0x60, |
---|
| 357 | DATA_ENTRY_DECR = 0x61, |
---|
| 358 | NRPN_LSB = 0x62, |
---|
| 359 | NRPN_MSB = 0x63, |
---|
| 360 | RPN_LSB = 0x64, |
---|
| 361 | RPN_MSB = 0x65, |
---|
| 362 | ALL_SOUND_OFF = 0x78, |
---|
| 363 | ALL_CTRL_OFF = 0x79, |
---|
| 364 | LOCAL_CONTROL = 0x7A, |
---|
| 365 | ALL_NOTES_OFF = 0x7B, |
---|
| 366 | OMNI_OFF = 0x7C, |
---|
| 367 | OMNI_ON = 0x7D, |
---|
| 368 | POLY_OFF = 0x7E, |
---|
| 369 | POLY_ON = 0x7F |
---|
| 370 | }; |
---|
| 371 | |
---|
| 372 | enum midi_meta_event { |
---|
| 373 | MIDI_COPYRIGHT = 0x02, |
---|
| 374 | MIDI_TRACK_NAME = 0x03, |
---|
| 375 | MIDI_INST_NAME = 0x04, |
---|
| 376 | MIDI_LYRIC = 0x05, |
---|
| 377 | MIDI_MARKER = 0x06, |
---|
| 378 | MIDI_CUE_POINT = 0x07, |
---|
| 379 | MIDI_EOT = 0x2f, |
---|
| 380 | MIDI_SET_TEMPO = 0x51, |
---|
| 381 | MIDI_SMPTE_OFFSET = 0x54, |
---|
| 382 | MIDI_TIME_SIGNATURE = 0x58, |
---|
| 383 | MIDI_KEY_SIGNATURE = 0x59, |
---|
| 384 | MIDI_SEQUENCER_EVENT = 0x7f |
---|
| 385 | }; |
---|
| 386 | |
---|
| 387 | enum aubio_player_status |
---|
| 388 | { |
---|
| 389 | AUBIO_MIDI_PLAYER_READY, |
---|
| 390 | AUBIO_MIDI_PLAYER_PLAYING, |
---|
| 391 | AUBIO_MIDI_PLAYER_DONE |
---|
| 392 | }; |
---|
| 393 | |
---|
| 394 | enum aubio_driver_status |
---|
| 395 | { |
---|
| 396 | AUBIO_MIDI_READY, |
---|
| 397 | AUBIO_MIDI_LISTENING, |
---|
| 398 | AUBIO_MIDI_DONE |
---|
| 399 | }; |
---|
| 400 | |
---|
| 401 | /* midi event */ |
---|
| 402 | aubio_midi_event_t* new_aubio_midi_event(void); |
---|
| 403 | int del_aubio_midi_event(aubio_midi_event_t* event); |
---|
| 404 | int aubio_midi_event_set_type(aubio_midi_event_t* evt, int type); |
---|
| 405 | int aubio_midi_event_get_type(aubio_midi_event_t* evt); |
---|
| 406 | int aubio_midi_event_set_channel(aubio_midi_event_t* evt, int chan); |
---|
| 407 | int aubio_midi_event_get_channel(aubio_midi_event_t* evt); |
---|
| 408 | int aubio_midi_event_get_key(aubio_midi_event_t* evt); |
---|
| 409 | int aubio_midi_event_set_key(aubio_midi_event_t* evt, int key); |
---|
| 410 | int aubio_midi_event_get_velocity(aubio_midi_event_t* evt); |
---|
| 411 | int aubio_midi_event_set_velocity(aubio_midi_event_t* evt, int vel); |
---|
| 412 | int aubio_midi_event_get_control(aubio_midi_event_t* evt); |
---|
| 413 | int aubio_midi_event_set_control(aubio_midi_event_t* evt, int ctrl); |
---|
| 414 | int aubio_midi_event_get_value(aubio_midi_event_t* evt); |
---|
| 415 | int aubio_midi_event_set_value(aubio_midi_event_t* evt, int val); |
---|
| 416 | int aubio_midi_event_get_program(aubio_midi_event_t* evt); |
---|
| 417 | int aubio_midi_event_set_program(aubio_midi_event_t* evt, int val); |
---|
| 418 | int aubio_midi_event_get_pitch(aubio_midi_event_t* evt); |
---|
| 419 | int aubio_midi_event_set_pitch(aubio_midi_event_t* evt, int val); |
---|
| 420 | int aubio_midi_event_length(unsigned char status); |
---|
| 421 | |
---|
| 422 | /* midi track */ |
---|
| 423 | aubio_track_t* new_aubio_track(int num); |
---|
| 424 | int del_aubio_track(aubio_track_t* track); |
---|
| 425 | int aubio_track_set_name(aubio_track_t* track, char* name); |
---|
| 426 | char* aubio_track_get_name(aubio_track_t* track); |
---|
| 427 | int aubio_track_add_event(aubio_track_t* track, aubio_midi_event_t* evt); |
---|
| 428 | aubio_midi_event_t* aubio_track_first_event(aubio_track_t* track); |
---|
| 429 | aubio_midi_event_t* aubio_track_next_event(aubio_track_t* track); |
---|
| 430 | int aubio_track_get_duration(aubio_track_t* track); |
---|
| 431 | int aubio_track_reset(aubio_track_t* track); |
---|
| 432 | int aubio_track_count_events(aubio_track_t* track, int* on, int* off); |
---|
| 433 | |
---|
| 434 | /* midi player */ |
---|
| 435 | aubio_midi_player_t* new_aubio_midi_player(void); |
---|
| 436 | sint_t del_aubio_midi_player(aubio_midi_player_t* player); |
---|
| 437 | sint_t aubio_midi_player_reset(aubio_midi_player_t* player); |
---|
| 438 | sint_t aubio_midi_player_add_track(aubio_midi_player_t* player, aubio_track_t* track); |
---|
| 439 | sint_t aubio_midi_player_count_tracks(aubio_midi_player_t* player); |
---|
| 440 | aubio_track_t* aubio_midi_player_get_track(aubio_midi_player_t* player, sint_t i); |
---|
| 441 | sint_t aubio_midi_player_add(aubio_midi_player_t* player, char* midifile); |
---|
| 442 | sint_t aubio_midi_player_load(aubio_midi_player_t* player, char *filename); |
---|
| 443 | sint_t aubio_midi_player_callback(void* data, uint_t msec); |
---|
| 444 | sint_t aubio_midi_player_play(aubio_midi_player_t* player); |
---|
| 445 | sint_t aubio_midi_player_play_offline(aubio_midi_player_t* player); |
---|
| 446 | sint_t aubio_midi_player_stop(aubio_midi_player_t* player); |
---|
| 447 | sint_t aubio_midi_player_set_loop(aubio_midi_player_t* player, sint_t loop); |
---|
| 448 | sint_t aubio_midi_player_set_midi_tempo(aubio_midi_player_t* player, sint_t tempo); |
---|
| 449 | sint_t aubio_midi_player_set_bpm(aubio_midi_player_t* player, sint_t bpm); |
---|
| 450 | sint_t aubio_midi_player_join(aubio_midi_player_t* player); |
---|
| 451 | sint_t aubio_track_send_events(aubio_track_t* track, |
---|
| 452 | /* aubio_synth_t* synth, */ |
---|
| 453 | aubio_midi_player_t* player, |
---|
| 454 | uint_t ticks); |
---|
| 455 | sint_t aubio_midi_send_event(aubio_midi_player_t* player, aubio_midi_event_t* event); |
---|
| 456 | |
---|
| 457 | /* midi parser */ |
---|
| 458 | aubio_midi_parser_t* new_aubio_midi_parser(void); |
---|
| 459 | int del_aubio_midi_parser(aubio_midi_parser_t* parser); |
---|
| 460 | aubio_midi_event_t* aubio_midi_parser_parse(aubio_midi_parser_t* parser, unsigned char c); |
---|
| 461 | |
---|
| 462 | /* midi file */ |
---|
| 463 | aubio_midi_file_t* new_aubio_midi_file(char* filename); |
---|
| 464 | void del_aubio_midi_file(aubio_midi_file_t* mf); |
---|
| 465 | int aubio_midi_file_read_mthd(aubio_midi_file_t* midifile); |
---|
| 466 | int aubio_midi_file_load_tracks(aubio_midi_file_t* midifile, aubio_midi_player_t* player); |
---|
| 467 | int aubio_midi_file_read_track(aubio_midi_file_t* mf, aubio_midi_player_t* player, int num); |
---|
| 468 | int aubio_midi_file_read_event(aubio_midi_file_t* mf, aubio_track_t* track); |
---|
| 469 | int aubio_midi_file_read_varlen(aubio_midi_file_t* mf); |
---|
| 470 | int aubio_midi_file_getc(aubio_midi_file_t* mf); |
---|
| 471 | int aubio_midi_file_push(aubio_midi_file_t* mf, int c); |
---|
| 472 | int aubio_midi_file_read(aubio_midi_file_t* mf, void* buf, int len); |
---|
| 473 | int aubio_midi_file_skip(aubio_midi_file_t* mf, int len); |
---|
| 474 | int aubio_midi_file_read_tracklen(aubio_midi_file_t* mf); |
---|
| 475 | int aubio_midi_file_eot(aubio_midi_file_t* mf); |
---|
| 476 | int aubio_midi_file_get_division(aubio_midi_file_t* midifile); |
---|
| 477 | |
---|
| 478 | |
---|
| 479 | /* midi driver */ |
---|
| 480 | aubio_midi_driver_t* new_aubio_midi_driver(char * name, |
---|
| 481 | handle_midi_event_func_t handler, void* event_handler_data); |
---|
| 482 | typedef int* (handle_midi_event_func_t) (void* data, aubio_midi_event_t* event); |
---|
| 483 | void del_aubio_midi_driver(aubio_midi_driver_t* driver); |
---|
| 484 | void aubio_midi_driver_settings(aubio_settings_t* settings); |
---|
| 485 | |
---|
| 486 | /* timer */ |
---|
| 487 | /* |
---|
| 488 | extern aubio_timer_t* new_aubio_timer(int msec, int * callback, |
---|
| 489 | void* data, int new_thread, int auto_destroy); |
---|
| 490 | extern int aubio_timer_join(aubio_timer_t* timer); |
---|
| 491 | extern int aubio_timer_stop(aubio_timer_t* timer); |
---|
| 492 | extern int delete_aubio_timer(aubio_timer_t* timer); |
---|
| 493 | extern void * aubio_timer_start(void * data); |
---|
| 494 | extern void aubio_time_config(void); |
---|
| 495 | */ |
---|
| 496 | |
---|
| 497 | /* list */ |
---|
| 498 | /* |
---|
| 499 | extern struct aubio_list_t* new_aubio_list(void); |
---|
| 500 | extern void del_aubio_list(struct aubio_list_t *list); |
---|
| 501 | extern void del_aubio_list1(struct aubio_list_t *list); |
---|
| 502 | #extern struct aubio_list_t* aubio_list_sort(struct aubio_list_t *list, aubio_compare_func_t compare_func); |
---|
| 503 | extern struct aubio_list_t* aubio_list_append(struct aubio_list_t *list, void* data); |
---|
| 504 | extern struct aubio_list_t* aubio_list_prepend(struct aubio_list_t *list, void* data); |
---|
| 505 | extern struct aubio_list_t* aubio_list_remove(struct aubio_list_t *list, void* data); |
---|
| 506 | extern struct aubio_list_t* aubio_list_remove_link(struct aubio_list_t *list, struct aubio_list_t *llink); |
---|
| 507 | extern struct aubio_list_t* aubio_list_nth(struct aubio_list_t *list, int n); |
---|
| 508 | extern struct aubio_list_t* aubio_list_last(struct aubio_list_t *list); |
---|
| 509 | extern struct aubio_list_t* aubio_list_insert_at(struct aubio_list_t *list, int n, void* data); |
---|
| 510 | */ |
---|