连续时间信号的频谱分析仪.docx

上传人:b****5 文档编号:30758965 上传时间:2023-08-20 格式:DOCX 页数:22 大小:193.86KB
下载 相关 举报
连续时间信号的频谱分析仪.docx_第1页
第1页 / 共22页
连续时间信号的频谱分析仪.docx_第2页
第2页 / 共22页
连续时间信号的频谱分析仪.docx_第3页
第3页 / 共22页
连续时间信号的频谱分析仪.docx_第4页
第4页 / 共22页
连续时间信号的频谱分析仪.docx_第5页
第5页 / 共22页
点击查看更多>>
下载资源
资源描述

连续时间信号的频谱分析仪.docx

《连续时间信号的频谱分析仪.docx》由会员分享,可在线阅读,更多相关《连续时间信号的频谱分析仪.docx(22页珍藏版)》请在冰豆网上搜索。

连续时间信号的频谱分析仪.docx

连续时间信号的频谱分析仪

郑州轻工业学院

课程设计说明书

题目:

基于MATLAB的连续时间信号的频域分析

姓名:

院(系):

电气信息工程学院

专业班级:

学号:

指导教师:

 

成绩:

 

 

郑州轻工业学院

课程设计任务书

题目基于MATLAB的连续时间信号的频域分析

专业、班级学号姓名

主要内容、基本要求、主要参考资料等:

主要内容:

利用MATLAB的图形处理功能、符号运算功能和数值计算功能,实现对连续时间信号的频域分析的MATLAB仿真,并绘制相应的信号频谱。

基本要求:

1、利用MATLAB绘制单位冲激信号、单位阶跃信号、实指数信号、正弦信号、非周期矩形脉冲信号和非周期三角波脉冲信号的频谱,并进行相应的频域分析。

2、利用MATLAB绘制周期方波信号、周期锯齿波信号和周期三角波信号的频谱,并进行相应的频域分析。

主要参考资料:

1、《信号与线性系统分析(第4版)》,吴大正等著,高等教育出版社,2008。

2、《数字信号处理教程——MATLAB释义与实现(第2版)》,陈怀琛著,电子工业出版社,2008。

3、《MATLAB及在电子信息课程中的应用(第4版)》,陈怀琛等著,电子工业出版社,2013。

 

完成期限:

2014.06.09~2014.06.13

指导教师签名:

课程负责人签名:

2014年6月6日

目录

摘要1

1绪论2

2傅里叶变换原理4

3基于MATLAB的连续时间信号频域分析5

3.1单位冲激信号时域波形图、频谱图5

3.2单位阶跃信号时域波形图、频谱图6

3.3实指数信号时域波形图、频谱图8

3.4正弦信号时域波形图、频谱图9

3.5非周期矩形脉冲信号时域波形图、频谱图11

3.6非周期三角波脉冲信号时域波形、频谱图12

3.7周期方波信号时域波形、频谱图13

3.8周期锯齿波信号时域波形、频谱图15

3.9周期三角波信号时域波形、频谱图16

结束语19

致谢20

参考文献21

基于MATLAB的连续时间信号的频域分析

摘要

随着时代的发展,人们对于广告的要求已经不再是那些平面上的画面。

由于人们真实所接触的东西都是三维立体的,因而人们也更希望广告也能给与他们真实的触感。

从而计算机图形设计的软件也越来越多。

 

专门用来进行绘图的软件有很多,例如,Photoshop,Clodraw,AutoCAD等。

另外还有些软件,如Flash,3D MAX,Maya等,除了能够完成绘图与建模外,还提供了强大的动画制作功能。

除了这些专用软件,诸多的语言也提供了画图工具,提供了用来制作动画的函数。

 

MATLAB是矩阵实验室(matrix laboratory)之意。

除具备卓越的数值计算能力外,它还提供了专业水平的符号计算,文字处理,可视化建模仿真和实时控制等功能。

经过不断完善,MATLAB已经发展成为适合多学科,多种工作平台的功能强大的大型软件。

由于MATLAB提供了三维绘制函数,而且是基于矩阵的,同时还在图形窗口上和语言中都提供了变换视点等功能,可以直接的从各个角度观察绘制出的三维物体。

