电子计时器Verilog代码远程云端平台Quartus

名称:电子计时器Verilog代码远程云端平台Quartus

软件:Quartus

语言:Verilog

代码功能:

电子计时器要求

同时可以用一个开关控制来记录三组时间并显示;

三组记录时间通过各自的开关可以控制其暂停和开始

数码管显示计时时间

本代码已在远程云端平台验证,远程云端平台如下,其他远程云端平台可以修改管脚适配:

远程平台照片.png

部分代码展示:

`timescale 1ns / 1ps
//
// Company: 
// Engineer: 
// 
// Create Date: 2020/01/04 22:08:34
// Design Name: 
// Module Name: single_timer
// Project Name: 
// Target Devices: 
// Tool Versions: 
// Description: 
// 
// Dependencies: 
// 
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
// 
//
module single_timer(
input clk_100HZ,
inputrst_n,
inputtime_ctrl,//高电平保持,低电平计数
outputreg [1:0]time_min_ge,//分钟个位
outputreg [3:0]time_sec_shi,//秒十位
outputreg [3:0]time_sec_ge,//秒个位
outputreg [3:0]time_msec_shi,//毫秒十位
outputreg [3:0]time_msec_ge//毫秒个位
    );
reg [1:0]min;
reg [5:0]sec;
reg [6:0]msec;
always@(posedge clk_100HZ or negedge rst_n)begin
if(!rst_n)begin
min<=0;
sec    <=0;
msec    <=0;
end
else begin
if(time_ctrl)begin//高电平保持,低电平计数
min<=min;
sec    <=sec    ;
msec    <=msec    ;
end
else begin
if(msec==99)begin//毫秒
msec<=0;
if(sec==59)begin//秒
sec<=0;
if(min==1)begin//分钟
min<=0;
end
else begin
min<=min+1;//分钟
end
end
else begin
sec<=sec+1;//秒
end
end
else begin
msec<=msec+1;//毫秒
end
end
end
end
always@(posedge clk_100HZ or negedge rst_n)begin
if(!rst_n)begin
time_min_ge<=0;
time_sec_shi<=0;
time_sec_ge<=0;
time_msec_shi<=0;
time_msec_ge<=0;
end
else begin
time_min_ge<=min;//分钟个位
time_sec_shi<=sec/10;//秒十位
time_sec_ge<=sec%10;//秒个位
time_msec_shi<=msec/10;//毫秒十位
time_msec_ge<=msec%10;//毫秒个位
end
end
endmodule

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值