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

阿里云 ip 网站wordpress搜索表单

阿里云 ip 网站,wordpress搜索表单,网站上的美工图片要怎么做,企业宣传片模板目录 一、项目需求分析 二、硬件平台介绍 消抖方法 三、核心代码解释 3.1.在vscode中按照以下框架创建文件夹并书写代码: 3.2.顶层设计: 3.3.模块交互: 3.4.各模块代码: 顶层模块top: 时钟分频模块clk_divid…

目录

一、项目需求分析

二、硬件平台介绍 

消抖方法

三、核心代码解释

3.1.在vscode中按照以下框架创建文件夹并书写代码:

3.2.顶层设计:

3.3.模块交互:

3.4.各模块代码:

顶层模块top:

时钟分频模块clk_divider

按键模块 key_debounce

边沿检测模块edge_detect

计数器模块min_sec_counter

三、操作及步骤设计步骤:

四、结果展示:

五、总结


引言:

一、项目需求分析

我们要实现的分秒计数器需要具备以下功能:

  • 基本计时功能:显示 00:00 到 59:59 的分秒计时
  • 暂停控制:通过按键实现计时的启动与暂停
  • 按键消抖:处理机械按键的抖动问题,确保输入稳定
  • 显示输出:通过开发板的七段数码管显示计时结果

二、硬件平台介绍 

  • 硬件平台介绍
  • DE2-115 开发板是 Altera(现 Intel)推出的一款高性能 FPGA 开发平台,其核心为 Cyclone IV EP4CE115F29C7N FPGA 芯片,板载资源丰富,包括:

  • 10 个独立按键(KEY0-KEY9)
  • 8 个七段数码管(HEX0-HEX7)
  • 50MHz 系统时钟

 按键消抖原理与实现

在设计计数器之前,我们需要先解决按键消抖问题。机械按键在按下和释放时会产生电信号抖动,持续时间通常为 5-20ms,如果不处理会导致一次按键被误识别为多次输入。

消抖方法

常用的按键消抖方法有:

  • 硬件消抖:通过 RC 滤波电路或专用消抖芯片实现
  • 软件消抖:通过 FPGA 内部逻辑延时判断实现

本项目采用软件消抖方案,其原理是:当检测到按键状态变化时,启动一个计数器,当计数器计满规定时间(如 20ms)后再次检测按键状态,如果状态与初始检测一致,则认为是有效按键。

三、核心代码解释

3.1.在vscode中按照以下框架创建文件夹并书写代码:

3.2.顶层设计:

顶层模块(top)
├── 按键消抖模块(key_debounce)
├── 边沿检测模块(edge_detect)
├── 时钟分频模块(clk_divider)
├── 分秒计数器(min_sec_counter)
└── 七段译码器(seg7_decoder)
 

3.3.模块交互:

CLK(50MHz) → 分频 → 1Hz时钟 → 计时模块
KEY → 消抖模块 → 暂停控制 → 计时模块
计时输出 → 数码管显示模块 → 物理数码管
 

3.4.各模块代码:

顶层模块top:
module top(input CLOCK_50,         // 50MHz时钟(PIN_Y2)input KEY0,             // 复位input KEY1,             // 暂停output [0:6] HEX7, HEX6,// 分十位、分个位output [0:6] HEX5, HEX4 // 秒十位、秒个位
);wire clk_1hz;               // 1Hz时钟信号
wire key_stable;            // 消抖后按键信号
wire pause_trigger;         // 边沿检测信号
reg pause_state = 1'b0;     // 暂停状态寄存器wire [3:0] min_tens, min_ones;
wire [3:0] sec_tens, sec_ones;// 按键消抖模块(20ms消抖)
key_debounce #(.DEBOUNCE_MS(20)) debounce_inst(.clk(CLOCK_50),.button_in(~KEY1),.button_out(key_stable)
);// 边沿检测模块
edge_detect edge_inst(.clk(CLOCK_50),.signal_in(key_stable),.edge_out(pause_trigger)
);// 时钟分频模块
clk_divider clk_div_inst(.clk(CLOCK_50),.reset(~KEY0),.pause(pause_state),.clk_out(clk_1hz)
);// 分秒计数器
min_sec_counter counter(.clk(clk_1hz),.reset(~KEY0),.min_tens(min_tens),.min_ones(min_ones),.sec_tens(sec_tens),.sec_ones(sec_ones)
);// 显示译码模块
seg7_decoder hex7(.bcd(min_tens), .seg(HEX7));
seg7_decoder hex6(.bcd(min_ones), .seg(HEX6));
seg7_decoder hex5(.bcd(sec_tens), .seg(HEX5));
seg7_decoder hex4(.bcd(sec_ones), .seg(HEX4));// 暂停状态机
always @(posedge CLOCK_50 or posedge ~KEY0) beginif (~KEY0) pause_state <= 1'b0;else if (pause_trigger) pause_state <= ~pause_state;
endendmodule
时钟分频模块clk_divider

