【【萌新的FPGA学习之按键控制LED实验】】

news2025/1/11 23:00:44

按键控制LED实验

在写这篇文章之前我必须对我的错误表示深刻的道歉
因为我之前的文章自己也是边看边学给大家带来了大的困扰
抱歉抱歉
我们这里讲述一下综合和仿真的关系
其实我们更多的是应该关注仿真下得到的波形情况 然后分析
对于综合,综合的最大的目的还是看功耗,面积使用效率等问题 。而对于网表 我以前看的太重要了 该该放下了
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

本节实验任务是使用底板上的 PL_KEY0 和 PL_KEY1 按键来控制底板上的 PL_LED0 和 PL_LED1 两
个 LED 闪烁。没有按键被按下时,两个 LED 保持常灭;如果按键 PL_KEY0 被按下,则两个 LED 交替闪
烁;如果按键 PL_KEY1 被按下,则两个 LED 同时闪烁。
在这里插入图片描述
在这里插入图片描述

根据上面的流水灯的案例我们知道当我们给灯的输出口高电平时点亮LED 0 就是灭

这次实验我们使用的是当我们按下按键的时候才会进行模式的各种变化 虽然我还没有往下品读 但是我大胆的猜测应该不会在这么靠前的地方就讲述按键消抖的原理吧 毕竟按键消抖挺麻烦的 所以这里的设计只是长按
我们在此处设计的方向是 按键设置为低电平有效,好处自己想
而对于灯的控制,我们设置为1为亮 0为灭
长按 KEY0 按键时,key 信号值为 2’b10,此时需要根据 LED 状态控制信号(led_flag)来判断 LED 灯
的状态。led_flag 为低电平时,给 LED 灯信号(led)赋值 2’b01,表示 LED0 灯亮,LED1 灯灭;led_flag 为
高电平时给 LED 灯赋值 2’b10,表示 LED0 灯灭,LED1 灯亮。长按 KEY0 按键,随着 led_flag 信号的翻转,
LED 在 2’b01 与 2’b10 之间交替变化,实物观察的现象就是两个 LED 灯交替闪烁了。
长按 KEY1 按键时,key 信号值为 2’b01,此时需要根据 LED 状态控制信号(led_flag)来判断 LED 灯
的状态。led_flag 为低电平时,给 LED 灯信号(led)赋值 2’b11,表示 LED0 与 LED1 都亮灯;led_flag 为
高电平时给 LED 灯赋值 2’b00,表示 LED0 与 LED1 都灭灯。长按 KEY1 按键,随着 led_flag 信号的翻转,
LED 在 2’b11 与 2’b00 之间交替变化,实物观察的现象就是两个 LED 灯同时闪烁了。
因为对于整个时序的变化其实只有两种,相互交错的跳跃 所以在此处我们引入了一个局内的变量用来控制这两种不同的状态

下面讲述一下代码的基本逻辑
对于整个逻辑思考能力很有帮助 因为电路是并行结构
我们观察可以将电路剖析成3部分
第一部分 因为我们要用系统时钟
所以我们设置一个随着时间而动的计数器 计数25000000次 正好是0.5s
然后我们再根据我们的功能
第二段
因为要求我们在摁下后功能持续变化 那么控制单元 就设置随着计数器的变化而变化
接下来第三段
在按键key 下case if(led_flag)就行
下面是代码详解

module key_led(
 input sys_clk , //系统时钟
 input sys_rst_n , //系统复位,低电平有效

input [1:0] key , //按键
output reg [1:0] led //LED 灯
);

