小梅哥FPGA学习笔记——计数器IP核调用及仿真

2023-11-05 11:59

本文主要是介绍小梅哥FPGA学习笔记——计数器IP核调用及仿真,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

计数器IP核调用

  • 计数器IP核使用
    • FPGA设计方式
    • 计数器IP核配置
    • Ip核实现到硬件RTL结构
  • 功能仿真
  • IP核调用实现计数器级联

计数器IP核使用

FPGA设计方式

1、原理图输入(不推荐)系统比较大的时候修改十分困难
2、Verilog HDL设计方式
3、IP核输入方式(例如FFT的实现,包括的原理到最终实现,使用verilogHDL进行开发内容多开发周期太长,缩短开发周期)

计数器IP核配置

QuartusII 提供的LPM_counter IP核的使用

1、 选择输出是多少位
2、 选择计数方式为1向上计数2向下计数3创建一个端口选择是增计数或减计数

在这里插入图片描述
3、 选择计数器类型1直接二进制计数2模的形式,计数器计数到设置的最大值直接清零
4、 选择需要的端口1时钟使能信号2计数使能信号3进位输入:若使用这个信号,只有当进位输入有效,才会进行计数4进位输出:若使用信号,当计数结果满预设值,会输出一个进位输出。用于实现计数器级联。
在这里插入图片描述
5、 清零、加载、置位选项

在这里插入图片描述
Finish后添加IP核,qip信息文件

在这里插入图片描述

qip信息文件
在这里插入图片描述
添加IP核到工程,counter.v就是需要添加等ip核文件。Counter_bb.v文件为blackbox黑盒文件,涉及到ip核具体实现有关,不需要关心。
添加counter.v文件后,代码如下
在这里插入图片描述
对于具体内容不用关心,只需要关心端口,将端口例化到用户设计中即可。
由于counter的ip核直接就可以作为输出,可以直接将counter设置为顶层模块进行输出。

Ip核实现到硬件RTL结构

总体框图
总体框图

没有使用到到引脚就会默认接地
在这里插入图片描述
Counter1、2、3及查找表等结构构成计数器,更加接近FPGA内部的电路结构
在这里插入图片描述

功能仿真

编写testbench文件
测试文件中需要给出输入计数的激励
这里每五个低电平产生一个高电平给到计数输入口,重复五次。每得到一个高电平计数器计数一次。

`timescale 1ns/1ns`define clock_period  20//定义时钟周期,频率20ns,周期20MHz
module counter_tb;//定位输入端口,输入端口使用reg类型reg cin;//进位输入reg clk;//计数基准时钟
//定位输出端口,输出端口用wire类型wire cout;wire [3:0] q;counter counter_0(//模块例化,对新的测试模块命名为counter_0.cin    (cin),.clock  (clk),.cout   (cout),  .q      (q)     );//原模块名 新模块名(//.原模块接口1 (新模块接口1),//.原模块接口2 (新模块接口2),//);//初始化时钟信号initial clk = 1 ;always #(`clock_period/2)clk = ~clk;//每到达时钟周期到一半时,对时钟进行翻转initial beginrepeat(20)begin//repeat重复循环5次cin = 0 ;#(`clock_period*5)cin = 1;//低电平保持五个时钟周期,高电平保持一个时钟周期,得到一个脉冲信号#(`clock_period)cin = 0;end#(`clock_period*200);$stop;endendmodule

仿真结果

在这里插入图片描述

在这里插入图片描述

由于设置ip核的最大计数值为10,计数器在计数满十次,在计数到9的时候,产生进位输出,下次的计数值为0。在0的时候产生一个毛刺的情况,可能是因为计数器ip核内有布局布线产生的。

更改ip核的设置
在这里插入图片描述
此时的进位标志只有当计数器计满时,产生进位标志。

在这里插入图片描述

IP核调用实现计数器级联

编写顶层模块,例化两个计数器,并进行级联。
顶层模块例化代码如下

module counter_top(cin,clk,cout,q);input cin;input clk;output cout;output [7:0] q;wire cout0;//顶层默克进行模块例化counter counter_0(//例化第一个模块.cin   (cin),.clock (clk),.cout  (cout0),//低位置位信号.q     (q[3:0])//低四位输出);counter counter_1(//例化第二个模块.cin   (cout0),//低位置位输出连接到高位输入.clock (clk),.cout  (cout),.q     (q[7:4])//高四位输出);endmodule

RTL视图如下所示。

在这里插入图片描述

编写顶层模块测试的testbench文件

`timescale 1ns/1ns`define clock_period  20//定义时钟周期,频率20ns,周期20MHz
module counter_top_tb;//定位输入端口,输入端口使用reg类型reg cin;//进位输入reg clk;//计数基准时钟
//定位输出端口,输出端口用wire类型wire cout;wire [7:0] q;counter_top counter_0(//模块例化,对新的测试模块命名为counter_0.cin    (cin),.clk  (clk),.cout   (cout),  .q      (q)     );//原模块名 新模块名(//.原模块接口1 (新模块接口1),//.原模块接口2 (新模块接口2),//);//初始化时钟信号initial clk = 1 ;always #(`clock_period/2)clk = ~clk;//每到达时钟周期到一半时,对时钟进行翻转initial beginrepeat(300)begin//repeat重复循环5次cin = 0 ;#(`clock_period*5)cin = 1;//低电平保持五个时钟周期,高电平保持一个时钟周期,得到一个脉冲信号#(`clock_period)cin = 0;end#(`clock_period*200);$stop;endendmodule

仿真结果波形
计数到255时cout输出一个脉冲信号。实现两个四位计数器级联进行计数。最高能计数到11111111(b)=255(d)

在这里插入图片描述
更改计数器的设置

在这里插入图片描述
让计数器每10产生一次输出
这样的结果是计数到153时cout输出一个脉冲,然后清零。理由:四位计数器的高四位输出为9(hex),低四位的最高输出也为9,那么输出的最大数字为99(hex)=153(d)

在这里插入图片描述

这篇关于小梅哥FPGA学习笔记——计数器IP核调用及仿真的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/349718

相关文章

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

Vue 调用摄像头扫描条码功能实现代码

《Vue调用摄像头扫描条码功能实现代码》本文介绍了如何使用Vue.js和jsQR库来实现调用摄像头并扫描条码的功能,通过安装依赖、获取摄像头视频流、解析条码等步骤,实现了从开始扫描到停止扫描的完整流... 目录实现步骤:代码实现1. 安装依赖2. vue 页面代码功能说明注意事项以下是一个基于 Vue.js

Linux系统中配置静态IP地址的详细步骤

《Linux系统中配置静态IP地址的详细步骤》本文详细介绍了在Linux系统中配置静态IP地址的五个步骤,包括打开终端、编辑网络配置文件、配置IP地址、保存并重启网络服务,这对于系统管理员和新手都极具... 目录步骤一:打开终端步骤二:编辑网络配置文件步骤三:配置静态IP地址步骤四:保存并关闭文件步骤五:重

Linux配置IP地址的三种实现方式

《Linux配置IP地址的三种实现方式》:本文主要介绍Linux配置IP地址的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录环境RedHat9第一种安装 直接配置网卡文件第二种方式 nmcli(Networkmanager command-line

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM