【FPGA】高云FPGA之科学的FPGA开发流程(二)

简介: 【FPGA】高云FPGA之科学的FPGA开发流程

【FPGA】高云FPGA之科学的FPGA开发流程(一)https://developer.aliyun.com/article/1472626


4、功能仿真

这里我们需要将我们的源代码设置为顶层文件(这里引用一下小梅哥的图),然后我们可以看到该源码所占用的资源情况

然后我们创建一个test beach测试文件

代码如下

`timescale 1ns/1ps
module mux_2_1_tb();
 
    reg In1;
    reg In2;
  reg Sel;
  wire Led;
  
  // 创建模块实例并赋值参数
  mux_2_1 Mux_2_1(
    .in1(In1),
    .in2(In2),
    .sel(Sel),
    .led(Led)
  );
  // 初始化运行 测试每个真值表上对应的参数设定
    initial begin
        In1 = 0;In2 = 0;Sel = 0;
    #100; 
    In1 = 0;In2 = 0;Sel = 1;
    #100;
    In1 = 0;In2 = 1;Sel = 0;
    #100;
        In1 = 0;In2 = 1;Sel = 1;
    #100;
    In1 = 1;In2 = 0;Sel = 0;
    #100;
    In1 = 1;In2 = 0;Sel = 1;
    #100;
    In1 = 1;In2 = 1;Sel = 0;
    #100;
    In1 = 1;In2 = 1;Sel = 1;
    #100;
  end
  
endmodule

点击综合和布线,验证有无逻辑错误

然后我们打开modsim软件创建工程

添加我们的两个源码文件并编译

进入 Add Simulation Configuration 页面,我们在 Design 标签页面中选择work 库中的“ mux_2_1_tb”模块作为设计顶层,点击复制模块名作为仿真配置“ Simulation Configuration Name”的命名,确保命名保持一致。在复杂的工程设计中,我们可以设计多个不同的仿真配置顶层对工程进行仿真测试。

点击“ Optimization Options…”, 在“ Optimization Options…” 设置栏中选择“ Apply full visibility to all modules(full debug module)”,点击“ OK”

配置元件库(这一步的操作需要在modsim中已经添加了高云fpga的仿真库后操),点击“ libraries” 设置栏, 在“ Search libraries(-L)” 一栏中点击“ Add…”添加我们新建的高云的库文件“ gw5a”,在“ Search Libraries First(-Lf)”同样选择库文件“ gw5a”,最后点击“ Save”保存设置;

然后双击我们的仿真文件进入仿真界面

然后我们选中模块右击后点击Add Wave放到显示波形中

添加好波形后回到“ Library”栏,右键单击“ work”点击 Update 将

“ mux_2_1_tb”文件更新在“ work”栏,如下所示

然后我们点击状态栏中的运行即可捕捉到波形,然后右击Zoom Full可以快速查看波形,在这一步我们可以验证我们的波形是否是我们需要的效果;

下一步我们可以将modsim的工程和波形文件保存到项目project路径下;

然后点击波形界面一下再点击这个按钮选择保存波形路径

下次还需打开工程只需要点击该目录下的.mpf文件即可

到这里功能仿真也就是RTL仿真就结束了,下一步我们需要分配我们程序中引脚并完成布局布线;


【FPGA】高云FPGA之科学的FPGA开发流程(三)https://developer.aliyun.com/article/1472628

相关文章
|
8月前
|
芯片 异构计算
【FPGA】高云FPGA之数字钟实验->HC595驱动数码管(一)
【FPGA】高云FPGA之数字钟实验->HC595驱动数码管
236 2
|
8月前
|
编译器 异构计算 内存技术
【FPGA】高云FPGA之科学的FPGA开发流程(三)
【FPGA】高云FPGA之科学的FPGA开发流程
246 0
【FPGA】高云FPGA之科学的FPGA开发流程(三)
|
8月前
|
芯片 异构计算
【FPGA】高云FPGA之科学的FPGA开发流程(一)
【FPGA】高云FPGA之科学的FPGA开发流程
200 0
|
8月前
|
芯片 异构计算
【FPGA】高云FPGA之数字钟实验->HC595驱动数码管(三)
【FPGA】高云FPGA之数字钟实验->HC595驱动数码管
180 4
|
8月前
|
存储 芯片 异构计算
【FPGA】高云FPGA之数字钟实验->HC595驱动数码管(二)
【FPGA】高云FPGA之数字钟实验->HC595驱动数码管
199 4
|
8月前
|
芯片 异构计算
【FPGA】高云FPGA之IP核的使用->PLL锁相环(二)
【FPGA】高云FPGA之IP核的使用->PLL锁相环
149 1
|
8月前
|
芯片 异构计算
【FPGA】高云FPGA之IP核的使用->PLL锁相环(一)
【FPGA】高云FPGA之IP核的使用->PLL锁相环
314 0
|
算法 编译器 测试技术
第二章 FPGA开发流程
第二章 FPGA开发流程
238 0
第二章 FPGA开发流程
|
3天前
|
算法 数据安全/隐私保护 异构计算
基于FPGA的变步长LMS自适应滤波器verilog实现,包括testbench
### 自适应滤波器仿真与实现简介 本项目基于Vivado2022a实现了变步长LMS自适应滤波器的FPGA设计。通过动态调整步长因子,该滤波器在收敛速度和稳态误差之间取得良好平衡,适用于信道均衡、噪声消除等信号处理应用。Verilog代码展示了关键模块如延迟单元和LMS更新逻辑。仿真结果验证了算法的有效性,具体操作可参考配套视频。
96 74
|
1月前
|
算法 数据安全/隐私保护 异构计算
基于FPGA的16QAM调制+软解调系统,包含testbench,高斯信道模块,误码率统计模块,可以设置不同SNR
本项目基于FPGA实现了16QAM基带通信系统,包括调制、信道仿真、解调及误码率统计模块。通过Vivado2019.2仿真,设置不同SNR(如8dB、12dB),验证了软解调相较于传统16QAM系统的优越性,误码率显著降低。系统采用Verilog语言编写,详细介绍了16QAM软解调的原理及实现步骤,适用于高性能数据传输场景。
138 69

热门文章

最新文章