matlab设计fpga实现联合ise和modelsim仿真的fir滤波器设计

matlab设计fpga实现联合ise和modelsim仿真的fir滤波器设计

ID:11120384

大小:28.62 KB

页数:23页

时间:2018-07-10

matlab设计fpga实现联合ise和modelsim仿真的fir滤波器设计_第1页
matlab设计fpga实现联合ise和modelsim仿真的fir滤波器设计_第2页
matlab设计fpga实现联合ise和modelsim仿真的fir滤波器设计_第3页
matlab设计fpga实现联合ise和modelsim仿真的fir滤波器设计_第4页
matlab设计fpga实现联合ise和modelsim仿真的fir滤波器设计_第5页
资源描述:

《matlab设计fpga实现联合ise和modelsim仿真的fir滤波器设计》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、MATLAB设计FPGA实现联合ISE和Modelsim仿真的FIR滤波器设计QQ:290632690肤浅。。。制作MATLAB设计,FPGA实现,联合ISE和Modelsim仿真的FIR滤波器设计摘要:本文首先利用MATLAB产生两个频率不一样的正弦信号,并将这两个正弦信号相加,得到一个混叠的波形;然后利用MATLAB设计一个FIR低通滤波器,并由Verilog实现,联合ISE和Modelsim仿真,实现滤除频率较高的信号,并将滤波后的数据送到MATLAB中分析。本文首先介绍FIR滤波器的基本原理,然后从目前最流行的的设计方式入手,逐步介绍FIR滤波器的设计,其流程图如

2、图1所示:图1一、FIR滤波器的基本原理:数字滤波器是从分析信号中提取用户需要的信息,滤去不需要的信号成分或者干扰成分。数字滤波器的数学模型:线性时不变数字滤波器的数学模型在时域中可以用线性常系数差分方程给出:y[n]???dky[n?k]??pqx[n?q]k?1q?0NM?p其等效的Z变换为:H(z)?q?0Nk?1Mqz?q1??dkz?k当dk全为0时,Z域系统函数只有零点,数字滤波器的单位脉冲响应有限,通常1QQ:290632690肤浅。。。制作这用滤波器被称为有限冲激响应(FIR)滤波器。它的输出只与当前的输入和过去的输入有关,跟过去的输出无关。FIR滤波器的

3、一个重要特性是具有线性相位,即系统的相异和频率成正比,可达到无失真传输。更加详细的介绍FIR滤波器的理论算法知识,请参考别的先关书籍资料、二、FIR滤波器的设计及验证:1)由MATLAB产生FIR滤波器的输入数据,并存放到.txt文件中用MATLAB产生两个频率分别为:0.5MHz和2MHz的正弦信号,并将这两个正弦信号叠加,得到一个混叠的信号,并将这个混叠信号的波形数据存放到C盘根目录下面的matlab_wave_data.txt文件中。MATLAB实现代码如下:clearall;fs=25000000;%25M采样率t=0:1/fs:0.0002;%共0.0002*2

4、5000000=5000个点f1=500000;f2=2000000;signal1=sin(2*pi*f1*t);%频率为0.5MHz的正弦信号2QQ:290632690肤浅。。。制作signal2=sin(2*pi*f2*t);%频率为2.0MHz的正弦信%由于正、余弦波形的值在[0,1]之间,需要量化成16bit,先将数值放大y2=fix(16384+(2^14-1)*signal1);%量化到15bity3=fix(16384+(2^14-1)*signal2);%量化到15bity1=y2+y3;%量化到16bit%再将放大的浮点值量化,并写道到存放在C盘的文本

5、中fid=fopen('c:/matlab_wave_data.txt','wt');fprintf(fid,'%x',y1);%以16进制的格式将数据存放到.txt文件中。如果不用16进制,后面%读数会出错。fclose(fid);plot(y2,'b');holdon;plot(y3,'b');holdon;plot(y1,'r');legend('0.5MHz正弦','2MHz正弦','两者叠加');title('

6、;MATLAB产生的两个正弦信号的叠加波形');信号波形图如图2所示:图23QQ:290632690肤浅。。。制作存放数据的文件路径、名称已经文本的内容如图3所示:图3用MATLAB回读C盘根目录下的matlab_wave_data.txt文件,验证存入的波形数据是否正确,MATLAB代码如下:fid=fopen('c:/matlab_wave_data.txt','r');fori=1:5001;%一共有5001个数据num(i)=fscanf(fid,'%x',1);%从fid所指的文件中,以16进制的方式读出一

7、个数据endfclose(fid);figure(2);plot(num,'b');legend('MATLAB从txt文件中读出的原始叠加波形数据');title('直接回读MATLAB产生的两个正弦信号的叠加波形');显示的波形如图4所示:4QQ:290632690肤浅。。。制作图4对比图4和图2中的叠加波形,可知以上操作的正确性。2)用MATLAB设计FIR滤波器输入信号是频率别为0.5MHz和2MHz的正弦信号的叠加,我们的任务是设计一个低通滤波器滤除掉2MHz的干扰信号

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。