上次实验提到过:DE2-115开发板配备了一个固定的时钟源。该开发板内置了一个50MHz的晶振,因此对于50MHz的时钟频率,时钟周期为20ns。

module clk_divider(input clk,input reset,input pause,output reg clk_out
);parameter DIV_FACTOR = 26'd49_999_999; // 50MHz→1Hzreg [25:0] cnt;always @(posedge clk or posedge reset) beginif (reset) begincnt <= 0;clk_out <= 0;end else if (!pause) begincnt <= (cnt == DIV_FACTOR) ? 0 : cnt + 1;if (cnt == DIV_FACTOR) clk_out <= ~clk_out;endend
endmodule
按键模块 key_debounce

我选择KEY0做为复位按钮,KEY1作为控制分秒计数器的暂停按钮

module key_debounce #(parameter DEBOUNCE_MS = 20  // 可配置消抖时间
)(input clk,input button_in,output reg button_out
);localparam MAX_COUNT = 50_000_000 * DEBOUNCE_MS / 1000;reg [23:0] cnt;always @(posedge clk) beginif (button_in != button_out) begincnt <= (cnt == MAX_COUNT-1) ? 0 : cnt + 1;if (cnt == MAX_COUNT-1) button_out <= button_in;end else begincnt <= 0;endend
endmodule
边沿检测模块edge_detect
module edge_detect(input clk,input signal_in,output reg edge_out
);reg signal_delay;always @(posedge clk) beginsignal_delay <= signal_in;edge_out <= signal_in & ~signal_delay; // 上升沿检测end
endmodule
计数器模块min_sec_counter
module min_sec_counter(input clk,input reset,output reg [3:0] min_tens,output reg [3:0] min_ones,output reg [3:0] sec_tens,output reg [3:0] sec_ones
);// 秒计数器always @(posedge clk or posedge reset) beginif (reset) beginsec_ones <= 4'd0;sec_tens <= 4'd0;end else beginif (sec_ones == 4'd9) beginsec_ones <= 4'd0;sec_tens <= (sec_tens == 4'd5) ? 4'd0 : sec_tens + 1;end else beginsec_ones <= sec_ones + 1;endendend// 分钟计数器always @(posedge clk or posedge reset) beginif (reset) beginmin_ones <= 4'd0;min_tens <= 4'd0;end else if (sec_tens == 4'd5 && sec_ones == 4'd9) beginif (min_ones == 4'd9) beginmin_ones <= 4'd0;min_tens <= (min_tens == 4'd5) ? 4'd0 : min_tens + 1;end else beginmin_ones <= min_ones + 1;endendend
endmodule

数码管模块seg7_decoder
之前提及到过,可以利用38译码器点亮7段数码管(其实只需要7段译码器即可),但是我们的输入情况有9种,所以七段译码器需要将4位BCD码转换为对应的段码;也说过数码管的点亮逻辑:FPGA输出低电压的时候,对应的字码段点亮,反之则熄灭

进行分秒展示,一共要用到4个数码管,为了更直观展示我选择:HEX7,HEX6作为分钟位,HEX5,HEX4做为秒位

module seg7_decoder(input [3:0] bcd,output reg [6:0] seg
);always @(*) begincase(bcd)4'd0 : seg = 7'b0000_001; // 04'd1 : seg = 7'b1001_111; // 14'd2 : seg = 7'b0010_010; // 24'd3 : seg = 7'b0000_110; // 34'd4 : seg = 7'b1001_100; // 44'd5 : seg = 7'b0100_100; // 54'd6 : seg = 7'b0100_000; // 64'd7 : seg = 7'b0001_111; // 74'd8 : seg = 7'b0000_000; // 84'd9 : seg = 7'b0001_000; // 9default: seg = 7'b1111_111; // 灭endcaseend
endmodule

