当前位置: 首页 > article >正文

用FPGA复刻经典数电实验:手把手教你实现一个带预置功能的十进制可逆计数器

用FPGA复刻经典数电实验手把手教你实现一个带预置功能的十进制可逆计数器记得大学时第一次在实验箱上搭建十进制计数器看着LED灯随着时钟信号跳动的那种兴奋感吗如今一块FPGA开发板就能重现这份经典体验还能赋予它更多可能性。本文将带你用Verilog语言在Quartus II平台上完整实现一个支持数据预置、双向计数、使能控制的智能计数器让课本上的状态图真正跑起来。1. 需求分析与架构设计传统实验箱 vs FPGA实现的差异就像手动组装家具和3D打印的区别。前者需要逐根连线后者通过代码描述功能。我们的计数器需要实现以下核心功能双向计数通过upd信号控制递增/递减模式同步预置当load有效时下一个时钟沿将data[3:0]的值载入计数器使能控制en信号为高电平时才允许计数进位输出计数到9递增模式或0递减模式时产生进位脉冲模块接口设计如下建议保存为dec_counter.vmodule dec_counter ( input wire clk, // 时钟信号建议接50MHz input wire rst, // 异步复位低有效 input wire en, // 计数使能 input wire load, // 同步预置使能 input wire upd, // 计数方向1递增0递减 input wire [3:0] data,// 预置数据输入 output reg [3:0] q, // 计数输出 output reg co // 进位/借位信号 );2. Verilog实现与关键代码解析2.1 核心计数逻辑计数器的灵魂在于状态转移。采用同步时序设计所有操作都在时钟上升沿触发always (posedge clk or negedge rst) begin if (!rst) begin q 4b0000; // 异步复位 co 1b0; end else if (load) begin q data; // 同步预置 co 1b0; end else if (en) begin case ({upd, q}) 5b1_1001: begin // 递增到9 q 4b0000; co 1b1; end 5b0_0000: begin // 递减到0 q 4b1001; co 1b1; end default: begin q upd ? q 1 : q - 1; co 1b0; end endcase end end代码亮点使用case语句清晰表达状态转移条件进位信号co只在临界状态9→0或0→9产生单周期脉冲所有信号变化严格同步于时钟边沿2.2 仿真测试技巧编写测试平台时建议采用分层激励法。先创建基础时钟再逐步添加控制信号initial begin // 初始化 rst 0; en 0; load 0; upd 1; data 4b0000; #20 rst 1; // 释放复位 // 测试递增计数 #30 en 1; #200 en 0; // 测试预置功能 #20 load 1; data 4b0110; #20 load 0; // 测试递减模式 #20 upd 0; en 1; #200 $stop; end仿真要点复位后先验证递增计数是否正常预置值建议选择非边界值如6以验证加载功能切换计数方向时观察过渡是否平滑3. 硬件部署与调试3.1 引脚分配策略根据Cyclone IV EP4CE6开发板资源推荐配置信号名开发板对应器件引脚号备注clk50MHz晶振PIN_88全局时钟输入rst按键KEY0PIN_24低电平复位en按键KEY1PIN_31按下使能计数load按键KEY3PIN_33按下加载预置值upd拨码SW2PIN_30上拨递增下拨递减data[3]拨码SW7PIN_44预置值高位data[0]拨码SW4PIN_32预置值低位q[3:0]LED3-LED0PIN_54-46二进制计数显示coLED4PIN_58进位指示灯布局技巧时钟信号必须分配到专用时钟引脚关键控制信号使用按键状态信号使用拨码开关LED显示按二进制权重顺序排列q[3]对应LED33.2 上板验证流程静态测试设置load1通过SW7-SW4输入不同值检查LED3-LED0是否准确显示预置值动态测试设置en1upd1观察递增计数当计数到9时确认LED4短暂亮起切换upd0验证递减功能边界测试在计数到9时快速切换方向测试使能信号en的实时响应4. 高级优化技巧4.1 时钟去抖动处理机械按键会产生抖动添加如下消抖模块module debounce ( input clk, input btn_in, output reg btn_out ); reg [19:0] counter; always (posedge clk) begin if (btn_in ! btn_out) counter counter 1; else counter 0; if (counter) btn_out btn_in; end endmodule参数调整20位计数器约实现20ms消抖50MHz时钟对rst、en、load等关键信号都应进行消抖4.2 可视化改进将二进制输出转换为七段数码管显示module bin2seg ( input [3:0] bin, output reg [6:0] seg ); always (*) begin case (bin) 4d0: seg 7b1000000; 4d1: seg 7b1111001; // ... 2-8省略 4d9: seg 7b0010000; default: seg 7b1111111; endcase end endmodule4.3 资源优化报告编译后查看Quartus的Flow Summary资源类型使用量总量利用率Logic Elements2862720.45%Registers8--Memory Bits0276K0%优化空间如果不需要预置功能可节省约30%逻辑资源共享消抖计数器可减少硬件开销5. 教学延伸与实践尝试给计数器添加这些扩展功能自动方向切换当检测到上下限时自动反转计数方向速度调节通过PLL生成不同频率的计数时钟预设记忆用FPGA的嵌入式存储器保存多个预置值调试时遇到计数异常可以检查仿真波形确认逻辑正确性用SignalTap II抓取实际信号逐步降低时钟频率定位时序问题

相关文章:

用FPGA复刻经典数电实验:手把手教你实现一个带预置功能的十进制可逆计数器

用FPGA复刻经典数电实验:手把手教你实现一个带预置功能的十进制可逆计数器 记得大学时第一次在实验箱上搭建十进制计数器,看着LED灯随着时钟信号跳动的那种兴奋感吗?如今,一块FPGA开发板就能重现这份经典体验,还能赋予…...

从CT扫描到雷达成像:一文讲透后向投影(BP)算法的前世今生与核心思想

从CT扫描到雷达成像:后向投影算法的跨学科智慧 1971年,英国工程师Godfrey Hounsfield发明了第一台医用CT扫描仪时,或许没想到这项技术会彻底改变医学诊断方式,更不会预料到它启发了另一种完全不同的成像技术——合成孔径雷达&…...

保姆级教程:在Ubuntu 20.04上为RISC-V芯片编译运行CoreMark(含多线程配置)

RISC-V平台CoreMark性能测试全流程实战指南 在嵌入式开发领域,处理器性能评估始终是硬件选型和系统优化的关键环节。CoreMark作为当前最权威的嵌入式CPU基准测试工具,其测试结果已成为衡量RISC-V处理器性能的黄金标准。本文将完整演示如何在Ubuntu 20.04…...

FPGA——AXI4总线实战:从协议解析到高效设计

1. AXI4总线协议基础解析 第一次接触AXI4总线时,我被它复杂的信号列表吓到了。但真正理解后发现,这套协议设计得非常精妙。AXI4(Advanced eXtensible Interface)是ARM公司推出的第三代AMBA总线标准,现在已经成为FPGA设…...

FPGA设计中的AXI4总线:从协议解析到高效接口设计实战

1. AXI4总线协议基础解析 第一次接触AXI4总线时,我被它那复杂的信号列表吓到了。但真正理解后才发现,这套协议设计得相当精妙。AXI4(Advanced eXtensible Interface)是ARM公司推出的第四代AMBA总线标准,现在已经成为FP…...

工业喷涂加工工艺详解及常见质量问题解决方案

摘要工业喷涂加工是金属件、五金件、设备外壳表面防护与装饰的核心工序,其工艺规范性直接决定工件使用寿命与外观质感。本文详细解析上海地区主流喷涂工艺(粉末喷涂、喷漆、水性漆喷涂)的核心流程、技术参数,结合行业实操经验&…...

DataX实战:用querySql搞定多表关联同步,别再傻傻分表导入了

DataX高级实战:querySql在多表关联同步中的深度应用 引言 在数据集成领域,ETL工程师经常面临一个经典难题:如何高效处理多表关联的数据同步任务?传统做法往往需要先分表导出再关联处理,不仅效率低下,还增加…...

告别评估版限制:手把手教你用注册机激活Keil5 MDK(STM32开发环境搭建)

突破Keil5 MDK评估版限制的完整解决方案 在嵌入式开发领域,Keil MDK作为ARM处理器的主流开发环境,其评估版对代码大小的限制常常让开发者感到束手束脚。当你精心编写的STM32程序超过32KB时,那个刺眼的编译错误提示就像一堵无形的墙&#xff0…...

5分钟掌握歌词滚动姬:免费开源的LRC歌词制作终极指南

5分钟掌握歌词滚动姬:免费开源的LRC歌词制作终极指南 【免费下载链接】lrc-maker 歌词滚动姬|可能是你所能见到的最好用的歌词制作工具 项目地址: https://gitcode.com/gh_mirrors/lr/lrc-maker 你是否曾经为了给心爱的歌曲制作精准的LRC歌词而烦…...

上海会场 | 5-6月学术会议征稿通知

6场会议覆盖图像处理、城市规划、半导体通信、风险管理、低碳能源与区块链经济 5月上海会议 第三届环境工程、城市规划与设计国际学术会议(EEUPD 2026) 开会时间:2026年5月8日-10日 会议亮点:环境工程、城市规划与设计同场讨论…...

【IEEE出版、中南大学主办】第七届计算机视觉、图像与深度学习国际学术会议(CVIDL 2026)

第七届计算机视觉、图像与深度学习国际学术会议(CVIDL 2026)定于2026年5月22-24日在中国 长沙隆重举行。会议旨在为从事计算机视觉、图像与深度学习研究的专家学者、工程技术人员、技术研发人员提供一个共享科研成果和前沿技术,了解学术发展…...

S7-1200PLC高级语言SCL数控G代码功能块源文件:解析与实现

S7-1200PLC 高级语言SCL数控G代码功能块源文件| S7-1200PLC 高级语言SCL数控G代码功能块源文件| S7-1200PLC 高级语言SCL数控G代码功能块源文件||| 整个G代码解析的程序做成了一个FB功能块,利用1200PLC内置的字符串控制指令来实现拆分提取字符串信息;整个程序的大概思路就是1.解…...

别再用默认值了!手把手教你调好STM32 MCSDK的电流环PI参数(附计算实例)

别再用默认值了!手把手教你调好STM32 MCSDK的电流环PI参数(附计算实例) 在电机控制领域,PI参数的整定一直是工程师们绕不开的话题。当你使用ST的MCSDK搭建好电机控制框架后,系统会自动生成一套默认的PI参数。这些参数确…...

2026奇点大会唯一认证的AI摘要合规框架(ISO/IEC 5055-AI Level 3),你的团队达标了吗?

第一章:2026奇点智能技术大会:AI代码摘要 2026奇点智能技术大会(https://ml-summit.org) 核心发布:CodeLens-7模型架构 大会首次开源轻量级AI代码摘要模型CodeLens-7,专为多语言函数级语义压缩设计。该模型支持Python、Go、Rust…...

WiMAX 802.16d技术架构与宽带部署实践

1. WiMAX 802.16d技术架构解析WiMAX 802.16d标准采用正交频分复用(OFDM)作为核心技术,通过将高速数据流分割为多个低速子载波传输,有效对抗多径干扰。其物理层支持256点FFT变换,每个子载波可独立选择BPSK、QPSK、16QAM…...

全志V3s荔枝派Zero新手避坑指南:三大开发环境(Camdriod/主线Uboot)怎么选?

全志V3s荔枝派Zero开发环境全景对比:从Camdriod到主线Linux的实战选择 第一次拿到荔枝派Zero开发板时,那种兴奋和迷茫交织的感觉至今记忆犹新。作为一款基于全志V3s芯片的经典开发板,它小巧的身躯里蕴含着强大的多媒体处理能力,但…...

MagiskOnWSALocal终极指南:5分钟打造完整Android环境的Windows子系统

MagiskOnWSALocal终极指南:5分钟打造完整Android环境的Windows子系统 【免费下载链接】MagiskOnWSALocal Integrate Magisk root and Google Apps into WSA (Windows Subsystem for Android) 项目地址: https://gitcode.com/gh_mirrors/ma/MagiskOnWSALocal …...

别再只调占空比了!舵机脉冲频率从50Hz到600Hz,实测告诉你哪些频率会让舵机‘罢工’

舵机控制进阶指南:突破50Hz限制的频率优化实战 第一次用Arduino控制舵机时,我也以为只要调准1ms到2ms的脉宽就够了。直到在机器人比赛现场,亲眼看到价值上万的机械臂因为频率设置不当而"跳机械舞"——那一刻才明白,舵机…...

从CCF A类清单看计算机学科前沿:如何选择你的学术发表阵地

1. CCF A类清单:计算机学术圈的"米其林指南" 第一次看到CCF A类清单时,我正为博士开题选方向发愁。导师甩给我这份列表说:"这就是计算机学界的米其林三星榜单,发一篇能顶三篇普通论文。"后来我才理解&#x…...

AMD Ryzen处理器终极调试指南:免费开源工具释放硬件全部潜能

AMD Ryzen处理器终极调试指南:免费开源工具释放硬件全部潜能 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: http…...

微信聊天记录导出工具:如何安全备份你的数字记忆

微信聊天记录导出工具:如何安全备份你的数字记忆 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 你是否曾经担心过,那些承载着珍贵回忆的微信聊天…...

SurveyKing开源问卷系统部署配置教程:从零搭建企业级调查平台

SurveyKing开源问卷系统部署配置教程:从零搭建企业级调查平台 【免费下载链接】SurveyKing One command to deploy a more powerful, self‑hosted alternative to SurveyMonkey. 项目地址: https://gitcode.com/gh_mirrors/su/SurveyKing SurveyKing是一款功…...

mysql高频触发器降低SQL执行效率_优化触发器逻辑或改用存储过程

触发器中避免嵌套多条DML、跨库查询和无索引SELECT,优先用ON DUPLICATE KEY UPDATE合并操作;存储过程须显式事务控制与错误处理;权限配置需指定低权限DEFINER并确保必要授权。触发器里写 UPDATE/INSERT 太多,SQL 执行变慢MySQL 触…...

SITS2026圆桌闭门纪要首度公开(含未删减技术分歧与路线图投票原始数据)

第一章:SITS2026圆桌:智能代码生成未来 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026圆桌论坛中,来自GitHub Copilot、Tabnine、CodeWhisperer及开源社区代表的工程师与AI语言模型研究者共同探讨了智能代码生成从“辅助补全”迈…...

STM32 CubeMX配置BMP280(I2C/SPI)避坑指南:从HAL库驱动到数据校准全流程

STM32 CubeMX配置BMP280(I2C/SPI)避坑指南:从HAL库驱动到数据校准全流程 第一次用STM32 CubeMX配置BMP280气压传感器时,我盯着屏幕上跳出的I2C错误标志发呆了半小时——明明按照手册一步步操作,为什么连最基本的通信都…...

神经符号AI:结合逻辑与学习的智能体

神经符号AI:结合逻辑与学习的智能体 一、 引言 (Introduction) 1.1 钩子 (The Hook):当GPT遇到“脑筋急转弯” 想象一下,你正在和当今最强大的语言模型GPT-4对话。你问它:“一个房间里有3个人,然后走进去2只狗,每个人都有1顶帽子,每只狗有4条腿。请问房间里现在有多少…...

【下一代编程范式倒计时】:SITS2026披露3项即将开源的智能生成协议(仅限首批注册开发者提前72小时获取)

第一章:SITS2026圆桌:智能代码生成未来 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026圆桌论坛上,来自GitHub、Tabnine、DeepMind与国内大模型实验室的七位核心研发者共同探讨了智能代码生成从“补全助手”迈向“协同编程伙伴”…...

从状态机到中断:深入解析NRF52832 ESB库的通信流程与调试技巧

从状态机到中断:深入解析NRF52832 ESB库的通信流程与调试技巧 在嵌入式无线通信领域,NRF52832凭借其强大的射频性能和灵活的协议栈支持,成为众多物联网设备的首选方案。其中Enhanced ShockBurst(ESB)协议作为与经典NRF24L01兼容的核心通信机…...

Bootstrap 5中浮动标签(Floating Labels)怎么用?

label必须置于input后且input需含placeholder,否则浮动失效;select无真正浮动动画,textarea正常;form-control类不可少;::placeholder样式需同步调整以避免视觉断裂。label 必须放在 input 后面,且 input 必…...

TI DP83822I PHY芯片Strap配置避坑指南:电阻计算与CPU引脚干扰分析

DP83822I PHY芯片Strap配置实战:电阻计算与系统级干扰排查手册 在以太网硬件设计中,PHY芯片的strap配置往往是决定系统能否正常工作的关键因素之一。TI的DP83822I作为一款高性价比的10/100M以太网PHY芯片,其strap引脚配置机制既提供了设计灵活…...