フィルターのクリア

What should be FFT of a constant function?

12 ビュー (過去 30 日間)
Richa Sharma
Richa Sharma 2012 年 12 月 11 日
As per theory,FFT of a constant fn. is a DC value. But when I take an array 'A' of ones of size 172, i.e. A[1 1 1 1 1.....172 times]
FFT(A)
gives DC as well as AC cofts. Why?
  2 件のコメント
Azzi Abdelmalek
Azzi Abdelmalek 2012 年 12 月 11 日
What do you mean by AC coefts?
Image Analyst
Image Analyst 2012 年 12 月 11 日
The FFT breaks up the signal into a weighted sum of sinusoidal signals. Any point in an FFT not at the center is the weight (coefficient) of one of the sinusoidal signals that goes into making up the final signal. The center frequency is flat (no sinusoid) and is often called the DC component.

サインインしてコメントする。

採用された回答

Walter Roberson
Walter Roberson 2012 年 12 月 11 日
Round-off error in the calculations. Look at the magnitudes: everything is down near 10E-15
  3 件のコメント
Muthu Annamalai
Muthu Annamalai 2012 年 12 月 11 日
You have the details right, Image Analyst; while the rest of the comments are only partly true.
Image Analyst
Image Analyst 2012 年 12 月 11 日
If you're interested in seeing the sinc effect, I posted some nice demo code here: http://www.mathworks.com/matlabcentral/answers/56139#comment_116309

サインインしてコメントする。

その他の回答 (1 件)

Azzi Abdelmalek
Azzi Abdelmalek 2012 年 12 月 11 日
編集済み: Azzi Abdelmalek 2012 年 12 月 11 日
If you mean by AC, sinusoidal signal, when you calculate its FFT, it's important to define the interval. To give a sens to your FFT, you have to calculate it in one period. For the sinusoidal signal, the period is 2*pi, then theoretically, the result will be one value at k=1 and not at k=0 like in a constant signal.
t=0:.1:2*pi-0.1;
g=fft(sin(t));
stem(abs(g))
For a constant the result will be a constant for k=0; and 0 elsewhere
h=ones(1,length(t))
figure;
stem(abs(fft(h)))
  1 件のコメント
Richa Sharma
Richa Sharma 2012 年 12 月 12 日
Thank You very much for your response. Actually, my inputs are digital images.I was trying to check the fft response for constant background in images. I am going for 1D FFT in matlab. Say, my image is I and I write J=FFT(I) Then,for constant background in I, first coft. in columns of J should have high coft. value, the rest should be zeros is what I was expecting.But I was getting nonzero cofts for other frequency bins also.I think it is due to Round-off error in the calculations as Roberson said.Kindly correct me if I am wrong. Regards

サインインしてコメントする。

カテゴリ

Help Center および File ExchangeMultirate Signal Processing についてさらに検索

タグ

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by