我正在使用tarosdsp从音频中提取特征。我已经能够提取mfcc功能。要提取其他特征,例如零交叉率,音高,我需要定义新的音频分配器,还是应该使用相同的分配器并添加音频处理器。一个例子会有所帮助。
我可以分别针对mfcc和pitch
final List<float[]>mfccList = new ArrayList<>(200);
String file3= source+'/'+file2.getName();
int sampleRate = 44100;
int bufferSize = 8192;
int bufferOverlap = 128;
AudioDispatcher dispatcher = AudioDispatcherFactory.fromPipe(file3, sampleRate,bufferSize, bufferOverlap);
final MFCC mfcc = new MFCC(bufferSize, sampleRate, 40, 50, 300, 3000);
dispatcher.addAudioProcessor(mfcc);
dispatcher.addAudioProcessor(new AudioProcessor() {
@Override
public void processingFinished() {
}
@Override
public boolean process(AudioEvent audioEvent) {
mfcc.process(audioEvent);
//final float audio_float[] = mfcc.getMFCC();
audio_float=mfcc.getMFCC();
//mfccList.add( mfcc.getMFCC());
System.out.print(Arrays.toString(audio_float));
我想将数组中的所有功能另存为[mfcc,pitch,zcr]
答案 0 :(得分:0)
使用同一调度程序和新的AudioProcessor。