本文要讲的就是如何用MATLAB语言来绘制三维图形和动画设计。

关键字三维立体广告/计算机图形/绘图/MATLAB语言

1.绪论

在科学技术飞速发展的今天,计算机正扮演着愈来愈重要的角色。

在进行科学研究与工程应用的过程中,科技人员往往会遇到大量繁重的数学运算和数值分析,传统的高级语言Basic、Fortran及C语言等虽然能在一定程度上减轻计算量,但它们均用人员具有较强的编程能力和对算法有深入的研究。

MATLAB是matrix&laboratory两个词的组合,意为矩阵工厂(矩阵实验室)。

MATLAB工作界面是由美国mathworks公司发布的主要面对科学计算、可视化以及交互式程序设计的高科技计算环境。

它将数值分析、矩阵计算、科学数据可视化以及非线性动态系统的建模和仿真等诸多强大功能集成在一个易于使用的视窗环境中,为科学研究、工程设计以及必须进行有效数值计算的众多科学领域提供了一种全面的解决方案,并在很大程度上摆脱了传统非交互式程序设计语言(如C、Fortran)的编辑模式,代表了当今国际科学计算软件的先进水平。

MATLAB和Mathematica、Maple并称为三大数学软件。

它在数学类科技应用软件中在数值计算方面首屈一指。

MATLAB可以进行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序等,主要应用于工程计算、控制设计、信号处理与通讯、图像处理、信号检测、金融建模设计与分析等领域。

正是由于MATLAB在数值计算及符号计算等方面的强大功能使MATLAB一路领先成为数学类科技应用软件中的佼佼者。

目前MATLAB已成为国际上公认的最优秀的科技应用软件。

了解MATLAB在电子信息工程课程中的应用熟练掌握信号的各类变换域的分析方法理解傅里叶级数傅里叶变换、拉氏变换、Z变换的定义和性质可以利用MATLAB软件编写函数实现各种变换通过修改参数生产曲线进而分析参数变化对各类信号曲线的影响熟悉MATLAB语言的使用掌握MATLAB矩阵输入、运算以及数字MATLAB数值的运算功能。

MATLAB的主要功能是用于矩阵运算,它具有丰富的矩阵运算函数能够在求解诸如各种复杂计算问题是时显得简捷、高效、方便。

同时MATLBA作为编程语言和可视化工具由于功能强大界面直观语言自然使用方便可解决工程、科学计算和数学学科中许多问题是目前高等院校与科研院所广泛使用的优秀应用软件,目前已经在信号处理、系统识别、自动控制、非线性系统、模糊控制、优化技术、神经网络、小波分析等领域得到了广泛的应用。

MATLAB之所以能得到广泛的应用是因为它具有如下的特点

●高质量和强大的数值计算功能

●有大量事先定义的数学函数,并且又很强的用户自定义函数的能力

●强大的符号计算功能

●灵活的程序接口功能

●强大的非线性动态系统建模和仿真功能

●能与其他语言编写的程序结合,具有输入输出格式化数据的能力

●数值分析和科学计算可视化功能

●有在多个应用领域解决难题的工具箱

●功能强大可扩展性强

●界面友好编程效率高

●有强大的绘图功能,可方便地输出复杂的二维、三维图形

●较强的文字处理功能

●在线帮助􀌉有利于自学。

此外,MATLAB还具有支持科学计算标准的开放式可扩充结构和跨平台兼容得特点,能够很好地解决科学和工程领域内的复杂问题。

MATLAB语言已经成为科学计算、系统仿真、信号与图像处理的主流软件。

2.傅里叶变换原理

设有连续时间周期信号

,它的周期为T,角频率

,且满足狄里赫利条件,则该周期信号可以展开成傅里叶级数,即可表示为一系列不同频率的正弦或复指数信号之和。

傅里叶级数有三角形式和指数形式两种

1.三角形式的傅里叶级数:

(2—1)

式中系数

称为傅里叶系数,可由下式求得:

(2—2)

2.指数形式的傅里叶级数:

(2—3)

式中系数

称为傅里叶复系数,可由下式求得:

