1.首先学习下傅里叶变换的东西。学高数的时候老师只是将傅里叶变换简单的说了下,并没有深入的讲解。而现在看来,傅里叶变换似乎是信号处理的方面的重点只是呢,现在就先学习学习傅里叶变换吧。

上面这幅图在知乎一个很著名的关于傅里叶变换的文章中的核心插图,我觉得这幅图很直观的就说明了傅里叶变换的实质。时域上的东西直观的反应到了频域上了,很完美的结合到了一起,233333.  无数正弦波叠加,震荡的叠加的最后结果竟然是方波,同理,任何周期性函数竟然都能拆分为傅里叶级数的形式,这样的简介与优雅,真令人折服。

2.MATLAB对信号做频谱分析

代码:(1)对 f1 = Sa(2t)的频谱分析

 clear;clc;
hold on;
R=0.05;
t=-1.2:R:1.2;
t1 = *t;
f1=sinc(t1); %Sa函数
subplot(,,),plot(t,f1)
xlabel('t'),ylabel('f1')
axis([-,,-0.3,1.2]); %写出Sa函数上下限 N=;
k=-N:N;
W1=;
W=k*W1/N;
F=f1*exp(-j*t'*W)*R; %f1的傅里叶变换
F=real(F); %取F的实部
subplot(,,),plot(W,F)
xlabel('W'),ylabel('F(jw)')

结果如下图:

(2)对 f2 = u(t+2) - u(t-2)的频谱分析

 R=0.05;
t=-:R:;
f2=(t>=-)-(t>=);
subplot(,,),plot(t,f2)
grid on;
xlabel('t'),ylabel('f2')
axis([-,,-0.5,1.5]); N=;k=-N:N;
W1=;
W=k*W1/N;
F=f2*exp(-j*t'*W)*R;
F=real(F);
subplot(,,),plot(W,F)
grid on;
xlabel('W'),ylabel('F(jw)')

结果如下图:

(3)对f3 = t[u(t+1) - u(t-1) ]的频谱分析

 R=0.05;
h=0.001;
t=-1.2:R:1.2;
y=t.*(t>=-)-t.*(t>=);
f4=diff(y)/h;
subplot(,,),plot(t,y)
xlabel('t'),ylabel('y')
axis([-1.2,1.2,-1.2,1.2]); N=;
k=-N:N;
W1=;
W=k*W1/N;
F=y*exp(-j*t'*W)*R;
F=real(F);
subplot(,,),plot(W,F)
xlabel('W'),ylabel('F(jw)')
axis([-,,-0.06,0.06]);

结果如下图:

(4)对正弦波做FFT频谱分析

 %*************************************************************************%
% FFT实践及频谱分析 %
%*************************************************************************%
%***************正弦波****************%
fs=;%设定采样频率
N=;
n=:N-;
t=n/fs;
f0=;%设定正弦信号频率
%生成正弦信号
x=sin(*pi*f0*t);
figure();
subplot();
plot(t,x);%作正弦信号的时域波形
xlabel('t');
ylabel('y');
title('正弦信号y=2*pi*10t时域波形');
grid; %进行FFT变换并做频谱图
y=fft(x,N);%进行fft变换
mag=abs(y);%求幅值
f=(:length(y)-)'*fs/length(y);%进行对应的频率转换
figure();
subplot();
plot(f,mag);%做频谱图
axis([,,,]);
xlabel('频率(Hz)');
ylabel('幅值');
title('正弦信号y=2*pi*10t幅频谱图N=128');
grid; %求均方根谱
sq=abs(y);
figure();
subplot();
plot(f,sq);
xlabel('频率(Hz)');
ylabel('均方根谱');
title('正弦信号y=2*pi*10t均方根谱');
grid; %求功率谱
power=sq.^;
figure();
subplot();
plot(f,power);
xlabel('频率(Hz)');
ylabel('功率谱');
title('正弦信号y=2*pi*10t功率谱');
grid; %求对数谱
ln=log(sq);
figure();
subplot();
plot(f,ln);
xlabel('频率(Hz)');
ylabel('对数谱');
title('正弦信号y=2*pi*10t对数谱');
grid; %用IFFT恢复原始信号
xifft=ifft(y);
magx=real(xifft);
ti=[:length(xifft)-]/fs;
figure();
subplot();
plot(ti,magx);
xlabel('t');
ylabel('y');
title('通过IFFT转换的正弦信号波形');
grid;

执行结果如下图:

(5)对矩形波做FFT频谱分析

 %****************.矩形波****************%
fs=;%设定采样频率
t=-:0.1:;
x=rectpuls(t,);
x=x(:);
figure();
subplot(); plot(t(:),x);%作矩形波的时域波形
xlabel('t');
ylabel('y');
title('矩形波时域波形');
grid; %进行FFT变换并做频谱图
y=fft(x);%进行fft变换
mag=abs(y);%求幅值
f=(:length(y)-)'*fs/length(y);%进行对应的频率转换
figure();
subplot();
plot(f,mag);%做频谱图
xlabel('频率(Hz)');
ylabel('幅值');
title('矩形波幅频谱图');
grid; %求均方根谱
sq=abs(y);
figure();
subplot();
plot(f,sq);
xlabel('频率(Hz)');
ylabel('均方根谱');
title('矩形波均方根谱');
grid; %求功率谱
power=sq.^;
figure();
subplot();
plot(f,power);
xlabel('频率(Hz)');
ylabel('功率谱');
title('矩形波功率谱');
grid; %求对数谱
ln=log(sq);
figure();
subplot();
plot(f,ln);
xlabel('频率(Hz)');
ylabel('对数谱');
title('矩形波对数谱');
grid; %用IFFT恢复原始信号
xifft=ifft(y);
magx=real(xifft);
ti=[:length(xifft)-]/fs;
figure();
subplot();
plot(ti,magx);
xlabel('t');
ylabel('y');
title('通过IFFT转换的矩形波波形');
grid;

执行结果如下图:

(6)对白噪声做频谱分析

 %****************.白噪声****************%
fs=;%设定采样频率
t=-:0.1:;
x=zeros(,);
x()=;
figure();
subplot();
plot(t(:),x);%作白噪声的时域波形
xlabel('t');
ylabel('y');
title('白噪声时域波形');
grid; %进行FFT变换并做频谱图
y=fft(x); %进行fft变换
mag=abs(y);%求幅值
f=(:length(y)-)'*fs/length(y);%进行对应的频率转换
figure();
subplot();
plot(f,mag);%做频谱图
xlabel('频率(Hz)');
ylabel('幅值');
title('白噪声幅频谱图');
grid; %求均方根谱
sq=abs(y);
figure();
subplot();
plot(f,sq);
xlabel('频率(Hz)');
ylabel('均方根谱');
title('白噪声均方根谱');
grid; %求功率谱
power=sq.^;
figure();
subplot();
plot(f,power);
xlabel('频率(Hz)');
ylabel('功率谱');
title('白噪声功率谱');
grid; %求对数谱
ln=log(sq);
figure();
subplot();
plot(f,ln);
xlabel('频率(Hz)');
ylabel('对数谱');
title('白噪声对数谱');
grid; %用IFFT恢复原始信号
xifft=ifft(y);
magx=real(xifft);
ti=[:length(xifft)-]/fs;
figure();
subplot();
plot(ti,magx);
xlabel('t');
ylabel('y');
title('通过IFFT转换的白噪声波形');
grid;

执行结果如下:

用MATLAB对信号做频谱分析的更多相关文章

  1. MATLAB信号与系统分析(五)——连续时间信号的频谱分析

    一.实验目的: 1.掌握傅立叶级数(FS),学会分析连续时间周期信号的频谱分析及MATLAB实现: 2.掌握傅立叶变换(FT),了解傅立叶变换的性质以及MATLAB实现. 二.利用符号运算求傅里叶级数 ...

  2. MATLAB实现连续周期信号的频谱分析(正余弦波信号举例)

    关于MATLAB实现连续信号的频谱分析,以正余弦波信号频谱分析为例分析如下: 1.含有频率f ,2f和3f的正弦波叠加信号,即: 其中,f =500Hz.试采用Matlab仿真软件对该信号进行频谱分析 ...

  3. MATLAB处理信号得到频谱、相谱、功率谱

    (此帖引至网络资源,仅供参考学习)第一:频谱 一.调用方法 X=FFT(x):X=FFT(x,N):x=IFFT(X);x=IFFT(X,N) 用MATLAB进行谱分析时注意: (1)函数FFT返回值 ...

  4. 一款DMA性能优化记录:异步传输和指定实时信号做async IO

    关键词:DMA.sync.async.SIGIO.F_SETSIG. DMA本身用于减轻CPU负担,进行CPU off-load搬运工作. 在DMA驱动内部实现有同步和异步模式,异步模式使用dma_a ...

  5. matlab 正弦信号产生

    fs=2400;%设定采样频率N=1000; %采样的点数n=0:N-1;t=n/fs; %1/fs相当于隔多长时间才一个点f1=50;%设定争先信号频率xn=sin(2*pi*f1*t);figur ...

  6. 余弦信号DFT频谱分析(继续)

    以前谈到序列的实际长度可以通过零填充方法加入,使得最终增加N添加表观分辨率. 但它并没有解决泄漏频率的问题. 根本原因在于泄漏窗口选择的频率. 由于矩形窗突然被切断,频谱旁瓣相对幅度过大,造成泄漏分量 ...

  7. 对AM信号FFT的matlab仿真

    普通调幅波AM的频谱,大信号包络检波频谱分析 u(t)=Ucm(1+macos t)cos ct ma称为调幅系数 它的频谱由载波,上下边频组成 , 包络检波中二极管截去负半周再用电容低通滤波,可 ...

  8. 小波变换检测信号突变点的MATLAB实现

    之前在不经意间也有接触过求突变点的问题.在我看来,与其说是求突变点,不如说是我们常常玩的"找不同".给你两幅图像,让你找出两个图像中不同的地方,我认为这其实也是找突变点在生活中的应 ...

  9. MATLAB—信号与系统中的应用

    文章目录 一. 理论知识 1.线性系统的响应 2.微分方程的解 Ⅰ.经典解 Ⅱ.完全响应 3.零输入响应 4.零状态响应 5.冲激响应 6.阶跃响应 7.卷积求零状态响应 二.连续信号的MATLAB描 ...

随机推荐

  1. System.Diagnostics.Process.Start的妙用

    我们经常会遇到在Winform或是WPF中点击链接或按钮打开某个指定的网址, 或者是需要打开电脑中某个指定的硬盘分区及文件夹, 甚至是"控制面板"相关的东西, 那么如何做呢? 答案 ...

  2. C++_系列自学课程_第_8_课_指针和引用_《C++ Primer 第四版》

    C语言最富有迷幻色彩的部分当属指针部分,无论是指针的定义还是指针的意义都可算是C语言中最复杂的内容.指针不但提供给了程序员直接操作硬件部分的操作接口,还提供给了程序员更多灵活的用法.C++继承这一高效 ...

  3. 从零开始学 Java - Windows 下安装 Tomcat

    谁都想分一杯羹 没有一个人是真正的无私到伟大的,我们试着说着做自己,与人为善,世界和平!殊不知,他们的真实目的当你知道后,你会被恶心到直摇头并下意识地迅速跑开,下辈子都不想见到他.不过,他没错,你也没 ...

  4. 【算法】PHP实现冒泡排序和快速排序--防遗忘

    有没有这样的感觉,排序算法虽然简单,但是没看过一次,一会就又忘了,所以有必要 自己使用实际的代码运行实现,才记忆牢固,为此Mark //需求:将数组中元素,从大到小排列$a = array(11, 2 ...

  5. MySQL 5.7:非结构化数据存储的新选择

    本文转载自:http://www.innomysql.net/article/23959.html (只作转载, 不代表本站和博主同意文中观点或证实文中信息) 工作10余年,没有一个版本能像MySQL ...

  6. 浅谈C# 多态的法力

    前言:我们都知道面向对象的三大特性:封装,继承,多态.封装和继承对于初学者而言比较好理解,但要理解多态,尤其是深入理解,初学者往往存在有很多困惑,为什么这样就可以?有时候感觉很不可思议,由此,面向对象 ...

  7. 单行文字滚动就用myslider

    单行文字滚动就用myslider,myslider是一个小型的内容滚动jquery插件. 首先请看实例:http://keleyi.com/jq/myslider/demo/4.htm 然后来看代码: ...

  8. AlloyRenderingEngine入门

    写在前面 AlloyRenderingEngine是一款非常快速的渲染引擎,目前该项目已经合并至 https://github.com/AlloyTeam/AlloyGameEngine/ , 属于A ...

  9. iOS中延时执行的几种方式的比较和汇总

    本文列举了四种延时执行某函数的方法及其一些区别.假如延时1秒时间执行下面的方法. - (void)delayMethod { NSLog(@"execute"); } 1.perf ...

  10. SAP RFC

    什么是RFC? RFC是SAP系统和其他(SAP或非SAP)系统间的一个重要而常用的双向接口技术,也被视为SAP与外部通信的基本协议.简单地说,RFC过程就是系统调用当前系统外的程序模块,从而实现某个 ...