quartus下联合modelsim_Altera仿真

news2024/11/24 7:24:44

vivado工程转换到quartus下联合modelsim仿真_内有小猪卖的博客-CSDN博客
这个博客是用单独的modelsim仿真,而下面的流程是使用quartus自带的modelsim-altera仿真。


        版本为:quartus ii 13.1 64-bit

        以fpga实现数码管和流水灯编码为例。数码管为1时,流水灯状态1234567->1234567;数码管为2时,流水灯状态1234567->7654321。事先建立一个空文件(test_nixie_tube)用来存放工程,注意路径不要有中文。


目录

一、建立工程

1、准备源码和仿真文件

2、新建工程

3、加载源文件

4、选择器件

5、仿真器配置

6、工程信息

二、配置工程

7、设置顶层文件

8、建立仿真文件

9、配置仿真工具路径

三、编译仿真

10、编译

11、仿真

参考文章


一、建立工程

1、准备源码和仿真文件

源文件 + 仿真文件(tb_top)  

2、新建工程

2.1 打开quartus II,点击file ---> New Project Wizard

1是我们事先建好的工程文件,2是工程名。为了方便这俩名字可以设置相同。

3、加载源文件

上一步配置好了点 next,然后点“...”选择我们写好的源文件。

 添加了3个源文件后,点击“next”。

4、选择器件

器件这块按需求选择。

5、仿真器配置

仿真器选择Modelsim-Altera,格式选择Verilog HDL。下面点击"next"

6、工程信息

下一个窗口是工程信息,直接点击“finish”。

 到此工程就建好了。

二、配置工程

7、设置顶层文件

先设置顶层top,告诉编译器哪个是顶层文件,否则会报错如下。

12007 Top-level design entity "your_project" is undefined
Quartus II 64-Bit Analysis & synthesis was unsuccessful. 1 error,0 warnings
293001 Quartus II Full compilation was unsuccessful. 3 errors,0 warnings

然后点这个三角,编译文件。

编译成功

查看rtl图(选做)

就可以看到了。 

8、建立仿真文件

        我们已经有一个仿真文件了,可以直接选仿真文件加载。因为我准备的基于vivado平台的,稍微有点不一样。比如quartus的仿真文件是.vt,而vivado的仿真文件是.v,这俩都是基于vivado平台的。

        为了保险起见,我们还是新建一个仿真文件,然后把之前的仿真内容复制过去。

        点击processing -----> start ------>start Test Bench Template Writer 新建一个仿真文件,我们去这个工程路径的simulation---->modelsim文件夹下找到.vt文件,然后编辑它。

        为了不和源码的顶层文件重名,将vt文件名改成tb_top;并将之前准备好的仿真文件内容复制过来。

        为了方便,仿真文件的module名也改成tb_top,然后保存。

9、配置仿真工具路径

打开配置菜单,找到 project Navigator ----> top 右键点击setting

 然后进入配置tb文件

数字1:新建仿真信息

数字2:tb文件名

数字3:tb文件中module名,所以这俩设置一样就很方便。

数字4:选择仿真文件

数字5:点击add 添加文件

数字6:表示加载了tb文件,然后点击ok

后面一路点击ok,大概3个ok。

三、编译仿真

10、编译

加载仿真文件后,再编译一次。

编译成功之后依次点击就行。

11、仿真

如果没有直接弹出来,找到仿真文件tb_top,然后点simulate。

6、先执行数字6,在深蓝色部分,把端口拖拽放到右侧灰色地方

1、重新运行程序restart

2、点击run,运行仿真波形

3、comtinue run:

        让仿真波形继续跑,因为会跑一段就停止,如果想让波形继续跑,就需要点击。

4、re-run :让波形重新跑

5、取消编译和仿真

5右边的stop按钮是停止仿真

正确显示波形

参考文章

Quartus同Modelsim的联合仿真_quartus 18.0与modelsim或modelsim altera进行波形联合仿真_1个程序源的博客-CSDN博客

【FPGA】TestBench中关于@eachvec_xiao_-_zhu的博客-CSDN博客

https://www.cnblogs.com/lsjjob/p/5127974.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/628232.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring中Bean加载流程

上面是跟踪了 getBean 的调用链创建的流程图,为了能够很好地理解 Bean 加载流程,省略一些异常、日志和分支处理和一些特殊条件的判断。 从上面的流程图中,可以看到一个 Bean 加载会经历这么几个阶段(用绿色标记)&…

机器学习算法分类(三)

在机器学习中,又分为监督学习、无监督学习、半监督学习、强化学习和深度学习。 监督、无监督、半监督学习 机器学习根据数据集是否有标签,又分为监督学习、无监督学习、半监督学习。 监督学习:训练数据集全部都有标签无监督学习&#xff1a…

grep命令的使用

grep命令是Linux中常用的文本搜索工具,它可以根据用户指定的模式,在文件或标准输入中查找匹配的文本行并返回。 下面是grep命令的一些常见选项: -i:忽略大小写-n:显示匹配行的行号-v:显示不匹配的行-r&am…

【新版】系统架构设计师 - 计算机系统基础知识

个人总结,仅供参考,欢迎加好友一起讨论 文章目录 架构 - 计算机系统基础知识考点摘要计算机系统计算机硬件组成浮点数Flynn分类法CISC与RISC流水线技术超标量流水线存储系统层次化存储结构CacheCache的命中率Cache的页面淘汰主存编址磁盘管理&#xff08…

《MySQL(四):基础篇- 约束》

