1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
use libc::{c_void, c_int, c_float, c_double}; pub type FFTSample = c_float; #[derive(Debug)] #[repr(C)] pub struct FFTComplex { re: FFTSample, im: FFTSample, } pub type FFTContext = c_void; #[derive(Eq, PartialEq, Copy, Clone, Debug)] #[repr(C)] pub enum RDFTransformType { DFT_R2C, IDFT_C2R, IDFT_R2C, DFT_C2R, } pub type RDFTContext = c_void; #[derive(Eq, PartialEq, Copy, Clone, Debug)] #[repr(C)] pub enum DCTTransformType { DCT_II = 0, DCT_III, DCT_I, DST_I, } pub type DCTContext = c_void; extern { pub fn av_fft_init(nbits: c_int, inverse: c_int) -> *mut FFTContext; pub fn av_fft_permute(s: *mut FFTContext, z: *mut FFTComplex); pub fn av_fft_calc(s: *mut FFTContext, z: *mut FFTComplex); pub fn av_fft_end(s: *mut FFTContext); pub fn av_mdct_init(nbits: c_int, inverse: c_int, scale: c_double) -> *mut FFTContext; pub fn av_imdct_calc(s: *mut FFTContext, output: *mut FFTSample, input: *const FFTSample); pub fn av_imdct_half(s: *mut FFTContext, output: *mut FFTSample, input: *const FFTSample); pub fn av_mdct_calc(s: *mut FFTContext, output: *mut FFTSample, input: *const FFTSample); pub fn av_mdct_end(s: *mut FFTContext); pub fn av_rdft_init(nbits: c_int, trans: RDFTransformType) -> *mut RDFTContext; pub fn av_rdft_calc(s: *mut RDFTContext, data: *mut FFTSample); pub fn av_rdft_end(s: *mut RDFTContext); pub fn av_dct_init(nbits: c_int, kind: DCTTransformType) -> *mut DCTContext; pub fn av_dct_calc(s: *mut DCTContext, data: *mut FFTSample); pub fn av_dct_end(s: *mut DCTContext); }