Why do I get "The number of requested coefficients must be equal to or less than 0" ?
조회 수: 4 (최근 30일)
이전 댓글 표시
Hi everyone,
I'm trying to compute the MELF coefficients of an audio file and with MATLAB's defect configuration I get this error:
Error using mfcc>iValidateBandEdges (line 360)
The number of requested coefficients must be equal to or less than 0.
Error in mfcc (line 129)
iValidateBandEdges(fs,options.BandEdges,options.NumCoeffs);
Error in pruebasAudio (line 63)
coeffs = mfcc(audioIn,fs);
This is the code I'm using:
dir = "Audios\00000798.aif";
[audioIn,fs] = audioread(dir);
coeffs = mfcc(audioIn,fs);
And the variables I obtain with the audioread function are:
audioIn => 75792x1 double
fs => 250
How can I solve this issue?
Thanks in advance.
댓글 수: 1
채택된 답변
MathWorks Audio Toolbox Team
2024년 12월 4일
편집: MathWorks Audio Toolbox Team
2024년 12월 4일
Your sample rate is so low that not even the first of the default bandpass filters fall within range. Could you say what kind of audio this is? It will help us cover your use case in the future.
You have a number of options.
- Modify the BandEdges option of mfcc. The default first band edge starts at ~133 Hz to follow the popular Slaney implementation. When modifying, you're using the o-shaughnessy mel formula and just fitting the requested number of mel bands.
- Use audioFeatureExtractor. By default, audioFeatureExtractor uses the o-shaughnessy mel formula, so it will automatically "just work". You will need to modify the Window, overlap length, and fftlength to fit the lower sample rate though. Other modified parameters in the example below are just to show equivalency between the two methods.
- Use the low-level building blocks: designAuditoryFitlerBank, stft, and cepstralCoefficients. Or melSpectrogram + cepstralCoeffiencts.
Here's an example of the first two options:
%% Option 1, use the BandEdges option of mfcc
fs = 250;
audioIn = rand(75792,1);
b = hz2mel([0,124]);
numBands = 16;
melVect = linspace(b(1),b(2),numBands+2);
hzVect = mel2hz(melVect);
melc1 = mfcc(audioIn,fs,BandEdges=hzVect,LogEnergy="ignore");% ignoring log-energy to show equivalency with next option
%% Option 2, use audioFeatureExtractor
afe = audioFeatureExtractor(SampleRate=fs,mfcc=true, ...
Window=hamming(round(0.03*fs),'periodic'), ... % These are defaults of mfcc--probably don't make sense for your signal
OverlapLength=round(0.02*fs), ... % These are defaults of mfcc--probably don't make sense for your signal
FFTLength=round(0.03*fs)); % These are defaults of mfcc--probably don't make sense for your signal
setExtractorParameters(afe,"melSpectrum", ...
SpectrumType="magnitude", ...
WindowNormalization=false, ...
FilterBankDesignDomain="linear", ...
FilterBankNormalization="bandwidth", ...
NumBands=numBands, ...
FrequencyRange=[0,124])
melc2 = extract(afe,audioIn);
Given the very small sample rate you're using, I'm not sure that mfcc would be the best option for feature extraction for you. Certainly the default Window, OverlapLength, and FFTLength will need to be modified to suite your application.
추가 답변 (0개)
참고 항목
카테고리
Help Center 및 File Exchange에서 Audio Processing Algorithm Design에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!