一、实验目的

  1. 掌握 Verilog 语言在硬件描述中的应用,通过编程实现分秒计数器的逻辑功能。

  2. 学习并实践按键消抖的原理与实现方法,提升对硬件电路中信号处理的理解。

  3. 熟悉在 DE2-115 开发板上进行 Verilog 程序的开发、调试及下载验证流程,将理论知识与实际硬件相结合 。

二、实验环境

  1. 硬件平台:DE2-115 开发板,该开发板搭载 Altera Cyclone IV E 系列 FPGA 芯片,提供丰富的外设资源,包括按键、数码管等,便于进行各类数字逻辑实验。

  2. 软件工具:Quartus Prime 开发套件,用于 Verilog 代码的编写、综合、布局布线以及下载到 FPGA 芯片中;ModelSim 用于 Verilog 代码的功能仿真,验证设计逻辑的正确性。

三、实验原理

3.1 分秒计数器原理

分秒计数器本质是一个多级计数器。秒计数器以 1Hz 的时钟信号作为计数脉冲,当秒计数器计数到 59 时,产生一个进位信号,触发分计数器加 1。分计数器同样在接收到进位信号时进行计数,当分计数器计数到 59 时,可根据需求选择是否继续进位或循环归零。

3.2 按键消抖原理

机械按键在按下和释放时,由于触点的弹性作用,会产生短暂的抖动,导致信号不稳定。按键消抖通过在检测到按键状态变化后,启动一个计数器,当计数器达到一定时间(如 10ms)且按键状态未再变化时,才认为按键状态有效,从而消除抖动带来的干扰。

四、模块设计与实现

4.1 按键消抖模块(debounce.v)
module debounce (input wire clk,input wire rst_n,input wire btn_in,output reg btn_out
);parameter DEBOUNCE_TIME = 16'd250000; // 10ms @ 25MHzreg [15:0] cnt;reg btn_reg1, btn_reg2;// 同步输入信号到时钟域always @(posedge clk or negedge rst_n) beginif (!rst_n) beginbtn_reg1 <= 1'b0;btn_reg2 <= 1'b0;endelse beginbtn_reg1 <= btn_in;btn_reg2 <= btn_reg1;endend// 消抖计数器always @(posedge clk or negedge rst_n) beginif (!rst_n) begincnt <= 16'd0;btn_out <= 1'b0;endelse beginif (btn_reg2 != btn_out) begincnt <= cnt + 1'b1;if (cnt >= DEBOUNCE_TIME) beginbtn_out <= btn_reg2;cnt <= 16'd0;endendelsecnt <= 16'd0;endendendmodule

该模块通过两级触发器将按键输入信号同步到时钟域,然后使用一个计数器在检测到按键状态变化时开始计数,当计数达到设定的消抖时间且按键状态稳定时,输出稳定的按键信号。