(2—4)

周期信号频谱具有三个特点[1]:

(1)离散性,即谱线是离散的;

(2)谐波性,即谱线只出现在基波频率的整数倍上;

(3)收敛性,即谐波的幅度随谐波次数的增高而减小。

周期信号的傅里叶分解用Matlab进行计算时,本质上是对信号进行数值积分运算。

在Matlab中有多种进行数值积分运算的方法,我们采用quadl函数,它有两种其调用形式。

y=quadl(‘func’,a,b)其中func是一个字符串,表示被积函数的.m文件名(函数名);a、b分别表示定积分的下限和上限。

3.基于MATLAB的连续时间信号频域分析

3.1单位冲激信号时域波形图、频谱图

(3—1)

"单位冲激函数"是“信号与系统”学科中的一个重要概念。

它是一个“面积”等于1的理想化了的窄脉冲。

也就是说,这个脉冲的幅度等于它的宽度的倒数。

当这个脉冲的宽度愈来愈小时,它的幅度就愈来愈大。

当它的宽度按照数学上极限法则趋近于零时,那么它的幅度就趋近于无限大,这样的一个脉冲就是“单位冲激函数”。

在实际工程中,像“单位冲激函数”这样的信号是不存在的,至多也就是近似而已。

在理论上定义这样一个函数,完全是为了分析研究方便的需要。

单位冲激函数又称为狄拉克函数,它具有选择性。

程序

clearall;

closeall;

N=1024;

t0=0;

f0=10;

fs=50;T=1/fs;

t=(0:

N-1)*T;

x=[(t-t0)==0];

subplot(3,1,1);

plot(t,x);xlabel('n');gridon;

k=(-N/2:

N/2-1)*fs/N;

y1=fftshift(fft(x));

aw1=abs(y1);

subplot(3,1,2);plot(k,aw1);grid;

aw2=angle(y1);

subplot(3,1,3);plot(k,aw2);grid;

图3.1单位冲激函数时域、频谱

3.2单位阶跃信号时域波形图、频谱图

(3—2)

单位阶跃信号是指在t<0的时候,信号量恒为0,在t>0的时候,信号量恒为1。

它是一种理想化的模型,因为在实际中,信号总是连续的,不可能在0点出现这样的“突变”.但是,建立这样一种模型,可以使我们分析的问题大为简化,抓住了主要因素,忽略了次要因素。

同时,建立这样一种简化的模型,有利于我们的学习,由浅入深,刚开始学习的时候不要考虑的太复杂。

其中阶跃响应的表示符号为s(t)。

程序:

clearall;

closeall;

N=1024;

t0=0;

f0=10;

fs=50;T=1/fs;

t=(0:

N-1)*T;

x=[t>=0];

subplot(3,1,1);

plot(t,x);xlabel('n');gridon;

k=(-N/2:

N/2-1)*fs/N;

y1=fftshift(fft(x));

aw1=abs(y1);

subplot(3,1,2);plot(k,aw1);grid;

aw2=angle(y1);

subplot(3,1,3);plot(k,aw2);grid;

图3.2单位阶跃信号时域、频谱图

3.3实指数信号时域波形图、频谱图

(3—3)

正弦信号是频率成分最为单一的一种信号,因这种信号的波形是数学上的正弦曲线而得名。

任何复杂信号——例如音乐信号,都可以通过傅里叶变换分解为许多频率不同、幅度不等的正弦信号的迭加。

程序:

clearall;

closeall;

T=0.1;N=100;D=2*pi/(N*T);

n=0:

N-1;x=exp(-0.1*n*T);

subplot(3,1,1);

plot(n,x);

Xa=T*fftshift(fft(x));

k=floor(-(N-1)/2:

(N-1)/2);

Xa

(1),subplot(3,1,2);

plot(k*D,abs(Xa));

subplot(3,1,3);

plot(k*D,angle(Xa));

图3.3实指数信号时域、频谱

3.4正弦信号时域波形图、频谱图

(3—4)

正弦信号是频率成分最为单一的一种信号,因这种信号的波形是数学上的正弦曲线而得名。

