使用tarosdsp提取多个音频功能

时间:2019-04-04 19:02:02

标签: java audio mfcc

我正在使用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]

1 个答案:

答案 0 :(得分:0)

使用同一调度程序和新的AudioProcessor。