信号的采样与恢复matlab实验报告,实验七 连续信号的采样与恢复

一、实验目的

通过MATLAB仿真验证抽样定理,进一步加深对抽样定理的理解。

二、实验原理

1. 连续信号的采样

对某一连续时间信号f(t)的采样原理图为:

2c5c3697c83510478d581218774f8299.png

由图可知,

ab1a19a248e466cd4c7f64f4c74fa9b5.png,其中,单位冲激采样信号

c8656ab7d948e72d2ba647e20da72a20.png的表达式为:

24bd6f378796a8a113dc0ad16985363a.png

其傅里叶变换为

643e90d13fcfe98a778a2ddde2f0c67a.png,其中

15d364ab22d107001f40f5fe36645d43.png,设

f85f9b01cf2fee96979ad254f991f9aa.png

26a96915b163186c3930bf2bfa311f10.png的傅里叶变换,

3e7f55cafbb9071cd6e85d592a103ddc.png的频谱为

b13c66b4be5c7d23637f5761d79efe21.png,根据傅里叶变换的频域卷积定理:

2ea339791f5e56a4775c93712735c465.png

若设

04588d3646a2a38d490c2792dc92a8ec.png是带限信号,带宽为

3b6168f988b88420e69a4c8558cbd2b5.png,即当

d450a144a659bb7408a33fd9f05199a7.png时,

91032467b8fae2b5b4cff76c1c116d9b.png的频谱

c9efd76ae78fb19c953ad065351974b2.png,则

08084cc396481eaed83b807280f2214d.png经过采样后的频谱

dbcb652455b2f20b1b2ffae0f2061da1.png就是

9f79a13c5b0e8f909c13254173f2f94d.png在频率轴上搬移至

ec17bd76d460b518e343dc1db0fef099.png处(幅度为原频谱的

921c760815bab213846d4cbe536a47da.png倍)。因此,当

3aa1d01be3b605d56dbdd5d99e9726d0.png时,频谱不发生混叠;当

09d4c24941149ab14e551eb1c1cae410.png时,频谱发生混叠。

2.连续信号的恢复

设信号

9ff9222555050f062c25763b5e8f653e.png被采样后形成的采样信号为

e7a244a57a59e46c5a4ae88ec1d2dcce.png,信号的重构是指由

1d334f2eab3f70e553209832da5287e9.png经内插处理后,恢复出原来的信号

ef653dd8b23818d63165b60e5f39cbc7.png的过程,因此又称为信号恢复。设

e9e3374e3418171ba747204ee6f667b4.png为带限信号,带宽为

12c53a32b18b18075a2e12001810e8e0.png,经采样后的频谱为

b5a3237cdd8e0fd51d218913c64198d0.png。设采样频谱

b1422fbdecabb3a78955c83652631e1f.png,则

144dc3e0741074471769d1a9d7f743f6.png是以

d00404175bf403e4ff2b3945bf1a2692.png为周期的谱线。现取一个频率特性为

e5e9e81017cbd7304820ce736813aa1f.png的理想低通滤波器与

56eedcff1ea28d6323529965aada0969.png相乘,得到的频谱即为原信号的频谱

62bc3561d507b7aebecd085b1a71a626.png。根据时域卷积定理:

117686c592c2856d60381467d80d08d6.png

其中,

be5fa72e91700524496239a6a7341da7.png

因此

