Custom FFT Function generates "Insufficient Number of Outputs"
2 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
Can someone help me determine why l'm getting this message? My Custom FFT Code:
function [X, freq] = centeredFFT(x,Fs)
N = length(x);
if mod(N,2)==0
k = -N/2:N/2-1;
else
k = -(N-1)/2:(N-1)/2;
end
T = N/Fs;
freq = k/T;
X = fft(x)/N;
X = fftshift(X);
end
My Double sided Frequency Spectrum Plot Code:
fo = 2000;
fp = 10000;
Fs = 4000;
Ts = 1/Fs;
t = 0:Ts:1-Ts;
s = (10 + cos(2*pi*fo*t)).*(cos(2*pi*fp*t));
[SfreqDomain,frequencyRange] = centeredFFT(s,Fs);
centeredFFT = figure;
stem(frequencyRange,abs(SfreqDomain));
grid on;
axis(-5,5,0,5);
Thank you for the assistance. Edited for typo.
[SL: edited to apply code formatting]
2 Commenti
David Goodmanson
il 8 Mar 2017
Hi Derrick This looks a lot like a case of defining centeredFFT = (something), somewhere in your script. Them Matlab doesn't recognize it as a function anymore and you get that kind of error message. I don't know the intent of the statement
enteredFFT = figure;
and if it is a typo for
centeredFFT = figure;
I would not know the intent of that either. But if the latter statement or something like it got executed, your function dies.
Risposte (1)
Brandon Eidson
il 15 Mar 2017
Hey Derrick, the only error I immediately see in your code is with your use of the "axis" command; you left off the brackets. That line should be as follows.
axis([-5,5,0,5]);
However, I am not sure if there is a case where that would produce the error "insufficient number of outputs". Making the above change allowed me to execute your provided code without error. If after changing the call to "axis" you are still getting an error, please provide more information about your workflow.
David did point out something helpful. The command
centeredFFT = figure;
will create the variable "centeredFFT" and store in it a function handle. But "centeredFFT" is the name of your custom. This type of naming convention is not recommended.
0 Commenti
Vedere anche
Categorie
Scopri di più su Fourier Analysis and Filtering in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!