三、操作及步骤设计步骤:

1.在vscode中按照以下框架创建文件夹并书写代码:

创建项目,选择芯片:

EP4CE115F29C7

由于有多个文件,需要把top文件设置为顶层文件:

引脚配置:

四、结果展示:

视频演示:

FPGA分秒计时器

五、总结

学习了分模块设计,实现了分秒计数器,FPGA渐入佳境。如文章有不妥之处,还望各位海涵。

参考文献:

[FGPA基础学习]分秒计数器的制作-CSDN博客


文章转载自:

http://U0PuSvvJ.nyjgm.cn
http://98bpmYOM.nyjgm.cn
http://yIGE5ocR.nyjgm.cn
http://6CrBhXo6.nyjgm.cn
http://1vzM9AwV.nyjgm.cn
http://VaQWenub.nyjgm.cn
http://DYnemK86.nyjgm.cn
http://H4O7RX2N.nyjgm.cn
http://OovPFaDL.nyjgm.cn
http://1kuIn76p.nyjgm.cn
http://D1J0EDwq.nyjgm.cn
http://cD67JK9R.nyjgm.cn
http://5uFRNGjy.nyjgm.cn
http://UywYMaM2.nyjgm.cn
http://UMBfpybW.nyjgm.cn
http://q7UJDUFf.nyjgm.cn
http://UQPP73Gg.nyjgm.cn
http://BZTWwj79.nyjgm.cn
http://nevmJkww.nyjgm.cn
http://N7UhRH4v.nyjgm.cn
http://BAawVWSb.nyjgm.cn
http://ReObv0mg.nyjgm.cn
http://qflZkcH0.nyjgm.cn
http://qDJbZqfK.nyjgm.cn
http://pTRRtJey.nyjgm.cn
http://BWMYLZw9.nyjgm.cn
http://3mFRprOg.nyjgm.cn
http://9iUqMlGQ.nyjgm.cn
http://kg9Uvm8T.nyjgm.cn
http://LdqrbHDS.nyjgm.cn
http://www.dtcms.com/wzjs/687905.html

相关文章:

  • 湖南英文网站建设企业网站的建设的目标人物是
  • 建设网站要多久到账免费的seo教程
  • 上海家装设计网站网页设计与制作步骤流程
  • 品牌网站建设小蝌蚪1返佣网站都是自己做的
  • 仿视频网站开发智能小程序开发
  • 如何建小企业网站深圳网络推广工资
  • 邯郸做网站的公司建设公司是什么意思
  • iis网站asp.net部署wordpress菜单页面跳转
  • 石家庄免费网站建设腾讯的wordpress怎么样
  • 广西省建设注册管理网站公司注册域名需要哪些条件
  • 网上商城网站开发公司如何做赚钱的网站
  • 电子商务网站开发的任务书我局 负责 建设 网站
  • 长沙网站建设260ewordpress在线
  • 网站前端设计培训黄石网站网站建设
  • dw做网站首页长宽设置多少腾讯云主机
  • 好看的ui网站页面设计有找专业做淘宝网站的美工
  • 电商网站建设的现实意义是什么主题公园网站建设
  • 百度收录检测如何优化网站标题
  • 网站建设中标公告如何使用云服务建设网站
  • 大连科技学院官方网站的建设与放店铺logo在线免费制作
  • 福州网站制作有限公司网站开发报价单
  • 做网站的网站赚钱吗外发加工会计分录
  • 德兴市网站建设服务公司成都seo培训班
  • 毕业设计可以做自己的网站吗住房和城乡建设岗位证书
  • 长垣做网站两学一做教育纪实评价系统网站
  • 室内装饰设计师证书seo推广营销网站
  • 安全认证的机票网站成就怎么做装修设计案例网站
  • 做asp网站教程wordpress 目录样式
  • 搭建网站要不要给域名对方wordpress 手机首页设置
  • 建设专业网站电话咨询珠海网站建设网