文档库 最新最全的文档下载
当前位置:文档库 › 实验四、利用FFT实现快速卷积

实验四、利用FFT实现快速卷积

实验四、利用FFT实现快速卷积
实验四、利用FFT实现快速卷积

实验四、利用FFT实现快速卷积

一、实验目的

1、加深理解FFT在实现数字滤波(或快速卷积)中的重要作用,更好的利用FFT进行数字信号处理。

2、掌握循环卷积和线性卷积两者之间的关系。

3、掌握结合实验中画出的序列特性曲线,分析所得的图形,说明用FFT实现快速卷积时有关参数的选择方法。

二、实验设备

微型计算机、Matlab7.0教学版

三、实验原理

应用FFT实现数字滤波器实际上就是用FFT来快速计算有限长度序列的线性卷积。

这种方法就是先将输入信号x(n)通过FFT变换为它的频谱采样值X(k),然后再和FIR滤波器的频响采样值H(k)相乘,H(k)可事先存放在存储器中,最后再将乘积H(k)X(k)通过快速傅里叶变换(简称IFFT)还原为时域序列,即得到输出y(n)。

现以FFT求有限长序列间的卷积及求有限长度序列与较长序列间的卷积为例来讨论FFT的快速卷积方法。

四、实验内容

(1)用Matlab编制信号产生子程序,产生典型信号供谱分析用;

(2)画对给出信号逐个进行谱分析,绘出序列和幅频特性曲线;

(3)设计利用快速傅里叶变换FFT计算线性卷积的程序;

(4)对结果进行分析;

五、实验结果

实现两个序列{3,2,0,6,0,2,-1,8}和{4,0,-1,2,-3,4,1,3}的线性卷积。

1、圆周卷积。

实验程序:

运算后图形

2、直接卷积

运算后图形

六、实验总结

这次实验加深了我对FFT在实现数字滤波(或快速卷积)中的重要作用的理

解,也让我能更好的利用FFT进行数字信号处理。我掌握了循环卷积和线性卷积两者之间的关系。从两种方法运行结果可以看出,圆周卷积和直接卷积的结果是相同的。

卷积计算

卷积计算

实验二卷积计算及定理 一、授课目的 利用卷积方法观察分析信号、系统的频谱特性 二、授课内容 1、卷积计算 在MATLAB 中,提供了卷积函数conv,即y=conv(x,h),调用十分方便。 n=1:50; % 定义序列的长度是50 hb=zeros(1,50); % 注意:MATLAB 中数组下标从1 开始 hb(1)=1; hb(2)=2.5; hb(3)=2.5; hb(4)=1; close all; subplot(3,1,1);stem(hb);title('系统hb[n]'); m=1:50; % 定义序列的长度 T=0.001; % 定义序列的采样率 A=444.128; %设置信号有关的参数 a=50*sqrt(2.0)*pi; w0=50*sqrt(2.0)*pi; x=A*exp(-a*m*T).*sin(w0*m*T); %pi 是MATLAB 定义的π,信号乘可采用“.* ”subplot(3,1,2);stem(x);title('输入信号x[n]'); y=conv(x,hb); subplot(3,1,3);stem(y);title('输出信号y[n]');

2、卷积定律验证 (1) n=1:50; % 定义序列的长度是50 hb=zeros(1,50); % 注意:MATLAB 中数组下标从1 开始 hb(1)=1; hb(2)=2.5; hb(3)=2.5; hb(4)=1; m=1:50; % 定义序列的长度 T=0.001; % 定义序列的采样率 A=444.128; %设置信号有关的参数 a=50*sqrt(2.0)*pi;

利用傅立叶变换计算线性卷积

