【FPGA】时序逻辑计数器——仿真验证

1.新建文件

先新建test bench文件,led_twinkle_tb,将需要仿真的模块添加到test bench中,也就是例化

2.搭建框架

写好基本框架

3.端口定义

在test bench中添加针对输入端口的激励信号的定义以及针对输出端口的观测信号的定义

4.进行连线

定义完成后将其和被测试模块连接到一起,进行连线

5.产生激励信号

产生时钟信号

  • 20ns的周期对应10ns高电平,10ns低电平
  • 先进行初始化
  • always后没有其他内容,无条件的执行后面的内容,延时10ns后Clk取反,~代表按位取反

产生复位信号

  • 先通过复位将D触发器的输出值设置为零,然后触发器从0开始,每个时钟周期加一
  • 在仿真时间线上往后推移201ns,再将Reset_n信号拉高,这样系统就从复位状态恢复出来,开始正常计数
  • #201:时钟每10ns翻转一次,10个时钟周期刚好200ns,即仿真的第200nsCLK信号刚好出现上升沿,如果此时Reset_n刚好从0到1,容易引起波形阅读的误会,影响对波形的分析,所以这里特意多等1ns
  • #2000_000_000是2s
  • $stop停止

6.进行仿真

通过图示选项进行仿真

Vivado中的默认停止时间是1000ns,所以会在1000ns的时候停止,这是需要手动点击Run All让仿真继续运行

对于时序逻辑的仿真,在分析波形的时候需要看时间是否精准

仿真软件有测量光标

Previous Transition:前一个变化的位置

Add Marker:添加光标

选中第一个蓝色标记线,会出现两个标记线之间的时间间隔

通过转换可得是500ms20ns,比预期的500ms多了20ns,刚好是一个CLK时钟周期的时间

计数器从最大值变为0也需要消耗一个时钟周期

解决上述问题,只需要将原本设计好的计时最大值减1即可

点击该图标,重新开始加载仿真

删除光标(右击光标就会出现)

Delete All Marker:删除所有光标

然后重新添加光标,重新吸附,可以看到时是500ns

initial reset信号在201ns之后才关断,所以实际计数信号是201纳秒才开始的。这个无所谓,电路一般都有个初始化过程。

相关推荐
qq_小单车4 小时前
xilinx-DNA
fpga开发·xilinx
Flamingˢ5 小时前
FPGA中的嵌入式块存储器RAM:从原理到实现的完整指南
fpga开发
Flamingˢ7 小时前
FPGA中的存储器模型:从IP核到ROM的深度解析与应用实例
网络协议·tcp/ip·fpga开发
FPGA小c鸡1 天前
【FPGA深度学习加速】RNN与LSTM硬件加速完全指南:从算法原理到硬件实现
rnn·深度学习·fpga开发
Aaron15881 天前
通信灵敏度计算与雷达灵敏度计算对比分析
网络·人工智能·深度学习·算法·fpga开发·信息与通信·信号处理
博览鸿蒙1 天前
IC 和 FPGA,到底区别在哪?
fpga开发
思尔芯S2C1 天前
FPGA原型验证实战:如何应对外设连接问题
fpga开发·risc-v·soc设计·prototyping·原型验证
Flamingˢ1 天前
FPGA实战:VGA成像原理、时序详解与Verilog控制器设计与验证
fpga开发
FPGA_小田老师1 天前
xilinx原语:OSERDES2(并串转换器)原语详解
fpga开发·lvds·xilinx原语·oserdese·并串转换
Blossom.1181 天前
从数字大脑到物理实体:具身智能时代的大模型微调与部署实战
人工智能·python·深度学习·fpga开发·自然语言处理·矩阵·django