fft(matlab)2

1.

Fs=1000;
N=1000;
n=0:N-1;
t=n/Fs;
x=sin(2*pi*50*t)+sin(2*pi*120*t)+rand(1,N);
y=abs(fft(x,N));
f=n*Fs/N;
subplot(211);
plot(f,y);

2.

fs=1*10^6;
t=0:1/fs:255/fs;
f1=200*10^3;
f2=400*10^3;

s1=sin(2*pi*f1*t);
s2=sin(2*pi*f2*t);

s=s1+s2;

N=256;

a=(abs(fft(s,N)));

fn=0:N-1;
fn=fn/N*fs;

stem(fn,a);

3.

hn=st
f1=200;  %200Hz
f2=800;  %800Hz
fs=2000; %2000Hz
t=0:1/fs:511/fs;  
s=sin(2*pi*f1*t)+sin(2*pi*f2*t); %叠加信号
N1=512;
a=abs(fft(s,N1));
y=filter(hn,1,s);
xh=0:(fs/length(a)):fs/2;
subplot(311)
plot(t,s)
subplot(312)
plot(t,y);
subplot(313)
plot(xh,a(1:length(xh)));

s=s/max(abs(s));
da=round(s*2047);
N=12;
fid=fopen('d:\data.txt','w');
for i=1:length(da)
 da1=dec2bin(da(i)+(da(i)<0)*2^N,N)   
  for j=1:N
      if da1(j)=='1'
       tb=1;
      else 
       tb=0;
      end
      fprintf(fid,'%d',tb);
  end
     fprintf(fid,'\r\n');
end
  fprintf(fid,':');
  fclose(fid);
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2D-FFT(二维快速傅里叶变换)是一种常用的信号处理技术,在MATLAB中可以通过使用fft2函数来实现。 MATLAB中的fft2函数可以对二维信号进行傅里叶变换。它将输入的二维信号作为输入,并将其转换为频域表示。频域表示结果是一个与原信号具有相同大小的复数矩阵。 使用fft2函数的语法如下: Y = fft2(X) 其中,X为输入的二维原始信号,Y为得到的频域表示结果。 以一个简单的例子说明如何使用MATLAB中的fft2函数。假设有一个5x5的二维信号矩阵X,其中存储了信号的时域表示。我们可以通过以下代码使用fft2函数来计算该信号的频域表示(复数矩阵Y): X = rand(5,5); % 创建一个随机的5x5信号矩阵 Y = fft2(X); % 计算信号的频域表示 计算结果Y是一个5x5的复数矩阵,它包含了信号在频域中的幅度和相位信息。我们可以通过取其实部或虚部来查看幅度或相位信息。例如,我们可以使用以下代码分别获取频域表示的幅度和相位信息: amplitude = abs(Y); % 获取频域表示的幅度信息 phase = angle(Y); % 获取频域表示的相位信息 通过对二维信号进行傅里叶变换,我们可以在频域中对信号进行分析和处理。例如,可以使用fft2函数进行频域滤波、频谱分析、图像增强等操作。 总之,MATLAB中的fft2函数可以用于对二维信号进行傅里叶变换,将信号从时域转换为频域。这种技术可以用于许多信号处理应用,如图像处理、语音处理等领域。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值