| | |
| |
|
| | use criterion::{black_box, criterion_group, criterion_main, Criterion}; |
| | use indextts::audio::{mel_spectrogram, AudioConfig}; |
| |
|
| | fn bench_mel_spectrogram(c: &mut Criterion) { |
| | let config = AudioConfig::default(); |
| |
|
| | |
| | let num_samples = config.sample_rate as usize; |
| | let signal: Vec<f32> = (0..num_samples).map(|i| (i as f32 * 0.01).sin()).collect(); |
| |
|
| | c.bench_function("mel_spectrogram_1s", |b| { |
| | b.iter(|| mel_spectrogram(black_box(&signal), black_box(&config))) |
| | }); |
| |
|
| | |
| | let long_signal: Vec<f32> = (0..num_samples * 10) |
| | .map(|i| (i as f32 * 0.01).sin()) |
| | .collect(); |
| |
|
| | c.bench_function("mel_spectrogram_10s", |b| { |
| | b.iter(|| mel_spectrogram(black_box(&long_signal), black_box(&config))) |
| | }); |
| | } |
| |
|
| | fn bench_stft(c: &mut Criterion) { |
| | let config = AudioConfig::default(); |
| | let num_samples = config.sample_rate as usize; |
| | let signal: Vec<f32> = (0..num_samples).map(|i| (i as f32 * 0.01).sin()).collect(); |
| |
|
| | c.bench_function("stft_1s", |b| { |
| | b.iter(|| { |
| | indextts::audio::mel::stft( |
| | black_box(&signal), |
| | black_box(config.n_fft), |
| | black_box(config.hop_length), |
| | black_box(config.win_length), |
| | ) |
| | }) |
| | }); |
| | } |
| |
|
| | criterion_group!(benches, bench_mel_spectrogram, bench_stft); |
| | criterion_main!(benches); |
| |
|