数电实验中设计数字钟所用到的代码详细版(Verilog语言来实现)

本文主要是介绍数电实验中设计数字钟所用到的代码详细版(Verilog语言来实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、模6计数器的代码:
  • 二、模10计数器的代码
  • 三、模60计数器的代码
  • 四、模24计数器的代码
  • 五、显示控制电路模块代码
  • 六、1khz和250khz时钟输出实现的代码
  • 七、数字钟的实现代码
  • 八、引脚设置:
  • 总结


前言

提示:这里可以添加本文要记录的大概内容:
这里主要展现实现数字钟的重要步骤的代码,有需求者自取。我们利用的是quartus II软件来实现。

一、模6计数器的代码:

module counter6(
input clk,rstn,ce,
output reg[3:0]counter6,
output tc6);assign tc6=(counter6==4'd5);
always @(posedge clk)
beginif(!rstn)counter6 = 4'd0;else if(~ce)counter6<=counter6;else if(counter6>=4'd5)counter6<=4'd0;elsecounter6<=counter6+1'b1; 
end 
endmodule 

仿真:
在这里插入图片描述

二、模10计数器的代码


module counter10(
input clk,rstn,ce,
output reg[3:0]counter10,
output tc10);assign tc10=(counter10==4'd9);
always @(posedge clk)
beginif(!rstn)counter10 = 4'd0;else if(~ce)counter10<=counter10;else if(counter10>=4'd9)counter10<=4'd0;elsecounter10<=counter10+1'b1; 
end 
endmodule 

仿真:
在这里插入图片描述

三、模60计数器的代码

这里需要调用上面模6和模10模块,故而应该将他们放到同一个工程下。

module counter60(
input clk,rstn,ce,
output [7:0]counter60,
output tc60);
wire tc10,tc6;
wire ce1;
counter6 u1(
.clk(clk),
.rstn(rstn),
.ce(ce1),
.counter6(counter60[7:4]),
.tc6(tc6));counter10 u2(
.clk(clk),
.rstn(rstn),
.ce(ce),
.counter10(counter60[3:0]),
.tc10(tc10));assign ce1=(counter60[3:0]==4'h9)&ce;//29的时候能保持
assign tc60=(tc10&tc6);
endmodule 

仿真:
在这里插入图片描述

四、模24计数器的代码

这里也需要调用模10和模6的模块,应该将他们放到同一个工程下面

module counter60(
input clk,rstn,ce,
output [7:0]counter60,
output tc60);
wire tc10,tc6;
wire ce1;
counter6 u1(
.clk(clk),
.rstn(rstn),
.ce(ce1),
.counter6(counter60[7:4]),
.tc6(tc6));counter10 u2(
.clk(clk),
.rstn(rstn),
.ce(ce),
.counter10(counter60[3:0]),
.tc10(tc10));assign ce1=(counter60[3:0]==4'h9)&ce;//29的时候能保持
assign tc60=(tc10&tc6);
endmodule 

仿真:
在这里插入图片描述

五、显示控制电路模块代码

module segdis(
input clk,rstn,
input [3:0]dig6,dig5,dig4,dig3,dig2,dig1,
output reg[6:0]dig_out,
output reg[5:0]dig_cs);
always@(posedge clk)
begin 
if(!rstn)dig_cs  <= 6'b111110;
else 	    dig_cs <= {dig_cs[4:0],dig_cs[5]};
end 
reg [3:0]dig_num;
always@(*)begin
case(dig_cs)
6'b111110:dig_num<=dig1;
6'b111101:dig_num<=dig2;
6'b111011:dig_num<=dig3;
6'b110111:dig_num<=dig4;
6'b101111:dig_num<=dig5;
6'b011111:dig_num<=dig6;
default:  dig_num<=dig6;
endcase
end 
always@(*)begin
case(dig_num)
4'd0:dig_out=7'b111_1110;
4'd1:dig_out=7'b011_0000;
4'd2:dig_out=7'b110_1101;
4'd3:dig_out=7'b111_1001;
4'd4:dig_out=7'b011_0011;
4'd5:dig_out=7'b101_1011;
4'd6:dig_out=7'b001_1111;
4'd7:dig_out=7'b111_0000;
4'd8:dig_out=7'b111_1111;
4'd9:dig_out=7'b111_1011;
default:dig_out=7'b111_1011;
endcase
end
//1 clk dig_cs
// mux dig6-dig1==>dig
//显示译码
endmodule 

六、1khz和250khz时钟输出实现的代码

  • 1khz:
module clock_div_1hz(
input clk,rstn,
output reg clk1hz);
reg [25:0] cnt1hz;always@(posedge clk)begin 
if(~rstn)begin cnt1hz <=26'd0;clk1hz <=1'b1;end
else if(cnt1hz>=26'd24999999)begin cnt1hz <=26'd0;clk1hz <= ~clk1hz;end
else begincnt1hz <=cnt1hz +1'b1;clk1hz <=clk1hz;end
end 
endmodule 
  • 250khz:
module clock_div_1hz(
input clk,rstn,
output reg clk1hz);
reg [25:0] cnt1hz;always@(posedge clk)begin 
if(~rstn)begin cnt1hz <=26'd0;clk1hz <=1'b1;end
else if(cnt1hz>=26'd24999999)begin cnt1hz <=26'd0;clk1hz <= ~clk1hz;end
else begincnt1hz <=cnt1hz +1'b1;clk1hz <=clk1hz;end
end 
endmodule 

七、数字钟的实现代码

这里需要调用前面的模24,模60,显示模块,1KHZ,250KHZ模块一块实现

module top(
input clk,rstn,en,
output [6:0]dig_out,
output [5:0]dig_cs);wire clk1;
wire clk2;
wire [7:0]counter24;
wire [7:0]counter60m;
wire [7:0]counter60s;
wire en1;
wire en2;
wire tc60s;
wire tc60m;
clock_div_250k u1(
.clk(clk),.rstn(rstn),.clk250khz(clk1));counter24 u3(
.clk(clk2),
.rstn(rstn),
.ce(en2),
.counter24(counter24));clock_div_1hz u4(
.clk(clk),
.rstn(rstn),
.clk1hz(clk2));
counter60 u5(.clk(clk2),
.rstn(rstn),
.ce(en1),
.counter60(counter60m),
.tc60(tc60m));
counter60 u6(.clk(clk2),
.rstn(rstn),
.ce(en),
.counter60(counter60s),
.tc60(tc60s));
segdis u2(
.clk(clk1),.rstn(rstn),.dig6(counter24[7:4]),.dig5(counter24[3:0]),.dig4(counter60m[7:4]),.dig3(counter60m[3:0]),
.dig2(counter60s[7:4]),.dig1(counter60s[3:0]),.dig_out(dig_out),.dig_cs(dig_cs));
assign en1=tc60s&en;
assign en2=tc60s&tc60m&en;endmodule 

八、引脚设置:

在这里插入图片描述

总结

本文主要展现了实现数字钟模块的几步重要代码,有需要者自取。

这篇关于数电实验中设计数字钟所用到的代码详细版(Verilog语言来实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1034565

相关文章

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Goland debug失效详细解决步骤(合集)

《Golanddebug失效详细解决步骤(合集)》今天用Goland开发时,打断点,以debug方式运行,发现程序并没有断住,程序跳过了断点,直接运行结束,网上搜寻了大量文章,最后得以解决,特此在这... 目录Bug:Goland debug失效详细解决步骤【合集】情况一:Go或Goland架构不对情况二: