What is the problem in this code?

2 visualizzazioni (ultimi 30 giorni)
f0=100;
f=(0:f0/40:f0*2);
Ts=1/fs;
n=0:8;
xs = 5*cos(2*pi*f0*n*Ts);
i=fft(xs);
plot(f,abs(i(1:81)))
  1 Commento
Hassan Ali Shah
Hassan Ali Shah il 2 Gen 2015
it gives the error Index exceeds matrix dimensions.
Error in Untitled (line 7) plot(n,abs(i(1:81)));

Accedi per commentare.

Risposta accettata

Shoaibur Rahman
Shoaibur Rahman il 2 Gen 2015
Modificato: Shoaibur Rahman il 2 Gen 2015
Your n has a length of 9, as n=0:8, so i will have length of 9 as well,and hence, you cannot write i(1:81). There are many ways to solve this. Here is one: replace n = 0:8 by n = linspace(0,8,length(f)). This will make both f and i of same length.
Also, although plot(f,abs(i(1:81))) works fine, but you can simply use plot(f,abs(i))
Another way may be: keep everything same, but write i = fft(xs,length(f)) . This will perform 81 point fft on xs. Again, you can use plot(f,abs(i))
  1 Commento
Hassan Ali Shah
Hassan Ali Shah il 2 Gen 2015
thanks dear. it worked.though both the ways are doing good,but your "another way" suits me more. thanks alot

Accedi per commentare.

Più risposte (0)

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!

Translated by