need help with the question
    1 visualización (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
This code is not working i am using this to calulate the amplitude  but i am getting this error 
Index exceeds matrix dimensions.
Error in t31 (line 11)
F1=Fmag(N/2+1:N);
l
load('data.mat');
dt=t(2)-t(1);% t vector has equally spaced t so this seprates t values
N=length(t);
F=fft(f,N); %fast fourier transform of f/N
Fshifted=fftshift(F);%place 0 frequency in the centre
Fmag=norm(Fshifted);%magnitude of fshifted 
nu_NY=1/dt/2;%nquist frequency 
nu=linspace(0,nu_NY,N/2+1);%spectrum of frequncy vals associated with FFT frequencies 
%adding postive and negative frequncies 
F1=Fmag(N/2+1:N);
F2=Fmag(N/2:-1:1);
a=[F1,0]+[0,F2];
%plotting amplitued vs assoicated frequencies
plot(a,nu)
4 comentarios
  per isakson
      
      
 el 16 de Abr. de 2019
				
      Editada: per isakson
      
      
 el 16 de Abr. de 2019
  
			Should it be indexing 
F1=Fmag(N/2+1:N);
as in the error message or a multiplication
F1=Fmag*(N/2+1:N);
as in the code ???
Respuestas (1)
  Walter Roberson
      
      
 el 16 de Abr. de 2019
        f is a vector. You fft it asking for an output the same length as it is, so F is a vector. fftshift of that is a vector. You then norm() that vector and assign the result to Fmag . norm() of a vector gives a scalar. Then on line 11, Fmag(N/2+1:N) is an attempt to index the scalar at a location that is not 1.
3 comentarios
Ver también
Categorías
				Más información sobre Fourier Analysis and Filtering en Help Center y File Exchange.
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!