![在这里插入图片描述](https://img-blog.csdnimg.cn/20201205213323451 3.应用举例

例:已知信号

c9b7ee307701d60467bdf5a6e9ee2c3f.png,信号的采样频率为ωs,信号的采样周期为Ts,信号的最高频率为ωm,低通截止频率为ωc

(1)当ωs=2ωm ,ωc=ωm时,用matlab对信号进行采样及恢复,分析误差,画出波形;

(2)当ωs=4ωm ,ωc=2ωm时,用matlab对信号进行采样及恢复,分析误差,画出波形;

(3)当ωs=ωm ,ωc=ωm时,用matlab对信号进行采样及恢复,分析误差,画出波形;

分析:

78892605dbd200612081a56b3060d420.png的傅里叶变换为:

5dd2559147616fb3326cd29813621cdd.png,

信号的最高频率为ωm=1,根据采样定理,当采样频率ωs=2ωm时为临界采样,当ωs>2ωm过采样,ωs<2ωm欠采样;恢复时,低通滤波器的的截止频率(ωs-ωm)≥ωc≥ωm

matlab里利用sinc函数实现Sa(t),即Sa(t)=sinc(t/pi)

(1)在临界采样状态下实现对信号Sa(t)的采样及由该采样信号恢复Sa(t)的参考程序如下:

clear all;

wm=1; %信号带宽

wc=wm; %滤波器截止频率

Ts=pi/wm; %采样间隔

ws=2*pi/Ts; %采样角频率

n=-100:100; %时域采样点数

nTs=n*Ts; %时域采样点

f=sinc(nTs/pi); %信号f(nTs)的表达式

t=-15:0.005:15;

fa=f*Ts*wc/pi*sinc((wc/pi)*(ones(length(nTs),1)*t-nTs'*ones(1,length(t)))); %信号重构

error=abs(fa-sinc(t/pi)); %求重构信号与原信号的误差

t1=-15:0.5:15;

f1=sinc(t1/pi);

subplot(3,1,1);

stem(t1,f1);

xlabel('kTs'); ylabel('f(kTs)');

title('sa(t)=sinc(t/pi)临界采样信号');

subplot(3,1,2);

plot(t,fa);

xlabel('t'); ylabel('fa(t)');

title('由sa(t)=sinc(t/pi)的临界采样信号重构sa(t)');

grid on;

subplot(3,1,3);

plot(t,error);

xlabel('t'); ylabel('error(t)');

title('临界采样信号与原信号的误差error(t)');

运行结果如下:

2595a2a1235dfb44415761a7b5cd7e75.png

三、实验内容

1、实现例子中的第(2)(3)问;

(2)程序如下:

clear all;

wm=1; %信号带宽

wc=2*wm; %滤波器截止频率

Ts=pi/wm; %采样间隔

ws=2*2*pi/Ts; %采样角频率

n=-100:100; %时域采样点数

nTs=n*Ts; %时域采样点

f=sinc(nTs/pi); %信号f(nTs)的表达式

t=-15:0.005:15;

fa=f*Ts*wc/pi*sinc((wc/pi)*(ones(length(nTs),1)*t-nTs'*ones(1,length(t)))); %信号重构

error=abs(fa-sinc(t/pi)); %求重构信号与原信号的误差

t1=-15:0.5:15;

f1=sinc(t1/pi);

subplot(3,1,1);

stem(t1,f1);

xlabel('kTs'); ylabel('f(kTs)');

title('sa(t)=sinc(t/pi)临界采样信号');

subplot(3,1,2);

plot(t,fa);

xlabel('t'); ylabel('fa(t)');

title('由sa(t)=sinc(t/pi)的临界采样信号重构sa(t)');

grid on;

subplot(3,1,3);

plot(t,error);

xlabel('t'); ylabel('error(t)');

title('临界采样信号与原信号的误差error(t)');

运行结果如下:

c3b71b5e31acee332d5bde395d24263d.png

(3)程序如下:

clear all;

wm=1; %信号带宽

wc=wm; %滤波器截止频率

Ts=pi/wm; %采样间隔

ws=pi/Ts; %采样角频率

n=-100:100; %时域采样点数

nTs=n*Ts; %时域采样点

f=sinc(nTs/pi); %信号f(nTs)的表达式

t=-15:0.005:15;

fa=f*Ts*wc/pi*sinc((wc/pi)*(ones(length(nTs),1)*t-nTs'*ones(1,length(t)))); %信号重构

error=abs(fa-sinc(t/pi)); %求重构信号与原信号的误差

t1=-15:0.5:15;

f1=sinc(t1/pi);

subplot(3,1,1);

stem(t1,f1);

xlabel('kTs'); ylabel('f(kTs)');

title('sa(t)=sinc(t/pi)临界采样信号');

subplot(3,1,2);

plot(t,fa);

xlabel('t'); ylabel('fa(t)');

title('由sa(t)=sinc(t/pi)的临界采样信号重构sa(t)');

grid on;

subplot(3,1,3);

plot(t,error);

xlabel('t'); ylabel('error(t)');

title('临界采样信号与原信号的误差error(t)');

运行结果如下:

6293676134962a2759126321223aefbb.png

2、当信号f(t)=ε(t+1)-ε(t-1),用matlab实现信号的采样和重建,并分析误差

(1)ωm=2π,ωc=1.2ωm,Ts=0.25

(2)ωm=2π,ωc=1.2ωm,Ts=1

(求大佬指点)

四、实验报告要求

1、 简述实验目的及实验原理

(1).加深理解采样对信号的时域和频域特性的影响;

(2).加深对 采样定理的理解和掌握,以及对信号恢复的必要性;

(3).掌握对连续信号在时域的采样与重构的方法。

2、 写出程序清单

3、 记录实验结果,并进行原理阐述

1.加深理解采样对信号的时域和频域特性的影响;

2.加深对 采样定理的理解和掌握,以及对信号恢复的必要性;

3.掌 握对连续信号在时域的采样与重构的方法。

4、 收获与建议

收获:通过这次实验,加深了对于采样定理的理解,对于信号与系统这么抽象的课程有了更加直观的了解。

建议:有的实验版上的可调电阻引脚断开了,希望修复。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/559351.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

treegrid 如何获取getchanges inserted_如何避开Vue性能优化之路的荆棘?

随着这几年前端技术快速发展&#xff0c;Vue框架在国内普及率极高&#xff0c;人人都会用&#xff0c;那Vue如何写得比别人优雅&#xff1f;如何写得比别人漂亮&#xff1f;鉴于一线互联网大厂在前沿技术领域的持续研究和大规模投入&#xff0c;直接向他们取经&#xff0c;是最…

matlab+信号+mpf,Python和Matlab中平均频率的差异

我有这个EMG signal&#xff0c;我想根据这个article绘制平均功率频率。我使用以下代码在Matlab中实现它&#xff1a;clear all;close all;EMGload(EMG.txt);N1000; %my windowz1;fs200 %sampling ratefor i1:length(EMG)-NDUM0;NUM0;FTfft(EMG(i:iN-1));psdFT.*conj(FT);NFFTl…

matlab和vlfeat关联,VLFeat在matlab和vs中安装

转&#xff1a;http://blog.csdn.net/u011718701/article/details/51452011博主最近用vlfeat库做课题&#xff0c;网上搜索使用方法&#xff0c;一大片都会告诉你说&#xff1a;run(/vl_setup) 然后就好啦哈哈哈哈哈哈~~~~~~~~~~~~~~But!理想很丰满&#xff0c;现实很骨感&…

document.createelement如何绑定点击事件_番外篇-EXCEL如何使用宏(VBA)

小编&#xff0c;会在后续推送一些关于VBA(宏)相关的文章(之前其实也推送了一些&#xff0c;其中也大概说了一下如何使用)&#xff0c;所以我们今天就专门写一篇如何使用宏&#xff0c;方便大家使用已经写好的宏。如何使用宏&#xff1a;常规宏VBA-一般都是此类1、调出-开发工具…

mysql --max_allowed_packet=32m,如何修改MySQL-max_allowed_packet

首先查找my.cnf的配置文件(为了让配置永久生效)mysql --help | grep my.cnf修改mysql配置文件&#xff0c;找到vim /etc/my.cnfmax_allowed_packet 1024M >改为2048M保存退出&#xff0c;重新启动mysql服务、/etc/init.d/mysqld restart登录mysql通过本地地址mysql -uroot…

局域网打印机反应慢_为什么你的Excel这么慢,这些原因必须要知道!

Excel是很多人的高频办公工具&#xff0c;但大家或多或少地遇到过&#xff0c;有时自己电脑的Excel很慢&#xff0c;导致工作的效率不高&#xff0c;可能就会导致要加班加点&#xff0c;也压缩了自己其他方面的时间。本文将介绍一些常见的Excel”慢“的情况及其解决方案&#x…

php密码安全检测,php – 密码安全随机字符串函数

目标&#xff1a;找到最加密的安全随机字符串生成器.在字符串中使用字母,数字和可能的特殊字符.我一直在这里和其他地方读书,但我仍然听到很多不同的答案/意见.那些对安全性和加密技术有最新知识且知识渊博的人可以在这里发出声音.以下函数将用于生成8个字符的随机密码,并生成1…

linux挂载fc存储有超级坏块_Nand Flash基础知识与坏块管理机制的研究

欢迎FPGA工程师加入官方微信技术群点击蓝字关注我们FPGA之家-中国最好最大的FPGA纯工程师社群概述Flash名称的由来&#xff0c;Flash的擦除操作是以block块为单位的&#xff0c;与此相对应的是其他很多存储设备&#xff0c;是以bit位为最小读取/写入的单位&#xff0c;Flash是一…

php 设置agent,限制某个目录禁止解析php及user_agent、php相关配置

一、 限定某个目录禁止解析php1、 核心配置文件内容php_admin_flag engine off2、curl测试时直接返回了php源代码&#xff0c;并未解析二、 限制user_agent1、 user_agent可以理解为浏览器标识2、核心配置文件内容RewriteEngine onRewriteCond %{HTTP_USER_AGENT} .curl. [NC,O…

python 打印xml文档树_[Python]xml.etree.ElementTree处理xml文档

需求&#xff1a;在实际应用中&#xff0c;需要对xml配置文件进行实时修改&#xff0c;1.增加、删除 某些节点2.增加&#xff0c;删除&#xff0c;修改某个节点下的某些属性3.增加&#xff0c;删除&#xff0c;修改某些节点的文本xml源文件格式[例]path"/tmp">out…

oracle最快访问行,Oracle技术网—在Oracle快速进行数据行存在性检查

在Oracle快速进行数据行存在性检查当在应用程序的业务逻辑中需要检查一个外键是否有相关的主键时&#xff0c;往往使用Select Count(*)类型的SQL语句。这是一个很显而易的方法&#xff0c;但却不是最快的方法。Count(*)函数调用可能会引起对整个表的进行扫描&#xff0c;这是一…

carsim中质心加速度_振动CAE分析在空调压缩机支架设计中的应用

【摘要】本文运用有限元分析方法分析空调压缩机系统模态&#xff0c;并通过分析引起振动的激励源&#xff0c;找出压缩机支架和安装螺栓断裂的根本原因&#xff0c;并根据分析提出了解决措施。关键词&#xff1a;空调压缩机支架模态激励共振一、引言发动机轮系需要驱动的工作部…

oracle windows server 2008,Node.js 在 Windows Server 2008 X64 连接Oracle 数据库

不需要安装Oralce客户端&#xff0c;不影响其它使用Oracle客户端的程序运行安装Node.JSnode-v12.13.0-x64.msi安装VC 2013运行时vcredist_x64.exe运行的版本要与Oracle 客户端匹配&#xff0c;下载Oracle 客户端instantclient-basiclite-windows.x64-18.5.0.0.0dbru.zip解压并放…

python中end 1 意思_python中“end=”是什么意思?_后端开发

c语言fopen函数的用法_后端开发在c语言中可以使用“fopen()”函数打开一个文件&#xff0c;该函数用于打开一个文件&#xff0c;其语法是“open(“file a”,”r”);”&#xff0c;其参数r表示只读属性。python中“end”是“print()”函数中的一个参数&#xff0c;会使该函数关闭…

oracle如何收缩表空间,ORACLE收缩表空间

最近导一个空库到数据库后&#xff0c;发现占用的表空间非常大&#xff0c;执行表收缩(SHRINK SPACE CASCADE)后&#xff0c;发现实际占用的空间不到1%。 但是收缩表空间大小提示错误 ALTER DATABASE DATAFILE D:\ora_tablespace\GCOMM2.dbf RESIZE 5000M; 提示&#x…

python 类 对象 知乎_python基础知识:类,对象,模块三者的区别

长话短说&#xff0c;我线代作业还没有写呢。有点编程语言知识的朋友应该知道&#xff0c;编程语言有“面向对象”和“面向过程”两种。解释一下&#xff1a;面向对象技术是目前流行的系统设计开发技术&#xff0c;它包括面向对象分析和面向对象程序设计。面向对象程序设计技术…

linux下usb驱动配置文件,Linux环境下USB的原理、驱动和配置

随着生活水平的提高&#xff0c;人们对USB设备的使用也越来越多&#xff0c;鉴于Linux在硬件配置上尚不能全部即插即用&#xff0c;因此关于Linux如何配置和使用&#xff0c;成为困扰我们的一大问题。本文引用地址&#xff1a;http://www.eepw.com.cn/article/70029.htmlinux操…

python的数据库中间件_数据库中间件设计方案

数据库中间件的主要作用是向应用程序开发人员屏蔽读写分离和分库分表面临的挑战&#xff0c;并隐藏底层实现细节&#xff0c;使得开发人员可以像操作单库单表那样去操作数据。在介绍分库分表的主流设计方案前&#xff0c;我们首先回顾一下在单个库的情况下&#xff0c;应用的架…

linux 内核重定位,Linux 内核学习笔记:预备知识之“目标文件”

8种机械键盘轴体对比本人程序员&#xff0c;要买一个写代码的键盘&#xff0c;请问红轴和茶轴怎么选&#xff1f;本文主要阐述 Linux 的目标文件(有可重定位目标文件、可执行目标文件和共享目标文件三种形式)&#xff0c;并把重点放在其格式和案例分析上。注&#xff1a;一般情…

python源码脚本实例_python编写一个会算账的脚本的示例代码

python算账脚本1.假如小明卡里有10000元去商场买东西发现钱不够又向父母借了5000账单如下2.以下脚本就能实现上面的运算from time import strftimeimport pickleimport ostry:def save():data strftime(\033[35m%Y-%m-%d\033[0m)money int(input(How much do you have to sav…