4.2 分秒计数器模块(counter.v)
	module counter (input wire clk,input wire rst_n,input wire pause,output reg [5:0] sec,output reg [5:0] min
);always @(posedge clk or negedge rst_n) beginif (!rst_n) beginsec <= 6'd0;min <= 6'd0;endelse if (!pause) beginif (sec == 6'd59) beginsec <= 6'd0;if (min == 6'd59)min <= 6'd0;elsemin <= min + 1'b1;endelsesec <= sec + 1'b1;endend
endmodule

在时钟上升沿或复位信号有效时,对分秒计数器进行操作。当暂停信号无效时,秒计数器在计数到 59 后归零并使分计数器加 1,分计数器计数到 59 后归零,实现循环计数;当暂停信号有效时,计数器停止计数。

4.3 顶层模块(top_module.v)
module top_module (input wire clk,input wire rst_n,input wire pause_btn,output reg [6:0] seg,output reg [3:0] an
);wire clean_pause;wire [5:0] sec;wire [5:0] min;debounce u1 (.clk(clk),.rst_n(rst_n),.btn_in(pause_btn),.btn_out(clean_pause));counter u2 (.clk(clk),.rst_n(rst_n),.pause(clean_pause),.sec(sec),.min(min));always @(*) begincase({an})4'b1110: beginan = 4'b1110;case(min[5:4])2'b00: seg = 7'b0000001;2'b01: seg = 7'b1001111;2'b10: seg = 7'b0010010;2'b11: seg = 7'b0000110;endcaseend4'b1101: beginan = 4'b1101;case(min[3:0])4'b0000: seg = 7'b0000001;4'b0001: seg = 7'b1001111;4'b0010: seg = 7'b0010010;4'b0011: seg = 7'b0000110;4'b0100: seg = 7'b1001100;4'b0101: seg = 7'b0100100;4'b0110: seg = 7'b0100000;4'b0111: seg = 7'b0001111;4'b1000: seg = 7'b0000000;4'b1001: seg = 7'b0000100;endcaseend4'b1011: beginan = 4'b1011;case(sec[5:4])2'b00: seg = 7'b0000001;2'b01: seg = 7'b1001111;2'b10: seg = 7'b0010010;2'b11: seg = 7'b0000110;endcaseend4'b0111: beginan = 4'b0111;case(sec[3:0])4'b0000: seg = 7'b0000001;4'b0001: seg = 7'b1001111;4'b0010: seg = 7'b0010010;4'b0011: seg = 7'b0000110;4'b0100: seg = 7'b1001100;4'b0101: seg = 7'b0100100;4'b0110: seg = 7'b0100000;4'b0111: seg = 7'b0001111;4'b1000: seg = 7'b0000000;4'b1001: seg = 7'b0000100;endcaseenddefault: beginan = 4'b1111;seg = 7'b1111111;endendcaseendendmodule

顶层模块将按键消抖模块和分秒计数器模块实例化并连接,同时实现数码管动态显示逻辑,通过扫描不同位的数码管,分时显示分和秒的数值。

五、实验结果与分析

程序在quartus上编译无误后,烧录到板子上运行

在这里插入图片描述

将编译后的程序下载到 DE2-115 开发板中,通过实际操作按键进行测试。按下复位按键,数码管显示 “00:00”;按下暂停按键,计数器暂停计数,数码管数值保持不变;再次按下暂停按键,计数器继续计数。数码管能够稳定、正确地显示分和秒的数值,实验功能成功实现。

六、总结

本次实验成功在 DE2-115 板子上使用 Verilog 实现了具有按键暂停和按键消抖功能的分秒计数器。通过实验,深入理解了 Verilog 语言的编程方法、按键消抖的原理以及 FPGA 开发流程。在实验过程中,也遇到了如数码管显示编码错误、时序匹配等问题,通过查阅资料和调试得以解决。

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

R4 LSTM-火灾温度预测

import tensorflow as tf import pandas as pd import numpy as npgpus tf.config.list_physical_devices("GPU") if gpus:tf.config.experimental.set_memory_growth(gpus[0], True) #设置GPU显存用量按需使用tf.config.set_visible_devices([gpus[0]],&…

什么是跨域问题?后端如何解决跨域问题?

跨域问题是指浏览器为了安全&#xff0c;对不同域&#xff08;包含不同协议、不同端口或不同主机名&#xff09;的请求进行限制&#xff0c;从而导致请求无法正常访问后端接口。 跨域问题的产生源于浏览器的同源策略&#xff08;Same-Origin Policy&#xff09;&#xff0c;这…

vue | rollup 打包 | 配置 rollup.config.js 文件,更改 rollup的行为

原因&#xff1a;将入口文件 转为 esm 和 umd 两种格式&#xff0c;要配置 rollup Rollup 已内置到 vite 工具中&#xff0c; 命令行打包&#xff0c;参数多&#xff0c;麻烦——》解决&#xff1a;创建配置文件&#xff0c;js 写的&#xff0c;rollup.config.js 配置 rollup.…

服务器中物理处理器和逻辑处理器的区别?

在服务器或任何计算机系统中&#xff0c;**物理处理器&#xff08;Physical Processor&#xff09;和逻辑处理器&#xff08;Logical Processor&#xff09;**是两个不同的概念&#xff0c;它们分别代表了硬件层面和操作系统层面的处理能力。 物理处理器&#xff08;Physical P…

【Gin框架】中间件

1. 什么是中间件 (Middleware)&#xff1f; 在 Web 框架的语境下&#xff0c;中间件 (Middleware) 是一种可重用的软件组件或函数&#xff0c;它被设计用来在 HTTP 请求-响应生命周期中的特定点拦截和处理请求或响应。在 Gin 框架中&#xff0c;中间件特指符合 gin.HandlerFun…

STUN (Session Traversal Utilities for NAT) 服务器是一种网络协议

STUN (Session Traversal Utilities for NAT) 服务器是一种网络协议&#xff0c;主要用于帮助位于网络地址转换 (NAT) 设备&#xff08;如路由器&#xff09;后面的客户端发现自己的公共 IP 地址和端口号。这对于建立点对点 (P2P) 通信至关重要&#xff0c;尤其是在 VoIP&#…

AQS详解

概念 AQS&#xff08;AbstractQueuedSynchronizer&#xff09; 是并发包&#xff08;java.util.concurrent&#xff09;的核心组件&#xff0c;用于构建锁和同步器&#xff08;如 ReentrantLock、Semaphore、CountDownLatch 等&#xff09;。它通过维护一个 CLH 队列 和 同步状…

python实战项目76:51job数据采集与分析

python实战项目76:51job数据采集与分析 一、数据采集二、数据预处理2.1 导入相关库、读取数据2.2 查看数据2.3 处理数据、删除重复值、删除空值2.4 处理薪资水平字段数据三、数据可视化3.1 不同公司规模招聘岗位数量分布3.2 不同公司性质招聘岗位数量分布3.3 不同年限要求招聘岗…

每天一个前端小知识 Day 7 - 现代前端工程化与构建工具体系

现代前端工程化与构建工具体系 1. 为什么要工程化&#xff1f;&#xff08;面试高频问题&#xff09; 问题痛点&#xff1a; 模块太多、无法组织&#xff1b;代码冗长、性能差&#xff1b;浏览器兼容性差&#xff1b;团队协作混乱&#xff0c;缺少规范与自动化。 工程化目标…

shell脚本--变量及特殊变量,算术逻辑运算

1.变量是什么 2.变量类型 3.动态&#xff0c;静态&#xff0c;强弱类型 4.变量的命名 5.变量的定义和引用 5.1三种变量类型 普通变量 环境变量 局部变量 5.2单引号&#xff0c;双引号&#xff0c;强弱引用 双引号对变量赋值的影响01:59&#xff1a;给变量加双引号&#x…

Python粒子群优化算法结合热力图TIFF文件案例

Python粒子群优化算法结合热力图TIFF文件案例 1. 项目概述 本项目使用粒子群优化算法(PSO)在热力图TIFF文件中寻找温度最高点。热力图通常以地理空间数据形式存储(TIFF格式),包含温度分布信息。PSO算法模拟鸟群觅食行为,通过粒子协作在搜索空间中寻找最优解。 import …

使用Mambaout替换YOLObackbone 整合全局信息,提升遮挡目标检测中定位能力,以及小目标、多尺度

近年来&#xff0c;Transformer 架构虽在各类任务中成为主流&#xff0c;但注意力机制的二次复杂度对长序列处理构成挑战。为此&#xff0c;类似 RNN 的模型如 Mamba 被引入&#xff0c;其核心是状态空间模型&#xff08;SSM&#xff09;&#xff0c;旨在以线性复杂度处理长序列…

力扣网C语言编程题:接雨水(动态规划实现)

一. 简介 本文记录力扣网上的逻辑编程题&#xff0c;涉及数组方面的&#xff0c;这里记录一下 C语言实现和Python实现。 二. 力扣网C语言编程题&#xff1a;接雨水 题目&#xff1a;接雨水 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子…

关于ubuntu环境下vscode进行debug的随笔

CMakeLists.txt的编写 顶层目录的CMakelists.txt 目录&#xff1a;./CMakeLists.txt #./CMakeLists.txt cmake_minimum_required(VERSION 3.10) project(xxx_project_name LANGUAGES CXX) #设置工程名# 设置 C 标准和编译选项 set(CMAKE_CXX_STANDARD 17) set(CMAKE_CXX_ST…

技术演进中的开发沉思-9:window编程系列-内核对象线程同步(下)

今天我们继续走进 Windows 内核的世界&#xff0c;就昨天没说完的内核对象与线程同步内容接着继续&#xff0c;它们就像精密仪器里的齿轮&#xff0c;虽不显眼&#xff0c;却至关重要。 异步设备 I/O 在 Windows 系统中&#xff0c;异步设备 I/O 就像是一场精心编排的接力赛。…

用AI从0开始量化交易-Anaconda环境(env)和缓存(pkg)更改储存位置

之前介绍了Anaconda的安装和环境建立&#xff0c;最近自己的量化交易工具开发的差不多了&#xff0c;却发生了尴尬的问题&#xff0c;C盘被不断增大的conda环境和缓存占据得快满了。 在网上找了些教程&#xff0c;大多是讲迁移的&#xff0c;专门讲改本地改储存位置的比较少&am…

Python爬虫工作基本流程及urllib模块详解

在2025年的数据驱动时代&#xff0c;网络数据成为企业与个人的“金矿”&#xff0c;而Python爬虫则是挖掘这金矿的“利器”&#xff01;无论是抓取电商价格、分析社交媒体趋势&#xff0c;还是构建知识库&#xff0c;Python爬虫都能让你事半功倍。然而&#xff0c;爬虫开发并非…

thinkphp8 模型-一对一,一对多,多对多 学习

thinkphp 命令创建模型&#xff08;和laravel基本一样&#xff09; php think make:model User 在模型里创建字段 protected $table User; protected $pk id; // 定义返回哪些字段 protected $field [id, name]; // 返回字段的类型 protected $schema [id > int] 模…

非线性方程组求解:复杂情况下的数值方法

在科学研究和工程应用中&#xff0c;非线性方程组的求解是一个常见的挑战。尤其当方程组包含复杂函数&#xff08;如特殊函数、积分、微分等&#xff09;&#xff0c;使得雅可比矩阵难以解析求导时&#xff0c;传统的基于解析雅可比矩阵的 Newton-Raphson 方法难以直接应用。本…

边缘计算网关EG8200Mini首发开箱视频丨破解工业互联“协议孤岛”,重塑数据价值核心引擎行业痛点直击|低代码开发

数据采集4G边缘计算网关plc 工业现场设备品牌林立&#xff08;西门子、三菱、欧姆龙等30品牌PLC&#xff09;、协议碎片化&#xff08;Modbus/OPC UA/BACnet等&#xff09;、网络环境复杂&#xff08;户外无光纤、车间电磁干扰&#xff09;——传统网关难以实现多源异构设备统一…