文章目录 4. 约束4.1 概述4.2 约束演示4.3 外键约束4.3.1 介绍4.3.2 语法4.3.3 删除/更新行为 4. 约束 4.1 概述 概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。 目的:保证数据库中数据的正确、有效性和完整性。 分类: 约…

YOLOv5白皮书-第Y6周:模型改进

目录 一、改进网络结构设计1 改进的注意力机制2 多尺度特征融合3 改进的激活函数 二 数据增强和数据平衡1 数据增强2 数据平衡3 注意事项 三、模型融合策略1 投票策略2 加权平均策略3 特征融合策略4 其他模型融合策略 🍨 本文为🔗365天深度学习训练营 中…

protobuf实现原理

文章目录 一、前言二、概述三、数据存储方式:Varints(一)原理(二)举例(三)缺点 四、协议的数据结构(一)原理(二)举例 一、前言 最近刚刚从一家公司离职,在职的时候使用到了go语言的grpc库,了解了除了json之外的另一个专门用于远程调用的序列…

二本计算机专业学长经验之谈

2023.6.9 今年的行情对我们这些双非大学、二本真的太难了,菜鸟今年感觉毕业找的工作真的又苦逼钱又少,准备跳槽的,结果满大街投简历,连个毛都没有,唯一一个给了个海笔,然后就没然后… 所以希望大家真的要好…

Element的Select分组全选模式

Select 选择器选择器的分组,如上图所示,我们希望做到的效果是,点击“热门城市”或“城市名”的时候全选分组的options。 思路 思路一:目前的Select 选择器分组OptionGroup的Title只是一个文本DOM,没用其他东西&#…

详解基于罗德里格斯(Rodrigues)公式由旋转向量到旋转矩阵的 Python 实现

文章目录 旋转向量 rotation vector旋转矩阵 rotation matrix罗德里格斯公式 Rodrigues formula基于 Python 和 NumPy 实现 Rodrigues 公式 旋转向量 rotation vector 任何一个旋转都可以通过一个 旋转轴 加一个 旋转角 进行描述, 即围绕 旋转轴 旋转一个 旋转角. 此时可以通过…

javascript 中的 URL 解码

文章目录 需要URL编解码JavaScript 中的 URL 解码使用 unescaped() 方法解码编码的 URL使用 decodeURI() 方法解码编码的 URL使用 decodeURIComponent() 方法解码编码的 URL 总结 本文着眼于 URL 解码以及如何使用 JavaScript 对编码的 URL 进行解码。 需要URL编解码 URL 应具…

政企HTTPS加密国产化替代的四要素

信创产业是数字经济、信息安全发展的基础,也是“新基建”的重要内容,将成为拉动中国经济增长的重要抓手之一。随着国资委79号文的发布,国央企落实信息化系统的信创国产化改造的步伐加快,贯彻“28N”战略,从党政机关扩展…

Doris学习笔记

1.数据模型 数据模型 - Apache Doris 1.1 Aggregate 模型(聚合) 可以发现,user_id、date、age ...等没有设置 AggregationType, 那么这几个字段就成了一个key了。设置了 AggregationType 字段,说明该列的属性已经成value了。 我们导入一张…

Linux·Binder机制原理

目录 前言 目录 1. Binder到底是什么? 2. 知识储备 2.1 进程空间划分 2.2 进程隔离 & 跨进程通信( IPC ) 2.5 内存映射 3. Binder 跨进程通信机制 模型 3.1 模型原理图 3.3 模型原理步骤说明 3.4 额外说明 4. Binder机制 在An…

自学黑客(网络安全),一般人我劝你还是算了

写在开篇 笔者本人 17 年就读于一所普通的本科学校,20 年 6 月在三年经验的时候顺利通过校招实习面试进入大厂,现就职于某大厂安全联合实验室。 我为啥说自学黑客,一般人我还是劝你算了吧!因为我就是那个不一般的人。 ​ 首先我…

elementui tree 支持虚拟滚动和treeLine (下)

​ 由于我之前没有发布过npm 包,这里还得现学一下。 参考资料: 链接: 如何写一个vue组件发布到npm,包教包会,保姆级教学链接: vue组件发布npm最佳实践 按照上面的步骤,我通过 vue-sfc-rollup 生成了项目,…

六级备考8天|CET-6|阅读强化|16:00~17:20

调整做题顺序:仔细阅读——>长篇阅读(信息匹配)——>翻译——>选词填空 顺关系 or 反关系 正态度 or 负态度 阅读要有针对性 理解要有空白性 2)高大上的思维来自于中文的语言特点 练习 第一段:例子,无观点&am…

微伴助手如何增加客户积分?如何自动给客户添加企业标签?

微伴助手是一款企业微信第三方应用,已经为电商、教育、金融、保险、医疗等机构提供技术支持,适用于引流获客、客户意向跟进、销售转化、社群运营等全方位营销场景,旨在帮助企业构建高转化率的私域流量池。 微伴助手基于企业微信开放的接口&a…

adb shell 调试 Android 串口 百度AI也很

在 Android 平台上进行串口调试需要使用 Android Debug Bridge (ADB) 工具。ADB 是一个命令行工具,可以通过 USB 连接 Android 设备,并执行各种命令来调试应用程序。 以下是使用 ADB shell 进行 Android 串口调试的步骤: 连接 Android 设备…

【2023最全教程】什么是自动化测试框架?熬夜7天整理出这一份3000字超全学习指南

所有软件在提供给用户之前都必须经过测试。软件测试是开发生命周期中必不可少的一步因为它确保用户必须收到符合其开发目的的高质量产品。每个企业都优先考虑测试;因此,大多数人更愿意从手动测试转向自动化。因此,自动化测试框架是任何软件测试过程的基础…