matlab重叠保留法,【matlab实现】重叠相加法与重叠保留法

两个有限长的序列,当一个序列的长度远大于另外一个序列的时候,如果仍采用常规的处理方法,效率会很低,所以引入了重叠相加法和重叠保留法。下面我们就利用MATLAB来实现这两种方法。

在下面的代码中,我使用了一个新的函数:tic和toc

其中tic是标记起始位置,toc是返回从tic到toc运行的时间,这个函数在对程序的运行时间的测量中很有用处。

下面进入代码阶段

重叠相加法:

MATLAB部分代码如下:

de44e67e39638b6dc3f8e019853f30d3.png

我得出的图像为:

f0ab2ff3e9111412bb22f1e1e6785f6a.png

这两张图像是一样的,也就说明重叠相加法代码的正确性。

仿照着重叠相加法的代码,我又写了重叠保留法的代码。

部分代码如下:

fbab596015d9a761fd253fe88a591345.png

利用重叠保留法得出的图像为:

0d4dc2b8cda25b69fd7d0d88f7cec515.png

验证两种方法的正确性之后,接着就要进行两种方法的比较了。

先说一说我自己的猜测,重叠相加法和重叠保留法一样需要计算N点的DFT然后再做相乘运算,但是重叠相加法需要进行一部分的加法运算,而重叠保留法只需要进行舍弃,所以在运行的速度上,重叠保留法应该比重叠相加法快,下面用MATLAB来进行验证。

首先对于重叠相加法

这里分块长度设置为10

23d950f6e7c624e1cf8a108819bcbd89.png

对于重叠保留法

分块长度设置为10

cd66a6c23d992360deb63ff6bfb0aeb4.png

可以看出在序列长度很大时,重叠保留法有略微的时间优势。

由于增加分块长度等同于减小序列长度,所以说就不做增加分块长度的实验了。

获取完整代码请阅读全文

隐藏内容需要支付:¥10

334fb81f40089e51e51aa9cb3e5ce520.png

查看隐藏内容需要支付:

¥10

d118c45243d02721e97a84887df2d3d7.png

支付宝

1941

请使用

支付宝 扫码支付

本文地址:https://ai.52learn.online/1941

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值