任何复杂信号——例如音乐信号,都可以通过傅里叶变换分解为许多频率不同、幅度不等的正弦信号的迭加。

程序:

clearall;

closeall;

N=512;

f0=10;

fs=50;T=1/fs;

t=linspace(-1,1,N);

x=sin(2*pi*f0*t);

subplot(3,1,1);

plot(t,x);xlabel('n');gridon;

k=(-N/2:

N/2-1)*fs/N;

y1=fftshift(fft(x));

aw1=abs(y1);

subplot(3,1,2);stem(k,aw1);grid;

subplot(3,1,3);plot(k,angle(y1));

图3.4正弦信号时域、频谱

3.5非周期矩形脉冲信号时域波形图、频谱图

(3—5)

产生一个周期为2,以t=2为对称轴的矩形波

程序:

closeall;

closeall;

t=0:

0.001:

4;

T=1;

y=rectpuls(t-2*T,2*T);

subplot(3,1,1);

plot(t,y,'b');

axis([-6,6,0,1.5]);

holdon

wf=20;

Nf=40;

w1=linspace(0,wf,Nf);dw=wf/(Nf-1);

F1=y*exp(-j*t'*w1)*0.001;

w=[-fliplr(w1),w1(2:

Nf)];

F=[fliplr(F1),F1(2:

Nf)];

%figure

(2)

subplot(3,1,2);

plot(w,abs(F),'linewidth',1.5)

subplot(3,1,3);

plot(w,angle(F));

图3.5非周期矩形脉冲信号时域、频谱

3.6非周期三角波脉冲信号时域波形、频谱图

(3—6)

产生以t=0,周期为4的三角波

程序:

T=4;

s=100000;

x=-6:

1/s:

6;

d=4;

y=tripuls(x,d,0.5);

subplot(3,1,1);

plot(x,y,'b');

axis([-4,4,0,1.5]);

holdon

wf=20;

Nf=40;

w1=linspace(0,wf,Nf);dw=wf/(Nf-1);

F1=y*exp(-j*x'*w1)*0.001;

w=[-fliplr(w1),w1(2:

Nf)];

F=[fliplr(F1),F1(2:

Nf)];

%figure

(2)

subplot(3,1,2);

plot(w,abs(F),'linewidth',1.5)

subplot(3,1,3);

plot(w,angle(F));

图3.6非周期三角波脉冲信号时域、频谱

3.7周期方波信号时域波形、频谱图

已知周期为T=2π,幅值为±1的周期性的方波信号,频率为10,占空比50%。

程序:

clearall;

closeall;

N=1024;

f0=10;

fs=30;

t=linspace(-1,1,N);

y=square(2*pi*10*t,50);%由函数生成锯齿波

axis([07*pi-1.51.5]);%规定尺度距离

subplot(3,1,1);

plot(t,y);%画出横轴为t纵轴为y的锯齿函数

xlabel('t');%为x轴添加标签

ylabel('幅度y');%为y轴添加标签

axis([-0.50.502]);

k=(-N/2:

N/2-1)*fs/N;

y1=fftshift(fft(y));

y2=y1*2/N;

aw1=abs(y2);

subplot(3,1,2);

stem(k,aw1);

aw2=angle(y2);

subplot(3,1,3);

stem(k,aw2);

grid;

图3.7周期方波信号时域、频谱

3.8周期锯齿波信号时域波形、频谱图

产生周期为0.2的三角波width取值1

程序:

clearall;

closeall;

N=1024;

f0=10;

fs=50;

t=linspace(-3,3,N)

y=sawtooth(2*pi*5*t,1);%由函数生成锯齿波

axis([07*pi-1.51.5]);%规定尺度距离

subplot(3,1,1);

plot(t,y);%画出横轴为t纵轴为y的锯齿函数

xlabel('t');%为x轴添加标签

ylabel('幅度y');%为y轴添加标签

axis([-1102]);

k=(-N/2:

N/2-1)*fs/N;

y1=fftshift(fft(y));

y2=y1*2/N;

aw1=abs(y2);

subplot(3,1,2);

stem(k,aw1);

aw2=angle(y2);

subplot(3,1,3);

stem(k,aw2);

grid;

图3.8周期锯齿波信号时域、频谱

3.9周期三角波信号时域波形、频谱图

产生一个宽度为4,周期为4的三角波

程序:

T=4;

x=-50:

0.002:

50;

d=-20:

T:

20;

y=pulstran(x,d,'tripuls',4);

subplot(3,1,1);

plot(x,y,'b');

axis([-6,6,0,1.5]);

title('三角波信号')

holdon

wf=20;

Nf=40;

w1=linspace(0,wf,Nf);dw=wf/(Nf-1);

F1=y*exp(-j*x'*w1)*0.001;

w=[-fliplr(w1),w1(2:

Nf)];

F=[fliplr(F1),F1(2:

Nf)];

%figure

(2)

subplot(3,1,2);

stem(w,abs(F),'linewidth',1.5)

subplot(3,1,3);

stem(w,angle(F),'linewidth',1.5)

title('频谱图')

图3.9周期三角波信号时域、频谱

结束语

通过这次课设,给我一个方向。

Matlab语言,初看起来不那么顺眼,但是一个小小的plot就能画出那么形象生动的sinx波形,这时我才明白,课本上的那些复杂的波形都可以通过matlab画出,刚开始写程序的确很痛苦,因为matlab的界面不是那么友好,字体,标记不如其它编译软件那么顺手,后来更改了字体和编辑工具,感觉对matlab的兴趣有如对Fpga一般。

初学都是很痛苦的,需要很大的耐性和良好的身体素质,在电脑面前一呆好几个小时那是很正常的。

但是呆的越久,写的越多,领悟也就越多。

特别是那些在课本上晦涩难懂的傅里叶变换,那些当初怎么想也想不到的图形就这么在电脑前出现了。

对那些变换性质有个更直观的理解,我想在学习信号与系统时,就应该好好同步学matlab。

Matlab有很多应用的地方,数学,信号,我想现在我找到了学matlab的方向,将重心集中在信号与系统方面,促进专业的学习。

 

致谢

课程设计暂告收尾,这也意味着我在大三这学期的结束。

回首既往,自己一生最宝贵的时光能于这样的校园之中,能在众多学富五车、才华横溢的老师们的熏陶下度过,实是荣幸之极。

在这三年的时间里,我在学习上和思想上都受益非浅。

这除了自身努力外,与各位老师、同学和朋友的关心、支持和鼓励是分不开的。

论文的写作是枯燥艰辛而又富有挑战的。

信号处理是业界一直探讨的热门话题,老师的谆谆诱导、同学的出谋划策及家长的支持鼓励,是我坚持完成论文的动力源泉。

在此,我特别要感谢我的导师老师。

从课程设计的选题、文献的采集、框架的设计、结构的布局到最终的课程设计定稿,从内容到格式,从标题到标点,她都费尽心血。

没有老师的辛勤栽培、孜孜教诲,就没有我课程设计的顺利完成。

通过这一阶段的努力,我的课程设计终于完成了,自己学会了很多,不仅对matlab有了更深一步的了解,而且学到了团队合作所应该有的品质,为将来的毕业论文做下了铺垫。

 

参考文献

1、《信号与线性系统分析(第4版)》,吴大正等著,高等教育出版社,2008。

2、《数字信号处理教程——MATLAB释义与实现(第2版)》,陈怀琛著,电子工业出版社,2008。

3、《MATLAB及在电子信息课程中的应用(第4版)》,陈怀琛等著,电子工业出版社,2013。

4、精通MATLAB6.5版,张志涌编,北京航空航天大学出版社,2003.03(第一版)

5、MATLABM语言高级编程,陈永春编,清华大学出版社,2004.01(第一版)

6、MATLAB程序设计,阮沈勇、王永利等编,电子工业出版社,2004.01(第一版)

7、《信号与线性系统分析(第4版)》,吴大正等著,高等教育出版社,2008。

8、《数字信号处理教程——MATLAB释义与实现(第2版)》,陈怀琛著,电子工业出版社,2008。

9、《MATLAB及在电子信息课程中的应用(第4版)》,陈怀琛等著,电子工业出版社,2013。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 小学教育 > 学科竞赛

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1