xilinx FPGA 平台实现数字信号 -- 低通滤波

xilinx FPGA 平台实现低通滤波效果:

  1. 生成一个10KHZ 叠加上100KHZ的信号,定义成data_all
  2. 使用1MHZ 采样频率,采取data_all 信号1024个点
  3. 试用低通滤波器 滤除100KHZ的信号,恢复出10KHZ信号

以下是matlab中实现:

matlab 复制代码
clc;
clear all;

FS = 1000000; 
N = 1024;
n = 1:1024;
t = 1/FS * n;

A1=1;
P1=0;
F1=10000;

A2=1;
P2=0;
F2=100000;

data1 = A1 * sin(2 *pi * t * F1) ;
data2 = A2 * sin(2 *pi * t * F2) ;

data_all = data1 + data2;

fix_data = fix(data_all/2 * (2^15-1) + (2^15-1));

%%%%%%%%%%%%%%%%%%%%%%生成dat文件%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
fid = fopen("fix_data.dat",'w');

for i=1:N 
    fprintf(fid,"%x\n",fix_data(i));
end

fclose(fid);

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

subplot (511);
plot(data1);

subplot (512);
plot(data2);

subplot (513);
plot(data_all);

a = 50000 * 2 /FS;
b = fir1(50,a,'low');
subplot (514);
stem(b);

data_f = filter(b,1,data_all);
subplot (515);
plot(data_f);

在FPGA中实现fir低通滤波的效果:

1.matlab 产生的 data_all 信号的 dat文件

2.FPGA中的RAM 存储 这个dat文件数据

3.配置 fir IP 核,加载 matlab 产生的 滤波系数

a.matlab 输入 fdatool 出现 滤波器 设置窗口,如下图

b. 设置好,可以看到下图在50k左边几乎是没有衰减的,右边频率经过 -40db的衰减。100倍的衰减,20db代表10倍衰减。

c. 送入 fir IP 数据都是 整数,没有小数,所以需要设置 下图参数为定点数,小数设置为0

d.生成 xilinx 平台需要的 coe 文件


4.仿真

使用vivado 仿真效果:上图是data_all 信号

下图是滤波后波形:

1.发现相位和data_all信号有偏差,相位是随机的,没有办法调整;

2.前50周期空窗期,没有意义,与滤波器阶数有关;

  1. 需要注意 fir IP 会对输入信号增益放大到一定倍数,所以最后IP核出来的数据需要缩小相应倍数
相关推荐
Moonnnn.4 小时前
【FPGA】设计流程——板级验证
fpga开发
ALINX技术博客4 小时前
ALINX 携手 PhineDesign 亮相日本 DSF2025,用 FPGA 产品力响应时代技术浪潮挑战!
fpga开发·fpga
电子凉冰8 小时前
FPGA强化-TFT_LCD液晶屏驱动设计与验证
fpga开发·1024程序员节
电子凉冰20 小时前
FPGA强化- HDMI显示器驱动设计与验证
fpga开发
FPGA-李宇航1 天前
RAM和ROM的定义和区别总结!!!
fpga开发
FPGA_小田老师1 天前
FPGA状态机设计实战:从概念到可靠实现的完整指南
fpga开发·状态机·锁存器·寄存器·可乐售卖机·状态机实战
云雾J视界1 天前
6G通信基站原型开发:Stratix 10 SoC片上128位AXI总线优化与400G加密引擎实现
fpga开发·soc·加密引擎·axi4总线·hyperflex架构·32核并行架构
江蘇的蘇1 天前
UltraScale/+ FPGA实现万兆网的两种方式:GT核、10G Ethernet Subsystem核
fpga开发
骁的小小站1 天前
Verilator 和 GTKwave联合仿真
开发语言·c++·经验分享·笔记·学习·fpga开发
知识充实人生1 天前
时序收敛方法一:控制集优化
stm32·单片机·fpga开发