序列的卷积和快速卷积运算的编程实现.doc
《序列的卷积和快速卷积运算的编程实现.doc》由会员分享,可在线阅读,更多相关《序列的卷积和快速卷积运算的编程实现.doc(10页珍藏版)》请在课桌文档上搜索。
1、-课程设计任务书题目: 序列的卷积和快速卷积运算的编程实现初始条件:1. Matlab6.5以上版本软件;2. 课程设计辅导资料:Matlab语言根底及使用入门、数字信号处理原理与实现、Matlab及在电子信息课程中的应用等;3. 先修课程:信号与系统、数字信号处理、Matlab应用实践及信号处理类课程等。要求完成的主要任务:包括课程设计工作量及其技术要求,以及说明书撰写等具体要求1. 课程设计时间:1周课实践;2. 课程设计容:序列的卷积和快速卷积运算的编程实现,具体包括:直接卷积及应用、快速卷积方法及实现、两者的比拟分析等;3. 本课程设计统一技术要求:研读辅导资料对应章节,对选定的设计题
2、目进展理论分析,针对具体设计局部的原理分析、建模、必要的推导和可行性分析,画出程序设计框图,编写程序代码含注释,上机调试运行程序,记录实验结果含计算结果和图表,并对实验结果进展分析和总结;4. 课程设计说明书按学校课程设计工作规中的统一书写格式撰写,具体包括: 目录; 与设计题目相关的理论分析、归纳和总结; 与设计容相关的原理分析、建模、推导、可行性分析; 程序设计框图、程序代码含注释、程序运行结果和图表、实验结果分析和总结; 课程设计的心得体会至少500字; 参考文献; 其它必要容等。指导教师签名:年月日系主任或责任教师签名:年月日摘要卷积在数字信号处理中有着重要的作用。然而直接计算卷积的运
3、算量非常大,它与序列长度的平方成反比,因此制约了卷积的应用。快速卷积是实现卷积的一种快速算法,减少了运算量,节约了时间。通过分析我们可在MATLAB里编程实现。关键词:卷积;快速卷积;MATLAB。目录1、直接卷积及应用21.1卷积的定义21.2、卷积的运用22、快速卷积方法及实现22.1快速卷积运算原理22.2实现方法2重叠相加法2重叠保存法23、直接卷积和快速卷积的分析比拟24、程序设计及仿真结果分析25、心得体会26、参考文献2. z.-1、直接卷积及应用1.1卷积的定义设:f(x),g(x)是R1上的两个可积函数,作积分:可以证明,关于几乎所有的实数x,上述积分是存在的。这样,随着x的
4、不同取值,这个积分就定义了一个新函数h(x),称为函数f与g的卷积,记为h(x)=(f*g)(x)。1.2、卷积的运用卷积是数字信号处理中最常见,也是最重要的运算之一,利用卷积可以实现相关计算和FIR滤波等等,正因为卷积如此重要,所以半个世纪以来,学者们提出了多种不同卷积实现构造。设输入信号为xt,其频谱函数为Xj该信号通过滤波器ht后,其输出信号yt的频谱函数Yj是频谱函数xj与滤波器的频谱函数Hj的乘积,即: Yj=XjHj而在时域,输出信号y(t)实际是输入信号x(t)与滤波器h(t)的卷积,就是说频谱函数的乘积相当于时间函数的卷积,反之亦然,即: y(t)=x(t)*h(t)在数字信号
5、处理系统中,无论在时域还是频域都离不开卷积运算和快速傅里叶运算,Matlab具有强大的矩阵运算能力。方便实用的绘图功能和语言的高度集成性。在DSP开发中,使用Matlab可以快速对系统进展仿真运算。2、快速卷积方法及实现2.1快速卷积运算原理在信号处理中,许多具体的应用是以线性卷积为根底的。当满足一定条件时,可以用圆周卷积来计算线性卷积。由圆周卷积定理知道,圆周卷积可以借助DFT来运算,因此DFT的快速算法FFT就可以用来计算线性卷积。设x1n与x2n分别是长度为N与M的有限长序列,它们的线性卷积为yln,L点的圆周卷积为ycn,它们的关系为 ycn=yl(n+rL)Rl(n)由上式可知圆周卷
6、积是线性卷积以L为周期进展延拓后,再取主值序列的结果。当满足LM+N-1时,周期延拓不发生混叠,就可以用圆周卷积来计算线性卷积。由圆周卷积定义可知,可以用FFT分别求出x1n与x2n的L点DFT X1k与X2k,即 X1k=DFT x1(n, X2k=DFT x2(n) ,再用IFFT计算X1(kX2(k)的L点IDFT得ycn,也就是x1n与x2n的线性卷积为yl(n),即 yl(n)=yc(n)=IDFTX1(k)X2k下列图为上述过程的示意图L点的FFTx1(n)L点的IFFTyc(n=yl(n)L点的FFTx2(n)2.2实现方法在实际应用中,常遇到的问题是参加卷积的两个序列的长度相差
7、较大,这样长度小的序列就需补很多的零点,这样就需要大的存储量,运算时间也会变长。常用的解决方法有两种,一是重叠相加法,另一种是重叠保存法。重叠相加法设序列x1n为无限长序列,序列x2n是长度为M的序列,由x1(n)构成长度为N的有限长序列 x1k(n)= x1(n), kNn(k+1)N-1 = 0其他式2.1因此 x1k(n)= x1k(n) 式2.2将式子代入卷积公式有 Y(n)=x1(n)*x2(n)=x2(n)* x1k(n) =x1k(n)*x2(n)= yk(n) 式2.3式中, yk(n)=x2(n)*xk(n)= x2(m)xk(n-m) 式2.4式2.3表示,计算x1(n)与
8、x2n的线性卷积y(n)时,可以先分段计算yk(n),然后再叠加起来即可。因为yk(n)的长度为M+N-1,因此ykn的后N-1个值与yk+1(n)的前N-1个值重叠,因此必须把yk(n)的后N-1个值与yk+1n前的N-1个值相加,因为称为重叠相加法。重叠保存法为了克制重叠相加法中分段卷积后任然需要相加的缺点,人们提出了重叠保存法。与重叠相加法不同的是,在对无限长序列x1(n)的后M-1个抽样值与后一段xk+1(n)的前M-1个抽样值一样,且分段的长度选圆周卷积的长度L,这样形成的分段序列为然后计算x2n与各分段x1k(n)之间的卷积: Yk=x2(n)*x1k(n)显然,yk(n)的前M-
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 序列 卷积 快速 运算 编程 实现

链接地址:https://www.desk33.com/p-7429.html