//parameter define
 parameter CNT_MAX = 25'd2500_0000; //LED 灯闪烁频率

 //reg define
 reg [24:0] cnt; //计数器
 reg led_flag; //LED 控制信号

 //*****************************************************
 //** main code
 //*****************************************************

 //计数器计时 0.5s
 always @(posedge sys_clk or negedge sys_rst_n) begin
 if(!sys_rst_n)
 cnt <= 25'd0;
 else if(cnt < (CNT_MAX - 25'd1))
 cnt <= cnt + 25'd1;
 else
 cnt <= 25'd0;
 end

 //每隔 500ms 就更改 LED 的闪烁状态
 always @ (posedge sys_clk or negedge sys_rst_n) begin
 if(!sys_rst_n)
 led_flag <= 1'b0;
 else if(cnt == (CNT_MAX - 25'd1))
 led_flag <= ~led_flag;
 end

 //根据按键的状态以及 LED 的闪烁状态来赋值 LED
 always @ (posedge sys_clk or negedge sys_rst_n) begin
 if(!sys_rst_n)
 led <= 2'b00;
 else case(key)
 2'b10 : //如果按键 0 被按下,则两个 LED 交替闪烁
 if(led_flag == 1'b0)
led <= 2'b01;
else
led <= 2'b10;
 2'b01 : //如果按键 1 被按下,则两个 LED 同时亮灭交替
 if(led_flag == 1'b0)
 led <= 2'b11;
 else
 led <= 2'b00;
 2'b11 : //如果两个按键都未被按下,则两个 LED 都保持常灭
led <= 2'b00;
 default: ;
 endcase
 end

endmodule

下面讲述的是testbench

 `timescale 1ns / 1ns //仿真单位/仿真精度
 
 module tb_key_led();
 
//parameter define
 parameter CLK_PERIOD = 20; //时钟周期 20ns
 
 //reg define
 reg sys_clk;
 reg sys_rst_n;
 reg [1:0] key;
 //wire define
wire [1:0] led;
//信号初始化
 initial begin
 sys_clk <= 1'b0;
 sys_rst_n <= 1'b0;
 key <= 2'b11;
 #200
 sys_rst_n <= 1'b1;
 //key 信号变化
 #200
 key <= 2'b11; //两个 PL 按键都未被按下
 #1000
 key <= 2'b10; //按下按键 0
 #2000
 key <= 2'b11; //两个 PL 按键都未被按下
 #1000
 key <= 2'b01; //按下按键 1
 end

 //产生时钟
 always #(CLK_PERIOD/2) sys_clk = ~sys_clk;

//例化待测设计
 key_led u_key_led(
 .sys_clk (sys_clk),
 .sys_rst_n (sys_rst_n),
 .key (key),
 .led (led)
 );

endmodule

评价是很简单

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

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

相关文章

计算机等级考试—信息安全三级真题二

目录 一、单选题 二、填空题 三、综合题 一、单选题

数据结构的奇妙世界:实用算法与实际应用

文章目录 数据结构和算法的基本概念数据结构数组链表栈队列树图 算法 常见的数据结构和算法排序算法快速排序示例 数据结构的应用数据库管理系统图像处理网络路由 数据结构和算法的性能分析时间复杂度空间复杂度 如何更好地编写代码避免常见错误结论 &#x1f389;欢迎来到数据…

Qt地铁智慧换乘系统浅学( 三 )最少路径和最少换乘实现

本算法全都基于广度优先 概念最短路径实现所用容器算法思路 最少换乘实现所需容器算法思路 成果展示代码实现判断是最短路径还是最少换乘最短路径代码实现最少换乘代码实现根据所得List画出线路 ui界面的维护&#xff08;前提条件&#xff09;界面初始化combox控件建立槽函数 概…

把Eclipse整个文件夹添加到Microsoft Defender的排除项中

一.原因&#xff1a; Windows 10卫士显著降低了Eclipse的速度&#xff0c;原因是Windows 10卫士扫描JAR文件。这个问题已经报告给微软了。在此之前&#xff0c;解决此问题的一个方法是将Eclipse根目录添加到Windows 10 Defender的排除列表中&#xff0c;详细步骤在这里共享。 …

前端JavaScript入门到精通,javascript核心进阶ES6语法、API、js高级等基础知识和实战 —— JS基础(五)

接受自己原本的样子&#xff0c; 比努力扮演另一个轻松多了。 思维导图 对象 什么是对象 对象使用 遍历对象 索引号是字符串型&#xff0c;不推荐遍历数组。 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><me…

docker实现mysql主从复制(巨详细!!!)

docker实现mysql主从复制&#xff08;巨详细&#xff01;&#xff01;&#xff01;&#xff09; 新建主机服务容器实例3307进入/mydata/mysql-master/conf目录下新建my.cnf修改完配置后重启master实例进入mysql-master容器master容器实例内创建数据同步用户新建 服务器容器实例…

【论文阅读】内存数据库并发控制算法的实验研究

内存数据库并发控制算法的实验研究 原文链接jos.org.cn/jos/article/pdf/6454 摘要 并发控制算法的基本思想归纳为"先定序后检验”&#xff0c;基于该思想对现有各类并发控制算法进行 了重新描述和分类总结&#xff0c;于在开源内存型分布式事务测试床 3TS 上的实际对比实…

Tune-A-Video论文阅读

论文链接&#xff1a;Tune-A-Video: One-Shot Tuning of Image Diffusion Models for Text-to-Video Generation 文章目录 摘要引言相关工作文生图扩散模型文本到视频生成模型文本驱动的视频编辑从单个视频生成 方法前提DDPMsLDMs 网络膨胀微调和推理模型微调基于DDIM inversio…

动手学深度学习(pytorch版)第二章-2.3线性代数Note-linear-algebra

类型 标量&#xff1a;仅包含一个数值被称为标量 向量&#xff1a;向量可以被视为标量值组成的列表 矩阵&#xff1a;正如向量将标量从零阶推广到一阶&#xff0c;矩阵将向量从一阶推广到二阶。 A torch.arange(20).reshape(5, 4) A.T //转置 张量&#xff1a;是描述具有…

[36c3 2019]includer

[36c3 2019]includer 题目描述&#xff1a;Just sitting here and waiting for PHP 8.0 (lolphp). 首先来了解一下临时文件包含之PHP - compress.zlib:// 在 php-src 里可以找到和 compress.zlib:// 有关的代码 | code 注意到 STREAM_WILL_CAST&#xff0c;涉及到 cast 经常…

企业微信-通用开发参数回调设置

公司业务需要开发企业微信&#xff0c;注册三方服务商审核通过后&#xff0c; 开始配置开发信息。本篇中记录在调试url验证中遇到错误及解决方式。 目录 准备工作 下载php加解密库 下载文件说明 设置白名单 设置路径 参数说明 设置ip 回调处理 回调类型&#xff1a; …

【C++】布隆过滤器简单操纵模拟以及常见题目

&#x1f30f;博客主页&#xff1a; 主页 &#x1f516;系列专栏&#xff1a; C ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ &#x1f60d;期待与大家一起进步&#xff01; 文章目录 前言一、求下标仿函数的建议二、布隆过滤器代码面试题1.近似算法&#xff1a;2.精确算…

Leetcode 409. 最长回文串

文章目录 题目代码&#xff08;9.24 首刷自解&#xff09; 题目 Leetcode 409. 最长回文串 代码&#xff08;9.24 首刷自解&#xff09; class Solution { public:int longestPalindrome(string s) {unordered_map<char, int> mp;for(char c : s) mp[c];int res 0;int…

【算法思想-排序】排序数组-力扣 912 题

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…

nexus 私服 拉不了 jar 包,报 Not authorized

如果你排查了所有情况,并且确定账号密码都没问题,路径也正确,并且setting.xml都配置正确了 可以看下是不是这个原因

5、SpringBoot_热部署

六、热部署 1.热部署概述 概述&#xff1a;程序更改后&#xff0c;不需要重新启动服务器也能够实现动态更新 springboot 项目如何实现热部署&#xff1f; tomcat 已经内置到项目容器中了希望tomcat监听外部程序变化通过新建一个程序来监控你代码的变化 2.依赖导入 依赖 <…

2023蓝帽杯半决赛misc题目复现

后续会逐渐完善&#xff1a; misc--排排坐吃果果 我真是无大语了&#xff0c;对于我的死脑筋&#xff0c;文件一打开是一片白色&#xff0c;但是点开单元格会看到里面有数字&#xff0c;我想到了修改单元格的格式&#xff0c;就是没想到转换字体的颜色&#xff0c;对此我表示…

构建基于neo4j知识图谱、elasticsearch全文检索的数字知识库

前言&#xff1a; 在数字化时代&#xff0c;知识库的建设正逐渐成为企业、学术机构和个人的重要资产。本文将介绍如何使用neo4j和elasticsearch这两种强大的数据库技术来构建知识库&#xff0c;并对其进行比较和探讨。 技术栈&#xff1a; springbootvueneo4jelasticsearch…

map的一些测试-string键的查找

主要区别在于声明map的时候多了一个less<> #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> #include <map> #include <chrono> using namespace std; class spender { public:spender(string strfun) :strfun(strfun…

LeetCode算法二叉树—相同的树

目录 100. 相同的树 - 力扣&#xff08;LeetCode&#xff09; 代码&#xff1a; 运行结果&#xff1a; 给你两棵二叉树的根节点 p 和 q &#xff0c;编写一个函数来检验这两棵树是否相同。 如果两个树在结构上相同&#xff0c;并且节点具有相同的值&#xff0c;则认为它们是…