实验一 利用傅立叶变换计算线性卷积 一、实验目的 1. 掌握MATLAB 的使用。 2. 掌握用直接法计算线性卷积的原理和方法 3. 掌握利用FFT 及IFFT 计算线性卷积的原理和方法 二、实验原理及方法 1、线性卷积的定义 序列)1N n 0(),n (x -≤≤和序列)1M n 0(),n (h -≤≤的线性卷积y(n)=x(n)*h(n)定义为: 10),()()(1 0-+≤≤-?= ∑-=M N n m n h m x n y N m 利用直接法计算线性卷积即用线性卷积的定义计算。 2、利用FFT 及IFFT 计算线性卷积的原理和方法 如果将序列x(n)和h(n) 补零,使其成为长度为L 的序列(L>=N+M-1), 则x(n)与h(n)的线性卷积y(n)=x(n)*h(n)与L 点圆周卷积相等,而圆周卷积可采用FFT 及IFFT 完成,即求y(n)=x(n)*h(n)可转化为: 对上式两端取FFT 得: Y(k)=X(k)H(k) 其中:X(k)=FFT[x(n)], H(k)=FFT[h(n)] 则:y(n)=IFFT[Y(k)] 三、实验仪器及材料 ⒈ 计算机,并装有MATLAB 程序 ⒉ 打印机

四、实验步骤 1、已知两序列: ???>≤≤=3n ; 03n 0;)5/3()n (h n 用Matlab 随机生成输入信号X (n ),范围为0~2; 2、得出用直接法(定义)计算线性卷积y(n)=x(n)*h(n)的结果; 3、用Matlab 编制利用FFT 和IFFT (圆周卷积)计算线性卷积y(n)=x(n)*h(n)的程序; 分别令圆周卷积的点数为L=5,7,8,10,打印结果。 4、对比直接法和圆周卷积法所得的结果。 五、实验说明: 1、实验前复习线性卷积,圆周卷积及FFT 内容。 2、利用FFT 计算线性卷积是将x(n)、h(n)用补零的方法延长到N+M-1,再用圆周卷积完成,因此要求x(n)、h(n)延长后的长度满足L>=N+M-1,才能保证用圆周卷积计算结果与直接法计算结果相同。 六、分析整理实验数据,写出实验报告 实验报告要求: 1、 手工计算两序列的线性卷积,并与计算机的结果比较,以验证手工计算的正确性。 2、 令L=5,用已编制好的程序分别采用直接法和FFT 法对两序列计算线性卷积y(n)=x(n)*h(n),并打印结果。 3、 令L=7,8,10,用已编制好的程序分别采用直接法和FFT 法对两序列计算线性卷积y(n)=x(n)*h(n),并对比所得的结果,打印L=7,8,10的结果。 4、 打印程序. 七、思考题 说明为什么L=7,8,10时采用直接法和FFT 法对两序列计算线性卷积y(n)=x(n)*h(n)的结果相同,而与L=5时计算结果不同? 附录:

关于卷积计算

这里说到的卷积计算,只是指我们对图像进行某种滤波处理或者是边缘检测、锐化等应用要用到的运算。通常,要进行卷积的话就必须要有一个模板(掩模),这些模板的实际就是在卷积计算是所用到的点乘系数,下面会详细说明。当然,以上说的只是一种理解,而不是卷积本身的概念。下面举例说明一下卷积运算。 假设一图像(矩阵)为: 1 2 3 4 5 6 7 8 9 现在要对其进行锐化,采用用Roberts 算子和Sobel 算子,其中Roberts 算子 采用的计算模板为 ,根据其计算公式,以上述中的图(矩阵)的中间的点(5)为例,该点用Roberts 的模板计算过程如下: g(i,j) = |-5 + 9| + |-6 + 8| = 4 + 2 = 6,也就是说,5 这点通过卷积计算之后的值为6。在计算的时候,只要把矩阵中的点与模板的点一一对应即可: 1 2 3 4 5 6 7 8 9 在要进行处理的点5中,对应模板上的位置,就得出5的系数是-1,6和8的系数是0,9的系数是1(针对x 模板而言,如果是针对y 模板,则5和9的系数是0,6的系数是-1,8的系数是1),然后求两模板运算结果的绝对值之和,参照Robert 算子的公式。 然后到Sobel 算子,它的模板比Roberts 的要复杂一些,但运算的方法是一样的。 采用上面所说的对应方法,根据dx 和dy ,可得1和7的系数是-1, 4的系 数是-2,6的系数是2,3和9的系数是1,其余为0(针对x 模板),Sobel 算子的Roberts 最大的一个不同就是,前者计算的当前位置是模板的中心位置,后者计算的当前位置是左上角,一般来说,模板采取都是m ×m (m 是奇数),所以大部分模板的计算当前位置都是模板的中心位置(我们接触到的模板就只有Robert 算子不是奇数×奇数的)。至于模板,题目应该会给定,但上面所说到的这两个模板,大家最好还是记一记。而在空间平滑滤波增强中,中值滤波和邻域平均,这两者与卷积的计算有相似之处,但卷积是不同的。其中两者同样具有模板的概念,但中值滤波只是在模板覆盖的点里求中值,领域平均则是求平均值,具体参看书本60页到64页。。 (,)|(1,1)(,)||(1,)(,1)| g i j f i j f i j f i j f i j =++-++-+??????????---=101202101x d ??????????---=121000121y d

利用FFT计算卷积

利用FFT 计算卷积 一.线卷积的作用及定义 线卷积包括卷积积分和卷积和。 1.线卷积的作用 求解线性系统对任意激励信号的零态响应。 2.卷积积分 ) (*)(d )()()(t h t x t h x t y =-= ? ∞∞ -τττ 3.卷积和 离散系统的时域分析是,已知离散系统的初始状态和输入信号(激励),求离散系统的输出(响应),两种方法:递推解法和离散卷积法。 卷积和:)()()()()(n h n x m n h m x n y m *=-= ∑ ∞ -∞ = 二.圆周卷积的定义 圆周移位:一周期为N 的周期序列, 可视为一主值序列在圆周上的循环移位。周期序列在时间轴上左移 右移m 反时针 转称为圆周移位。 时域圆周卷积(循环卷积) )()()(n h n x n y ?=()()()∑ -=-= 1 )(N m N N n R m n h m x 条件:两序列实现圆卷积的条件是:长度相等,如果不相等, 可通过增补零值来使之相等。 特点:卷积求和范围只在10-≤≤N m 有限区间进行;卷积时不作反褶平移, 而是反褶圆移 步骤:量置换→反褶→圆移→相乘→求和。 三.两者的关系 有限长序列的圆卷积和线卷积的关系 在一般情况下,两序列的圆卷积和线卷积是不相等的,这是因为:线卷积是

平移, 结果长度为121-+=N N L ;而圆卷积是圆移,结果长度为2 1 N N L ==。只有 在两卷积的结果长度相时,二者才有相同的结果。解决方法是:在作圆卷积时,通过加零的方法,使两序列的长度都增加到121-+=N N L ,此时,圆卷积的结果和线卷积同。 四.利用FFT 计算卷积 工程实际需要解决的卷积:)()()(n h n x n y *=,但其计算量很大。 而圆卷积为:)()()(n h n x n y ?=,便于采用FFT 算法, 故计算速度快。若将线卷积的两个序列用增补零的方法将长度取为一致,此时两序列的离散线卷积和圆周卷积结果是相等的,这样就则可以通过圆卷积来快速计算线卷积。 1、 利用FFT 计算卷积的步骤 (1)设两序列原长度分别为:N 和M ,将长度增加到1-+≥M N L (L 为2的整数次幂); (2)用FFT 法求加长序列的DFT 频谱; (3)计算两序列DFT 频谱的乘积; (4)用IFFT 求DFT 频谱乘积的逆变换,便得两序列的离散线卷积。 2、分段快速卷积 设)(n x 为长序列,)(n h 为短序列,长度为M ,则两序列的离散线卷积可以写成如 下 形 式 , ∑∑∑-=-+=-=+-+ +-+ -= *=1 1 )1(1 2)()()()()()()()()(N m n K kN m N N m m N h m x m N h m x m N h m x n h n x n y 上述每个子段长度为N 。为便于圆卷积计算,将长度通过补零加长为:1-+=M N L x (n 0 n h (n 根据各子段()n x k 增补零的部位不一样而分两种算法。

卷积的快速算法++教程文件

《数字信号处理》 课程设计报告 专业:通信工程 班级:通信08-2BF 组次:第10组 姓名: 学号:14082300925

一、 设计目的 卷积运算是一种有别于其他运算的新型运算,是信号处理中一种常用的工具。随着信号与系统理论的研究的深入及计算机技术发展,卷积运算被广泛地运用到现代地震勘测,超声诊断,光学诊断,光学成像,系统辨识及其他诸多新处理领域中。了解并灵活运卷积运算用去解决问题,提高理论知识水平和动手能力,才是学习卷积运算的真正目的。通过这次课程设计,一方面加强对《数字信号处理》这门课程的理解和应用,另一方面体会到学校开这些大学课程的意义。 二、设计任务 探寻一种运算量更少,算法步骤更简单的算法来实现卷积运算,文中主要通过阶梯函数卷积计算方法和斜体函数卷积计算方法对比来得出最终结论。 三、设计原理 1,什么是卷积? 卷积是数字信号处理中经常用到的运算。其基本的表达式为: ()()()∑=-= n m m n x m h n y 0 换而言之,假设两个信号f 1(t)和f 2(t),两者做卷积运算定义为 f(t) d 做一变量代换不难得出: f(t) d =f 1(t)*f 2(t)=f 2(t)*f 1(t) 在教材上,我们知道用图解法很容易理解卷积运算的过程,在此不在赘述。 2,什么是阶梯函数 所谓阶梯函数,即是可以用阶梯函数u(t) 和u(t-1)的线性组合来表示的函数,可以看做是一些矩形脉冲的集合,图1-1给除了两个阶梯函数的例子。

1—1 其中 f(t)=2u(t)+u(t-1)-2u(t-2)-u(t-3), h(t)= 2u(t)-u(t-1)+2u(t-2)-3u(t-3). 以图1—1中两个阶梯函数为例介绍本文提出的阶梯函数卷积算法。 根据卷积的性质(又称为杜阿美尔积分),上述f(t)与h(t)的卷积等于f(t)的导数与h(t)的积分的卷积,即: f(t)*h(t)=* 由于f(t)为阶梯函数,因此其导数也为冲击函数及其延时的线性组合, 如图1—2(a) 所示。

二维矩阵卷积的并行计算方法

第52卷第3期2018年3月浙 江 大 学 学 报(工学版)J o u r n a l o f Z h e j i a n g U n i v e r s i t y (E n g i n e e r i n g S c i e n c e )V o l .52N o .3M a r .2018 收稿日期:20170304.网址:w w w.z j u j o u r n a l s .c o m /e n g /f i l e u p /H T M L /201803013.h t m 基金项目:国家自然科学基金资助项目(60133007,61572025);国家重点研发计划资助项目(2016Y F B 0200401). 作者简介:张军阳(1987 ),男,博士生,从事体系结构二机器学习二嵌入式系统研究.o r c i d .o r g /0000-0002-2993-4494.E -m a i l :z h a n g j u n y a n g 11@n u d t .e d u .c n 通信联系人:郭阳,男,教授.o r c i .o r g /0000-0003-1600-4666.E -m a i l :g u o y a n g @n u d t .e d u .c n D O I :10.3785/j .i s s n .1008-973X.2018.03.013二维矩阵卷积的并行计算方法 张军阳,郭阳,扈啸 (国防科技大学计算机学院,湖南长沙410073 )摘 要:为了提高卷积神经网络模型中二维矩阵卷积的计算效率,基于F T 2000多核向量处理器研究二维矩阵卷积 的并行实现方法.通过使用广播指令将卷积核元素广播至向量寄存器,使用向量L O A D 指令加载卷积矩阵行元素,并通过混洗操作将不易并行化的矩阵卷积操作变成可以向量化的乘加操作,实现了通过减少访存二充分复用已取数 据的方式来提高算法的执行效率.设计卷积矩阵规模变化二卷积核规模不变和卷积矩阵规模不变二卷积核规模变化2种常用矩阵卷积计算方式,并对比分析不同计算方式对算法执行效率的影响.基于服务器级多核C P U 和T I 6678进 行实验对比,实验结果显示,F T 2000比多核C P U 及T I 6678具有更好的计算优势,相比多核C P U 最高可加速11974 倍,相比T I 6678可加速21倍.关键词:矩阵卷积;向量处理器;并行算法;性能优化;卷积神经网络 中图分类号:T P391 文献标志码:A 文章编号:1008973X (2018)03051509 P a r a l l e l c o m p u t i n g m e t h o d f o r t w o -d i m e n s i o n a lm a t r i x c o n v o l u t i o n Z H A N GJ u n -y a n g ,G U O Y a n g ,HU X i a o (C o l l e g e o f C o m p u t e r ,N a t i o n a l U n i v e r s i t y o f D e f e n s eT e c h n o l o g y ,C h a n g s h a 410073,C h i n a )A b s t r a c t :A p a r a l l e l i m p l e m e n t a t i o nm e t h o db a s e do nm u l t i -c o r e v e c t o r p r o c e s s o rF T 2000w a s p r o p o s e d t o i m p r o v e t h e c o m p u t a t i o n a l e f f i c i e n c y o f t w o -d i m e n s i o n a lm a t r i x c o n v o l u t i o n i n c o n v o l u t i o nn e u r a l n e t w o r k m o d e l .T h e c o n v o l u t i o nk e r n e l e l e m e n tw a s b r o a d c a s t t o v e c t o r r e g i s t e r b y u s i n g b r o a d c a s t i n s t r u c t i o n ;t h e r o we l e m e n t s o f t h e c o n v o l u t i o nm a t r i xw e r e v e c t o r l o a d e d .W i t h s h u f f l e o p e r a t i o n ,t h e o p e r a t i o n o fm a t r i x c o n v o l u t i o n ,w h i c h i sh a r dt ob e p a r a l l e l l e d ,c a nb ev e c t o r i z e db y u s i n g m u l t i p l y -a d do p e r a t i o n ,a n dt h e i m p l e m e n t a t i o ne f f i c i e n c y w a s a c h i e v e d t h r o u g h r e d u c t i o n o f a c c e s s ,f u l l r e u s e o f o b t a i n e d d a t a .T w o k i n d s o f c o m m o nm a t r i xc o n v o l u t i o n m e t h o d sw e r ed e s i g n e d :c h a n g i n g c o n v o l u t i o n m a t r i xs c a l ew i t hc o n s t a n t c o n v o l u t i o nk e r n e l s i z e ,a n d c o n s t a n t c o n v o l u t i o nm a t r i x s i z ew i t h c h a n g i n g c o n v o l u t i o nk e r n e l s c a l e .T h e i n f l u e n c e o f d i f f e r e n t c a l c u l a t i o n m e t h o d s o n t h e a l g o r i t h m e x e c u t i o n e f f i c i e n c y w a s a n a l y z e d a n d c o m p a r e d .F i n a l l y ,t h e c o m p a r i s o ne x p e r i m e n t sw e r e t a k e nb a s e do n t h e s e r v e r -l e v e lm u l t i -c o r eC P Ua n d T I 6678.R e s u l t s s h o wt h a tF T 2000h a sab e t t e r c o m p u t i n g a d v a n t a g eo v e rm u l t i -c o r eC P Ua n dT I 6678,w h i c hc a na c c e l e r a t eu p t o 11974t i m e s c o m p a r e d t om u l t i -c o r eC P U ,w h i l e t oT I 6678i t i s 21t i m e s .K e y w o r d s :m a t r i x c o n v o l u t i o n ;v e c t o r p r o c e s s o r ;p a r a l l e l a l g o r i t h m ;p e r f o r m a n c e o p t i m i z a t i o n ;c o n v o l u t i o n n e u r a l n e t w o r k

用友成本卷积计算规则等

成本卷积相关规则及操作说明等 品种法或分步法,启用生产制造数据来源 来源于存 货核算系统,出库类别:生产材料领 入库类别:半成品入库/产成品入库计入入库数 来源于总帐系统 来源于总帐系统 来源于总帐系统 2、 定义费用明细与总帐接口 制造费用-折旧 FS ("510103",月,"借","888",2010) 制造费用-管理人员工资FS ("510102",月,"借","888",2010) 制造费用-水电费 FS ("510101",月,"借","888",2010) 直接人工 FS ("500102",月,"借","888",2010) 3、 定义分配率 共用材料分配率: 直接人工分配率: 制造费用分配率: 在产品分配率: 材料成本 4、 存货核算模块 选项: A 核算方式:零出库成本选择、入库单成本选择、红字出库单 成本选择等,均不能选择“手工输入”,建议选择上次出库或上次入 库成本。 二、 卷积操作功能: 1、 卷积计算检查: 包含对存货核算的检查。计算检查按范围进行分类,计算结果 可按检查范围分类查询。检查完成后,自动保存计算结果,每次计 算后覆盖前次数据。 2、 卷积计算: 一次性按顺序由低层到高层完成所有 BOM 层次成本计算,包含 各层入库单、出库单记账、期末处理、材料及外购半成品耗用表取 数、成本计算、产成品成本分配,中间没有任何交互。其中所有核 算型仓库的出入库单据类型进行记账,所有仓库进行期末处理。 一、 基础设置: 1、成本选项: 成 本核算方法: 存货数据来源: 用计入直接材 料, 量 人工费用来 源: 产品权重系数 产品权重系数 产品权重系数

实验一序列`卷积运算

实验一 离散时间信号分析 一、实验目的 1.掌握各种常用的序列,理解其数学表达式和波形表示。 2.掌握在计算机中生成及绘制数字信号波形的方法。 3.掌握序列的相加、相乘、移位、反褶等基本运算及计算机实现与作用。 4.掌握线性卷积软件实现的方法。 5.掌握计算机的使用方法和常用系统软件及应用软件的使用。 6.通过编程,上机调试程序,进一步增强使用计算机解决问题的能力。 二、实验原理 1.序列的基本概念 离散时间信号在数学上可用时间序列)}({n x 来表示,其中)(n x 代表序列的第n 个数字,n 代表时间的序列,n 的取值范围为∞<<∞-n 的整数,n 取其它值)(n x 没有意义。离散时间信号可以是由模拟信号通过采样得到,例如对模拟信号)(t x a 进行等间隔采样,采样间隔为T ,得到)}({nT x a 一个有序的数字序列就是离散时间信号,简称序列。 2.常用序列 常用序列有:单位脉冲序列(单位抽样))(n δ、单位阶跃序列)(n u 、矩形序列)(n R N 、实指数序列、复指数序列、正弦型序列等。 3.序列的基本运算 序列的运算包括移位、反褶、和、积、标乘、累加、差分运算等。 4.序列的卷积运算 )()()()()(n h n x m n h m x n y m *=-= ∑∞ -∞= 上式的运算关系称为卷积运算,式中*代表两个序列卷积运算。两个序列的卷积是一个序列与另一个序列反褶后逐次移位乘积之和,故称为离散卷积,也称两序列的线性卷积。其计算的过程包括以下4个步骤。 (1)反褶:先将)(n x 和)(n h 的变量n 换成m ,变成)(m x 和)(m h ,再将)(m h 以纵轴为对称轴反褶成)(m h -。 (2)移位:将)(m h -移位n ,得)(m n h -。当n 为正数时,右移n 位;当n 为负数时,左移n 位。 (3)相乘:将)(m n h -和)(m x 的对应点值相乘。 (4)求和:将以上所有对应点的乘积累加起来,即得)(n y 。

卷积的几种计算方法以及程序实现FFT算法.

数字信号处理 function r = test(L x = rand(1 , L ; tic N = length(x ; X1 = x * exp(-j * 2 * pi / N * (0:N-1'*(0:N-1 ; t1 = toc ; tic X2 = ditany(x ; t2 = toc ; r = t1 / t2 ; %max(abs(X1 - X2 return ; function X = ditany(x N = length(x ; if N == 1 X=x; else %factorize N = a * b flag = 0 ; for a = 2:fix(sqrt(N if fix(N / a == N / a flag = 1 ; break ; end end if ~flag a=N; end b=N/a; %start caculation of length b dft %and assemble the a sequences W = exp(-1j * 2 * pi / N * (0:a-1'*(0:b-1 ; %preallocation of space will be needed here %to accelerate the programme XX = [] ; for ii = 1:a XX = [XX ; ditany(x(ii:a:N] ; end X = [] ; XX = XX .* W ; for jj = 1:a tmp = exp(-j * 2 * pi / N * (0:a-1 * b * (jj - 1 * XX ; X = [X , tmp] ; end end Made by 霏烟似雨 数字信号处理 return ; 所有自然数: Made by 霏烟似雨

相关文档